/* assets/future-seo.css
   Shared FutureLens styles for Worker-rendered forecast HTML pages.
   Mirrors the SPA visual language without requiring the full client app.
*/
:root{
  --bg:#07111f;
  --bg-2:#0a1730;
  --surface:rgba(11,22,41,.88);
  --line:rgba(173,201,255,.14);
  --line-strong:rgba(103,232,249,.34);
  --fg:#eff4ff;
  --muted:#97a6ca;
  --accent:#67e8f9;
  --accent-2:#86efac;
  --accent-3:#8b5cf6;
  --warm:#fbbf24;
  --danger:#fca5a5;
  --ok:#6ee7b7;
  --shadow:0 24px 80px rgba(0,0,0,.38);
  --shadow-soft:0 12px 40px rgba(0,0,0,.25);
  --radius-xl:28px;
  --radius-lg:22px;
  --radius-md:18px;
  --container:1220px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  min-height:100vh;
  color:var(--fg);
  font:400 16px/1.55 Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:
    radial-gradient(circle at top left, rgba(103,232,249,.16), transparent 32%),
    radial-gradient(circle at top right, rgba(139,92,246,.16), transparent 28%),
    radial-gradient(circle at 20% 80%, rgba(134,239,172,.12), transparent 24%),
    linear-gradient(180deg, #06101d 0%, #081425 34%, #09172c 100%);
  overflow-x:hidden;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:0;
  background:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size:30px 30px;
  mask-image:linear-gradient(180deg, rgba(0,0,0,.55), transparent 85%);
  opacity:.22;
}
a{color:inherit;text-decoration:none}
button,input,select{font:inherit}
img,svg{display:block}
.wrap{overflow-wrap:anywhere;word-break:break-word}
.muted{color:var(--muted)}
.container{position:relative;z-index:1;width:min(var(--container), calc(100% - 32px));margin-inline:auto}
.surface{
  position:relative;
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:var(--radius-xl);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015)), var(--surface);
  box-shadow:var(--shadow-soft);
  backdrop-filter:blur(18px);
}
.surface::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.24), transparent);
  opacity:.7;
  pointer-events:none;
}
.topbar{
  position:sticky;
  top:0;
  z-index:30;
  background:rgba(7,14,28,.68);
  border-bottom:1px solid rgba(173,201,255,.10);
  backdrop-filter:blur(20px);
  box-shadow:0 12px 40px rgba(0,0,0,.22);
}
.topbar-inner{
  min-height:74px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:12px 0;
}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.brand-mark{
  width:42px;
  height:42px;
  border-radius:16px;
  flex:0 0 auto;
  display:grid;
  place-items:center;
  color:#08131f;
  background:linear-gradient(135deg, var(--accent), var(--accent-2));
  border:1px solid rgba(103,232,249,.22);
  box-shadow:0 8px 20px rgba(0,0,0,.2);
  font-weight:900;
}
.brand-name{display:block;font-size:1.05rem;font-weight:800;letter-spacing:.02em}
.brand-tag{display:block;font-size:.72rem;color:var(--muted);letter-spacing:.12em;text-transform:uppercase}
.nav-actions,.detail-actions,.actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.btn,.chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:42px;
  padding:0 14px;
  border-radius:14px;
  border:1px solid transparent;
  color:var(--fg);
  background:transparent;
  cursor:pointer;
  transition:transform .18s ease, background .18s ease, border-color .18s ease, box-shadow .18s ease;
  text-decoration:none;
}
.btn:hover,.chip:hover{transform:translateY(-1px);background:rgba(255,255,255,.05)}
.btn-primary{
  color:#08131f;
  background:linear-gradient(135deg, var(--accent), var(--accent-2));
  font-weight:700;
  box-shadow:0 12px 26px rgba(103,232,249,.18);
}
.btn-outline{border-color:rgba(173,201,255,.16);background:rgba(255,255,255,.02)}
.inline{width:auto}
.detail-shell{padding-top:24px;padding-bottom:40px}
.breadcrumbs{display:flex;gap:8px;align-items:center;flex-wrap:wrap;color:var(--muted);font-size:.92rem;margin-bottom:14px}
.breadcrumbs a{color:inherit}
.detail-hero{padding:clamp(22px,3vw,40px);margin-bottom:24px;box-shadow:var(--shadow)}
.detail-title{margin:0;font-size:clamp(2rem,4vw,3.2rem);line-height:1;letter-spacing:-.045em;text-wrap:balance}
.gradient-text{
  background:linear-gradient(115deg, #f9fbff 5%, #8fe9ff 40%, #91ffcf 90%);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.detail-summary{margin:18px 0 0;color:var(--muted);line-height:1.74;font-size:1rem}
.detail-actions{margin-top:22px}
.pill-row{display:flex;gap:10px;flex-wrap:wrap}
.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:9px 12px;
  border-radius:999px;
  font-size:.82rem;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(173,201,255,.12);
}
.pill.warm{color:#221400;background:rgba(251,191,36,.92);font-weight:700;border-color:transparent}
.pill.risk{background:rgba(252,165,165,.14);color:#ffd8d8;border-color:rgba(252,165,165,.12)}
.fact-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:24px}
.fact-tile{padding:18px;border-radius:18px;border:1px solid rgba(173,201,255,.12);background:rgba(255,255,255,.035)}
.fact-label{font-size:.82rem;color:var(--muted);text-transform:uppercase;letter-spacing:.12em}
.fact-value{margin-top:10px;font-size:1.1rem;line-height:1.35;font-weight:700}
.detail-grid{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(300px,.85fr);gap:24px}
.section{padding:24px;margin-bottom:24px;content-visibility:auto;contain-intrinsic-size:420px}
.section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.section h2,.section h3,.section h4{margin:0;font-size:1.02rem;font-weight:800;letter-spacing:.01em}
.scenario-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.scenario-card{padding:18px;border-radius:20px;border:1px solid rgba(173,201,255,.12);background:rgba(255,255,255,.03)}
.scenario-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.scenario-pct{color:#09131f;background:linear-gradient(135deg,var(--accent),var(--accent-2));border-radius:999px;padding:6px 10px;font-size:.82rem;font-weight:800;white-space:nowrap}
.bar{height:10px;border-radius:999px;background:rgba(255,255,255,.06);overflow:hidden;margin:14px 0 12px}
.bar>span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--accent),var(--accent-2))}
.projection-list{display:grid;gap:14px}
.projection{padding:18px;border-radius:20px;border:1px solid rgba(173,201,255,.12);background:rgba(255,255,255,.03)}
.projection-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;flex-wrap:wrap;margin-bottom:10px}
.horizon{display:inline-flex;align-items:center;gap:8px;padding:7px 10px;border-radius:999px;font-size:.82rem;background:rgba(103,232,249,.13);color:#dffcff}
.steps{display:grid;gap:10px}
.step{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:flex-start;padding:12px 14px;border-radius:16px;background:rgba(255,255,255,.03);border:1px solid rgba(173,201,255,.10)}
.step-num{width:28px;height:28px;border-radius:999px;background:rgba(255,255,255,.08);display:grid;place-items:center;font-weight:700}
.sticky{position:sticky;top:96px}
.list-plain{display:grid;gap:10px}
.related{
  display:block;
  width:100%;
  text-align:left;
  padding:14px;
  border-radius:16px;
  border:1px solid rgba(173,201,255,.10);
  background:rgba(255,255,255,.03);
  color:var(--fg);
}
.related:hover{background:rgba(255,255,255,.05)}
.guardrail{
  padding:14px 16px;
  border-radius:18px;
  border:1px solid rgba(251,191,36,.22);
  background:rgba(251,191,36,.10);
  color:#ffe7aa;
  line-height:1.58;
}
.guardrail strong{color:#fff7d6}
.source-list{display:grid;gap:10px;margin-top:10px}
.source-list a,.source-list span{
  display:block;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid rgba(173,201,255,.10);
  background:rgba(255,255,255,.03);
  color:var(--fg);
  overflow-wrap:anywhere;
}
.keyword-row{display:flex;gap:8px;flex-wrap:wrap}
.chip{
  min-height:36px;
  padding:0 12px;
  border-radius:999px;
  border-color:rgba(173,201,255,.14);
  background:rgba(255,255,255,.03);
}
.mini-note{margin-top:10px;color:var(--muted);font-size:.9rem;line-height:1.55}
.foot{padding:34px 0 40px;color:var(--muted);text-align:center}
.card{height:100%;display:flex;flex-direction:column;gap:18px;padding:24px;border-radius:var(--radius-xl)}
.card h2{margin:0;font-size:clamp(1.36rem,2.5vw,1.78rem);line-height:1.12;letter-spacing:-.03em;text-wrap:balance}
.card p{margin:0}
.summary{color:var(--muted);line-height:1.72;font-size:.98rem}
@media (max-width:1180px){
  .detail-grid{grid-template-columns:1fr}
  .sticky{position:static}
}
@media (max-width:760px){
  .container{width:min(var(--container), calc(100% - 20px))}
  .topbar-inner{align-items:flex-start;flex-direction:column}
  .nav-actions{width:100%;justify-content:flex-start}
  .detail-grid,.fact-grid{grid-template-columns:1fr}
  .detail-hero,.section,.surface{border-radius:22px}
  .detail-hero,.section{padding:18px}
  .btn,.chip{width:100%;justify-content:center}
  .btn.inline,.chip.inline{width:auto}
  .detail-shell,.detail-grid,.detail-grid>div,.detail-grid>aside,.detail-hero,.section,.scenario-grid,.scenario-card,.projection,.projection-top,.scenario-top,.fact-grid,.detail-actions,.pill-row{min-width:0}
  .scenario-grid{grid-template-columns:minmax(0,1fr)}
  .scenario-top>*,
  .projection-top>*,
  .pill-row>*{min-width:0;max-width:100%}
  .detail-actions>.btn.inline{width:100%;justify-content:center}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}
@media print{
  body{background:#fff!important;color:#111!important}
  body::before,.topbar,.detail-actions,.foot{display:none!important}
  .surface,.card,.section,.detail-hero{background:#fff!important;color:#111!important;box-shadow:none!important;border:1px solid #ddd!important}
  .muted,.summary,.detail-summary{color:#333!important}
  .container{width:100%!important}
}
