/* NutraSafe per-additive + hub page components. Loaded AFTER design.css.
   Everything is scoped under .nx so it never collides with design.css. Brand
   tokens (--cream, --ink, --yellow-pop, --indigo, --coral, --sage, ...) come
   from design.css :root. */

.nx{max-width:780px;margin:0 auto;padding:0 22px;font-family:var(--display);color:var(--ink)}
.nx h1{font-size:clamp(38px,8vw,62px);line-height:1;font-weight:800;letter-spacing:-.02em;margin:14px 0 6px}
.nx h2{font-size:26px;font-weight:800;letter-spacing:-.01em;margin-bottom:12px}
.nx p{font-size:18px;line-height:1.55;margin-bottom:12px;color:var(--ink)}
.nx a{color:var(--indigo)}

/* hero */
.nx .ehero{padding:34px 0 8px}
.nx .eyebrow{font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft);display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.nx .ecode{background:var(--ink);color:var(--yellow-pop);padding:3px 9px;border-radius:6px;font-weight:700;font-family:var(--mono)}
.nx .aka{color:var(--ink-fade);font-size:15px;font-family:var(--mono);margin-top:4px}
.nx .chips{display:flex;flex-wrap:wrap;gap:7px;margin:18px 0 4px}
.nx .chip{font-size:13px;font-weight:600;padding:4px 11px;border-radius:20px;border:1.5px solid var(--ink);display:inline-flex;gap:6px;align-items:center}
.nx .chip.yes{background:var(--sage);color:var(--cream);border-color:var(--sage)}
.nx .chip.no{background:var(--coral);color:#fff;border-color:var(--coral-deep)}
.nx .chip.check{background:var(--yellow-pop)}
.nx .chip.cat{background:var(--ink);color:var(--cream)}

/* takeaway band */
.nx .takeaway{background:var(--ink);color:var(--cream);border-radius:20px;padding:26px 28px;margin:26px 0 8px}
.nx .takeaway .lab{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--yellow-pop);margin-bottom:8px}
.nx .takeaway p{font-size:21px;font-weight:600;line-height:1.4;color:var(--cream);margin:0}

/* concern callout */
.nx .warn{background:#FBE4DF;border:1.5px solid var(--coral-deep);border-left:6px solid var(--coral);border-radius:14px;padding:20px 22px;margin:28px 0}
.nx .warn .lab{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--coral-deep);font-weight:700;margin-bottom:6px}
.nx .warn p{margin:0}
.nx .warn b{font-weight:800}

/* sections */
.nx section{padding:26px 0;border-top:1.5px solid var(--rule)}
.nx section.first{border-top:none}
.nx section p.lead{font-size:20px}

/* key insights */
.nx .insights{display:grid;gap:12px;margin-top:8px}
.nx .ins{background:var(--surface);border:1.5px solid var(--ink);border-radius:16px;padding:18px 20px}
.nx .ins .yr{font-family:var(--mono);font-size:13px;font-weight:700;background:var(--yellow);padding:2px 9px;border-radius:6px;display:inline-block;margin-bottom:8px;color:var(--ink)}
.nx .ins .tag{font-family:var(--mono);font-size:11px;color:var(--ink-fade);text-transform:uppercase;letter-spacing:.06em;margin-left:8px}
.nx .ins p{margin:0;font-weight:500}
.nx .ins .src{font-size:13px;color:var(--ink-fade);margin-top:8px}

/* honest read */
.nx .honest{background:var(--sage-soft);border:1.5px solid var(--ink);border-radius:18px;padding:24px 26px;margin-top:8px}
.nx .honest .lab{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--sage);font-weight:700;margin-bottom:8px}
.nx .honest p:last-child{margin-bottom:0}

/* fact tiles */
.nx .facts{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:6px}
.nx .fact{border:1.5px solid var(--ink);border-radius:14px;padding:16px 18px;background:var(--butter)}
.nx .fact .k{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:5px}
.nx .fact .v{font-weight:600;font-size:16px;line-height:1.35}
@media(max-width:560px){.nx .facts{grid-template-columns:1fr}}

.nx details{border-top:1.5px solid var(--rule);margin-top:8px}
.nx summary{cursor:pointer;font-family:var(--mono);font-size:13px;font-weight:600;color:var(--indigo);padding:16px 0}
.nx details ul{margin:0 0 16px 20px;font-size:14px;color:var(--ink-soft);line-height:1.7}

/* in-page app CTA */
.nx .ecta{background:var(--yellow);border:2px solid var(--ink);border-radius:24px;padding:34px 30px;margin:36px 0;text-align:center;box-shadow:8px 8px 0 var(--ink)}
.nx .ecta h3{font-size:28px;font-weight:800;letter-spacing:-.01em;margin-bottom:8px}
.nx .ecta p{font-size:16px;margin-bottom:18px}
.nx .ecta .btn-ink{display:inline-block;background:var(--ink);color:var(--cream);font-weight:700;font-size:16px;padding:14px 26px;border-radius:40px}
.nx .ecta .subnote{font-size:13px;color:var(--ink-soft);margin-top:12px;font-family:var(--mono)}
.nx .related{font-family:var(--mono);font-size:13px;color:var(--ink-fade);margin-top:14px}
.nx .related a{margin-right:14px}

/* ===== authority template: science by concern ===== */
.nx .sci{margin:18px 0 22px}
.nx .sci h3{font-size:20px;font-weight:800;letter-spacing:-.01em;margin:0 0 8px}
.nx .sci .sciplain{font-size:18px;color:var(--ink);margin:0 0 14px}
.nx .finds{display:grid;gap:10px}
.nx .find{background:var(--surface);border:1.5px solid var(--ink);border-left:5px solid var(--indigo);border-radius:12px;padding:14px 16px}
.nx .find p{font-size:16px;font-weight:500;margin:0 0 8px;line-height:1.5}
.nx .find .fmeta{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.nx .find .fsrc{font-size:13px;color:var(--ink-soft);font-weight:600}
.nx .find .fyr{font-family:var(--mono);font-size:11px;font-weight:700;background:var(--yellow);color:var(--ink);padding:1px 7px;border-radius:5px}
.nx .find .fstr{font-family:var(--mono);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:var(--ink);color:var(--cream);padding:2px 8px;border-radius:5px}

/* ===== authority template: regulatory box ===== */
.nx .regbox{border:1.5px solid var(--ink);border-radius:16px;overflow:hidden;background:var(--butter)}
.nx .regrow{display:grid;grid-template-columns:160px 1fr;gap:16px;padding:14px 18px;border-top:1.5px solid var(--rule)}
.nx .regrow:first-child{border-top:none}
.nx .regrow .rk{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);font-weight:700;padding-top:2px}
.nx .regrow .rv{font-size:16px;line-height:1.45;font-weight:500}
@media(max-width:560px){.nx .regrow{grid-template-columns:1fr;gap:4px}}

/* ===== authority template: FAQ ===== */
.nx .faq{display:grid;gap:0;border:1.5px solid var(--ink);border-left:5px solid var(--indigo);border-radius:16px;overflow:hidden;background:var(--surface)}
.nx details.qa{border-top:1.5px solid var(--rule);margin:0}
.nx details.qa:first-child{border-top:none}
.nx details.qa summary{font-family:var(--display);font-size:17px;font-weight:700;color:var(--ink);padding:16px 18px;list-style:none}
.nx details.qa summary::-webkit-details-marker{display:none}
.nx details.qa summary::after{content:"+";float:right;color:var(--indigo);font-weight:800;font-size:20px;line-height:1}
.nx details.qa[open]{background:rgba(51,64,224,.05)}
.nx details.qa[open] summary{color:var(--indigo)}
.nx details.qa[open] summary::after{content:"\2212"}
.nx details.qa p{font-size:16px;padding:0 18px 18px;margin:0;color:var(--ink-soft);line-height:1.55}
.nx .srclist{margin:0 0 14px 20px;font-size:14px;color:var(--ink-soft);line-height:1.8}
.nx .srclist a{color:var(--indigo);font-weight:600}

/* ===== hub ===== */
.nx .hub-hero{padding:40px 0 12px}
.nx .hub-lede{font-size:20px;color:var(--ink-soft);margin-top:10px;max-width:620px}
.nx #hubq{width:100%;padding:14px 18px;font-size:17px;font-family:var(--display);border:2px solid var(--ink);border-radius:14px;margin:22px 0 6px;background:#fff}
.nx .hubcount{font-family:var(--mono);font-size:13px;color:var(--ink-fade);margin-bottom:10px}
.nx .hubcount b{color:var(--coral-deep)}
/* sub-tabs as pills (no folder look, no rules) */
.nx .etabs{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0 30px}
.nx .etab{font-weight:700;font-size:15px;padding:10px 20px;border:2px solid var(--ink);border-radius:40px;background:var(--surface);cursor:pointer;color:var(--ink);transition:transform .12s,box-shadow .12s}
.nx .etab:hover{transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--ink)}
.nx .etab[aria-selected="true"]{background:var(--ink);color:var(--cream)}
.nx .etab[aria-selected="true"]:hover{box-shadow:4px 4px 0 var(--coral)}
/* category sections with numbered colour eyebrow */
.nx .catsec{margin:36px 0}
.nx .catsec h3{font-size:23px;font-weight:800;margin:0;display:flex;align-items:center;gap:11px;letter-spacing:-.01em}
.nx .cnum{font-family:var(--mono);font-size:14px;font-weight:700;padding:4px 10px;border-radius:8px}
.nx .catsec .csub{font-family:var(--mono);font-size:12px;color:var(--ink-fade);text-transform:uppercase;letter-spacing:.06em;margin:7px 0 14px}
/* per-category colour accents on the eyebrow number + card code chip */
.nx .catsec.colours .hc,.nx .catsec.colours .cnum{background:var(--coral);color:#fff}
.nx .catsec.preservatives .hc,.nx .catsec.preservatives .cnum{background:var(--indigo);color:#fff}
.nx .catsec.antioxidants .hc,.nx .catsec.antioxidants .cnum{background:var(--sage);color:#fff}
.nx .catsec.thickeners .hc,.nx .catsec.thickeners .cnum{background:var(--yellow);color:var(--ink)}
.nx .catsec.acidity .hc,.nx .catsec.acidity .cnum{background:var(--cobalt);color:#fff}
.nx .catsec.flavour .hc,.nx .catsec.flavour .cnum{background:var(--pink);color:var(--ink)}
.nx .catsec.glazing .hc,.nx .catsec.glazing .cnum{background:var(--marigold);color:var(--ink)}
.nx .catsec.other .hc,.nx .catsec.other .cnum{background:var(--ink);color:var(--cream)}
.nx .hub-hero h1 .dot{color:var(--coral)}
.nx .hub-cross{font-size:15px;margin-top:6px}
.nx .hub-cross a{font-weight:700}
.nx .hubgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:10px;padding-bottom:8px}
.nx .hubcard{border:1.5px solid var(--ink);border-radius:14px;padding:14px 16px;background:var(--surface);transition:transform .12s ease,box-shadow .12s ease;display:block}
.nx .hubcard:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--ink)}
.nx .hubcard .hc{font-family:var(--mono);font-weight:700;font-size:14px;background:var(--yellow);padding:1px 7px;border-radius:5px;color:var(--ink)}
.nx .hubcard .hn{font-weight:600;margin-top:7px;line-height:1.25;color:var(--ink)}
.nx .hubcard .hf{margin-top:7px;min-height:18px}
.nx .flag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:1px 6px;border-radius:8px}
.nx .flag.watch{background:var(--coral);color:#fff}
.nx .flag.notuk{background:var(--ink-fade);color:#fff}
.nx .noresults{font-family:var(--mono);font-size:14px;color:var(--ink-fade);padding:20px 0}
.nx .upd{font-family:var(--mono);font-size:12px;color:var(--ink-fade);margin:24px 0 8px}
