/* =========================================================================
   MYTHOSH — Design System
   Editorial / Swiss-meets-playful. Paper + ink + per-tool accents.
   Hand-built. No framework.
   ========================================================================= */

/* ----- Fonts: Fontshare (Clash Display + General Sans) — distinctive, not the
   default Inter/Roboto stack that screams "template". ----- */
@import url('https://api.fontshare.com/v2/css?f[]=clash-display@600,700&f[]=general-sans@400,500,600&display=swap');

/* ---------------------------------- Reset --------------------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{min-height:100%;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img,svg,video{display:block;max-width:100%;height:auto}
button,input,textarea,select{font:inherit;color:inherit}
button{background:none;border:none;cursor:pointer}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
:focus-visible{outline:3px solid var(--lime);outline-offset:3px;border-radius:4px}

/* --------------------------------- Tokens --------------------------------- */
:root{
  /* surfaces */
  --paper:#F2EFE6;
  --paper-2:#EAE6D9;
  --card:#FBF9F3;
  --ink:#15140E;
  --ink-2:#2c2b22;
  --ink-70:rgba(21,20,14,.70);
  --ink-50:rgba(21,20,14,.50);
  --ink-30:rgba(21,20,14,.30);
  --line:rgba(21,20,14,.13);
  --line-2:rgba(21,20,14,.22);

  /* accents */
  --lime:#CBF23E;
  --lime-deep:#A8CC1F;
  --violet:#6B4BF0;   /* JSON  */
  --teal:#0FB5A6;     /* QR    */
  --coral:#FF5A3C;    /* PDF   */
  --sun:#FFB23C;      /* Image */

  /* type */
  --display:'Clash Display','Clash Display Placeholder',system-ui,sans-serif;
  --sans:'General Sans','General Sans Placeholder',system-ui,-apple-system,sans-serif;
  --mono:ui-monospace,'SF Mono','Cascadia Code','JetBrains Mono',Menlo,monospace;

  /* geometry */
  --maxw:1280px;
  --gutter:clamp(20px,5vw,72px);
  --r-sm:10px;
  --r:18px;
  --r-lg:28px;
  --r-xl:40px;

  /* motion */
  --ease:cubic-bezier(.16,1,.3,1);
  --ease-out:cubic-bezier(.22,1,.36,1);
  --dur:.6s;

  --header-h:74px;
}

/* --------------------------------- Base ----------------------------------- */
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  font-size:clamp(1rem,.97rem + .2vw,1.075rem);
  overflow-x:hidden;
  position:relative;
}

/* subtle film grain — reads as intentional texture, not template */
body::before{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.035;
  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='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

::selection{background:var(--lime);color:var(--ink)}

/* ------------------------------- Typography ------------------------------- */
h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:.98;letter-spacing:-.02em}
h1{font-size:clamp(2.7rem,1.6rem + 5.4vw,6.6rem)}
h2{font-size:clamp(2rem,1.2rem + 3.4vw,4.3rem)}
h3{font-size:clamp(1.4rem,1.1rem + 1.2vw,2.1rem);line-height:1.02}
h4{font-size:clamp(1.1rem,1rem + .5vw,1.35rem);line-height:1.1;letter-spacing:-.01em}
p{max-width:62ch}
strong{font-weight:600}

.eyebrow{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-50);display:inline-flex;align-items:center;gap:.6em;font-weight:500;
}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--ink-30)}
.eyebrow--center::before{display:none}

.mark{
  background:linear-gradient(180deg,transparent 58%,var(--lime) 58%);
  padding:0 .04em;
}
.text-lg{font-size:clamp(1.1rem,1rem + .6vw,1.35rem);color:var(--ink-70);line-height:1.5}

/* --------------------------------- Layout --------------------------------- */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(64px,9vw,140px)}
.section--tight{padding-block:clamp(48px,6vw,90px)}
.divider{height:1px;background:var(--line);border:0}

.grid{display:grid;gap:clamp(20px,3vw,40px)}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.cols-3,.cols-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.cols-2,.cols-3,.cols-4{grid-template-columns:1fr}}

/* --------------------------------- Buttons -------------------------------- */
.btn{
  --bg:var(--ink);--fg:var(--paper);
  position:relative;display:inline-flex;align-items:center;gap:.6em;
  padding:.95em 1.5em;border-radius:100px;font-weight:600;font-size:.98rem;
  background:var(--bg);color:var(--fg);overflow:hidden;isolation:isolate;
  transition:transform .35s var(--ease),color .35s var(--ease);
  will-change:transform;line-height:1;
}
.btn svg{width:1.05em;height:1.05em;transition:transform .35s var(--ease)}
.btn::after{
  content:"";position:absolute;inset:0;z-index:-1;border-radius:inherit;
  background:var(--lime);transform:translateY(101%);transition:transform .4s var(--ease);
}
.btn:hover{color:var(--ink)}
.btn:hover::after{transform:translateY(0)}
.btn:hover svg{transform:translate(3px,-3px)}
.btn:active{transform:scale(.97)}

.btn--ghost{--bg:transparent;--fg:var(--ink);border:1.5px solid var(--line-2)}
.btn--ghost:hover{color:var(--ink)}
.btn--lime{--bg:var(--lime);--fg:var(--ink)}
.btn--lime::after{background:var(--ink)}
.btn--lime:hover{color:var(--paper)}
.btn--lg{padding:1.15em 1.9em;font-size:1.05rem}

.textlink{
  display:inline-flex;align-items:center;gap:.45em;font-weight:600;
  background:linear-gradient(var(--ink),var(--ink)) 0 100%/0 1.5px no-repeat;
  transition:background-size .4s var(--ease);padding-bottom:2px;
}
.textlink svg{width:1em;height:1em;transition:transform .35s var(--ease)}
.textlink:hover{background-size:100% 1.5px}
.textlink:hover svg{transform:translate(3px,-3px)}

/* ---------------------------------- Tags ---------------------------------- */
.tag{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;
  padding:.42em .7em;border:1px solid var(--line-2);border-radius:100px;color:var(--ink-70);
  display:inline-block;line-height:1;white-space:nowrap;
}
.tag--solid{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.tag--lime{background:var(--lime);border-color:var(--lime);color:var(--ink)}

/* ================================= HEADER ================================= */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--header-h);
  display:flex;align-items:center;
  transition:transform .45s var(--ease),background .35s ease,border-color .35s ease,backdrop-filter .35s ease;
  border-bottom:1px solid transparent;
}
.site-header.is-scrolled{
  background:rgba(242,239,230,.78);backdrop-filter:blur(14px) saturate(1.4);
  border-bottom-color:var(--line);
}
.site-header.is-hidden{transform:translateY(-100%)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;width:100%}

.brand{display:inline-flex;align-items:center;gap:.6em;font-family:var(--display);font-weight:700;font-size:1.3rem;letter-spacing:-.02em}
.brand__mark{width:30px;height:30px;flex:none}
.brand__dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--lime);margin-left:1px;align-self:flex-end;margin-bottom:.32em}

.nav{display:flex;align-items:center;gap:.35rem}
.nav a{
  position:relative;padding:.55em .85em;border-radius:100px;font-weight:500;font-size:.96rem;
  color:var(--ink-70);transition:color .25s ease;
}
.nav a::after{
  content:"";position:absolute;left:.85em;right:.85em;bottom:.42em;height:1.5px;
  background:var(--ink);transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease);
}
.nav a:hover{color:var(--ink)}
.nav a:hover::after{transform:scaleX(1)}
.nav a[aria-current="page"]{color:var(--ink)}
.nav a[aria-current="page"]::after{transform:scaleX(1);background:var(--lime);height:3px;bottom:.32em}

.header-cta{display:flex;align-items:center;gap:.75rem}

/* burger */
.burger{display:none;width:46px;height:46px;border-radius:50%;border:1.5px solid var(--line-2);position:relative}
.burger span{position:absolute;left:13px;right:13px;height:2px;background:var(--ink);transition:transform .35s var(--ease),opacity .2s ease}
.burger span:nth-child(1){top:18px}
.burger span:nth-child(2){top:24px}
.burger span:nth-child(3){top:30px}
body.nav-open .burger span:nth-child(1){transform:translateY(6px) rotate(45deg)}
body.nav-open .burger span:nth-child(2){opacity:0}
body.nav-open .burger span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

@media(max-width:860px){
  .nav,.header-cta .btn{display:none}
  .burger{display:block}
  .mobile-nav{display:flex}
}

/* mobile nav overlay */
.mobile-nav{
  position:fixed;inset:0;z-index:999;background:var(--paper);
  flex-direction:column;justify-content:center;gap:.25rem;padding:var(--gutter);
  transform:translateY(-100%);transition:transform .55s var(--ease);
  display:none;
}
@media(max-width:860px){.mobile-nav{display:flex}}
body.nav-open .mobile-nav{transform:translateY(0)}
.mobile-nav a{font-family:var(--display);font-size:clamp(2rem,9vw,3rem);font-weight:600;letter-spacing:-.02em;padding:.18em 0;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.mobile-nav a span{font-family:var(--mono);font-size:.8rem;color:var(--ink-50)}
.mobile-nav .btn{margin-top:1.5rem;align-self:flex-start}

/* ================================== HERO ================================= */
.hero{position:relative;padding-top:calc(var(--header-h) + clamp(40px,7vw,90px));padding-bottom:clamp(40px,6vw,70px);overflow:hidden}
.hero__inner{position:relative;z-index:2}
.hero h1{margin:.18em 0 .4em;max-width:14ch}
.hero h1 .line{display:block;overflow:hidden}
.hero h1 .line>span{display:block}
.hero__lead{max-width:46ch;font-size:clamp(1.05rem,1rem + .5vw,1.3rem);color:var(--ink-70)}
.hero__cta{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.2rem}

/* floating shapes */
.blob{position:absolute;border-radius:50%;filter:blur(2px);z-index:1;pointer-events:none;mix-blend-mode:multiply;opacity:.85}
.blob--1{width:clamp(160px,22vw,320px);height:clamp(160px,22vw,320px);background:var(--lime);top:8%;right:6%}
.blob--2{width:clamp(120px,15vw,220px);height:clamp(120px,15vw,220px);background:var(--violet);bottom:6%;right:24%;opacity:.5}
.blob--3{width:90px;height:90px;background:var(--coral);top:46%;left:-20px;opacity:.6}
@media(max-width:860px){.blob--2,.blob--3{display:none}.blob--1{opacity:.5;top:2%;right:-40px}}

/* hero stat chip */
.hero__chips{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:2.4rem}

/* =============================== MARQUEE ================================== */
.marquee{
  border-block:1px solid var(--ink);background:var(--lime);overflow:hidden;
  padding-block:.7rem;white-space:nowrap;
}
.marquee__track{display:inline-flex;gap:2.5rem;animation:marquee 28s linear infinite;will-change:transform}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee span{font-family:var(--display);font-weight:600;font-size:clamp(1rem,1.5vw,1.4rem);text-transform:uppercase;letter-spacing:.01em;display:inline-flex;align-items:center;gap:2.5rem}
.marquee span::after{content:"✺";color:var(--ink);font-size:.8em}
@keyframes marquee{to{transform:translateX(-50%)}}
.marquee--ink{background:var(--ink);border-color:var(--ink)}
.marquee--ink span{color:var(--paper)}
.marquee--ink span::after{color:var(--lime)}

/* ============================== TOOL CARDS =============================== */
.tools-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(18px,2.4vw,28px)}
@media(max-width:760px){.tools-grid{grid-template-columns:1fr}}

.tool-card{
  --accent:var(--violet);
  position:relative;display:flex;flex-direction:column;min-height:300px;
  background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:clamp(24px,3vw,38px);overflow:hidden;isolation:isolate;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .5s ease;
  will-change:transform;
}
.tool-card::before{
  content:"";position:absolute;inset:0;z-index:-1;background:var(--accent);opacity:0;
  transition:opacity .5s var(--ease);
}
.tool-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -28px rgba(21,20,14,.35);border-color:var(--accent)}
.tool-card__top{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:auto}
.tool-card__num{font-family:var(--mono);font-size:.78rem;color:var(--ink-50);letter-spacing:.1em}
.tool-card__icon{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;background:var(--accent);color:#fff;flex:none}
.tool-card__icon svg{width:26px;height:26px}
.tool-card h3{margin:1.6rem 0 .5rem;transition:transform .5s var(--ease)}
.tool-card__desc{color:var(--ink-70);max-width:42ch;transition:color .5s ease}
.tool-card__tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1.4rem}
.tool-card__cta{display:inline-flex;align-items:center;gap:.5em;margin-top:1.8rem;font-weight:600;font-size:.95rem}
.tool-card__cta svg{width:1.1em;height:1.1em;transition:transform .4s var(--ease)}
.tool-card:hover .tool-card__cta svg{transform:translate(4px,-4px)}
.tool-card__arrow{position:absolute;top:clamp(24px,3vw,38px);right:clamp(24px,3vw,38px);opacity:0;transform:translate(-6px,6px);transition:.5s var(--ease)}
.tool-card:hover .tool-card__arrow{opacity:0}

/* coming soon variant */
.tool-card--soon{border-style:dashed;background:transparent}
.tool-card--soon:hover{transform:translateY(-6px)}
.tool-card__badge{position:absolute;top:0;right:0;background:var(--ink);color:var(--paper);font-family:var(--mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;padding:.5em .9em;border-bottom-left-radius:14px}

/* ============================== FEATURE / WHY ============================ */
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(28px,5vw,80px);align-items:end}
@media(max-width:860px){.split{grid-template-columns:1fr;align-items:start;gap:1.5rem}}

.principle{
  border-top:1px solid var(--ink);padding-top:1.4rem;
}
.principle__num{font-family:var(--mono);font-size:.8rem;color:var(--ink-50);letter-spacing:.1em}
.principle h4{margin:.9rem 0 .55rem}
.principle p{color:var(--ink-70);font-size:.98rem}
.principle__icon{width:40px;height:40px;margin-bottom:1rem;color:var(--ink)}

/* ================================ STATS ================================== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
@media(max-width:760px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{background:var(--card);padding:clamp(24px,3vw,40px)}
.stat__num{font-family:var(--display);font-weight:600;font-size:clamp(2.4rem,2rem + 2.4vw,4rem);line-height:1;letter-spacing:-.03em}
.stat__num small{font-size:.5em;color:var(--lime-deep)}
.stat__label{font-family:var(--mono);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-50);margin-top:.8rem}

/* =============================== MANIFESTO ============================== */
.manifesto{background:var(--ink);color:var(--paper)}
.manifesto .eyebrow{color:rgba(242,239,230,.55)}
.manifesto .eyebrow::before{background:rgba(242,239,230,.3)}
.manifesto h2{font-size:clamp(1.9rem,1.2rem + 3.4vw,4rem);max-width:18ch}
.manifesto h2 em{font-style:normal;color:var(--lime)}
.manifesto p{color:rgba(242,239,230,.7)}

/* ================================== FAQ ================================= */
.faq{border-top:1px solid var(--line)}
.faq__item{border-bottom:1px solid var(--line)}
.faq__q{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
  text-align:left;padding:1.5rem 0;font-family:var(--display);font-weight:600;
  font-size:clamp(1.1rem,1rem + .7vw,1.55rem);letter-spacing:-.01em;
}
.faq__icon{flex:none;width:34px;height:34px;border-radius:50%;border:1.5px solid var(--line-2);position:relative;transition:background .3s ease,border-color .3s ease}
.faq__icon::before,.faq__icon::after{content:"";position:absolute;top:50%;left:50%;width:13px;height:2px;background:var(--ink);transform:translate(-50%,-50%);transition:transform .35s var(--ease)}
.faq__icon::after{transform:translate(-50%,-50%) rotate(90deg)}
.faq__item.is-open .faq__icon{background:var(--lime);border-color:var(--lime)}
.faq__item.is-open .faq__icon::after{transform:translate(-50%,-50%) rotate(0)}
.faq__a{overflow:hidden;height:0;transition:height .4s var(--ease)}
.faq__a-inner{padding-bottom:1.6rem;color:var(--ink-70);max-width:70ch}

/* ================================ CTA BAND ============================== */
.cta-band{position:relative;background:var(--lime);border-radius:var(--r-xl);padding:clamp(40px,6vw,90px);overflow:hidden;text-align:center}
.cta-band h2{max-width:16ch;margin-inline:auto}
.cta-band p{margin:1.2rem auto 2rem;color:var(--ink-2)}
.cta-band .btn{--bg:var(--ink);--fg:var(--lime)}
.cta-band .btn::after{background:var(--paper)}
.cta-band .btn:hover{color:var(--ink)}

/* ================================ FOOTER =============================== */
.site-footer{background:var(--ink);color:var(--paper);padding-block:clamp(56px,7vw,96px) 2rem}
.site-footer a{color:rgba(242,239,230,.65);transition:color .25s ease}
.site-footer a:hover{color:var(--lime)}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:clamp(28px,4vw,56px)}
@media(max-width:860px){.footer-top{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-top{grid-template-columns:1fr}}
.footer-brand .brand{color:var(--paper);font-size:1.5rem;margin-bottom:1rem}
.footer-brand p{color:rgba(242,239,230,.6);max-width:34ch;font-size:.96rem}
.footer-col h5{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(242,239,230,.4);margin-bottom:1.2rem;font-weight:500}
.footer-col li{margin-bottom:.7rem}
.footer-bottom{display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;margin-top:clamp(40px,6vw,72px);padding-top:1.6rem;border-top:1px solid rgba(242,239,230,.13);font-size:.85rem;color:rgba(242,239,230,.5)}
.footer-bottom .socials{display:flex;gap:.5rem}
.footer-bottom .socials a{width:38px;height:38px;border:1px solid rgba(242,239,230,.18);border-radius:50%;display:grid;place-items:center}
.footer-bottom .socials a:hover{background:var(--lime);border-color:var(--lime);color:var(--ink)}
.footer-bottom .socials svg{width:17px;height:17px}

/* big footer wordmark */
.footer-word{font-family:var(--display);font-weight:700;font-size:clamp(3.5rem,18vw,16rem);line-height:.8;letter-spacing:-.04em;color:rgba(242,239,230,.06);margin-top:clamp(30px,5vw,60px);user-select:none;text-align:center;overflow:hidden}

/* =========================== PAGE HERO (inner) ========================== */
.page-hero{padding-top:calc(var(--header-h) + clamp(48px,7vw,100px));padding-bottom:clamp(30px,4vw,56px)}
.page-hero h1{max-width:18ch;margin:.3em 0 .35em}
.breadcrumb{font-family:var(--mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-50);display:flex;gap:.5em;align-items:center}
.breadcrumb a:hover{color:var(--ink)}
.breadcrumb span{color:var(--ink-30)}

/* prose for content/legal pages */
.prose h2{margin:2.2rem 0 1rem}
.prose h3{margin:1.8rem 0 .8rem}
.prose p,.prose li{color:var(--ink-70);margin-bottom:1rem;max-width:68ch}
.prose ul{margin:0 0 1.4rem 1.1rem;list-style:disc}
.prose li{margin-bottom:.5rem}
.prose a{color:var(--ink);font-weight:600;text-decoration:underline;text-decoration-color:var(--lime);text-underline-offset:3px;text-decoration-thickness:2px}

/* tool detail spec list */
.spec{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
@media(max-width:680px){.spec{grid-template-columns:1fr}}
.spec div{background:var(--card);padding:1.5rem}
.spec dt{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-50);margin-bottom:.5rem}
.spec dd{font-weight:600;font-size:1.05rem}

.feature-row{display:flex;gap:1.1rem;align-items:flex-start}
.feature-row__icon{flex:none;width:46px;height:46px;border-radius:12px;background:var(--paper-2);display:grid;place-items:center;color:var(--ink)}
.feature-row__icon svg{width:22px;height:22px}
.feature-row h4{margin-bottom:.4rem}
.feature-row p{color:var(--ink-70);font-size:.96rem}

/* contact form */
.form{display:grid;gap:1.2rem}
.field label{display:block;font-family:var(--mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-50);margin-bottom:.5rem}
.field input,.field textarea,.field select{
  width:100%;padding:.95em 1.1em;background:var(--card);border:1.5px solid var(--line-2);
  border-radius:var(--r-sm);transition:border-color .25s ease,box-shadow .25s ease;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 4px rgba(203,242,62,.4)}
.field textarea{min-height:150px;resize:vertical}

/* 404 */
.error-hero{min-height:80vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.error-hero h1{font-size:clamp(6rem,30vw,22rem);line-height:.8}

/* =========================== SCROLL REVEAL =========================== */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal].is-in{opacity:1;transform:none}
[data-reveal-stagger]>*{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
[data-reveal-stagger].is-in>*{opacity:1;transform:none}

/* hero load animation */
.hero h1 .line>span,.hero [data-hero]{opacity:0;transform:translateY(30px)}
.hero.is-ready h1 .line>span,.hero.is-ready [data-hero]{opacity:1;transform:none;transition:opacity .9s var(--ease),transform .9s var(--ease)}
.hero.is-ready h1 .line:nth-child(1)>span{transition-delay:.05s}
.hero.is-ready h1 .line:nth-child(2)>span{transition-delay:.13s}
.hero.is-ready h1 .line:nth-child(3)>span{transition-delay:.21s}
.hero.is-ready [data-hero="1"]{transition-delay:.34s}
.hero.is-ready [data-hero="2"]{transition-delay:.44s}
.hero.is-ready [data-hero="3"]{transition-delay:.54s}

/* custom cursor (desktop, pointer:fine only) */
.cursor{position:fixed;top:0;left:0;width:9px;height:9px;border-radius:50%;background:var(--ink);z-index:10000;pointer-events:none;transform:translate(-50%,-50%);mix-blend-mode:difference;display:none}
.cursor-ring{position:fixed;top:0;left:0;width:38px;height:38px;border:1.5px solid var(--ink);border-radius:50%;z-index:10000;pointer-events:none;transform:translate(-50%,-50%);transition:width .25s ease,height .25s ease,background .25s ease,opacity .25s ease;mix-blend-mode:difference;display:none}
.cursor-ring.is-hover{width:56px;height:56px;background:rgba(255,255,255,.1)}
@media(pointer:fine){.cursor,.cursor-ring{display:block}}

/* utilities */
.center{text-align:center}
.mx-auto{margin-inline:auto}
.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}.mt-3{margin-top:3rem}
.maxw-sm{max-width:640px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.accent-violet{--accent:var(--violet)}
.accent-teal{--accent:var(--teal)}
.accent-coral{--accent:var(--coral)}
.accent-sun{--accent:var(--sun)}

/* ===================== reduced motion: turn it all off ==================== */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  [data-reveal],[data-reveal-stagger]>*,.hero h1 .line>span,.hero [data-hero]{opacity:1!important;transform:none!important}
  .cursor,.cursor-ring{display:none!important}
  .marquee__track{animation:none}
}
