/* ============================================================
   Notico — shared styles (single source of truth)
   Edit here once; every page that links this file updates.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,500;12..96,600;12..96,700;12..96,800&family=Hanken+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root{
  --paper:#f6f8fc;--paper-2:#e9eff8;--ink:#14213d;--ink-soft:#42506b;--ink-mute:#74809a;
  --line:rgba(20,33,61,.12);--line-soft:rgba(20,33,61,.07);
  --blue:#1f62e0;--blue-bright:#4f8bf5;--blue-wash:#e4ecfc;
  --cta:#3a8dff;--cta-deep:#2f78e0;          /* product accent (blue) */
  --early:#ff4c4c;--early-deep:#e63b3b;       /* primary Get Early Access (red) */
  --green:#0fa37a;--navy:#0f1d39;--navy-2:#16264a;
  --radius:18px;
  --shadow-sm:0 1px 2px rgba(20,33,61,.05),0 4px 14px rgba(20,33,61,.05);
  --shadow-md:0 12px 40px rgba(20,33,61,.10);
  --shadow-lg:0 30px 80px rgba(20,33,61,.16);
  --display:"Bricolage Grotesque",serif;--body:"Hanken Grotesk",sans-serif;--mono:"JetBrains Mono",monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--body);background:var(--paper);color:var(--ink);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
::selection{background:var(--blue);color:#fff}
section[id]{scroll-margin-top:84px}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--mono);font-size:.72rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--blue);display:inline-flex;align-items:center;gap:.55em}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.06;letter-spacing:-.025em}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;font-family:var(--body);font-weight:600;font-size:.97rem;padding:.85em 1.35em;border-radius:999px;cursor:pointer;border:1px solid transparent;transition:transform .25s cubic-bezier(.2,.7,.2,1),box-shadow .25s,background .2s;white-space:nowrap}
.btn-primary{background:var(--early);color:#fff;font-weight:700;box-shadow:0 8px 22px rgba(255,76,76,.36)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(255,76,76,.5);background:var(--early-deep)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{background:#fff;transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.btn-blue{background:var(--cta);color:#fff}
.btn-blue:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(58,141,255,.4)}
.btn svg{width:1.05em;height:1.05em}
.btn-signin{gap:.45em}
.btn-signin svg{width:1.15em;height:1.15em}

/* ============================================================
   COMPONENT: header  (data-component="header")
   ============================================================ */
[data-component="header"]{display:contents}
.site-header{position:sticky;top:0;z-index:60;transition:background .3s,box-shadow .3s,border-color .3s;border-bottom:1px solid transparent}
.site-header.scrolled{background:#fff;backdrop-filter:saturate(160%) blur(14px);border-bottom-color:var(--line-soft);box-shadow:0 2px 18px rgba(20,33,61,.07)}
.site-header .nav{display:flex;align-items:center;justify-content:space-between;height:70px;gap:1rem}
.brand{display:flex;align-items:center;gap:.55rem;font-family:var(--display);font-weight:800;font-size:1.32rem;letter-spacing:-.03em;color:var(--ink)}
.brand .mark{width:30px;height:30px;flex:0 0 auto;object-fit:contain;filter:drop-shadow(0 1px 3px rgba(20,33,61,.28))}
.nav-links{display:flex;align-items:center;gap:1.7rem}
.nav-links a{font-size:.93rem;font-weight:500;color:var(--ink-soft);position:relative}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-5px;height:2px;width:0;background:var(--blue);transition:width .28s}
.nav-links a:hover{color:var(--ink)}.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:.6rem}
.burger{display:none;background:none;border:1px solid var(--line);border-radius:10px;width:42px;height:42px;cursor:pointer;align-items:center;justify-content:center;color:var(--ink)}
.burger svg{width:22px;height:22px}
.mnav{display:none;flex-direction:column;position:fixed;inset:70px 0 auto 0;z-index:55;background:rgba(246,248,252,.98);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);padding:1rem 24px 1.4rem;transform:translateY(-130%);transition:transform .35s ease}
.mnav.open{transform:translateY(0)}
.mnav a{padding:.85rem 0;font-weight:600;border-bottom:1px solid var(--line-soft);color:var(--ink)}
.mnav .btn{margin-top:.9rem}

/* ============================================================
   COMPONENT: recent blogs  (data-component="recent-blogs")
   Horizontal, scroll-snap carousel; cards peek; images fill.
   ============================================================ */
.recent{padding:clamp(40px,5vw,64px) 0;--cols:3.5}  /* desktop: 3 full + half peeking */
.recent .rb-head{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;flex-wrap:wrap;margin-bottom:1.6rem}
.recent .rb-head h2{font-size:clamp(1.5rem,3vw,2.1rem);margin-top:.5rem}
.rb-scroller{overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:4px 2px 16px;scroll-padding-left:2px}
.rb-scroller::-webkit-scrollbar{display:none}
.rb-track{display:flex;gap:1.1rem;width:max-content}
.rb-card{flex:0 0 auto;width:calc((min(100vw - 48px, 1132px) - (var(--cols) - 1) * 1.1rem) / var(--cols));min-width:0;scroll-snap-align:start;display:flex;flex-direction:column;gap:.7rem}
.rb-card .thumb{width:100%;aspect-ratio:16/10;border-radius:14px;overflow:hidden;background:var(--paper-2);border:1px solid var(--line);position:relative;transition:transform .3s,box-shadow .3s}
.rb-card .thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.rb-card:hover .thumb{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.rb-card .kicker{font-family:var(--mono);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute)}
.rb-card h3{font-size:.98rem;line-height:1.25;transition:color .2s}
.rb-card:hover h3{color:var(--blue)}
.rb-empty{aspect-ratio:16/10;border-radius:14px;border:1px dashed var(--line);background:var(--paper-2);display:flex;align-items:center;justify-content:center;color:var(--ink-mute);font-family:var(--mono);font-size:.7rem}

/* ---------- ALL POSTS (full blog list grid, used on /blog/) ---------- */
.bloglist{padding:clamp(40px,6vw,80px) 0 clamp(48px,6vw,84px)}
.bl-intro{max-width:60ch;margin-bottom:clamp(28px,4vw,48px)}
.bl-intro h1{font-size:clamp(2.1rem,5vw,3.4rem);margin:.6rem 0 .8rem}
.bl-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2.2vw,30px)}
.bl-card{display:flex;flex-direction:column;gap:.6rem}
.bl-thumb{aspect-ratio:16/10;border-radius:14px;overflow:hidden;border:1px solid var(--line);background:var(--paper-2);transition:transform .3s,box-shadow .3s}
.bl-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.bl-card:hover .bl-thumb{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.bl-card:hover .bl-thumb img{transform:scale(1.04)}
.bl-card .kicker{font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--blue)}
.bl-card h2{font-size:1.04rem;line-height:1.3;letter-spacing:-.02em;transition:color .2s}
.bl-card:hover h2{color:var(--blue)}
.bl-ex{font-size:.86rem;color:var(--ink-soft);line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.bl-meta{font-family:var(--mono);font-size:.7rem;color:var(--ink-mute);margin-top:auto;padding-top:.3rem}
@media(max-width:1100px){.bl-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:820px){.bl-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.bl-grid{grid-template-columns:1fr}}

/* ============================================================
   COMPONENT: early access  (data-component="early-access")
   ============================================================ */
.early{padding:clamp(56px,7vw,90px) 0}
.cta{background:linear-gradient(135deg,var(--blue),var(--navy));color:#fff;border-radius:30px;padding:clamp(40px,6vw,68px) clamp(28px,5vw,60px);text-align:center;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 15%,rgba(120,170,255,.32),transparent 42%),radial-gradient(circle at 8% 100%,rgba(255,255,255,.14),transparent 45%)}
.cta-inner{position:relative;max-width:600px;margin:0 auto}
.cta h2{color:#fff;font-size:clamp(1.7rem,3.4vw,2.4rem)}
.cta p{color:rgba(255,255,255,.85);margin:1rem auto 1.7rem;max-width:46ch}
.seg{display:inline-flex;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.28);border-radius:999px;padding:.3rem;margin:1.25rem auto 1.3rem;gap:.25rem}
.seg-btn{border:none;background:transparent;color:rgba(255,255,255,.86);font-family:var(--body);font-weight:600;font-size:.9rem;padding:.55em 1.15em;border-radius:999px;cursor:pointer;transition:background .2s,color .2s;white-space:nowrap}
.seg-btn.active{background:#fff;color:var(--blue)}
.seg-btn:not(.active):hover{color:#fff}
.form{display:flex;gap:.6rem;max-width:480px;margin:0 auto;background:#fff;border-radius:999px;padding:.4rem;box-shadow:var(--shadow-lg)}
.form input[type=email]{flex:1;border:none;outline:none;background:transparent;padding:.7em 1.1em;font-family:var(--body);font-size:.97rem;color:var(--ink);min-width:0}
.form .btn{flex:0 0 auto}
.formmsg{margin-top:.9rem;font-size:.9rem;font-weight:600;min-height:1.2em}
.fine{font-family:var(--mono);font-size:.74rem;color:rgba(255,255,255,.7);margin-top:1.1rem}

/* early-access POPUP (used on pages that have no #early section) */
.early-modal{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;padding:28px}
.early-modal.open{display:flex}
.em-backdrop{position:absolute;inset:0;background:rgba(15,29,57,.55);backdrop-filter:blur(5px)}
.em-dialog{position:relative;width:100%;max-width:620px;animation:em-in .32s cubic-bezier(.2,.7,.2,1)}
.em-dialog .cta{border-radius:26px}
.em-close{position:absolute;top:-16px;right:-16px;width:46px;height:46px;border-radius:50%;background:var(--blue);color:#fff;border:3px solid #fff;font-size:1.7rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);z-index:3;padding:0}
.em-close:hover{background:var(--blue-bright);transform:scale(1.06)}
@keyframes em-in{from{opacity:0;transform:translateY(22px) scale(.98)}to{opacity:1;transform:none}}

/* ============================================================
   COMPONENT: footer  (data-component="footer")
   ============================================================ */
.site-footer{background:var(--navy);color:rgba(255,255,255,.7);padding:clamp(48px,6vw,72px) 0 32px}
.site-footer .foot-top{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;align-items:flex-start;padding-bottom:2.4rem;border-bottom:1px solid rgba(255,255,255,.1)}
.site-footer .foot-brand{max-width:300px}
.site-footer .foot-brand .brand{color:#fff;margin-bottom:.8rem}
.site-footer .foot-brand p{font-size:.88rem;color:rgba(255,255,255,.55)}
.site-footer .foot-cols{display:flex;gap:clamp(2rem,5vw,5rem);flex-wrap:wrap}
.site-footer .foot-col h4{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.45);margin-bottom:1rem;font-weight:500}
.site-footer .foot-col a{display:block;font-size:.92rem;margin-bottom:.7rem;color:rgba(255,255,255,.78)}
.site-footer .foot-col a:hover{color:#fff}
.site-footer .foot-bot{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding-top:1.8rem;font-size:.82rem;color:rgba(255,255,255,.45)}

/* ---------- shared reveal animation ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:900px){
  .recent{--cols:2.5}              /* tablet: 2 full + half peeking */
}
@media(max-width:720px){
  .nav-links{display:none}
  .burger{display:flex}
  .mnav{display:flex}
  .site-header .nav{gap:.55rem}               /* tighter so CTAs never overlap the logo */
  .nav-cta{gap:.45rem}
  /* sign-in stays on mobile, icon only */
  .btn-signin .signin-txt{display:none}
  .btn-signin{padding:0;width:42px;height:42px;border-radius:10px}   /* match the hamburger */
  .site-header .brand-name{display:none}      /* mobile: logo mark only, frees space */
  .seg{gap:.2rem}
  .seg-btn{font-size:.82rem;padding:.5em .85em}
  /* smaller header CTA padding on mobile */
  .site-header .nav-cta .btn-primary{padding:.6em .9em;font-size:.9rem}
  .em-close{top:-12px;right:6px}
  .form{flex-direction:column;border-radius:18px;padding:.6rem}
  .form .btn{width:100%}
  .recent{--cols:1.5}              /* mobile: 1 full + half peeking */
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}.mq-track{animation:scroll 32s linear infinite!important}}
