/*
Theme Name: Sane Seven
Theme URI: https://www.saneseven.com
Author: Sane Seven
Description: Cinematic portfolio theme for Sane Seven — the artist making the visual record of women and power. Self-contained custom post types for Projects and Portraits, no plugins required.
Version: 1.0.3
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: saneseven
*/

:root{
  --ink:#14110F;
  --ink-raised:#1C1714;
  --ink-line:#2C2521;
  --paper:#F2ECE3;
  --paper-dim:#A89E92;
  --rose:#E2B0AA;
  --maxw:1280px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--ink);
  color:var(--paper);
  font-family:"Hanken Grotesk",system-ui,sans-serif;
  font-weight:300;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--rose);color:var(--ink)}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}

.display{font-family:"Fraunces",Georgia,serif;font-weight:300;line-height:1.02;letter-spacing:-0.01em}
.eyebrow{font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;font-weight:500;color:var(--paper-dim)}

/* nav */
header.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:26px 40px;transition:background .4s ease,padding .4s ease,border-color .4s ease;
  border-bottom:1px solid transparent;
}
header.nav.scrolled{
  background:rgba(20,17,15,.82);backdrop-filter:saturate(140%) blur(14px);
  border-color:var(--ink-line);padding:18px 40px;
}
.brand{font-family:"Fraunces",serif;font-weight:400;font-size:1.18rem;letter-spacing:.02em}
.navlinks{display:flex;gap:34px;align-items:center}
.navlinks a{font-size:.82rem;letter-spacing:.06em;color:var(--paper-dim);transition:color .25s}
.navlinks a:hover{color:var(--paper)}
.nav-cta{border:1px solid var(--ink-line);padding:9px 18px;border-radius:100px;color:var(--paper)!important}
.nav-cta:hover{border-color:var(--rose)}
.menu-btn{display:none;background:none;border:none;color:var(--paper);font-size:1.4rem;cursor:pointer;line-height:1}

/* mobile panel */
.mobile-nav{
  position:fixed;inset:0;z-index:49;background:var(--ink);
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:30px;
  opacity:0;pointer-events:none;transition:opacity .4s ease;
}
.mobile-nav.open{opacity:1;pointer-events:auto}
.mobile-nav a{font-family:"Fraunces",serif;font-size:2rem;color:var(--paper)}

/* hero */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden}
.hero-img{position:absolute;inset:0;z-index:0}
.hero-img img{width:100%;height:100%;object-fit:cover;object-position:center top;filter:saturate(.85) contrast(1.02)}
.hero-img::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(20,17,15,.55) 0%,rgba(20,17,15,.1) 30%,rgba(20,17,15,.55) 70%,var(--ink) 100%),
    linear-gradient(90deg,rgba(20,17,15,.6) 0%,rgba(20,17,15,0) 55%);
}
.hero-inner{position:relative;z-index:2;padding-bottom:9vh}
.hero h1{font-size:clamp(2.7rem,7.2vw,6.2rem);max-width:16ch;margin:.5em 0 .7em}
.hero h1 em{font-style:italic;color:var(--rose)}
.hero-sub{max-width:44ch;font-size:clamp(1rem,1.4vw,1.18rem);color:var(--paper);opacity:.9;font-weight:300}
.credits{display:flex;flex-wrap:wrap;gap:8px 26px;align-items:center;margin-top:42px;padding-top:26px;border-top:1px solid var(--ink-line);max-width:760px}
.credits span{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--paper-dim)}

section{padding:130px 0}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:64px}
.sec-head h2{font-size:clamp(2rem,4.2vw,3.4rem);max-width:18ch}
.sec-head .eyebrow{margin-bottom:18px}
.sec-note{max-width:34ch;color:var(--paper-dim);font-size:.96rem;padding-bottom:6px}

/* question signature */
.question{border-top:1px solid var(--ink-line);border-bottom:1px solid var(--ink-line);padding:96px 0}
.question p{font-family:"Fraunces",serif;font-style:italic;font-weight:300;font-size:clamp(1.7rem,4.6vw,3.6rem);line-height:1.18;max-width:24ch;letter-spacing:-0.01em}
.question .qmark{color:var(--rose)}
.question .who{display:block;margin-top:30px;font-family:"Hanken Grotesk",sans-serif;font-style:normal;font-size:.8rem;letter-spacing:.22em;text-transform:uppercase;color:var(--paper-dim)}

/* projects */
.project{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;padding:74px 0;border-top:1px solid var(--ink-line)}
.project:first-of-type{border-top:none}
.project.flip .p-media{order:2}
.p-media{display:block;position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--ink-raised)}
.p-media img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s cubic-bezier(.16,.84,.34,1);filter:saturate(.9)}
.project:hover .p-media img{transform:scale(1.04)}
.p-body h3 a{transition:color .25s}
.p-body h3 a:hover{color:var(--rose)}
.p-status{position:absolute;top:18px;left:18px;z-index:2;background:rgba(20,17,15,.78);backdrop-filter:blur(6px);border:1px solid var(--ink-line);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;padding:7px 13px;border-radius:100px;color:var(--rose)}
.p-status.done{color:var(--paper-dim)}
.p-body .p-partner{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--paper-dim);margin-bottom:18px}
.p-body h3{font-family:"Fraunces",serif;font-weight:300;font-size:clamp(1.7rem,3vw,2.5rem);line-height:1.08;margin-bottom:22px}
.p-body p{color:var(--paper);opacity:.82;max-width:46ch;margin-bottom:26px;font-size:1.02rem}
.p-link{display:inline-flex;align-items:center;gap:10px;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--paper)}
.p-link .arr{transition:transform .3s}
.p-link:hover .arr{transform:translateX(6px)}

/* portraits — masonry, natural proportions, no cropping */
.portraits-masonry{column-count:3;column-gap:6px}
.pt{
  display:block;width:100%;break-inside:avoid;margin:0 0 6px;
  position:relative;overflow:hidden;background:var(--ink-raised);
  border:none;padding:0;cursor:pointer;line-height:0;
}
.pt img{
  width:100%;height:auto;display:block;
  transition:transform 1.2s cubic-bezier(.16,.84,.34,1),filter .6s;
  filter:saturate(.82) brightness(.92);
}
.pt:hover img{transform:scale(1.04);filter:saturate(1) brightness(1)}
.pt.plate{min-height:340px;display:flex;align-items:flex-end;background:radial-gradient(120% 100% at 30% 0%, #2a221e 0%, #161210 70%);cursor:default}
.pt-cap{
  position:absolute;left:0;right:0;bottom:0;z-index:2;
  padding:22px;text-align:left;line-height:1.4;
  background:linear-gradient(180deg,rgba(20,17,15,0),rgba(20,17,15,.85));
  opacity:0;transition:opacity .4s ease;
}
.pt:hover .pt-cap,.pt.plate .pt-cap{opacity:1}
.pt-cap .nm{display:block;font-family:"Fraunces",serif;font-size:1.3rem;font-weight:400;color:var(--paper)}
.pt-cap .rl{display:block;font-size:.72rem;letter-spacing:.1em;color:var(--paper-dim);text-transform:uppercase;margin-top:6px}

/* lightbox */
.ss-lightbox{
  position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;
  background:rgba(12,10,9,.96);opacity:0;pointer-events:none;transition:opacity .35s ease;padding:24px;
}
.ss-lightbox.open{opacity:1;pointer-events:auto}
.ss-lightbox img{max-width:92vw;max-height:90vh;width:auto;height:auto;object-fit:contain;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.ss-lightbox-close{
  position:absolute;top:22px;right:28px;background:none;border:none;color:var(--paper);
  font-size:2.4rem;line-height:1;cursor:pointer;opacity:.8;transition:opacity .25s;
}
.ss-lightbox-close:hover{opacity:1}

/* about */
.about{display:grid;grid-template-columns:0.85fr 1fr;gap:80px;align-items:center}
.about-media{aspect-ratio:4/5;overflow:hidden;background:var(--ink-raised)}
.about-media img{width:100%;height:100%;object-fit:cover;filter:saturate(.85) grayscale(.15)}
.about-text h2{font-size:clamp(1.9rem,3.4vw,2.9rem);margin-bottom:30px;max-width:16ch}
.about-text p{color:var(--paper);opacity:.85;font-size:1.08rem;max-width:50ch;margin-bottom:22px}
.sign{font-family:"Fraunces",serif;font-style:italic;font-size:1.5rem;color:var(--rose);margin-top:34px}

/* recognition */
.recog{border-top:1px solid var(--ink-line);border-bottom:1px solid var(--ink-line)}
.recog-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--ink-line)}
.recog-cell{background:var(--ink);padding:54px 36px}
.recog-cell .num{font-family:"Fraunces",serif;font-size:clamp(2.4rem,4vw,3.4rem);font-weight:300;line-height:1}
.recog-cell .lbl{color:var(--paper-dim);font-size:.82rem;letter-spacing:.04em;margin-top:14px;max-width:22ch}

/* contact */
.contact{text-align:center;padding:150px 0}
.contact h2{font-size:clamp(2.4rem,6vw,5rem);max-width:18ch;margin:0 auto 40px}
.contact h2 em{font-style:italic;color:var(--rose)}
.contact .mailto{font-family:"Fraunces",serif;font-size:clamp(1.2rem,2.4vw,1.8rem);border-bottom:1px solid var(--ink-line);padding-bottom:6px;transition:border-color .3s}
.contact .mailto:hover{border-color:var(--rose)}

/* footer */
footer.site-footer{border-top:1px solid var(--ink-line);padding:54px 0 60px}
.foot{display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap}
.foot .brand{font-size:1.05rem}
.foot-links{display:flex;gap:26px}
.foot-links a{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--paper-dim)}
.foot-links a:hover{color:var(--paper)}
.foot-fine{font-size:.74rem;color:var(--paper-dim);letter-spacing:.04em}

/* single project */
.single-hero{position:relative;min-height:70vh;display:flex;align-items:flex-end;overflow:hidden}
.single-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(.85)}
.single-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,17,15,.3),rgba(20,17,15,.9))}
.single-hero .inner{position:relative;z-index:2;padding-bottom:8vh}
.single-hero h1{font-size:clamp(2.4rem,5vw,4.4rem);max-width:16ch;margin-top:.4em}
.single-body{padding:90px 0;max-width:740px}
.single-body p{font-size:1.12rem;opacity:.88;margin-bottom:26px}
.back-link{display:inline-block;margin-top:40px;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--paper-dim)}
.back-link:hover{color:var(--paper)}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity 1s ease,transform 1s cubic-bezier(.16,.84,.34,1)}
.reveal.in{opacity:1;transform:none}

@media (max-width:900px){
  .wrap{padding:0 24px}
  header.nav{padding:20px 24px}
  .navlinks{display:none}
  .menu-btn{display:block}
  section{padding:90px 0}
  .project,.about{grid-template-columns:1fr;gap:34px}
  .project.flip .p-media{order:0}
  .portraits-masonry{column-count:2}
  .recog-grid{grid-template-columns:1fr 1fr}
  .pt-cap{opacity:1}
  .sec-head{flex-direction:column;align-items:flex-start;gap:20px}
  .credits{margin-top:34px}
}
@media (max-width:560px){
  .portraits-masonry{column-count:1}
}
@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none;transition:none}
  .project:hover .p-media img,.pt:hover img{transform:none}
}
