/* ============================================================
   Factory Portal UI kit — LIGHT theme.
   The friendly, factory-facing front door. Reuses the brand's
   "paper" world (white surfaces, ink text, the one blue, a green
   energy spark) so it stays in-brand while reading clearly apart
   from the dark institutional site.
   Tokens come from the design system (link ../../styles.css first).
   ============================================================ */
* { box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { margin:0; background:var(--paper-soft); color:var(--ink); font-family:var(--font-sans); font-size:16px; line-height:1.7; -webkit-font-smoothing:antialiased; }
a { color:inherit; text-decoration:none; }
h1,h2,h3,h4 { margin:0; font-family:var(--font-serif); font-weight:600; letter-spacing:-.015em; line-height:1.2; color:var(--ink); }
img { max-width:100%; }
.wrap { max-width:1140px; margin:0 auto; padding:0 28px; width:100%; }
.mono { font-family:var(--font-mono); font-variant-numeric:tabular-nums; }

/* ink hierarchy on paper */
.ink-2 { color:var(--ink-muted); }
.spark { color:#16894a; }

/* eyebrow (factory = friendlier, still tracked) */
.eyebrow { display:inline-flex; align-items:center; gap:9px; font:600 12px/1.4 var(--font-sans); letter-spacing:.12em; text-transform:uppercase; color:var(--accent); margin:0 0 16px; }
.eyebrow::before { content:""; width:22px; height:1px; background:currentColor; opacity:.6; }
.eyebrow.green { color:#16894a; }

/* buttons */
.btn { display:inline-flex; align-items:center; gap:9px; font:600 15px/1 var(--font-sans); padding:14px 22px; border-radius:var(--radius-btn); border:1px solid transparent; cursor:pointer; transition:transform .18s var(--ease),background .18s,border-color .18s,box-shadow .18s; }
.btn svg { width:17px; height:17px; }
.btn-primary { background:var(--accent); color:#fff; }
.btn-primary:hover { background:var(--accent-hover); box-shadow:0 14px 30px rgba(59,130,246,.28); transform:translateY(-1px); }
.btn-ghost { background:#fff; color:var(--ink); border-color:var(--line-light); }
.btn-ghost:hover { border-color:var(--accent); color:var(--accent); }
.btn-arrow { display:inline-flex; transition:transform .2s; }
.btn:hover .btn-arrow { transform:translateX(3px); }
.btn-block { width:100%; justify-content:center; }
.btn[disabled] { opacity:.4; pointer-events:none; }

/* nav */
.fnav { position:sticky; top:0; z-index:50; background:rgba(248,250,252,.86); backdrop-filter:blur(12px); border-bottom:1px solid var(--line-light); }
.fnav-inner { display:flex; align-items:center; gap:20px; height:64px; }
.fbrand { display:flex; align-items:center; gap:10px; cursor:pointer; }
.fbrand img { width:30px; height:30px; border-radius:8px; }
.fbrand .nm { display:flex; flex-direction:column; line-height:1.12; }
.fbrand .nm b { font-size:14.5px; font-weight:700; color:var(--ink); }
.fbrand .nm span { font-size:10.5px; color:var(--ink-muted); letter-spacing:.03em; }
.fnav-links { display:flex; gap:2px; margin-left:6px; flex:1; }
.fnav-links a { padding:8px 11px; border-radius:8px; font-size:13.5px; color:var(--ink-muted); cursor:pointer; transition:color .15s,background .15s; }
.fnav-links a:hover { color:var(--ink); background:#fff; }
.fnav-links a.active { color:var(--accent); background:var(--accent-weak); }
.fnav-right { display:flex; align-items:center; gap:12px; }
.flang { display:flex; align-items:center; gap:6px; font-size:12.5px; color:var(--ink-muted); }
.flang a { cursor:pointer; } .flang a.on { color:var(--ink); font-weight:600; }

/* sections */
.section { padding:88px 0; }
.section.tight { padding:64px 0; }
.section.alt { background:#fff; border-top:1px solid var(--line-light); border-bottom:1px solid var(--line-light); }
.shead { max-width:680px; margin:0 0 44px; }
.shead.center { margin-left:auto; margin-right:auto; text-align:center; }
h1 { font-size:clamp(32px,4.2vw,50px); }
h2 { font-size:clamp(26px,3vw,36px); }
.lede { color:var(--ink-muted); font-size:18px; line-height:1.55; margin:18px 0 0; }

/* hero */
.fhero { padding:72px 0 84px; background:radial-gradient(1100px 460px at 12% -8%,rgba(59,130,246,.10),transparent 60%),radial-gradient(820px 460px at 100% 0%,rgba(48,209,88,.10),transparent 55%); }
.fhero-grid { display:grid; grid-template-columns:1.04fr .96fr; gap:54px; align-items:center; }
.fhero h1 { margin-bottom:20px; }
.fhero-actions { display:flex; gap:13px; margin-top:30px; flex-wrap:wrap; }
.trust { display:flex; align-items:center; gap:8px; color:var(--ink-muted); font-size:13px; margin-top:24px; flex-wrap:wrap; }

/* snapshot preview card */
.snap { background:#fff; border:1px solid var(--line-light); border-radius:var(--radius-lg); box-shadow:0 30px 70px rgba(15,23,42,.12); overflow:hidden; }
.snap__head { display:flex; align-items:center; justify-content:space-between; padding:16px 20px; border-bottom:1px solid var(--line-light); background:var(--paper-soft); }
.snap__head b { font-family:var(--font-sans); font-size:13px; font-weight:700; color:var(--ink); }
.snap__demo { font:600 9.5px/1 var(--font-mono); letter-spacing:.08em; text-transform:uppercase; color:#fff; background:var(--ink-muted); padding:4px 7px; border-radius:5px; }
.snap__loc { padding:14px 20px 8px; font-size:13px; color:var(--ink-muted); display:flex; align-items:center; gap:7px; }
.snap__grid { display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--line-light); border-top:1px solid var(--line-light); }
.snap__cell { background:#fff; padding:14px 20px; }
.snap__cell .l { font:600 9.5px/1.3 var(--font-sans); letter-spacing:.07em; text-transform:uppercase; color:var(--ink-muted); }
.snap__cell .v { margin-top:5px; font:600 21px/1 var(--font-mono); font-variant-numeric:tabular-nums; color:var(--ink); }
.snap__cell .v.sp { color:#16894a; }
.snap__foot { padding:13px 20px; border-top:1px solid var(--line-light); display:flex; align-items:center; justify-content:space-between; gap:10px; }
.snap__foot .step { font-size:13px; color:var(--ink); font-weight:600; }
.snap__foot .step span { color:var(--ink-muted); font-weight:400; }

/* question chips */
.qgrid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.qcard { background:#fff; border:1px solid var(--line-light); border-radius:var(--radius-card); padding:22px; display:flex; gap:14px; align-items:flex-start; }
.qcard .n { font:600 13px/1 var(--font-mono); color:var(--accent); border:1px solid var(--accent-weak); background:var(--accent-weak); border-radius:7px; padding:7px 9px; flex:none; }
.qcard p { margin:0; font-size:15.5px; color:var(--ink); font-weight:500; line-height:1.5; }

/* three steps */
.fsteps { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.fstep { background:#fff; border:1px solid var(--line-light); border-radius:var(--radius-card); padding:26px; }
.fstep .no { font:600 13px var(--font-mono); color:var(--accent); }
.fstep .rule { height:1px; background:var(--line-light); margin:14px 0; }
.fstep h3 { font-size:19px; margin-bottom:9px; }
.fstep p { color:var(--ink-muted); font-size:14.5px; margin:0; line-height:1.6; }

/* outputs grid */
.outs { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.out { background:#fff; border:1px solid var(--line-light); border-radius:12px; padding:18px; }
.out .l { font:600 10px/1.3 var(--font-sans); letter-spacing:.06em; text-transform:uppercase; color:var(--ink-muted); }
.out .v { margin-top:8px; font-family:var(--font-serif); font-size:17px; font-weight:600; color:var(--ink); }
.out small { display:block; margin-top:8px; color:var(--ink-muted); font-size:11.5px; line-height:1.45; }

/* scenarios */
.scens { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
.scen { background:#fff; border:1px solid var(--line-light); border-radius:var(--radius-card); padding:24px; }
.scen .tag { font:600 11px var(--font-mono); letter-spacing:.04em; color:var(--accent); text-transform:uppercase; }
.scen h3 { font-size:18px; margin:10px 0 8px; }
.scen p { margin:0; color:var(--ink-muted); font-size:14.5px; line-height:1.6; }

/* trust boundary */
.bound { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.bcard { background:var(--paper-soft); border:1px solid var(--line-light); border-radius:var(--radius-card); padding:22px; }
.bcard strong { display:block; font-family:var(--font-serif); font-size:17px; margin-bottom:7px; color:var(--ink); }
.bcard span { color:var(--ink-muted); font-size:14px; line-height:1.55; }

/* disclaimer */
.disclaimer { color:var(--ink-muted); font-size:12.5px; line-height:1.6; max-width:880px; }

/* ===================== ASSESSMENT WIZARD ===================== */
.wizard-overlay { position:fixed; inset:0; z-index:100; background:rgba(11,18,32,.55); backdrop-filter:blur(4px); display:flex; align-items:flex-start; justify-content:center; padding:40px 20px; overflow-y:auto; }
.wizard { background:#fff; border-radius:var(--radius-lg); width:100%; max-width:680px; box-shadow:0 40px 100px rgba(0,0,0,.4); overflow:hidden; }
.wiz-head { display:flex; align-items:center; justify-content:space-between; padding:18px 24px; border-bottom:1px solid var(--line-light); }
.wiz-head b { font-family:var(--font-sans); font-size:14px; font-weight:700; }
.wiz-close { width:32px; height:32px; border:1px solid var(--line-light); border-radius:8px; background:#fff; cursor:pointer; color:var(--ink-muted); display:flex; align-items:center; justify-content:center; }
.wiz-close:hover { color:var(--ink); border-color:var(--ink-muted); }
.wiz-prog { display:flex; gap:5px; padding:14px 24px 0; }
.wiz-prog .seg { flex:1; height:4px; border-radius:3px; background:var(--line-light); }
.wiz-prog .seg.on { background:var(--accent); }
.wiz-body { padding:22px 24px 26px; }
.wiz-step-tag { font:600 11px var(--font-mono); letter-spacing:.08em; text-transform:uppercase; color:var(--accent); }
.wiz-body h3 { font-size:23px; margin:8px 0 4px; }
.wiz-body .sub { color:var(--ink-muted); font-size:14.5px; margin:0 0 20px; }
.field { display:block; margin-bottom:16px; }
.field > label { display:block; font:600 11px/1.3 var(--font-sans); letter-spacing:.04em; text-transform:uppercase; color:var(--ink-muted); margin-bottom:7px; }
.field input, .field select { width:100%; border:1px solid var(--line-light); border-radius:9px; background:#fff; color:var(--ink); font:500 15px/1.4 var(--font-sans); padding:12px 13px; outline:none; }
.field input:focus, .field select:focus { border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-weak); }
.row2 { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.opts { display:grid; gap:10px; }
.opts.two { grid-template-columns:1fr 1fr; }
.opt { border:1px solid var(--line-light); border-radius:10px; padding:13px 15px; cursor:pointer; font-size:14.5px; color:var(--ink); display:flex; align-items:center; gap:10px; transition:border-color .15s,background .15s; }
.opt:hover { border-color:var(--accent); }
.opt.on { border-color:var(--accent); background:var(--accent-weak); }
.opt .tick { width:18px; height:18px; border-radius:5px; border:1px solid var(--line-light); flex:none; display:flex; align-items:center; justify-content:center; color:#fff; font-size:11px; }
.opt.on .tick { background:var(--accent); border-color:var(--accent); }
.opt .ttl { font-weight:600; } .opt .desc { color:var(--ink-muted); font-size:12.5px; }
.map-sim { height:150px; border-radius:10px; border:1px solid var(--line-light); background:linear-gradient(135deg,#eef2f7 0 25%,#e5ebf3 25% 50%,#f4f6fa 50% 75%,#e8eef6 75%); position:relative; overflow:hidden; margin-bottom:6px; }
.map-sim::before { content:""; position:absolute; inset:30px 60px; border:2px dashed var(--accent); border-radius:6px; background:rgba(59,130,246,.08); }
.map-sim .pin { position:absolute; left:50%; top:50%; transform:translate(-50%,-100%); font-size:22px; }

/* interactive roof polygon map */
.roofmap { position:relative; border-radius:10px; overflow:hidden; border:1px solid var(--line-light); margin-bottom:10px;
  background:linear-gradient(135deg,#e8eef5 0 25%,#e0e8f1 25% 50%,#eef2f7 50% 75%,#e4ecf5 75%); }
.roofmap svg { display:block; width:100%; height:auto; cursor:crosshair; touch-action:none; }
.roofmap .rm-hint { position:absolute; left:12px; top:12px; font:600 11px/1.4 var(--font-sans); color:var(--ink-muted); background:rgba(255,255,255,.85); padding:5px 9px; border-radius:6px; pointer-events:none; }
.roofmap .rm-area { position:absolute; right:12px; bottom:12px; font:600 13px/1 var(--font-mono); color:var(--accent); background:rgba(255,255,255,.92); padding:7px 10px; border-radius:6px; pointer-events:none; }
.rm-tools { display:flex; align-items:center; gap:10px; margin-bottom:14px; }
.rm-tools button { border:1px solid var(--line-light); background:#fff; border-radius:8px; padding:7px 12px; font:600 12.5px/1 var(--font-sans); color:var(--ink-muted); cursor:pointer; }
.rm-tools button:hover { border-color:var(--accent); color:var(--accent); }
.rm-tools .hint { font-size:12px; color:var(--ink-muted); }
.wiz-foot { display:flex; align-items:center; justify-content:space-between; padding:18px 24px; border-top:1px solid var(--line-light); background:var(--paper-soft); }
.wiz-foot .back { font-size:14px; color:var(--ink-muted); cursor:pointer; background:none; border:none; }
.wiz-foot .back:hover { color:var(--ink); }

/* result */
.result-score { display:flex; align-items:center; gap:22px; padding:4px 0 20px; border-bottom:1px solid var(--line-light); margin-bottom:20px; }
.ring { width:104px; height:104px; border-radius:50%; display:grid; place-items:center; flex:none; position:relative; }
.ring .rv { position:relative; font:600 30px/1 var(--font-mono); color:var(--ink); }
.ring .rv small { font-size:13px; color:var(--ink-muted); }
.result-score .lead h4 { font-size:20px; margin:0 0 4px; }
.result-score .lead p { margin:0; color:var(--ink-muted); font-size:14px; }
.result-grid { display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--line-light); border:1px solid var(--line-light); border-radius:12px; overflow:hidden; }
.rcell { background:#fff; padding:14px 16px; }
.rcell .l { font:600 9.5px/1.3 var(--font-sans); letter-spacing:.06em; text-transform:uppercase; color:var(--ink-muted); }
.rcell .v { margin-top:6px; font:600 19px/1.1 var(--font-mono); font-variant-numeric:tabular-nums; color:var(--ink); }
.rcell .v.sp { color:#16894a; }
.result-risks { margin:18px 0; display:flex; flex-wrap:wrap; gap:8px; }
.rpill { display:inline-flex; align-items:center; gap:7px; font:600 11.5px/1 var(--font-sans); padding:7px 11px; border-radius:999px; border:1px solid var(--line-light); color:var(--ink-muted); }
.rpill::before { content:""; width:7px; height:7px; border-radius:50%; background:var(--warn-on-paper); }

/* ===================== LIVE HERO ESTIMATOR ===================== */
.estimator { background:#fff; border:1px solid var(--line-light); border-radius:var(--radius-lg); box-shadow:0 30px 70px rgba(15,23,42,.12); overflow:hidden; }
.est-head { display:flex; align-items:center; justify-content:space-between; padding:16px 22px; border-bottom:1px solid var(--line-light); background:var(--paper-soft); }
.est-head b { font-family:var(--font-sans); font-size:14px; font-weight:700; color:var(--ink); }
.est-head .live { display:inline-flex; align-items:center; gap:6px; font:600 10px/1 var(--font-mono); letter-spacing:.06em; text-transform:uppercase; color:#16894a; }
.est-head .live::before { content:""; width:7px; height:7px; border-radius:50%; background:#30D158; box-shadow:0 0 0 3px rgba(48,209,88,.18); }
.est-body { padding:20px 22px 8px; }
.est-ctrl { margin-bottom:18px; }
.est-ctrl .top { display:flex; align-items:baseline; justify-content:space-between; margin-bottom:9px; }
.est-ctrl .lab { font:600 12px/1 var(--font-sans); color:var(--ink); }
.est-ctrl .val { font:600 16px/1 var(--font-mono); font-variant-numeric:tabular-nums; color:var(--accent); }
input[type=range].slider { -webkit-appearance:none; appearance:none; width:100%; height:6px; border-radius:999px; background:linear-gradient(90deg,var(--accent) var(--pct,50%),var(--line-light) var(--pct,50%)); outline:none; cursor:pointer; }
input[type=range].slider::-webkit-slider-thumb { -webkit-appearance:none; appearance:none; width:20px; height:20px; border-radius:50%; background:#fff; border:2px solid var(--accent); box-shadow:0 2px 8px rgba(59,130,246,.35); cursor:pointer; }
input[type=range].slider::-moz-range-thumb { width:18px; height:18px; border-radius:50%; background:#fff; border:2px solid var(--accent); box-shadow:0 2px 8px rgba(59,130,246,.35); cursor:pointer; }
.est-seg { display:flex; gap:8px; }
.est-seg button { flex:1; border:1px solid var(--line-light); background:#fff; border-radius:9px; padding:10px; font:600 13px/1 var(--font-sans); color:var(--ink-muted); cursor:pointer; transition:all .15s; }
.est-seg button.on { border-color:var(--accent); background:var(--accent-weak); color:var(--accent); }
.rooffill { margin-top:4px; }
.rooffill .track { height:14px; border-radius:7px; background:repeating-linear-gradient(135deg,#eef2f7 0 7px,#e7edf4 7px 14px); border:1px solid var(--line-light); overflow:hidden; position:relative; }
.rooffill .fill { height:100%; background:linear-gradient(90deg,var(--accent),#2563eb); border-radius:7px 0 0 7px; transition:width .35s var(--ease); }
.rooffill .cap { display:flex; justify-content:space-between; margin-top:7px; font:500 11px/1.4 var(--font-sans); color:var(--ink-muted); }
.est-readout { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line-light); border-top:1px solid var(--line-light); }
.est-readout .r { background:#fff; padding:14px 16px; }
.est-readout .r .l { font:600 9px/1.3 var(--font-sans); letter-spacing:.06em; text-transform:uppercase; color:var(--ink-muted); }
.est-readout .r .v { margin-top:5px; font:600 18px/1 var(--font-mono); font-variant-numeric:tabular-nums; color:var(--ink); }
.est-save { padding:18px 22px; background:linear-gradient(180deg,#f0f9f2,#eaf6ee); border-top:1px solid #d6ebdd; display:flex; align-items:center; justify-content:space-between; gap:12px; }
.est-save .l { font:600 11px/1.3 var(--font-sans); letter-spacing:.04em; text-transform:uppercase; color:#16894a; }
.est-save .v { font:700 30px/1 var(--font-mono); font-variant-numeric:tabular-nums; color:#13733f; letter-spacing:-.01em; }
.est-save .v small { font-size:14px; font-weight:600; color:#16894a; }
.est-foot { padding:14px 22px 18px; }
.est-foot .note { margin:10px 0 0; font-size:11px; color:var(--ink-muted); line-height:1.5; }

/* ===================== SPLIT WIZARD ===================== */
.wizard.wide { max-width:880px; }
.wiz-split { display:grid; grid-template-columns:1fr .82fr; }
.wiz-main { padding:22px 24px 0; }
.wiz-aside { background:var(--paper-soft); border-left:1px solid var(--line-light); padding:22px 22px 24px; }
.wiz-aside .tag { font:600 10px/1 var(--font-mono); letter-spacing:.08em; text-transform:uppercase; color:#16894a; display:flex; align-items:center; gap:6px; }
.wiz-aside .tag::before { content:""; width:6px; height:6px; border-radius:50%; background:#30D158; }
.wiz-aside h5 { font-family:var(--font-serif); font-size:16px; font-weight:600; margin:8px 0 14px; color:var(--ink); }
.mini-grid { display:grid; gap:1px; background:var(--line-light); border:1px solid var(--line-light); border-radius:10px; overflow:hidden; }
.mini-grid .m { background:#fff; padding:11px 13px; display:flex; align-items:center; justify-content:space-between; gap:8px; }
.mini-grid .m .l { font:600 10.5px/1.2 var(--font-sans); color:var(--ink-muted); }
.mini-grid .m .v { font:600 15px/1 var(--font-mono); font-variant-numeric:tabular-nums; color:var(--ink); }
.mini-grid .m .v.sp { color:#16894a; }
.mini-ring { display:flex; align-items:center; gap:14px; margin-bottom:16px; }
.mini-ring .ring { width:72px; height:72px; }
.mini-ring .ring .rv { font-size:22px; } .mini-ring .ring .rv small { font-size:10px; }
.mini-ring .lab { font:600 12px/1.4 var(--font-sans); color:var(--ink); }
.mini-ring .lab span { display:block; font-weight:400; color:var(--ink-muted); font-size:11px; }

/* ===================== REGION KNOWLEDGE BASE / RISK RADAR ===================== */
.kb-toolbar { display:flex; align-items:center; justify-content:space-between; gap:16px; margin-bottom:30px; flex-wrap:wrap; }
.kb-toggle { display:inline-flex; background:#fff; border:1px solid var(--line-light); border-radius:11px; padding:4px; gap:4px; }
.kb-toggle button { border:none; background:none; padding:10px 18px; border-radius:8px; font:600 14px/1 var(--font-sans); color:var(--ink-muted); cursor:pointer; display:flex; align-items:center; gap:8px; transition:all .15s; }
.kb-toggle button .flag { font-size:16px; }
.kb-toggle button.on { background:var(--accent); color:#fff; }
.kb-note { font-size:12.5px; color:var(--ink-muted); max-width:360px; }
.kb-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.kb-card { background:#fff; border:1px solid var(--line-light); border-radius:var(--radius-card); padding:22px; cursor:pointer; transition:border-color .15s, transform .15s, box-shadow .15s; display:flex; flex-direction:column; gap:11px; text-align:left; }
.kb-card:hover { border-color:var(--accent); transform:translateY(-2px); box-shadow:0 18px 40px rgba(15,23,42,.10); }
.kb-card .cat { display:flex; align-items:center; justify-content:space-between; gap:10px; }
.kb-card .cat .c { font:600 10px/1 var(--font-mono); letter-spacing:.07em; text-transform:uppercase; color:var(--accent); }
.kb-card h3 { font-size:16.5px; line-height:1.35; }
.kb-card p { margin:0; color:var(--ink-muted); font-size:13.5px; line-height:1.55; }
.kb-card .more { margin-top:auto; padding-top:4px; font:600 13px var(--font-sans); color:var(--accent); display:flex; align-items:center; gap:6px; }
.kb-card .more svg { width:15px; height:15px; }
.kb-rel { font:600 9.5px/1 var(--font-sans); letter-spacing:.05em; text-transform:uppercase; padding:5px 9px; border-radius:999px; white-space:nowrap; }
.kb-rel.High { color:var(--risk-on-paper); background:rgba(220,38,38,.08); }
.kb-rel.Medium { color:var(--warn-on-paper); background:rgba(217,119,6,.10); }
.kb-rel.Low { color:#16894a; background:rgba(22,137,74,.10); }

/* article reading panel */
.article { background:#fff; border-radius:var(--radius-lg); width:100%; max-width:680px; box-shadow:0 40px 100px rgba(0,0,0,.4); overflow:hidden; }
.article-head { padding:22px 26px 18px; border-bottom:1px solid var(--line-light); display:flex; justify-content:space-between; align-items:flex-start; gap:16px; }
.article-head .c { font:600 10px/1 var(--font-mono); letter-spacing:.08em; text-transform:uppercase; color:var(--accent); }
.article-head h3 { font-size:23px; margin-top:9px; line-height:1.25; }
.article-head .meta { display:flex; align-items:center; gap:9px; margin-top:11px; }
.article-body { padding:4px 26px 12px; max-height:56vh; overflow-y:auto; }
.article-sec { padding:16px 0; border-top:1px solid var(--line-light); }
.article-sec:first-child { border-top:none; }
.article-sec h4 { font:600 11px/1 var(--font-sans); letter-spacing:.06em; text-transform:uppercase; color:var(--ink-muted); margin-bottom:9px; }
.article-sec p { margin:0; font-size:14.5px; line-height:1.66; color:var(--ink); }
.article-sec.help { background:var(--accent-weak); margin:8px -26px 0; padding:16px 26px; border-top:none; }
.article-sec.help h4 { color:var(--accent); }
.article-foot { padding:16px 26px; border-top:1px solid var(--line-light); background:var(--paper-soft); display:flex; align-items:center; justify-content:space-between; gap:14px; }
.article-src { font-size:11.5px; color:var(--ink-muted); line-height:1.5; }

@media(max-width:960px){
  .fnav-links { display:none; }
  .fhero-grid { grid-template-columns:1fr; gap:40px; }
  .qgrid,.fsteps,.outs,.kb-grid { grid-template-columns:1fr; }
  .scens,.bound,.result-grid,.snap__grid,.est-readout { grid-template-columns:1fr; }
  .wiz-split { grid-template-columns:1fr; }
  .wiz-aside { border-left:0; border-top:1px solid var(--line-light); }
}

/* ===================== CONTENT PAGES (solutions / radar / report / contact) ===================== */
.fnav-links a[aria-current="page"] { color:var(--accent); background:var(--accent-weak); }
.page-hero { padding:54px 0 8px; }
.crumb { display:flex; align-items:center; gap:8px; font:600 12px/1 var(--font-mono); letter-spacing:.04em; color:var(--ink-muted); margin-bottom:18px; flex-wrap:wrap; }
.crumb a { color:var(--accent); }
.crumb .sep { opacity:.5; }
.page-hero h1 { font-size:clamp(30px,3.8vw,46px); max-width:18ch; }
.page-hero .lede { max-width:680px; }
.page-actions { display:flex; gap:13px; margin-top:28px; flex-wrap:wrap; }

.prose { max-width:760px; }
.prose p { color:var(--ink-muted); font-size:16px; line-height:1.7; margin:0 0 16px; }
.prose strong { color:var(--ink); }

.feature-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.feature-grid.two { grid-template-columns:repeat(2,1fr); }
.feature { background:#fff; border:1px solid var(--line-light); border-radius:var(--radius-card); padding:24px; }
.feature .ic { width:38px; height:38px; border-radius:10px; background:var(--accent-weak); color:var(--accent); display:flex; align-items:center; justify-content:center; margin-bottom:14px; }
.feature .ic.green { background:rgba(48,209,88,.12); color:#16894a; }
.feature h3 { font-size:18px; margin-bottom:8px; }
.feature p { margin:0; color:var(--ink-muted); font-size:14.5px; line-height:1.6; }

.checklist { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:12px; }
.checklist li { display:flex; gap:12px; align-items:flex-start; font-size:15.5px; color:var(--ink); line-height:1.55; }
.checklist li::before { content:""; width:20px; height:20px; border-radius:6px; background:var(--accent-weak); flex:none; margin-top:1px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%233B82F6' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12l4 4 10-10'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:center; }
.checklist.warn li::before { background:rgba(217,119,6,.12);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23D97706' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 9v4M12 17h.01M10.3 3.9 1.8 18a2 2 0 0 0 1.7 3h17a2 2 0 0 0 1.7-3L13.7 3.9a2 2 0 0 0-3.4 0Z'/%3E%3C/svg%3E"); }

.cta-band { background:linear-gradient(180deg,#eef4ff,#e8f0fe); border-top:1px solid var(--line-light); border-bottom:1px solid var(--line-light); }
.cta-band .inner { text-align:center; max-width:720px; margin:0 auto; }
.cta-band h2 { margin-bottom:14px; }

/* lead capture form */
.leadform { background:#fff; border:1px solid var(--line-light); border-radius:var(--radius-lg); box-shadow:0 24px 60px rgba(15,23,42,.10); overflow:hidden; }
.leadform .lf-head { padding:22px 26px; border-bottom:1px solid var(--line-light); background:var(--paper-soft); }
.leadform .lf-head h3 { font-size:21px; margin-bottom:4px; }
.leadform .lf-head p { margin:0; color:var(--ink-muted); font-size:14px; }
.leadform .lf-body { padding:24px 26px; }
.lf-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.lf-grid .full { grid-column:1 / -1; }
.consent { display:flex; gap:11px; align-items:flex-start; padding:13px 14px; border:1px solid var(--line-light); border-radius:10px; cursor:pointer; font-size:13.5px; color:var(--ink); line-height:1.5; transition:border-color .15s,background .15s; }
.consent:hover { border-color:var(--accent); }
.consent input { margin:0; width:18px; height:18px; flex:none; margin-top:1px; accent-color:var(--accent); }
.consent.required { background:var(--paper-soft); }
.consent .opt { color:var(--ink-muted); font-weight:400; }
.leadform .lf-foot { padding:18px 26px; border-top:1px solid var(--line-light); background:var(--paper-soft); display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap; }

/* dual entry block (also used on institutional site link) */
.dual { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.dual .d { border:1px solid var(--line-light); border-radius:var(--radius-card); padding:28px; background:#fff; display:flex; flex-direction:column; }
.dual .d.factory { border-color:rgba(48,209,88,.4); background:linear-gradient(180deg,#f3fbf5,#fff); }
.dual .d .lab { font:600 11px/1 var(--font-mono); letter-spacing:.08em; text-transform:uppercase; color:var(--accent); margin-bottom:10px; }
.dual .d.factory .lab { color:#16894a; }
.dual .d h3 { font-size:21px; margin-bottom:8px; }
.dual .d p { margin:0 0 18px; color:var(--ink-muted); font-size:14.5px; line-height:1.6; }
.dual .d .btn { margin-top:auto; align-self:flex-start; }

/* sample report — paper document */
.doc-toc { display:grid; grid-template-columns:repeat(2,1fr); gap:8px 28px; }
.doc-toc .t { display:flex; align-items:baseline; justify-content:space-between; gap:10px; padding:9px 0; border-bottom:1px solid var(--line-light); font-size:14px; color:var(--ink); }
.doc-toc .t span { font:600 11px var(--font-mono); color:var(--ink-muted); }
.doc-pages { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.doc-sheet { background:#fff; border:1px solid var(--line-light); border-radius:8px; box-shadow:0 18px 50px rgba(15,23,42,.12); padding:22px; min-height:380px; display:flex; flex-direction:column; }
.doc-sheet .dh { display:flex; justify-content:space-between; font:600 9px/1.3 var(--font-sans); letter-spacing:.1em; text-transform:uppercase; color:var(--ink-muted); border-bottom:1px solid var(--line-light); padding-bottom:11px; }
.doc-sheet h4 { font:600 19px/1.15 var(--font-serif); color:var(--ink); margin:15px 0 12px; letter-spacing:-.01em; }
.doc-sheet .dgrid { display:grid; grid-template-columns:1fr 1fr; gap:9px; }
.doc-sheet .dc { border:1px solid var(--line-light); border-radius:5px; padding:9px 11px; }
.doc-sheet .dc .l { font:600 8.5px/1.2 var(--font-sans); letter-spacing:.06em; text-transform:uppercase; color:var(--ink-muted); }
.doc-sheet .dc .v { margin-top:4px; font:600 15px/1 var(--font-mono); color:var(--ink); }
.doc-sheet .dc .v.sp { color:#16894a; }
.doc-sheet .dsrc { margin-top:auto; padding-top:12px; border-top:1px solid var(--line-light); font:500 10px/1.5 var(--font-sans); color:var(--ink-muted); }
.doc-roof { height:96px; border:1px solid var(--line-light); border-radius:6px; margin:4px 0 12px; background:repeating-linear-gradient(135deg,#eef2f7 0 8px,#e7edf4 8px 16px); position:relative; }
.doc-roof::before { content:""; position:absolute; inset:14px 22px; border:1px dashed var(--accent); border-radius:4px; background:rgba(59,130,246,.07); }

/* risk radar article accordion */
.radar-cat { margin-bottom:14px; }
.radar-cat > summary { list-style:none; cursor:pointer; background:#fff; border:1px solid var(--line-light); border-radius:var(--radius-card); padding:20px 22px; display:flex; align-items:center; justify-content:space-between; gap:14px; transition:border-color .15s; }
.radar-cat > summary::-webkit-details-marker { display:none; }
.radar-cat[open] > summary { border-color:var(--accent); border-radius:var(--radius-card) var(--radius-card) 0 0; }
.radar-cat > summary:hover { border-color:var(--accent); }
.radar-cat .rc-l .c { font:600 10px/1 var(--font-mono); letter-spacing:.07em; text-transform:uppercase; color:var(--accent); }
.radar-cat .rc-l h3 { font-size:18px; margin-top:7px; }
.radar-cat .rc-r { display:flex; align-items:center; gap:12px; flex:none; }
.radar-cat .chev { width:20px; height:20px; color:var(--ink-muted); transition:transform .2s; }
.radar-cat[open] .chev { transform:rotate(180deg); }
.radar-body { border:1px solid var(--accent); border-top:none; border-radius:0 0 var(--radius-card) var(--radius-card); background:#fff; padding:4px 22px 18px; }
.radar-body .rs { padding:15px 0; border-top:1px solid var(--line-light); }
.radar-body .rs:first-child { border-top:none; }
.radar-body .rs h4 { font:600 11px/1 var(--font-sans); letter-spacing:.06em; text-transform:uppercase; color:var(--ink-muted); margin-bottom:8px; }
.radar-body .rs p { margin:0; font-size:14.5px; line-height:1.65; color:var(--ink); }
.radar-body .rsrc { margin-top:8px; font-size:11.5px; color:var(--ink-muted); }

@media(max-width:960px){
  .feature-grid, .feature-grid.two, .lf-grid, .dual, .doc-pages, .doc-toc { grid-template-columns:1fr; }
}

/* ===================== MOBILE NAV (hamburger) — added for factory.joule.vn ===================== */
.fnav-inner { position:relative; }
.fnav-toggle { display:none; flex-direction:column; gap:4px; width:40px; height:40px; align-items:center; justify-content:center; background:#fff; border:1px solid var(--line-light); border-radius:9px; cursor:pointer; flex:none; }
.fnav-toggle span { width:18px; height:2px; background:var(--ink); border-radius:2px; transition:transform .2s, opacity .2s; }
.fnav-toggle.open span:nth-child(1){ transform:translateY(6px) rotate(45deg); }
.fnav-toggle.open span:nth-child(2){ opacity:0; }
.fnav-toggle.open span:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }

@media(max-width:960px){
  .fnav-inner { gap:12px; }
  .fbrand { order:1; margin-right:auto; }        /* brand left, push lang + burger to the right */
  .fnav-toggle { display:flex; order:3; margin-left:4px; }
  .fnav-right { order:2; gap:10px; margin-left:auto; }  /* right-align 中/VN/EN + burger */
  .fnav-right .btn { display:none; }            /* CTA repeated in-page; save top-bar room */
  .fbrand .nm span { display:none; }            /* drop subtitle on small screens */
  .fnav-links { display:none; position:absolute; top:64px; left:0; right:0; flex-direction:column; gap:0; margin:0; padding:8px 18px 14px;
    background:#fff; border-bottom:1px solid var(--line-light); box-shadow:0 18px 40px rgba(15,23,42,.10); z-index:60; }
  .fnav-links.open { display:flex; }
  .fnav-links a { padding:13px 8px; font-size:15.5px; border-bottom:1px solid var(--line-light); border-radius:0; }
  .fnav-links a:last-child { border-bottom:0; }
}
@media(max-width:420px){
  .flang { font-size:12px; gap:5px; }
  .fbrand .nm b { font-size:13.5px; }
}

/* estimator country selector (VN / TW) */
.est-head { flex-wrap:wrap; gap:8px; }
.est-region { display:inline-flex; gap:4px; background:var(--paper-soft); border:1px solid var(--line-light); border-radius:999px; padding:3px; }
.est-region button { display:inline-flex; align-items:center; gap:5px; border:0; background:transparent; cursor:pointer; font:600 12px/1 var(--font-sans); color:var(--ink-muted); padding:6px 11px; border-radius:999px; transition:background .15s,color .15s; }
.est-region button .flag { font-size:13px; }
.est-region button.on { background:#fff; color:var(--ink); box-shadow:0 1px 3px rgba(15,23,42,.12); }
