/* ============================================================
   CREATE PIXELS — Photography & Creative Studio
   Design system + components
   ============================================================ */

:root{
  --ink:        #0b0b0d;
  --ink-2:      #111114;
  --ink-3:      #17171b;
  --line:       rgba(255,255,255,.10);
  --line-strong:rgba(255,255,255,.18);

  --gold:       #f2a63b;
  --gold-soft:  #f6c766;
  --gold-deep:  #e0871a;
  --gold-grad:  linear-gradient(135deg, #f6c766 0%, #f2a63b 45%, #e0871a 100%);

  --cream:      #f6f2e9;
  --cream-2:    #efe9db;
  --paper-ink:  #14140f;

  --white:      #ffffff;
  --muted:      #9a9aa3;
  --muted-2:    #6f6f78;

  --ff-display: "Anton", "Archivo", sans-serif;
  --ff-head:    "Archivo", sans-serif;
  --ff-body:    "Inter", sans-serif;
  --ff-serif:   "Cormorant Garamond", serif;

  --ease:       cubic-bezier(.22,1,.36,1);
  --ease-2:     cubic-bezier(.65,.05,.36,1);

  --maxw: 1280px;
  --pad: clamp(20px, 5vw, 80px);
}

*{ margin:0; padding:0; box-sizing:border-box; }

html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  font-family:var(--ff-body);
  background:var(--ink);
  color:var(--white);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body.is-locked{ overflow:hidden; }

img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
ul{ list-style:none; }

::selection{ background:var(--gold); color:var(--ink); }

.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }
.section{ padding-block:clamp(70px, 11vw, 150px); position:relative; }

/* hide native cursor only on capable pointers */
@media (hover:hover) and (pointer:fine){
  body{ cursor:none; }
  a,button,[data-cursor]{ cursor:none; }
}

/* ---------- Typography helpers ---------- */
.kicker{
  display:inline-block;
  font-family:var(--ff-head);
  font-weight:600;
  font-size:.78rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:1.1rem;
}
.kicker.center{ display:block; text-align:center; }

.section-title{
  font-family:var(--ff-display);
  font-weight:400;
  font-size:clamp(2.4rem, 6.5vw, 5.4rem);
  line-height:.95;
  letter-spacing:.005em;
  text-transform:uppercase;
}
.section-title.center{ text-align:center; }
.ital{
  font-family:var(--ff-serif);
  font-style:italic;
  font-weight:500;
  text-transform:none;
  color:var(--gold);
  letter-spacing:0;
}

.section-head{
  display:flex; justify-content:space-between; align-items:flex-end;
  gap:40px; flex-wrap:wrap; margin-bottom:clamp(36px,5vw,64px);
}
.section-head__note{
  max-width:380px; color:var(--muted); font-size:1.02rem;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  --b: var(--white);
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--ff-head); font-weight:600;
  font-size:.92rem; letter-spacing:.02em;
  padding:1.05em 1.7em; border-radius:100px;
  position:relative; overflow:hidden; isolation:isolate;
  transition:color .4s var(--ease), border-color .4s var(--ease), transform .4s var(--ease);
  white-space:nowrap;
}
.btn__arrow{ transition:transform .4s var(--ease); }
.btn:hover .btn__arrow{ transform:translate(3px,-3px); }

.btn--solid{ background:var(--gold-grad); color:var(--ink); box-shadow:0 10px 30px -10px rgba(242,166,59,.6); }
.btn--solid::before{
  content:""; position:absolute; inset:0; z-index:-1; background:var(--white);
  transform:translateY(101%); transition:transform .5s var(--ease);
}
.btn--solid:hover{ color:var(--ink); }
.btn--solid:hover::before{ transform:translateY(0); }

.btn--ghost{ border:1px solid var(--line-strong); color:var(--white); }
.btn--ghost::before{
  content:""; position:absolute; inset:0; z-index:-1; background:var(--white);
  transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease);
}
.btn--ghost:hover{ color:var(--ink); border-color:var(--white); }
.btn--ghost:hover::before{ transform:scaleX(1); }

.btn--pill{ background:var(--white); color:var(--ink); padding:.85em 1.4em; font-size:.85rem; }
.btn--pill::before{
  content:""; position:absolute; inset:0; z-index:-1; background:var(--gold);
  transform:scaleX(0); transform-origin:right; transition:transform .45s var(--ease);
}
.btn--pill:hover::before{ transform:scaleX(1); transform-origin:left; }

/* ============================================================
   PRELOADER
   ============================================================ */
.preloader{
  position:fixed; inset:0; z-index:9999; background:var(--ink);
  display:flex; align-items:center; justify-content:center;
}
.preloader__inner{ text-align:center; position:relative; z-index:2; }
.preloader__logo{ display:flex; justify-content:center; margin-bottom:18px; }
.preloader__img{ width:150px; height:auto; flex:none; align-self:center; display:block; filter:drop-shadow(0 0 28px rgba(242,166,59,.35)); animation:plpulse 2.2s ease-in-out infinite; }
@keyframes plpulse{ 0%,100%{ transform:scale(.92); opacity:.7; } 50%{ transform:scale(1); opacity:1; } }
@keyframes plspin{ to{ transform:rotate(360deg); } }
.pl-ring{ stroke-dasharray:214; stroke-dashoffset:214; animation:plring 1.6s var(--ease) forwards; }
@keyframes plring{ to{ stroke-dashoffset:0; } }
.preloader__brand{
  font-family:var(--ff-display); font-size:1.6rem; letter-spacing:.32em;
  text-transform:uppercase; padding-left:.32em;
}
.preloader__brand span{ color:var(--gold); }
.preloader__count{
  margin-top:10px; font-family:var(--ff-head); font-weight:700;
  font-size:.9rem; color:var(--muted); letter-spacing:.1em;
}
.preloader__count i{ font-style:normal; }
.preloader__curtain{
  position:absolute; inset:0; background:var(--ink); z-index:1; transform-origin:top;
}
.preloader.is-done .preloader__inner{ opacity:0; transform:translateY(-12px); transition:.5s var(--ease); }
.preloader.is-done{ transform:translateY(-100%); transition:transform .9s var(--ease-2) .25s; }

/* ============================================================
   CUSTOM CURSOR
   ============================================================ */
.cursor, .cursor-ring{ position:fixed; top:0; left:0; pointer-events:none; z-index:9998; border-radius:50%;
  transform:translate(-50%,-50%); will-change:transform; }
.cursor{ width:7px; height:7px; background:var(--gold); }
.cursor-ring{
  width:38px; height:38px; border:1px solid rgba(255,255,255,.5);
  transition:width .3s var(--ease), height .3s var(--ease), background .3s var(--ease), border-color .3s var(--ease);
  display:flex; align-items:center; justify-content:center;
}
.cursor-ring__label{
  font-family:var(--ff-head); font-size:.6rem; font-weight:700; letter-spacing:.1em;
  text-transform:uppercase; color:var(--ink); opacity:0; transition:opacity .25s; white-space:nowrap;
}
body.cur-hover .cursor-ring{ width:54px; height:54px; background:rgba(255,255,255,.12); border-color:transparent; }
body.cur-view .cursor-ring{ width:84px; height:84px; background:var(--gold); border-color:transparent; }
body.cur-view .cursor-ring__label{ opacity:1; }
body.cur-view .cursor{ opacity:0; }
@media (hover:none),(pointer:coarse){ .cursor,.cursor-ring{ display:none !important; } }

/* ============================================================
   SCROLL PROGRESS
   ============================================================ */
.scroll-progress{
  position:fixed; top:0; left:0; height:3px; width:0%;
  background:var(--gold-grad); z-index:9000;
}

/* ============================================================
   HEADER / NAV
   ============================================================ */
.header{
  position:fixed; top:0; left:0; width:100%; z-index:900;
  padding:18px var(--pad);
  transition:padding .4s var(--ease);
}
.header__inner{
  max-width:var(--maxw); margin-inline:auto;
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  padding:11px 13px 11px 22px; border-radius:100px;
  border:1px solid var(--line);
  background:rgba(17,17,20,.5);
  backdrop-filter:blur(18px) saturate(150%);
  -webkit-backdrop-filter:blur(18px) saturate(150%);
  transition:background .4s var(--ease), border-color .4s var(--ease), box-shadow .4s var(--ease);
}
.header.is-scrolled{ padding-top:12px; padding-bottom:12px; }
.header.is-scrolled .header__inner{
  background:rgba(12,12,15,.8);
  border-color:var(--line-strong);
  box-shadow:0 22px 50px -26px rgba(0,0,0,.85);
}
.brand{ display:flex; align-items:center; gap:11px; }
.brand__mark{ height:30px; width:auto; display:block; transition:transform .5s var(--ease), filter .5s var(--ease); filter:drop-shadow(0 2px 8px rgba(242,166,59,.25)); }
.brand:hover .brand__mark{ transform:scale(1.08); }
.brand__text{
  font-family:var(--ff-head); font-weight:600; letter-spacing:.22em;
  font-size:.92rem; text-transform:uppercase; line-height:1;
}
.brand__text b{ color:var(--gold); font-weight:800; }

.nav{ display:flex; gap:clamp(16px, 1.8vw, 30px); }
.nav a{
  font-family:var(--ff-head); font-weight:500; font-size:.9rem;
  letter-spacing:.04em; position:relative; padding:4px 0; color:rgba(255,255,255,.82);
  transition:color .3s;
}
.nav a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:1.5px; width:0;
  background:var(--gold); transition:width .35s var(--ease);
}
.nav a:hover{ color:var(--white); }
.nav a:hover::after{ width:100%; }

.header__cta{ margin-left:auto; }
.nav + .header__cta{ margin-left:0; }

.burger{ display:none; width:42px; height:42px; flex-direction:column; gap:6px;
  align-items:center; justify-content:center; }
.burger span{ width:24px; height:2px; background:var(--white); transition:.4s var(--ease); }
body.menu-open .burger span:nth-child(1){ transform:translateY(4px) rotate(45deg); }
body.menu-open .burger span:nth-child(2){ transform:translateY(-4px) rotate(-45deg); }

/* mobile overlay */
.menu-overlay{
  position:fixed; inset:0; z-index:850; background:var(--ink-2);
  display:flex; flex-direction:column; justify-content:flex-start;
  padding:var(--pad); padding-top:clamp(104px, 15vh, 150px);
  overflow-y:auto; -webkit-overflow-scrolling:touch;
  clip-path:circle(0% at calc(100% - 40px) 40px);
  transition:clip-path .7s var(--ease-2);
  pointer-events:none;
}
body.menu-open .menu-overlay{ clip-path:circle(150% at calc(100% - 40px) 40px); pointer-events:auto; }
.menu-overlay__nav{ display:flex; flex-direction:column; gap:2px; }
.menu-overlay__nav a{
  font-family:var(--ff-display); font-size:clamp(1.7rem,7.5vw,3rem);
  text-transform:uppercase; line-height:1.04; color:var(--white);
  display:flex; align-items:baseline; gap:14px; transition:color .3s, padding-left .35s var(--ease);
}
.menu-overlay__nav a i{ font-family:var(--ff-head); font-size:.78rem; font-style:normal; color:var(--gold); font-weight:700; }
.menu-overlay__nav a:hover{ color:var(--gold); padding-left:14px; }
.menu-overlay__foot{ display:flex; flex-wrap:wrap; gap:18px; margin-top:auto;
  border-top:1px solid var(--line); padding-top:24px; color:var(--muted); font-size:.95rem; }
.menu-overlay__foot a:hover{ color:var(--gold); }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; min-height:100svh; display:flex; flex-direction:column;
  justify-content:center; padding:120px var(--pad) 90px; overflow:hidden;
}
.hero__media{ position:absolute; inset:0; z-index:-2; }
.hero__media img{ width:100%; height:100%; object-fit:cover; transform:scale(1.08); }
.hero__scrim{
  position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(11,11,13,.92) 0%, rgba(11,11,13,.62) 42%, rgba(11,11,13,.32) 100%),
    linear-gradient(0deg, rgba(11,11,13,.95) 2%, rgba(11,11,13,0) 40%);
}
.hero__inner{ max-width:980px; }
.hero__eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--ff-head); font-weight:500; font-size:.82rem;
  letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.82);
  border:1px solid var(--line-strong); border-radius:100px; padding:.55em 1.1em;
  margin-bottom:28px; background:rgba(255,255,255,.04); backdrop-filter:blur(4px);
}
.hero__eyebrow .dot{ width:8px; height:8px; border-radius:50%; background:var(--gold);
  box-shadow:0 0 0 0 rgba(242,166,59,.6); animation:pulse 2.2s infinite; }
@keyframes pulse{ 70%{ box-shadow:0 0 0 8px rgba(242,166,59,0); } 100%{ box-shadow:0 0 0 0 rgba(242,166,59,0); } }

.hero__title{
  font-family:var(--ff-display); font-weight:400;
  font-size:clamp(3.2rem, 12vw, 9.5rem); line-height:.86;
  text-transform:uppercase; letter-spacing:.004em;
}
.hero__title .line{ display:block; overflow:hidden; }
.hero__title .line > span{ display:block; transform:translateY(110%); }
.hero__title .gold > span{ color:var(--gold); }

.hero__sub{
  font-family:var(--ff-serif); font-size:clamp(1.2rem,2.6vw,1.9rem);
  font-weight:500; color:rgba(255,255,255,.9); max-width:620px; margin-top:30px; line-height:1.45;
}
.hero__sub em{ color:var(--gold); font-style:italic; }

.hero__actions{ display:flex; gap:16px; flex-wrap:wrap; margin-top:38px; }

.hero__scroll{
  position:absolute; left:var(--pad); bottom:34px; display:flex; align-items:center; gap:14px;
  font-family:var(--ff-head); font-size:.72rem; letter-spacing:.25em; text-transform:uppercase;
  color:var(--muted);
}
.hero__scroll-line{ width:46px; height:1px; background:var(--line-strong); position:relative; overflow:hidden; }
.hero__scroll-line::after{ content:""; position:absolute; inset:0; background:var(--gold); transform:translateX(-100%);
  animation:scrollline 2.2s var(--ease) infinite; }
@keyframes scrollline{ 50%{ transform:translateX(0); } 100%{ transform:translateX(100%); } }

.hero__badge{
  position:absolute; right:var(--pad); bottom:34px; display:flex; flex-direction:column; gap:8px; align-items:flex-end;
}
.hero__badge-tag{
  font-family:var(--ff-head); font-size:.7rem; letter-spacing:.2em; text-transform:uppercase;
  color:rgba(255,255,255,.7); border:1px solid var(--line); border-radius:100px; padding:.4em .9em;
  background:rgba(255,255,255,.03); backdrop-filter:blur(4px);
}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{
  background:var(--gold); color:var(--ink); overflow:hidden; padding:16px 0;
  border-block:1px solid rgba(0,0,0,.1); white-space:nowrap;
}
.marquee__track{ display:inline-flex; gap:0; animation:marq 28s linear infinite; }
.marquee__track span{
  font-family:var(--ff-display); font-size:1.3rem; letter-spacing:.04em;
  text-transform:uppercase; padding-right:24px;
}
@keyframes marq{ to{ transform:translateX(-50%); } }

/* ============================================================
   STUDIO / ABOUT
   ============================================================ */
.studio{ background:var(--ink); }
.studio__grid{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(30px,5vw,70px); align-items:start; }
.studio__head{
  font-family:var(--ff-display); font-weight:400; text-transform:uppercase;
  font-size:clamp(1.9rem,4.2vw,3.5rem); line-height:1.02;
}
.studio__right p{ color:var(--muted); font-size:1.08rem; margin-bottom:22px; }
.studio__right p strong{ color:var(--white); font-weight:600; }
.studio__signature{ margin-top:30px; padding-top:22px; border-top:1px solid var(--line); }
.studio__sig-name{ display:block; font-family:var(--ff-serif); font-style:italic; font-size:1.7rem; color:var(--gold); }
.studio__sig-role{ font-family:var(--ff-head); font-size:.78rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted-2); }

.stats{
  display:grid; grid-template-columns:repeat(4,1fr); gap:24px;
  margin-top:clamp(50px,7vw,90px); padding-top:clamp(40px,5vw,60px); border-top:1px solid var(--line);
}
.stat__num{
  display:block; font-family:var(--ff-display); font-size:clamp(2.6rem,5vw,4.4rem);
  line-height:1; color:var(--white); letter-spacing:.01em;
}
.stat__label{ font-family:var(--ff-head); font-size:.82rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); }

/* ============================================================
   WORK / GALLERY
   ============================================================ */
.work{ background:var(--ink-2); }
.filters{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:34px; }
.filter{
  font-family:var(--ff-head); font-weight:500; font-size:.86rem; letter-spacing:.03em;
  padding:.6em 1.2em; border-radius:100px; border:1px solid var(--line-strong);
  color:var(--muted); transition:all .35s var(--ease);
}
.filter:hover{ color:var(--white); border-color:var(--white); }
.filter.is-active{ background:var(--gold); color:var(--ink); border-color:var(--gold); }

.gallery{
  display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:230px; gap:14px;
}
.gcard{
  position:relative; overflow:hidden; border-radius:16px; background:var(--ink-3);
  transition:opacity .5s var(--ease), transform .5s var(--ease), filter .5s var(--ease);
}
.gcard--tall{ grid-row:span 2; }
.gcard--wide{ grid-column:span 2; }
.gcard img{ width:100%; height:100%; object-fit:cover; transition:transform .9s var(--ease), filter .6s; }
.gcard:hover img{ transform:scale(1.07); }
.gcard figcaption{
  position:absolute; inset:auto 0 0 0; padding:18px 18px 16px;
  background:linear-gradient(0deg, rgba(8,8,9,.9), rgba(8,8,9,0));
  transform:translateY(8px); opacity:0; transition:.45s var(--ease);
}
.gcard:hover figcaption{ transform:translateY(0); opacity:1; }
.gcard__cat{ display:block; font-family:var(--ff-head); font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-bottom:3px; }
.gcard__title{ font-family:var(--ff-serif); font-style:italic; font-size:1.25rem; }
.gcard.is-hidden{ opacity:0; transform:scale(.92); pointer-events:none; position:absolute; visibility:hidden; }

/* ============================================================
   SERVICES
   ============================================================ */
.services{
  background:
    radial-gradient(50% 40% at 88% 4%, rgba(242,166,59,.08), transparent 60%),
    var(--ink);
}
.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.svc{
  position:relative; padding:38px 32px 34px; border-radius:22px;
  background:linear-gradient(180deg, var(--ink-3), var(--ink-2));
  border:1px solid var(--line); overflow:hidden; isolation:isolate;
  transition:transform .5s var(--ease), border-color .5s var(--ease);
}
.svc::before{
  content:""; position:absolute; inset:0; z-index:-1; opacity:0;
  background:radial-gradient(120% 80% at 50% -10%, rgba(242,166,59,.16), transparent 60%);
  transition:opacity .5s var(--ease);
}
.svc:hover{ transform:translateY(-6px); border-color:var(--line-strong); }
.svc:hover::before{ opacity:1; }
.svc__no{
  position:absolute; top:24px; right:28px; font-family:var(--ff-display);
  font-size:2.6rem; color:rgba(255,255,255,.06); line-height:1;
}
.svc__icon{
  width:56px; height:56px; border-radius:14px; display:flex; align-items:center; justify-content:center;
  background:rgba(242,166,59,.12); color:var(--gold); margin-bottom:24px;
  transition:background .4s var(--ease), color .4s var(--ease);
}
.svc:hover .svc__icon{ background:var(--gold); color:var(--ink); }
.svc__title{ font-family:var(--ff-head); font-weight:700; font-size:1.4rem; margin-bottom:10px; }
.svc__desc{ color:var(--muted); font-size:.98rem; margin-bottom:22px; }
.svc__list{ display:grid; gap:1px; border-top:1px solid var(--line); }
.svc__list li{
  font-family:var(--ff-head); font-size:.95rem; color:rgba(255,255,255,.84);
  padding:10px 0 10px 22px; border-bottom:1px solid var(--line); position:relative;
}
.svc__list li::before{
  content:""; position:absolute; left:2px; top:50%; width:7px; height:7px; transform:translateY(-50%) rotate(45deg);
  border:1.5px solid var(--gold); border-left:none; border-bottom:none;
}

/* ============================================================
   WHY US
   ============================================================ */
.why{ background:var(--cream); color:var(--paper-ink); }
.why .kicker{ color:var(--gold-deep); }
.why .section-title{ color:var(--paper-ink); }
.why .ital{ color:var(--gold-deep); }
.why__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:clamp(40px,5vw,64px); }
.why__item{
  background:rgba(255,255,255,.6); border:1px solid rgba(20,20,15,.08); border-radius:20px;
  padding:34px 28px; transition:transform .5s var(--ease), box-shadow .5s var(--ease), background .5s;
}
.why__item:hover{ transform:translateY(-6px); box-shadow:0 24px 50px -28px rgba(20,20,15,.4); background:var(--white); }
.why__icon{
  display:inline-flex; align-items:center; justify-content:center;
  width:54px; height:54px; border-radius:50%; background:var(--gold-grad); color:var(--ink);
  font-size:1.4rem; margin-bottom:20px;
}
.why__item h3{ font-family:var(--ff-head); font-weight:700; font-size:1.22rem; margin-bottom:8px; }
.why__item p{ color:#55554c; font-size:.96rem; }

/* ============================================================
   PROCESS
   ============================================================ */
.process{ background:var(--ink); }
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; counter-reset:step; }
.step{ position:relative; padding:34px 26px 34px 0; border-top:2px solid var(--line); }
.step + .step{ padding-left:30px; border-left:1px solid var(--line); }
.step__no{ font-family:var(--ff-display); font-size:1.1rem; color:var(--gold); letter-spacing:.1em; }
.step h3{ font-family:var(--ff-head); font-weight:800; font-size:1.6rem; margin:14px 0 10px; text-transform:uppercase; }
.step p{ color:var(--muted); font-size:.98rem; }
.step::after{
  content:""; position:absolute; top:-7px; left:0; width:12px; height:12px; border-radius:50%;
  background:var(--gold);
}
.step + .step::after{ left:30px; }

/* ============================================================
   SHOWREEL BAND
   ============================================================ */
.band{ position:relative; padding:clamp(80px,12vw,160px) 0; overflow:hidden; text-align:center; }
.band__media{ position:absolute; inset:0; z-index:-2; }
.band__media img{ width:100%; height:100%; object-fit:cover; transform:scale(1.06); }
.band__scrim{ position:absolute; inset:0; background:rgba(11,11,13,.74); }
.band__title{
  font-family:var(--ff-display); font-size:clamp(2.4rem,7vw,6rem); line-height:.95;
  text-transform:uppercase;
}
.band__btn{ margin-top:34px; }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.voices{ background:var(--ink-2); }
.voices__slider{ overflow:hidden; margin-top:clamp(40px,5vw,60px); }
.voices__track{ display:flex; transition:transform .7s var(--ease-2); }
.voice{
  flex:0 0 100%; padding:0 clamp(0px,4vw,60px); text-align:center;
}
.voice__stars{ color:var(--gold); letter-spacing:.2em; font-size:1.1rem; margin-bottom:22px; }
.voice p{
  font-family:var(--ff-serif); font-size:clamp(1.4rem,3.4vw,2.5rem); line-height:1.4; font-weight:500;
  max-width:900px; margin-inline:auto;
}
.voice p em{ color:var(--gold); font-style:italic; }
.voice footer{ margin-top:28px; }
.voice footer span{ display:block; font-family:var(--ff-head); font-weight:700; font-size:1.05rem; }
.voice footer i{ font-style:normal; color:var(--muted); font-size:.85rem; letter-spacing:.1em; text-transform:uppercase; }
.voices__dots{ display:flex; gap:10px; justify-content:center; margin-top:40px; }
.voices__dots button{ width:9px; height:9px; border-radius:50%; background:var(--line-strong); transition:.35s var(--ease); }
.voices__dots button.is-active{ background:var(--gold); width:26px; border-radius:5px; }

/* ============================================================
   CONTACT
   ============================================================ */
.contact{
  position:relative; overflow:hidden;
  background:
    radial-gradient(55% 45% at 80% 8%, rgba(242,166,59,.10), transparent 60%),
    radial-gradient(50% 40% at 12% 100%, rgba(37,211,102,.07), transparent 60%),
    var(--ink);
}
.contact__top{ text-align:center; max-width:760px; margin:0 auto clamp(40px,5vw,64px); }
.contact__head{ font-family:var(--ff-display); font-size:clamp(2.4rem,6vw,4.6rem); line-height:.98; text-transform:uppercase; }
.contact__lead{ color:var(--muted); font-size:1.08rem; margin-top:20px; }

.contact__cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.ccard{
  position:relative; display:flex; flex-direction:column; justify-content:space-between; gap:28px;
  min-height:188px; padding:28px; border-radius:22px; overflow:hidden; isolation:isolate;
  background:linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.018));
  border:1px solid var(--line); backdrop-filter:blur(8px);
  transition:transform .5s var(--ease), border-color .5s var(--ease);
}
.ccard::after{ content:""; position:absolute; inset:0; z-index:-1; opacity:0;
  background:radial-gradient(120% 90% at 30% 0%, rgba(242,166,59,.16), transparent 60%);
  transition:opacity .5s var(--ease); }
.ccard:hover{ transform:translateY(-6px); border-color:var(--line-strong); }
.ccard:hover::after{ opacity:1; }
.ccard__icon{ width:52px; height:52px; border-radius:14px; display:flex; align-items:center; justify-content:center;
  background:rgba(242,166,59,.12); color:var(--gold); flex:none; }
.ccard__icon svg{ width:24px; height:24px; }
.ccard__lbl{ display:block; font-family:var(--ff-head); font-size:.74rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--muted-2); margin-bottom:7px; }
.ccard__val{ font-family:var(--ff-head); font-weight:700; font-size:1.25rem; line-height:1.2; word-break:break-word; }
.ccard__arrow{ position:absolute; top:26px; right:26px; font-size:1.15rem; color:var(--muted);
  transition:transform .4s var(--ease), color .4s var(--ease); }
.ccard:hover .ccard__arrow{ transform:translate(3px,-3px); color:var(--gold); }

.ccard--wa{ grid-column:span 2; min-height:200px;
  background:linear-gradient(135deg, rgba(37,211,102,.22), rgba(37,211,102,.05));
  border-color:rgba(37,211,102,.35); }
.ccard--wa::after{ background:radial-gradient(120% 90% at 18% 0%, rgba(37,211,102,.3), transparent 62%); }
.ccard--wa .ccard__icon{ background:#25d366; color:#fff; }
.ccard--wa .ccard__val{ font-size:1.55rem; }
.ccard--wa .ccard__arrow{ color:#25d366; }
.ccard--wa:hover{ border-color:#25d366; }

@media (max-width:1024px){
  .contact__cards{ grid-template-columns:repeat(2,1fr); }
  .ccard--wa{ grid-column:span 2; }
}
@media (max-width:640px){
  .contact__cards{ grid-template-columns:1fr; }
  .ccard--wa{ grid-column:auto; }
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--ink-2); border-top:1px solid var(--line); padding-block:64px 30px; }
.footer__top{ display:grid; grid-template-columns:1.2fr 1.8fr; gap:50px; padding-bottom:46px; border-bottom:1px solid var(--line); }
.footer__brand{ display:flex; flex-direction:column; gap:14px; }
.footer__logo{ height:42px; width:auto; align-self:flex-start; flex:none; display:block; filter:drop-shadow(0 2px 12px rgba(242,166,59,.18)); }
.footer__name{ font-family:var(--ff-head); font-weight:600; letter-spacing:.2em; text-transform:uppercase; font-size:1rem; }
.footer__name b{ color:var(--gold); font-weight:800; }
.footer__tag{ font-family:var(--ff-serif); font-style:italic; font-size:1.3rem; color:var(--muted); max-width:280px; }
.footer__cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
.footer__col h4{ font-family:var(--ff-head); font-size:.78rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-bottom:16px; }
.footer__col a, .footer__col span{ display:block; color:var(--muted); font-size:.96rem; margin-bottom:9px; transition:color .3s; }
.footer__col a:hover{ color:var(--white); }
.footer__bottom{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; padding-top:24px; color:var(--muted-2); font-size:.85rem; }
.footer__credit{ font-family:var(--ff-head); letter-spacing:.16em; text-transform:uppercase; color:var(--gold); font-size:.78rem; }

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox{
  position:fixed; inset:0; z-index:9995; background:rgba(6,6,7,.96);
  display:flex; align-items:center; justify-content:center;
  opacity:0; pointer-events:none; transition:opacity .4s var(--ease); padding:30px;
}
.lightbox.is-open{ opacity:1; pointer-events:auto; }
.lightbox__stage{ max-width:min(1100px,92vw); max-height:86vh; display:flex; flex-direction:column; align-items:center; gap:14px; }
.lightbox__stage img{ max-height:78vh; width:auto; border-radius:6px; box-shadow:0 30px 80px -20px rgba(0,0,0,.8);
  transform:scale(.96); transition:transform .4s var(--ease); }
.lightbox.is-open .lightbox__stage img{ transform:scale(1); }
.lightbox__stage figcaption{ font-family:var(--ff-serif); font-style:italic; font-size:1.2rem; color:rgba(255,255,255,.85); }
.lightbox__close{ position:absolute; top:24px; right:30px; font-size:1.6rem; color:var(--white); width:48px; height:48px;
  border:1px solid var(--line-strong); border-radius:50%; transition:.3s var(--ease); display:flex; align-items:center; justify-content:center; }
.lightbox__close:hover{ background:var(--gold); color:var(--ink); border-color:var(--gold); transform:rotate(90deg); }
.lightbox__nav{ position:absolute; top:50%; transform:translateY(-50%); font-size:2.6rem; color:var(--white);
  width:60px; height:60px; border-radius:50%; border:1px solid var(--line); transition:.3s var(--ease);
  display:flex; align-items:center; justify-content:center; line-height:0; }
.lightbox__nav:hover{ background:var(--gold); color:var(--ink); border-color:var(--gold); }
.lightbox__nav--prev{ left:24px; }
.lightbox__nav--next{ right:24px; }

/* ============================================================
   FLOATING WHATSAPP
   ============================================================ */
.wa-fab{
  position:fixed; right:24px; bottom:24px; z-index:801; width:58px; height:58px; border-radius:50%;
  background:#25d366; color:#fff; display:flex; align-items:center; justify-content:center;
  box-shadow:0 14px 34px -8px rgba(37,211,102,.6);
  transition:transform .4s var(--ease), box-shadow .4s var(--ease);
}
.wa-fab::before{
  content:""; position:absolute; inset:0; border-radius:50%; background:#25d366; z-index:-1;
  animation:waPulse 2.6s ease-out infinite;
}
@keyframes waPulse{ 0%{ transform:scale(1); opacity:.5; } 70%{ transform:scale(1.75); opacity:0; } 100%{ opacity:0; } }
.wa-fab:hover{ transform:translateY(-3px) scale(1.06); box-shadow:0 18px 40px -8px rgba(37,211,102,.7); }
.wa-fab__tip{
  position:absolute; right:72px; top:50%; transform:translateY(-50%) translateX(8px);
  background:var(--ink-2); color:#fff; font-family:var(--ff-head); font-weight:500; font-size:.8rem;
  letter-spacing:.03em; padding:.55em .9em; border-radius:8px; white-space:nowrap;
  border:1px solid var(--line); opacity:0; pointer-events:none; transition:.35s var(--ease);
}
.wa-fab__tip::after{
  content:""; position:absolute; right:-5px; top:50%; transform:translateY(-50%) rotate(45deg);
  width:9px; height:9px; background:var(--ink-2); border-right:1px solid var(--line); border-top:1px solid var(--line);
}
.wa-fab:hover .wa-fab__tip{ opacity:1; transform:translateY(-50%) translateX(0); }

/* ============================================================
   BACK TO TOP
   ============================================================ */
.totop{
  position:fixed; right:24px; bottom:92px; z-index:800; width:50px; height:50px; border-radius:50%;
  background:var(--gold); color:var(--ink); font-size:1.2rem; box-shadow:0 12px 30px -8px rgba(242,166,59,.6);
  opacity:0; transform:translateY(20px) scale(.8); pointer-events:none; transition:.4s var(--ease);
}
.totop.is-visible{ opacity:1; transform:translateY(0) scale(1); pointer-events:auto; }
.totop:hover{ transform:translateY(-3px) scale(1.05); }

@media (prefers-reduced-motion: reduce){ .wa-fab::before{ animation:none; } }

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.is-in{ opacity:1; transform:none; }
.hero__title .line.is-in > span,
.hero__title .line > span.play{ transform:translateY(0); transition:transform 1s var(--ease); }

/* img fallback styling (broken image -> branded gradient) */
img.img-broken{
  background:
    radial-gradient(120% 120% at 30% 0%, rgba(242,166,59,.25), transparent 55%),
    linear-gradient(135deg, #1a1a1e, #0d0d10);
  position:relative; min-height:200px;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .nav, .header__cta{ display:none; }
  .burger{ display:flex; }
  .gallery{ grid-template-columns:repeat(2,1fr); grid-auto-rows:220px; }
  .gcard--wide{ grid-column:span 2; }
  .svc-grid{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:repeat(2,1fr); gap:34px 24px; }
  .why__grid{ grid-template-columns:repeat(2,1fr); }
  .steps{ grid-template-columns:repeat(2,1fr); }
  .step + .step{ border-left:none; padding-left:0; }
  .step{ padding-right:20px; }
  .step::after, .step + .step::after{ left:0; }
  .studio__grid{ grid-template-columns:1fr; }
  .footer__top{ grid-template-columns:1fr; gap:40px; }
}

@media (max-width:640px){
  .section-head{ align-items:flex-start; }
  .gallery{ grid-template-columns:1fr; grid-auto-rows:280px; }
  .gcard--wide, .gcard--tall{ grid-column:auto; grid-row:auto; }
  .stats{ grid-template-columns:1fr 1fr; }
  .why__grid{ grid-template-columns:1fr; }
  .steps{ grid-template-columns:1fr; }
  .footer__cols{ grid-template-columns:1fr; gap:24px; }
  .hero__badge{ display:none; }
  .lightbox__nav{ width:46px; height:46px; font-size:2rem; }
  .lightbox__nav--prev{ left:10px; }
  .lightbox__nav--next{ right:10px; }
}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
  .reveal{ opacity:1; transform:none; }
  .hero__title .line > span{ transform:none; }
}

/* ============================================================
   ✦ ENHANCEMENTS LAYER ✦
   ============================================================ */

/* --- film grain + global ambience --- */
body::after{
  content:""; position:fixed; inset:0; z-index:9990; pointer-events:none; opacity:.05;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px 200px;
}

/* --- hero: cinematic ken-burns + gold ambience + title shimmer --- */
.hero__media{ animation:kenburns 22s var(--ease) infinite alternate; will-change:transform; }
@keyframes kenburns{ from{ transform:scale(1.02); } to{ transform:scale(1.1); } }
.hero::after{
  content:""; position:absolute; inset:0; z-index:-1; pointer-events:none;
  background:radial-gradient(60% 50% at 18% 30%, rgba(242,166,59,.16), transparent 60%);
}
.hero__title .gold > span{
  background:linear-gradient(100deg, #e0871a 0%, #f6c766 28%, #fff5e0 42%, #f6c766 56%, #e0871a 100%);
  background-size:220% 100%;
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
  animation:shimmer 6s linear infinite;
}
@keyframes shimmer{ to{ background-position:220% 0; } }

/* --- gallery 3D tilt support --- */
.gallery{ perspective:1400px; }
.gcard{ transform-style:preserve-3d; }

/* --- magnetic button smoothing --- */
.btn[data-magnetic]{ will-change:transform; }

/* ============================================================
   PACKAGES
   ============================================================ */
.packages{
  background:
    radial-gradient(50% 45% at 12% 0%, rgba(242,166,59,.08), transparent 60%),
    var(--ink);
}
.pkg-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; align-items:stretch; }
.pkg{
  position:relative; display:flex; flex-direction:column; gap:22px;
  padding:36px 30px; border-radius:22px; overflow:hidden; isolation:isolate;
  background:linear-gradient(180deg, var(--ink-3), var(--ink-2));
  border:1px solid var(--line);
  transition:transform .5s var(--ease), border-color .5s var(--ease);
}
.pkg::before{
  content:""; position:absolute; inset:0; z-index:-1; opacity:0;
  background:radial-gradient(120% 80% at 50% -10%, rgba(242,166,59,.14), transparent 60%);
  transition:opacity .5s var(--ease);
}
.pkg:hover{ transform:translateY(-6px); border-color:var(--line-strong); }
.pkg:hover::before{ opacity:1; }
.pkg--featured{
  border-color:rgba(242,166,59,.45);
  background:linear-gradient(180deg, rgba(242,166,59,.08), var(--ink-2));
  box-shadow:0 30px 70px -34px rgba(242,166,59,.5);
}
.pkg--featured::before{ opacity:1; }
.pkg__badge{
  position:absolute; top:18px; right:18px; font-family:var(--ff-head); font-weight:700;
  font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ink);
  background:var(--gold-grad); padding:.45em .8em; border-radius:100px;
}
.pkg__top{ display:flex; flex-direction:column; gap:4px; }
.pkg__name{ font-family:var(--ff-head); font-weight:800; font-size:1.5rem; }
.pkg__for{ font-family:var(--ff-head); font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted-2); }
.pkg__price{ font-family:var(--ff-serif); font-style:italic; font-size:1.7rem; color:var(--gold); }
.pkg__price span{ font-family:var(--ff-head); font-style:normal; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted-2); }
.pkg__list{ display:grid; gap:1px; border-top:1px solid var(--line); margin-top:2px; }
.pkg__list li{
  padding:11px 0 11px 24px; border-bottom:1px solid var(--line); position:relative;
  font-size:.96rem; color:rgba(255,255,255,.84);
}
.pkg__list li::before{
  content:""; position:absolute; left:2px; top:50%; width:7px; height:7px; transform:translateY(-50%) rotate(45deg);
  border:1.5px solid var(--gold); border-left:none; border-bottom:none;
}
.pkg__cta{ margin-top:auto; justify-content:center; }

/* ============================================================
   FAQ
   ============================================================ */
.faq{ background:var(--ink-2); }
.faq-list{ max-width:880px; }
.faq-item{ border-top:1px solid var(--line); }
.faq-item:last-child{ border-bottom:1px solid var(--line); }
.faq-q{
  width:100%; display:flex; align-items:center; justify-content:space-between; gap:24px;
  padding:26px 0; text-align:left; font-family:var(--ff-head); font-weight:600;
  font-size:clamp(1.05rem,2.2vw,1.4rem); color:var(--white); transition:color .3s;
}
.faq-q:hover{ color:var(--gold); }
.faq-ic{ position:relative; width:18px; height:18px; flex:none; }
.faq-ic::before, .faq-ic::after{
  content:""; position:absolute; inset:0; margin:auto; background:var(--gold); transition:transform .4s var(--ease);
}
.faq-ic::before{ width:18px; height:2px; }
.faq-ic::after{ width:2px; height:18px; }
.faq-item.is-open .faq-ic::after{ transform:rotate(90deg) scaleX(0); }
.faq-item.is-open .faq-q{ color:var(--gold); }
.faq-a{ overflow:hidden; max-height:0; transition:max-height .5s var(--ease); }
.faq-a p{ padding:0 0 26px; color:var(--muted); font-size:1.02rem; line-height:1.7; max-width:64ch; }

/* ============================================================
   INSTAGRAM FEED
   ============================================================ */
.insta{ background:var(--ink); }
.insta__head{ display:flex; align-items:flex-end; justify-content:space-between; gap:30px; flex-wrap:wrap; margin-bottom:clamp(30px,4vw,50px); }
.insta__grid{ display:grid; grid-template-columns:repeat(6,1fr); gap:10px; }
.insta__cell{
  position:relative; aspect-ratio:1/1; overflow:hidden; border-radius:14px; background:var(--ink-3);
}
.insta__cell img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease), filter .5s; filter:grayscale(.15); }
.insta__cell:hover img{ transform:scale(1.12); filter:grayscale(0); }
.insta__cell::after{
  content:""; position:absolute; inset:0; background:linear-gradient(0deg, rgba(242,166,59,.35), transparent 60%);
  opacity:0; transition:opacity .4s var(--ease);
}
.insta__cell:hover::after{ opacity:1; }
.insta__ig{
  position:absolute; inset:0; margin:auto; width:44px; height:44px; display:grid; place-items:center;
  border-radius:50%; background:rgba(11,11,13,.5); border:1px solid rgba(255,255,255,.5); color:#fff;
  opacity:0; transform:scale(.7); transition:.4s var(--ease); backdrop-filter:blur(4px);
}
.insta__ig svg{ width:22px; height:22px; }
.insta__cell:hover .insta__ig{ opacity:1; transform:scale(1); }

@media (max-width:1024px){
  .pkg-grid{ grid-template-columns:1fr; max-width:520px; margin-inline:auto; }
  .insta__grid{ grid-template-columns:repeat(3,1fr); }
}
@media (max-width:640px){
  .insta__grid{ grid-template-columns:repeat(2,1fr); }
}
