/* ============================================================
   SayWork — shared design foundation
   Tokens, base, and reusable marketing components.
   Used by every page. "calm but rugged."
   ============================================================ */

:root{
  /* surfaces & ink (light — primary) */
  --paper:#F6F5F2; --surface:#FFFFFF; --surface-2:#FBFBF9;
  --ink:#1A1A1C; --ink-2:#65656B; --ink-3:#9A9AA0;
  --hair:rgba(0,0,0,.08); --hair-2:rgba(0,0,0,.14);

  /* accent — coral (the one signature color) */
  --accent:#F24E3A;        /* bright — big controls / glyphs only */
  --accent-deep:#B92E22;   /* darker — text, links, buttons */
  --accent-wash:#F7E4E0;   /* faint coral tint for chips/badges */

  /* dark surfaces (for contrast bands) */
  --d-paper:#121214; --d-surface:#1E1E22; --d-surface-2:#26262B;
  --d-ink:#F2F2F0; --d-ink-2:#A6A6AC; --d-ink-3:#76767C;
  --d-hair:rgba(255,255,255,.10); --d-hair-2:rgba(255,255,255,.16);
  --d-accent:#FF5A47; --d-accent-2:#FF7A6A;

  /* type-chip colors */
  --walk-bg:#F3E9DD; --walk-fg:#8A5620;
  --meet-bg:#E7EEF7; --meet-fg:#2C5887;
  --todo-bg:#E7F1E9; --todo-fg:#37704A;
  --mem-bg:#EFEAF7;  --mem-fg:#5F4C94;
  --insp-bg:#DDF0EC; --insp-fg:#1F7A6B;

  /* pipeline */
  --green:#2F9E54; --blue:#2F6FE0; --amber:#B5790C; --red:#D23B33; --gray:#8E8E93;

  /* radii */
  --r-card:18px; --r-field:14px; --r-pill:999px; --r-screen:46px;

  /* type */
  --font:-apple-system,"SF Pro Display","SF Pro Text",system-ui,"Segoe UI",Roboto,sans-serif;

  /* layout */
  --maxw:1180px;
}

*{box-sizing:border-box;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font);color:var(--ink);
  background:#E9E9EC;
  background-image:radial-gradient(120% 80% at 50% -8%, #F4F3F0 0%, #ECEBEC 52%, #E4E4E7 100%);
  background-attachment:fixed;
  line-height:1.55;font-size:17px;
}
a{color:var(--accent-deep);text-decoration:none}
img,svg{display:block}
::selection{background:rgba(242,78,58,.18)}

/* ---------- layout helpers ---------- */
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 28px}
.wrap-narrow{max-width:880px}
.section{padding:96px 0}
.section-sm{padding:64px 0}
.eyebrow{
  font-size:13px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;
  color:var(--accent-deep);margin:0 0 16px;display:inline-flex;align-items:center;gap:8px;
}
.eyebrow::before{content:"";width:18px;height:2px;border-radius:2px;background:var(--accent)}
h1,h2,h3{margin:0;letter-spacing:-.5px;font-weight:700;text-wrap:balance}
h1{font-size:clamp(40px,6vw,68px);line-height:1.04;letter-spacing:-1.5px}
h2{font-size:clamp(30px,3.6vw,46px);line-height:1.08;letter-spacing:-1px}
h3{font-size:22px;line-height:1.2}
.lead{font-size:clamp(18px,1.6vw,21px);line-height:1.55;color:var(--ink-2);text-wrap:pretty}
.muted{color:var(--ink-2)}
.faint{color:var(--ink-3)}
.center{text-align:center}
.section-head{max-width:680px;margin:0 auto 56px;text-align:center}
.section-head.left{margin-left:0;text-align:left}
.section-head p{margin:18px 0 0}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;font-family:inherit;font-size:16px;font-weight:600;
  padding:14px 22px;border-radius:var(--r-pill);border:1px solid transparent;cursor:pointer;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease;white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--accent-deep);color:#fff;box-shadow:0 8px 22px -10px rgba(185,46,34,.7)}
.btn-primary:hover{background:#a52a1f;box-shadow:0 12px 28px -10px rgba(185,46,34,.8)}
.btn-ghost{background:var(--surface);color:var(--ink);border-color:var(--hair)}
.btn-ghost:hover{border-color:var(--hair-2);box-shadow:0 4px 14px -8px rgba(0,0,0,.25)}
.btn-text{color:var(--accent-deep);padding:0;font-weight:600;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.btn-text svg{width:16px;height:16px;transition:transform .15s}
.btn-text:hover svg{transform:translateX(3px)}

/* App Store badge (built, not imported) */
.appstore{
  display:inline-flex;align-items:center;gap:12px;background:var(--ink);color:#fff;
  padding:11px 20px 11px 18px;border-radius:14px;border:1px solid var(--ink);
  transition:transform .15s ease, box-shadow .2s ease;
  box-shadow:0 10px 26px -14px rgba(0,0,0,.5);
}
.appstore:hover{transform:translateY(-2px);box-shadow:0 16px 34px -16px rgba(0,0,0,.55)}
.appstore svg{width:26px;height:26px;flex:0 0 26px;color:#fff}
.appstore .as-txt{display:flex;flex-direction:column;line-height:1.12;text-align:left}
.appstore .as-txt small{font-size:11px;font-weight:500;opacity:.82;letter-spacing:.2px}
.appstore .as-txt b{font-size:19px;font-weight:600;letter-spacing:-.3px}
.appstore.light{background:var(--surface);color:var(--ink);border-color:var(--hair)}
.appstore.light svg{color:var(--ink)}

/* ---------- brandmark / wordmark ---------- */
.brand{display:inline-flex;align-items:center;gap:11px}
.brand .dot{
  width:34px;height:34px;border-radius:10px;background:var(--accent);
  display:flex;align-items:center;justify-content:center;flex:0 0 34px;
  box-shadow:0 6px 16px -6px rgba(242,78,58,.6);
}
.brand .dot svg{width:19px;height:19px}
.brand b{font-size:19px;font-weight:600;letter-spacing:-.2px;color:var(--ink)}
.brand.lg .dot{width:44px;height:44px;border-radius:13px;flex-basis:44px}
.brand.lg .dot svg{width:24px;height:24px}
.brand.lg b{font-size:24px}
.brand.on-dark b{color:var(--d-ink)}

/* ---------- frosted floating nav ---------- */
.nav{position:fixed;top:18px;left:0;right:0;z-index:50;pointer-events:none;padding:0 14px}
.nav .bar{
  pointer-events:auto;display:flex;align-items:center;gap:18px;
  max-width:var(--maxw);margin:0 auto;padding:11px 12px 11px 20px;
  background:rgba(255,255,255,.72);
  backdrop-filter:blur(26px) saturate(180%);-webkit-backdrop-filter:blur(26px) saturate(180%);
  border:1px solid rgba(255,255,255,.6);border-radius:var(--r-pill);
  box-shadow:0 10px 30px -14px rgba(0,0,0,.22),0 1px 0 rgba(255,255,255,.7) inset;
}
.nav .links{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav .links a{
  color:var(--ink-2);font-size:15px;font-weight:600;padding:8px 14px;border-radius:var(--r-pill);
  transition:color .15s, background .15s;
}
.nav .links a:hover{color:var(--ink);background:rgba(0,0,0,.04)}
.nav .links a.active{color:var(--accent-deep)}
.nav .nav-cta{margin-left:6px}
@media(max-width:720px){
  .nav .links a:not(.keep){display:none}
  .nav .bar{padding-right:10px}
}

/* ---------- type chips ---------- */
.chip{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;padding:5px 11px;border-radius:var(--r-pill)}
.chip svg{width:12px;height:12px}
.chip.walk{background:var(--walk-bg);color:var(--walk-fg)}
.chip.meet{background:var(--meet-bg);color:var(--meet-fg)}
.chip.todo{background:var(--todo-bg);color:var(--todo-fg)}
.chip.mem{background:var(--mem-bg);color:var(--mem-fg)}
.chip.insp{background:var(--insp-bg);color:var(--insp-fg)}

/* pipeline dots */
.state{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600}
.state .d{width:7px;height:7px;border-radius:50%;display:inline-block}
.s-ready{color:var(--green)} .s-ready .d{background:var(--green)}
.s-work{color:var(--blue)}  .s-work .d{background:var(--blue);animation:sw-blink 1.1s infinite}
.s-review{color:var(--amber)} .s-review .d{background:var(--amber)}
.s-fail{color:var(--red)}   .s-fail .d{background:var(--red)}
.s-queued{color:var(--gray)} .s-queued .d{background:var(--gray)}
@keyframes sw-blink{0%,100%{opacity:1}50%{opacity:.25}}

/* ---------- cards ---------- */
.card{
  background:var(--surface);border:1px solid var(--hair);border-radius:var(--r-card);
  box-shadow:0 2px 3px rgba(0,0,0,.04);
}
.card-pad{padding:26px}

/* feature row */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.feature.flip .feature-media{order:2}
.feature-copy h2{font-size:clamp(28px,3vw,38px)}
.feature-copy p{margin:18px 0 0}
.feature-list{list-style:none;margin:26px 0 0;padding:0;display:flex;flex-direction:column;gap:14px}
.feature-list li{display:flex;gap:12px;align-items:flex-start;font-size:16px;color:var(--ink-2)}
.feature-list li .tick{
  width:22px;height:22px;border-radius:7px;background:var(--accent-wash);color:var(--accent-deep);
  flex:0 0 22px;display:flex;align-items:center;justify-content:center;margin-top:1px;
}
.feature-list li .tick svg{width:13px;height:13px}
@media(max-width:860px){
  .feature{grid-template-columns:1fr;gap:36px}
  .feature.flip .feature-media{order:0}
}

/* ---------- footer ---------- */
.footer{background:var(--d-paper);color:var(--d-ink-2);padding:72px 0 40px}
.footer a{color:var(--d-ink-2)}
.footer a:hover{color:var(--d-ink)}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;margin-bottom:56px}
.footer h4{font-size:13px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--d-ink-3);margin:0 0 18px}
.footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px;font-size:15px}
.footer .blurb{font-size:15px;line-height:1.6;color:var(--d-ink-2);max-width:300px;margin:18px 0 22px}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding-top:28px;border-top:1px solid var(--d-hair);font-size:13.5px;color:var(--d-ink-3);flex-wrap:wrap}
.footer-bottom .legal{display:flex;gap:22px;flex-wrap:wrap}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr 1fr}}

/* ---------- phone mockup ---------- */
.phone{
  width:var(--pw,300px);aspect-ratio:392/846;border-radius:calc(var(--pw,300px) * .138);
  background:linear-gradient(145deg,#3a3a3d,#1c1c1f 55%,#101012);
  padding:calc(var(--pw,300px) * .028);position:relative;flex:0 0 auto;
  box-shadow:0 1px 0 rgba(255,255,255,.18) inset,0 40px 70px -28px rgba(0,0,0,.5),0 18px 40px -22px rgba(0,0,0,.36);
}
.phone .screen{
  position:relative;width:100%;height:100%;border-radius:calc(var(--pw,300px) * .112);
  overflow:hidden;background:var(--paper);display:flex;flex-direction:column;
}
.phone .island{position:absolute;top:3.4%;left:50%;transform:translateX(-50%);
  width:31%;height:3.6%;background:#000;border-radius:99px;z-index:6}
.phone .p-status{height:6.4%;flex:0 0 6.4%;display:flex;align-items:flex-end;justify-content:space-between;
  padding:0 8% 1.4%;font-size:calc(var(--pw,300px) * .039);font-weight:600;color:var(--ink)}
.phone .p-status .sig{display:inline-flex;gap:5px;align-items:center}
.phone .p-status .sig svg{height:calc(var(--pw,300px) * .04);width:auto}
.phone .p-body{flex:1;overflow:hidden;position:relative;padding:0 6.5%}

/* glass tab bar inside phone */
.phone .p-tabbar{
  position:absolute;left:5%;right:5%;bottom:2.6%;height:9%;z-index:8;
  background:rgba(255,255,255,.74);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);
  border:1px solid rgba(255,255,255,.6);border-radius:99px;
  box-shadow:0 10px 26px -12px rgba(0,0,0,.24),0 1px 0 rgba(255,255,255,.7) inset;
  display:flex;align-items:center;justify-content:space-around;padding:0 6%;
}
.phone .p-tab{color:var(--ink-3);display:flex}
.phone .p-tab svg{width:calc(var(--pw,300px) * .066);height:calc(var(--pw,300px) * .066)}
.phone .p-tab.active{color:var(--accent-deep)}
.phone .p-fab{
  width:calc(var(--pw,300px) * .165);height:calc(var(--pw,300px) * .165);border-radius:50%;
  background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;margin-top:-14%;
  box-shadow:0 10px 22px -8px rgba(242,78,58,.7);
}
.phone .p-fab svg{width:46%;height:46%}

/* shared mockup interior bits (scaled by em from phone width) */
.phone .p-title{font-size:calc(var(--pw,300px) * .082);font-weight:700;letter-spacing:-.5px;margin:4% 0 1%}
.phone .p-sub{font-size:calc(var(--pw,300px) * .037);color:var(--ink-3);margin:0 0 4%}
.phone .m-card{background:var(--surface);border:1px solid var(--hair);border-radius:calc(var(--pw,300px) * .05);
  box-shadow:0 1px 2px rgba(0,0,0,.04)}

/* floating phone wrapper for hero — box-shadow (NOT filter) so the
   device subtree is never layerized & resampled, keeping text crisp */
.phone-float{box-shadow:0 1px 0 rgba(255,255,255,.18) inset,0 54px 84px -34px rgba(0,0,0,.26),0 24px 48px -26px rgba(0,0,0,.2)}

/* small reveal on scroll */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* dark band */
.band-dark{background:var(--d-paper);color:var(--d-ink)}
.band-dark h2{color:var(--d-ink)}
.band-dark .lead,.band-dark .muted{color:var(--d-ink-2)}
.band-dark .eyebrow{color:var(--d-accent-2)}
.band-dark .eyebrow::before{background:var(--d-accent)}

/* ============================================================
   Automatic dark mode — follows the OS (prefers-color-scheme).
   Light "Calm Paper" above stays the default. No manual toggle.
   Redefining the tokens here flows through every page; a few
   hardcoded surfaces get targeted overrides. AA maintained.
   ============================================================ */
@media (prefers-color-scheme: dark){
  :root{
    /* deep warm-charcoal surfaces (never pure black) */
    --paper:#1A1817; --surface:#232120; --surface-2:#1F1D1C;
    /* warm off-white ink at AA contrast */
    --ink:#F3EEE8; --ink-2:#B4AEA7; --ink-3:#948D86;
    --hair:rgba(255,255,255,.10); --hair-2:rgba(255,255,255,.18);
    /* bright coral kept for decorative fills; lighter coral
       takes over text & links through --accent-deep (AA on dark) */
    --accent:#F24E3A;
    --accent-deep:#FF8472;
    --accent-wash:rgba(242,78,58,.16);
  }

  body{
    color:var(--ink);
    background:#141212;
    background-image:radial-gradient(120% 80% at 50% -8%, #221E1D 0%, #1A1717 52%, #141212 100%);
  }
  ::selection{background:rgba(255,122,106,.26)}

  /* frosted floating nav → dark glass */
  .nav .bar{
    background:rgba(30,27,26,.72);
    border-color:rgba(255,255,255,.10);
    box-shadow:0 12px 34px -16px rgba(0,0,0,.7),0 1px 0 rgba(255,255,255,.06) inset;
  }
  .nav .links a:hover{color:var(--ink);background:rgba(255,255,255,.06)}

  /* primary button stays a bright coral that clears AA with white text */
  .btn-primary{background:#D8402D;box-shadow:0 10px 26px -10px rgba(216,64,45,.75)}
  .btn-primary:hover{background:#E84C36;box-shadow:0 14px 32px -10px rgba(232,76,54,.85)}

  /* App Store badge → light badge on dark (Apple's dark-bg guidance) */
  .appstore{background:#F3EEE8;color:#171311;border-color:#F3EEE8;box-shadow:0 12px 30px -16px rgba(0,0,0,.8)}
  .appstore svg{color:#171311}
  .appstore .as-txt small{opacity:.66}
  .appstore.light{background:var(--surface);color:var(--ink);border-color:var(--hair-2)}
  .appstore.light svg{color:var(--ink)}

  /* cards & elevation tuned for a dark canvas */
  .card{box-shadow:0 2px 4px rgba(0,0,0,.4)}

  /* privacy band reads as a deliberate, deeper panel */
  .band-dark{
    background:#100E0E;
    border-top:1px solid var(--d-hair);
    border-bottom:1px solid var(--d-hair);
  }

  /* ---- phone mockups render the app's DARK appearance in dark mode ----
     Authentic dark UI, with strong device separation from the dark page. */
  .phone, .sw-phone{
    --paper:#0F0F12;        /* screen: cooler near-black, distinct from the warm page */
    --surface:#1C1C20;      /* in-app cards, elevated above the screen */
    --surface-2:#161619;
    --ink:#F2F2F4; --ink-2:#A6A6AD; --ink-3:#78787F;
    --hair:rgba(255,255,255,.10); --hair-2:rgba(255,255,255,.18);
    --accent:#FF5A47;       /* bright coral controls pop on dark */
    --accent-deep:#FF7A6A;  /* coral text / active tab, legible on dark surfaces */
    --accent-wash:rgba(255,90,71,.16);
  }
  /* device frame: lighter rim + outer ring + deep shadow + faint glow */
  .phone{
    background:linear-gradient(145deg,#4a4a50,#1d1d20 55%,#0c0c0e);
    box-shadow:
      0 0 0 1px rgba(255,255,255,.07),
      0 1px 0 rgba(255,255,255,.22) inset,
      0 40px 80px -26px rgba(0,0,0,.78),
      0 16px 40px -20px rgba(0,0,0,.6),
      0 0 64px -12px rgba(255,120,106,.10);
  }
  .phone .screen{box-shadow:inset 0 0 0 1px rgba(255,255,255,.06)}
  .phone-float{
    box-shadow:
      0 0 0 1px rgba(255,255,255,.07),
      0 1px 0 rgba(255,255,255,.22) inset,
      0 60px 96px -34px rgba(0,0,0,.8),
      0 24px 56px -26px rgba(0,0,0,.62),
      0 0 80px -14px rgba(255,120,106,.12);
  }
  /* in-screen surfaces that were hardcoded light */
  .phone .p-tabbar{background:rgba(26,26,30,.72);border-color:rgba(255,255,255,.10);
    box-shadow:0 10px 26px -12px rgba(0,0,0,.5),0 1px 0 rgba(255,255,255,.06) inset}
  .phone .m-skel{background:#2A2A30}
}

/* ============================================================
   Responsive / touch refinements
   Phones use fixed-px mockups; cap them to the viewport so they
   never overflow on narrow Androids / small iPhones. Keep tap
   targets comfortable on touch widths.
   ============================================================ */
@media (max-width:480px){
  /* every mockup shrinks to fit the phone, never wider than its design size.
     !important is required to override the inline --pw that phone.js sets. */
  .sw-phone{--pw:min(78vw,320px) !important}
  /* a touch more breathing room at the screen edges */
  .wrap{padding-left:22px;padding-right:22px}
}

/* nav links get a 44px tap height on tablet/touch widths (they're
   hidden below 720px, where only the brand + CTA remain) */
@media (max-width:900px){
  .nav .links a{min-height:44px;display:inline-flex;align-items:center}
}

/* very small phones: show the brand mark without the wordmark so the
   "Start free trial" CTA always fits and never crowds the edge */
@media (max-width:380px){
  .nav .brand b{display:none}
  .nav .bar{padding-left:14px;padding-right:10px;gap:10px}
}
