/* =====================================================
   Carté — Dark & Luxury design system
   ===================================================== */

:root{
  --bg:        #0a0a0b;
  --bg-2:      #0e0e10;
  --surface:   #141417;
  --surface-2: #1b1b1f;
  --line:      rgba(255,255,255,.08);
  --line-2:    rgba(255,255,255,.14);

  --text:      #f4f1ea;
  --muted:     #9a958c;
  --muted-2:   #6f6b63;

  --gold:      #d9b46a;
  --gold-2:    #f3d9a0;
  --gold-deep: #b8893f;
  --gold-grad: linear-gradient(135deg,#f3d9a0 0%,#d9b46a 45%,#b8893f 100%);

  --radius:    18px;
  --radius-sm: 12px;
  --maxw:      1240px;

  --ease:      cubic-bezier(.22,1,.36,1);
  --font-d:    "Playfair Display", Georgia, serif;
  --font-b:    "Manrope", system-ui, -apple-system, sans-serif;
}

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

html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; background:var(--bg); overflow-x:clip; }
html.lenis,html.lenis body{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto !important; }

body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-b);
  font-weight:400;
  line-height:1.6;
  overflow-x:clip;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

::selection{ background:var(--gold); color:#1a130a; }

/* dark themed scrollbar */
html{ scrollbar-color:var(--gold-deep) var(--bg); scrollbar-width:thin; }
::-webkit-scrollbar{ width:11px; height:11px; }
::-webkit-scrollbar-track{ background:var(--bg); }
::-webkit-scrollbar-thumb{ background:linear-gradient(var(--gold-deep),var(--gold)); border-radius:10px; border:3px solid var(--bg); }
::-webkit-scrollbar-thumb:hover{ background:var(--gold); }

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

.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(20px,5vw,48px); }

/* ---------- Typography helpers ---------- */
.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-size:.74rem; font-weight:600; letter-spacing:.28em; text-transform:uppercase;
  color:var(--gold);
}
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--gold); opacity:.6; }

.section{ position:relative; padding:clamp(80px,11vw,150px) 0; }
.section__head{ max-width:760px; margin-bottom:clamp(40px,6vw,72px); }
.section__head--row{ display:flex; align-items:flex-end; justify-content:space-between; gap:32px; max-width:none; flex-wrap:wrap; }
.section__title{
  font-family:var(--font-d); font-weight:600;
  font-size:clamp(2rem,5vw,3.4rem); line-height:1.08; letter-spacing:-.01em;
  margin-top:18px;
}
.section__title em{ font-style:italic; color:transparent; background:var(--gold-grad); -webkit-background-clip:text; background-clip:text; }

/* ---------- Buttons ---------- */
.btn{
  --pad:14px 26px;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:var(--pad); border-radius:100px; font-weight:600; font-size:.95rem;
  position:relative; overflow:hidden; transition:transform .4s var(--ease), box-shadow .4s var(--ease), background .4s var(--ease);
  white-space:nowrap;
}
.btn--lg{ --pad:17px 32px; font-size:1rem; }
.btn--block{ width:100%; }
.btn--gold{ background:var(--gold-grad); color:#160f04; box-shadow:0 10px 30px -10px rgba(217,180,106,.6); }
.btn--gold:hover{ box-shadow:0 16px 40px -10px rgba(217,180,106,.8); transform:translateY(-2px); }
.btn--ghost{ border:1px solid var(--line-2); color:var(--text); background:rgba(255,255,255,.02); backdrop-filter:blur(6px); }
.btn--ghost:hover{ border-color:var(--gold); color:var(--gold-2); transform:translateY(-2px); }
.btn svg{ transition:transform .4s var(--ease); }
.btn:hover svg{ transform:translateX(4px); }
.play-dot{ width:9px; height:9px; border-radius:50%; background:var(--gold); box-shadow:0 0 0 5px rgba(217,180,106,.18); }

/* ---------- Grain + glow ---------- */
.grain{
  position:fixed; inset:0; z-index:9; pointer-events:none; opacity:.045; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- Preloader ---------- */
.preloader{ position:fixed; inset:0; z-index:1000; background:var(--bg); display:grid; place-items:center; transition:transform 1.1s var(--ease), visibility 1.1s; will-change:transform; }
.preloader::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:1px; background:linear-gradient(90deg,transparent,var(--gold),transparent); }
.preloader.is-done{ transform:translateY(-101%); visibility:hidden; }
.preloader__inner{ display:flex; flex-direction:column; align-items:center; text-align:center; }

/* rotating gold ring + monogram */
.preloader__ring{ position:relative; width:62px; height:62px; display:grid; place-items:center; margin-bottom:30px; animation:preRise 1s var(--ease) both; }
.preloader__ring svg{ position:absolute; inset:0; width:100%; height:100%; animation:preSpin 1.5s linear infinite; }
.preloader__ring-trk{ fill:none; stroke:rgba(255,255,255,.07); stroke-width:2; }
.preloader__ring-arc{ fill:none; stroke:var(--gold); stroke-width:2; stroke-linecap:round; stroke-dasharray:163; filter:drop-shadow(0 0 6px rgba(217,180,106,.6)); animation:preArc 1.4s var(--ease) infinite alternate; }
.preloader__mark{ font-family:var(--font-d); font-size:1.4rem; color:var(--gold-2); }
@keyframes preSpin{ to{ transform:rotate(360deg); } }
@keyframes preArc{ 0%{ stroke-dashoffset:150; } 100%{ stroke-dashoffset:44; } }

/* wordmark with gold shimmer sweep */
.preloader__brand{ font-family:var(--font-d); font-size:clamp(2.6rem,7vw,4.4rem); letter-spacing:.04em; display:block;
  background:linear-gradient(100deg,var(--gold-deep) 18%,#fff5e0 50%,var(--gold-deep) 82%); background-size:220% 100%;
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent;
  animation:preRise 1s var(--ease) both, preShimmer 2.4s linear infinite; }
@keyframes preShimmer{ to{ background-position:-220% 0; } }
.preloader__tag{ display:block; margin-top:14px; font-size:.7rem; font-weight:600; letter-spacing:.4em; color:var(--muted-2); text-transform:uppercase; animation:preRise 1s var(--ease) .15s both; }

/* filling progress bar */
.preloader__bar{ display:block; width:210px; max-width:58vw; height:2px; margin-top:34px; background:rgba(255,255,255,.08); border-radius:2px; overflow:hidden; animation:preRise 1s var(--ease) .25s both; }
.preloader__bar i{ display:block; height:100%; width:0; background:var(--gold-grad); box-shadow:0 0 12px rgba(217,180,106,.7); border-radius:2px; }
@keyframes preRise{ from{ opacity:0; transform:translateY(40px); } to{ opacity:1; transform:none; } }

/* ---------- Custom cursor ---------- */
.cursor,.cursor-dot{ position:fixed; top:0; left:0; z-index:999; pointer-events:none; border-radius:50%; mix-blend-mode:difference; }
.cursor{ width:38px; height:38px; border:1px solid rgba(255,255,255,.7); transform:translate(-50%,-50%); transition:width .3s var(--ease), height .3s var(--ease), background .3s; }
.cursor-dot{ width:5px; height:5px; background:#fff; transform:translate(-50%,-50%); }
.cursor.is-hover{ width:74px; height:74px; background:rgba(255,255,255,.12); border-color:transparent; }
.cursor.is-view::after{ content:"VIEW"; font-size:.6rem; letter-spacing:.12em; font-weight:700; color:#fff; }
.cursor.is-hidden,.cursor-dot.is-hidden{ opacity:0; }
body.has-cursor *{ cursor:none; }
body.has-cursor iframe{ cursor:auto; }

/* ---------- Navbar ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  padding:18px clamp(20px,5vw,48px);
  transition:background .5s var(--ease), padding .5s var(--ease), border-color .5s;
  border-bottom:1px solid transparent;
}
.nav.is-scrolled{ background:rgba(10,10,11,.72); backdrop-filter:blur(16px) saturate(140%); padding-block:12px; border-bottom-color:var(--line); }
.nav__logo{ display:inline-flex; align-items:center; gap:10px; font-family:var(--font-d); font-size:1.45rem; letter-spacing:.02em; }
.nav__logo-mark{
  display:grid; place-items:center; width:34px; height:34px; border-radius:9px;
  background:var(--gold-grad); color:#160f04; font-weight:700; font-size:1.1rem;
  box-shadow:0 6px 18px -6px rgba(217,180,106,.7);
}
.nav__links{ display:flex; gap:30px; margin-inline:auto; }
.nav__links a{ font-size:.92rem; font-weight:500; color:var(--muted); position:relative; padding:6px 0; transition:color .3s; }
.nav__links a::after{ content:""; position:absolute; left:0; bottom:0; width:0; height:1px; background:var(--gold); transition:width .35s var(--ease); }
.nav__links a:hover{ color:var(--text); }
.nav__links a:hover::after{ width:100%; }
.nav__actions{ display:flex; align-items:center; gap:16px; }
.lang-toggle{ display:inline-flex; align-items:center; gap:5px; font-size:.82rem; font-weight:700; letter-spacing:.06em; color:var(--muted-2); }
.lang-toggle__opt{ transition:color .3s; padding:2px; }
.lang-toggle__opt.is-active{ color:var(--gold-2); }
.lang-toggle__sep{ opacity:.4; }
.nav__cta{ --pad:11px 22px; font-size:.88rem; }
.nav__burger{ display:none; flex-direction:column; gap:5px; width:34px; height:34px; align-items:center; justify-content:center; }
.nav__burger span{ width:22px; height:2px; background:var(--text); border-radius:2px; transition:.35s var(--ease); }
.nav__burger.is-open span:nth-child(1){ transform:translateY(3.5px) rotate(45deg); }
.nav__burger.is-open span:nth-child(2){ transform:translateY(-3.5px) rotate(-45deg); }

/* ---------- Hero ---------- */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; padding-top:120px; overflow:hidden; }
.hero__bg{ position:absolute; inset:0; z-index:-1; }
.hero__glow{ position:absolute; border-radius:50%; filter:blur(110px); opacity:.5; }
.hero__glow--1{ width:560px; height:560px; top:-160px; right:-80px; background:radial-gradient(circle,rgba(217,180,106,.45),transparent 70%); }
.hero__glow--2{ width:480px; height:480px; bottom:-180px; left:-120px; background:radial-gradient(circle,rgba(120,90,200,.22),transparent 70%); }
.hero__inner{ display:grid; grid-template-columns:1.15fr .85fr; align-items:center; gap:48px; width:100%; }
.hero__content{ max-width:640px; }
.hero__title{ font-family:var(--font-d); font-weight:600; font-size:clamp(2.6rem,6.4vw,5rem); line-height:1.02; letter-spacing:-.015em; margin:22px 0 26px; }
.hero__title .line{ display:block; overflow:hidden; }
.hero__title em{ font-style:italic; color:transparent; background:var(--gold-grad); -webkit-background-clip:text; background-clip:text; }
.hero__sub{ font-size:clamp(1.02rem,1.6vw,1.2rem); color:var(--muted); max-width:520px; }
.hero__cta{ display:flex; gap:16px; flex-wrap:wrap; margin:34px 0 0; }
.hero__stats{ display:flex; gap:38px; margin-top:54px; flex-wrap:wrap; }
.hero__stat{ display:flex; flex-direction:column; }
.hero__stat b{ font-family:var(--font-d); font-size:2rem; color:var(--gold-2); line-height:1; }
.hero__stat span{ font-size:.82rem; color:var(--muted-2); margin-top:6px; max-width:120px; }

/* hero visual + phone */
.hero__visual{ position:relative; display:flex; justify-content:center; align-items:center; }
.phone{
  position:relative; width:288px; aspect-ratio:9/19; border-radius:42px;
  background:linear-gradient(160deg,#26262b,#0d0d0f);
  padding:11px; box-shadow:0 50px 90px -30px rgba(0,0,0,.8), 0 0 0 1px rgba(255,255,255,.06), inset 0 0 0 2px rgba(255,255,255,.03);
}
.phone--float{ animation:floaty 6s ease-in-out infinite; }
@keyframes floaty{ 0%,100%{ transform:translateY(-8px) rotate(-2deg);} 50%{ transform:translateY(8px) rotate(2deg);} }
.phone__notch{ position:absolute; top:14px; left:50%; transform:translateX(-50%); width:96px; height:22px; background:#0a0a0b; border-radius:0 0 14px 14px; z-index:3; }
.phone__screen{ width:100%; height:100%; border-radius:32px; overflow:hidden; background:var(--bg-2); position:relative; }
.phone__frame{ width:100%; height:100%; border:0; display:block; background:var(--bg-2); border-radius:32px; }

.hero__qr{ position:absolute; bottom:6%; left:-6%; display:flex; flex-direction:column; align-items:center; gap:7px;
  background:var(--surface); border:1px solid var(--line); border-radius:16px; padding:12px; box-shadow:0 24px 50px -20px rgba(0,0,0,.8); animation:floaty 7s ease-in-out infinite reverse; }
.hero__qr span{ font-size:.64rem; font-weight:600; letter-spacing:.05em; color:var(--muted); text-transform:uppercase; }
.hero__qr-code{ width:74px; height:74px; border-radius:8px; background:#fff; padding:7px; }
.hero__qr-code canvas{ width:100%; height:100%; image-rendering:pixelated; }

.hero__scroll{ position:absolute; bottom:26px; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:9px; font-size:.66rem; letter-spacing:.22em; text-transform:uppercase; color:var(--muted-2); }
.hero__scroll i{ width:1px; height:42px; background:linear-gradient(var(--gold),transparent); position:relative; overflow:hidden; }
.hero__scroll i::after{ content:""; position:absolute; top:-50%; left:0; width:100%; height:50%; background:var(--gold-2); animation:scrolldot 1.8s ease-in-out infinite; }
@keyframes scrolldot{ to{ top:100%; } }

/* ---------- Marquee ---------- */
.marquee{ border-block:1px solid var(--line); padding:24px 0; overflow:hidden; background:var(--bg-2); }
.marquee__track{ display:flex; align-items:center; gap:34px; white-space:nowrap; width:max-content; animation:marq 32s linear infinite; }
.marquee__track span{ font-family:var(--font-d); font-size:clamp(1.4rem,3vw,2.2rem); color:var(--muted-2); transition:color .3s; }
.marquee__track i{ color:var(--gold); font-style:normal; font-size:1rem; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
.marquee__track span:hover{ color:var(--gold-2); }
@keyframes marq{ to{ transform:translateX(-50%); } }

/* ---------- Services ---------- */
.services__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.service-card{
  position:relative; padding:34px 30px 32px; border-radius:var(--radius);
  background:linear-gradient(180deg,var(--surface),var(--bg-2));
  border:1px solid var(--line); overflow:hidden;
  transition:transform .5s var(--ease), border-color .5s, box-shadow .5s;
  transform-style:preserve-3d;
}
.service-card::before{ content:""; position:absolute; inset:0; background:radial-gradient(400px circle at var(--mx,50%) var(--my,0%),rgba(217,180,106,.14),transparent 60%); opacity:0; transition:opacity .5s; }
.service-card:hover{ border-color:var(--line-2); transform:translateY(-6px); box-shadow:0 40px 70px -40px rgba(0,0,0,.9); }
.service-card:hover::before{ opacity:1; }
.service-card--feat{ background:linear-gradient(180deg,rgba(217,180,106,.08),var(--bg-2)); border-color:rgba(217,180,106,.28); }
.service-card__num{ font-family:var(--font-d); font-size:.95rem; color:var(--gold); opacity:.7; }
.service-card__icon{ width:54px; height:54px; border-radius:14px; display:grid; place-items:center; margin:16px 0 20px; background:rgba(217,180,106,.1); border:1px solid rgba(217,180,106,.2); }
.service-card__icon svg{ width:26px; height:26px; fill:none; stroke:var(--gold-2); stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round; }
.service-card h3{ font-family:var(--font-d); font-size:1.55rem; font-weight:600; margin-bottom:12px; }
.service-card p{ color:var(--muted); font-size:.95rem; margin-bottom:20px; }
.service-card__list li{ position:relative; padding-left:24px; font-size:.88rem; color:var(--muted); margin-bottom:9px; }
.service-card__list li::before{ content:"✦"; position:absolute; left:0; color:var(--gold); font-size:.7rem; top:3px; }
.service-card__tag{ position:absolute; top:20px; right:20px; font-size:.62rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:#160f04; background:var(--gold-grad); padding:5px 11px; border-radius:100px; }

/* ---------- Work / Portfolio ---------- */
.work__filters{ display:flex; gap:8px; flex-wrap:wrap; }
.work__filters button{ font-size:.85rem; font-weight:600; color:var(--muted); padding:9px 18px; border-radius:100px; border:1px solid var(--line); transition:.3s; }
.work__filters button:hover{ color:var(--text); border-color:var(--line-2); }
.work__filters button.is-active{ color:#160f04; background:var(--gold-grad); border-color:transparent; }
.work__grid{ display:grid; grid-template-columns:repeat(3,1fr); grid-auto-rows:300px; gap:18px; }
.work-card{ position:relative; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); transition:transform .5s var(--ease), opacity .5s, filter .5s; }
.work-card--tall{ grid-row:span 2; }
.work-card--wide{ grid-column:span 2; }
.work-card__img{ position:absolute; inset:0; background-size:cover; background-position:center; transition:transform .9s var(--ease); }
.work-card::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 35%,rgba(8,8,9,.92)); }
.work-card__body{ position:absolute; left:24px; bottom:22px; right:24px; z-index:2; transform:translateY(8px); opacity:.9; transition:transform .5s var(--ease), opacity .5s; }
.work-card__cat{ font-size:.68rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-2); }
.work-card__body h3{ font-family:var(--font-d); font-size:1.5rem; font-weight:600; margin:6px 0 2px; }
.work-card__body p{ font-size:.85rem; color:var(--muted); }
.work-card__go{ position:absolute; top:18px; right:18px; z-index:2; width:42px; height:42px; border-radius:50%; display:grid; place-items:center; background:rgba(255,255,255,.1); backdrop-filter:blur(6px); border:1px solid var(--line-2); font-size:1.1rem; opacity:0; transform:scale(.7) rotate(-20deg); transition:.5s var(--ease); }
.work-card:hover{ transform:translateY(-5px); }
.work-card:hover .work-card__img{ transform:scale(1.08); }
.work-card:hover .work-card__body{ transform:translateY(0); opacity:1; }
.work-card:hover .work-card__go{ opacity:1; transform:scale(1) rotate(0); }
.work-card.is-hidden{ opacity:0; filter:grayscale(1); pointer-events:none; display:none; }

/* ---------- Demo (live QR menu) ---------- */
.demo{ overflow:hidden; }
.demo__glow{ position:absolute; top:10%; right:-10%; width:600px; height:600px; border-radius:50%; filter:blur(130px); background:radial-gradient(circle,rgba(217,180,106,.18),transparent 70%); z-index:0; }
.demo__inner{ position:relative; z-index:1; display:grid; grid-template-columns:1fr 1fr; align-items:center; gap:60px; }
.demo__lead{ color:var(--muted); font-size:1.05rem; margin:22px 0 26px; max-width:480px; }
.demo__points{ margin-bottom:32px; }
.demo__points li{ display:flex; align-items:flex-start; gap:12px; margin-bottom:14px; font-size:.96rem; }
.demo__points svg{ width:22px; height:22px; flex-shrink:0; fill:none; stroke:var(--gold-2); stroke-width:2.4; stroke-linecap:round; stroke-linejoin:round; padding:4px; background:rgba(217,180,106,.12); border-radius:50%; }
.demo__device{ display:flex; justify-content:center; position:relative; }
.demo__device-glow{ position:absolute; inset:-40px; background:radial-gradient(circle,rgba(217,180,106,.16),transparent 65%); filter:blur(40px); z-index:-1; }
.phone--lg{ width:330px; }

/* ---------- Process ---------- */
.process__steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; counter-reset:s; }
.process-step{ position:relative; padding:30px 24px; border-radius:var(--radius); background:var(--surface); border:1px solid var(--line); transition:.5s var(--ease); }
.process-step:hover{ border-color:rgba(217,180,106,.3); transform:translateY(-5px); }
.process-step__num{ font-family:var(--font-d); font-size:2.6rem; color:transparent; -webkit-text-stroke:1px var(--gold-deep); display:block; margin-bottom:14px; }
.process-step h3{ font-family:var(--font-d); font-size:1.3rem; font-weight:600; margin-bottom:10px; }
.process-step p{ font-size:.9rem; color:var(--muted); }

/* ---------- Stats band ---------- */
.stats-band{ border-block:1px solid var(--line); background:linear-gradient(180deg,var(--bg-2),var(--bg)); }
.stats-band__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; padding:clamp(50px,7vw,80px) 0; }
.stat{ text-align:center; }
.stat b{ font-family:var(--font-d); font-size:clamp(2.6rem,5vw,3.8rem); background:var(--gold-grad); -webkit-background-clip:text; background-clip:text; color:transparent; line-height:1; display:block; }
.stat span{ font-size:.9rem; color:var(--muted); margin-top:10px; display:block; }

/* ---------- Testimonials ---------- */
.testimonials__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.testimonial{ padding:32px 28px; border-radius:var(--radius); background:var(--surface); border:1px solid var(--line); transition:.5s var(--ease); }
.testimonial:hover{ border-color:rgba(217,180,106,.3); transform:translateY(-5px); }
.testimonial__stars{ color:var(--gold); letter-spacing:.15em; margin-bottom:16px; font-size:.95rem; }
.testimonial blockquote{ font-family:var(--font-d); font-style:italic; font-size:1.18rem; line-height:1.5; margin-bottom:22px; }
.testimonial figcaption{ display:flex; flex-direction:column; gap:2px; }
.testimonial figcaption b{ font-weight:600; }
.testimonial figcaption span{ font-size:.82rem; color:var(--muted-2); }

/* ---------- Pricing ---------- */
.pricing__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; align-items:stretch; }
.price-card{ position:relative; display:flex; flex-direction:column; padding:36px 30px; border-radius:var(--radius); background:var(--surface); border:1px solid var(--line); transition:.5s var(--ease); }
.price-card:hover{ transform:translateY(-6px); border-color:var(--line-2); }
.price-card--feat{ background:linear-gradient(180deg,rgba(217,180,106,.1),var(--bg-2)); border-color:rgba(217,180,106,.35); box-shadow:0 40px 80px -50px rgba(217,180,106,.5); }
.price-card__badge{ position:absolute; top:-12px; left:50%; transform:translateX(-50%); font-size:.64rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:#160f04; background:var(--gold-grad); padding:6px 16px; border-radius:100px; white-space:nowrap; }
.price-card h3{ font-family:var(--font-d); font-size:1.5rem; font-weight:600; }
.price-card__desc{ font-size:.86rem; color:var(--muted-2); margin:6px 0 22px; min-height:38px; }
.price-card__price{ display:flex; align-items:baseline; gap:10px; flex-wrap:wrap; padding-bottom:8px; }
.price-card__price b{ display:inline-flex; align-items:center; gap:.4em; font-family:var(--font-b); font-style:normal; font-size:1.02rem; font-weight:600; letter-spacing:.01em; color:var(--gold-2); line-height:1.2; }
.price-card__price b::after{ content:"→"; font-size:1.05em; transition:transform .3s var(--ease); }
.price-card:hover .price-card__price b::after{ transform:translateX(4px); }
.price-card__price b em{ font-style:normal; font-family:var(--font-b); font-size:1rem; color:var(--muted-2); }
.price-card__note{ display:block; font-size:.78rem; color:var(--muted-2); padding-bottom:22px; margin-bottom:22px; border-bottom:1px solid var(--line); }
.pricing__foot{ text-align:center; max-width:680px; margin:30px auto 0; font-size:.92rem; line-height:1.6; color:var(--muted); }

/* optional care / maintenance plan band */
.care{ margin-top:28px; display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; padding:28px 32px; border-radius:var(--radius); background:linear-gradient(120deg,rgba(217,180,106,.07),var(--bg-2)); border:1px solid var(--line); }
.care__l{ max-width:600px; }
.care__tag{ font-size:.7rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); }
.care__l h3{ font-family:var(--font-d); font-size:1.55rem; font-weight:600; margin:9px 0; }
.care__l p{ color:var(--muted); font-size:.95rem; }
.care__r{ display:flex; align-items:center; gap:24px; flex-wrap:wrap; }
.care__price b{ font-family:var(--font-d); font-style:italic; font-size:1.5rem; color:var(--gold-2); line-height:1.1; display:block; }
.care__price b em{ font-style:normal; font-family:var(--font-b); font-size:.95rem; color:var(--muted); }
.care__price span{ font-size:.78rem; color:var(--muted-2); }
@media (max-width:760px){ .care{ padding:24px; } .care__r{ width:100%; justify-content:space-between; } }
.price-card ul{ flex:1; margin-bottom:26px; }
.price-card li{ position:relative; padding-left:26px; font-size:.9rem; color:var(--muted); margin-bottom:12px; }
.price-card li::before{ content:"✓"; position:absolute; left:0; color:var(--gold); font-weight:700; }

/* ---------- Contact ---------- */
.contact{ overflow:hidden; }
.contact__glow{ position:absolute; bottom:-20%; left:50%; transform:translateX(-50%); width:800px; height:500px; border-radius:50%; filter:blur(150px); background:radial-gradient(circle,rgba(217,180,106,.16),transparent 70%); }
.contact__inner{ position:relative; z-index:1; display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.contact__title{ font-family:var(--font-d); font-weight:600; font-size:clamp(2.2rem,4.5vw,3.4rem); line-height:1.08; margin:20px 0 18px; }
.contact__title em{ font-style:italic; color:transparent; background:var(--gold-grad); -webkit-background-clip:text; background-clip:text; }
.contact__lead{ color:var(--muted); font-size:1.05rem; max-width:420px; }
.contact__meta{ margin-top:30px; display:flex; flex-direction:column; gap:14px; }
.contact__meta li{ display:flex; align-items:center; gap:12px; color:var(--muted); font-size:.95rem; }
.contact__meta a{ display:inline-flex; align-items:center; gap:12px; color:var(--muted); transition:color .3s; }
.contact__meta a:hover{ color:var(--gold-2); }
.contact__meta svg{ width:20px; height:20px; fill:none; stroke:var(--gold-2); stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; }
.btn--wa{ background:linear-gradient(135deg,#34d36f,#1faa52); color:#04210f; box-shadow:0 12px 30px -12px rgba(37,211,102,.6); margin-top:24px; }
.btn--wa svg{ fill:currentColor; stroke:none; }
.btn--wa:hover{ box-shadow:0 18px 42px -12px rgba(37,211,102,.85); transform:translateY(-2px); }

.contact__form{ display:grid; grid-template-columns:1fr 1fr; gap:18px; padding:36px; border-radius:var(--radius); background:var(--surface); border:1px solid var(--line); }
.field{ position:relative; }
.field--full{ grid-column:1/-1; }
.field input,.field select,.field textarea{
  width:100%; padding:18px 16px 8px; background:var(--bg-2); border:1px solid var(--line);
  border-radius:var(--radius-sm); color:var(--text); font-family:inherit; font-size:.95rem; transition:border-color .3s, box-shadow .3s; resize:none;
}
.field textarea{ padding-top:24px; }
.field select{ padding-top:24px; appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%23d9b46a' stroke-width='1.6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 16px center; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(217,180,106,.15); }
.field label{ position:absolute; left:16px; top:14px; font-size:.95rem; color:var(--muted-2); pointer-events:none; transition:.25s var(--ease); }
.field input:focus+label,.field input:not(:placeholder-shown)+label,
.field textarea:focus+label,.field textarea:not(:placeholder-shown)+label{ top:6px; font-size:.68rem; color:var(--gold); letter-spacing:.04em; }
.field--select{ display:flex; flex-direction:column; gap:8px; }
.field--select > label{ position:static; padding-left:3px; font-size:.72rem; font-weight:600; color:var(--gold); letter-spacing:.05em; text-transform:uppercase; pointer-events:auto; }
.field--select select{ padding:15px 16px; }
.field input.invalid,.field textarea.invalid{ border-color:#e0606a; }
.contact__note{ grid-column:1/-1; font-size:.78rem; color:var(--muted-2); text-align:center; }
.contact__note.is-success{ color:#7ee0a8; }
.contact__note.is-error{ color:#ff8f8f; }

/* ---------- Footer ---------- */
.footer{ border-top:1px solid var(--line); padding-top:60px; background:var(--bg-2); }
.footer__inner{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; padding-bottom:40px; }
.footer__brand p{ color:var(--muted); font-size:.92rem; max-width:300px; margin-top:16px; }
.footer__nav,.footer__social{ display:flex; flex-direction:column; gap:12px; }
.footer__nav a,.footer__social a{ color:var(--muted); font-size:.92rem; transition:color .3s; width:fit-content; }
.footer__nav a:hover,.footer__social a:hover{ color:var(--gold-2); }
.footer__bottom{ display:flex; justify-content:space-between; align-items:center; padding:24px 0; border-top:1px solid var(--line); font-size:.8rem; color:var(--muted-2); flex-wrap:wrap; gap:10px; }

/* ---------- Reveal animations ---------- */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.is-in{ opacity:1; transform:none; }
.reveal-up{ display:inline-block; transform:translateY(110%); transition:transform 1s var(--ease); }
.is-in .reveal-up,.line.is-in .reveal-up{ transform:none; }

/* ---------- Responsive ---------- */
@media (max-width:1080px){
  .hero__inner{ grid-template-columns:1fr; gap:60px; }
  .hero__visual{ order:-1; }
  .phone--float{ width:250px; }
  .demo__inner,.contact__inner{ grid-template-columns:1fr; gap:40px; }
  .services__grid,.testimonials__grid,.pricing__grid{ grid-template-columns:1fr 1fr; }
  .work__grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:760px){
  body.has-cursor *{ cursor:auto; }
  .cursor,.cursor-dot{ display:none; }
  .nav.is-scrolled{ backdrop-filter:none; background:rgba(10,10,11,.95); }
  .nav__links{ position:fixed; inset:0; width:100%; flex-direction:column; justify-content:center; align-items:center; gap:30px; padding:90px 40px 40px; background:rgba(8,8,9,.98); backdrop-filter:blur(24px); transform:translateX(100%); transition:transform .55s var(--ease); margin:0; z-index:1; }
  .nav__links.is-open{ transform:none; }
  .nav__links a{ font-size:1.5rem; font-family:var(--font-d); color:var(--text); }
  .nav__logo,.nav__actions{ position:relative; z-index:2; }
  .nav__burger{ display:flex; }
  .nav__cta{ display:none; }
  .services__grid,.process__steps,.stats-band__grid,.testimonials__grid,.pricing__grid,.work__grid,.footer__inner{ grid-template-columns:1fr; }
  .work__grid{ grid-auto-rows:240px; }
  .work-card--tall,.work-card--wide{ grid-row:auto; grid-column:auto; }
  .contact__form{ grid-template-columns:1fr; padding:24px; }
  .section__head--row{ align-items:flex-start; }
  .hero__stats{ gap:24px; }
  .footer__bottom{ justify-content:center; text-align:center; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001s !important; transition-duration:.05s !important; }
  .reveal,.reveal-up{ opacity:1; transform:none; }
  .phone--float{ animation:none; }
}

/* =====================================================
   Interactive layer (added)
   ===================================================== */

/* scroll progress */
.scroll-progress{ position:fixed; top:0; left:0; height:3px; width:0; z-index:200; background:var(--gold-grad); box-shadow:0 0 14px rgba(217,180,106,.7); transition:width .1s linear; }

/* hero canvas particles */
.hero__canvas{ position:absolute; inset:0; width:100%; height:100%; z-index:-1; pointer-events:none; }
.webgl-on .hero__glow{ opacity:0; }

/* gold button shine sweep */
.btn--gold::after{ content:""; position:absolute; top:0; left:-130%; width:55%; height:100%; background:linear-gradient(100deg,transparent,rgba(255,255,255,.55),transparent); transform:skewX(-18deg); pointer-events:none; }
.btn--gold:hover::after{ animation:shine .9s var(--ease); }
@keyframes shine{ from{ left:-130%; } to{ left:140%; } }

/* hero rotating word */
.hero__rotator{ display:inline-flex; align-items:center; gap:10px; margin-top:26px; font-size:.95rem; color:var(--muted); font-weight:500; }
.rotator{ position:relative; display:inline-block; min-width:210px; height:1.5em; overflow:hidden; vertical-align:bottom; }
.rotator__word{ display:inline-block; font-family:var(--font-d); font-style:italic; font-size:1.25rem; line-height:1.45; color:transparent; background:var(--gold-grad); -webkit-background-clip:text; background-clip:text; will-change:transform; }
.rotator__word.animate{ animation:wordIn .6s var(--ease); }
@keyframes wordIn{ from{ transform:translateY(110%); opacity:0; } to{ transform:none; opacity:1; } }

/* image marquee band */
.img-marquee{ overflow:hidden; padding:6px 0 4px; -webkit-mask:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); mask:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); }
.img-marquee__track{ display:flex; gap:16px; width:max-content; animation:marq 48s linear infinite; will-change:transform; }
.img-marquee:hover .img-marquee__track{ animation-play-state:paused; }
.img-marquee__item{ width:clamp(200px,22vw,280px); height:clamp(140px,15vw,180px); border-radius:16px; background-size:cover; background-position:center; flex-shrink:0; border:1px solid var(--line); filter:grayscale(.35) brightness(.82); transition:filter .5s var(--ease), transform .5s var(--ease); position:relative; }
.img-marquee__item::after{ content:attr(data-label); position:absolute; left:14px; bottom:12px; font-size:.78rem; font-weight:600; letter-spacing:.04em; color:#fff; opacity:0; transform:translateY(6px); transition:.4s var(--ease); text-shadow:0 2px 8px rgba(0,0,0,.6); }
.img-marquee__item:hover{ filter:none; transform:scale(1.05); }
.img-marquee__item:hover::after{ opacity:1; transform:none; }

/* demo design switcher */
.design-switch{ display:flex; align-items:center; gap:14px; margin:24px 0 2px; flex-wrap:wrap; }
.design-switch > span{ font-size:.82rem; color:var(--muted-2); font-weight:500; }
.design-switch__tabs{ display:flex; gap:8px; }
.design-switch__tabs button{ font-size:.82rem; font-weight:600; color:var(--muted); padding:8px 16px; border-radius:100px; border:1px solid var(--line); transition:.3s; }
.design-switch__tabs button:hover{ color:var(--text); border-color:var(--line-2); }
.design-switch__tabs button.on{ color:#160f04; background:var(--gold-grad); border-color:transparent; }

/* velocity-driven skew utility */
.skewable{ will-change:transform; }

/* =====================================================
   Scroll story (pinned cinematic)
   ===================================================== */
.story{ position:relative; height:420vh; background:var(--bg); }
.story__sticky{ position:sticky; top:0; height:100vh; overflow:hidden; }
.story__scene{ position:absolute; inset:0; display:flex; align-items:center; }
.story__bg{ position:absolute; inset:0; background-size:cover; background-position:center; opacity:0; transform:scale(1.16); filter:brightness(.4) saturate(.92); transition:opacity 1.1s var(--ease); will-change:opacity,transform; }
.story__scene.is-active .story__bg{ opacity:1; animation:kenburns 9s var(--ease) forwards; }
@keyframes kenburns{ from{ transform:scale(1.16); } to{ transform:scale(1.0); } }
.story__veil{ position:absolute; inset:0; background:linear-gradient(90deg,rgba(7,7,8,.94) 0%,rgba(7,7,8,.6) 55%,rgba(7,7,8,.15) 100%); }
.story__veil::after{ content:""; position:absolute; inset:0; background:linear-gradient(0deg,rgba(7,7,8,.7),transparent 40%); }
.story__qr{ position:absolute; inset:0; width:100%; height:100%; opacity:0; transition:opacity 1.1s var(--ease); background:#070708; }
.story__scene--qr.is-active .story__qr{ opacity:1; }
.story__veil--qr{ background:linear-gradient(90deg,rgba(7,7,8,.5) 0%,rgba(7,7,8,.22) 50%,rgba(7,7,8,.05) 100%); }
.story__veil--qr::after{ background:radial-gradient(58% 80% at 22% 56%,rgba(7,7,8,.85) 0%,rgba(7,7,8,.45) 36%,transparent 64%); }
.story__body{ position:relative; z-index:2; width:100%; opacity:0; transform:translateY(48px); transition:opacity .9s var(--ease) .15s, transform .9s var(--ease) .15s; text-shadow:0 0 30px rgba(7,7,8,.85), 0 2px 10px rgba(0,0,0,.6); }
.story__scene.is-active .story__body{ opacity:1; transform:none; }
.story__step{ font-family:var(--font-d); font-weight:600; font-size:clamp(6.5rem,19vw,15rem); line-height:.82; color:transparent; -webkit-text-stroke:1.5px var(--gold-deep); display:block; margin-bottom:6px; opacity:.55; letter-spacing:-.02em; }
.story__body h3{ font-family:var(--font-d); font-weight:600; font-size:clamp(2.2rem,5.6vw,4.6rem); line-height:1.04; letter-spacing:-.01em; margin-bottom:20px; max-width:760px; }
.story__body h3 em{ font-style:italic; color:transparent; background:var(--gold-grad); -webkit-background-clip:text; background-clip:text; }
.story__body p{ font-size:clamp(1rem,1.5vw,1.25rem); color:var(--muted); max-width:500px; }
.story__label{ position:absolute; top:clamp(26px,7vh,64px); left:0; right:0; z-index:3; }
.story__label .container,.story__label{ padding-inline:clamp(20px,5vw,48px); }
.story__rail{ position:absolute; right:clamp(20px,4vw,48px); top:50%; transform:translateY(-50%); width:2px; height:min(220px,32vh); background:var(--line); z-index:3; border-radius:2px; overflow:hidden; }
.story__rail i{ position:absolute; inset:0; background:var(--gold-grad); transform:scaleY(0); transform-origin:top; }
@media (max-width:760px){
  .story{ height:380vh; }
  .story__veil{ background:linear-gradient(0deg,rgba(7,7,8,.96),rgba(7,7,8,.5)); }
  .story__veil--qr{ background:linear-gradient(0deg,rgba(7,7,8,.5) 0%,rgba(7,7,8,.16) 50%,rgba(7,7,8,.04) 100%); }
  .story__veil--qr::after{ background:radial-gradient(78% 52% at 50% 52%,rgba(7,7,8,.72) 0%,transparent 72%); }
  .story__rail{ display:none; }
}

/* =====================================================
   Experience — cursor + scroll signature dish
   ===================================================== */
.exp{ position:relative; height:360vh; background:var(--bg); }
.exp__stage{ position:sticky; top:0; height:100vh; overflow:hidden; display:grid; place-items:center; perspective:1200px; }
.exp__glow{ position:absolute; width:96vmin; height:96vmin; border-radius:50%; filter:blur(95px); opacity:0; transition:opacity 1.1s var(--ease); pointer-events:none; }
.exp__glow.is-on{ opacity:.6; }
.exp__glow--0{ background:radial-gradient(circle,#d9b46a,transparent 64%); }
.exp__glow--1{ background:radial-gradient(circle,#2fa37a,transparent 64%); }
.exp__glow--2{ background:radial-gradient(circle,#e08aa0,transparent 64%); }
.exp__glow--3{ background:radial-gradient(circle,#e8a23a,transparent 64%); }
.exp__glow--4{ background:radial-gradient(circle,#7b8cff,transparent 64%); }
.exp__eyebrow{ position:absolute; top:clamp(88px,13vh,130px); left:50%; transform:translateX(-50%); z-index:4; }
.exp__labels{ position:absolute; inset:0; z-index:3; pointer-events:none; }
.exp__label{ position:absolute; left:50%; top:50%; transform:translate(-50%,-50%) translate(var(--x),var(--y)); font-family:var(--font-d); font-style:italic; font-size:clamp(.95rem,1.8vw,1.5rem); color:var(--gold-2); opacity:.72; white-space:nowrap; will-change:margin; text-shadow:0 2px 16px rgba(0,0,0,.6); }
.exp__tilt{ position:relative; width:min(58vmin,480px); aspect-ratio:1; transform-style:preserve-3d; will-change:transform; transition:transform .25s var(--ease); }
.exp__disc{ position:absolute; inset:0; will-change:transform; }
.exp__plate{ position:absolute; inset:0; border-radius:50%; background-size:cover; background-position:center; opacity:0; transition:opacity 1s var(--ease); box-shadow:0 60px 120px -34px rgba(0,0,0,.85), inset 0 0 0 1px rgba(255,255,255,.08); }
.exp__plate.is-on{ opacity:1; }
.exp__ring{ position:absolute; inset:-3.5%; border-radius:50%; border:1px solid rgba(217,180,106,.28); pointer-events:none; }
.exp__orbit{ position:absolute; inset:-6%; border-radius:50%; pointer-events:none; z-index:2; will-change:transform; }
.exp__orbit i{ position:absolute; top:-5px; left:50%; margin-left:-5px; width:10px; height:10px; border-radius:50%; background:var(--gold-2); box-shadow:0 0 18px 3px rgba(243,217,160,.6); }
.exp__counter{ position:absolute; right:clamp(20px,5vw,64px); top:50%; transform:translateY(-50%); z-index:4; text-align:right; line-height:1; }
.exp__counter b{ font-family:var(--font-d); font-weight:600; font-size:clamp(2.2rem,4.5vw,3.6rem); color:var(--gold-2); display:block; }
.exp__counter span{ font-size:.72rem; color:var(--muted-2); letter-spacing:.14em; }
.exp__dish{ font-family:var(--font-d); font-style:italic; font-size:clamp(.95rem,1.6vw,1.2rem); color:var(--gold-2); opacity:.85; letter-spacing:.02em; margin-bottom:10px; }
.exp__copy{ position:absolute; left:0; right:0; bottom:clamp(8vh,11vh,130px); z-index:4; text-align:center; padding-inline:24px; }
.exp__titles{ position:relative; min-height:2.5em; font-size:clamp(1.9rem,5vw,3.4rem); margin-bottom:16px; }
.exp__title{ position:absolute; left:0; right:0; top:0; font-family:var(--font-d); font-weight:600; font-size:1em; line-height:1.1; letter-spacing:-.01em; opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.exp__title.is-on{ opacity:1; transform:none; }
.exp__title em{ font-style:italic; color:transparent; background:var(--gold-grad); -webkit-background-clip:text; background-clip:text; }
.exp__sub{ color:var(--muted); font-size:clamp(.95rem,1.5vw,1.1rem); max-width:440px; margin-inline:auto; }
.exp__hint{ position:absolute; bottom:24px; left:50%; transform:translateX(-50%); z-index:4; font-size:.66rem; letter-spacing:.24em; text-transform:uppercase; color:var(--muted-2); }
@media (max-width:760px){
  .exp{ height:300vh; }
  .exp__tilt{ width:74vmin; }
  .exp__label{ font-size:.82rem; opacity:.6; }
  .exp__copy{ bottom:8vh; }
  .exp__counter{ display:none; }
}

/* ============ Craft / physical formats — 3D flip showcase ============ */
.craft{
  --c-surface:#141417; --c-surface-2:#1b1b1f; --c-hair:rgba(255,255,255,.08);
  --c-text:#f4f1ea; --gold-light:#f3d9a0;
  position:relative; padding:clamp(5rem,10vh,9rem) 0 0; background:var(--bg);
}
.craft::before{ content:""; position:absolute; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(60% 50% at 12% 0%, rgba(217,180,106,.07), transparent 60%),
    radial-gradient(50% 45% at 100% 100%, rgba(184,137,63,.06), transparent 60%); }
.craft__inner{ position:relative; z-index:1; }

.craft__head{ max-width:46rem; margin:0 auto clamp(1rem,3vh,2.5rem); }
.craft__title{ margin:.6rem 0 1.2rem; }
.craft__title em{ font-style:italic; background:var(--gold-grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.craft__lede{ color:var(--muted); font-size:clamp(1rem,1.15vw,1.18rem); line-height:1.7; max-width:38rem; }

/* tall scroll track that pins the rotating stage */
.craft__scroll{ position:relative; height:400vh; z-index:1; }
.craft__pin{ position:sticky; top:0; height:100svh; display:grid; place-items:center; overflow:hidden; }
.craft__layout{ display:grid; grid-template-columns:1.05fr .95fr; align-items:center; gap:clamp(2rem,5vw,5rem); width:100%; }

/* the 3D stage + rotating coin */
.craft__stage{ position:relative; display:grid; place-items:center; perspective:1600px; }
.craft__stage::after{ content:""; position:absolute; width:78%; height:26%; left:11%; bottom:6%; z-index:0;
  background:radial-gradient(ellipse at center, rgba(217,180,106,.20), transparent 70%); filter:blur(22px); }
.craft__rotor{ position:relative; width:min(90%,540px); aspect-ratio:520/400; transform-style:preserve-3d; will-change:transform; z-index:1; }
.craft__face{ position:absolute; inset:0; backface-visibility:hidden; -webkit-backface-visibility:hidden;
  border-radius:20px; overflow:hidden; display:grid; place-items:center;
  background:radial-gradient(120% 120% at 30% 20%, var(--c-surface-2), var(--c-surface));
  border:1px solid var(--c-hair); box-shadow:0 50px 100px -45px rgba(0,0,0,.85), 0 0 0 1px rgba(217,180,106,.06); }
.craft__face--back{ transform:rotateY(180deg); }
.craft__face svg{ width:94%; height:94%; display:block; }

/* copy panel (updates per object) */
.craft__copy{ max-width:30rem; --lop:1; }
.craft__index{ display:block; font-family:var(--font-d); font-size:clamp(2.4rem,4vw,3.6rem); line-height:1; color:transparent; background:var(--gold-grad); -webkit-background-clip:text; background-clip:text; opacity:.9; letter-spacing:-.02em; margin-bottom:1rem; }
.craft__copy .craft__index, .craft__copy .craft__name, .craft__copy .craft__desc, .craft__copy .craft__tag{ opacity:var(--lop); transition:opacity .12s linear; }
.craft__name{ font-family:var(--font-d); color:var(--c-text); font-size:clamp(1.6rem,2.6vw,2.3rem); line-height:1.15; margin:0 0 .7rem; }
.craft__desc{ color:var(--muted); font-size:1.05rem; line-height:1.65; margin:0 0 1.3rem; max-width:30rem; }
.craft__tag{ display:inline-flex; align-items:center; gap:.5ch; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-light); padding:.45rem .9rem; border:1px solid rgba(217,180,106,.25); border-radius:999px; background:rgba(217,180,106,.04); }
.craft__dots{ display:flex; gap:12px; margin-top:2rem; }
.craft__dot{ width:9px; height:9px; border-radius:50%; background:var(--c-hair); cursor:pointer; transition:transform .3s var(--ease), background .3s, box-shadow .3s; }
.craft__dot:hover{ background:rgba(217,180,106,.5); }
.craft__dot.on{ background:var(--gold); box-shadow:0 0 0 5px rgba(217,180,106,.12); transform:scale(1.15); }

.craft__hint{ position:absolute; bottom:22px; left:50%; transform:translateX(-50%); font-size:.62rem; letter-spacing:.22em; text-transform:uppercase; color:var(--muted-2); display:flex; align-items:center; gap:9px; opacity:.65; }
.craft__hint::after{ content:""; width:26px; height:1px; background:linear-gradient(90deg,var(--gold),transparent); }

.craft__cta{ margin:clamp(3rem,6vh,5rem) auto 0; text-align:center; display:flex; flex-direction:column; align-items:center; gap:1.6rem; padding-bottom:clamp(3rem,7vh,6rem); }
.craft__cta-line{ font-family:var(--font-d); font-style:italic; font-size:clamp(1.4rem,2.6vw,2.2rem); color:var(--c-text); line-height:1.3; max-width:24ch; }
.craft__cta-btn{ display:inline-flex; align-items:center; gap:.9ch; font-size:.84rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:#0a0a0b; padding:1rem 1.8rem; border-radius:999px; background:var(--gold-grad); transition:transform .5s var(--ease), filter .5s ease; }
.craft__cta-btn:hover{ transform:translateY(-3px); filter:brightness(1.06); }
.craft__cta-arrow{ transition:transform .5s var(--ease); }
.craft__cta-btn:hover .craft__cta-arrow{ transform:translateX(4px); }

@media (max-width:860px){
  .craft__layout{ grid-template-columns:1fr; gap:1.6rem; justify-items:center; text-align:center; }
  .craft__rotor{ width:min(88%,420px); }
  .craft__stage{ order:1; }
  .craft__copy{ order:2; }
  .craft__dots{ justify-content:center; }
  .craft__desc{ margin-inline:auto; }
}
@media (prefers-reduced-motion: reduce){
  .craft__scroll{ height:auto; }
  .craft__pin{ position:static; height:auto; padding:2rem 0 3rem; overflow:visible; }
  .craft__rotor{ transform:none !important; }
  .craft__face--back{ display:none; }
  .craft__hint{ display:none; }
}
