
:root{
  --bg:#0b1220;
  --card:#0f172a;
  --ink:#e5edff;
  --muted:#c7d2fe;
  --accent:#6ea8fe;
  --accent2:#22c55e;
  --border:#1f2a44;
}

:root.light{
  --bg:#f8fafc;
  --card:#ffffff;
  --ink:#0f172a;
  --muted:#475569;
  --accent:#2563eb;
  --accent2:#16a34a;
  --border:#e2e8f0;
}

*{box-sizing:border-box}
html,body{font-family:'Inter','Roboto',system-ui,-apple-system,Segoe UI,Arial,sans-serif;margin:0;padding:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--ink);
  background:var(--bg);line-height:1.75}
a{color:var(--accent);text-decoration:none;transition:all .2s ease}a:hover{opacity:.9;text-decoration:underline}
img{max-width:100%;display:block}
.container{max-width:1120px;margin:0 auto;padding:0 20px}
.header{position:sticky;top:0;background:color-mix(in oklab, var(--bg), #000 10%);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);z-index:20}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;align-items:center;gap:12px;font-weight:800;letter-spacing:.2px;color:var(--ink)}
.brand img{height:30px;filter:drop-shadow(0 2px 6px rgba(110,168,254,.35))}
.menu{display:flex;gap:18px;flex-wrap:wrap}
.menu a{padding:8px 10px;border-radius:10px;color:var(--ink)}
.menu a.active{background:linear-gradient(135deg, rgba(110,168,254,.18), rgba(34,197,94,.18));border:1px solid rgba(110,168,254,.35)}
.theme-toggle{border:1px solid var(--border);background:transparent;color:var(--ink);padding:8px 12px;border-radius:10px;cursor:pointer}
.theme-toggle:hover{background:rgba(255,255,255,.06)}
.hero{padding:72px 0 32px}
.badge{display:inline-block;padding:6px 12px;border:1px solid rgba(110,168,254,.35);border-radius:999px;font-size:12px;color:var(--ink);background:rgba(110,168,254,.12)}
h1{font-size:clamp(28px,4vw,44px);margin:.4em 0 .2em;font-weight:900;letter-spacing:-.4px}
.lead{color:var(--muted);max-width:820px}
.grid{display:grid;gap:22px;margin-top:26px}
@media(min-width:980px){.grid{grid-template-columns:2fr 1fr}}
.card, article{border:1px solid var(--border);border-radius:16px;padding:22px;background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.01));box-shadow:0 10px 30px rgba(0,0,0,.25)}
.card h3, article h2{margin:0 0 10px 0}
.section{margin:44px 0}
.list{list-style:disc;padding-left:20px}
.footer{border-top:1px solid var(--border);margin-top:44px}
.footer .container{padding:24px 20px;color:var(--muted);font-size:14px}
.btn{display:inline-block;padding:12px 16px;border-radius:12px;background:linear-gradient(135deg, var(--accent), #4f8df6);color:#081022;border:1px solid rgba(110,168,254,.6);font-weight:700;transition:transform .08s ease}
.btn:hover{filter:brightness(1.08);text-decoration:none;transform:translateY(-1px)}
.cards{display:grid;gap:16px}
@media(min-width:760px){.cards{grid-template-columns:repeat(3,1fr)}}
.meta{color:var(--muted);font-size:14px;margin-bottom:6px}
.kicker{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em}
.figure{background:rgba(110,168,254,.06);border:1px dashed rgba(110,168,254,.35);border-radius:12px;padding:12px;text-align:center;color:var(--muted);font-size:13px}
.small{font-size:13px;color:var(--muted)}
.table{width:100%;border-collapse:collapse}
.table th,.table td{border:1px solid var(--border);padding:10px;text-align:left;vertical-align:top}
blockquote{border-left:4px solid rgba(110,168,254,.35);padding-left:12px;color:var(--ink);background:rgba(110,168,254,.06);border-radius:6px}
details{border:1px solid var(--border);border-radius:12px;padding:14px 16px;background:rgba(255,255,255,.03)}
details+details{margin-top:12px}
summary{cursor:pointer;font-weight:800;color:var(--ink)}
form{display:grid;gap:10px}
input,textarea{font:inherit;padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:transparent;color:var(--ink)}
hr.divider{border:0;height:1px;background:linear-gradient(90deg, rgba(110,168,254,0), rgba(110,168,254,.5), rgba(110,168,254,0));margin:28px 0}

/* Back to top */
#topBtn{position:fixed;right:16px;bottom:16px;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:rgba(255,255,255,.06);color:var(--ink);cursor:pointer;display:none}
#cookie{position:fixed;left:16px;bottom:16px;max-width:520px;background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.03));border:1px solid var(--border);border-radius:12px;padding:14px;color:var(--ink);display:none}
#cookie button{margin-left:10px}


/* --- Mobile nav improvements --- */
.menu-toggle{display:none;border:1px solid var(--border);background:transparent;color:var(--ink);
  padding:8px 12px;border-radius:10px;cursor:pointer;margin-left:10px}
.menu-toggle:hover{background:rgba(255,255,255,.06)}
.brand{white-space:nowrap}

@media(max-width: 920px){
  .menu{display:none;position:absolute;top:100%;left:0;right:0;
    background:color-mix(in oklab, var(--bg), #000 8%);border-bottom:1px solid var(--border);
    padding:12px 20px;flex-direction:column;gap:12px}
  .menu.open{display:flex}
  .nav{position:relative}
  .theme-toggle{display:none}
  .hero{padding-top:56px}
}


/* --- Nav as flat buttons --- */
.menu a{
  display:inline-block;
  padding:8px 16px;
  border-radius:8px;
  background:rgba(255,255,255,0.06);
  border:1px solid var(--border);
  transition:background .2s ease, color .2s ease;
}
.menu a:hover{
  background:rgba(110,168,254,0.2);
  text-decoration:none;
}
.menu a.active{
  background:var(--accent);
  color:#081022;
  font-weight:700;
}


/* --- Header search --- */
.searchbar{display:flex;align-items:center;gap:8px;margin-left:10px}
.searchbar input{padding:8px 10px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--ink);min-width:180px}
.search-results{position:absolute;top:100%;right:20px;max-width:420px;background:color-mix(in oklab, var(--bg), #000 10%);
  border:1px solid var(--border);border-radius:10px;padding:10px;display:none;z-index:50}
.search-results.open{display:block}
.search-results a{display:block;padding:6px 8px;border-radius:8px}
.search-results a:hover{background:rgba(255,255,255,.06);text-decoration:none}

/* Cookie banner better spacing */
#cookie{display:none;position:fixed;left:16px;right:16px;bottom:16px;max-width:720px;margin:auto;z-index:40}
#cookie .row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
#cookie .close{border:1px solid var(--border);background:transparent;color:var(--ink);padding:8px 12px;border-radius:10px;cursor:pointer}
#cookie .close:hover{background:rgba(255,255,255,.06)}

/* Smooth scrolling */
html{scroll-behavior:smooth}


/* Focus styles for accessibility */
:focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:8px}

/* Breadcrumbs */
.breadcrumbs{font-size:13px;color:var(--muted);margin-top:16px;margin-bottom:8px}
.breadcrumbs a{color:var(--accent)}

/* Print styles */
@media print{
  .header,#cookie,#topBtn,.theme-toggle,.menu,.searchbar,.btn-print{display:none !important}
  body{background:#fff;color:#000}
  article,.card{border:none;box-shadow:none}
  a{color:#000;text-decoration:underline}
}

/* Hero illustrations */
.hero-illus{display:block;margin:14px 0 0 0}

/* --- CLEAN THEME TWEAKS --- */
.menu a{
  display:inline-block;
  padding:8px 12px;
  border-radius:8px;
  background:transparent;
  border:1px solid transparent;
}
.menu a:hover{
  background:rgba(255,255,255,0.06);
  border-color:var(--border);
  text-decoration:none;
}
.menu a.active{
  background:rgba(110,168,254,0.18);
  color:var(--ink);
  border-color:rgba(110,168,254,0.5);
}
.lang{font-size:13px}
.lang a{color:var(--muted)}
.lang a:hover{color:var(--accent)}
/* Hide hero illustration blocks for a cleaner look */
.hero-illus{display:none !important}


/* --- NAV FIX: keep header single-line & tidy --- */
.header .nav{display:flex;align-items:center;gap:14px;flex-wrap:nowrap}
.brand{flex:0 0 auto;white-space:nowrap}
.menu{flex:1 1 auto;display:flex;justify-content:center;gap:14px;flex-wrap:nowrap;min-width:0}
.menu a{flex:0 0 auto;white-space:nowrap}
.searchbar{flex:0 0 auto}
.searchbar input{min-width:140px;max-width:220px}
.theme-toggle{flex:0 0 auto}
/* Avoid accidental second row */
.header{min-height:58px}
/* If still narrow, allow menu to scroll horizontally instead of wrapping */
@media(max-width: 1060px){
  .menu{overflow-x:auto;justify-content:flex-start}
}

/* --- Brand as Home icon --- */
.brand svg{height:28px;width:auto;display:block;fill:var(--ink);transition:opacity .2s ease, transform .06s ease}
.brand:hover svg{opacity:.9;transform:translateY(-1px)}


/* --- HEADER GRID FIX --- */
.header .nav{
  display:grid;
  grid-template-columns:auto 1fr auto auto;
  align-items:center;
  gap:12px;
}
.brand{white-space:nowrap}
.menu{
  display:flex;
  gap:12px;
  justify-content:center;
  flex-wrap:nowrap;
  overflow-x:auto;
  scrollbar-width:none;
}
.menu::-webkit-scrollbar{display:none}
.menu a{flex:0 0 auto;white-space:nowrap}
.searchbar{min-width:0}
.searchbar input{width:220px;max-width:28vw;min-width:140px}
/* Ensure menu doesn't slide under search on tight widths */
@media(max-width: 1120px){
  .searchbar input{max-width:22vw}
}
@media(max-width: 980px){
  .searchbar input{display:none}
}

.menu a{padding:6px 10px}


/* ===== Sidebar layout ===== */
.layout{display:grid;grid-template-columns:220px 1fr;gap:18px;align-items:start}
.sidebar{position:sticky;top:64px;height:calc(100vh - 64px);padding:8px 6px 16px 12px;border-right:1px solid var(--border)}
.sidebar a{display:block;padding:10px 12px;margin:4px 0;border-radius:10px;border:1px solid transparent;color:var(--ink)}
.sidebar a:hover{background:rgba(255,255,255,.06);text-decoration:none;border-color:var(--border)}
.sidebar a.active{background:rgba(110,168,254,.18);border-color:rgba(110,168,254,.5)}
/* Hide the old top menu */
.menu{display:none !important}
/* Make header compact since no menu in it */
.header .nav{grid-template-columns:auto 1fr auto;gap:12px}
/* Responsive: collapse sidebar to top dropdown on small screens */
@media(max-width: 980px){
  .layout{display:block}
  .sidebar{position:relative;top:auto;height:auto;border-right:none;border-bottom:1px solid var(--border);padding:8px 12px;margin:0 20px}
  .sidebar .toggle{display:inline-block;margin-bottom:8px}
  .sidebar .links{display:none}
  .sidebar.open .links{display:block}
  .sidebar .toggle button{border:1px solid var(--border);background:transparent;color:var(--ink);padding:8px 12px;border-radius:10px}
}


/* ====== Energy/Vibe upgrade ====== */

/* Smooth theme transition */
:root, :root.light {
  transition: background-color .25s ease, color .25s ease;
}

/* Airier vertical rhythm */
.hero{padding:84px 0 36px}
.section{margin:56px 0}

/* Card lift + hover */
.card, article{
  transition: transform .12s ease, box-shadow .2s ease, background .25s ease, border-color .25s ease;
}
.card:hover, article:hover{
  transform: translateY(-1px);
  box-shadow: 0 14px 30px rgba(0,0,0,.25);
}

/* Buttons */
.btn{
  transition: transform .06s ease, filter .2s ease, background .25s ease, color .25s ease, border-color .25s ease;
}
.btn:hover{ transform: translateY(-1px); }

/* Sidebar links vibe */
.sidebar a{
  position:relative;
  transition: background .2s ease, border-color .2s ease, color .2s ease, transform .06s ease;
}
.sidebar a:hover{ transform: translateX(2px); }
.sidebar a.active{
  background: linear-gradient(90deg, rgba(110,168,254,.18), rgba(110,168,254,.04));
  border-color: rgba(110,168,254,.5);
}

/* Links underline animation */
a{ text-decoration:none; background-image: linear-gradient(currentColor, currentColor);
    background-size: 0% 1px; background-repeat:no-repeat; background-position: 0 100%;
    transition: background-size .2s ease; }
a:hover{ background-size: 100% 1px; }
.menu a, .sidebar a{ background-image:none } /* keep buttons clean */

/* Search input focus */
.searchbar input{ transition: box-shadow .2s ease, border-color .2s ease }
.searchbar input:focus{ outline:none; border-color: rgba(110,168,254,.6); box-shadow: 0 0 0 4px rgba(110,168,254,.15) }

/* Cookie + Top button subtle effects */
#cookie{ transition: opacity .25s ease }
#topBtn{ transition: opacity .2s ease, transform .1s ease }
#topBtn:hover{ transform: translateY(-2px) }

/* Reduce motion for users who prefer it */
@media (prefers-reduced-motion: reduce) {
  *{ transition: none !important }
  .card:hover, article:hover, .btn:hover, .sidebar a:hover, #topBtn:hover { transform: none !important }
}

.header{background:#0b1220cc;backdrop-filter: blur(12px)}
:root.light .header{background:#ffffffd0;backdrop-filter: blur(12px)}
