:root{
  /* Match frontend/src/theme/theme.ts */
  --bg: #FBF6F2;
  --surface: #FFFFFF;
  --surface2: #F4ECE7;
  --border: rgba(36, 22, 16, 0.08);
  --text: #241610;
  --muted: #5E4B43;
  --subtle: #7A6961;

  --primary: #C97145;
  --primary2: #E7B7B3;
  --primarySoft: rgba(201, 113, 69, 0.14);
  --primaryBorderSoft: rgba(201, 113, 69, 0.25);
  --danger: #DC2626;

  --shadow: rgba(2, 6, 23, 0.14);
  --onDark: #FFFFFF;

  --radius: 18px;
  --radius2: 14px;
  --max: 1120px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  background:
    radial-gradient(900px 520px at 12% 8%, rgba(201,113,69,0.14), transparent 62%),
    radial-gradient(820px 520px at 88% 10%, rgba(231,183,179,0.16), transparent 60%),
    linear-gradient(180deg, var(--bg), #F8EFEA 65%, #F7EEE8);
  color: var(--text);
}

a{color:inherit;text-decoration:none}
button{font:inherit}

.sr{
  position:absolute;
  width:1px;height:1px;
  padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
.skip{
  position:absolute;left:-999px;top:10px;
  background: var(--surface);color: var(--text);
  padding:10px 12px;border-radius:10px;
  z-index:9999;
}
.skip:focus{left:12px}

.container{max-width:var(--max);margin:0 auto;padding:0 18px}

.topbar{
  position:sticky;top:0;z-index:50;
  backdrop-filter: blur(10px);
  background: rgba(251, 246, 242, 0.72);
  border-bottom: 1px solid var(--border);
}
.topbar[data-elevate="1"]{
  background: rgba(251, 246, 242, 0.90);
  border-bottom-color: rgba(36, 22, 16, 0.12);
}
.topbar__inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 0;
}

.brand{display:flex;align-items:center;gap:10px}
.brand__mark{
  width:34px;height:34px;border-radius:10px;
  display:grid;place-items:center;
  background: linear-gradient(135deg, var(--primary), var(--primary2));
  color: var(--onDark);font-weight:1000;
}
.brand__name{font-weight:950;letter-spacing:-0.02em}
.brand--small .brand__mark{width:30px;height:30px;border-radius:9px}
.brand__logo{
  height: 44px;
  width: auto;
  display: block;
}
.brand__logo--small{
  height: 28px;
}

.nav{display:flex;align-items:center;gap:12px}
.nav__toggle{
  display:none;
  border:1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  width:42px;height:42px;border-radius:12px;
  align-items:center;justify-content:center;
}
.nav__toggleLines{
  width:18px;height:12px;display:block;position:relative;
}
.nav__toggleLines:before,.nav__toggleLines:after{
  content:"";position:absolute;left:0;right:0;height:2px;border-radius:2px;background:var(--text);
}
.nav__toggleLines:before{top:0}
.nav__toggleLines:after{bottom:0}
.nav__menu{display:flex;align-items:center;gap:14px}
.nav__link{color:var(--muted);font-weight:800}
.nav__link:hover{color:var(--text)}
.nav__cta{margin-left:8px}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  border-radius: 14px;
  padding:12px 14px;
  border:1px solid rgba(36, 22, 16, 0.10);
  background: var(--surface);
  color: var(--text);
  font-weight:900;
  gap:10px;
  transition: transform .15s ease, background .15s ease, border-color .15s ease, opacity .15s ease;
  cursor:pointer;
}
.btn:hover{transform: translateY(-1px);border-color:rgba(36, 22, 16, 0.14);background: rgba(36, 22, 16, 0.03)}
.btn:active{transform: translateY(0)}
.btn--primary{
  background: linear-gradient(135deg, var(--primary), var(--primary2));
  border-color: rgba(201, 113, 69, 0.35);
  color: var(--onDark);
}
.btn--secondary{
  background: rgba(36, 22, 16, 0.04);
}
.btn--ghost{
  background: transparent;
}

.hero{padding:56px 0 26px}
.hero__grid{display:grid;grid-template-columns: 1.25fr 0.95fr;gap:26px;align-items:center}
.eyebrow{color:var(--subtle);font-weight:900;letter-spacing:.08em;text-transform:uppercase;font-size:12px;margin:0 0 10px}
.hero__title{
  margin:0 0 12px;
  font-size: clamp(34px, 3.8vw, 56px);
  line-height:1.03;
  letter-spacing:-0.03em;
}
.hero__lead{margin:0 0 18px;color:var(--muted);font-size:16px;line-height:1.6}
.hero__actions{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0 14px}
.hero__trust{display:flex;gap:10px;flex-wrap:wrap}
.chip{
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:999px;
  border:1px solid rgba(36, 22, 16, 0.10);
  background: rgba(255,255,255,0.70);
  color: var(--muted);
  font-weight:800;
  font-size:12px;
}
.chip__dot{width:9px;height:9px;border-radius:99px;background: rgba(36, 22, 16, 0.18)}
.chip__dot--ok{background: linear-gradient(135deg, var(--primary), var(--primary2))}

.hero__visual{position:relative;min-height:460px}
.hero__bg{
  position:absolute;inset: -40px -18px -30px -18px;
  background:
    radial-gradient(520px 300px at 30% 35%, rgba(201,113,69,0.14), transparent 62%),
    radial-gradient(560px 360px at 70% 55%, rgba(231,183,179,0.16), transparent 60%);
  filter: blur(2px);
  z-index:0;
}
.phone{position:relative;z-index:1;margin-left:auto}
.phone__glow{
  position:absolute;inset:-30px -30px -30px -30px;
  background: radial-gradient(240px 200px at 60% 20%, rgba(201,113,69,0.22), transparent 65%);
  filter: blur(12px);
  opacity:0.9;
}
.phone__screen{
  width:min(360px, 86vw);
  height: 520px;
  border-radius: 34px;
  background: linear-gradient(180deg, rgba(255,255,255,0.95), rgba(244,236,231,0.92));
  border: 1px solid rgba(36,22,16,0.10);
  box-shadow: 0 22px 60px var(--shadow);
  overflow:hidden;
  position:relative;
}
.phone__screen:before{
  /* subtle bezel */
  content:"";
  position:absolute;
  inset:0;
  border-radius: 34px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.22);
  pointer-events:none;
  z-index: 5;
}
.phone__screen:after{
  /* notch */
  content:"";
  position:absolute;
  top:10px;
  left:50%;
  transform:translateX(-50%);
  width: 120px;
  height: 22px;
  border-radius: 999px;
  background: rgba(2,6,23,0.22);
  filter: blur(0.2px);
  opacity: 0.35;
  z-index: 4;
}

/* Hero mock UI inside the phone (no real screenshots here) */
.mockTop{display:flex;justify-content:space-between;align-items:center;padding:16px 16px 10px;position:relative;z-index:1}
.mockLogo{font-weight:1000;letter-spacing:-0.03em}
.mockPill{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 10px;border-radius:999px;
  background: rgba(201,113,69,0.10);
  border:1px solid rgba(201,113,69,0.18);
  color: var(--muted);font-weight:900;font-size:12px;
}
.mockPill__icon{width:16px;height:16px;display:inline-block;color: var(--text)}
.mockPill__icon svg{width:16px;height:16px;display:block}

.mockCards{padding:10px 16px 86px;display:grid;gap:12px;position:relative;z-index:1}
.mockCard{
  display:grid;grid-template-columns: 70px 1fr;gap:12px;
  padding:12px;border-radius:16px;
  background: rgba(244,236,231,0.92);
  border:1px solid rgba(36,22,16,0.08);
}
.mockCover{
  border-radius:12px;
  background: linear-gradient(135deg, rgba(109,94,252,0.9), rgba(77,215,255,0.85));
  height:90px;
}
.mockCover.alt{background: linear-gradient(135deg, rgba(255,55,95,0.85), rgba(109,94,252,0.85))}
.mockMeta{display:flex;flex-direction:column;justify-content:center;gap:8px}
.mockLine{height:10px;border-radius:999px;background: rgba(36, 22, 16, 0.10)}
.mockLine.w70{width:70%}
.mockLine.w62{width:62%}
.mockLine.w55{width:55%}
.mockLine.w50{width:50%}
.mockLine.w40{width:40%}
.mockLine.w35{width:35%}
.mockRow{display:flex;gap:8px;margin-top:2px}
.mockChip{
  padding:6px 10px;
  border-radius:999px;
  background: rgba(201,113,69,0.12);
  border:1px solid rgba(201,113,69,0.18);
  color: var(--muted);
  font-weight:900;
  font-size:11px;
}
.mockChip.ghost{
  background: rgba(36,22,16,0.04);
  border-color: rgba(36,22,16,0.10);
}

.mockTabs{
  position:absolute;
  left:0;right:0;bottom:0;
  height: 78px;
  padding: 12px 14px 14px;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 10px;
  background: rgba(255,255,255,0.86);
  border-top: 1px solid rgba(36,22,16,0.08);
  z-index: 3;
}
.mockTab{
  width:44px;height:44px;border-radius:14px;
  display:grid;place-items:center;
  color: rgba(36,22,16,0.60);
  border: 1px solid rgba(36,22,16,0.08);
  background: rgba(36,22,16,0.02);
}
.mockTab svg{width:22px;height:22px;display:block}
.mockScanFab{
  width: 56px;
  height: 56px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--primary), var(--primary2));
  color: var(--onDark);
  display:grid;
  place-items:center;
  border:1px solid rgba(201, 113, 69, 0.28);
  box-shadow: 0 18px 40px rgba(2,6,23,0.16);
  transform: translateY(-16px);
}
.mockScanFab svg{width:24px;height:24px;display:block}

.section{padding:56px 0}
.section--alt{background: linear-gradient(180deg, rgba(255,255,255,0.55), rgba(255,255,255,0.00))}
.section__head{max-width:740px;margin:0 0 22px}
.section__head h2{margin:0 0 10px;font-size:28px;letter-spacing:-0.02em}
.section__head p{margin:0;color:var(--muted);line-height:1.6}

.grid3{display:grid;grid-template-columns: repeat(3, 1fr);gap:14px}
.card{
  border-radius: var(--radius);
  background: var(--surface);
  border: 1px solid var(--border);
  padding:16px;
  min-height: 132px;
}
.card h3{margin:0 0 8px;font-size:16px}
.card p{margin:0;color:var(--muted);line-height:1.6}

.steps{display:grid;gap:12px;list-style:none;padding:0;margin:0}
.steps__item{
  display:grid;grid-template-columns: 46px 1fr;gap:12px;
  padding:14px;border-radius: var(--radius);
  background: var(--surface);
  border:1px solid var(--border);
}
.steps__num{
  width:40px;height:40px;border-radius:14px;
  background: var(--primarySoft);
  border:1px solid var(--primaryBorderSoft);
  display:grid;place-items:center;
  font-weight:1000;color: var(--text);
}
.steps__item h3{margin:0 0 6px}
.steps__item p{margin:0;color:var(--muted);line-height:1.6}

.shots{display:grid;grid-template-columns: repeat(3, 1fr);gap:14px}
.shot{
  border-radius: var(--radius);
  background: var(--surface);
  border:1px solid var(--border);
  overflow:hidden;
}
.shot__btn{
  display:block;
  width:100%;
  padding:0;
  border:0;
  background: transparent;
  cursor: zoom-in;
}
.shot__img{
  width:100%;
  height: 520px;
  object-fit: cover;
  object-position: top;
  display:block;
  background:
    linear-gradient(135deg, rgba(201,113,69,0.14), rgba(231,183,179,0.12));
}
.shot__cap{padding:12px 14px;color:var(--muted);font-weight:900}

.lightbox{
  position:fixed;
  inset:0;
  z-index:9999;
  display:none;
}
.lightbox.is-open{display:block}
.lightbox__backdrop{
  position:absolute;
  inset:0;
  border:0;
  background: rgba(2,6,23,0.70);
}
.lightbox__dialog{
  position:absolute;
  left:50%;
  top:50%;
  transform: translate(-50%,-50%);
  width: min(420px, calc(100vw - 28px));
  max-height: calc(100vh - 40px);
  border-radius: 22px;
  background: rgba(255,255,255,0.96);
  border: 1px solid rgba(255,255,255,0.20);
  box-shadow: 0 22px 60px rgba(2,6,23,0.32);
  overflow:hidden;
}
.lightbox__close{
  position:absolute;
  top:10px;
  right:10px;
  width:40px;
  height:40px;
  border-radius: 14px;
  border:1px solid rgba(36,22,16,0.10);
  background: rgba(255,255,255,0.90);
  color: var(--text);
  cursor:pointer;
  font-weight:1000;
}
.lightbox__img{
  width:100%;
  height:auto;
  display:block;
  max-height: calc(100vh - 40px);
  object-fit: contain;
  background: #000;
}

.faq{display:grid;gap:10px}
.faq__item{
  border-radius: var(--radius);
  background: var(--surface);
  border:1px solid var(--border);
  padding:14px;
}
.faq__item summary{
  cursor:pointer;
  font-weight:950;
  list-style:none;
}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item p{margin:10px 0 0;color:var(--muted);line-height:1.6}

.cta{
  display:flex;align-items:center;justify-content:space-between;
  gap:14px;
  border-radius: 22px;
  padding:18px;
  background:
    radial-gradient(520px 260px at 20% 40%, rgba(201,113,69,0.14), transparent 60%),
    radial-gradient(520px 260px at 80% 40%, rgba(231,183,179,0.16), transparent 60%),
    rgba(255,255,255,0.75);
  border:1px solid rgba(36,22,16,0.10);
}
.cta__copy h2{margin:0 0 6px;font-size:22px}
.cta__copy p{margin:0;color:var(--muted);line-height:1.6}
.cta__actions{display:flex;gap:10px;flex-wrap:wrap}

.footer{padding:22px 0;border-top:1px solid rgba(36,22,16,0.08)}
.footer__inner{display:flex;align-items:center;justify-content:space-between;gap:14px}
.footer__note{margin:10px 0 0;color:var(--subtle)}
.footer__right{display:flex;gap:14px;color:var(--muted);font-weight:800}
.footer__right a:hover{color:var(--text)}

.toast{
  position:fixed;left:50%;bottom:16px;transform:translateX(-50%);
  background: rgba(36, 22, 16, 0.92);
  border: 1px solid rgba(255,255,255,0.18);
  color: var(--onDark);
  padding:10px 12px;border-radius: 14px;
  max-width: min(520px, calc(100vw - 24px));
  opacity:0;pointer-events:none;
  transition: opacity .2s ease, transform .2s ease;
}
.toast.is-on{opacity:1;transform:translateX(-50%) translateY(-6px)}

/* Reveal */
[data-reveal]{opacity:0;transform: translateY(12px);transition: opacity .5s ease, transform .5s ease}
[data-reveal].is-in{opacity:1;transform:none}

@media (max-width: 980px){
  .hero__grid{grid-template-columns: 1fr;gap:18px}
  .phone{margin:0 auto}
  .grid3{grid-template-columns: 1fr 1fr}
  .shots{grid-template-columns: 1fr}
}
@media (max-width: 720px){
  .nav__toggle{display:inline-flex}
  .nav__menu{
    position:absolute;right:18px;top:60px;
    background: rgba(251, 246, 242, 0.96);
    border:1px solid rgba(36,22,16,0.10);
    border-radius: 16px;
    padding:10px;
    display:none;
    flex-direction:column;
    align-items:stretch;
    gap:10px;
    min-width: 220px;
    box-shadow: 0 18px 40px rgba(2,6,23,0.14);
  }
  .nav__menu.is-open{display:flex}
  .nav__cta{margin-left:0}
  .grid3{grid-template-columns: 1fr}
  .cta{flex-direction:column;align-items:flex-start}
  .footer__inner{flex-direction:column;align-items:flex-start}
}


