/* =========================================================
   {platform_name} — Investment Report / Annual Report
   Warm cream ground, deep ink, pine-green accent.
   Serif headlines (Newsreader) + Figtree body. Exhibit-style
   figures, ruled tables, "No. NN" section marks. Mobile-first.
   ========================================================= */

@font-face { font-family:"Newsreader"; font-weight:500; font-style:normal; font-display:swap; src:url("../fonts/newsreader-500.woff2") format("woff2"),url("../fonts/newsreader-500.woff") format("woff"); }
@font-face { font-family:"Newsreader"; font-weight:600; font-style:normal; font-display:swap; src:url("../fonts/newsreader-600.woff2") format("woff2"),url("../fonts/newsreader-600.woff") format("woff"); }
@font-face { font-family:"Newsreader"; font-weight:700; font-style:normal; font-display:swap; src:url("../fonts/newsreader-700.woff2") format("woff2"),url("../fonts/newsreader-700.woff") format("woff"); }
@font-face { font-family:"Figtree"; font-weight:400; font-style:normal; font-display:swap; src:url("../fonts/figtree-400.woff2") format("woff2"),url("../fonts/figtree-400.woff") format("woff"); }
@font-face { font-family:"Figtree"; font-weight:500; font-style:normal; font-display:swap; src:url("../fonts/figtree-500.woff2") format("woff2"),url("../fonts/figtree-500.woff") format("woff"); }
@font-face { font-family:"Figtree"; font-weight:600; font-style:normal; font-display:swap; src:url("../fonts/figtree-600.woff2") format("woff2"),url("../fonts/figtree-600.woff") format("woff"); }
@font-face { font-family:"Figtree"; font-weight:700; font-style:normal; font-display:swap; src:url("../fonts/figtree-700.woff2") format("woff2"),url("../fonts/figtree-700.woff") format("woff"); }

:root {
  --cream: #f4efe3;
  --cream-2: #ece5d4;
  --paper: #faf6ec;
  --ink: #20251f;
  --ink-2: #3c4439;
  --ink-soft: #5e6657;
  --ink-mute: #8a8f80;
  --rule: #cdc6b3;
  --rule-2: #b7b09b;
  --pine: #1f5135;
  --pine-2: #2c6b48;
  --pine-bright: #357a52;
  --gold: #9a7b32;
  --max: 1150px;
  --pad: 20px;
  --serif: "Newsreader", Georgia, "Times New Roman", serif;
  --sans: "Figtree", system-ui, -apple-system, "Segoe UI", sans-serif;
}

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0; background: var(--cream); color: var(--ink);
  font-family: var(--sans); font-size: 16px; line-height: 1.62;
  overflow-wrap: break-word; word-break: normal; -webkit-font-smoothing: antialiased;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
ul { margin: 0; padding: 0; list-style: none; }
button { font: inherit; cursor: pointer; }
:focus-visible { outline: 2px solid var(--pine); outline-offset: 3px; }

.wrap { width: 100%; max-width: var(--max); margin: 0 auto; padding-inline: var(--pad); }
.block { padding-block: 56px; border-top: 1px solid var(--rule); }
.block--paper { background: var(--paper); }
.block--pine { background: var(--pine); color: #eef1ea; border-top: 0; }

.mark-no { display: flex; align-items: baseline; gap: 12px; font-family: var(--serif); font-weight: 600; font-size: 0.86rem; letter-spacing: 0.04em; text-transform: uppercase; color: var(--pine); margin: 0 0 16px; }
.mark-no::after { content: ""; flex: 1; height: 1px; background: var(--rule-2); align-self: center; }
.mark-no b { color: var(--ink-mute); font-weight: 600; }
.h2 { font-family: var(--serif); font-weight: 700; font-size: clamp(1.7rem, 4.6vw, 2.5rem); line-height: 1.12; letter-spacing: -0.01em; margin: 0 0 14px; }
.sub { color: var(--ink-soft); max-width: 64ch; margin: 0; font-size: 1.02rem; }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: 9px; font-family: var(--sans); font-weight: 600; font-size: 0.94rem; padding: 13px 26px; border: 1.5px solid var(--pine); border-radius: 4px; transition: background .16s, color .16s; }
.btn--solid { background: var(--pine); color: #f4efe3; }
.btn--solid:hover { background: var(--pine-2); border-color: var(--pine-2); }
.btn--line { background: transparent; color: var(--pine); }
.btn--line:hover { background: var(--pine); color: #f4efe3; }
.btn--wide { width: 100%; }
.btn--onpine { border-color: #eef1ea; color: #eef1ea; background: transparent; }
.btn--onpine:hover { background: #eef1ea; color: var(--pine); }
.btn--onpine.btn--solid { background: var(--gold); border-color: var(--gold); color: #1c1607; }
.btn--onpine.btn--solid:hover { background: #b08f3f; border-color: #b08f3f; }

/* Header */
.masthead { background: var(--cream); border-bottom: 2px solid var(--ink); }
.masthead__row { display: flex; align-items: center; justify-content: space-between; gap: 14px; height: 66px; }
.brand { display: inline-flex; align-items: center; gap: 11px; }
.brand__g { width: 30px; height: 30px; }
.brand__t { font-family: var(--serif); font-weight: 700; font-size: 1.2rem; letter-spacing: -0.01em; }
.menu { display: none; gap: 26px; }
.menu a { font-weight: 500; font-size: 0.9rem; color: var(--ink-2); }
.menu a:hover { color: var(--pine); }
.masthead__act { display: none; gap: 12px; align-items: center; }
.signlink { font-weight: 500; font-size: 0.9rem; color: var(--ink-2); }
.burger { display: inline-flex; flex-direction: column; gap: 5px; width: 42px; height: 38px; align-items: center; justify-content: center; background: transparent; border: 1.5px solid var(--ink); border-radius: 4px; }
.burger span { width: 18px; height: 2px; background: var(--ink); }
.drawer { display: none; background: var(--paper); border-bottom: 1px solid var(--rule); }
.drawer.open { display: block; }
.drawer a { display: block; padding: 13px var(--pad); border-bottom: 1px solid var(--rule); font-weight: 500; }
.drawer .btn { margin: 14px var(--pad); }

/* Hero — editorial report header */
.hero { background: var(--cream); padding-block: 50px 52px; border-bottom: 1px solid var(--rule); }
.hero__report { font-family: var(--serif); font-style: italic; font-size: 0.95rem; color: var(--gold); margin: 0 0 10px; }
.hero__eyebrow { font-weight: 600; font-size: 0.74rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--pine); margin: 0 0 14px; }
.hero__title { font-family: var(--serif); font-weight: 700; font-size: clamp(2.3rem, 6.6vw, 3.9rem); line-height: 1.04; letter-spacing: -0.015em; margin: 0 0 18px; max-width: 16ch; }
.hero__lead { color: var(--ink-soft); font-size: 1.12rem; margin: 0 0 24px; max-width: 58ch; }
.hero__actions { display: flex; flex-wrap: wrap; gap: 12px; }
.hero__stats { display: grid; grid-template-columns: 1fr 1fr; margin-top: 34px; border-top: 2px solid var(--ink); }
.hero__stat { padding: 18px 16px 16px; border-bottom: 1px solid var(--rule); border-right: 1px solid var(--rule); }
.hero__sv { font-family: var(--serif); font-weight: 700; font-size: 1.9rem; color: var(--pine); letter-spacing: -0.01em; }
.hero__sk { font-size: 0.82rem; color: var(--ink-soft); }
.hero__note { font-size: 0.8rem; color: var(--ink-mute); margin: 14px 0 0; font-style: italic; }

/* Risk — disclosure exhibits */
.risk__grid { display: grid; gap: 0; margin-top: 28px; border-top: 1px solid var(--rule-2); }
.risk__row { display: grid; grid-template-columns: auto 1fr; gap: 20px; padding: 24px 0; border-bottom: 1px solid var(--rule-2); }
.risk__no { font-family: var(--serif); font-style: italic; font-size: 1.3rem; color: var(--gold); }
.risk__t { font-family: var(--serif); font-weight: 700; font-size: 1.3rem; margin: 0 0 6px; }
.risk__x { color: var(--ink-soft); margin: 0; }

/* Principles — columns with stat */
.prin { display: grid; gap: 22px; margin-top: 30px; }
.prin__col { background: var(--paper); border: 1px solid var(--rule); border-radius: 6px; padding: 26px; }
.prin__stat { display: flex; align-items: baseline; gap: 8px; margin-bottom: 14px; padding-bottom: 14px; border-bottom: 1px solid var(--rule); }
.prin__statv { font-family: var(--serif); font-weight: 700; font-size: 2.4rem; color: var(--pine); line-height: 1; }
.prin__statl { font-size: 0.8rem; color: var(--ink-mute); text-transform: uppercase; letter-spacing: 0.06em; }
.prin__t { font-family: var(--serif); font-weight: 700; font-size: 1.3rem; margin: 0 0 4px; }
.prin__lead { color: var(--ink-2); font-weight: 600; margin: 0 0 14px; }
.prin__points li { position: relative; padding-left: 22px; margin-bottom: 9px; color: var(--ink-soft); font-size: 0.92rem; }
.prin__points li::before { content: ""; position: absolute; left: 0; top: 9px; width: 7px; height: 7px; background: var(--pine); border-radius: 50%; }

/* Features — numbered editorial rows */
.feat { margin-top: 30px; }
.feat__row { display: grid; grid-template-columns: auto 1fr; gap: 22px; padding: 26px 0; border-bottom: 1px solid var(--rule); }
.feat__row:first-child { border-top: 1px solid var(--rule); }
.feat__idx { font-family: var(--serif); font-weight: 700; font-size: 2rem; color: var(--rule-2); line-height: 1; }
.feat__t { font-family: var(--serif); font-weight: 700; font-size: 1.4rem; margin: 0 0 8px; }
.feat__x { color: var(--ink-soft); margin: 0; max-width: 70ch; }

/* Analytics — exhibit panel */
.an { display: grid; gap: 28px; margin-top: 30px; }
.an__points { display: grid; gap: 12px; }
.an__points li { position: relative; padding-left: 26px; color: var(--ink-2); }
.an__points li::before { content: "—"; position: absolute; left: 0; color: var(--pine); font-weight: 700; }
.exhibit { background: var(--paper); border: 1px solid var(--rule); border-radius: 6px; overflow: hidden; }
.exhibit__head { background: var(--pine); color: #eef1ea; padding: 14px 18px; font-family: var(--serif); font-weight: 600; font-size: 1.02rem; }
.exhibit__metrics { display: grid; grid-template-columns: repeat(3, 1fr); border-bottom: 1px solid var(--rule); }
.exhibit__m { padding: 16px; border-right: 1px solid var(--rule); }
.exhibit__mv { font-family: var(--serif); font-weight: 700; font-size: 1.3rem; color: var(--pine); }
.exhibit__mk { font-size: 0.76rem; color: var(--ink-soft); }
.exhibit__alloc { padding: 18px; }
.exhibit__atitle { font-size: 0.76rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-mute); margin: 0 0 14px; }
.bar { margin-bottom: 12px; }
.bar__top { display: flex; justify-content: space-between; font-size: 0.86rem; margin-bottom: 5px; }
.bar__pct { font-weight: 700; color: var(--pine); }
.bar__track { height: 8px; background: var(--cream-2); border-radius: 999px; overflow: hidden; }
.bar__fill { height: 100%; background: linear-gradient(90deg, var(--pine), var(--pine-bright)); border-radius: 999px; }
.exhibit__cap { padding: 0 18px 16px; font-size: 0.74rem; color: var(--ink-mute); font-style: italic; margin: 0; }

/* Form — bordered ledger card */
.fcard { background: var(--paper); border: 2px solid var(--ink); border-radius: 6px; overflow: hidden; margin-top: 8px; }
.fcard__inner { display: grid; gap: 0; }
.fcard__intro { padding: 28px; }
.fcard__intro .h2 { margin-bottom: 10px; }
.fcard__form { padding: 28px; background: var(--cream); border-top: 1px solid var(--rule); }
.lg { display: grid; gap: 14px; }
.fl { display: grid; gap: 6px; }
.fl label { font-weight: 600; font-size: 0.8rem; color: var(--ink-2); }
.fl input { width: 100%; background: #fff; border: 1px solid var(--rule-2); border-radius: 4px; padding: 13px 14px; font-size: 0.95rem; font-family: var(--sans); color: var(--ink); transition: border-color .15s, box-shadow .15s; }
.fl input::placeholder { color: var(--ink-mute); }
.fl input:focus { outline: none; border-color: var(--pine); box-shadow: 0 0 0 3px rgba(31,81,53,0.12); }
.lf { margin-top: 16px; display: grid; gap: 12px; }
.lf-sec { font-size: 0.8rem; color: var(--ink-soft); display: flex; gap: 8px; align-items: center; margin: 0; }
.lf-sec svg { color: var(--pine); flex: none; }
.lf-con { font-size: 0.76rem; color: var(--ink-mute); margin: 0; line-height: 1.5; }
.iti { width: 100%; }

/* Process — ledger steps */
.steps { margin-top: 30px; border-top: 1px solid var(--rule); }
.pstep { display: grid; grid-template-columns: auto 1fr; gap: 22px; padding: 24px 0; border-bottom: 1px solid var(--rule); }
.pstep__n { font-family: var(--serif); font-weight: 700; font-size: 1.5rem; color: var(--pine); }
.pstep__t { font-family: var(--serif); font-weight: 700; font-size: 1.25rem; margin: 0 0 6px; }
.pstep__x { color: var(--ink-soft); margin: 0; }

/* FAQ — two-column Q/A */
.faqs { display: grid; gap: 0; margin-top: 30px; border-top: 1px solid var(--rule); }
.faq { padding: 22px 0; border-bottom: 1px solid var(--rule); }
.faq__q { font-family: var(--serif); font-weight: 700; font-size: 1.16rem; margin: 0 0 8px; }
.faq__a { color: var(--ink-soft); margin: 0; font-size: 0.94rem; }

/* Platform — table */
.ptable { width: 100%; border-collapse: collapse; margin-top: 28px; border: 2px solid var(--ink); background: var(--paper); }
.ptable caption { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); }
.ptable thead th { text-align: left; font-family: var(--serif); font-style: italic; font-size: 0.86rem; color: var(--ink-soft); padding: 13px 16px; background: var(--cream); border-bottom: 2px solid var(--ink); }
.ptable tbody th { text-align: left; font-weight: 600; color: var(--ink); padding: 14px 16px; border-bottom: 1px solid var(--rule); font-size: 0.92rem; width: 42%; }
.ptable tbody td { padding: 14px 16px; border-bottom: 1px solid var(--rule); color: var(--ink-soft); font-size: 0.92rem; }
.ptable tbody tr:last-child th, .ptable tbody tr:last-child td { border-bottom: 0; }

/* Reviews — on pine, quote wall */
.rv__head { display: flex; align-items: baseline; gap: 16px; flex-wrap: wrap; margin-top: 6px; }
.rv__big { font-family: var(--serif); font-weight: 700; font-size: 2.6rem; color: var(--gold); line-height: 1; }
.rv__stars { color: var(--gold); letter-spacing: 2px; }
.rv__count { color: #c2cbbf; font-size: 0.9rem; }
.rv__grid { display: grid; gap: 16px; margin-top: 28px; }
.rv__card { background: rgba(255,255,255,0.05); border: 1px solid rgba(238,241,234,0.16); border-radius: 6px; padding: 22px; }
.rv__q { font-family: var(--serif); font-size: 1.02rem; line-height: 1.5; color: #eef1ea; margin: 0 0 16px; }
.rv__who { display: flex; align-items: center; gap: 12px; }
.rv__ini { width: 38px; height: 38px; border-radius: 50%; background: var(--gold); color: #1c1607; font-weight: 700; display: inline-flex; align-items: center; justify-content: center; }
.rv__name { font-weight: 600; }
.rv__role { font-size: 0.8rem; color: #aab5a6; }
.rv__dis { color: #aab5a6; font-size: 0.78rem; margin-top: 18px; font-style: italic; }

/* Final CTA — editorial closing band */
.close { background: var(--cream-2); border-top: 2px solid var(--ink); }
.close__inner { display: grid; gap: 22px; }
.close__h { font-family: var(--serif); font-weight: 700; font-size: clamp(1.8rem, 5vw, 2.7rem); line-height: 1.08; letter-spacing: -0.01em; margin: 0 0 10px; max-width: 18ch; }
.close__d { color: var(--ink-soft); margin: 0; max-width: 56ch; }
.close__note { font-size: 0.8rem; color: var(--ink-mute); margin: 16px 0 0; font-style: italic; }

/* Footer */
.foot { background: var(--ink); color: #d6dad1; padding-block: 46px 26px; }
.foot__top { display: grid; gap: 28px; padding-bottom: 26px; border-bottom: 1px solid #3a4137; }
.foot__about { color: #aab2a3; font-size: 0.9rem; margin: 14px 0 0; max-width: 42ch; }
.foot__cols { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.foot__col h3 { font-family: var(--serif); font-style: italic; font-size: 0.92rem; color: var(--gold); margin: 0 0 12px; }
.foot__col a { display: block; color: #c2c8bc; font-size: 0.88rem; padding: 4px 0; }
.foot__col a:hover { color: #fff; }
.foot__risk { padding-block: 24px; border-bottom: 1px solid #3a4137; }
.foot__risk h3 { font-family: var(--serif); font-weight: 700; font-size: 0.96rem; color: #eaeee5; margin: 0 0 10px; }
.foot__risk p { color: #969d8d; font-size: 0.8rem; line-height: 1.6; margin: 0 0 10px; }
.foot__base { padding-top: 18px; display: flex; flex-wrap: wrap; gap: 8px 18px; justify-content: space-between; font-size: 0.8rem; color: #969d8d; }
.foot__brand { display: inline-flex; align-items: center; gap: 10px; }
.foot__brand .brand__t { color: #eaeee5; }

/* Service pages */
.page { min-height: 100vh; display: flex; flex-direction: column; }
.page__main { flex: 1 0 auto; display: flex; align-items: center; }
.sys { max-width: 560px; }
.sys__eyebrow { font-weight: 600; font-size: 0.74rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--pine); }
.sys__title { font-family: var(--serif); font-weight: 700; font-size: clamp(2.1rem, 7vw, 3.2rem); letter-spacing: -0.01em; line-height: 1.05; margin: 14px 0 12px; }
.sys__desc { color: var(--ink-soft); margin: 0 0 26px; max-width: 48ch; font-size: 1.04rem; }

.skip { position: absolute; left: 12px; top: -60px; background: var(--pine); color: #f4efe3; padding: 10px 16px; z-index: 100; transition: top .15s; font-weight: 600; border-radius: 4px; }
.skip:focus { top: 12px; }

@media (min-width: 720px) {
  .hero__stats { grid-template-columns: repeat(4, 1fr); }
  .prin { grid-template-columns: repeat(3, 1fr); }
  .an { grid-template-columns: 1fr 1.15fr; align-items: start; }
  .fcard__inner { grid-template-columns: 1fr 1fr; }
  .fcard__form { border-top: 0; border-left: 1px solid var(--rule); }
  .faqs { grid-template-columns: 1fr 1fr; gap: 0 44px; }
  .rv__grid { grid-template-columns: repeat(3, 1fr); }
  .close__inner { grid-template-columns: 1.3fr auto; align-items: center; }
  .foot__cols { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 1000px) {
  :root { --pad: 38px; }
  .block, .hero { padding-block: 82px; }
  .hero { padding-block: 64px 70px; }
  .menu, .masthead__act { display: flex; }
  .burger { display: none; }
  .drawer { display: none !important; }
  .foot__top { grid-template-columns: 1.3fr 1fr; }
}
@media (prefers-reduced-motion: reduce) { * { scroll-behavior: auto !important; transition: none !important; } }
