:root{
    --cream:#FAF4E8;
    --cream-2:#F2E7D2;
    --ink:#1E3A32;
    --ink-2:#274A40;
    --ink-soft:#456258;
    --amber:#E89A3C;
    --amber-deep:#8A5210;
    --coral:#B84A32;
    --line:#E2D4BB;
    --radius:22px;
    --shadow:0 24px 60px -28px rgba(30,58,50,.45);
    --shadow-sm:0 10px 28px -16px rgba(30,58,50,.4);
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    font-family:"Hanken Grotesk",sans-serif;
    background:var(--cream);
    color:var(--ink);
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  /* grain overlay */
  body::before{
    content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.04;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%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");
  }
  .wrap{max-width:1140px;margin:0 auto;padding:0 24px}
  [id]{scroll-margin-top:90px}
  h1,h2,h3{font-family:"Fraunces",serif;font-weight:600;line-height:1.08;letter-spacing:-.01em}
  a{color:inherit;text-decoration:none}
  .accent{color:var(--amber-deep)}

  /* nav */
  header{position:sticky;top:0;z-index:50;background:rgba(250,244,232,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
  .nav{display:flex;align-items:center;justify-content:space-between;height:74px;gap:18px}
  .nav-links{display:flex;align-items:center;gap:28px}
  .nav-links a{font-family:"Hanken Grotesk";font-weight:500;font-size:.97rem;color:var(--ink-2);transition:color .15s ease}
  .nav-links a:hover{color:var(--amber-deep)}
  .nav-right{display:flex;align-items:center;gap:12px}
  .nav-links .nav-cta{display:none}
  .burger{display:none;width:42px;height:42px;border:1px solid var(--line);background:var(--cream);border-radius:12px;cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:4px}
  .burger span{display:block;width:18px;height:2px;background:var(--ink);border-radius:2px;transition:transform .25s ease,opacity .2s ease}
  .burger.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
  .burger.open span:nth-child(2){opacity:0}
  .burger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
  .nav-overlay{display:none}
  .brand{display:flex;align-items:center;gap:11px;font-family:"Fraunces",serif;font-weight:600;font-size:1.5rem}
  .brand svg{width:34px;height:34px;display:block}
  .badge{font-family:"Hanken Grotesk";font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--amber-deep);background:rgba(232,154,60,.14);border:1px solid rgba(232,154,60,.35);padding:5px 11px;border-radius:100px}
  .btn{display:inline-flex;align-items:center;gap:9px;font-family:"Hanken Grotesk";font-weight:600;font-size:1rem;padding:14px 24px;border-radius:100px;cursor:pointer;border:none;transition:transform .18s ease, box-shadow .18s ease, background .18s ease}
  .btn-primary{background:var(--ink);color:var(--cream)}
  .btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm);background:var(--ink-2)}
  .btn-amber{background:var(--amber);color:var(--ink)}
  .btn-amber:hover{transform:translateY(-2px);box-shadow:0 14px 30px -14px rgba(232,154,60,.7);background:var(--amber-deep);color:var(--cream)}
  .btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
  .btn-ghost:hover{background:var(--ink);color:var(--cream)}
  .nav .btn{padding:11px 20px;font-size:.94rem}

  /* hero */
  .hero{position:relative;padding:72px 0 90px}
  .hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
  .eyebrow{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:.85rem;letter-spacing:.04em;color:var(--ink-soft);margin-bottom:22px}
  .eyebrow::before{content:"";width:26px;height:1.5px;background:var(--amber-deep)}
  .hero h1{font-size:clamp(2.5rem,5.4vw,4rem)}
  .hero h1 em{font-style:normal;color:var(--amber-deep)}
  .hero p.lead{font-size:1.22rem;color:var(--ink-soft);margin:24px 0 34px;max-width:30em}
  .cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
  .trust{margin-top:26px;font-size:.92rem;color:var(--ink-soft);display:flex;align-items:center;gap:8px}
  .trust .dot{width:7px;height:7px;border-radius:50%;background:var(--amber)}

  /* hero visual */
  .hero-visual{position:relative;display:flex;justify-content:center;align-items:center;min-height:380px}
  .moon{position:absolute;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle at 50% 45%,rgba(232,154,60,.45),rgba(232,154,60,.06) 62%,transparent 72%);filter:blur(2px);z-index:0}
  .owl-stage{position:relative;z-index:2;width:230px;height:230px;background:var(--cream);border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow)}
  .owl-stage svg{width:150px;height:150px}
  .speech{position:absolute;z-index:3;background:var(--ink);color:var(--cream);font-family:"Fraunces",serif;font-style:italic;font-size:1.05rem;padding:12px 18px;border-radius:16px;box-shadow:var(--shadow-sm);bottom:8px;right:0}
  .speech::after{content:"";position:absolute;top:-7px;left:34px;width:14px;height:14px;background:var(--ink);transform:rotate(45deg)}
  .tag-float{position:absolute;z-index:3;top:18px;left:-6px;background:var(--cream);border:1px solid var(--line);border-radius:14px;padding:10px 14px;font-size:.82rem;font-weight:600;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:8px}
  .tag-float .tick{width:20px;height:20px;border-radius:50%;background:var(--amber);color:var(--ink);display:grid;place-items:center;font-size:.7rem;font-weight:700}

  /* stat band */
  .band{background:var(--ink);color:var(--cream);padding:44px 0}
  .band .wrap{display:flex;align-items:center;gap:30px;flex-wrap:wrap;justify-content:space-between}
  .band .big{font-family:"Fraunces",serif;font-size:clamp(2.4rem,5vw,3.4rem);line-height:1;color:var(--amber)}
  .band p{max-width:30em;font-size:1.1rem;color:#D8E3DD}

  /* sections */
  section.block{padding:84px 0}
  .kicker{font-weight:600;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--amber-deep);margin-bottom:14px}
  .block h2{font-size:clamp(2rem,4vw,2.9rem);max-width:16em}
  .block .sub{color:var(--ink-soft);font-size:1.12rem;margin-top:14px;max-width:34em}

  /* steps */
  .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:52px}
  .step{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:28px 22px;position:relative}
  .step .num{font-family:"Fraunces",serif;font-size:2.3rem;color:var(--amber-deep);line-height:1;margin-bottom:12px}
  .step h3{font-size:1.32rem;margin-bottom:8px}
  .step p{color:var(--ink-soft)}

  /* sms preview */
  .preview{background:var(--ink);color:var(--cream)}
  .preview .wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
  .preview .kicker{color:var(--amber)}
  .preview h2{color:var(--cream)}
  .preview p.note{color:#C4D4CD;font-size:1.08rem;margin-top:18px;max-width:30em}
  .phone{justify-self:center;width:286px;background:#0f211c;border-radius:42px;padding:14px;box-shadow:0 40px 80px -30px rgba(0,0,0,.6);border:1px solid #2a4339}
  .phone-screen{background:#11241e;border-radius:30px;padding:18px 14px 20px}
  .msg-viewport{position:relative;height:300px;overflow:hidden;-webkit-mask-image:linear-gradient(to bottom,transparent 0,#000 16px,#000 calc(100% - 18px),transparent 100%);mask-image:linear-gradient(to bottom,transparent 0,#000 16px,#000 calc(100% - 18px),transparent 100%)}
  .msg-track{position:absolute;top:0;left:0;right:0;will-change:transform}
  .phone-top{text-align:center;color:#9fb6ad;font-size:.74rem;margin-bottom:18px}
  .sender{text-align:center;margin-bottom:18px}
  .sender .avatar{width:46px;height:46px;border-radius:50%;background:var(--amber);margin:0 auto 7px;display:grid;place-items:center}
  .sender .avatar svg{width:28px;height:28px}
  .sender .name{font-weight:700;font-size:.95rem;color:var(--cream)}
  .bubble{background:#e9e9eb;color:#111;border-radius:18px;border-bottom-left-radius:5px;padding:13px 15px;font-size:.92rem;line-height:1.5;max-width:92%;box-shadow:0 2px 6px rgba(0,0,0,.2)}
  .bubble strong{font-weight:700}
  .bubble .sig{display:block;margin-top:9px;font-style:italic;color:#444}
  .stamp{font-size:.68rem;color:#7f968d;margin:6px 0 0 6px}

  /* values */
  .cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:52px}
  .card{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;transition:transform .2s ease,box-shadow .2s ease}
  .card:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm)}
  .card .ico{width:50px;height:50px;border-radius:14px;background:rgba(232,154,60,.16);display:grid;place-items:center;margin-bottom:18px}
  .card .ico svg{width:26px;height:26px;stroke:var(--amber-deep)}
  .card h3{font-size:1.28rem;margin-bottom:8px}
  .card p{color:var(--ink-soft)}

  /* pricing */
  .pricing{background:var(--cream-2)}
  .stripe-wrap{max-width:900px;margin:46px auto 0}
  .stripe-wrap stripe-pricing-table{display:block}

  /* faq */
  .faq-list{max-width:940px;margin:42px auto 0;display:grid;grid-template-columns:1fr 1fr;gap:0 48px;align-items:start}
  .faq{border-bottom:1px solid var(--line)}
  .faq summary{list-style:none;cursor:pointer}
  .faq summary::-webkit-details-marker{display:none}
  .faq summary::marker{content:""}
  .faq button{width:100%;background:none;border:none;text-align:left;padding:15px 2px;font-family:"Hanken Grotesk";font-size:1rem;font-weight:600;color:var(--ink);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:14px;line-height:1.4}
  .faq button .pm{flex:0 0 auto;font-size:1.45rem;font-weight:300;color:var(--amber-deep);line-height:1;transition:transform .25s ease}
  .faq[open] button .pm{transform:rotate(45deg)}
  .faq .ans{overflow:hidden;max-height:0;transition:max-height .3s ease;color:var(--ink-soft)}
  .faq[open] .ans{max-height:260px}
  .faq .ans p{padding:0 2px 16px;font-size:.95rem;line-height:1.55}

  /* waitlist */
  .waitlist{background:var(--ink);color:var(--cream);text-align:center}
  .waitlist h2{color:var(--cream);font-size:clamp(2rem,4vw,2.8rem);max-width:18em;margin:0 auto}
  .waitlist p.sub{color:#C4D4CD;margin:16px auto 0;max-width:32em;font-size:1.1rem}
  .form{max-width:480px;margin:34px auto 0;display:flex;gap:10px}
  .form input{flex:1;padding:16px 20px;border-radius:100px;border:1px solid #3a564c;background:#16302a;color:var(--cream);font-family:"Hanken Grotesk";font-size:1rem}
  .form input::placeholder{color:#8aa399}
  .form input:focus{outline:2px solid var(--amber)}
  .form .btn{white-space:nowrap}
  .thanks{display:none;max-width:480px;margin:30px auto 0;background:#16302a;border:1px solid #3a564c;border-radius:18px;padding:26px;font-family:"Fraunces",serif;font-size:1.25rem;font-style:italic}
  .thanks.show{display:block;animation:pop .4s ease}
  .micro{margin-top:16px;font-size:.85rem;color:#8aa399}
  @keyframes pop{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}

  /* footer */
  footer{padding:48px 0;background:var(--cream);border-top:1px solid var(--line)}
  footer .wrap{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
  footer .brand{font-size:1.25rem}
  footer .tagline{font-family:"Fraunces",serif;font-style:italic;color:var(--ink-soft)}
  footer .legal{font-size:.82rem;color:var(--ink-soft);width:100%;margin-top:10px}

  /* threats / prevention */
  .threats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:48px}
  .threat{background:var(--cream);border:1px solid var(--line);border-left:3px solid var(--coral);border-radius:var(--radius);padding:26px}
  .threat .scam-tag{display:inline-flex;align-items:center;gap:8px;font-size:.74rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--coral);margin-bottom:13px}
  .threat .scam-tag .dot{width:7px;height:7px;border-radius:50%;background:var(--coral)}
  .threat h3{font-size:1.24rem;margin-bottom:8px}
  .threat p{color:var(--ink-soft);font-size:1rem}
  .threat .trap{margin-top:14px;font-size:.95rem;color:var(--coral);font-weight:600}
  .threat .trap span{color:var(--ink-soft);font-weight:400}
  .stat-callout{margin-top:30px;background:rgba(216,101,75,.08);border:1px solid rgba(216,101,75,.25);border-radius:var(--radius);padding:24px 28px;display:flex;gap:20px;align-items:center;flex-wrap:wrap}
  .stat-callout .figure{font-family:"Fraunces",serif;font-size:2.4rem;color:var(--coral);line-height:1;flex:0 0 auto}
  .stat-callout p{color:var(--ink-2);max-width:42em;font-size:1.02rem}

  /* roadmap */
  .roadmap{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px}
  .road{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:28px 26px;position:relative}
  .road .soon{position:absolute;top:22px;right:22px;font-size:.66rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--amber-deep);background:rgba(232,154,60,.16);border:1px solid rgba(232,154,60,.35);padding:4px 10px;border-radius:100px}
  .road .live{position:absolute;top:22px;right:22px;font-size:.66rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#2f6b4f;background:rgba(47,107,79,.14);border:1px solid rgba(47,107,79,.4);padding:4px 10px;border-radius:100px}
  .road .ico{width:46px;height:46px;border-radius:13px;background:rgba(232,154,60,.14);display:grid;place-items:center;margin-bottom:16px}
  .road .ico svg{width:24px;height:24px;stroke:var(--amber-deep);fill:none}
  .road h3{font-size:1.2rem;margin-bottom:7px;max-width:12em}
  .road p{color:var(--ink-soft);font-size:1rem}

  /* entrance animation */
  .reveal{opacity:0;transform:translateY(18px);animation:rise .7s cubic-bezier(.2,.7,.2,1) forwards}
  .d1{animation-delay:.05s}.d2{animation-delay:.16s}.d3{animation-delay:.28s}.d4{animation-delay:.4s}.d5{animation-delay:.52s}
  @keyframes rise{to{opacity:1;transform:none}}

  @media(min-width:901px) and (max-width:1024px){
    .roadmap{grid-template-columns:repeat(2,1fr)}
  }
  @media(max-width:900px){
    .hero-grid,.preview .wrap,.band .wrap{grid-template-columns:1fr}
    .hero-visual{order:-1;min-height:300px}
    .steps,.cards,.threats-grid,.roadmap,.faq-list{grid-template-columns:1fr}
    .preview .wrap{gap:40px}
    .nav .hide-sm{display:none}
    .burger{display:flex}
    .nav-right .btn{display:none}
    .nav-links{position:fixed;top:74px;left:0;right:0;background:var(--ink);border-bottom:1px solid #2a4339;flex-direction:column;align-items:stretch;gap:0;padding:8px 24px 22px;transform:translateY(-10px);opacity:0;pointer-events:none;transition:transform .22s ease,opacity .22s ease;box-shadow:0 24px 40px -20px rgba(0,0,0,.5);z-index:60}
    .nav-links.open{transform:none;opacity:1;pointer-events:auto}
    .nav-links a:not(.btn){padding:16px 2px;border-bottom:1px solid #2a4339;font-size:1.08rem;color:var(--cream)}
    .nav-links a:not(.btn):last-of-type{border-bottom:none}
    .nav-links .nav-cta{display:inline-flex;justify-content:center;margin-top:16px;background:var(--amber);color:var(--ink)}
    .nav-overlay{display:block;position:fixed;inset:74px 0 0;background:rgba(15,33,28,.5);z-index:40;opacity:0;pointer-events:none;transition:opacity .22s ease}
    .nav-overlay.open{opacity:1;pointer-events:auto}
  }
  @media(max-width:520px){
    .form{flex-direction:column}
    .form .btn{width:100%;justify-content:center}
    .hero{padding:48px 0 64px}
    section.block{padding:60px 0}
  }

  /* accessibilité */
  .skip-link{position:absolute;left:12px;top:-60px;z-index:200;background:var(--ink);color:var(--cream);font-family:"Hanken Grotesk";font-weight:600;padding:12px 18px;border-radius:0 0 12px 12px;transition:top .2s ease}
  .skip-link:focus{top:0;outline:2px solid var(--amber)}
  .visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
  a:focus-visible,button:focus-visible,summary:focus-visible{outline:2px solid var(--amber-deep);outline-offset:2px;border-radius:6px}

/* ── Page landing ── */
.crumbs{font-size:.85rem;color:var(--ink-soft);padding-top:20px;display:flex;gap:8px;flex-wrap:wrap}
  .crumbs a:hover{color:var(--amber-deep)}
  .crumbs .sep{opacity:.5}
  .crumbs .cur{color:var(--ink)}
  .foot-links{display:flex;flex-wrap:wrap;gap:8px 22px;width:100%;margin-top:6px}
  .foot-links a{font-size:.9rem;color:var(--ink-soft)}
  .foot-links a:hover{color:var(--amber-deep)}
  .prose p{color:var(--ink-soft);font-size:1.1rem;margin-top:16px;max-width:44em}
  .prose h3{font-size:1.45rem;margin-top:36px}
  .prose ul{margin:16px 0 0;padding-left:1.1em;max-width:44em}
  .prose li{color:var(--ink-soft);font-size:1.08rem;margin-top:10px;padding-left:6px}
  .prose li::marker{color:var(--amber-deep)}
  .rule-box{margin-top:30px;background:rgba(47,107,79,.08);border:1px solid rgba(47,107,79,.3);border-radius:var(--radius);padding:26px 30px}
  .rule-box .label{font-size:.74rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#2f6b4f;margin-bottom:8px;display:flex;align-items:center;gap:8px}
  .rule-box .label svg{width:18px;height:18px;stroke:#2f6b4f;fill:none}
  .rule-box p{color:var(--ink-2);font-size:1.08rem;margin:0;max-width:46em}
  .related .cards .card{display:block;color:inherit}
  .related .card .arrow{margin-top:14px;color:var(--amber-deep);font-weight:600;font-size:.94rem}
  .related .card:hover .arrow{text-decoration:underline}  .takeaway-box{background:var(--cream-2);border:1px solid var(--line);border-left:3px solid var(--amber-deep);border-radius:0 var(--radius) var(--radius) 0;padding:20px 24px;margin:0 0 8px}
  .takeaway-label{font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--amber-deep);margin-bottom:12px}
  .takeaway-list{list-style:none;display:flex;flex-direction:column;gap:8px;margin:0;padding:0}
  .takeaway-list li{font-size:.96rem;color:var(--ink-2);display:grid;grid-template-columns:20px 1fr;gap:6px;align-items:start;line-height:1.5}
  .takeaway-list li::before{content:"✓";color:var(--amber-deep);font-weight:700;line-height:1.5}
