@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=Space+Grotesk:wght@500;600;700&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;font-size:1rem;line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:currentColor;text-decoration:underline;text-underline-offset:3px}
a:hover{opacity:.85}

.surface-dark{background:#1A1D23;color:#E8ECF1}
.surface-light{background:#E8ECF1;color:#1A1D23}
.surface-accent{background:#2563EB;color:#E8ECF1}
.surface-deep{background:#1A1D23;color:#60A5FA}

.container{width:min(1140px,92vw);margin-inline:auto}
.section{padding:4.5rem 0}
.section-label{font-family:'Space Grotesk',sans-serif;font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;opacity:.7;margin-bottom:.5rem}
h1,h2,h3,h4{font-family:'Space Grotesk',sans-serif;line-height:1.15;font-weight:600}
h1{font-size:clamp(2.5rem,5vw,3.5rem)}
h2{font-size:clamp(1.75rem,3vw,2.25rem);margin-bottom:1rem}
h3{font-size:1.25rem;margin-bottom:.5rem}
p{margin-bottom:1rem}
ul,ol{margin-bottom:1rem;padding-left:1.25rem}
li{margin-bottom:.35rem}

.site-header{position:sticky;top:0;z-index:100;border-bottom:1px solid rgba(232,236,241,.12)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;gap:1rem}
.logo{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.15rem;text-decoration:none;letter-spacing:-.02em}
.logo span{color:#2563EB}
.nav-list{display:flex;flex-wrap:wrap;gap:.25rem 1.25rem;list-style:none;padding:0;margin:0}
.nav-list a{text-decoration:none;font-size:.9rem;font-weight:500}
.nav-list a[aria-current="page"]{text-decoration:underline}

.btn{display:inline-block;padding:.75rem 1.35rem;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:.9rem;text-decoration:none;border:2px solid transparent;border-radius:4px;cursor:pointer;transition:opacity .2s}
.btn-primary{background:#2563EB;color:#E8ECF1;border-color:#2563EB}
.btn-outline{background:transparent;border-color:currentColor}
.btn-group{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem}

.hero-editorial{min-height:90vh;display:grid;grid-template-columns:1fr 2px 1fr;align-items:stretch}
.hero-editorial .hero-main{padding:3rem 0;display:flex;flex-direction:column;justify-content:center}
.hero-editorial .hero-divider{background:rgba(26,29,35,.15);width:2px}
.hero-editorial .hero-visual{position:relative;display:flex;align-items:center;justify-content:center;padding:2rem}
.hero-editorial .hero-visual img{width:100%;max-width:380px;aspect-ratio:3/4;object-fit:cover;border-radius:4px}
.hero-serial{font-family:'Space Grotesk',sans-serif;font-size:.85rem;color:#2563EB;margin-bottom:.75rem}
.hero-caption{font-size:.8rem;margin-top:.75rem;opacity:.75}
.trust-strip{display:flex;flex-wrap:wrap;gap:1rem 2rem;margin-top:2rem;font-size:.85rem;opacity:.85}

.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}
.grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem}
.grid-4{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem}

.card{padding:1.75rem;border-radius:4px;border:1px solid rgba(26,29,35,.1)}
.surface-dark .card{border-color:rgba(232,236,241,.12)}
.module-tag{font-family:'Space Grotesk',sans-serif;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:#2563EB;margin-bottom:.5rem}

.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1.5rem;text-align:center;padding:2rem 0}
.stat-num{font-family:'Space Grotesk',sans-serif;font-size:2rem;font-weight:700;color:#2563EB}
.stat-label{font-size:.85rem;opacity:.8}

.content-img{border-radius:4px;margin:1.5rem 0}
.img-caption{font-size:.8rem;opacity:.7;margin-top:.5rem}

.page-hero{padding:3.5rem 0 2rem}
.page-hero h1{margin-bottom:.75rem}

.faq-item{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(26,29,35,.1)}
.surface-dark .faq-item{border-color:rgba(232,236,241,.12)}
.faq-q{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:1.05rem;margin-bottom:.5rem}

.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-weight:500;margin-bottom:.35rem;font-size:.9rem}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.65rem .85rem;border:1px solid rgba(26,29,35,.2);border-radius:4px;font:inherit;background:#fff;color:#1A1D23}
.form-group textarea{min-height:140px;resize:vertical}
.form-check{display:flex;gap:.65rem;align-items:flex-start;font-size:.9rem}
.form-check input{margin-top:.25rem}
.hp{position:absolute;left:-9999px;opacity:0;height:0;width:0;overflow:hidden}

.site-footer{padding:3rem 0 2rem;border-top:1px solid rgba(232,236,241,.12);font-size:.875rem}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:2rem}
.footer-grid h4{font-size:.95rem;margin-bottom:.75rem}
.footer-grid ul{list-style:none;padding:0}
.footer-grid li{margin-bottom:.35rem}
.footer-grid a{text-decoration:none}
.footer-bottom{padding-top:1.5rem;border-top:1px solid rgba(232,236,241,.08);font-size:.8rem;opacity:.85}
.disclaimer{font-size:.8rem;opacity:.8;margin-top:1rem;line-height:1.5}

.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:200;padding:1.25rem;box-shadow:0 -4px 24px rgba(0,0,0,.15)}
.cookie-inner{max-width:1140px;margin:0 auto;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem}
.cookie-actions{display:flex;flex-wrap:wrap;gap:.5rem}
.cookie-modal{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;padding:1rem}
.cookie-modal[hidden]{display:none}
.cookie-modal-inner{max-width:520px;width:100%;padding:2rem;border-radius:6px;max-height:90vh;overflow-y:auto}
.cookie-option{margin-bottom:1rem;padding:.75rem;border:1px solid rgba(26,29,35,.15);border-radius:4px}

.error-page{min-height:60vh;display:flex;align-items:center;text-align:center;padding:4rem 0}
.error-page h1{margin-bottom:1rem}

.reveal{opacity:1;transform:none}
.js .reveal:not(.is-visible){opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
@media (prefers-reduced-motion:reduce){
  .js .reveal:not(.is-visible){opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}
@media (max-width:768px){
  .hero-editorial{grid-template-columns:1fr;min-height:70vh}
  .hero-editorial .hero-divider{display:none}
  .nav-list{font-size:.85rem}
}
