/* ============================================================
   Semblance — site styles
   Dark, moody, premium. One typeface (Hanken Grotesk).
   ============================================================ */

:root{
  --bg:#0A0A0B;
  --surface:#16140F;
  --elevated:#1F1C16;
  --border:#2A2620;
  --border-faint:#16140F;
  --text:#F4EFE6;
  --text-body:#D8D2C6;
  --text-2:#A39E95;
  --muted:#8A857E;
  --subtle:#5A5650;
  --accent:#E8A48C;
  --accent-hover:#efb6a1;
  --maxw:1160px;
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--bg);
  color:var(--text);
  font-family:"Hanken Grotesk",system-ui,-apple-system,sans-serif;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  line-height:1.5;
}
a{text-decoration:none;color:inherit;}
img{display:block;max-width:100%;}
::selection{background:var(--accent);color:var(--bg);}

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

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(10,10,11,0.72);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border-faint);
}
.site-header .wrap{height:80px;display:flex;align-items:center;justify-content:space-between;}
.brand{display:flex;align-items:center;gap:11px;font-size:23px;font-weight:600;letter-spacing:-0.01em;color:var(--text);}
.brand img{height:36px;width:auto;}
.nav{display:flex;align-items:center;gap:36px;}
.nav a{font-size:16px;color:var(--muted);font-weight:500;transition:color .15s;}
.nav a.btn-primary{color:var(--bg);}
.nav a:hover{color:var(--text);}

/* ---------- Buttons ---------- */
.btn-primary{
  display:inline-flex;align-items:center;gap:11px;
  background:var(--accent);color:var(--bg);
  padding:15px 26px;border-radius:100px;
  font-size:15px;font-weight:600;border:none;cursor:pointer;
  font-family:inherit;transition:background .15s;
}
.btn-primary.sm{padding:13px 22px;font-size:16px;gap:8px;}
.btn-primary:hover{background:var(--accent-hover);}
.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;
  font-size:15px;font-weight:500;color:var(--text);
  border-bottom:1px solid var(--border);padding-bottom:3px;transition:border-color .15s;
}
.btn-ghost:hover{border-color:var(--accent);}
.btn-ghost .arr{color:var(--accent);}

/* ---------- Typography helpers ---------- */
.eyebrow{font-size:13px;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--accent);}
.eyebrow.muted{color:var(--muted);}
.group-label{font-size:12px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--subtle);}
h1,h2,h3{font-weight:600;margin:0;}
.h1{font-size:68px;line-height:1.02;letter-spacing:-0.02em;}
.h1 em{font-style:normal;color:var(--accent);}
.h2{font-size:42px;line-height:1.1;letter-spacing:-0.01em;}
.accent{color:var(--accent);font-style:normal;}

/* ---------- Hero ---------- */
.hero{display:flex;gap:56px;align-items:flex-start;padding:88px 0 24px;flex-wrap:wrap;}
#how{padding-top:64px;}
.hero-copy{flex:1 1 420px;min-width:340px;}
.hero-copy h1{margin:0 0 24px;color:var(--text);}
.hero-sub{font-size:18px;line-height:1.55;color:var(--text-2);max-width:42ch;margin:0;}
.hero-media{flex:0 1 420px;min-width:300px;}
.dot{color:var(--border);}

/* ---------- Before/After slider ---------- */
.ba-slider{
  position:relative;width:100%;aspect-ratio:4/5;
  border-radius:20px;overflow:hidden;border:1px solid var(--border);
  background:var(--surface);
  box-shadow:0 30px 80px -30px rgba(0,0,0,0.8);
  user-select:none;touch-action:none;
}
.ba-layer{position:absolute;inset:0;}
.ba-layer img{width:100%;height:100%;object-fit:cover;}
.ba-before{clip-path:inset(0 calc((100 - var(--pos,50)) * 1%) 0 0);}
.ba-badge{
  position:absolute;top:16px;padding:6px 13px;border-radius:100px;
  background:rgba(10,10,11,0.55);backdrop-filter:blur(8px);
  border:1px solid rgba(244,239,230,0.14);
  font-size:11px;letter-spacing:0.14em;font-weight:600;text-transform:uppercase;color:var(--text);
}
.ba-badge.before{left:16px;}
.ba-badge.after{right:16px;}
.ba-divider{
  position:absolute;top:0;bottom:0;left:calc(var(--pos,50) * 1%);
  width:44px;transform:translateX(-50%);
  cursor:ew-resize;display:flex;align-items:center;justify-content:center;z-index:5;
}
.ba-line{position:absolute;top:0;bottom:0;left:50%;width:2px;transform:translateX(-50%);
  background:rgba(244,239,230,0.9);box-shadow:0 0 16px rgba(0,0,0,0.5);}
.ba-handle{
  position:relative;width:52px;height:52px;border-radius:50%;
  background:var(--text);color:var(--bg);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 20px rgba(0,0,0,0.55);
}
.ba-handle:focus-visible{outline:2px solid var(--accent);outline-offset:3px;}

.examples{display:flex;align-items:center;gap:6px;margin:18px 2px 0;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px;}
.examples::-webkit-scrollbar{display:none;}
.examples .lbl{flex-shrink:0;}
.ex-pill{flex-shrink:0;}
.examples .lbl{font-size:11px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--subtle);margin-right:0;flex:none;}
.ex-pill{
  display:inline-flex;align-items:center;padding:7px 12px;border-radius:100px;
  font-size:12.5px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap;
  background:transparent;color:var(--muted);border:1px solid var(--border);transition:all .15s;
}
.ex-pill:hover{border-color:var(--accent);color:var(--text);}
.ex-pill[aria-pressed="true"]{background:var(--accent);color:var(--bg);border-color:var(--accent);}

.disclaimer{display:flex;align-items:flex-start;gap:8px;margin:14px 2px 0;font-size:12.5px;line-height:1.5;color:var(--subtle);}
.disclaimer .mk{color:var(--accent);flex:none;margin-top:1px;}

/* ---------- Direct answer ---------- */
.section{padding:96px 0 80px;scroll-margin-top:80px;}
.section.tight{padding:24px 0 8px;}
.answer{
  max-width:880px;background:linear-gradient(180deg,var(--surface),#100E09);
  border:1px solid var(--border);border-radius:18px;padding:34px 40px;
}
.answer .eyebrow{margin-bottom:14px;}
.answer p{font-size:20px;line-height:1.6;color:var(--text-body);margin:0;}

/* ---------- How it works ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.step{border:1px solid var(--border);border-radius:16px;padding:28px;background:var(--surface);}
.step .ico{display:flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:12px;background:var(--elevated);color:var(--accent);margin-bottom:22px;}
.step .num{font-size:13px;color:var(--subtle);font-weight:600;margin-bottom:8px;}
.step h3{font-size:19px;margin:0 0 8px;color:var(--text);}
.step p{font-size:15px;line-height:1.55;color:var(--muted);margin:0;}

/* ---------- Procedure cards ---------- */
.proc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:12px;}
.proc-card{
  display:flex;flex-direction:column;padding:16px 18px;border-radius:14px;
  border:1px solid var(--border);background:var(--surface);transition:all .15s;
}
.proc-card.live{cursor:pointer;border-color:rgba(232,164,140,0.42);background:rgba(232,164,140,0.07);}
.proc-card.live:hover{background:rgba(232,164,140,0.15);border-color:var(--accent);}
.name-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:5px;}
.proc-card .name{font-size:15.5px;font-weight:600;color:var(--text);}
.proc-card .tag{font-size:10px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--accent);flex:none;}
.proc-card .tag.soon{color:var(--subtle);}
.proc-card .desc{font-size:13px;line-height:1.45;color:var(--muted);margin:0;}

/* ---------- FAQ ---------- */
.faq-grid{display:flex;gap:64px;align-items:flex-start;flex-wrap:wrap;}
.faq-grid .head{flex:0 0 280px;}
.faq-grid .head h2{font-size:40px;line-height:1.08;letter-spacing:-0.01em;}
.faq-list{flex:1 1 460px;min-width:320px;}
.faq{border-bottom:1px solid var(--border);padding:22px 0;}
.faq summary{display:flex;align-items:center;justify-content:space-between;gap:16px;font-size:17px;font-weight:600;color:var(--text);cursor:pointer;list-style:none;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary .pm{color:var(--accent);font-size:20px;flex:none;transition:transform .2s;}
.faq[open] summary .pm{transform:rotate(45deg);}
.faq p{font-size:15.5px;line-height:1.6;color:var(--muted);margin:14px 0 0;max-width:62ch;}

/* ---------- Closing CTA ---------- */
.cta-band{
  position:relative;border-radius:24px;border:1px solid var(--border);
  background:radial-gradient(120% 140% at 80% 0%,rgba(232,164,140,0.14),transparent 55%),#121009;
  padding:72px 56px;text-align:center;overflow:hidden;
}
.cta-band h2{font-size:54px;line-height:1.04;letter-spacing:-0.02em;margin:0 0 18px;}
.cta-band p{font-size:18px;color:var(--text-2);max-width:46ch;margin:0 auto 32px;line-height:1.55;}

/* ---------- Footer ---------- */
.site-footer{border-top:1px solid var(--border-faint);background:var(--bg);}
.site-footer .wrap{padding:56px 32px 40px;}
.foot-top{display:flex;justify-content:space-between;gap:48px;flex-wrap:wrap;margin-bottom:40px;}
.foot-brand{max-width:320px;}
.foot-brand .logo{display:flex;align-items:center;gap:10px;margin-bottom:14px;}
.foot-brand .logo img{height:26px;}
.foot-brand .logo span{font-size:21px;font-weight:600;letter-spacing:-0.01em;}
.foot-brand p{font-size:14px;line-height:1.6;color:var(--subtle);margin:0;}
.foot-cols{display:flex;gap:64px;flex-wrap:wrap;}
.foot-col .group-label{display:block;margin-bottom:16px;}
.foot-col .links{display:flex;flex-direction:column;gap:12px;font-size:14px;color:var(--muted);}
.foot-col .links a{transition:color .15s;}
.foot-col .links a:hover{color:var(--text);}
.foot-bottom{border-top:1px solid var(--border-faint);padding-top:24px;display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;}
.foot-bottom p{font-size:12.5px;line-height:1.5;color:var(--subtle);margin:0;}
.foot-bottom .legal{max-width:64ch;}
.foot-bottom .copy{white-space:nowrap;}

/* ---------- Procedure page bits ---------- */
.breadcrumb{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--subtle);padding:32px 0 0;}
.breadcrumb a{color:var(--muted);transition:color .15s;}
.breadcrumb a:hover{color:var(--text);}
.breadcrumb .here{color:var(--text);}
.proc-head{padding:36px 0 8px;}
.proc-head h1{font-size:60px;line-height:1.03;letter-spacing:-0.02em;margin:18px 0 26px;max-width:16ch;}
.answer.compact{padding:30px 36px;}
.answer.compact p{font-size:19px;}
.proc-main{display:flex;gap:56px;align-items:flex-start;padding:56px 0 24px;flex-wrap:wrap;}
.proc-media{flex:0 1 460px;min-width:320px;}
.proc-support{flex:1 1 360px;min-width:300px;padding-top:6px;}
.proc-support h2{font-size:32px;line-height:1.1;margin:0 0 20px;}
.bullets{display:flex;flex-direction:column;gap:18px;margin-bottom:34px;}
.bullet{display:flex;gap:14px;}
.bullet .m{color:var(--accent);flex:none;margin-top:2px;}
.bullet p{font-size:15.5px;line-height:1.55;color:var(--text-2);margin:0;}
.bullet strong{color:var(--text);font-weight:600;}
.section.bordered{border-top:1px solid var(--border-faint);margin-top:48px;padding:64px 0 80px;}
.related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;}
.related{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:20px 22px;border:1px solid var(--border);border-radius:14px;background:var(--surface);transition:all .15s;}
.related:hover{border-color:var(--accent);background:var(--elevated);}
.related .name{display:block;font-size:16px;font-weight:600;margin-bottom:3px;color:var(--text);}
.related .note{font-size:13px;color:var(--muted);}
.related .arr{color:var(--subtle);}

/* ---------- No-example placeholder ---------- */
.placeholder{
  position:relative;width:100%;aspect-ratio:4/5;border-radius:20px;overflow:hidden;
  border:1px solid var(--border);
  background:radial-gradient(120% 90% at 50% 18%,rgba(232,164,140,0.10),transparent 60%),linear-gradient(160deg,#1B1810,#100E09);
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px;
}
.placeholder svg{opacity:0.6;margin-bottom:28px;}
.soon-pill{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(232,164,140,0.34);border-radius:100px;padding:7px 15px;margin-bottom:18px;}
.soon-pill .d{width:6px;height:6px;border-radius:50%;background:var(--accent);}
.soon-pill span{font-size:11.5px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--accent);}
.placeholder .cap{font-size:15px;line-height:1.6;color:var(--muted);margin:0;max-width:34ch;}

/* ---------- Responsive ---------- */
@media (max-width:860px){
  .h1{font-size:48px;}
  .proc-head h1{font-size:42px;}
  .h2,.faq-grid .head h2{font-size:32px;}
  .cta-band h2{font-size:38px;}
  .cta-band{padding:52px 28px;}
  .steps{grid-template-columns:1fr;}
  .section{padding:64px 0 56px;}
}
@media (max-width:520px){
  .wrap{padding:0 20px;}
  .h1{font-size:40px;}
  .nav{gap:18px;}
  .nav a:not(.btn-primary){display:none;}
}

/* ---------- Official App Store badge ---------- */
.appstore-badge{
  display:inline-flex;align-items:center;gap:14px;
  background:#000;border:1px solid rgba(244,239,230,0.22);
  border-radius:14px;padding:15px 28px;color:#fff;
  transition:border-color .15s,transform .15s;
}
.appstore-badge:hover{border-color:rgba(244,239,230,0.55);transform:translateY(-1px);}
.appstore-badge{white-space:nowrap;}
.appstore-badge svg{width:30px;height:30px;}
.appstore-badge .col{display:flex;flex-direction:column;line-height:1.08;text-align:left;}
.appstore-badge .b1{font-size:13px;font-weight:400;letter-spacing:0.01em;}
.appstore-badge .b2{font-size:23px;font-weight:600;letter-spacing:-0.01em;}

/* ---------- Hero social proof ---------- */
.hero-h1{font-size:64px;line-height:1.05;letter-spacing:-0.01em;margin:0 0 28px;color:var(--text);}
.hero-h1 em{font-style:normal;color:var(--accent);}
.award-row{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-bottom:22px;justify-content:center;}
.award-pill{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(232,164,140,0.4);background:rgba(232,164,140,0.07);border-radius:100px;padding:7px 14px;font-size:12.5px;font-weight:600;color:var(--accent);letter-spacing:0.02em;white-space:nowrap;}
.award-pill .d{width:6px;height:6px;border-radius:50%;background:var(--accent);}
.rating{display:inline-flex;align-items:center;gap:8px;}
.stars{color:var(--accent);letter-spacing:2px;font-size:14px;}
.rating .t{font-size:13px;color:var(--muted);}
.rating .t strong{color:var(--text);font-weight:600;}
.hero-cta{display:flex;align-items:center;gap:14px;margin-top:32px;flex-wrap:wrap;}
.hero-divider{width:100%;height:1px;background:var(--border);margin-top:28px;}
.social-proof{display:flex;align-items:center;gap:14px;margin-top:43px;}
.avatars{display:flex;align-items:center;}
.avatars img{height:34px;width:auto;}
.sp-text{text-align:left;}
.sp-text .sp-line1{font-size:14.5px;font-weight:600;color:var(--text);margin:0 0 4px;max-width:36ch;}
.sp-text .sp-line2{font-size:13px;color:var(--muted);margin:0;display:flex;align-items:center;gap:8px;}

/* ---------- Social-proof bar ---------- */
.proof-bar{display:flex;align-items:center;justify-content:center;gap:18px 40px;flex-wrap:wrap;padding:28px 32px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.proof-item{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--muted);}
.proof-item strong{color:var(--text);font-weight:600;}
.award-lockup{display:flex;align-items:center;gap:8px;color:var(--text);font-weight:600;font-size:14.5px;}
.laurel{color:var(--accent);flex:none;}
.laurel.flip{transform:scaleX(-1);}
@media (max-width:860px){
  .hero-h1{font-size:44px;}
  .proof-bar{gap:14px 28px;padding:22px;}
}
