/* ===========================================================================
   InkCurity — personal portfolio of Jan Klotz
   Dark "Ink-craft" design system. No external resources, no trackers.
   =========================================================================== */

/* ---- Self-hosted fonts ---------------------------------------------------- */
@font-face{font-family:"Fredoka";src:url("/assets/fonts/fredoka-400.woff2") format("woff2");font-weight:400;font-display:swap}
@font-face{font-family:"Fredoka";src:url("/assets/fonts/fredoka-600.woff2") format("woff2");font-weight:600;font-display:swap}
@font-face{font-family:"Inter";src:url("/assets/fonts/inter-400.woff2") format("woff2");font-weight:400;font-display:swap}
@font-face{font-family:"Inter";src:url("/assets/fonts/inter-500.woff2") format("woff2");font-weight:500;font-display:swap}
@font-face{font-family:"Inter";src:url("/assets/fonts/inter-700.woff2") format("woff2");font-weight:700;font-display:swap}
@font-face{font-family:"JetBrains Mono";src:url("/assets/fonts/jetbrains-mono-400.woff2") format("woff2");font-weight:400;font-display:swap}
@font-face{font-family:"JetBrains Mono";src:url("/assets/fonts/jetbrains-mono-500.woff2") format("woff2");font-weight:500;font-display:swap}
@font-face{font-family:"Caveat";src:url("/assets/fonts/caveat-400.woff2") format("woff2");font-weight:400;font-display:swap}
@font-face{font-family:"Caveat";src:url("/assets/fonts/caveat-700.woff2") format("woff2");font-weight:700;font-display:swap}

/* ---- Tokens --------------------------------------------------------------- */
:root{
  --bg:#070b1a;
  --bg-elev:#0c1328;
  --bg-elev-2:#111b38;
  --border:rgba(118,140,205,.16);
  --border-strong:rgba(118,140,205,.32);
  --text:#e8ecf8;
  --muted:#8893b8;
  --faint:#586492;
  --accent:#5eead4;
  --accent-ink:#2dd4bf;
  --accent-2:#ec4899;
  --amber:#fbbf24;
  --glow-sm:0 0 0 1px rgba(94,234,212,.05), 0 10px 34px -14px rgba(94,234,212,.20);
  --glow-md:0 0 0 1px rgba(94,234,212,.13), 0 16px 52px -14px rgba(94,234,212,.34);
  --glow-lg:0 0 0 1px rgba(94,234,212,.18), 0 24px 74px -16px rgba(94,234,212,.46);
  --maxw:1080px;
  --radius:16px;
  --gap:clamp(1rem,3vw,2rem);
  --font-display:"Fredoka",system-ui,sans-serif;
  --font-body:"Inter",system-ui,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  --font-hand:"Caveat","Comic Sans MS",cursive;
}

:root.theme-light{
  --bg:#fff7ed;
  --bg-elev:#ffffff;
  --bg-elev-2:#fff1f2;
  --border:rgba(190,24,93,.18);
  --border-strong:rgba(190,24,93,.34);
  --text:#24111d;
  --muted:#6f4b5d;
  --faint:#9f6b82;
  --accent:#db2777;
  --accent-ink:#be185d;
  --accent-2:#0891b2;
  --glow-sm:0 0 0 1px rgba(219,39,119,.08), 0 10px 34px -16px rgba(190,24,93,.18);
  --glow-md:0 0 0 1px rgba(219,39,119,.14), 0 16px 52px -18px rgba(190,24,93,.26);
  --glow-lg:0 0 0 1px rgba(219,39,119,.18), 0 24px 74px -20px rgba(190,24,93,.34);
}

/* ---- Reset / base --------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;overflow-x:hidden}
body{
  min-height:100vh;
  overflow-x:hidden;
  background:var(--bg);
  background-image:
    radial-gradient(1000px 560px at 84% -12%,rgba(56,120,220,.18),transparent 62%),
    radial-gradient(900px 560px at 6% 108%,rgba(120,70,200,.14),transparent 60%),
    radial-gradient(700px 420px at 92% 96%,rgba(94,234,212,.05),transparent 60%);
  background-attachment:fixed;
  color:var(--text);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
:root.theme-light body{
  background-image:
    radial-gradient(1000px 560px at 84% -12%,rgba(219,39,119,.16),transparent 62%),
    radial-gradient(900px 560px at 6% 108%,rgba(8,145,178,.12),transparent 60%),
    radial-gradient(700px 420px at 92% 96%,rgba(251,191,36,.12),transparent 60%);
}
:root.theme-light ::selection{background:rgba(219,39,119,.22);color:#24111d}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

img,svg{display:block;max-width:100%}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--accent-ink)}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}
::selection{background:rgba(94,234,212,.28);color:#fff}

h1,h2,h3{font-family:var(--font-display);font-weight:600;line-height:1.1;letter-spacing:-.01em}
strong{font-weight:700;color:#fff}
:root.theme-light strong{color:#24111d}
hr{border:0;height:1px;background:var(--border);margin:2.5rem 0}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.1rem,4vw,2rem)}
.page{padding:clamp(2.5rem,7vw,5rem) 0 4rem}
.lead{color:var(--muted);font-size:1.15rem;max-width:60ch}

/* eyebrow / mono labels */
.eyebrow,.mono{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.eyebrow{display:inline-flex;align-items:center;flex-wrap:wrap;gap:.6rem;margin-bottom:1.4rem;max-width:100%;line-height:1.45}
.eyebrow::before{content:"";width:3px;height:1.05em;background:var(--accent);display:inline-block;border-radius:2px}
.dash::before{content:"— ";color:var(--faint)}

/* hand-written marginalia */
.note{
  font-family:var(--font-hand);font-size:1.32rem;line-height:1.25;
  color:var(--accent);transform:rotate(-2deg);display:inline-block;
}
.note .arrow{color:var(--accent-2);font-family:var(--font-mono);font-size:.95rem}

/* ---- Nav ------------------------------------------------------------------ */
.nav{position:sticky;top:0;z-index:50;background:rgba(7,11,26,.80);backdrop-filter:blur(10px)}
:root.theme-light .nav{
  background:rgba(255,250,245,.88);
  border-bottom:1px solid rgba(190,24,93,.12);
  box-shadow:0 12px 34px -30px rgba(190,24,93,.45);
}
.nav-inner{display:flex;align-items:center;gap:1.5rem;height:68px}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--font-mono);font-weight:500;font-size:1.05rem;color:var(--text)}
.brand img{width:28px;height:28px}
.brand b{color:var(--accent);font-weight:500}
.brand:hover{color:var(--text)}
:root.theme-light .brand:hover{color:var(--accent-ink)}
.nav-links{margin-left:auto;display:flex;align-items:center;gap:clamp(.9rem,3vw,2rem)}
.nav-links a{font-family:var(--font-mono);font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--accent)}
.pill{
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--accent);border:1px solid var(--border-strong);border-radius:999px;
  padding:.34rem .7rem;display:inline-flex;align-items:center;gap:.45rem;background:transparent;cursor:pointer;
}
.pill .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent)}
.lang{color:var(--muted);border-color:var(--border)}
.lang:hover{color:var(--accent);border-color:var(--border-strong)}
.hairline{
  height:2px;opacity:.9;
  background:linear-gradient(90deg,var(--accent),var(--accent-2),#6366f1,var(--accent));
  background-size:300% 100%;
  animation:hairslide 7s linear infinite;
  box-shadow:0 0 12px -2px rgba(94,234,212,.5);
}
:root.theme-light .hairline{box-shadow:0 0 12px -2px rgba(219,39,119,.42)}
@keyframes hairslide{to{background-position:-300% 0}}

/* ---- Hero ----------------------------------------------------------------- */
.hero{padding:clamp(3rem,9vw,6.5rem) 0 2rem}
.hero h1{
  font-size:clamp(2.6rem,8vw,5.4rem);line-height:1.04;letter-spacing:-.02em;
  max-width:16ch;
}
.hero h1 .ink{position:relative;color:var(--accent);white-space:nowrap}
.hero h1 .ink svg{
  position:absolute;left:-2%;right:-2%;bottom:-.18em;width:104%;height:.4em;
  color:var(--accent-2);overflow:visible;
}
.hero h1 .ink path{
  stroke:currentColor;stroke-width:7;fill:none;stroke-linecap:round;
  stroke-dasharray:1;stroke-dashoffset:1;
  animation:draw 1.1s ease .35s forwards;
}
@keyframes draw{to{stroke-dashoffset:0}}
.cursor{
  display:inline-block;width:.5ch;height:1em;background:var(--accent);
  vertical-align:-.08em;margin-left:.06em;animation:blink 1.1s steps(1) infinite;
}
@keyframes blink{50%{opacity:0}}
.hero p{margin-top:1.6rem;color:var(--muted);font-size:1.22rem;max-width:54ch}
.hero p b{color:var(--text)}
.cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:2.2rem;align-items:center}

.btn{
  font-family:var(--font-mono);font-size:.86rem;letter-spacing:.04em;
  display:inline-flex;align-items:center;gap:.55rem;padding:.78rem 1.25rem;
  border-radius:10px;border:1px solid transparent;transition:transform .15s ease,background .15s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--accent);color:#04130f;font-weight:500}
.btn-primary:hover{background:var(--accent-ink);color:#04130f}
.btn-ghost{border-color:var(--border-strong);color:var(--text)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn-link{color:var(--muted)}
.btn-link:hover{color:var(--accent)}

/* ---- Status block --------------------------------------------------------- */
.status{
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  margin-top:3rem;padding:1.5rem 0;display:grid;gap:.85rem;
}
.status-row{font-family:var(--font-mono);font-size:.82rem;letter-spacing:.06em;color:var(--text);
  display:flex;flex-wrap:wrap;gap:.5rem 2.5rem}
.status-row span{display:inline-flex;gap:.7rem}
.status-row .k{color:var(--muted);text-transform:uppercase;letter-spacing:.16em;min-width:9ch}
.status-row .k.live{color:var(--accent)}

/* ---- Wax / public-key seal ------------------------------------------------ */
.seal{
  margin-top:2.5rem;display:flex;gap:1.1rem;align-items:center;
  background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);
  padding:1.1rem 1.3rem;max-width:420px;position:relative;box-shadow:var(--glow-md);
  transition:box-shadow .25s ease,transform .2s ease;
}
.seal:hover{box-shadow:var(--glow-lg);transform:translateY(-3px);animation:glowBreathStrong 2s ease-in-out infinite}
.seal .stamp{
  flex:none;width:54px;height:54px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,rgba(236,72,153,.55),rgba(236,72,153,.18));
  border:2px dashed rgba(236,72,153,.6);display:grid;place-items:center;
  color:var(--accent-2);font-family:var(--font-mono);font-size:1.2rem;
}
.seal h3{font-family:var(--font-body);font-weight:700;font-size:.95rem;color:#fff;margin-bottom:.2rem}
.seal .fp{font-family:var(--font-mono);font-size:.86rem;color:var(--muted);letter-spacing:.04em}
.seal .fp b{color:var(--accent)}

/* ---- Terminal status block ------------------------------------------------ */
.term{
  margin-top:3rem;max-width:680px;overflow:hidden;border-radius:14px;
  background:#070c1a;border:1px solid var(--border);box-shadow:var(--glow-sm);
  font-family:var(--font-mono);font-size:.86rem;line-height:1.5;
}
:root.theme-light .term{background:#fffaf5}
.term-bar{
  display:flex;align-items:center;gap:.8rem;padding:.6rem .95rem;
  background:rgba(255,255,255,.03);border-bottom:1px solid var(--border);
}
.term-dots{display:flex;gap:7px}
.term-dots i{width:11px;height:11px;border-radius:50%;display:block}
.term-dots i:nth-child(1){background:#ff5f57}
.term-dots i:nth-child(2){background:#febc2e}
.term-dots i:nth-child(3){background:#28c840}
.term-title{color:var(--faint);letter-spacing:.06em;font-size:.78rem}
.term-body{padding:1.15rem 1.25rem}
.term-body{overflow:visible}
.term-line{color:var(--muted);margin:.12rem 0;white-space:nowrap}
/* fish powerline prompt (jan@inkcurity theme) */
.pl{display:inline-flex;align-items:stretch;vertical-align:middle}
.pl .seg{display:inline-flex;align-items:center;padding:.04rem .5rem;font-size:.78rem;font-weight:600;letter-spacing:.01em}
.pl .seg.vi{background:#2faa3f;color:#06210b}
.pl .seg.user{background:#ccd2db;color:#20242d}
.pl .seg.user b{color:#444b59;font-weight:700}
.pl .seg.path{background:#2b3142;color:#cdd6ea}
.pl .seg.path b{color:#fff;font-weight:700}
.pl .chev{width:0;align-self:stretch;border-top:.62rem solid transparent;border-bottom:.62rem solid transparent;border-left:.42rem solid;margin-right:.2rem}
.pl .chev.vi{border-left-color:#2faa3f}
.pl .chev.user{border-left-color:#ccd2db}
.pl .chev.path{border-left-color:#2b3142}
.term-cmd{color:#e8ecf8;margin-left:.3rem}
:root.theme-light .term-cmd{color:var(--text)}
.term-out{color:var(--text);margin:.1rem 0 .8rem 0}
.term-out::before{content:"› ";color:var(--faint)}
.term-out:last-of-type{margin-bottom:0}
.term-out .dot-on{
  display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 8px var(--accent);vertical-align:middle;margin-right:.45rem;
}
.term-line .cursor{vertical-align:-.18em;margin-left:.25rem}
/* interactive prompt */
.term{cursor:text}
.term-form{display:flex;align-items:center;flex-wrap:nowrap}
.term-input{
  flex:1;min-width:3ch;background:transparent;border:0;outline:0;padding:0;
  margin-left:.35rem;color:#e8ecf8;font:inherit;caret-color:var(--accent);
}
:root.theme-light .term-input{color:var(--text)}
.term-input::placeholder{color:var(--faint)}
.term-echo{color:var(--muted);margin:.12rem 0}
.term-err{color:#ff6b8b;margin:.1rem 0 .8rem;white-space:pre-wrap}
.term-help{color:var(--muted);margin:.1rem 0 .8rem;white-space:pre-wrap}
.term-help b{color:#e8ecf8;font-weight:600}
:root.theme-light .term-help b{color:var(--text)}
.term-help .sw{display:inline-block;width:.62em;height:.62em;border-radius:50%;
  vertical-align:-.02em;margin:0 .12rem;border:1px solid rgba(255,255,255,.18)}
.term-ok{color:var(--accent);margin:.1rem 0 .8rem}
.term-ascii{
  color:var(--muted);margin:.1rem 0 .8rem;white-space:pre;overflow-x:auto;
  font-family:var(--font-mono);font-size:.82rem;line-height:1.35;
}
.term-ascii b{color:#e8ecf8;font-weight:600}
:root.theme-light .term-ascii b{color:var(--text)}
.term-ascii .nf-logo,.term-ascii .nf-key{color:var(--accent)}

/* ---- Footer contact list -------------------------------------------------- */
.reach{list-style:none;margin:0;padding:0}
.reach li{display:flex;align-items:center;gap:.6rem;margin-bottom:.6rem;
  font-family:var(--font-mono);font-size:.86rem;color:var(--muted)}
.reach li:last-child{margin-bottom:0}
.reach .ico{flex:none;width:18px;height:18px;color:var(--muted);display:block}
.reach .ico svg{width:18px;height:18px;display:block;fill:currentColor}
.reach a{color:var(--muted)}
.reach a:hover{color:var(--accent)}
.reach .sep{color:var(--faint);margin:0 .2rem}
.reach .dc{color:var(--muted)}
.hs-badge{height:18px;width:auto;display:inline-block;vertical-align:middle;margin-left:.15rem}
/* language toggle as a flag */
.pill.lang{padding:.32rem .5rem}
.pill.lang svg{width:22px;height:14px;border-radius:2px;display:block}

/* ---- Cards / grid --------------------------------------------------------- */
.grid{display:grid;gap:1.2rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}
.card{
  background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);
  padding:1.5rem;position:relative;overflow:hidden;box-shadow:var(--glow-sm);
  transition:transform .2s ease,border-color .2s ease,background .2s ease,box-shadow .25s ease;
}
.card::after{
  content:"";position:absolute;inset:auto -40% -60% auto;width:240px;height:240px;
  background:radial-gradient(circle,rgba(94,234,212,.10),transparent 70%);
  opacity:0;transition:opacity .25s ease;pointer-events:none;
}
.card:hover{transform:translateY(-4px);border-color:var(--border-strong);background:var(--bg-elev-2);box-shadow:var(--glow-md);animation:glowBreathStrong 2.6s ease-in-out infinite}
.card:hover::after{opacity:1}
.card.feature{border-color:rgba(236,72,153,.4);box-shadow:var(--glow-md)}
.card.feature:hover{box-shadow:var(--glow-lg);animation:glowBreathStrong 1.9s ease-in-out infinite}

@keyframes glowBreath{0%,100%{box-shadow:var(--glow-sm)}50%{box-shadow:var(--glow-md)}}
@keyframes glowBreathStrong{0%,100%{box-shadow:var(--glow-md)}50%{box-shadow:var(--glow-lg)}}
.card-meta{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.6rem}
.card-meta .mono{font-size:.74rem;letter-spacing:.16em}
.card h3{font-size:1.45rem;margin-bottom:.5rem}
.card p{color:var(--muted);font-size:.97rem}
.card .divider{border-top:1px dashed var(--border-strong);margin:1.1rem 0 .9rem}
.card-foot{display:flex;align-items:center;justify-content:space-between;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.1em;color:var(--muted)}
.card-foot a{color:var(--muted)}.card-foot a:hover{color:var(--accent)}

.badge{
  font-family:var(--font-mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;
  padding:.32rem .6rem;border-radius:999px;border:1px solid currentColor;display:inline-flex;align-items:center;gap:.4rem;
}
.badge::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.badge.mint{color:var(--accent)}
.badge.magenta{color:var(--accent-2)}
.badge.amber{color:var(--amber)}
.badge.muted{color:var(--faint)}

/* ---- Callouts ------------------------------------------------------------- */
.callouts{display:grid;gap:1.1rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));margin:1.8rem 0}
.callout{
  background:var(--bg-elev);border:1px solid var(--border);border-radius:14px;padding:1.15rem 1.25rem;
  display:flex;gap:.85rem;box-shadow:var(--glow-sm);
  transition:box-shadow .25s ease;
}
.callout:hover{box-shadow:var(--glow-md);animation:glowBreath 3s ease-in-out infinite}
.callout .ic{flex:none;width:28px;height:28px;border-radius:7px;display:grid;place-items:center;
  font-family:var(--font-mono);font-size:.95rem;background:rgba(94,234,212,.12);color:var(--accent)}
.callout.warn .ic{background:rgba(251,191,36,.14);color:var(--amber)}
.callout h4{font-family:var(--font-body);font-weight:700;font-size:.93rem;color:#fff;margin-bottom:.25rem}
.callout p{color:var(--muted);font-size:.9rem}

/* ---- Contact table -------------------------------------------------------- */
.contact{
  background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);
  padding:.6rem 1.4rem;font-family:var(--font-mono);font-size:.92rem;max-width:560px;
}
.contact div{
  display:grid;grid-template-columns:10ch minmax(0,1fr);column-gap:1.2rem;
  align-items:start;padding:.7rem 0;border-bottom:1px dashed var(--border);
}
.contact div:last-child{border-bottom:0}
.contact .k{color:var(--muted);white-space:nowrap}
.contact .k::before{content:"— ";color:var(--faint)}
.contact a{color:var(--accent);overflow-wrap:anywhere}

/* ---- Prose (legal pages) -------------------------------------------------- */
.prose{max-width:70ch}
.prose h2{font-size:1.5rem;margin:2.2rem 0 .7rem}
.prose p,.prose li{color:var(--muted);margin-bottom:.85rem}
.prose ul{padding-left:1.2rem;margin-bottom:1rem}
.prose a{text-decoration:underline;text-underline-offset:3px}
.back{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);display:block;width:max-content;max-width:100%;margin-bottom:1rem}
.back + .eyebrow{display:flex;margin-bottom:1.3rem}
.back:hover{color:var(--accent)}

/* ---- Footer --------------------------------------------------------------- */
.footer{border-top:1px solid var(--border);margin-top:5rem;padding:3rem 0 2.5rem}
.footer-cols{display:grid;gap:2rem;grid-template-columns:1.4fr 1fr 1fr}
.footer h5{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);margin-bottom:1rem}
.footer h5::before{content:"— "}
.footer p{color:var(--muted);font-size:.9rem;max-width:34ch}
.footer ul{list-style:none}
.footer li{margin-bottom:.55rem}
.footer li a{font-family:var(--font-mono);font-size:.86rem;color:var(--muted)}
.footer li a:hover{color:var(--accent)}
.footer-base{display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;
  margin-top:2.5rem;padding-top:1.5rem;border-top:1px dashed var(--border);
  font-family:var(--font-mono);font-size:.78rem;color:var(--faint)}
.censor{display:inline-flex;gap:5px}
.censor i{display:block;width:14px;height:11px;background:rgba(99,109,131,.4);border-radius:2px}

/* ---- Ink splatter accent -------------------------------------------------- */
.splat{position:absolute;color:var(--accent-2);opacity:.05;pointer-events:none;z-index:-1}
.splat.a{top:8%;right:-40px;width:240px;transform:rotate(12deg)}
.splat.b{bottom:6%;left:-50px;width:200px;transform:rotate(-18deg);color:var(--accent)}

/* ---- Reveal on scroll ----------------------------------------------------- */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ---- Easter-egg splatter burst ------------------------------------------- */
.burst{position:fixed;inset:0;pointer-events:none;z-index:999;display:grid;place-items:center}
.burst svg{
  width:min(58vw,480px);color:var(--accent-2);
  filter:drop-shadow(0 0 18px rgba(236,72,153,.5));
  animation:burstFade 1.15s linear forwards;
}
/* hand-drawn ink frames played like a sprite (steps feel) */
.burst .fr{opacity:0}
.burst .f1{animation:sf1 1.15s linear forwards}
.burst .f2{animation:sf2 1.15s linear forwards}
.burst .f3{animation:sf3 1.15s linear forwards}
.burst .f4{animation:sf4 1.15s linear forwards}
@keyframes sf1{0%,10%{opacity:1}10.01%,100%{opacity:0}}
@keyframes sf2{0%,10%{opacity:0}10.01%,21%{opacity:1}21.01%,100%{opacity:0}}
@keyframes sf3{0%,21%{opacity:0}21.01%,34%{opacity:1}34.01%,100%{opacity:0}}
@keyframes sf4{0%,34%{opacity:0}34.01%,80%{opacity:1}100%{opacity:0}}
@keyframes burstFade{0%{transform:scale(.96)}30%{transform:scale(1.03)}45%,100%{transform:scale(1)}}

/* clickable seal stamp */
.seal .stamp{cursor:pointer;transition:transform .2s ease}
.seal .stamp:hover{transform:rotate(-8deg) scale(1.08)}
.seal .stamp.sealed{animation:stamp .55s ease}
@keyframes stamp{0%{transform:scale(1)}38%{transform:scale(.74) rotate(-12deg)}70%{transform:scale(1.12) rotate(4deg)}100%{transform:scale(1)}}

/* hero triple-click ink flash */
.hero h1.ink-flash .ink{animation:inkflash 1.1s ease}
@keyframes inkflash{0%,100%{color:var(--accent)}45%{color:var(--accent-2);text-shadow:0 0 22px rgba(236,72,153,.65)}}

/* status pill click feedback */
.pill.poked .dot{animation:pokedot .6s ease}
@keyframes pokedot{50%{transform:scale(2.4);background:var(--accent-2);box-shadow:0 0 12px var(--accent-2)}}

/* ---- Responsive ----------------------------------------------------------- */
@media (max-width:760px){
  body{font-size:16px}
  .wrap{padding:0 clamp(1rem,5vw,1.35rem)}
  .nav-links{gap:.9rem}
  .nav-links .navlink{display:none}
  .footer-cols{grid-template-columns:1fr;gap:1.6rem}
  .eyebrow{font-size:.72rem;letter-spacing:.14em;line-height:1.55}
  .page{padding-top:clamp(2.1rem,8vw,3rem)}
  .page h1{overflow-wrap:anywhere}
  .hero{padding:clamp(2.6rem,10vw,4rem) 0 1.5rem}
  .hero h1{font-size:clamp(2.35rem,11vw,3rem);max-width:100%}
  .hero h1 .ink{display:block;width:max-content;max-width:100%}
  .hero h1 .ink svg{left:0;right:0;width:100%}
  .hero p{font-size:1.08rem}
  .cta{gap:.7rem}
  .btn{padding:.72rem 1rem}
  .btn-link{flex-basis:100%;max-width:100%;white-space:normal;overflow-wrap:anywhere}
  .note{font-size:1.1rem;display:block;transform:rotate(-1deg);max-width:100%}
  .seal{max-width:100%}
  .term{font-size:.78rem;border-radius:12px}
  .term-title{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .term-body{padding:.9rem .85rem;overflow:hidden}
  .pl .seg{font-size:.7rem;padding:.03rem .38rem}
  .back{display:inline-flex;align-items:center;gap:.3rem;border:1px solid var(--border);border-radius:7px;padding:.26rem .6rem .26rem .45rem;margin-bottom:.85rem;width:auto;transition:border-color .2s ease,color .15s ease}
  .back:hover{border-color:var(--border-strong)}
  .back + .eyebrow{margin-bottom:1.1rem}
  .grid{grid-template-columns:minmax(0,1fr)}
  .callouts{grid-template-columns:1fr}
  .splat.a{right:-20px;width:min(180px,45vw)}
  .splat.b{left:-20px;width:min(160px,42vw)}
}

/* ---- Reduced motion ------------------------------------------------------- */
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  .hero h1 .ink path{stroke-dashoffset:0}
  .cursor{opacity:1}
}
