/* ===========================================================
   LightCater — modern SaaS stylesheet (Linear / Stripe style)
   Re-theme via the variables in :root.
   =========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Inter+Tight:wght@400;500;600;700;800&family=Inter:wght@400;450;500;600&display=swap');

:root{
  /* palette — refined, restrained */
  --bg:#fafafa;
  --bg-soft:#f4f5f4;
  --card:#ffffff;
  --ink:#0c1410;
  --ink-2:#3d4a44;
  --ink-3:#6b7873;
  --line:#e7eae8;
  --line-2:#eef1ef;

  --brand:#0e7a52;       /* deep emerald */
  --brand-2:#16a06b;     /* brighter */
  --brand-ink:#0a3d2a;
  --brand-50:#eaf6f0;
  --brand-100:#d3ecdf;
  --glow:rgba(22,160,107,.18);

  --maxw:1080px;
  --r:14px;
  --r-sm:10px;
  --r-lg:22px;
  --sh-1:0 1px 2px rgba(12,20,16,.04), 0 1px 3px rgba(12,20,16,.06);
  --sh-2:0 4px 12px rgba(12,20,16,.06), 0 12px 28px rgba(12,20,16,.06);
  --sh-3:0 20px 50px rgba(12,20,16,.12);

  --display:'Inter Tight', system-ui, sans-serif;
  --body:'Inter', system-ui, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--body);color:var(--ink);background:var(--bg);line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ---------- type ---------- */
h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.05;letter-spacing:-.03em;color:var(--ink)}
h1{font-size:clamp(2.5rem,5.4vw,3.9rem);letter-spacing:-.04em}
h2{font-size:clamp(1.9rem,3.6vw,2.7rem);letter-spacing:-.035em}
h3{font-size:1.18rem;letter-spacing:-.02em}
.lead{font-size:clamp(1.05rem,1.6vw,1.22rem);color:var(--ink-3);max-width:54ch;line-height:1.6}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--body);font-weight:600;font-size:.8rem;
  letter-spacing:.02em;color:var(--brand);background:var(--brand-50);border:1px solid var(--brand-100);
  padding:6px 13px;border-radius:999px}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--brand-2);box-shadow:0 0 0 3px var(--glow)}
.grad{background:linear-gradient(120deg,var(--brand-2),var(--brand));-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--body);font-weight:600;
  font-size:.95rem;padding:11px 20px;border-radius:10px;cursor:pointer;border:1px solid transparent;
  transition:transform .14s ease,box-shadow .2s ease,background .18s ease,border-color .18s ease;white-space:nowrap}
.btn svg{width:16px;height:16px}
.btn-primary{background:var(--brand);color:#fff;box-shadow:0 1px 2px rgba(14,122,82,.4),0 4px 14px rgba(14,122,82,.22)}
.btn-primary:hover{background:var(--brand-2);transform:translateY(-1px);box-shadow:0 2px 4px rgba(14,122,82,.4),0 8px 22px rgba(14,122,82,.3)}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--ink-3);transform:translateY(-1px);box-shadow:var(--sh-1)}
.btn-lg{padding:14px 26px;font-size:1rem;border-radius:11px}
.btn-block{width:100%}

/* ---------- header ---------- */
header.site{position:sticky;top:0;z-index:60;background:rgba(250,250,250,.8);backdrop-filter:blur(14px) saturate(1.4);border-bottom:1px solid var(--line-2)}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px;gap:20px}
.brand{display:flex;align-items:center;gap:9px;font-family:var(--display);font-size:1.22rem;font-weight:700;letter-spacing:-.04em}
.brand .mark{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;
  background:linear-gradient(140deg,var(--brand-2),var(--brand));color:#fff;font-weight:800;font-size:.95rem;
  box-shadow:0 2px 6px rgba(14,122,82,.4),inset 0 1px 0 rgba(255,255,255,.25)}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{font-weight:500;font-size:.92rem;color:var(--ink-2);padding:8px 13px;border-radius:8px;transition:background .15s,color .15s}
.nav-links a:hover{background:var(--bg-soft);color:var(--ink)}
.nav-links a.active{color:var(--brand);font-weight:600}
.nav-cta{display:flex;align-items:center;gap:9px}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;font-size:1.4rem;color:var(--ink);padding:6px}
@media(max-width:820px){
  .nav-links{display:none}
  .nav-cta .btn-ghost{display:none}
  .nav-toggle{display:block}
  .nav-links.open{display:flex;position:absolute;top:64px;left:0;right:0;flex-direction:column;align-items:stretch;
    background:var(--bg);padding:14px 24px 20px;gap:4px;border-bottom:1px solid var(--line);box-shadow:var(--sh-2)}
  .nav-links.open a{padding:12px 14px}
}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;padding:74px 0 64px}
.hero::before{content:"";position:absolute;inset:0;z-index:-2;background:
  radial-gradient(680px 320px at 78% -8%,var(--glow),transparent 62%),
  radial-gradient(560px 360px at 6% 108%,rgba(22,160,107,.07),transparent 60%)}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;opacity:.5;
  background-image:linear-gradient(var(--line-2) 1px,transparent 1px),linear-gradient(90deg,var(--line-2) 1px,transparent 1px);
  background-size:44px 44px;mask-image:radial-gradient(640px 420px at 70% 20%,#000,transparent 75%)}
.hero-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:48px;align-items:center}
.hero h1{margin:20px 0 18px}
.hero .lead{margin-bottom:26px}
.hero-cta{display:flex;gap:11px;flex-wrap:wrap;margin-bottom:18px}
.trust{display:flex;align-items:center;gap:8px;font-size:.88rem;color:var(--ink-3)}
.trust b{color:var(--brand-ink);font-weight:600}
.avatars{display:flex}
.avatars span{width:24px;height:24px;border-radius:50%;border:2px solid var(--bg);margin-left:-7px;
  background:linear-gradient(140deg,var(--brand-2),var(--brand))}
.avatars span:first-child{margin-left:0}
@media(max-width:820px){.hero-grid{grid-template-columns:1fr;gap:34px}.hero{padding:54px 0 48px}}

/* product mock */
.mock{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-3);overflow:hidden;position:relative}
.mock::before{content:"";position:absolute;inset:0;border-radius:var(--r-lg);pointer-events:none;box-shadow:inset 0 1px 0 rgba(255,255,255,.7)}
.mock-bar{display:flex;align-items:center;gap:6px;padding:11px 14px;border-bottom:1px solid var(--line-2);background:#fcfdfc}
.mock-bar .d{width:9px;height:9px;border-radius:50%}
.mock-bar .t{margin-left:8px;font-size:.76rem;color:var(--ink-3);font-weight:500;font-family:var(--body)}
.mock-body{padding:16px}
.cal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.cal-head .m{font-family:var(--display);font-size:1.02rem;font-weight:600;letter-spacing:-.02em}
.chip{font-size:.72rem;font-weight:600;color:var(--brand);background:var(--brand-50);border:1px solid var(--brand-100);padding:3px 9px;border-radius:999px}
.chip.amber{color:#b06a13;background:#fbf1e1;border-color:#f3dcbb}
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}
.cal .d{aspect-ratio:1;border-radius:7px;background:var(--bg-soft);display:grid;place-items:center;font-size:.76rem;color:var(--ink-3);font-weight:500;font-family:var(--body)}
.cal .d.h{background:transparent;color:#b9c4be;font-size:.68rem}
.cal .d.ev{background:var(--brand);color:#fff}
.cal .d.ev2{background:#e8a33d;color:#fff}

/* ---------- full month calendar (calx) ---------- */
:root{
  --ev-purple:#7c5cff; --ev-purple-bg:#efeaff;
  --ev-green:#16a06b;  --ev-green-bg:#e3f6ed;
  --ev-amber:#e8951f;  --ev-amber-bg:#fbedd6;
  --ev-blue:#2f8de0;   --ev-blue-bg:#e2f0fb;
  --ev-pink:#e0559b;   --ev-pink-bg:#fbe6f1;
}
.calx-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.calx-head .mt{display:flex;align-items:center;gap:10px}
.calx-head .mt b{font-family:var(--display);font-size:1.12rem;font-weight:700;letter-spacing:-.02em}
.calx-head .nav-btns{display:flex;gap:6px}
.calx-head .nav-btns span{width:26px;height:26px;border-radius:7px;border:1px solid var(--line);display:grid;place-items:center;color:var(--ink-3);font-size:.8rem;background:#fff}
.calx-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:6px}
.calx-dow span{text-align:center;font-size:.68rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3)}
.calx{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.calx .cell{aspect-ratio:1/1.05;border:1px solid var(--line-2);border-radius:9px;background:#fff;padding:5px 5px 4px;display:flex;flex-direction:column;gap:3px;overflow:hidden;position:relative;transition:border-color .15s,box-shadow .15s}
.calx .cell:hover{border-color:var(--brand-100);box-shadow:var(--sh-1)}
.calx .cell .dn{font-size:.72rem;font-weight:600;color:var(--ink-2);line-height:1}
.calx .cell.out{background:var(--bg-soft);border-color:transparent}
.calx .cell.out .dn{color:#c2ccc7}
.calx .cell.today{border-color:var(--brand);box-shadow:0 0 0 2px var(--glow)}
.calx .cell.today .dn{color:var(--brand)}
.calx .e{font-size:.6rem;font-weight:600;line-height:1.25;padding:2px 5px;border-radius:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.calx .e.purple{background:var(--ev-purple-bg);color:var(--ev-purple)}
.calx .e.green{background:var(--ev-green-bg);color:var(--ev-green)}
.calx .e.amber{background:var(--ev-amber-bg);color:#b06a13}
.calx .e.blue{background:var(--ev-blue-bg);color:var(--ev-blue)}
.calx .e.pink{background:var(--ev-pink-bg);color:var(--ev-pink)}
.calx .more{font-size:.58rem;color:var(--ink-3);font-weight:600;padding-left:3px}
/* color dot legend */
.cal-legend{display:flex;flex-wrap:wrap;gap:12px;margin-top:14px;padding-top:13px;border-top:1px solid var(--line-2)}
.cal-legend .lg{display:flex;align-items:center;gap:6px;font-size:.74rem;color:var(--ink-2);font-weight:500}
.cal-legend .lg i{width:9px;height:9px;border-radius:3px;display:inline-block}
.lg.purple i{background:var(--ev-purple)} .lg.green i{background:var(--ev-green)}
.lg.amber i{background:var(--ev-amber)} .lg.blue i{background:var(--ev-blue)} .lg.pink i{background:var(--ev-pink)}
@media(max-width:520px){.calx .e{font-size:.54rem;padding:1px 4px}.calx .cell{aspect-ratio:1/1.15}}
.rows{margin-top:13px;display:flex;flex-direction:column;gap:8px}
.row{display:flex;align-items:center;gap:10px;padding:9px 11px;border:1px solid var(--line-2);border-radius:10px;background:#fff}
.row .pin{width:6px;height:28px;border-radius:4px;background:var(--brand)}
.row .pin.a{background:#e8a33d}
.row .meta{flex:1;min-width:0}
.row .meta b{display:block;font-size:.84rem;font-weight:600;font-family:var(--body);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.row .meta span{font-size:.74rem;color:var(--ink-3)}

/* ---------- logos / proof strip ---------- */
.proof{border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2);background:#fff}
.proof .wrap{padding:26px 24px;display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;text-align:center}
.proof p{font-size:.86rem;color:var(--ink-3);font-weight:500}

/* ---------- sections ---------- */
section{padding:72px 0}
.sec-head{max-width:60ch;margin-bottom:42px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{margin:14px 0 14px}

/* bento feature grid */
.bento{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}
.cell{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:24px;position:relative;
  transition:transform .16s ease,box-shadow .2s ease,border-color .2s;overflow:hidden}
.cell:hover{transform:translateY(-3px);box-shadow:var(--sh-2);border-color:var(--brand-100)}
.cell.lg{grid-column:span 3}
.cell.sm{grid-column:span 2}
.cell.wide{grid-column:span 6}
.cell .ic{width:40px;height:40px;border-radius:11px;background:var(--brand-50);border:1px solid var(--brand-100);display:grid;place-items:center;margin-bottom:15px}
.cell .ic svg{width:20px;height:20px;stroke:var(--brand);fill:none;stroke-width:1.7}
.cell h3{font-family:var(--display);font-size:1.06rem;margin-bottom:7px}
.cell p{font-size:.93rem;color:var(--ink-3);line-height:1.55}
@media(max-width:820px){.bento{grid-template-columns:repeat(2,1fr)}.cell.lg,.cell.sm,.cell.wide{grid-column:span 2}}
@media(max-width:520px){.bento{grid-template-columns:1fr}.cell.lg,.cell.sm,.cell.wide{grid-column:span 1}}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:820px){.steps{grid-template-columns:1fr}}
.step{padding:26px;background:var(--card);border:1px solid var(--line);border-radius:var(--r);position:relative}
.step .n{display:inline-grid;place-items:center;width:30px;height:30px;border-radius:9px;background:var(--brand);color:#fff;
  font-family:var(--display);font-weight:700;font-size:.95rem;margin-bottom:14px}
.step h3{font-family:var(--display);font-size:1.05rem;margin-bottom:8px}
.step p{font-size:.92rem;color:var(--ink-3)}
.step .line{position:absolute;top:40px;right:-8px;width:16px;height:2px;background:var(--line);z-index:1}
@media(max-width:820px){.step .line{display:none}}

/* split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;padding:40px 0}
.split.rev .txt{order:2}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:28px}.split.rev .txt{order:0}}
.split .txt h2{margin:14px 0 14px}
.split .txt p{color:var(--ink-3);margin-bottom:13px;font-size:1.02rem}
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-2);padding:20px}
.panel .ph{display:flex;align-items:center;justify-content:space-between;padding-bottom:13px;border-bottom:1px solid var(--line-2);margin-bottom:13px}
.panel .ph b{font-family:var(--display);font-size:1.02rem;font-weight:600}
.li{display:flex;justify-content:space-between;padding:9px 0;font-size:.9rem;border-bottom:1px solid var(--line-2);color:var(--ink-2)}
.li span:last-child{font-weight:600;color:var(--ink)}
.li.total{border-bottom:0;padding-top:13px;font-size:1rem}
.li.total span:last-child{color:var(--brand)}
.sig{margin-top:15px;border:1.5px dashed var(--brand-100);background:var(--brand-50);border-radius:10px;padding:12px;text-align:center;
  color:var(--brand);font-family:var(--display);font-weight:600;font-size:.98rem}

/* feature list ticks */
.ticks{list-style:none;display:flex;flex-direction:column;gap:10px;margin-top:8px}
.ticks li{display:flex;gap:10px;align-items:flex-start;font-size:.96rem;color:var(--ink-2)}
.ticks .tk{flex:0 0 18px;width:18px;height:18px;border-radius:50%;background:var(--brand-50);border:1px solid var(--brand-100);display:grid;place-items:center;margin-top:2px}
.ticks .tk svg{width:11px;height:11px;stroke:var(--brand);fill:none;stroke-width:2.4}

/* ---------- pricing ---------- */
.price-wrap{max-width:440px;margin:0 auto}
.price-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-3);overflow:hidden;position:relative}
.price-card .ribbon{position:absolute;top:16px;right:-34px;transform:rotate(45deg);background:var(--brand);color:#fff;
  font-size:.7rem;font-weight:700;letter-spacing:.05em;padding:5px 40px;font-family:var(--body)}
.price-top{padding:32px 32px 24px;border-bottom:1px solid var(--line-2)}
.price-top .plan{font-weight:600;color:var(--brand);font-size:.82rem;letter-spacing:.06em;text-transform:uppercase}
.price-top .amt{font-family:var(--display);font-size:3.4rem;font-weight:800;letter-spacing:-.04em;margin:8px 0 2px;line-height:1}
.price-top .amt small{font-size:1rem;color:var(--ink-3);font-weight:500}
.price-top .add{color:var(--ink-3);font-size:.95rem;margin-top:4px}
.price-top .add b{color:var(--ink)}
.price-list{list-style:none;padding:24px 32px 4px}
.price-list li{display:flex;gap:10px;align-items:flex-start;padding:8px 0;font-size:.95rem;color:var(--ink-2)}
.price-list .tk{flex:0 0 18px;width:18px;height:18px;border-radius:50%;background:var(--brand-50);border:1px solid var(--brand-100);display:grid;place-items:center;margin-top:2px}
.price-list .tk svg{width:11px;height:11px;stroke:var(--brand);fill:none;stroke-width:2.4}
.price-foot{padding:10px 32px 32px}
.price-foot .micro{margin-top:13px;font-size:.83rem;color:var(--ink-3);text-align:center}

/* calculator */
.calc{max-width:440px;margin:0 auto;background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-1);padding:28px;text-align:center}
.calc input{width:120px;text-align:center;font-family:var(--display);font-size:1.4rem;font-weight:700;padding:8px;border:1.5px solid var(--line);border-radius:10px;color:var(--ink)}
.calc input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--glow)}
.calc-out{display:flex;justify-content:center;gap:30px;flex-wrap:wrap;margin:20px 0 8px}
.calc-out .v{font-family:var(--display);font-size:1.5rem;font-weight:700}
.calc-out .k{font-size:.82rem;color:var(--ink-3)}

/* ---------- faq ---------- */
.faq{max-width:720px;margin:0 auto}
.qa{background:var(--card);border:1px solid var(--line);border-radius:var(--r-sm);margin-bottom:10px;overflow:hidden;transition:border-color .2s}
.qa[open]{border-color:var(--brand-100)}
.qa summary{cursor:pointer;padding:18px 22px;font-weight:600;font-size:.98rem;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px}
.qa summary::-webkit-details-marker{display:none}
.qa summary::after{content:"";width:11px;height:11px;border-right:2px solid var(--brand);border-bottom:2px solid var(--brand);transform:rotate(45deg);transition:transform .2s;flex:0 0 11px;margin-top:-4px}
.qa[open] summary::after{transform:rotate(-135deg);margin-top:2px}
.qa .a{padding:0 22px 18px;color:var(--ink-3);font-size:.95rem}

/* ---------- cta ---------- */
.cta{position:relative;background:linear-gradient(135deg,var(--brand),var(--brand-ink));border-radius:var(--r-lg);
  padding:54px 44px;text-align:center;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;opacity:.4;
  background-image:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:40px 40px;mask-image:radial-gradient(500px 220px at 80% 0,#000,transparent 70%)}
.cta h2{color:#fff;position:relative}
.cta .grad{background:linear-gradient(120deg,#bff0d6,#7fdcae);-webkit-background-clip:text;background-clip:text;color:transparent}
.cta p{color:rgba(255,255,255,.82);max-width:50ch;margin:13px auto 26px;position:relative}
.cta-row{display:flex;gap:11px;justify-content:center;flex-wrap:wrap;position:relative}
.cta .btn-primary{background:#fff;color:var(--brand-ink)}
.cta .btn-primary:hover{background:var(--brand-50)}
.cta .btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
.cta .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.1)}

/* ---------- forms ---------- */
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:40px;align-items:start}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr;gap:28px}}
.form-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-2);padding:30px}
.seg{display:flex;gap:6px;background:var(--bg-soft);padding:5px;border-radius:11px;margin-bottom:22px}
.seg button{flex:1;border:0;background:transparent;font-family:var(--body);font-weight:600;font-size:.92rem;color:var(--ink-3);padding:10px;border-radius:8px;cursor:pointer;transition:all .16s}
.seg button.on{background:#fff;color:var(--brand);box-shadow:var(--sh-1)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.form-grid{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.field.full{grid-column:1/-1}
.field label{font-weight:600;font-size:.86rem;color:var(--ink-2)}
.field input,.field select,.field textarea{font-family:var(--body);font-size:.97rem;padding:11px 13px;border:1.5px solid var(--line);
  border-radius:9px;background:#fff;color:var(--ink);transition:border-color .15s,box-shadow .15s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--glow)}
.field textarea{resize:vertical;min-height:104px}
.ci{display:flex;gap:13px;margin-bottom:20px;align-items:flex-start}
.ci .ic{width:38px;height:38px;border-radius:10px;background:var(--brand-50);border:1px solid var(--brand-100);display:grid;place-items:center;flex:0 0 38px}
.ci .ic svg{width:18px;height:18px;stroke:var(--brand);fill:none;stroke-width:1.7}
.ci b{display:block;font-size:.94rem}
.ci span{font-size:.9rem;color:var(--ink-3)}
.note{background:var(--brand-50);border:1px solid var(--brand-100);border-radius:11px;padding:15px 17px;font-size:.89rem;color:var(--brand-ink);margin-top:18px}

/* ---------- doc pages ---------- */
.doc{max-width:720px;margin:0 auto}
.doc h2{font-size:1.3rem;margin:28px 0 9px}
.doc p{color:var(--ink-3);margin-bottom:11px;font-size:.97rem}
.doc .ph{background:var(--brand-50);border:1px dashed var(--brand-100);border-radius:10px;padding:14px 16px;color:var(--brand-ink);font-size:.9rem;margin-bottom:6px}

/* ---------- footer ---------- */
footer.site{background:#fff;border-top:1px solid var(--line);padding:52px 0 26px;margin-top:8px}
.foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:34px}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr;gap:26px}}
.foot-grid .about{color:var(--ink-3);font-size:.91rem;margin-top:13px;max-width:32ch}
.foot-col h4{font-family:var(--body);font-size:.76rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);margin-bottom:13px;font-weight:600}
.foot-col a{display:block;color:var(--ink-2);font-size:.92rem;padding:5px 0;transition:color .15s}
.foot-col a:hover{color:var(--brand)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:13px;margin-top:38px;padding-top:22px;border-top:1px solid var(--line-2);font-size:.86rem;color:var(--ink-3)}
.foot-bottom .links{display:flex;gap:18px}
.foot-bottom .links a:hover{color:var(--brand)}

/* page hero */
.phero{padding:60px 0 26px;text-align:center}
.phero .lead{margin:16px auto 0}

/* reveal — only hides when JS is present (js-on), so content never disappears if JS fails */
.js-on .reveal{opacity:0;transform:translateY(14px);transition:opacity .55s ease,transform .55s ease}
.js-on .reveal.in{opacity:1;transform:none}
