/* ============================================================
   Roastline — interior pages
   Extends landing.css (tokens, nav, footer, buttons, console).
   ============================================================ */

/* ---------- compact page hero ---------- */
.page-hero{position:relative;overflow:hidden;padding:84px 0 64px;border-bottom:1px solid var(--line);}
.page-hero.tall{padding:104px 0 90px;}
.page-hero .glow{position:absolute;top:-160px;right:-120px;width:820px;height:620px;pointer-events:none;
  background:radial-gradient(closest-side,rgba(216,90,48,.13),rgba(239,159,39,.04) 46%,transparent 72%);}
.page-hero .bg-curve{position:absolute;inset:0;width:100%;height:100%;opacity:.5;pointer-events:none;}
.page-hero h1{font-size:clamp(38px,5vw,62px);font-weight:600;letter-spacing:-.03em;line-height:1.03;text-wrap:balance;margin-top:22px;max-width:18ch;}
.page-hero .lede{font-size:clamp(18px,1.6vw,22px);color:var(--dim);line-height:1.55;margin-top:24px;max-width:620px;text-wrap:pretty;}
.page-hero .hero-cta{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap;}

/* breadcrumb */
.crumb{font-family:var(--mono);font-size:12.5px;letter-spacing:.06em;color:var(--faint);display:flex;gap:9px;align-items:center;}
.crumb a{color:var(--faint);}
.crumb a:hover{color:var(--dim);}
.crumb .sep{opacity:.5;}

/* generic interior section spacing a touch tighter than landing */
.sec{padding:96px 0;position:relative;}
.sec.tight{padding:68px 0;}
.sec.alt{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}

/* ============================================================
   PROSE  (about / legal / guide article)
   ============================================================ */
.prose{max-width:760px;}
.prose h2{font-size:clamp(24px,2.4vw,32px);font-weight:600;letter-spacing:-.02em;margin:52px 0 16px;line-height:1.15;}
.prose h2:first-child{margin-top:0;}
.prose h3{font-size:21px;font-weight:600;margin:34px 0 12px;letter-spacing:-.01em;}
.prose p{font-size:18px;line-height:1.68;color:var(--dim);margin-bottom:18px;text-wrap:pretty;}
.prose p b,.prose p strong{color:var(--ink);font-weight:600;}
.prose ul,.prose ol{margin:0 0 18px 0;padding-left:4px;list-style:none;display:flex;flex-direction:column;gap:11px;}
.prose li{font-size:18px;line-height:1.6;color:var(--dim);display:flex;gap:13px;align-items:flex-start;}
.prose ul li::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--orange);margin-top:10px;flex:none;}
.prose ol{counter-reset:n;}
.prose ol li{counter-increment:n;}
.prose ol li::before{content:counter(n);font-family:var(--mono);font-size:13px;color:var(--orange);
  width:24px;flex:none;padding-top:2px;}
.prose a.lnk{color:var(--ink);text-decoration:underline;text-decoration-color:var(--orange);text-underline-offset:3px;}
.prose blockquote{border-left:2px solid var(--orange);padding:6px 0 6px 24px;margin:26px 0;
  font-size:22px;line-height:1.5;color:var(--ink);font-weight:500;}

/* two-column doc/legal layout w/ sticky sidebar TOC */
.layout{display:grid;grid-template-columns:240px 1fr;gap:56px;align-items:start;}
.toc{position:sticky;top:92px;display:flex;flex-direction:column;gap:3px;}
.toc .tt{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin-bottom:12px;}
.toc a{font-size:15px;color:var(--dim);padding:7px 12px;border-radius:8px;border-left:2px solid transparent;transition:.15s;}
.toc a:hover{color:var(--ink);background:rgba(255,255,255,.03);}
.toc a.on{color:var(--ink);border-left-color:var(--orange);background:rgba(216,90,48,.06);}
.meta-line{font-family:var(--mono);font-size:13px;color:var(--faint);letter-spacing:.04em;}

/* ============================================================
   FEATURE / VALUE GRID  (about, careers, contact)
   ============================================================ */
.vgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:52px;}
.vcard{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:30px 28px;display:flex;flex-direction:column;gap:13px;}
.vcard .ic{width:44px;height:44px;border-radius:11px;border:1px solid var(--line);background:var(--panel);
  display:flex;align-items:center;justify-content:center;color:var(--orange);margin-bottom:4px;}
.vcard h4{font-size:21px;font-weight:600;letter-spacing:-.01em;}
.vcard p{font-size:16px;color:var(--dim);line-height:1.55;}

/* big stat band */
.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:52px;}
.statband .s{display:flex;flex-direction:column;gap:8px;border-left:1px solid var(--line);padding-left:22px;}
.statband .s:first-child{border-left:none;padding-left:0;}
.statband .num{font-size:clamp(34px,4vw,52px);font-weight:600;letter-spacing:-.03em;line-height:1;}
.statband .cap{font-size:15px;color:var(--dim);line-height:1.45;}

/* team grid */
.team{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:48px;}
.member{display:flex;flex-direction:column;gap:14px;}
.member .ph{aspect-ratio:1;border-radius:14px;background:repeating-linear-gradient(135deg,var(--panel) 0 11px,var(--panel-2) 11px 22px);
  border:1px solid var(--line);display:flex;align-items:flex-end;padding:14px;}
.member .ph .mono{font-size:11px;color:var(--faint);}
.member .nm{font-size:18px;font-weight:600;}
.member .rl{font-family:var(--mono);font-size:13px;color:var(--orange);}
.member .bio{font-size:14px;color:var(--dim);line-height:1.5;}

/* ============================================================
   PRICING extras (comparison + faq)
   ============================================================ */
.toggle-bill{display:inline-flex;gap:4px;background:var(--panel);border:1px solid var(--line);border-radius:999px;padding:4px;margin-top:30px;}
.toggle-bill button{font-family:var(--disp);font-size:14px;font-weight:500;color:var(--dim);background:transparent;border:none;
  padding:9px 18px;border-radius:999px;cursor:pointer;transition:.15s;}
.toggle-bill button.on{background:var(--orange);color:#140b07;}
.toggle-bill .save{font-family:var(--mono);font-size:11px;color:var(--teal);}

.cmp{width:100%;border-collapse:collapse;margin-top:24px;}
.cmp th,.cmp td{text-align:left;padding:17px 20px;border-bottom:1px solid var(--line);font-size:16px;}
.cmp thead th{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);font-weight:500;
  position:sticky;top:70px;background:var(--bg);}
.cmp tbody td{color:var(--dim);}
.cmp tbody td:first-child{color:var(--ink);}
.cmp td.c{text-align:center;}
.cmp .grp td{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);
  background:var(--surface);padding-top:22px;padding-bottom:10px;}
.cmp col.hi,.cmp th.hi{background:rgba(216,90,48,.05);}
.cmp .yes{color:var(--teal);}
.cmp .no{color:var(--faint);}
.tick{display:inline-flex;}

.faq{display:flex;flex-direction:column;max-width:820px;margin:0 auto;}
.faq details{border-top:1px solid var(--line);padding:6px 0;}
.faq details:last-child{border-bottom:1px solid var(--line);}
.faq summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:20px;
  padding:22px 4px;font-size:20px;font-weight:500;color:var(--ink);}
.faq summary::-webkit-details-marker{display:none;}
.faq summary .pl{position:relative;width:18px;height:18px;flex:none;}
.faq summary .pl::before,.faq summary .pl::after{content:"";position:absolute;background:var(--orange);transition:.2s;}
.faq summary .pl::before{left:8px;top:0;width:2px;height:18px;}
.faq summary .pl::after{left:0;top:8px;width:18px;height:2px;}
.faq details[open] summary .pl::before{transform:rotate(90deg);opacity:0;}
.faq .ans{font-size:17px;color:var(--dim);line-height:1.6;padding:0 4px 24px;max-width:680px;}

/* ============================================================
   DOCS hub
   ============================================================ */
.doc-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px;}
.doc-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:28px;
  display:flex;flex-direction:column;gap:10px;transition:.15s;}
.doc-card:hover{border-color:rgba(255,255,255,.18);transform:translateY(-2px);}
.doc-card .ic{width:40px;height:40px;border-radius:10px;border:1px solid var(--line);background:var(--panel);
  display:flex;align-items:center;justify-content:center;color:var(--orange);margin-bottom:6px;}
.doc-card h4{font-size:20px;font-weight:600;letter-spacing:-.01em;}
.doc-card p{font-size:15px;color:var(--dim);line-height:1.5;}
.doc-card .links{display:flex;flex-direction:column;gap:2px;margin-top:8px;}
.doc-card .links a{font-size:15px;color:var(--dim);padding:6px 0;display:flex;align-items:center;gap:9px;transition:.15s;}
.doc-card .links a:hover{color:var(--ink);}
.doc-card .links a::before{content:"›";color:var(--orange);font-size:16px;}

.code{background:#0a0a09;border:1px solid var(--line);border-radius:12px;padding:18px 20px;overflow-x:auto;
  font-family:var(--mono);font-size:14px;line-height:1.7;color:var(--dim);margin:22px 0;}
.code .c-key{color:var(--teal);}
.code .c-str{color:var(--amber);}
.code .c-com{color:var(--faint);}
.code .prompt{color:var(--orange);user-select:none;}
.callout{display:flex;gap:14px;background:rgba(26,188,156,.06);border:1px solid rgba(26,188,156,.28);border-radius:12px;
  padding:18px 20px;margin:24px 0;}
.callout .ic{color:var(--teal);flex:none;}
.callout p{font-size:16px;color:var(--dim);line-height:1.55;margin:0;}
.callout b{color:var(--ink);}

/* ============================================================
   DEVICES
   ============================================================ */
.dev-filter{display:flex;gap:10px;margin-top:42px;flex-wrap:wrap;}
.dev-filter .chip{font-family:var(--mono);font-size:13px;letter-spacing:.04em;color:var(--dim);background:var(--panel);
  border:1px solid var(--line);border-radius:999px;padding:9px 16px;cursor:pointer;transition:.15s;}
.dev-filter .chip.on,.dev-filter .chip:hover{color:var(--ink);border-color:rgba(255,255,255,.2);}
.dev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:28px;}
.dev{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:26px;display:flex;flex-direction:column;gap:16px;}
.dev .top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;}
.dev .badge{font-family:var(--mono);font-size:11px;letter-spacing:.08em;padding:5px 11px;border-radius:999px;white-space:nowrap;}
.badge.live{background:rgba(26,188,156,.14);color:var(--teal);}
.badge.beta{background:rgba(239,159,39,.14);color:var(--amber);}
.badge.soon{background:rgba(255,255,255,.06);color:var(--faint);}
.badge.req{background:rgba(216,90,48,.14);color:var(--orange);}
.dev .glyph{width:54px;height:54px;border-radius:12px;border:1px solid var(--line);background:var(--panel);
  display:flex;align-items:center;justify-content:center;color:var(--dim);}
.dev h4{font-size:21px;font-weight:600;letter-spacing:-.01em;}
.dev .sub{font-family:var(--mono);font-size:12.5px;color:var(--faint);letter-spacing:.04em;margin-top:-8px;}
.dev .specs{display:flex;flex-direction:column;gap:9px;border-top:1px solid var(--line);padding-top:16px;margin-top:2px;}
.dev .specs .r{display:flex;justify-content:space-between;font-size:14px;}
.dev .specs .r .k{color:var(--faint);font-family:var(--mono);font-size:12.5px;letter-spacing:.04em;}
.dev .specs .r .v{color:var(--dim);}

/* ============================================================
   CHANGELOG
   ============================================================ */
.log{max-width:880px;margin:0 auto;}
.entry{display:grid;grid-template-columns:200px 1fr;gap:40px;padding:44px 0;border-top:1px solid var(--line);}
.entry .side{position:sticky;top:92px;align-self:start;}
.entry .ver{font-family:var(--mono);font-size:13px;color:var(--orange);letter-spacing:.06em;}
.entry .date{font-family:var(--mono);font-size:13px;color:var(--faint);margin-top:6px;}
.entry h3{font-size:26px;font-weight:600;letter-spacing:-.02em;margin-bottom:8px;}
.entry .tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px;}
.entry .tag{font-family:var(--mono);font-size:11px;letter-spacing:.06em;padding:4px 10px;border-radius:999px;}
.tag.new{background:rgba(26,188,156,.14);color:var(--teal);}
.tag.imp{background:rgba(239,159,39,.14);color:var(--amber);}
.tag.fix{background:rgba(255,255,255,.06);color:var(--dim);}
.entry .body p{font-size:17px;color:var(--dim);line-height:1.6;margin-bottom:14px;}
.entry .body ul{list-style:none;display:flex;flex-direction:column;gap:10px;}
.entry .body li{font-size:16px;color:var(--dim);line-height:1.55;display:flex;gap:12px;align-items:flex-start;}
.entry .body li::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--faint);margin-top:9px;flex:none;}

/* ============================================================
   STATUS
   ============================================================ */
.status-banner{display:flex;align-items:center;gap:16px;background:rgba(26,188,156,.07);border:1px solid rgba(26,188,156,.3);
  border-radius:14px;padding:24px 28px;margin-top:8px;}
.status-banner .big{width:14px;height:14px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 5px rgba(26,188,156,.16);flex:none;}
.status-banner h3{font-size:22px;font-weight:600;letter-spacing:-.01em;}
.status-banner p{font-size:14px;color:var(--dim);font-family:var(--mono);margin-top:3px;}
.svc{display:flex;flex-direction:column;gap:0;margin-top:36px;border:1px solid var(--line);border-radius:16px;overflow:hidden;}
.svc .row{display:grid;grid-template-columns:1fr auto;gap:20px;align-items:center;padding:22px 26px;border-top:1px solid var(--line);background:var(--surface);}
.svc .row:first-child{border-top:none;}
.svc .name{font-size:18px;font-weight:500;display:flex;align-items:center;gap:12px;}
.svc .name .d{width:9px;height:9px;border-radius:50%;flex:none;}
.d.up{background:var(--teal);}.d.deg{background:var(--amber);}.d.down{background:var(--orange);}
.svc .name .sub{font-family:var(--mono);font-size:12px;color:var(--faint);margin-top:3px;}
.svc .state{font-family:var(--mono);font-size:13px;letter-spacing:.04em;}
.state.up{color:var(--teal);}.state.deg{color:var(--amber);}
.bars{display:flex;gap:2px;align-items:flex-end;height:30px;margin-top:30px;}
.bars i{flex:1;height:100%;border-radius:1px;background:var(--teal);opacity:.85;}
.bars i.deg{background:var(--amber);}
.bars i.down{background:var(--orange);}
.uptime-row{display:flex;justify-content:space-between;margin-top:10px;font-family:var(--mono);font-size:12px;color:var(--faint);}

/* ============================================================
   BLOG / ROAST GUIDES
   ============================================================ */
.cat-row{display:flex;gap:10px;margin-top:40px;flex-wrap:wrap;}
.cat-row .chip{font-family:var(--mono);font-size:13px;letter-spacing:.04em;color:var(--dim);background:var(--panel);
  border:1px solid var(--line);border-radius:999px;padding:9px 16px;cursor:pointer;transition:.15s;}
.cat-row .chip.on,.cat-row .chip:hover{color:var(--ink);border-color:rgba(255,255,255,.2);}
.feature-post{display:grid;grid-template-columns:1.15fr 1fr;gap:0;border:1px solid var(--line);border-radius:18px;overflow:hidden;margin-top:30px;}
.feature-post .art{background:var(--surface);position:relative;min-height:340px;display:flex;align-items:center;justify-content:center;padding:30px;border-right:1px solid var(--line);}
.feature-post .body{padding:44px;display:flex;flex-direction:column;justify-content:center;gap:16px;}
.feature-post .body h3{font-size:clamp(26px,3vw,38px);font-weight:600;letter-spacing:-.02em;line-height:1.1;}
.feature-post .body p{font-size:18px;color:var(--dim);line-height:1.6;}
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:32px;}
.post{background:var(--surface);border:1px solid var(--line);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;transition:.15s;}
.post:hover{border-color:rgba(255,255,255,.18);transform:translateY(-3px);}
.post .art{height:170px;background:var(--panel);border-bottom:1px solid var(--line);position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.post .body{padding:24px;display:flex;flex-direction:column;gap:10px;flex:1;}
.post .cat{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;}
.post h4{font-size:20px;font-weight:600;letter-spacing:-.01em;line-height:1.2;}
.post p{font-size:15px;color:var(--dim);line-height:1.5;flex:1;}
.post .pmeta{font-family:var(--mono);font-size:12px;color:var(--faint);display:flex;gap:10px;align-items:center;margin-top:6px;}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;}
.field{display:flex;flex-direction:column;gap:9px;margin-bottom:20px;}
.field label{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);}
.field input,.field textarea,.field select{background:var(--surface);border:1px solid var(--line);border-radius:11px;
  padding:14px 16px;color:var(--ink);font-family:var(--disp);font-size:16px;outline:none;transition:border-color .15s;width:100%;}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--orange);}
.field textarea{resize:vertical;min-height:130px;line-height:1.5;}
.field.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.contact-method{display:flex;gap:16px;padding:22px 0;border-top:1px solid var(--line);}
.contact-method:first-of-type{border-top:none;}
.contact-method .ic{width:42px;height:42px;border-radius:11px;border:1px solid var(--line);background:var(--panel);
  display:flex;align-items:center;justify-content:center;color:var(--orange);flex:none;}
.contact-method h4{font-size:18px;font-weight:600;}
.contact-method p{font-size:15px;color:var(--dim);line-height:1.5;margin-top:3px;}
.contact-method a{color:var(--teal);}

/* ============================================================
   CAREERS roles
   ============================================================ */
.roles{margin-top:44px;border-top:1px solid var(--line);}
.role{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;padding:26px 4px;border-bottom:1px solid var(--line);transition:.15s;}
.role:hover{background:rgba(255,255,255,.02);padding-left:14px;padding-right:14px;}
.role h4{font-size:21px;font-weight:600;letter-spacing:-.01em;}
.role .rmeta{display:flex;gap:18px;margin-top:8px;font-family:var(--mono);font-size:13px;color:var(--faint);flex-wrap:wrap;}
.role .rmeta span{display:flex;align-items:center;gap:7px;}
.role .arrow{color:var(--orange);font-size:22px;}

/* ============================================================
   shared CTA band (interior pages)
   ============================================================ */
.cta-band{position:relative;overflow:hidden;background:var(--surface);border-top:1px solid var(--line);text-align:center;padding:104px 0;}
.cta-band svg.bg{position:absolute;inset:0;width:100%;height:100%;opacity:.45;pointer-events:none;}
.cta-band h2{position:relative;z-index:1;font-size:clamp(30px,4.4vw,52px);font-weight:600;letter-spacing:-.03em;line-height:1.06;max-width:820px;margin:0 auto;text-wrap:balance;}
.cta-band .sub{position:relative;z-index:1;margin:18px auto 0;max-width:560px;}
.cta-band .row{position:relative;z-index:1;display:flex;gap:14px;justify-content:center;margin-top:34px;flex-wrap:wrap;}

/* ============================================================
   responsive
   ============================================================ */
@media (max-width:980px){
  .sec{padding:72px 0;}
  .layout{grid-template-columns:minmax(0,1fr);gap:30px;}
  .layout>*{min-width:0;}
  .toc{position:static;flex-direction:row;flex-wrap:wrap;gap:6px;border-bottom:1px solid var(--line);padding-bottom:20px;}
  .toc .tt{width:100%;}
  .vgrid,.doc-cards,.dev-grid,.post-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);}
  .team{grid-template-columns:minmax(0,1fr) minmax(0,1fr);}
  .statband{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:30px;}
  .statband .s{border-left:none;padding-left:0;}
  .contact-grid{grid-template-columns:minmax(0,1fr);gap:40px;}
  .contact-grid>*{min-width:0;}
  .feature-post{grid-template-columns:minmax(0,1fr);}
  .feature-post .art{border-right:none;border-bottom:1px solid var(--line);min-height:240px;}
  .entry{grid-template-columns:minmax(0,1fr);gap:16px;}
  .entry .side{position:static;}
  .vgrid>*,.doc-cards>*,.dev-grid>*,.post-grid>*,.team>*,.statband>*{min-width:0;}
}
@media (max-width:680px){
  .wrap{padding:0 20px;}
  .sec{padding:60px 0;}
  .vgrid,.doc-cards,.dev-grid,.post-grid,.team,.statband{grid-template-columns:minmax(0,1fr);}
  .field.row2{grid-template-columns:minmax(0,1fr);}
  .cmp{font-size:14px;display:block;overflow-x:auto;white-space:nowrap;}
  .role{grid-template-columns:minmax(0,1fr);gap:14px;}
}
