/*
Theme Name: Routine Genius
Theme URI: https://routine-genius.com/
Author: Jesse Meister
Author URI: https://routine-genius.com/
Description: Dark-mode theme for Routine Genius — private AI tools for daily progress. Three pages: Home, Work (products), Studio. Pages auto-created on activation.
Version: 2.3.0
Requires at least: 6.0
Requires PHP: 7.4
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: routine-genius
Tags: dark-mode, one-column, custom-colors, custom-menu, threaded-comments, translation-ready
*/

/* =========================================================
   Routine Genius — theme stylesheet
   Toned, restrained palette. Accent used sparingly.
   ========================================================= */

:root{
  --bg:#0a0a0a;
  --bg-2:#101010;
  --fg:#ebe5d8;
  --fg-dim:#8a8678;
  --muted:#5a5853;
  --line:#1c1c1b;
  --line-2:#262624;
  --accent:#c9b896;
  --accent-soft:#3a3528;
  --serif:'Instrument Serif', ui-serif, Georgia, serif;
  --sans:'Inter', ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--fg);
  font-family:var(--sans);
  font-weight:400;
  font-size:16px;
  line-height:1.5;
  letter-spacing:-0.01em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
::selection{background:var(--accent);color:#0a0a0a}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
button,input,textarea,select{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
input,textarea,select{cursor:text}

.wrap{max-width:1440px;margin:0 auto;padding:0 32px}
@media(max-width:720px){.wrap{padding:0 20px}}

/* nav */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 32px;
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  background:rgba(10,10,10,.6);
  border-bottom:1px solid transparent;
  transition:border-color .3s ease, background .3s ease;
}
.nav.scrolled{border-bottom-color:var(--line)}
.nav__logo{display:flex;align-items:center;gap:10px;font-weight:600;letter-spacing:-.02em;font-size:16px}
.nav__logo .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);opacity:.85}
.nav__cta{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 18px;border:1px solid var(--line-2);border-radius:999px;
  font-size:13px;letter-spacing:.01em;
  transition:background .2s,border-color .2s,color .2s;
}
.nav__cta:hover{background:var(--fg);color:#0a0a0a;border-color:var(--fg)}
.nav__cta .arrow{transition:transform .25s}
.nav__cta:hover .arrow{transform:translate(2px,-2px)}
@media(max-width:820px){.nav{padding:18px 20px}}

/* segmented page selector */
.nav__segments{
  display:inline-flex;align-items:center;
  background:rgba(255,255,255,.025);
  border:1px solid var(--line);
  border-radius:999px;
  padding:4px;gap:2px;
}
.seg{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 18px;border-radius:999px;
  font-size:13px;color:var(--fg-dim);letter-spacing:-.005em;
  transition:background .25s ease, color .25s ease;
  position:relative;
}
.seg::before{
  content:"";width:8px;height:8px;border-radius:50%;
  border:1px solid var(--line-2);background:transparent;
  transition:background .25s ease, border-color .25s ease;
  flex-shrink:0;
}
.seg:hover{color:var(--fg)}
.seg:hover::before{border-color:var(--fg-dim)}
.seg.is-active{background:var(--fg);color:#0a0a0a}
.seg.is-active::before{background:#0a0a0a;border-color:#0a0a0a}
@media(max-width:540px){
  /* Mobile: stack the nav so segments stay accessible */
  .nav{
    flex-wrap:wrap;
    padding:14px 16px 10px;
    row-gap:8px;
  }
  .nav__logo{order:1}
  .nav__cta{order:2;padding:8px 14px;font-size:12px}
  .nav__segments{
    display:inline-flex;
    order:3;
    width:100%;
    justify-content:center;
  }
  .seg{padding:6px 14px;font-size:12px}
  .seg::before{width:6px;height:6px}
}

/* hero */
.hero{
  min-height:100vh;
  display:flex;flex-direction:column;justify-content:center;
  padding:140px 32px 80px;
  position:relative;overflow:hidden;
}
.hero--short{min-height:auto;padding:180px 32px 80px}
.hero__inner{max-width:1440px;margin:0 auto;width:100%}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--fg-dim);margin-bottom:48px;
}
.eyebrow .line{width:36px;height:1px;background:var(--fg-dim)}
.hero__h1{
  font-size:clamp(48px, 9vw, 156px);
  line-height:.92;font-weight:600;letter-spacing:-.045em;
  max-width:18ch;
}
.hero__h1 em{font-family:var(--serif);font-weight:400;font-style:italic;letter-spacing:-.02em;color:var(--fg-dim)}
.hero__h1 .accent{color:var(--accent)}
.hero__sub{
  margin-top:48px;display:flex;justify-content:space-between;align-items:flex-end;gap:60px;
  border-top:1px solid var(--line);padding-top:32px;
}
.hero__lede{max-width:42ch;color:var(--fg-dim);font-size:17px;line-height:1.55}
.hero__lede strong{color:var(--fg);font-weight:500}
.hero__meta{font-size:13px;color:var(--muted);text-align:right;font-variant-numeric:tabular-nums}
.hero__meta div{margin-bottom:4px}
@media(max-width:820px){
  .hero{padding:120px 20px 60px}
  .hero--short{padding:140px 20px 60px}
  .hero__sub{flex-direction:column;align-items:flex-start;gap:24px}
  .hero__meta{text-align:left}
}
@media(max-width:540px){
  .hero{padding-top:150px}
  .hero--short{padding-top:170px}
}
.hero__bg{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(900px 500px at 80% 10%, rgba(201,184,150,.04), transparent 60%),
    radial-gradient(700px 600px at 0% 80%, rgba(255,255,255,.015), transparent 60%);
  z-index:0;
}
.hero > *{position:relative;z-index:1}

/* marquee */
.marquee{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  overflow:hidden;white-space:nowrap;padding:24px 0;
  font-size:clamp(28px,4vw,56px);font-weight:500;letter-spacing:-.03em;
}
.marquee__track{display:inline-flex;gap:48px;animation:scroll 42s linear infinite;padding-left:48px}
.marquee__track span{color:var(--fg-dim)}
.marquee__track .sep{color:var(--accent);font-family:var(--serif);font-style:italic}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* sections */
section{padding:140px 0;position:relative}
@media(max-width:820px){section{padding:90px 0}}
.section__head{
  display:grid;grid-template-columns:1fr 2fr;gap:80px;align-items:flex-end;
  margin-bottom:80px;
}
.section__label{
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-dim);
  display:flex;align-items:center;gap:12px;
}
.section__label::before{content:"";width:6px;height:6px;background:var(--accent);border-radius:50%;opacity:.7}
.section__title{font-size:clamp(36px,5.5vw,84px);line-height:1;font-weight:500;letter-spacing:-.035em}
.section__title em{font-family:var(--serif);font-weight:400;font-style:italic;color:var(--fg-dim)}
@media(max-width:820px){.section__head{grid-template-columns:1fr;gap:24px;margin-bottom:48px}}

/* services */
.services{border-top:1px solid var(--line)}
.services__list{border-top:1px solid var(--line)}
.svc{
  display:grid;grid-template-columns:80px 1fr 2fr 80px;
  gap:32px;align-items:center;padding:36px 0;
  border-bottom:1px solid var(--line);
  cursor:pointer;position:relative;transition:padding .3s ease;
}
.svc::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg, transparent 0%, rgba(201,184,150,.04) 50%, transparent 100%);
  opacity:0;transition:opacity .35s;
}
.svc:hover{padding-left:24px}
.svc:hover::before{opacity:1}
.svc__num{font-size:13px;color:var(--muted);font-variant-numeric:tabular-nums}
.svc__name{font-size:clamp(28px,3.4vw,48px);font-weight:500;letter-spacing:-.025em}
.svc__name em{font-family:var(--serif);font-weight:400;font-style:italic;color:var(--fg-dim)}
.svc__desc{color:var(--fg-dim);font-size:15px;line-height:1.55;max-width:52ch}
.svc__icon{justify-self:end;color:var(--fg-dim);transition:transform .35s, color .35s}
.svc:hover .svc__icon{transform:translate(8px,-8px);color:var(--fg)}
@media(max-width:820px){
  .svc{grid-template-columns:40px 1fr 32px;gap:16px;padding:28px 0}
  .svc__desc{grid-column:1/-1;margin-top:8px}
}

/* work / case studies */
.work{background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.work__grid{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
.case{
  position:relative;overflow:hidden;border-radius:14px;aspect-ratio:4/3;
  cursor:pointer;background:#111;border:1px solid var(--line-2);isolation:isolate;
}
.case--lg{grid-column:span 7}
.case--md{grid-column:span 5}
.case--full{grid-column:span 12;aspect-ratio:21/9}
.case--half{grid-column:span 6}
.case--third{grid-column:span 4;aspect-ratio:1/1}
@media(max-width:820px){
  .work__grid{gap:16px}
  .case--lg,.case--md,.case--half,.case--full,.case--third{grid-column:span 12;aspect-ratio:4/3}
}
.case__art{position:absolute;inset:0;transition:transform .9s cubic-bezier(.2,.6,.2,1)}
.case:hover .case__art{transform:scale(1.04)}
.case__overlay{position:absolute;inset:0;background:linear-gradient(180deg, transparent 30%, rgba(0,0,0,.65) 100%)}
.case__meta{
  position:absolute;left:24px;right:24px;bottom:22px;
  display:flex;justify-content:space-between;align-items:flex-end;gap:24px;z-index:2;
}
.case__title{font-size:clamp(20px,2.4vw,30px);font-weight:600;letter-spacing:-.02em;line-height:1.1}
.case__tag{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-dim);margin-bottom:8px}
.case__year{font-size:13px;color:var(--fg-dim);font-variant-numeric:tabular-nums;white-space:nowrap}
.case__hover{
  position:absolute;top:20px;right:20px;
  width:42px;height:42px;border-radius:50%;
  background:var(--fg);color:#0a0a0a;
  display:flex;align-items:center;justify-content:center;
  transform:scale(.6) rotate(-30deg);opacity:0;
  transition:transform .35s, opacity .35s;
  z-index:2;font-size:14px;
}
.case:hover .case__hover{transform:scale(1) rotate(0);opacity:1}

.art-1{background:radial-gradient(circle at 30% 30%, #2a2a25, #0a0a0a 70%)}
.art-1::before{content:"";position:absolute;inset:0;background:
  radial-gradient(2px 2px at 22% 28%,#c9b896,transparent),
  radial-gradient(1.5px 1.5px at 60% 50%,#c9b89680,transparent),
  radial-gradient(1px 1px at 78% 30%,#fff8,transparent),
  radial-gradient(1px 1px at 35% 70%,#fff5,transparent);
  opacity:.7;
}
.art-2{background:linear-gradient(135deg, #18191c, #0a0a0a)}
.art-2::before{content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(45deg, transparent 0 24px, rgba(255,255,255,.03) 24px 25px),
  radial-gradient(circle at 70% 30%, rgba(201,184,150,.10), transparent 50%);
}
.art-3{background:linear-gradient(180deg,#1a1410,#0a0a0a)}
.art-3::before{content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 50% 60%, rgba(201,184,150,.16), transparent 55%),
  repeating-radial-gradient(circle at 50% 60%, transparent 0 30px, rgba(255,255,255,.025) 30px 31px);
}
.art-4{background:#0d0d0d}
.art-4::before{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg, transparent 49.5%, rgba(201,184,150,.4) 49.5% 50.5%, transparent 50.5%),
  radial-gradient(circle at 50% 50%, rgba(201,184,150,.06), transparent 60%);
}
.art-5{background:linear-gradient(160deg, #1f1d1c, #0a0a0a)}
.art-5::before{content:"";position:absolute;inset:0;
  background:conic-gradient(from 180deg at 50% 50%, rgba(201,184,150,.0), rgba(201,184,150,.14), rgba(255,255,255,.0), rgba(201,184,150,.0));
  filter:blur(40px);
}
.art-6{background:#0c0c0c}
.art-6::before{content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 50% 50%, rgba(255,255,255,.06), transparent 50%),
  repeating-linear-gradient(0deg, transparent 0 18px, rgba(255,255,255,.02) 18px 19px);
}
.art-7{background:linear-gradient(200deg, #1a1c1a, #0a0a0a)}
.art-7::before{content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at 70% 80%, rgba(201,184,150,.12), transparent 60%);
}
.art-8{background:#0b0b0b}
.art-8::before{content:"";position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(201,184,150,.08) 0 50%, transparent 50%);
}

/* approach */
.approach__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.step{background:var(--bg);padding:48px 32px;min-height:340px;display:flex;flex-direction:column;justify-content:space-between;transition:background .3s}
.step > div:last-child{min-height:9.5em} /* keep title baselines aligned across the four steps */
.step:hover{background:var(--bg-2)}
.step__num{font-family:var(--serif);font-style:italic;font-size:64px;color:var(--accent);line-height:1;opacity:.85}
.step__title{font-size:24px;font-weight:600;letter-spacing:-.02em;margin-bottom:14px;margin-top:auto;padding-top:48px}
.step__desc{font-size:14px;color:var(--fg-dim);line-height:1.6}
@media(max-width:980px){.approach__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.approach__grid{grid-template-columns:1fr}}

/* stats */
.stats{border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:48px}
.stat__num{font-size:clamp(48px,6vw,92px);font-weight:500;letter-spacing:-.04em;line-height:1}
.stat__num em{font-family:var(--serif);font-weight:400;font-style:italic;color:var(--accent)}
.stat__label{margin-top:14px;color:var(--fg-dim);font-size:14px;line-height:1.5;max-width:24ch}
@media(max-width:820px){.stats__grid{grid-template-columns:repeat(2,1fr);gap:40px}}

/* clients */
.clients__grid{display:grid;grid-template-columns:repeat(6,1fr);border:1px solid var(--line)}
.client{
  aspect-ratio:1.8/1;display:flex;align-items:center;justify-content:center;
  border-right:1px solid var(--line);
  color:var(--fg-dim);font-size:18px;font-weight:600;letter-spacing:-.01em;
  transition:background .3s, color .3s;position:relative;overflow:hidden;
}
.client:hover{background:var(--bg-2);color:var(--fg)}
.client:nth-child(6n){border-right:none}
@media(max-width:820px){
  .clients__grid{grid-template-columns:repeat(3,1fr)}
  .client{border-bottom:1px solid var(--line)}
  .client:nth-child(6n){border-right:1px solid var(--line)}
  .client:nth-child(3n){border-right:none}
  .client:nth-last-child(-n+3){border-bottom:none}
}
@media(max-width:480px){
  .clients__grid{grid-template-columns:repeat(2,1fr)}
  .client{border-bottom:1px solid var(--line)}
  .client:nth-child(3n){border-right:1px solid var(--line)}
  .client:nth-child(2n){border-right:none}
  .client:nth-last-child(-n+2){border-bottom:none}
}

/* contact form */
.contact{padding:140px 0 80px;border-top:1px solid var(--line)}
.contact__inner{max-width:1440px;margin:0 auto;padding:0 32px}
.contact h2{font-size:clamp(48px,9vw,160px);line-height:.92;font-weight:500;letter-spacing:-.045em}
.contact h2 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--fg-dim)}
.contact h2 .accent{color:var(--accent)}
.contact__form-wrap{margin-top:80px;border-top:1px solid var(--line);padding-top:60px}
.contact__after{
  margin-top:80px;border-top:1px solid var(--line);padding-top:48px;
  display:grid;grid-template-columns:1fr 1fr;gap:48px;
}
.contact__after h4{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.contact__after p,.contact__after a{font-size:15px;color:var(--fg-dim);line-height:1.7}
.contact__after a:hover{color:var(--fg)}
@media(max-width:820px){.contact__after{grid-template-columns:1fr;gap:32px}}

.form{display:grid;grid-template-columns:1fr 1fr;gap:0}
.field{position:relative;border-bottom:1px solid var(--line);padding:18px 0;grid-column:span 1}
.field--full{grid-column:1/-1}
.field label{display:block;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.field input,.field textarea,.field select{
  width:100%;background:transparent;border:0;outline:none;
  font-size:18px;font-weight:400;color:var(--fg);padding:6px 0;letter-spacing:-.01em;font-family:var(--sans);
}
.field input::placeholder,.field textarea::placeholder{color:var(--muted)}
.field textarea{resize:vertical;min-height:90px;line-height:1.5}
.field select{appearance:none;background-image:linear-gradient(45deg, transparent 50%, var(--fg-dim) 50%), linear-gradient(135deg, var(--fg-dim) 50%, transparent 50%);background-position:calc(100% - 18px) 16px, calc(100% - 12px) 16px;background-size:6px 6px;background-repeat:no-repeat;padding-right:32px}
.field select option{background:var(--bg);color:var(--fg)}
.field--actions{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;border-bottom:0;padding-top:32px}
.field--actions .note{font-size:13px;color:var(--muted);max-width:42ch;line-height:1.55}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 28px;border:1px solid var(--fg);border-radius:999px;
  font-size:15px;color:var(--fg);background:transparent;
  transition:background .25s,color .25s,border-color .25s;cursor:pointer;
}
.btn:hover{background:var(--fg);color:#0a0a0a}
.btn .arrow{transition:transform .25s}
.btn:hover .arrow{transform:translate(3px,-3px)}
@media(max-width:540px){.form{grid-template-columns:1fr}}

/* end CTA */
.endcta{padding:140px 0;border-top:1px solid var(--line);text-align:center}
.endcta h2{font-size:clamp(40px,7vw,108px);font-weight:500;letter-spacing:-.04em;line-height:1;max-width:18ch;margin:0 auto}
.endcta h2 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--fg-dim)}
.endcta .btn{margin-top:48px}

/* footer */
.footer{padding:32px;border-top:1px solid var(--line);font-size:13px;color:var(--muted)}
.footer__inner{max-width:1440px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.footer__legal{display:flex;gap:24px}
.footer__legal a:hover{color:var(--fg)}

/* reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s ease, transform .9s ease}
.reveal.in{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}
.reveal[data-delay="4"]{transition-delay:.32s}

/* studio */
.studio__lead{display:grid;grid-template-columns:1fr 2fr;gap:80px;border-top:1px solid var(--line);padding-top:60px}
.studio__lead .col__label{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.studio__lead .col__body{font-size:clamp(20px,2.2vw,28px);line-height:1.4;letter-spacing:-.018em;color:var(--fg);max-width:54ch}
.studio__lead .col__body em{font-family:var(--serif);font-style:italic;color:var(--fg-dim)}
@media(max-width:820px){.studio__lead{grid-template-columns:1fr;gap:24px}}

.principles{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.principle{background:var(--bg);padding:48px 32px;min-height:280px}
.principle__num{font-size:11px;letter-spacing:.18em;color:var(--muted);text-transform:uppercase;margin-bottom:24px}
.principle__title{font-size:22px;font-weight:600;letter-spacing:-.02em;margin-bottom:12px}
.principle__title em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--fg-dim)}
.principle__desc{font-size:14px;color:var(--fg-dim);line-height:1.6}
@media(max-width:820px){.principles{grid-template-columns:1fr}}

.team{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.member{
  border:1px solid var(--line);border-radius:12px;
  padding:24px;background:var(--bg-2);
  transition:border-color .3s, transform .3s;
}
.member:hover{border-color:var(--line-2);transform:translateY(-2px)}
.member__avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg, #2a2820, #0a0a0a);margin-bottom:32px;border:1px solid var(--line-2)}
.member__name{font-size:17px;font-weight:600;letter-spacing:-.01em}
.member__role{font-size:13px;color:var(--fg-dim);margin-top:4px}
@media(max-width:980px){.team{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.team{grid-template-columns:1fr}}

.team--solo{display:flex;justify-content:center}
.team--solo .member--feature{
  max-width:640px;width:100%;padding:48px;
  display:grid;grid-template-columns:auto 1fr;gap:40px;align-items:flex-start;
}
.team--solo .member__avatar{width:96px;height:96px;margin:0;background:linear-gradient(135deg,#3a3528,#0a0a0a)}
.team--solo .member__name{font-size:28px;letter-spacing:-.02em}
.team--solo .member__role{font-size:14px;color:var(--fg-dim);margin-top:6px;letter-spacing:.005em}
.team--solo .member__bio{margin-top:24px;padding-top:24px;border-top:1px solid var(--line);font-size:15px;color:var(--fg-dim);line-height:1.65}
.team--solo .member__contact{margin-top:20px;font-size:14px}
.team--solo .member__contact a{color:var(--fg);border-bottom:1px solid var(--line-2);padding-bottom:2px;transition:border-color .25s}
.team--solo .member__contact a:hover{border-color:var(--accent)}
@media(max-width:680px){
  .team--solo .member--feature{grid-template-columns:1fr;gap:24px;padding:32px}
  .team--solo .member__avatar{width:72px;height:72px}
}

/* =========================================================
   Long-form prose pages (privacy, terms, support, contact)
   ========================================================= */
.prose-wrap{padding:60px 0 140px;border-top:1px solid var(--line)}
.prose{
  max-width:760px;margin:0 auto;padding:0 32px;
  font-size:16px;line-height:1.7;color:var(--fg-dim);
}
.prose .prose__meta{
  font-size:13px;color:var(--muted);
  margin-bottom:40px;padding-bottom:24px;
  border-bottom:1px solid var(--line);
  letter-spacing:.04em;
}
.prose h2{
  font-size:24px;color:var(--fg);
  margin-top:56px;margin-bottom:16px;
  letter-spacing:-.02em;font-weight:600;
}
.prose h2:first-of-type{margin-top:0}
.prose h3{
  font-size:17px;color:var(--fg);
  margin-top:32px;margin-bottom:10px;
  font-weight:600;
}
.prose p{margin-bottom:18px}
.prose ul,.prose ol{margin:14px 0 22px 22px}
.prose ul li,.prose ol li{margin-bottom:8px}
.prose a{
  color:var(--fg);
  border-bottom:1px solid var(--line-2);
  transition:border-color .25s;
}
.prose a:hover{border-bottom-color:var(--accent)}
.prose strong{color:var(--fg);font-weight:500}
.prose code{
  background:var(--bg-2);
  padding:2px 6px;border-radius:4px;
  font-size:14px;color:var(--fg);
  font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;
}
.prose .callout{
  background:var(--bg-2);
  border:1px solid var(--line);
  border-left:2px solid var(--accent);
  padding:20px 24px;margin:28px 0;border-radius:6px;
  color:var(--fg);
}
.prose .callout strong{color:var(--accent)}
.prose .legal{
  font-size:14px;color:var(--muted);
  text-transform:uppercase;letter-spacing:.04em;
}
@media(max-width:540px){
  .prose-wrap{padding:40px 0 80px}
  .prose{padding:0 20px}
  .prose h2{font-size:22px;margin-top:44px}
}

/* Cipher product page status badge */
.status-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;border-radius:999px;
  background:rgba(201,184,150,.08);border:1px solid var(--line-2);
  font-size:13px;color:var(--accent);letter-spacing:.02em;
}
.status-pill .pulse{
  width:8px;height:8px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 12px rgba(201,184,150,.5);
  animation:status-pulse 2s ease-in-out infinite;
}
@keyframes status-pulse{0%,100%{opacity:1}50%{opacity:.5}}
