:root{
  /* fonts */
  --font-sans:-apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --font-mono:'IBM Plex Mono', ui-monospace, 'SF Mono', Menlo, monospace;
  --font-display:'Fraunces', Georgia, 'Times New Roman', serif;

  /* brand palette */
  --cream:#f2eee3;
  --charcoal:#1c1b19;
  --orange:#e8973a;
  --teal:#6ca6a0;
  --purple:#9e90d8;

  /* light sections */
  --paper:#f2eee3;
  --ink:#1f1d1a;
  --ink-soft:#6b665c;
  --line:rgba(31,29,26,.14);

  --accent:#e0852b;          /* orange — accent text */
  --accent-press:#c66f1d;
  --accent-deep:#b5631a;     /* deep orange — accent text on cream */
  --teal-deep:#357a72;       /* deep teal  — secondary accent text */
  --accent-blue:#2f6ae0;     /* blue — primary button */
  --accent-blue-press:#2554c4;
  --on-accent:#fff7ec;

  /* hero — only approved bg/text combinations (from the brand colour grid) */
  --h1-bg:#3d1fe0; --h1-fg:#f3f0ff;   /* indigo  / white       */
  --h2-bg:#1f7a4f; --h2-fg:#f2efe6;   /* green   / white       */
  --h3-bg:#5ba8e5; --h3-fg:#a8e89c;   /* blue    / mint-green  */
  --h4-bg:#f4a8c0; --h4-fg:#1f1d1a;   /* pink    / charcoal    */
  --h5-bg:#ffe01f; --h5-fg:#f4501f;   /* yellow  / orange-red  */
  --hero-bg:#3d1fe0;
  --hero-fg:#f3f0ff;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ font-family:var(--font-sans); -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{ background:var(--paper); color:var(--ink); overflow-x:hidden; }
::selection{ background:var(--accent); color:var(--charcoal); }

/* fixed brand mark, top-left — difference blend keeps it visible on every section */
.logo{ position:fixed; top:18px; left:22px; z-index:50; display:inline-flex; align-items:center;
  font-family:var(--font-mono); font-weight:500;
  font-size:1.05rem; letter-spacing:.02em; color:#fff; mix-blend-mode:difference; text-decoration:none; user-select:none; }
.logo .logo-mark{ height:1.35em; width:auto; display:block; margin-left:8px; filter:brightness(0) invert(1); }
.logo .eyes{ display:inline-block; }
/* footer mark + contact, centered at the bottom of the page */
.site-foot{ display:flex; align-items:center; justify-content:center; gap:18px; padding:48px 0 56px; }
.site-foot .foot-mark{ height:30px; width:auto; display:block; }
.site-foot .foot-contact{ font-family:var(--font-mono); font-size:.82rem; font-weight:500; letter-spacing:.02em;
  color:var(--ink-soft); text-decoration:none; transition:color .25s ease; }
.site-foot .foot-contact:hover{ color:var(--ink); }
.logo .eyes.happy{ animation:eyesHappy .5s cubic-bezier(.34,1.6,.5,1); }
@keyframes eyesHappy{ 0%{ transform:translateY(2px) scale(.9); } 55%{ transform:translateY(-2px) scale(1.18); } 100%{ transform:none; } }

/* ---- HERO ---- */
.hero{ position:relative; height:100vh; overflow:hidden; display:flex; justify-content:center; align-items:center; background:var(--hero-bg); }
.hero main{ position:relative; width:100%; max-width:1000px; aspect-ratio:16/9; backface-visibility:hidden; }
.slide{ opacity:0; width:100%; position:absolute; inset:0; display:flex; flex-direction:column; justify-content:center; align-items:center; }
.slide .row{ display:flex; justify-content:center; flex-wrap:nowrap; }
/* one uniform weight, no mixed thicknesses */
.slide p{ font-family:var(--font-mono); font-weight:300; font-size:clamp(.9rem,3.4vw,2.2rem); flex-shrink:0;
  line-height:1; margin:1ch; white-space:nowrap; letter-spacing:-0.01em; color:var(--hero-fg); }
/* the offer line is longer prose — bigger, and allowed to wrap onto two lines */
.slide:nth-child(3) p{ white-space:normal; max-width:22ch; text-align:center; line-height:1.14; font-size:clamp(1.5rem,4vw,2.6rem); }
/* the centre message lines wrap to two lines (e.g. "We make sure it's / worth shipping.") */
.slide:nth-child(1) p.center{ white-space:normal; max-width:22ch; text-align:center; line-height:1.14; }
/* difference blend keeps the cue legible on every approved background colour */
.scroll-cue{ position:absolute; left:50%; bottom:28px; transform:translateX(-50%); color:#fff; mix-blend-mode:difference;
  font-family:var(--font-mono); font-weight:300; font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; opacity:.85; animation:bob 2s ease-in-out infinite; }
@keyframes bob{ 0%,100%{ transform:translate(-50%,0); } 50%{ transform:translate(-50%,7px); } }
.hero .fallback{ display:none; text-align:center; padding:0 24px; position:relative; }
.hero.static main{ display:none; }
.hero.static .fallback{ display:block; }
.hero.static .fallback h1{ font-family:var(--font-display); font-size:clamp(2.4rem,7vw,5rem); font-weight:600; color:var(--hero-fg); line-height:1.0; letter-spacing:-0.03em; }
.hero.static .fallback h1 span{ color:var(--accent-deep); display:block; font-style:italic; }

/* ---- readable content ---- */
.wrap{ max-width:760px; margin:0 auto; padding:0 clamp(22px,5vw,40px); }
section.block{ padding:clamp(90px,14vh,160px) 0; }
.pitch{ text-align:left; }
.pitch p{ font-size:clamp(0.95rem,1.5vw,1.1rem); line-height:1.55; font-weight:300; color:var(--ink); }
.pitch p + p{ margin-top:1.3em; }
/* Apple-style lead-ins: same size and face, just heavier weight */
.pitch strong{ font-weight:600; font-style:normal; color:var(--ink); }
.who-link{ font-family:var(--font-mono); font-weight:500; font-size:.82em; color:var(--accent-deep); text-decoration:none; transition:opacity .2s ease; }
.who-link:hover{ opacity:.65; }
/* accent words: same mono face as the logo; colour follows the hero background */
.pitch b{ font-family:var(--font-mono); font-style:normal; font-weight:500; color:var(--hero-now, var(--h2-bg)); transition:color .4s linear; }

.eyebrow{ text-align:center; font-family:var(--font-mono); font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--accent-deep); font-weight:500; margin-bottom:34px; }

/* ---- FREE-TRIAL CTA button (inline in the pitch flow) ---- */
.btn{ display:inline-flex; align-items:center; gap:11px; margin-top:34px; background:var(--accent-blue); color:#fff; text-decoration:none;
  border:0; cursor:pointer; appearance:none;
  font-family:var(--font-mono); font-size:.98rem; font-weight:500; padding:17px 30px; border-radius:999px; transition:transform .45s cubic-bezier(.34,1.5,.5,1), background .3s ease; }
.btn:hover{ transform:translateY(-3px) scale(1.03); background:var(--accent-blue-press); }
.btn .arr{ transition:transform .45s cubic-bezier(.34,1.5,.5,1); } .btn:hover .arr{ transform:translateX(6px); }
.pitch .btn-note{ margin-top:14px; font-size:12px; line-height:1.4; font-weight:300; text-align:center; color:var(--ink-soft); opacity:.7; }

/* ---- GLASS CTA (adapted from Petr Knoll's glass button) — centered, full width ---- */
@property --angle-1{ syntax:"<angle>"; inherits:false; initial-value:-75deg; }
@property --angle-2{ syntax:"<angle>"; inherits:false; initial-value:-45deg; }

.glass-cta{ --anim--hover-time:400ms; --anim--hover-ease:cubic-bezier(.25,1,.5,1); --btn-radius:9px;
  width:100%; margin-top:34px; font-size:clamp(1rem,1.4vw,1.18rem); }

.glass-cta .button-wrap{ position:relative; z-index:2; width:100%; border-radius:var(--btn-radius); background:transparent;
  pointer-events:none; transition:all var(--anim--hover-time) var(--anim--hover-ease); }

.glass-cta .button-shadow{ --shadow-cuttoff-fix:2em; position:absolute;
  width:calc(100% + var(--shadow-cuttoff-fix)); height:calc(100% + var(--shadow-cuttoff-fix));
  top:calc(0% - var(--shadow-cuttoff-fix) / 2); left:calc(0% - var(--shadow-cuttoff-fix) / 2);
  filter:blur(clamp(2px,.125em,12px)); overflow:visible; pointer-events:none; }
.glass-cta .button-shadow::after{ content:""; position:absolute; z-index:0; inset:0; border-radius:var(--btn-radius);
  background:linear-gradient(180deg, rgba(0,0,0,.2), rgba(0,0,0,.1));
  width:calc(100% - var(--shadow-cuttoff-fix) - .25em); height:calc(100% - var(--shadow-cuttoff-fix) - .25em);
  top:calc(var(--shadow-cuttoff-fix) - .5em); left:calc(var(--shadow-cuttoff-fix) - .875em);
  padding:.125em; box-sizing:border-box;
  mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); mask-composite:exclude;
  transition:all var(--anim--hover-time) var(--anim--hover-ease); overflow:visible; opacity:1; }

.glass-cta button{ --border-width:clamp(1px,.0625em,4px); all:unset; cursor:pointer; position:relative;
  display:block; width:100%; box-sizing:border-box; -webkit-tap-highlight-color:rgba(0,0,0,0); pointer-events:auto; z-index:3;
  background:linear-gradient(180deg, color-mix(in srgb, var(--hero-now, var(--h1-bg)) 24%, transparent) 0%, transparent 80%),
    linear-gradient(-75deg, rgba(255,255,255,.05), rgba(255,255,255,.2), rgba(255,255,255,.05));
  border-radius:var(--btn-radius);
  box-shadow:inset 0 .125em .125em rgba(0,0,0,.05), inset 0 -.125em .125em rgba(255,255,255,.5),
    0 .25em .125em -.125em rgba(0,0,0,.2), 0 0 .1em .25em inset rgba(255,255,255,.2), 0 0 0 0 rgba(255,255,255,1);
  backdrop-filter:blur(clamp(1px,.125em,4px)); -webkit-backdrop-filter:blur(clamp(1px,.125em,4px));
  transition:all var(--anim--hover-time) var(--anim--hover-ease); }

.glass-cta button:hover{ transform:scale(.985); backdrop-filter:blur(.01em); -webkit-backdrop-filter:blur(.01em);
  box-shadow:inset 0 .125em .125em rgba(0,0,0,.05), inset 0 -.125em .125em rgba(255,255,255,.5),
    0 .15em .05em -.1em rgba(0,0,0,.25), 0 0 .05em .1em inset rgba(255,255,255,.5), 0 0 0 0 rgba(255,255,255,1); }

.glass-cta button span{ position:relative; display:block; text-align:center; user-select:none;
  font-family:var(--font-sans); letter-spacing:-0.01em; font-weight:500; font-size:1em; color:var(--hero-now, var(--h1-bg));
  transition:all var(--anim--hover-time) var(--anim--hover-ease);
  padding-inline:1.5em; padding-block:1.25em; }
.glass-cta .arr{ display:inline-block; font-style:normal; margin-left:.15em; transition:transform var(--anim--hover-time) var(--anim--hover-ease); }
.glass-cta button:hover .arr{ transform:translateX(.25em); }

.glass-cta button span::after{ content:""; display:block; position:absolute; z-index:3;
  width:calc(100% - var(--border-width)); height:calc(100% - var(--border-width));
  top:calc(0% + var(--border-width) / 2); left:calc(0% + var(--border-width) / 2); box-sizing:border-box;
  border-radius:var(--btn-radius); overflow:clip;
  background:linear-gradient(var(--angle-2), rgba(255,255,255,0) 0%, rgba(255,255,255,.5) 40% 50%, rgba(255,255,255,0) 55%);
  mix-blend-mode:screen; pointer-events:none; background-size:200% 200%; background-position:0% 50%; background-repeat:no-repeat;
  transition:background-position calc(var(--anim--hover-time) * 1.25) var(--anim--hover-ease), --angle-2 calc(var(--anim--hover-time) * 1.25) var(--anim--hover-ease); }
.glass-cta button:hover span::after{ background-position:25% 50%; }
.glass-cta button:active span::after{ background-position:50% 15%; --angle-2:-15deg; }

.glass-cta button::after{ content:""; position:absolute; z-index:1; inset:0; border-radius:var(--btn-radius);
  width:calc(100% + var(--border-width)); height:calc(100% + var(--border-width));
  top:calc(0% - var(--border-width) / 2); left:calc(0% - var(--border-width) / 2); padding:var(--border-width); box-sizing:border-box;
  background:conic-gradient(from var(--angle-1) at 50% 50%,
      var(--hero-now, var(--h1-bg)),
      color-mix(in srgb, var(--hero-now, var(--h1-bg)) 0%, transparent) 5% 40%,
      var(--hero-now, var(--h1-bg)) 50%,
      color-mix(in srgb, var(--hero-now, var(--h1-bg)) 0%, transparent) 60% 95%,
      var(--hero-now, var(--h1-bg))),
    linear-gradient(180deg, rgba(255,255,255,.5), rgba(255,255,255,.5));
  mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); mask-composite:exclude;
  transition:all var(--anim--hover-time) var(--anim--hover-ease), --angle-1 500ms ease;
  box-shadow:inset 0 0 0 calc(var(--border-width) / 2) rgba(255,255,255,.5); }
.glass-cta button:hover::after{ --angle-1:-125deg; }
.glass-cta button:active::after{ --angle-1:-75deg; }

.glass-cta .button-wrap:has(button:hover) .button-shadow{ filter:blur(clamp(2px,.0625em,6px)); transition:filter var(--anim--hover-time) var(--anim--hover-ease); }
.glass-cta .button-wrap:has(button:hover) .button-shadow::after{ top:calc(var(--shadow-cuttoff-fix) - .875em); opacity:1; }
.glass-cta .button-wrap:has(button:active){ transform:rotate3d(1,0,0,25deg); }
.glass-cta .button-wrap:has(button:active) button{
  box-shadow:inset 0 .125em .125em rgba(0,0,0,.05), inset 0 -.125em .125em rgba(255,255,255,.5),
    0 .125em .125em -.125em rgba(0,0,0,.2), 0 0 .1em .25em inset rgba(255,255,255,.2),
    0 .225em .05em 0 rgba(0,0,0,.05), 0 .25em 0 0 rgba(255,255,255,.75), inset 0 .25em .05em 0 rgba(0,0,0,.15); }
.glass-cta .button-wrap:has(button:active) .button-shadow{ filter:blur(clamp(2px,.125em,12px)); }
.glass-cta .button-wrap:has(button:active) .button-shadow::after{ top:calc(var(--shadow-cuttoff-fix) - .5em); opacity:.75; }

@media (hover:none) and (pointer:coarse){
  .glass-cta button span::after, .glass-cta button:active span::after{ --angle-2:-45deg; }
  .glass-cta button::after, .glass-cta button:hover::after, .glass-cta button:active::after{ --angle-1:-75deg; }
}

/* ---- REQUEST-AVAILABILITY MODAL ---- */
.modal{ position:fixed; inset:0; z-index:100; display:flex; align-items:center; justify-content:center; padding:24px; }
.modal[hidden]{ display:none; }
.modal-backdrop{ position:absolute; inset:0; background:rgba(28,27,25,.55); backdrop-filter:blur(3px); -webkit-backdrop-filter:blur(3px);
  opacity:0; animation:fadeIn .25s ease forwards; }
.modal-card{ position:relative; width:min(440px,100%); background:var(--paper); color:var(--ink);
  border:1px solid var(--line); border-radius:20px; padding:38px 34px 34px; box-shadow:0 30px 80px rgba(28,27,25,.28);
  opacity:0; transform:translateY(14px) scale(.98); animation:cardIn .4s cubic-bezier(.34,1.4,.5,1) .04s forwards; }
@keyframes fadeIn{ to{ opacity:1; } }
@keyframes cardIn{ to{ opacity:1; transform:none; } }

.modal-x{ position:absolute; top:14px; right:16px; border:0; background:none; cursor:pointer; line-height:1;
  font-size:1.5rem; color:var(--ink-soft); transition:color .2s ease; }
.modal-x:hover{ color:var(--ink); }
/* same type vocabulary as the pitch: sans-600 lead-in + light sans body */
.modal-lead{ font-size:1.15rem; line-height:1.4; font-weight:300; color:var(--ink); margin-bottom:8px; }
.modal-lead strong{ font-weight:600; }
.modal-sub{ font-size:.98rem; line-height:1.55; font-weight:300; color:var(--ink-soft); margin-bottom:26px; }

.req-form{ display:flex; flex-direction:column; gap:12px; }
.req-form input, .req-form select{ font-family:var(--font-sans); font-size:1rem; font-weight:300; color:var(--ink);
  background:#fff; border:1px solid var(--line); border-radius:11px; padding:14px 15px; width:100%; transition:border-color .2s ease, box-shadow .2s ease; appearance:none; }
.req-form select{ background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b665c' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 15px center; padding-right:38px; }
.req-form input:focus, .req-form select:focus{ outline:none; border-color:var(--accent-blue); box-shadow:0 0 0 3px rgba(47,106,224,.16); }
.req-form input::placeholder{ color:#b3ad9f; }
.req-form select:invalid{ color:#b3ad9f; }

.drop{ display:flex; flex-direction:column; align-items:center; gap:5px; text-align:center; cursor:pointer; margin-top:2px;
  border:1.5px dashed var(--line); border-radius:11px; padding:20px 16px; background:rgba(255,255,255,.4);
  transition:border-color .2s ease, background .2s ease; }
.drop:hover, .drop:focus-visible{ outline:none; border-color:var(--accent-deep); background:rgba(255,255,255,.7); }
.drop.dragover{ border-color:var(--accent-blue); border-style:solid; background:rgba(47,106,224,.07); }
.drop.has-file{ border-style:solid; border-color:var(--accent-deep); }
.drop-text{ font-size:.95rem; font-weight:300; color:var(--ink); }
.drop-link{ color:var(--accent-deep); text-decoration:underline; text-underline-offset:2px; }
.drop-hint{ font-size:.82rem; font-weight:300; color:var(--ink-soft); }
.glass-cta--modal{ margin-top:6px; font-size:1rem; }
.req-error{ font-size:.85rem; font-weight:300; color:#c0392b; text-align:center; margin-top:4px; }

.req-done{ text-align:center; padding:14px 0 6px; }
body.modal-open{ overflow:hidden; }

/* reveals */
.rv{ opacity:0; transform:translateY(20px); transition:opacity .7s cubic-bezier(.2,.8,.2,1), transform .8s cubic-bezier(.34,1.4,.5,1); }
.rv.in{ opacity:1; transform:none; }

/* mobile: keep the decorative wall fitting, but let the message lines stay big by
   wrapping instead of shrinking to a single line */
@media (max-width:600px){
  .slide p{ font-size:clamp(.9rem,3.8vw,1.35rem); margin:.6ch; }
  .slide:nth-child(1) p.center{ max-width:15ch; line-height:1.16; }
  /* the key words get more room and size on mobile */
  .slide:nth-child(2) p{ font-size:clamp(1.1rem,4.6vw,1.5rem); margin:.8ch; }
  .slide:nth-child(3) p{ font-size:clamp(1.4rem,6vw,1.9rem); max-width:16ch; line-height:1.18; }
  .pitch p{ font-size:clamp(1.05rem,3.8vw,1.25rem); line-height:1.55; }
}
@media (prefers-reduced-motion:reduce){ .rv{ opacity:1; transform:none; transition:none; } .scroll-cue{ animation:none; } }
