:root{--text:#ffffffb3;--text-h:#fff;--bg:#011a28;--surface:#012738;--surface-alt:#013348;--border:#ffffff1a;--accent:#bf6200;--accent-alt:#219ebc;--sans:"Roboto", "Inter", "Helvetica", "Arial", sans-serif;--serif:"IBM Plex Serif", serif;font:18px/145% var(--sans);color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,:before,:after{box-sizing:border-box}body{min-height:100svh;margin:0}#root{min-height:100svh}h1,h2,h3{font-family:var(--serif);letter-spacing:.015em;color:var(--text-h);font-weight:700}h1{font-size:clamp(2rem,5vw,3rem);line-height:1.15}a{transition:opacity .2s}a:hover{opacity:.85}.page{flex-direction:column;min-height:100svh;display:flex}.header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1.25rem 2rem;display:flex}.logo{font-family:var(--serif);color:var(--text-h);letter-spacing:.015em;font-size:1.1rem;font-weight:700;text-decoration:none}.nav{gap:1.5rem;display:flex}.nav a{color:var(--text);font-size:.95rem;text-decoration:none;transition:color .2s}.nav a:hover{color:var(--text-h)}.hero{text-align:center;max-width:42rem;margin:0 auto;padding:6rem 2rem 5rem}.hero-label{text-transform:uppercase;letter-spacing:.12em;color:var(--accent-alt);margin:0 0 1rem;font-size:.85rem}.hero h1{margin:0 0 1.25rem}.hero-text{margin:0;font-size:1.15rem;line-height:1.6}.section{box-sizing:border-box;width:100%;max-width:56rem;margin:0 auto;padding:3rem 2rem}.section h2{margin:0 0 1.5rem;font-size:1.5rem}.section-text{max-width:36rem;margin:0;font-size:1.05rem;line-height:1.65}.section-text a{color:var(--accent-alt)}.card-grid{grid-template-columns:repeat(auto-fill,minmax(16rem,1fr));gap:1.5rem;display:grid}.card{border:1px solid var(--border);background:var(--surface);border-radius:8px;overflow:hidden}.card-placeholder{aspect-ratio:16/9;background:linear-gradient(135deg, var(--surface-alt) 0%, var(--border) 100%)}.card h3{color:var(--text-h);margin:1rem 1.25rem .5rem;font-size:1.1rem;font-weight:500}.card p{margin:0 1.25rem 1.25rem;font-size:.95rem;line-height:1.5}.footer{text-align:center;border-top:1px solid var(--border);margin-top:auto;padding:2rem;font-size:.875rem}@media (width<=640px){.header{flex-direction:column;gap:1rem;padding:1.25rem 1.5rem}.hero{padding:4rem 1.5rem 3rem}.section{padding:2.5rem 1.5rem}}
