/* ============================================================
   Lino — landing & legal pages · shared styles
   ============================================================ */
:root{
  --bg:#FAEFE6;
  --card:#FFFFFF;
  --soft:#FBF4ED;
  --ink:#1F1A17;
  --muted:#6F635B;
  --line:#EFE0D2;
  --line-soft:#F5EAD9;
  --accent:#2E78EE;
  --accent-soft:#E8F1FE;
  --g-brand:linear-gradient(155deg,#DFD8F2 0%,#E8F1FE 55%,#F7CFD9 100%);
  --maxw:1120px;
  --radius:20px;
}

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

html{scroll-behavior:smooth}
body{
  font-family:'Inter',-apple-system,system-ui,sans-serif;
  background:var(--bg);color:var(--ink);
  -webkit-font-smoothing:antialiased;
  line-height:1.55;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

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

h1,h2,h3{font-family:'Fraunces',Georgia,serif;font-weight:500;letter-spacing:-0.02em;line-height:1.08;color:var(--ink)}
em{font-style:italic;color:var(--accent)}

.eyebrow{
  font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--accent);
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:'Inter',sans-serif;font-size:15px;font-weight:600;
  padding:13px 22px;border-radius:14px;border:none;cursor:pointer;
}
.btn.primary{background:var(--accent);color:#fff;box-shadow:0 8px 20px -10px rgba(46,120,238,.55)}
.btn.ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn .arrow{font-family:'Fraunces',serif;font-style:italic;font-weight:400}

/* store badges */
.stores{display:flex;flex-wrap:wrap;gap:12px}
.store{
  display:inline-flex;align-items:center;gap:12px;
  background:var(--ink);color:#fff;border-radius:13px;padding:10px 20px;transition:opacity .15s;
}
.store:hover{opacity:.88}
.store svg{width:21px;height:21px;flex-shrink:0;fill:#fff}
.store>span{display:flex;flex-direction:column;line-height:1;text-align:left}
.store .st-top{font-size:9.5px;opacity:.72;letter-spacing:.03em;margin-bottom:3px}
.store .st-big{font-size:16.5px;font-weight:600;line-height:1;font-family:'Fraunces',serif;letter-spacing:-0.01em}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:20;background:#fff}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:88px}
.brand{display:flex;align-items:center;gap:10px}
.brand img{width:34px;height:34px;object-fit:contain}
.brand b{font-family:'Fraunces',serif;font-size:22px;font-weight:500;letter-spacing:-0.01em}
.nav-links{display:flex;align-items:center;gap:38px}
.nav-links a{font-size:14px;font-weight:500;color:var(--muted)}
.nav-links a:hover{color:var(--ink)}
.nav-links .btn{padding:9px 16px;font-size:14px}
@media(max-width:720px){.nav-links a:not(.btn){display:none}}

/* ---------- hero ---------- */
.hero{padding:64px 0 40px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero h1{font-size:clamp(40px,6vw,64px)}
.hero p.lede{font-size:18px;color:var(--muted);margin:18px 0 28px;max-width:34ch}
.hero-art{
  position:relative;border-radius:34px;background:var(--g-brand);
  aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;
}
.hero-art::before{content:"";position:absolute;width:56%;height:56%;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.55),transparent 70%);top:8%;right:6%}
.hero-art img{
  width:78%;position:relative;z-index:2;
  filter:drop-shadow(0 22px 30px rgba(80,40,20,.20));
}
.hero .micro{font-size:13px;color:var(--muted);margin-top:14px}
@media(max-width:860px){.hero-grid{grid-template-columns:1fr;gap:32px}.hero-art{max-width:380px;order:-1}}

/* ---------- section ---------- */
.section{padding:64px 0}
.section-head{max-width:640px;margin-bottom:40px}
.section-head h2{font-size:clamp(28px,4vw,40px)}
.section-head p{color:var(--muted);font-size:17px;margin-top:12px}

/* ---------- features ---------- */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:860px){.feat-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.feat-grid{grid-template-columns:1fr}}
.feat{background:var(--card);border:1px solid var(--line-soft);border-radius:var(--radius);padding:24px}
.feat .ic{
  font-family:'Fraunces',serif;font-style:italic;font-weight:500;
  font-size:50px;line-height:1;color:var(--accent);margin-bottom:14px;
}
.feat h3{font-size:19px}
.feat p{color:var(--muted);font-size:14.5px;margin-top:8px}

/* ---------- story rows with phone mockups ---------- */
.story{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;padding:46px 0}
.story.rev .story-text{order:2}
@media(max-width:820px){.story{grid-template-columns:1fr;gap:24px}.story.rev .story-text{order:0}}
.story-text h2{font-size:clamp(28px,3.6vw,38px)}
.story-text p{color:var(--muted);font-size:17px;margin-top:14px;max-width:40ch}
.story-art{position:relative;display:flex;justify-content:center;align-items:center;min-height:520px}
.story-art .stage-bg{position:absolute;inset:8% 4%;border-radius:36px;background:var(--g-brand)}
.story.s-rooms .stage-bg{background:linear-gradient(160deg,#E5F1E0,#CDE5C7)}
.story.s-nudge .stage-bg{background:linear-gradient(160deg,#FFEDE6,#FFD9CC)}

/* phone */
.phone{position:relative;width:248px;flex:none;background:#fff;border-radius:42px;padding:8px;box-shadow:0 46px 80px -40px rgba(80,40,20,.45);z-index:2}
.phone .scr{position:relative;border-radius:34px;overflow:hidden;background:var(--card);aspect-ratio:9/19.3}
.phone .notch{position:absolute;top:8px;left:50%;transform:translateX(-50%);width:78px;height:19px;background:#1F1A17;border-radius:999px;z-index:5}
.phone-ghost{position:absolute;width:248px;aspect-ratio:9/19.3;border-radius:42px;background:rgba(255,255,255,.55);box-shadow:0 40px 70px -45px rgba(80,40,20,.3);z-index:1}

/* mini app screen */
.mini{position:absolute;inset:0;padding:34px 13px 12px;display:flex;flex-direction:column;gap:8px;font-family:'Inter',sans-serif}
.mini-top{display:flex;align-items:center;justify-content:space-between}
.mini-brand{display:flex;align-items:center;gap:6px;font-family:'Fraunces',serif;font-size:14px;font-weight:500}
.mini-brand img{width:17px;height:17px}
.mini-av{width:22px;height:22px;border-radius:50%;background:#F2C2C8;color:#8E2D40;display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-size:10px;font-weight:600}
.mini-h{font-family:'Fraunces',serif;font-size:17px;font-weight:500;letter-spacing:-0.01em;line-height:1.1;margin-top:4px}
.mini-h em{color:var(--accent);font-style:italic}
.mini-sub{font-size:10px;color:var(--muted);margin-top:-2px}
.mini-sec{font-size:8.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-top:6px}
.mini-filters{display:flex;gap:5px;flex-wrap:wrap}
.mchip{font-size:9px;font-weight:600;padding:5px 9px;border-radius:999px;border:1px solid var(--line-soft);color:var(--ink);background:#fff;white-space:nowrap}
.mchip.on{background:var(--accent-soft);border-color:transparent;color:var(--accent)}
.mtask{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line-soft);border-radius:12px;padding:8px 9px}
.mtask.pin{background:var(--g-brand);border-color:transparent;position:relative}
.mtask .chk{width:14px;height:14px;border-radius:50%;border:1.6px solid #d9c8b8;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.mtask.done .chk{background:var(--accent-soft);border-color:transparent;color:var(--accent);font-size:9px}
.mtask .tx{flex:1;min-width:0}
.mtask .tx b{display:block;font-size:11px;font-weight:600;color:var(--ink);line-height:1.2}
.mtask.done .tx b{color:var(--muted);text-decoration:line-through}
.mtask .tx span{font-size:8.5px;color:var(--muted)}
.mroom{font-size:8px;font-weight:600;padding:2px 6px;border-radius:5px;flex-shrink:0}
.mroom.k{background:#FFE8C9;color:#9A6A12}
.mroom.b{background:#CFDDEE;color:#1F4F7A}
.mroom.l{background:#F2C2C8;color:#8E2D40}
.mroom.s{background:#C5E8D9;color:#1F6F58}
.mrec{color:var(--accent);flex-shrink:0;display:flex}
.mrec svg{width:12px;height:12px}

/* lock-screen mini */
.mini-lock{position:absolute;inset:0;background:var(--g-brand);display:flex;flex-direction:column;align-items:center;padding-top:54px}
.lk-time{font-family:'Fraunces',serif;font-size:50px;font-weight:500;color:#1F1A17;line-height:1;letter-spacing:-0.02em}
.lk-date{font-size:10px;color:#6F635B;margin-top:4px}
.lk-note{margin:auto 12px 22px;background:rgba(255,255,255,.78);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.6);border-radius:18px;padding:12px 13px;box-shadow:0 14px 28px -14px rgba(80,40,20,.3)}
.lk-note .nh{display:flex;align-items:center;gap:7px;font-size:9.5px;color:var(--muted)}
.lk-note .nh img{width:15px;height:15px}
.lk-note .nh b{color:var(--ink);font-weight:600}
.lk-note .nb{font-size:11.5px;font-weight:600;color:var(--ink);margin-top:7px;line-height:1.3}
.lk-note .ns{font-size:10.5px;color:var(--muted);margin-top:2px;line-height:1.3}

/* floating accent chip over a phone (glass) */
.float-chip{
  position:absolute;z-index:4;display:flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.72);backdrop-filter:blur(18px) saturate(1.6);
  border:1px solid rgba(255,255,255,.7);border-radius:16px;padding:10px 13px;
  box-shadow:0 20px 40px -18px rgba(80,40,20,.32);max-width:230px;
}
.float-chip .fc-ic{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}
.float-chip b{display:block;font-size:12.5px;font-weight:700;color:var(--ink);line-height:1.15}
.float-chip span{font-size:11px;color:var(--muted);line-height:1.2}
.fc-tl{top:8%;left:-6%}
.fc-br{bottom:10%;right:-6%}

/* ============================================================
   v3 — hero card, schematic phone, how it works, tiles
   ============================================================ */
.section.tint{background:var(--accent-soft)}

/* hero as a rounded card */
.hero2{padding:40px 0 16px}
.hero-card{position:relative;overflow:hidden;background:var(--accent-soft);border-radius:38px;
  display:grid;grid-template-columns:1.04fr .96fr;gap:44px;align-items:center;padding:62px 60px}
.hero-card .hb{position:absolute;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.6),transparent 70%);top:-130px;right:-90px;z-index:0}
.hero-card .hc-text{position:relative;z-index:1}
.hero-card h1{font-size:clamp(42px,5.2vw,64px)}
.hero-card .lede{color:var(--muted);font-size:18px;margin:18px 0 26px;max-width:30ch}
.hero-card .micro{font-size:13px;color:var(--muted);margin-top:14px}
@media(max-width:840px){.hero-card{grid-template-columns:1fr;text-align:center;padding:40px 24px}.hero-card .lede{margin-left:auto;margin-right:auto}.hero-card .stores{justify-content:center}}
.hero-art2{position:relative;display:flex;align-items:center;justify-content:center;z-index:1;min-height:480px}
.hero-mascot{position:absolute;width:136px;left:0;bottom:0;z-index:3;filter:drop-shadow(0 16px 22px rgba(80,40,20,.18))}

/* schematic phone — thin outline */
.sphone{position:relative;width:252px;flex:none;background:#fff;border-radius:44px;padding:8px;
  box-shadow:0 50px 90px -40px rgba(60,30,15,.5),0 8px 24px -10px rgba(60,30,15,.2);z-index:2}
.sphone.sm{width:198px;border-radius:36px;padding:6px}
.sphone .scr{position:relative;border-radius:37px;overflow:hidden;background:#fff;aspect-ratio:9/19.3}
.sphone .shot{display:block;width:100%;height:100%;object-fit:cover;object-position:top center}
/* how-it-works — bare screenshot, no device frame, bigger */
.shot-card{width:264px;max-width:100%;border-radius:30px;overflow:hidden;background:#fff;margin-bottom:24px;
  box-shadow:0 38px 70px -30px rgba(60,30,15,.42),0 6px 18px -8px rgba(60,30,15,.16)}
.shot-card img{display:block;width:100%}
.hero-shot{width:284px;margin-bottom:0}
.sphone.sm .scr{border-radius:31px}
.sphone .notch{position:absolute;top:10px;left:50%;transform:translateX(-50%);width:72px;height:20px;border-radius:999px;background:#1F1A17;z-index:6}
.sphone.sm .notch{width:54px;height:15px;top:8px}
.m-status{display:flex;justify-content:space-between;align-items:center;font-size:9.5px;font-weight:600;color:var(--ink);padding:0 3px 1px}
.sphone.sm .m-status{font-size:8px}
.m-status .bat{width:16px;height:8px;border:1.2px solid currentColor;border-radius:2px;opacity:.85;position:relative;flex-shrink:0}
.m-status .bat::after{content:"";position:absolute;left:1.5px;top:1.5px;bottom:1.5px;right:5px;background:currentColor;border-radius:1px}

/* mini app screen */
.mini{position:absolute;inset:0;padding:36px 13px 12px;display:flex;flex-direction:column;gap:7px;font-family:'Inter',sans-serif}
.sphone.sm .mini{padding:28px 9px 10px;gap:6px}
.m-top{display:flex;align-items:center;justify-content:space-between}
.m-brand{display:flex;align-items:center;gap:5px;font-family:'Fraunces',serif;font-size:13px;font-weight:500}
.m-brand img{width:15px;height:15px}
.m-av{width:20px;height:20px;border-radius:50%;background:#F2C2C8;color:#8E2D40;display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-size:9px;font-weight:600}
.m-h{font-family:'Fraunces',serif;font-size:15px;font-weight:500;letter-spacing:-0.01em;margin-top:3px;line-height:1.1}
.m-h em{color:var(--accent);font-style:italic}
.m-sub{font-size:9px;color:var(--muted)}
.m-sec{font-size:8px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-top:4px}
.m-filters{display:flex;gap:4px;flex-wrap:wrap}
.fchip{font-size:8px;font-weight:600;padding:4px 7px;border-radius:999px;border:1px solid var(--line-soft);background:#fff;white-space:nowrap}
.fchip.on{background:var(--accent-soft);border-color:transparent;color:var(--accent)}
.task{display:flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--line-soft);border-radius:11px;padding:7px 8px}
.task.pin{background:var(--g-brand);border-color:transparent}
.ck{width:13px;height:13px;border-radius:50%;border:1.5px solid #d9c8b8;flex-shrink:0}
.tt{flex:1;min-width:0}
.tt b{display:block;font-size:10px;font-weight:600;line-height:1.2}
.tt span{font-size:8px;color:var(--muted)}
.rm{font-size:7.5px;font-weight:600;padding:2px 5px;border-radius:5px;flex-shrink:0}
.rm.k{background:#FFE8C9;color:#9A6A12}.rm.b{background:#CFDDEE;color:#1F4F7A}.rm.l{background:#F2C2C8;color:#8E2D40}.rm.s{background:#C5E8D9;color:#1F6F58}.rm.bd{background:#C8B8D5;color:#4A3370}
.rec{color:var(--accent);display:flex;flex-shrink:0}.rec svg{width:11px;height:11px}
.m-nav{margin-top:auto;display:flex;align-items:center;gap:12px;padding:8px 4px 2px;border-top:1px solid var(--line-soft)}
.m-nav .ni{font-size:7.5px;font-weight:600;color:var(--muted)}
.m-nav .ni.on{color:var(--accent)}
.m-nav .fab{margin-left:auto;width:22px;height:22px;border-radius:8px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;line-height:1}
.sphone.sm .m-nav .ni{font-size:6.5px}
.mini-lock{position:absolute;inset:0;background:var(--g-brand);display:flex;flex-direction:column;align-items:center;padding-top:42px}
.lk-time{font-family:'Fraunces',serif;font-size:40px;font-weight:500;letter-spacing:-0.02em;line-height:1}
.lk-date{font-size:8.5px;color:#6F635B;margin-top:3px}
.lk-note{margin:auto 9px 16px;background:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.6);border-radius:15px;padding:10px 11px;box-shadow:0 12px 22px -12px rgba(60,30,15,.3)}
.lk-note .nh{display:flex;align-items:center;gap:5px;font-size:8px;color:var(--muted)}
.lk-note .nh img{width:12px;height:12px}.lk-note .nh b{color:var(--ink);font-weight:600}
.lk-note .nb{font-size:10px;font-weight:600;margin-top:5px;line-height:1.25}
.lk-note .ns{font-size:8.5px;color:var(--muted);margin-top:2px;line-height:1.25}

/* how it works */
.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:8px}
@media(max-width:760px){.how-grid{grid-template-columns:1fr;gap:40px;max-width:320px;margin:0 auto}}
.how-step{text-align:center;display:flex;flex-direction:column;align-items:center}
.how-step .sphone{margin-bottom:20px}
.how-num{width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.how-step h3{font-size:19px}
.how-step p{color:var(--muted);font-size:14.5px;margin-top:8px;max-width:30ch}

/* tile colours for the WHAT'S INSIDE grid */

/* ---------- band (quote / philosophy) ---------- */
.band{background:var(--accent-soft);border-radius:32px;padding:56px 40px;text-align:center;margin:8px 0}
.band h2{font-size:clamp(26px,4vw,38px);max-width:18ch;margin:0 auto}
.band p{color:var(--muted);font-size:17px;margin:16px auto 0;max-width:48ch}

/* ---------- pricing ---------- */
.price-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;max-width:760px;margin:0 auto}
@media(max-width:640px){.price-grid{grid-template-columns:1fr}}
.plan{background:var(--card);border:1px solid var(--line-soft);border-radius:var(--radius);padding:28px}
.plan.featured{border-color:var(--accent);box-shadow:0 18px 40px -22px rgba(46,120,238,.4)}
.plan .tag{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.plan.featured .tag{color:var(--accent)}
.plan .price{font-family:'Fraunces',serif;font-size:34px;font-weight:500;margin:8px 0 2px}
.plan .price span{font-size:15px;color:var(--muted);font-family:'Inter',sans-serif;font-weight:500}
.plan ul{list-style:none;margin:18px 0 0;display:flex;flex-direction:column;gap:10px}
.plan li{font-size:14.5px;color:var(--ink);display:flex;gap:10px;align-items:flex-start}
.plan li::before{content:"✓";color:var(--accent);font-weight:700;flex-shrink:0}
.plan li.off{color:var(--muted)}
.plan li.off::before{content:"–";color:var(--muted)}

/* ---------- CTA strip ---------- */
.cta{text-align:center;padding:72px 0}
.cta h2{font-size:clamp(30px,5vw,46px)}
.cta p{color:var(--muted);font-size:17px;margin:14px 0 26px}
.cta .stores{justify-content:center}

/* ---------- footer ---------- */
.footer{border-top:1px solid var(--line-soft);padding:44px 0;margin-top:40px}
.footer-in{display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between;align-items:flex-start}
.footer .brand b{font-size:20px}
.footer .f-tag{color:var(--muted);font-size:13.5px;margin-top:10px;max-width:30ch}
.f-cols{display:flex;gap:56px;flex-wrap:wrap}
.f-col h4{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:12px}
.f-col a{display:block;font-size:14px;color:var(--ink);margin-bottom:9px}
.f-col a:hover{color:var(--accent)}
.f-base{margin-top:32px;padding-top:20px;border-top:1px solid var(--line-soft);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:var(--muted);font-size:13px}

/* ---------- legal / prose pages ---------- */
.legal{padding:56px 0 40px}
.legal .prose{max-width:740px;margin:0 auto}
.legal h1{font-size:clamp(34px,5vw,48px)}
.legal .updated{color:var(--muted);font-size:14px;margin-top:12px}
.legal .note{background:var(--soft);border:1px solid var(--line-soft);border-radius:14px;padding:14px 18px;font-size:13.5px;color:var(--muted);margin:24px 0}
.prose h2{font-size:22px;margin:36px 0 10px}
.prose h3{font-size:17px;margin:22px 0 6px;font-family:'Inter',sans-serif;font-weight:700;letter-spacing:0}
.prose p{color:var(--muted);font-size:15.5px;margin:10px 0}
.prose ul{margin:10px 0 10px 22px;color:var(--muted);font-size:15.5px}
.prose li{margin:6px 0}
.prose a{color:var(--accent);font-weight:500}
.back-link{display:inline-flex;gap:6px;align-items:center;color:var(--accent);font-size:14px;font-weight:600;margin-bottom:8px}
