:root{--black:#000;--ink:#1d1d1f;--muted:rgba(0,0,0,.64);--paper:#f5f5f7;--white:#fff;--blue:#946b2d;--blue2:#d8b26e;--gold:#d8b26e;--surface:#171719;--line:rgba(255,255,255,.14);--radius:18px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--paper);color:var(--ink)}a{color:inherit;text-decoration:none}.nav{position:fixed;z-index:20;top:0;left:0;right:0;height:52px;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(18px,4vw,56px);background:rgba(0,0,0,.8);backdrop-filter:saturate(180%) blur(20px);color:white}.brand{font-weight:650;letter-spacing:-.02em}.navlinks{display:flex;gap:22px;align-items:center;font-size:13px;color:rgba(255,255,255,.82)}.nav-cta{border:1px solid rgba(255,255,255,.35);border-radius:999px;padding:7px 13px}.section-black,.scene.dark{background:#000;color:white}.hero{min-height:100svh;display:grid;grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);gap:clamp(32px,6vw,80px);align-items:center;padding:96px clamp(22px,5vw,80px) 56px}.eyebrow{text-transform:uppercase;letter-spacing:.16em;color:var(--gold);font-size:12px;font-weight:700;margin:0 0 18px}.eyebrow.dark{color:#8b6a31}h1,h2,h3,p{margin-top:0}h1{font-size:clamp(44px,7.1vw,92px);line-height:.99;letter-spacing:-.07em;margin-bottom:30px;max-width:1040px}h2{font-size:clamp(34px,5vw,68px);line-height:1.02;letter-spacing:-.055em;margin-bottom:18px}h3{font-size:22px;letter-spacing:-.03em}.subhead,.lead{font-size:clamp(18px,2vw,24px);line-height:1.38;color:rgba(255,255,255,.74);max-width:760px}.lead{color:rgba(0,0,0,.64)}.lead.inverted{color:rgba(255,255,255,.7)}.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:34px}.button{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:13px 20px;font-weight:600;border:1px solid transparent;min-height:48px;cursor:pointer}.button.primary{background:var(--blue);color:white}.button.secondary{border-color:rgba(255,255,255,.44);color:white}.button.full{width:100%;margin-top:16px}.hero-facts{display:flex;gap:10px;flex-wrap:wrap;margin-top:32px}.hero-facts span{font-size:12px;color:rgba(255,255,255,.74);border:1px solid var(--line);border-radius:999px;padding:8px 10px}.hero-card{display:flex;justify-content:center}.campaign-frame{width:min(620px,100%);border-radius:38px;overflow:hidden;background:#111;border:1px solid rgba(255,255,255,.16);box-shadow:0 30px 80px rgba(0,0,0,.55);position:relative}.campaign-frame img{display:block;width:100%;aspect-ratio:14/9;object-fit:cover}.campaign-caption{position:absolute;left:18px;right:18px;bottom:18px;border:1px solid rgba(255,255,255,.18);border-radius:22px;background:rgba(0,0,0,.58);backdrop-filter:blur(16px);padding:16px}.campaign-caption span{display:block;color:var(--gold);font-size:12px;text-transform:uppercase;letter-spacing:.14em;font-weight:750}.campaign-caption strong{display:block;color:white;font-size:20px;letter-spacing:-.03em;margin-top:5px}.phone-shell{width:min(390px,100%);padding:14px;border-radius:38px;background:#111;border:1px solid rgba(255,255,255,.16);box-shadow:0 30px 80px rgba(0,0,0,.55)}.status-row{height:26px;display:flex;gap:5px;justify-content:center}.status-row span{width:5px;height:5px;background:rgba(255,255,255,.38);border-radius:50%}.look-preview{height:310px;border-radius:28px;background:linear-gradient(135deg,#27221a,#0d0d0e);display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:10px}.portrait{border-radius:22px;background:radial-gradient(circle at 50% 24%,#9d6e4a 0 14%,#4a2e22 15% 26%,#1b1514 27% 100%)}.portrait-b{background:radial-gradient(circle at 50% 24%,#9d6e4a 0 14%,#26160f 15% 23%,#0f0d0c 24% 100%)}.phone-shell h2{font-size:28px;margin:20px 10px 8px}.phone-shell p{margin:7px 10px;color:rgba(255,255,255,.72)}.mini-total{font-size:30px;font-weight:750;margin:18px 10px}.phone-shell button{width:calc(100% - 20px);margin:0 10px 8px;border:0;background:white;color:#111;border-radius:999px;padding:14px;font-weight:700}.scene{padding:clamp(72px,10vw,140px) clamp(22px,5vw,80px)}.scene.light{background:var(--paper)}.steps,.style-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:38px}.steps article,.style-card{background:white;border-radius:var(--radius);padding:26px;min-height:210px}.steps span{color:#a5762d;font-weight:800}.steps p,.style-card p{color:var(--muted);line-height:1.5}.style-card{background:#151517;color:white;border:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;justify-content:space-between;cursor:pointer;transition:border-color .18s ease,transform .18s ease}.style-card:hover,.style-card:focus-visible{border-color:rgba(216,178,110,.4);transform:translateY(-2px);outline:none}.style-card:active{transform:translateY(0)}.style-card p{color:rgba(255,255,255,.62)}.style-meta{display:flex;justify-content:space-between;gap:8px;color:var(--gold);font-weight:700;font-size:14px;margin-top:18px}.style-card-cta{display:block;color:var(--gold);font-size:13px;font-weight:700;margin-top:10px;opacity:.72;transition:opacity .18s ease}.style-card:hover .style-card-cta,.style-card:focus-visible .style-card-cta{opacity:1}.ai-panel,.quote-scene,.booking-scene{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,70px);align-items:start}.upload-box,.quote-app,.booking-form{background:white;border-radius:26px;padding:28px;box-shadow:0 24px 70px rgba(0,0,0,.08)}.booking-form{background:#151517;border:1px solid rgba(255,255,255,.1)}label{display:block;font-weight:650;margin-bottom:16px}input,select,textarea{width:100%;margin-top:8px;border:1px solid rgba(0,0,0,.14);border-radius:14px;padding:14px 14px;font:inherit;background:#fff;color:#111}textarea{min-height:110px;resize:vertical}.booking-form input,.booking-form textarea{background:#0f0f10;border-color:rgba(255,255,255,.16);color:white}.toggle-row{display:flex;gap:10px;align-items:center}.toggle-row input{width:auto}.result-card{background:#f5f5f7;border-radius:20px;padding:18px;display:grid;gap:12px}.result-card div{display:flex;justify-content:space-between;gap:20px;border-bottom:1px solid rgba(0,0,0,.08);padding-bottom:10px}.result-card div:last-child{border-bottom:0}.result-card span{color:rgba(0,0,0,.56)}.result-card strong{font-size:18px;text-align:right}.split{display:grid;grid-template-columns:1fr 1fr;gap:12px}.file-card{display:flex;align-items:center;gap:14px;border:1px solid rgba(0,0,0,.12);border-radius:18px;padding:18px;background:#fafafa;cursor:pointer;transition:.18s ease}.file-card:hover{border-color:rgba(148,107,45,.45);background:#fff}.file-card-text{flex:1;min-width:0}.file-card span,.file-card-text span{display:block;color:rgba(0,0,0,.56);font-size:13px;margin-bottom:7px}.file-card strong,.file-card-text strong{display:block;font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-card input{position:absolute;opacity:0;pointer-events:none;width:1px;height:1px}.file-thumb{width:52px;height:52px;border-radius:12px;background:rgba(0,0,0,.04);background-size:cover;background-position:center;flex-shrink:0;transition:.2s ease}.file-thumb.has-image{box-shadow:0 2px 12px rgba(0,0,0,.12)}.status-text{font-size:14px;color:rgba(0,0,0,.58);margin:12px 0 0}.status-text.inverted{color:rgba(255,255,255,.58)}.ohnohoney{position:absolute;left:-9999px;height:0;overflow:hidden}@media(max-width:900px){.navlinks a:not(.nav-cta){display:none}.hero,.ai-panel,.quote-scene,.booking-scene{grid-template-columns:1fr}.steps,.style-grid{grid-template-columns:1fr 1fr}.hero{padding-top:88px}h1{font-size:clamp(48px,14vw,72px)}}@media(max-width:560px){.steps,.style-grid{grid-template-columns:1fr}.scene{padding-inline:18px}.split{grid-template-columns:1fr}.phone-shell{border-radius:28px}.look-preview{height:240px}.nav{padding-inline:14px}}

/* Hero AI try-on first step */
.hero-preview-card { width: 100%; }
.hero-preview-panel {
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 2rem;
  padding: clamp(.85rem, 2vw, 1rem);
  background: linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.05));
  box-shadow: 0 2rem 5rem rgba(0,0,0,.38);
  backdrop-filter: blur(18px);
}
.hero-preview-topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: .35rem .35rem .85rem;
  color: #fff;
}
.hero-preview-topline span {
  color: var(--gold);
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: .68rem;
  font-weight: 850;
}
.hero-preview-topline strong { font-size: 1.15rem; letter-spacing: -.035em; }
.hero-preview-photo {
  position: relative;
  overflow: hidden;
  border-radius: 1.55rem;
  background: #111;
  aspect-ratio: 4 / 5;
}
.hero-preview-photo img { width: 100%; height: 100%; object-fit: cover; display: block; filter: saturate(1.04) contrast(1.03); }
.hero-preview-photo-overlay {
  position: absolute;
  left: .75rem;
  right: .75rem;
  bottom: .75rem;
  border-radius: 1.05rem;
  padding: .85rem;
  background: rgba(0,0,0,.72);
  color: #fff;
  backdrop-filter: blur(16px);
}
.hero-preview-photo-overlay span { display: block; color: var(--gold); font-size: .68rem; font-weight: 850; letter-spacing: .11em; text-transform: uppercase; margin-bottom: .2rem; }
.hero-preview-photo-overlay strong { font-size: 1.1rem; letter-spacing: -.03em; }
.hero-preview-controls {
  display: grid;
  gap: .75rem;
  padding-top: .85rem;
}
.hero-preview-controls label { color: rgba(255,255,255,.78); font-weight: 750; font-size: .88rem; }
.hero-preview-controls select {
  width: 100%;
  margin-top: .35rem;
  background: rgba(255,255,255,.95);
  color: #111;
  border: 0;
}
.hero-file-card {
  border-color: rgba(255,255,255,.18);
  background: rgba(255,255,255,.1);
  color: #fff;
}
.hero-file-card .file-card-text span { color: rgba(255,255,255,.62); }
.hero-file-card .file-card-text strong { color: #fff; }
.hero-preview-note {
  color: rgba(255,255,255,.58);
  font-size: .82rem;
  line-height: 1.4;
  margin: 0;
}
@media(max-width:720px){
  .hero-preview-panel { border-radius: 1.5rem; }
  .hero-preview-photo { aspect-ratio: 5 / 4; border-radius: 1.2rem; }
  .hero-preview-topline { align-items: flex-start; flex-direction: column; gap: .25rem; }
}

/* AI preview intake fields */
.upload-box input[type="text"],
.upload-box input[type="tel"],
.upload-box select {
  margin-bottom: 4px;
}

/* Public-ready form/privacy details */
.file-card input[type="file"] {
  position: absolute;
  inline-size: 1px;
  block-size: 1px;
  opacity: 0;
  pointer-events: none;
}
.ohnohoney {
  position: absolute;
  left: -9999px;
  inline-size: 1px;
  block-size: 1px;
  overflow: hidden;
}

/* Mobile-first conversion layer */
.mobile-sticky-cta{display:none}
@media(max-width:720px){
  body{padding-bottom:calc(108px + env(safe-area-inset-bottom))}
  .nav{height:58px;padding-inline:16px}.brand{font-size:15px}.navlinks{gap:8px}.nav-cta{background:#fff;color:#111;border-color:#fff;padding:8px 12px}.navlinks a:not(.nav-cta){display:none}
  .hero{min-height:auto;display:flex;flex-direction:column;padding:86px 16px 34px;gap:24px}.hero-copy{width:100%}
  .eyebrow{font-size:10px;letter-spacing:.14em;margin-bottom:14px}h1{font-size:clamp(42px,13.2vw,58px);line-height:.98;letter-spacing:-.058em;margin-bottom:18px;text-wrap:balance}.subhead{font-size:18px;line-height:1.36}.actions{display:grid;grid-template-columns:1fr;gap:10px;margin-top:24px}.button{width:100%;min-height:52px}.hero-facts{display:grid;grid-template-columns:1fr;gap:8px;margin-top:20px}.hero-facts span{text-align:center;font-size:12px;color:rgba(255,255,255,.86);padding:10px 12px}
  .campaign-frame{border-radius:28px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.45)}.campaign-frame img{aspect-ratio:4/5}.campaign-caption{left:12px;right:12px;bottom:12px;border-radius:18px;padding:13px}.campaign-caption strong{font-size:17px}.campaign-caption span{font-size:10px}
  .scene{padding:58px 16px}h2{font-size:clamp(32px,10vw,44px);line-height:1.02}.lead{font-size:17px}.steps,.style-grid{grid-template-columns:1fr;gap:10px;margin-top:26px}.steps article,.style-card{min-height:auto;border-radius:18px;padding:20px}.style-meta{font-size:13px}
  .ai-panel,.quote-scene,.booking-scene{grid-template-columns:1fr;gap:22px}.upload-box,.quote-app,.booking-form{border-radius:22px;padding:18px}.result-card div{display:grid;grid-template-columns:1fr;gap:4px}.result-card strong{text-align:left;font-size:22px}.split{grid-template-columns:1fr}input,select,textarea{font-size:16px;min-height:52px}.file-card{padding:16px}.mobile-sticky-cta{position:fixed;left:10px;right:10px;bottom:calc(10px + env(safe-area-inset-bottom));z-index:30;display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:8px;border-radius:999px;background:rgba(0,0,0,.78);backdrop-filter:blur(18px);box-shadow:0 10px 36px rgba(0,0,0,.28);transform:translateY(130%);opacity:0;pointer-events:none;transition:.22s ease}.mobile-sticky-cta.is-visible{transform:translateY(0);opacity:1;pointer-events:auto}.mobile-sticky-cta a{min-height:48px;border-radius:999px;display:flex;align-items:center;justify-content:center;font-weight:750}.mobile-sticky-cta a:first-child{color:white;border:1px solid rgba(255,255,255,.22)}.mobile-sticky-cta a:last-child{background:var(--blue);color:white}
}
@media(min-width:721px){.mobile-sticky-cta{display:none!important}}

/* WhatsApp floating action button */
.whatsapp-fab{position:fixed;z-index:25;bottom:calc(24px + env(safe-area-inset-bottom));right:20px;width:56px;height:56px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.4);transform:translateY(150%);opacity:0;pointer-events:none;transition:transform .2s ease,box-shadow .2s ease,opacity .2s ease}.whatsapp-fab.is-visible{transform:translateY(0);opacity:1;pointer-events:auto}.whatsapp-fab.is-visible:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(37,211,102,.55)}
@media(max-width:720px){.whatsapp-fab{bottom:calc(80px + env(safe-area-inset-bottom));right:14px;width:52px;height:52px}.whatsapp-fab.is-visible:hover{transform:scale(1.08)}}

/* Public-ready trust, zones, FAQ, and footer polish */
.zone-grid,
.trust-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(260px, 100%), 1fr));
  gap: clamp(0.875rem, 2vw, 1.25rem);
  margin-top: clamp(1.5rem, 4vw, 2.5rem);
}
.zone-card,
.trust-card {
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 1.375rem;
  padding: clamp(1.125rem, 3vw, 1.625rem);
  background: rgba(255,255,255,.68);
  box-shadow: 0 1.25rem 3.75rem rgba(0,0,0,.06);
}
.scene.dark .trust-card {
  border-color: rgba(255,255,255,.13);
  background: rgba(255,255,255,.06);
  box-shadow: none;
}
.zone-card h3,
.trust-card h3 { margin-bottom: .625rem; }
.zone-card p,
.trust-card p { color: rgba(0,0,0,.64); line-height: 1.55; margin-bottom: 0; }
.scene.dark .trust-card p { color: rgba(255,255,255,.68); }
.faq-list { display: grid; gap: .75rem; margin-top: clamp(1.5rem, 4vw, 2.5rem); max-width: 58rem; }
.faq-item { border: 1px solid rgba(0,0,0,.1); border-radius: 1.125rem; background: rgba(255,255,255,.74); overflow: hidden; }
.faq-item summary { min-height: 3.25rem; display: flex; align-items: center; padding: 1rem 1.125rem; cursor: pointer; font-weight: 750; letter-spacing: -.02em; }
.faq-item p { padding: 0 1.125rem 1.125rem; color: rgba(0,0,0,.66); line-height: 1.56; margin: 0; }
.site-footer { background: #050505; color: #fff; padding: clamp(2rem, 5vw, 4rem) clamp(1rem, 5vw, 5rem) calc(1.25rem + env(safe-area-inset-bottom)); }
.footer-inner { display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(12rem, .8fr) minmax(12rem, .7fr); gap: clamp(1.5rem, 4vw, 3rem); align-items: start; }
.footer-brand p,
.footer-contact p,
.footer-legal p { color: rgba(255,255,255,.62); line-height: 1.5; }
.footer-links { display: grid; gap: .65rem; }
.footer-links a { color: rgba(255,255,255,.78); min-height: 2.75rem; display: inline-flex; align-items: center; }
.footer-links a:hover { color: #fff; }
.footer-legal { border-top: 1px solid rgba(255,255,255,.12); margin-top: 2rem; padding-top: 1rem; }
@media (max-width: 720px) {
  .zone-grid,
  .trust-grid { grid-template-columns: 1fr; gap: .75rem; }
  .zone-card,
  .trust-card { border-radius: 1.125rem; padding: 1.125rem; }
  .faq-item summary { min-height: 3.5rem; }
  .footer-inner { grid-template-columns: 1fr; gap: 1.25rem; }
}

/* Booking quote summary card */
.booking-quote-summary {
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 16px;
  padding: 14px;
  margin-bottom: 16px;
  background: rgba(255,255,255,.04);
}
.bqs-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 6px 0;
}
.bqs-row + .bqs-row {
  border-top: 1px solid rgba(255,255,255,.08);
}
.bqs-row span {
  color: rgba(255,255,255,.54);
  font-size: 13px;
}
.bqs-row strong {
  color: var(--gold);
  font-size: 15px;
}

/* Quote section CTA styles */
.quote-deposit-info {
  font-size: 13px;
  color: rgba(0,0,0,.52);
  margin: 10px 0 0;
  text-align: center;
  line-height: 1.4;
}
/* Quote section primary — funnels to booking form for lead capture */
.quote-reserve-cta {
  width: 100%;
  gap: 10px;
  margin-top: 16px;
  background: var(--blue);
  color: #fff;
  font-weight: 700;
  font-size: 16px;
  border: none;
  transition: background .18s ease, transform .18s ease;
}
.quote-reserve-cta:hover {
  background: #7a5924;
  transform: scale(1.02);
}
/* Quote section secondary — direct WhatsApp fallback */
.quote-wa-direct {
  width: 100%;
  margin-top: 10px;
  gap: 8px;
  background: transparent;
  border: 1px solid rgba(0,0,0,.14);
  color: rgba(0,0,0,.64);
  font-weight: 600;
  font-size: 14px;
  transition: border-color .18s ease, color .18s ease;
}
.quote-wa-direct:hover {
  border-color: #25d366;
  color: #1a9e4a;
}
.quote-wa-direct svg {
  flex-shrink: 0;
  color: #25d366;
}

/* WhatsApp booking fallback CTA */
.booking-divider {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 18px 0 14px;
}
.booking-divider::before,
.booking-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: rgba(255,255,255,.14);
}
.booking-divider span {
  color: rgba(255,255,255,.44);
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .1em;
}
.wa-book-cta {
  width: 100%;
  gap: 10px;
  background: #25d366;
  color: #fff;
  font-weight: 700;
  border: none;
  transition: background .18s ease, transform .18s ease;
}
.wa-book-cta:hover {
  background: #1ebe5a;
  transform: scale(1.02);
}
.wa-book-cta.needs-whatsapp-confirmation {
  box-shadow: 0 0 0 3px rgba(37,211,102,.32), 0 .55rem 1.75rem rgba(37,211,102,.28);
}
.wa-book-cta svg {
  flex-shrink: 0;
}
.wa-reassurance {
  font-size: 13px;
  color: rgba(255,255,255,.52);
  margin: 10px 0 0;
  text-align: center;
  line-height: 1.4;
}
.booking-form-submit {
  width: 100%;
  background: transparent;
  border: 1px solid rgba(255,255,255,.22);
  color: rgba(255,255,255,.78);
  font-weight: 600;
}
.booking-form-submit:hover {
  border-color: rgba(255,255,255,.4);
  color: #fff;
}

/* Preview Your Look web app */
.preview-studio-section {
  display: grid;
  grid-template-columns: minmax(0, .85fr) minmax(320px, 1.15fr);
  gap: clamp(1.5rem, 5vw, 4rem);
  align-items: start;
}
.preview-copy { position: sticky; top: 5.5rem; }
.preview-badges {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-top: 1.25rem;
}
.preview-badges span,
.studio-status,
.chip {
  border: 1px solid rgba(0,0,0,.1);
  border-radius: 999px;
  background: rgba(255,255,255,.72);
  color: rgba(0,0,0,.72);
  padding: .55rem .8rem;
  font-size: .78rem;
  font-weight: 750;
}
.preview-studio {
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 2rem;
  background: rgba(255,255,255,.82);
  box-shadow: 0 2rem 5rem rgba(0,0,0,.08);
  padding: clamp(1rem, 3vw, 1.5rem);
  overflow: hidden;
}
.studio-topline {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;
}
.studio-topline strong { display: block; font-size: 1.2rem; letter-spacing: -.04em; }
.studio-kicker { display: block; color: #8b6a31; font-size: .7rem; font-weight: 800; letter-spacing: .16em; text-transform: uppercase; margin-bottom: .15rem; }
.studio-status { background: #111; color: #fff; border-color: #111; white-space: nowrap; }
.preview-stage {
  display: grid;
  grid-template-columns: minmax(12rem, .9fr) minmax(0, 1.1fr);
  gap: 1rem;
  align-items: stretch;
}
.phone-preview {
  position: relative;
  min-height: 34rem;
  border-radius: 2rem;
  padding: .75rem;
  background: #050505;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.08), 0 1.25rem 3rem rgba(0,0,0,.18);
}
.phone-glow {
  position: absolute;
  inset: 18% -12% auto;
  height: 12rem;
  background: radial-gradient(circle, rgba(216,178,110,.26), transparent 64%);
  pointer-events: none;
}
.phone-screen {
  position: relative;
  z-index: 1;
  height: 100%;
  min-height: 32.5rem;
  border-radius: 1.45rem;
  overflow: hidden;
  background: linear-gradient(145deg, #e9e2d7, #fff 48%, #d8c5a5);
  display: flex;
  align-items: center;
  justify-content: center;
}
.phone-screen img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: none;
  filter: saturate(1.02) contrast(1.02);
}
.phone-screen img.is-visible { display: block; }
.phone-screen img.is-generated-preview { object-fit: contain; background: #111; }
.empty-selfie {
  width: 74%;
  aspect-ratio: 3/4;
  border: 1px dashed rgba(0,0,0,.22);
  border-radius: 1.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(0,0,0,.46);
  font-weight: 800;
}
.style-overlay {
  position: absolute;
  left: .8rem;
  right: .8rem;
  bottom: .8rem;
  border-radius: 1.2rem;
  padding: .85rem;
  background: rgba(0,0,0,.72);
  color: #fff;
  backdrop-filter: blur(16px);
}
.style-overlay span { display: block; color: var(--gold); font-size: .74rem; font-weight: 800; text-transform: uppercase; letter-spacing: .12em; margin-bottom: .2rem; }
.style-overlay strong { font-size: 1.15rem; letter-spacing: -.03em; }
.studio-controls { display: grid; gap: .75rem; align-content: start; }
.studio-controls input,
.studio-controls select { width: 100%; }
.file-card.compact { min-height: auto; }
.micro-controls { display: flex; gap: .45rem; flex-wrap: wrap; }
.chip { cursor: pointer; min-height: 2.5rem; }
.chip.is-active { background: #111; color: #fff; border-color: #111; }
.preview-results {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .65rem;
  margin-top: 1rem;
}
.look-option {
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 1rem;
  padding: .45rem;
  background: #fff;
  text-align: left;
  cursor: pointer;
  box-shadow: 0 .75rem 1.75rem rgba(0,0,0,.05);
}
.look-option.is-selected { border-color: var(--blue); box-shadow: 0 0 0 2px rgba(148,107,45,.18); }
.look-image-frame { position: relative; overflow: hidden; aspect-ratio: 1; border-radius: .75rem; display: block; margin-bottom: .55rem; background: #111; }
.look-image-frame img { width: 100%; height: 100%; object-fit: cover; display: block; transform: scale(1.01); }
.look-image-frame i { position: absolute; inset: 0; pointer-events: none; background: radial-gradient(circle at 50% 10%, rgba(255,255,255,.18), transparent 28%), linear-gradient(180deg, transparent 38%, rgba(0,0,0,.34)); mix-blend-mode: screen; opacity: .75; }
.look-image-frame em { position: absolute; left: .45rem; top: .45rem; border-radius: 999px; padding: .26rem .46rem; background: rgba(0,0,0,.66); color: white; font-size: .58rem; font-style: normal; font-weight: 850; letter-spacing: .08em; text-transform: uppercase; backdrop-filter: blur(10px); }
.look-option.is-generated .look-image-frame[data-mode="personalized"]::after { content: ''; position: absolute; left: 16%; right: 16%; top: 2%; height: 46%; border-radius: 46% 46% 36% 36%; border: 3px solid rgba(216,178,110,.92); border-bottom-width: 8px; box-shadow: inset 0 -18px 26px rgba(70,38,18,.42), 0 16px 28px rgba(0,0,0,.18); opacity: .88; mix-blend-mode: multiply; pointer-events: none; }
.look-option.is-generated .look-image-frame.style-cornrows::after { background: repeating-linear-gradient(90deg, rgba(42,24,13,.82) 0 5px, rgba(216,178,110,.72) 5px 7px); }
.look-option.is-generated .look-image-frame.style-boxMedium::after,
.look-option.is-generated .look-image-frame.style-knotless::after { background: repeating-linear-gradient(115deg, rgba(42,24,13,.82) 0 8px, rgba(216,178,110,.82) 8px 10px); }
.look-option.is-generated .look-image-frame.style-boho::after,
.look-option.is-generated .look-image-frame.style-passion::after { background: radial-gradient(circle at 25% 65%, rgba(216,178,110,.92) 0 5px, transparent 6px), repeating-linear-gradient(105deg, rgba(42,24,13,.76) 0 9px, rgba(216,178,110,.72) 9px 11px); }
.look-option.is-generated .look-image-frame.style-senegalese::after { background: repeating-linear-gradient(125deg, rgba(35,22,13,.9) 0 10px, rgba(216,178,110,.8) 10px 12px); }
.look-option.is-generated .look-image-frame.style-festival::after { background: radial-gradient(circle at 75% 24%, rgba(216,178,110,.95) 0 4px, transparent 5px), repeating-linear-gradient(90deg, rgba(42,24,13,.82) 0 6px, rgba(216,178,110,.75) 6px 8px); }
.look-option.is-generated .look-image-frame.style-kids::after { background: repeating-linear-gradient(90deg, rgba(42,24,13,.74) 0 7px, rgba(216,178,110,.7) 7px 9px); }
.look-option span { color: #8b6a31; font-size: .68rem; font-weight: 900; letter-spacing: .14em; }
.look-option strong { display: block; font-size: .88rem; letter-spacing: -.03em; margin-top: .1rem; }
.look-option small { display: block; color: rgba(0,0,0,.52); line-height: 1.25; margin-top: .16rem; }
@media (max-width: 980px) {
  .preview-studio-section { grid-template-columns: 1fr; }
  .preview-copy { position: static; }
}
@media (max-width: 720px) {
  .preview-studio-section { padding-inline: 16px; }
  .preview-badges { display: grid; grid-template-columns: 1fr 1fr; }
  .preview-badges span:last-child { grid-column: 1 / -1; }
  .preview-studio { border-radius: 1.5rem; padding: .85rem; margin-inline: 0; }
  .studio-topline { align-items: flex-start; }
  .preview-stage { grid-template-columns: 1fr; }
  .phone-preview { min-height: 28rem; border-radius: 1.5rem; }
  .phone-screen { min-height: 26.5rem; border-radius: 1rem; }
  .preview-results { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .look-option { border-radius: .9rem; }
  .look-option strong { font-size: .82rem; }
}

/* WhatsApp AI preview CTA */
.preview-status-area {
  margin: 12px 0 0;
}
.preview-status-area .status-text {
  margin: 0 0 6px;
}
.wa-preview-ready {
  font-size: 14px;
  font-weight: 600;
  color: rgba(0,0,0,.74);
  margin: 0 0 10px;
  line-height: 1.4;
}
.wa-preview-cta {
  width: 100%;
  gap: 10px;
  background: #25d366;
  color: #fff;
  font-weight: 700;
  border: none;
  transition: background .18s ease, transform .18s ease;
  margin-bottom: 8px;
}
.wa-preview-cta:hover {
  background: #1ebe5a;
  transform: scale(1.02);
}
.wa-preview-cta svg {
  flex-shrink: 0;
}
.preview-delivery-actions {
  display: grid;
  gap: 8px;
  margin-bottom: 8px;
}
.generated-preview-card {
  display: grid;
  gap: 12px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 18px;
  padding: 10px;
  background: #fff;
  box-shadow: 0 18px 40px rgba(0,0,0,.08);
  margin-bottom: 12px;
}
.generated-preview-card img {
  width: 100%;
  border-radius: 14px;
  display: block;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  background: #111;
}
.generated-preview-copy { display: grid; gap: 8px; }
.preview-quote-mini {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 6px 10px;
  align-items: baseline;
  font-size: 13px;
}
.preview-quote-mini span { color: rgba(0,0,0,.54); }
.preview-quote-mini strong { text-align: right; color: #111; }
.wa-preview-download,
.wa-preview-email-cta {
  width: 100%;
  justify-content: center;
  background: #111;
  color: #fff;
  border-color: #111;
  font-weight: 800;
}
.wa-preview-email-cta:hover {
  background: #2a2a2a;
  transform: scale(1.02);
}
.wa-preview-privacy {
  font-size: 12px;
  color: rgba(0,0,0,.44);
  margin: 6px 0 0;
  text-align: center;
  line-height: 1.4;
}
.book-this-look-cta {
  width: 100%;
  gap: 8px;
  margin-bottom: 8px;
  background: var(--blue);
  color: #fff;
  font-weight: 700;
  border: none;
  transition: background .18s ease, transform .18s ease;
}
.book-this-look-cta:hover {
  background: #7a5924;
  transform: scale(1.02);
}

/* Anchor scroll offset — prevent fixed nav from covering section headings */
#how, #styles, #ai-preview, #quote, #book, #zones, #trust, #faq { scroll-margin-top: 76px; }
@media (max-width: 720px) {
  #how, #styles, #ai-preview, #quote, #book, #zones, #trust, #faq { scroll-margin-top: 72px; }
}

/* Mobile preview polish */
.file-card.compact .file-thumb::after {
  content: '+';
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  color: rgba(0,0,0,.34);
  font-weight: 900;
  font-size: 1.35rem;
}
.file-card.compact .file-thumb.has-image::after { content: ''; }
@media (max-width: 720px) {
  .preview-copy { padding-top: .5rem; }
  .preview-copy .lead { margin-bottom: 1rem; }
  .preview-stage { gap: .85rem; }
  .phone-preview { order: 2; }
  .studio-controls { order: 1; }
  .preview-results { padding-bottom: 1rem; }
}

/* Desktop/tablet layout correction for Preview Your Look.
   Keep the marketing copy and studio stacked until there is real desktop width.
   This prevents the preview phone + form from looking squeezed or shifted on laptops. */
@media (max-width: 1320px) {
  .preview-studio-section {
    grid-template-columns: 1fr;
  }
  .preview-copy {
    position: static;
    max-width: 760px;
  }
  .preview-studio {
    width: 100%;
    max-width: 1040px;
    margin-inline: auto;
  }
}

@media (max-width: 980px) {
  .preview-stage {
    grid-template-columns: 1fr;
  }
  .studio-controls {
    order: 1;
  }
  .phone-preview {
    order: 2;
    overflow: hidden;
    min-height: clamp(26rem, 72vw, 34rem);
  }
  .phone-screen {
    min-height: clamp(24rem, 68vw, 32.5rem);
  }
}

@media (min-width: 1321px) {
  .preview-studio {
    min-width: 0;
  }
  .preview-stage {
    grid-template-columns: minmax(15rem, .95fr) minmax(18rem, 1.05fr);
  }
}
/* Hero inline preview + gated quote */
.hero-inline-preview {
  display: grid;
  grid-template-columns: 82px 1fr;
  gap: 12px;
  align-items: center;
  margin-top: 12px;
  padding: 10px;
  border-radius: 18px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 18px 40px rgba(0,0,0,.22);
}
.hero-inline-preview[hidden] { display: none; }
.hero-inline-preview-frame {
  overflow: hidden;
  border-radius: 14px;
  background: #111;
  aspect-ratio: 3 / 4;
}
.hero-inline-preview-frame img { width: 100%; height: 100%; display: block; object-fit: cover; }
.hero-inline-preview-copy { display: grid; gap: 8px; color: #111; }
.hero-inline-preview-copy span { font-size: 13px; font-weight: 850; line-height: 1.25; }
.hero-inline-preview-copy .button { min-height: 42px; padding: 10px 14px; font-size: 13px; }
.quote-contact-gate {
  display: grid;
  gap: 10px;
  padding: 14px;
  border-radius: 18px;
  background: rgba(148,107,45,.1);
  border: 1px solid rgba(148,107,45,.22);
}
.quote-contact-gate strong { font-size: 18px; letter-spacing: -.02em; }
.quote-contact-gate p { margin: 0; color: rgba(0,0,0,.62); line-height: 1.4; font-size: 14px; }
.is-hidden { display: none !important; }
.result-card.is-locked strong { color: rgba(0,0,0,.48); }
.result-card.is-locked { border-style: dashed; }

/* Hero in-place preview loading + Get my quote */
.hero-preview-loading {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .8rem;
  background: rgba(8,6,4,.62);
  backdrop-filter: blur(6px);
  color: #fff;
  z-index: 2;
}
.hero-preview-loading[hidden] { display: none; }
.hero-preview-loading p { margin: 0; font-size: .9rem; font-weight: 750; letter-spacing: -.01em; }
.hp-spinner {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 3px solid rgba(255,255,255,.22);
  border-top-color: var(--gold);
  animation: hp-spin .8s linear infinite;
}
@keyframes hp-spin { to { transform: rotate(360deg); } }
.hero-get-quote-btn {
  width: 100%;
  margin-top: .7rem;
  background: var(--blue);
  color: #fff;
  font-weight: 800;
  border: none;
  min-height: 46px;
}
.hero-get-quote-btn:hover { background: #7a5924; }
.hero-get-quote-btn[hidden] { display: none; }

/* Quote section preview recap */
.quote-fieldgroup { display: grid; gap: .75rem; margin-bottom: .25rem; }
.quote-preview-recap {
  display: grid;
  grid-template-columns: 84px 1fr;
  gap: 14px;
  align-items: center;
  margin-top: 18px;
  padding: 12px;
  border-radius: 16px;
  background: rgba(148,107,45,.1);
  border: 1px solid rgba(148,107,45,.22);
}
.quote-preview-recap[hidden] { display: none; }
.quote-preview-recap-frame {
  overflow: hidden;
  border-radius: 12px;
  background: #111;
  aspect-ratio: 3 / 4;
}
.quote-preview-recap-frame img { width: 100%; height: 100%; display: block; object-fit: cover; }
.quote-preview-recap span { display: block; color: #8b6a31; font-size: .7rem; font-weight: 850; letter-spacing: .12em; text-transform: uppercase; }
.quote-preview-recap strong { display: block; font-size: 1.05rem; letter-spacing: -.02em; margin: .15rem 0 .3rem; }
.quote-preview-recap p { margin: 0; font-size: .82rem; color: rgba(0,0,0,.6); line-height: 1.4; }


/* Hero: clean photo + status + actions below (Get my quote never covers the photo) */
.hero-preview-photo { position: relative; }
.hero-preview-zoom {
  position: absolute;
  top: .6rem;
  right: .6rem;
  width: 2.2rem;
  height: 2.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 999px;
  background: rgba(0,0,0,.55);
  color: #fff;
  cursor: pointer;
  backdrop-filter: blur(8px);
  z-index: 2;
}
.hero-preview-zoom[hidden] { display: none; }
.hero-preview-zoom:hover { background: rgba(0,0,0,.75); }
.hero-preview-photo img { cursor: zoom-in; }
.hero-preview-status {
  display: flex;
  flex-direction: column;
  gap: .12rem;
  margin: 0 0 .25rem;
}
.hero-preview-status strong { color: var(--gold); font-size: .72rem; font-weight: 850; letter-spacing: .12em; text-transform: uppercase; }
.hero-preview-status span { color: rgba(255,255,255,.82); font-size: .92rem; font-weight: 650; letter-spacing: -.01em; }
.hero-preview-controls input[type="text"],
.hero-preview-controls #heroStyleNote {
  width: 100%;
  margin-top: .35rem;
  background: rgba(255,255,255,.95);
  color: #111;
  border: 0;
}
.hero-preview-actionrow { display: grid; gap: .55rem; }
.hero-preview-actionrow[hidden] { display: none; }
.hero-get-quote-btn {
  width: 100%;
  background: var(--blue);
  color: #fff;
  font-weight: 800;
  border: none;
  min-height: 48px;
}
.hero-get-quote-btn:hover { background: #7a5924; }
.hero-preview-saverow { display: grid; grid-template-columns: 1fr 1fr; gap: .5rem; }
.hero-mini-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.28);
  background: rgba(255,255,255,.06);
  color: #fff;
  font-weight: 700;
  font-size: .82rem;
  cursor: pointer;
}
.hero-mini-btn:hover { border-color: rgba(255,255,255,.55); background: rgba(255,255,255,.12); }

/* Phone row: country dial-code selector left of the number */
.phone-row { display: grid; grid-template-columns: minmax(8.5rem, .9fr) 1.4fr; gap: .5rem; }
.phone-row .phone-country { margin: 0; }
.phone-row .phone-number { margin: 0; }
@media (max-width: 420px) {
  .phone-row { grid-template-columns: 1fr; }
}

/* Lightbox: enlarged preview + save */
.lightbox {
  position: fixed;
  inset: 0;
  z-index: 60;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  padding: clamp(1rem, 4vw, 2.5rem);
  background: rgba(0,0,0,.92);
  backdrop-filter: blur(6px);
}
.lightbox[hidden] { display: none; }
.lightbox img {
  max-width: min(92vw, 620px);
  max-height: 74vh;
  border-radius: 14px;
  object-fit: contain;
  box-shadow: 0 20px 60px rgba(0,0,0,.6);
}
.lightbox-close {
  position: absolute;
  top: 1rem;
  right: 1.1rem;
  width: 2.6rem;
  height: 2.6rem;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  color: #fff;
  font-size: 1.6rem;
  line-height: 1;
  cursor: pointer;
}
.lightbox-close:hover { background: rgba(255,255,255,.26); }
.lightbox-save { min-width: 12rem; }
