/* ============================================================
   Streamless — shared stylesheet for all pages
   Edit design tokens, fonts, nav, footer, and buttons here ONCE
   and every page updates. Page-specific differences (content
   width, a few doc tweaks) are scoped via <body> classes:
     index.html   → <body>            (marketing home)
     privacy/terms→ <body class="legal">
     refund       → <body class="legal refund">
     support      → <body class="support">
   ============================================================ */

/* --- design tokens (change colours + fonts here) --- */
:root{
  --cream:#F7F4EE;
  --cream-deep:#EFE9DD;
  --cream-card:#FBF9F4;
  --ink:#1A1612;
  --ink-soft:#6B6157;
  --orange:#FF6A00;
  --orange-deep:#E25D00;
  --line:rgba(26,22,18,0.13);
  --serif:'Bree Serif',Georgia,serif;
  --mono:'JetBrains Mono',ui-monospace,'SF Mono',Menlo,monospace;
}

/* --- base --- */
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--cream);
  color:var(--ink);
  font-family:var(--mono);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body.legal,body.support{line-height:1.7;}
/* grain overlay */
body::before{
  content:"";
  position:fixed;inset:0;
  pointer-events:none;z-index:9999;
  opacity:0.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
a{color:inherit;text-decoration:none;}

.wrap{max-width:1120px;margin:0 auto;padding:0 32px;}
body.legal .wrap{max-width:760px;}
body.support .wrap{max-width:680px;}

/* --- labels + headings --- */
.eyebrow{
  font-family:var(--mono);font-size:12px;font-weight:700;
  letter-spacing:0.18em;text-transform:uppercase;color:var(--orange);
  display:inline-block;
}
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.04;letter-spacing:-0.015em;}

/* --- buttons --- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-weight:700;font-size:14px;
  letter-spacing:0.02em;
  background:var(--orange);color:#fff;
  padding:15px 26px;border-radius:10px;
  border:1px solid var(--orange);
  transition:transform .18s ease,background .18s ease,box-shadow .18s ease;
  cursor:pointer;
}
.btn:hover{background:var(--orange-deep);transform:translateY(-2px);box-shadow:0 10px 24px -10px rgba(226,93,0,0.6);}
.btn .arrow{transition:transform .18s ease;}
.btn:hover .arrow{transform:translateX(3px);}
.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line);}
.btn.ghost:hover{background:var(--ink);color:var(--cream);border-color:var(--ink);box-shadow:none;}
.pricetag{font-family:var(--mono);font-size:13px;color:var(--ink-soft);letter-spacing:0.01em;}

/* --- nav --- */
nav{
  position:sticky;top:0;z-index:100;
  background:rgba(247,244,238,0.82);
  backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid var(--line);
}
.nav-inner{max-width:1120px;margin:0 auto;padding:0 32px;display:flex;align-items:center;justify-content:space-between;height:64px;}
.logo{font-family:var(--serif);font-weight:700;font-size:25px;letter-spacing:-0.01em;display:flex;align-items:center;gap:13px;text-decoration:none;}
.logo img{width:44px;height:44px;display:block;}
.nav-back{font-family:var(--mono);font-size:13px;color:var(--ink-soft);text-decoration:none;}
.nav-back:hover{color:var(--orange);}
.nav-links{display:flex;align-items:center;gap:30px;font-family:var(--mono);font-size:13px;}
.nav-links a.txt{color:var(--ink-soft);transition:color .15s;}
.nav-links a.txt:hover{color:var(--ink);}
.nav-links .btn{padding:10px 18px;}

/* ============================================================
   HOME PAGE (index.html) components
   ============================================================ */

/* hero */
.hero{padding:88px 0 56px;position:relative;}
.hero h1{font-size:clamp(44px,7.2vw,86px);margin:22px 0 0;max-width:13ch;}
.hero h1 em{font-style:italic;color:var(--orange);font-weight:400;}
.hero .sub{font-family:var(--mono);font-size:clamp(15px,1.7vw,18px);color:var(--ink-soft);max-width:46ch;margin:26px 0 0;line-height:1.65;}
.hero .cta-row{display:flex;align-items:center;gap:22px;margin-top:36px;flex-wrap:wrap;}

/* mac window */
.window{
  background:var(--cream-card);
  border:1px solid var(--line);
  border-radius:10px;
  overflow:hidden;
  box-shadow:0 40px 80px -40px rgba(26,22,18,0.32),0 8px 20px -12px rgba(26,22,18,0.18);
}
.window .bar{
  height:38px;display:flex;align-items:center;gap:8px;padding:0 15px;
  background:var(--cream-deep);border-bottom:1px solid var(--line);
}
.window .bar i{width:11px;height:11px;border-radius:50%;display:block;}
.window .bar .r{background:#E8857A;}.window .bar .y{background:#E6C25C;}.window .bar .g{background:#9CC07F;}
.window .bar span{font-family:var(--mono);font-size:11px;color:var(--ink-soft);margin-left:12px;letter-spacing:0.04em;}
.placeholder{
  position:relative;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:
    repeating-linear-gradient(45deg,transparent,transparent 11px,rgba(26,22,18,0.025) 11px,rgba(26,22,18,0.025) 12px),
    var(--cream-card);
  color:var(--ink-soft);text-align:center;gap:8px;padding:40px 24px;
  font-family:var(--mono);
}
.placeholder .ph-tag{font-size:11px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--orange);}
.placeholder .ph-desc{font-size:13px;color:var(--ink-soft);max-width:34ch;}
.hero-shot .placeholder{height:420px;}
/* Real app screenshots stand on their own — they carry their own
   macOS window chrome + drop shadow (captured transparent), so no
   faux .window frame is drawn around them. Sized to natural aspect. */
.shot{display:block;width:100%;height:auto;}

/* feature images are zoomable */
.frow .shot{cursor:zoom-in;transition:transform .25s ease;border-radius:8px;}
.frow .shot:hover{transform:translateY(-3px);}

/* marquee */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--cream-deep);overflow:hidden;}
.marquee-track{display:flex;gap:0;white-space:nowrap;animation:slide 34s linear infinite;width:max-content;}
.marquee-track span{font-family:var(--mono);font-size:13px;font-weight:500;letter-spacing:0.04em;color:var(--ink);padding:15px 0;}
.marquee-track span::after{content:"·";color:var(--orange);margin:0 26px;}
@keyframes slide{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* sections */
section.block{padding:96px 0;}
.block.alt{background:var(--cream-deep);}
.head{max-width:38ch;margin-bottom:54px;}
.head h2{font-size:clamp(30px,4.4vw,50px);margin-top:16px;}
.head .lede{font-family:var(--mono);color:var(--ink-soft);margin-top:18px;font-size:15px;line-height:1.65;max-width:48ch;}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.step{border-top:2px solid var(--ink);padding-top:22px;}
.step .num{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--orange);letter-spacing:0.1em;}
.step h3{font-size:23px;margin:14px 0 12px;}
.step p{font-family:var(--mono);font-size:14px;color:var(--ink-soft);line-height:1.65;}

/* value grid */
.values{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:8px;overflow:hidden;}
.value{background:var(--cream);padding:34px 32px;}
.value h3{font-family:var(--mono);font-weight:700;font-size:16px;letter-spacing:-0.01em;display:flex;align-items:center;gap:11px;}
.value h3::before{content:"";width:8px;height:8px;background:var(--orange);border-radius:50%;flex:none;}
.value p{font-family:var(--mono);font-size:14px;color:var(--ink-soft);margin-top:13px;line-height:1.65;}
.block.alt .value{background:var(--cream-deep);}

/* feature rows */
.frow{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;margin-bottom:84px;}
.frow:last-child{margin-bottom:0;}
.frow.flip .ftext{order:2;}
.ftext h3{font-size:clamp(26px,3.4vw,38px);}
.ftext p{font-family:var(--mono);font-size:15px;color:var(--ink-soft);margin-top:18px;line-height:1.7;max-width:42ch;}
.frow .placeholder{height:300px;}

/* devices spec */
.spec{border:1px solid var(--line);border-radius:8px;overflow:hidden;background:var(--cream-card);}
.spec-row{display:grid;grid-template-columns:200px 1fr;border-bottom:1px solid var(--line);}
.spec-row:last-child{border-bottom:none;}
.spec-row .k{font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;padding:26px 28px;background:var(--cream-deep);color:var(--ink);}
.spec-row .v{font-family:var(--mono);font-size:15px;padding:26px 28px;color:var(--ink);display:flex;flex-wrap:wrap;gap:8px 0;align-items:center;}
.spec-row.no .v{color:var(--ink-soft);}
.chip{display:inline-flex;align-items:center;padding:5px 13px;border:1px solid var(--line);border-radius:40px;font-size:13px;margin-right:9px;}
.spec-row .v .chip{background:var(--cream);}
.spec-row.yes .chip{border-color:rgba(255,106,0,0.4);}
.spec-row.yes .chip::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--orange);margin-right:8px;}
.spec-row .chip sup{color:var(--orange);font-weight:700;}
.spec-note{font-family:var(--mono);font-size:13px;line-height:1.7;color:var(--ink-soft);margin-top:22px;}
.spec-note strong{color:var(--ink);font-weight:700;}
.spec-note .ast{color:var(--orange);font-weight:700;margin-right:4px;}

/* pricing */
.price-card{text-align:center;max-width:540px;margin:0 auto;border:1px solid var(--line);border-radius:12px;padding:56px 40px;background:var(--cream-card);}
.price-big{font-family:var(--serif);font-size:84px;font-weight:500;line-height:1;}
.price-big span{color:var(--orange);}
.price-card .once{font-family:var(--mono);font-size:13px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-soft);margin-top:8px;}
.price-card .terms{font-family:var(--mono);font-size:14px;color:var(--ink-soft);margin:24px auto 30px;max-width:34ch;line-height:1.7;}

/* maker */
.maker{max-width:60ch;}
.maker h2{font-size:clamp(26px,3.6vw,40px);}
.maker p{font-family:var(--mono);font-size:15px;color:var(--ink-soft);margin-top:20px;line-height:1.75;}

/* final cta */
.final{text-align:center;padding:110px 0;background:var(--ink);color:var(--cream);}
.final h2{font-size:clamp(34px,5.2vw,62px);color:var(--cream);}
.final h2 em{color:var(--orange);font-style:italic;font-weight:400;}
.final .cta-row{justify-content:center;margin-top:38px;display:flex;align-items:center;gap:22px;flex-wrap:wrap;}
.final .pricetag{color:rgba(247,244,238,0.6);}
.final .btn.ghost{color:var(--cream);border-color:rgba(247,244,238,0.3);}
.final .btn.ghost:hover{background:var(--cream);color:var(--ink);border-color:var(--cream);}

/* lightbox (click-to-enlarge feature shots) */
.lightbox{
  position:fixed;inset:0;z-index:1000;
  display:flex;align-items:center;justify-content:center;
  padding:48px;
  background:rgba(26,22,18,0.82);
  backdrop-filter:saturate(120%) blur(6px);
  opacity:0;visibility:hidden;
  transition:opacity .28s ease,visibility .28s ease;
  cursor:zoom-out;
}
.lightbox.open{opacity:1;visibility:visible;}
.lightbox img{
  max-width:100%;max-height:100%;
  width:auto;height:auto;
  border-radius:10px;
  box-shadow:0 40px 90px -30px rgba(0,0,0,0.7);
  transform:scale(.96);transition:transform .28s cubic-bezier(.2,.7,.2,1);
}
.lightbox.open img{transform:scale(1);}
.lightbox .close{
  position:absolute;top:22px;right:26px;
  width:40px;height:40px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(247,244,238,0.1);border:1px solid rgba(247,244,238,0.25);
  color:var(--cream);font-family:var(--mono);font-size:20px;line-height:1;
  cursor:pointer;transition:background .15s ease;
}
.lightbox .close:hover{background:rgba(247,244,238,0.22);}

/* reveal animation */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}
.d1{transition-delay:.08s;}.d2{transition-delay:.16s;}.d3{transition-delay:.24s;}

/* ============================================================
   LEGAL / DOC PAGES (privacy, terms, refund, support)
   ============================================================ */
.doc{padding:72px 0 96px;}
body.support .doc{padding:72px 0 110px;}
.doc h1{font-family:var(--serif);font-weight:500;font-size:clamp(36px,6vw,56px);line-height:1.05;letter-spacing:-0.015em;margin:16px 0 10px;}
body.support .doc h1{margin:16px 0 14px;}
.updated{font-family:var(--mono);font-size:13px;color:var(--ink-soft);margin-bottom:48px;}
.doc h2{font-family:var(--serif);font-weight:500;font-size:25px;margin:46px 0 14px;letter-spacing:-0.01em;}
.doc h2 .n{font-family:var(--mono);font-size:14px;color:var(--orange);font-weight:700;margin-right:12px;vertical-align:middle;}
.doc p{font-family:var(--mono);font-size:15px;color:var(--ink);margin-bottom:16px;}
.doc p.muted{color:var(--ink-soft);}
.doc .lede{font-family:var(--mono);font-size:15px;color:var(--ink-soft);margin-bottom:14px;max-width:52ch;}
.doc ul{list-style:none;margin:0 0 18px;padding:0;}
.doc li{font-family:var(--mono);font-size:15px;color:var(--ink);padding-left:22px;position:relative;margin-bottom:11px;}
.doc li::before{content:"";position:absolute;left:2px;top:11px;width:7px;height:7px;background:var(--orange);border-radius:50%;}
.doc a.inline{color:var(--orange-deep);text-decoration:underline;text-underline-offset:3px;}

.callout{background:var(--cream-deep);border:1px solid var(--line);border-left:3px solid var(--orange);border-radius:4px;padding:22px 24px;margin:24px 0;}
.callout p{margin:0;font-size:14px;color:var(--ink-soft);}
body.refund .callout{padding:24px 26px;}
body.refund .callout p{font-size:15px;color:var(--ink);}
body.refund .callout strong{color:var(--ink);}
.note{font-family:var(--mono);font-size:12px;color:var(--orange-deep);background:rgba(255,106,0,0.07);border:1px dashed rgba(255,106,0,0.4);border-radius:4px;padding:12px 16px;margin:16px 0;}

/* support — contact methods */
.methods{margin:40px 0 0;display:flex;flex-direction:column;gap:12px;}
.method{
  display:flex;align-items:center;gap:16px;text-decoration:none;
  background:var(--cream-card);border:1px solid var(--line);border-radius:8px;
  padding:18px 20px;transition:border-color .15s,transform .15s,box-shadow .15s;
}
.method:hover{border-color:var(--orange);transform:translateY(-2px);box-shadow:0 12px 26px -16px rgba(26,22,18,0.3);}
.method .glyph{
  flex:none;width:42px;height:42px;border-radius:8px;background:var(--cream-deep);
  display:flex;align-items:center;justify-content:center;color:var(--orange);
}
.method:hover .glyph{background:var(--orange);color:var(--cream);}
.method .glyph svg{width:20px;height:20px;}
.method .txt{display:flex;flex-direction:column;}
.method .label{font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-soft);}
.method .val{font-family:var(--mono);font-size:15px;color:var(--ink);margin-top:2px;}
.method .chev{margin-left:auto;color:var(--ink-soft);font-family:var(--mono);}
.method:hover .chev{color:var(--orange);}

/* --- footer --- */
footer{padding:48px 0;border-top:1px solid var(--line);}
body.legal footer,body.support footer{padding:44px 0;}
body.support footer{margin-top:80px;}
.foot-inner{max-width:1120px;margin:0 auto;padding:0 32px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px;font-family:var(--mono);font-size:13px;color:var(--ink-soft);}
body.legal .foot-inner,body.support .foot-inner{gap:16px;}
.foot-links{display:flex;gap:24px;flex-wrap:wrap;}
.foot-links a{text-decoration:none;}
.foot-links a:hover{color:var(--orange);}

/* --- responsive --- */
@media(max-width:860px){
  .nav-links .txt{display:none;}
  .steps{grid-template-columns:1fr;}
  .values{grid-template-columns:1fr;}
  .frow{grid-template-columns:1fr;gap:28px;margin-bottom:56px;}
  .frow.flip .ftext{order:0;}
  .spec-row{grid-template-columns:1fr;}
  .spec-row .k{padding-bottom:8px;}
  .spec-row .v{padding-top:12px;}
  .hero{padding:56px 0 40px;}
  section.block{padding:64px 0;}
}
