/* OPPI Finnish-education hub, shared styles. Nordic, editorial, brand-aligned. */
:root{
  --indigo:#2a295f; --ink:#1a1845; --amber:#f2b441; --gold:#c5af7a;
  --cream:#faf8f3; --paper:#ffffff; --line:#e7e4dc; --mut:#6f6e82; --soft:#f2f0ea;
  --maxw:760px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
/* body bg only; typography scoped to the content so it never touches the site chrome */
body{margin:0;background:var(--cream);-webkit-font-smoothing:antialiased}
main.wrap{color:var(--ink);font-family:'DM Sans',-apple-system,Arial,sans-serif;font-size:18px;line-height:1.7}
article a{color:var(--indigo);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}
article a:hover{color:var(--amber)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}

/* clear the site's fixed nav (nav + footer come entirely from site.css) */
main.wrap{padding-top:104px}
@media(max-width:640px){main.wrap{padding-top:80px}}

/* hero / article head */
.eyebrow{font-family:'Jost';font-weight:600;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
h1{font-family:'Jost';font-weight:700;line-height:1.12;font-size:clamp(30px,5vw,46px);color:var(--indigo);margin:.3em 0 .35em}
h2{font-family:'Jost';font-weight:600;font-size:clamp(22px,3.4vw,30px);color:var(--indigo);margin:1.7em 0 .5em;line-height:1.2}
h3{font-family:'Jost';font-weight:600;font-size:20px;color:var(--ink);margin:1.4em 0 .4em}
.lede{font-size:21px;line-height:1.6;color:#36344f}
article{padding:34px 0 10px}
article p{margin:0 0 1.1em}
article ul,article ol{margin:0 0 1.2em;padding-left:1.2em}
article li{margin:.4em 0}
blockquote{margin:1.4em 0;padding:14px 20px;border-left:3px solid var(--amber);background:var(--paper);border-radius:0 10px 10px 0;color:#36344f;font-size:18px}
.meta{font-size:13px;color:var(--mut);margin-top:6px}
hr{border:none;border-top:1px solid var(--line);margin:34px 0}

/* callout / key-facts card (also helps GEO: crawlable structured facts) */
.facts{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:18px 20px;margin:24px 0}
.facts .t{font-family:'Jost';font-weight:600;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.facts ul{margin:0;padding-left:1.1em}
.facts li{margin:.35em 0;font-size:16px}

/* FAQ */
.faq{margin:18px 0}
.faq details{border-bottom:1px solid var(--line);padding:14px 0}
.faq summary{font-family:'Jost';font-weight:600;font-size:18px;color:var(--ink);cursor:pointer;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{content:'+';color:var(--amber);font-weight:700;margin-right:10px}
.faq details[open] summary::before{content:'–'}
.faq p{margin:.7em 0 0;font-size:16.5px;color:#36344f}

/* related links grid */
.related{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:18px 0 6px}
.related a{display:block;background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:14px 16px;text-decoration:none;color:var(--ink);font-weight:500;font-size:15.5px;line-height:1.35}
.related a:hover{border-color:var(--gold);color:var(--indigo)}
@media(max-width:560px){.related{grid-template-columns:1fr}}

/* CTA */
.cta{background:var(--indigo);border-radius:16px;padding:26px 26px;margin:34px 0;color:#fff}
.cta h2{color:#fff;margin:.1em 0 .3em}
.cta p{color:#d9d8ec;margin:0 0 16px}
.cta .cta-proof{font-size:14px;color:#b9b8d6;border-top:1px solid rgba(255,255,255,.14);padding-top:12px;margin-top:2px}
.btn{display:inline-block;background:var(--amber);color:#2a295f;font-family:'Jost';font-weight:700;font-size:15px;padding:12px 22px;border-radius:10px;text-decoration:none}
.btn:hover{background:#ffc659;color:#2a295f}

/* footer comes entirely from the site chrome (site.css) */

/* hub index cards */
.hub-pillars{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:26px 0}
.hub-pillars a{display:block;background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:22px;text-decoration:none}
.hub-pillars a:hover{border-color:var(--gold)}
.hub-pillars .k{font-family:'Jost';font-weight:600;font-size:19px;color:var(--indigo);margin-bottom:6px}
.hub-pillars .d{color:#46455c;font-size:15.5px;line-height:1.5}
@media(max-width:560px){.hub-pillars{grid-template-columns:1fr}}
