/* ===== Pixcy Studios — Fine-Art Editorial (light) =====
   Tokens follow design-system primitive→semantic architecture.
   Type scale: Major Third (1.25). Tracking/contrast per brand spec. */
:root{
  /* primitives */
  --c-paper:#F7F4EE; --c-paper-2:#EFEAE0; --c-paper-3:#FBF9F5;
  --c-ink:#1B1916; --c-ink-60:#6B645A; --c-ink-40:#9A9388;
  --c-bronze:#9A7B4F; --c-bronze-2:#B79466; --c-white:#fff;
  --c-line:rgba(27,25,22,.14);
  /* semantic */
  --bg:var(--c-paper); --surface:var(--c-paper-3); --soft:var(--c-paper-2);
  --text:var(--c-ink); --muted:var(--c-ink-60); --faint:var(--c-ink-40);
  --accent:var(--c-bronze); --line:var(--c-line);
  /* type */
  --disp:'Fraunces',Georgia,serif; --sans:'Inter',system-ui,sans-serif;
  --t-5xl:clamp(2.8rem,7vw,5.6rem); --t-4xl:clamp(2.2rem,5vw,3.6rem);
  --t-2xl:1.953rem; --t-xl:1.563rem; --t-lg:1.25rem; --t-sm:.8rem; --t-xs:.7rem;
  --maxw:1300px; --gut:clamp(1.2rem,4vw,2.6rem);
  --e:cubic-bezier(.22,.7,.2,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--sans);font-weight:300;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

.kicker{font-size:var(--t-xs);font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:1.1rem}
.kicker-on-img{color:#f3e6cf}
.sec-title{font-family:var(--disp);font-weight:300;font-size:var(--t-4xl);line-height:1.02;letter-spacing:-.02em;color:var(--text)}
.sec-lead{color:var(--muted);max-width:60ch;margin:1.1rem auto 0;font-size:var(--t-lg);font-weight:300}

.btn{display:inline-block;font-size:var(--t-sm);font-weight:500;letter-spacing:.04em;padding:1rem 2rem;border-radius:2px;transition:.4s var(--e)}
.btn-solid{background:var(--accent);color:#fff}
.btn-solid:hover{background:var(--text)}
.btn-line{border:1px solid var(--line);color:var(--text)}
.btn-line:hover{border-color:var(--accent);color:var(--accent)}
.btn-block{width:100%;text-align:center;padding:1.1rem}

/* ===== Header — solid, no scroll border ===== */
.nav{position:sticky;top:0;z-index:50;background:var(--bg);transition:box-shadow .4s var(--e)}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:1.25rem var(--gut);display:flex;align-items:center;justify-content:space-between}
.nav.lift{box-shadow:0 10px 30px -22px rgba(27,25,22,.4)}   /* soft shadow, NOT a hard border */
.brand{font-family:var(--disp);font-weight:400;font-size:1.5rem;letter-spacing:.01em;color:var(--text)}
.brand span{font-style:italic;color:var(--accent)}
.nav-links{display:flex;align-items:center;gap:2.2rem}
.nav-links a{font-size:var(--t-sm);font-weight:400;letter-spacing:.04em;color:var(--muted);transition:.25s}
.nav-links a:hover,.nav-links a.active{color:var(--text)}
.nav-cta{border:1px solid var(--accent);color:var(--accent)!important;padding:.55rem 1.25rem;border-radius:2px}
.nav-cta:hover{background:var(--accent);color:#fff!important}
.nav-toggle{display:none;flex-direction:column;gap:6px;padding:6px;z-index:60}
.nav-toggle span{width:25px;height:1.5px;background:var(--text);transition:.35s var(--e)}
.nav-toggle.open span:nth-child(1){transform:translateY(4px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){transform:translateY(-4px) rotate(-45deg)}

/* ===== Hero ===== */
.hero{position:relative;height:calc(100svh - 72px);min-height:520px;overflow:hidden;display:flex;align-items:flex-end;background:#000}
.hero-media{position:absolute;inset:0;overflow:hidden;z-index:0}
.hero-media iframe,.hero-poster{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100vw;height:56.25vw;min-height:100%;min-width:177.78vh;pointer-events:none}
.hero-poster{object-fit:cover;width:100%;height:100%;min-width:0}
.hero-veil{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(20,17,13,.18),transparent 30%,transparent 60%,rgba(20,17,13,.55))}
.hero-copy{position:relative;z-index:2;max-width:var(--maxw);width:100%;margin:0 auto;padding:0 var(--gut) clamp(3rem,7vh,5.5rem);color:#fff}
.hero-title{font-family:var(--disp);font-weight:300;font-size:var(--t-5xl);line-height:.98;letter-spacing:-.02em}
.hero-title em{font-style:italic;color:var(--c-bronze-2)}
.hero-sub{margin-top:1.2rem;font-size:var(--t-lg);font-weight:300;color:rgba(255,255,255,.9);letter-spacing:.01em}
.scroll-cue{position:absolute;left:50%;bottom:1.6rem;transform:translateX(-50%);z-index:2}
.scroll-cue span{display:block;width:1px;height:46px;background:linear-gradient(#fff,transparent);animation:cue 2.4s ease-in-out infinite}
@keyframes cue{0%,100%{opacity:.25;transform:scaleY(.6)}50%{opacity:.9;transform:scaleY(1)}}

/* ===== Statement ===== */
.statement{text-align:center;max-width:920px;margin:0 auto;padding:clamp(4.5rem,10vw,8rem) var(--gut)}
.statement p{font-family:var(--disp);font-weight:300;font-size:clamp(1.7rem,4vw,3rem);line-height:1.22;letter-spacing:-.01em;color:var(--text)}
.statement em{font-style:italic;color:var(--accent)}
.statement .sig{display:block;margin-top:1.6rem;font-size:var(--t-sm);letter-spacing:.12em;text-transform:uppercase;color:var(--faint)}

/* ===== Sections ===== */
.section{max-width:var(--maxw);margin:0 auto;padding:clamp(4rem,9vw,7rem) var(--gut)}
.section-soft{max-width:none;background:var(--soft)}
.section-soft>*{max-width:var(--maxw);margin-left:auto;margin-right:auto}
.sec-head{text-align:center;margin-bottom:clamp(2.6rem,5vw,4rem)}
.sec-action{text-align:center;margin-top:3rem}

/* ===== Gallery (editorial) ===== */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:clamp(150px,18vw,250px);gap:14px;grid-auto-flow:dense}
.g{overflow:hidden;position:relative;background:var(--soft);cursor:pointer}
.g img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--e),filter .6s}
.g::after{content:'';position:absolute;inset:0;background:rgba(27,25,22,0);transition:.5s}
.g:hover img{transform:scale(1.05)}
.g:hover::after{background:rgba(27,25,22,.1)}
.g-wide{grid-column:span 2}.g-tall{grid-row:span 2}.g-big{grid-column:span 2;grid-row:span 2}

/* ===== Films ===== */
.films{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.films .film:first-child{grid-column:span 2;grid-row:span 2}
.film{position:relative;overflow:hidden;aspect-ratio:16/9;background:#000;cursor:pointer;box-shadow:0 16px 40px -28px rgba(27,25,22,.5)}
.film img{width:100%;height:100%;object-fit:cover;opacity:.96;transition:.9s var(--e)}
.film:hover img{transform:scale(1.05);opacity:1}
.film::after{content:'';position:absolute;inset:0;background:linear-gradient(transparent 60%,rgba(0,0,0,.4))}
.film-play{position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center}
.film-play svg{width:52px;height:52px;fill:#fff;opacity:.92;filter:drop-shadow(0 2px 12px rgba(0,0,0,.5));transition:.4s var(--e)}
.film:hover .film-play svg{transform:scale(1.14)}

/* ===== Services ===== */
.svcs{border-top:1px solid var(--line)}
.svc{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:clamp(1rem,4vw,3rem);padding:clamp(1.6rem,4vw,2.5rem) .3rem;border-bottom:1px solid var(--line);transition:.45s var(--e)}
.svc:hover{padding-left:1.3rem;background:linear-gradient(90deg,rgba(154,123,79,.05),transparent)}
.svc-n{font-family:var(--disp);font-style:italic;font-size:1.5rem;color:var(--accent);opacity:.8}
.svc h3{font-family:var(--disp);font-weight:400;font-size:var(--t-2xl);letter-spacing:-.01em}
.svc p{color:var(--muted);font-size:.98rem;max-width:62ch;margin-top:.3rem}
.svc-go{font-size:var(--t-sm);font-weight:500;color:var(--accent);white-space:nowrap;opacity:0;transform:translateX(-8px);transition:.4s var(--e)}
.svc:hover .svc-go{opacity:1;transform:none}

/* ===== Reviews (slow) ===== */
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.marquee-track{display:flex;gap:22px;width:max-content;animation:scrollx 120s linear infinite}  /* slow */
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes scrollx{to{transform:translateX(-50%)}}
.review{flex:0 0 380px;max-width:84vw;background:var(--c-white);border:1px solid var(--line);border-radius:4px;padding:2.1rem;display:flex;flex-direction:column}
.review-stars{color:var(--accent);letter-spacing:.18em;margin-bottom:1rem}
.review-text{font-family:var(--disp);font-weight:300;font-size:1.18rem;line-height:1.5;color:var(--text);flex:1}
.review-by{margin-top:1.4rem;display:flex;align-items:center;gap:.75rem}
.review-av{width:38px;height:38px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--disp)}
.review-name{font-weight:500;font-size:.92rem}
.review-src{font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--faint)}

/* ===== About ===== */
.about-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2rem,6vw,5rem);align-items:center}
.about-img{aspect-ratio:4/5;overflow:hidden;background:var(--soft)}
.about-img img{width:100%;height:100%;object-fit:cover}
.about-body .sec-title{margin-bottom:1.4rem}
.about-body p{color:var(--muted);margin-bottom:1rem;max-width:58ch}

/* ===== Contact ===== */
.contact{background:var(--soft)}
.contact-inner{max-width:var(--maxw);margin:0 auto;padding:clamp(4rem,9vw,7rem) var(--gut);display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,6vw,5rem);align-items:center}
.contact-title{font-family:var(--disp);font-weight:300;font-size:var(--t-4xl);line-height:1.0;letter-spacing:-.02em;color:var(--text)}
.contact-blurb{margin-top:1.2rem;font-size:var(--t-lg);color:var(--muted);max-width:44ch}
.contact-blurb strong{color:var(--text);font-weight:500}
.contact-proof{display:flex;align-items:center;gap:.7rem;margin-top:1.5rem;font-size:.92rem;color:var(--muted)}
.contact-proof .stars{color:var(--accent);letter-spacing:.12em}
.contact-direct{margin-top:1.9rem;display:flex;flex-direction:column;gap:.7rem}
.contact-direct a{font-size:1rem;color:var(--text);width:fit-content;border-bottom:1px solid transparent;transition:.25s}
.contact-direct a:hover{border-color:var(--accent);color:var(--accent)}
.contact-social{display:flex;gap:1.4rem;margin-top:1.7rem}
.contact-social a{font-size:.72rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.contact-social a:hover{color:var(--text)}
.contact-card{background:var(--c-white);border-radius:6px;padding:clamp(1.6rem,4vw,2.4rem);box-shadow:0 40px 80px -40px rgba(60,45,20,.35)}
.contact-card label{display:block;font-size:var(--t-sm);font-weight:500;color:var(--muted);margin-bottom:1rem}
.contact-card label small{font-weight:400;color:var(--faint)}
.contact-card .row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.contact-card input,.contact-card select,.contact-card textarea{display:block;width:100%;margin-top:.45rem;background:var(--c-paper-3);border:1px solid var(--line);border-radius:3px;padding:.85rem .9rem;font-family:var(--sans);font-size:.95rem;font-weight:400;color:var(--text);transition:.25s}
.contact-card input::placeholder,.contact-card textarea::placeholder{color:var(--faint)}
.contact-card :focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px rgba(154,123,79,.15)}
.contact-card textarea{resize:vertical}
.contact-card .btn{margin-top:.4rem}
.card-note{font-size:.74rem;color:var(--faint);text-align:center;margin-top:.8rem}

/* ===== Footer ===== */
.footer{background:var(--bg);text-align:center;padding:3.4rem 1.5rem;border-top:1px solid var(--line)}
.footer .brand{display:inline-block;font-size:1.4rem;margin-bottom:1rem}
.footer p{color:var(--muted);font-size:.86rem}
.foot-fine{font-size:.74rem;color:var(--faint);margin-top:.5rem}

/* ===== Float ===== */
.wa-float{position:fixed;bottom:22px;right:22px;z-index:40;width:54px;height:54px;border-radius:50%;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 28px rgba(37,211,102,.4);transition:.3s var(--e)}
.wa-float:hover{transform:scale(1.08)}

/* ===== Modals ===== */
.vmodal,.lightbox{position:fixed;inset:0;z-index:100;background:rgba(20,17,13,.94);display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .4s}
.vmodal.active,.lightbox.active{display:flex;opacity:1}
.vm-frame{width:min(92vw,1120px);aspect-ratio:16/9}
.vm-frame iframe{width:100%;height:100%;border:0;border-radius:4px}
.vm-close{position:fixed;top:20px;right:26px;font-size:2.4rem;color:#fff;z-index:110;opacity:.85;line-height:1}
.vm-close:hover{opacity:1}
.lb-img{max-width:92vw;max-height:86vh;object-fit:contain;border-radius:3px}
.lb-nav{position:fixed;top:50%;transform:translateY(-50%);font-size:3rem;color:#fff;opacity:.55;padding:1rem}
.lb-nav:hover{opacity:1}
.lb-prev{left:2vw}.lb-next{right:2vw}

/* ===== Reveal (calm) ===== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity 1.1s var(--e),transform 1.1s var(--e)}
.reveal.in{opacity:1;transform:none}

/* ===== Responsive ===== */
@media(max-width:900px){
  .nav-toggle{display:flex}
  .nav-links{position:fixed;inset:0;background:var(--bg);flex-direction:column;justify-content:center;gap:1.8rem;transform:translateX(100%);transition:transform .45s var(--e)}
  .nav-links.open{transform:none}
  .nav-links a{font-size:1.15rem}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .g-big{grid-column:span 2;grid-row:span 2}
  .films{grid-template-columns:1fr 1fr}
  .films .film:first-child{grid-column:span 2;grid-row:auto}
  .about-grid,.contact-inner{grid-template-columns:1fr}
  .svc{grid-template-columns:auto 1fr}.svc-go{display:none}
}
@media(max-width:540px){
  .gallery{grid-template-columns:1fr 1fr;grid-auto-rows:150px}
  .g-big,.g-wide{grid-column:span 2}
  .films,.films .film:first-child{grid-template-columns:1fr;grid-column:auto}
  .contact-card .row{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001s!important;animation-iteration-count:1!important}
  .reveal{opacity:1;transform:none}.marquee-track{animation:none}
}
