
:root{
  --bg:#0b0d12; --bg2:#0e121a; --card:#121723; --text:#e7ecf3; --muted:#aeb8cc;
  --primary:#7dd3fc; --accent:#c084fc; --ok:#34d399; --warn:#fbbf24; --danger:#f87171;
  --ring: 0 0 0 2px rgba(125,211,252,.35), 0 0 0 6px rgba(192,132,252,.2);
  --shadow: 0 10px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:linear-gradient(180deg,var(--bg),var(--bg2));color:var(--text);font:16px/1.6 ui-sans-serif,system-ui,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto;border-radius:16px;box-shadow:var(--shadow)}
.hdr{position:sticky;top:0;z-index:50;display:flex;gap:16px;align-items:center;justify-content:space-between;padding:16px 20px;background:rgba(11,13,18,.7);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.06)}
.brand{display:flex;gap:10px;align-items:center;font-weight:700;color:var(--text)}
.nav{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.navlink{padding:8px 10px;color:var(--muted)}
.btn{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(255,255,255,.12);border-radius:999px;padding:10px 14px}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--accent));color:#0a0a0a;font-weight:700;border:none;box-shadow:var(--shadow)}
.hero{padding:64px 20px 24px;display:grid;gap:24px;max-width:1200px;margin:0 auto}
.kicker{color:var(--muted);text-transform:uppercase;letter-spacing:.2em;font-weight:600}
.h1{font-size:clamp(28px,4vw,52px);line-height:1.1;margin:0}
.h2{font-size:clamp(22px,2.8vw,36px);line-height:1.2;margin:0 0 10px}
.lead{color:var(--muted);font-size:clamp(16px,1.8vw,18px)}
.grid{display:grid;gap:18px}
.cards{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.card{background:linear-gradient(180deg,var(--card),#0d121c);border:1px solid rgba(255,255,255,.06);padding:16px;border-radius:20px;box-shadow:var(--shadow)}
.card h3{margin:8px 0 6px}
.card p{color:var(--muted);margin:0 0 8px}
.meta{font-size:12px;color:var(--muted)}
.ftr{margin-top:40px;padding:28px 20px;border-top:1px solid rgba(255,255,255,.06);background:rgba(8,10,14,.6);backdrop-filter:blur(8px)}
.ftr-grid{max-width:1200px;margin:0 auto;display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.copy{text-align:center;color:var(--muted);margin-top:10px}
.container{max-width:1100px;margin:0 auto;padding:28px 20px}
.prose{color:var(--text)}
.prose h1,.prose h2,.prose h3{line-height:1.2}
.prose h1{font-size:clamp(26px,3vw,40px)}
.prose h2{font-size:clamp(20px,2.4vw,28px)}
.prose h3{font-size:clamp(18px,2vw,22px)}
.prose p{margin:12px 0}
figure{margin:16px 0}
figcaption{color:var(--muted);font-size:13px;margin-top:6px}
.badge{display:inline-block;padding:4px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.12);color:var(--muted);font-size:12px}
.kpi{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin:18px 0}
.kpi .card{display:flex;flex-direction:column;gap:4px;align-items:flex-start}
.mono{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace}
.hero-visual{position:relative;overflow:hidden;border-radius:24px;border:1px solid rgba(255,255,255,.06)}
.hero-visual::before{content:"";position:absolute;inset:-30%;background:radial-gradient(1200px 400px at 0% 0%,rgba(125,211,252,.15),transparent 60%), radial-gradient(1200px 400px at 100% 0%,rgba(192,132,252,.15),transparent 60%)}
.hero-visual img{display:block;width:100%;filter:contrast(1.05) saturate(1.05) brightness(.9);object-fit:cover}
.articles-list{display:grid;gap:16px}
.article-item{display:grid;gap:10px;grid-template-columns:120px 1fr;align-items:center;background:linear-gradient(180deg,var(--card),#0d121c);border:1px solid rgba(255,255,255,.06);padding:10px;border-radius:16px}
.article-item img{width:120px;height:80px;border-radius:10px object-fit:cover; aspect-ratio:3/2; }
#consent-banner{position:fixed;left:0;right:0;bottom:0;padding:12px;background:rgba(6,8,12,.9);border-top:1px solid rgba(255,255,255,.08);z-index:9999}
#consent-banner .consent-card{max-width:1200px;margin:0 auto;display:flex;gap:12px;align-items:center;justify-content:space-between}
#consent-banner p{margin:0;color:var(--muted)}
#consent-banner .consent-actions{display:flex;gap:8px}
#consent-banner button{border:none;padding:10px 14px;border-radius:999px}
#consent-banner #consent-accept{background:linear-gradient(135deg,var(--primary),var(--accent));color:#0a0a0a;font-weight:700}
#consent-banner #consent-reject{background:transparent;color:var(--muted);border:1px solid rgba(255,255,255,.12)}
.tool-wrap{display:grid;gap:16px;grid-template-columns:1fr}
.canvas-bar{display:flex;gap:10px;flex-wrap:wrap}
input[type="number"], input[type="text"]{background:#0b0f16;color:var(--text);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:8px 10px}
label{color:var(--muted);font-size:14px}
.tool-card{background:linear-gradient(180deg,var(--card),#0d121c);border:1px solid rgba(255,255,255,.06);padding:16px;border-radius:16px}
.canvas-stage{width:100%;max-width:100%;border-radius:16px;border:1px dashed rgba(255,255,255,.15);background:#0a0d14;display:block;box-shadow:var(--shadow);aspect-ratio:16/9}
.note{color:var(--muted);font-size:14px}

/* Ensure card images show fully with letterboxing in dark bg */
.card > img{width:100%;height:180px;object-fit:contain;background:#0a0d14;border-radius:12px}

figure img{width:100%;height:auto}


/* About polish */
.about-hero{margin-bottom:1.5rem}
.prose .lead{font-size:1.15rem;line-height:1.7;color:#cbd5e1;max-width:68ch}
.prose p{max-width:75ch}
.prose h2{margin-top:1.6rem}
.site-footer{margin-top:3rem}
.footer-grid{display:flex;gap:2rem;justify-content:space-between;align-items:flex-start;flex-wrap:wrap}
.footer-links a{margin-right:1rem;opacity:.9}
.footer-links a:hover{opacity:1}



/* Policy / TOC styling */
.policy .lead{font-size:1.1rem;line-height:1.7;color:#cbd5e1;max-width:70ch}
.toc{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.06);padding:0.75rem 1rem;border-radius:12px;margin:1rem 0 1.25rem}
.toc ol{margin:0.5rem 0 0 1.25rem}
.toc a{text-decoration:none}
.toc a:hover{text-decoration:underline}
.policy h2{margin-top:1.4rem}

