:root{
  --blue:#0b4fcb;
  --blue-dark:#063a98;
  --orange:#f97316;
  --orange-dark:#ea580c;
  --bg:#f4f7fb;
  --surface:#ffffff;
  --ink:#0f172a;
  --muted:#516173;
  --border:rgba(2,6,23,.12);
  --shadow:0 18px 50px rgba(2,6,23,.12);
  --radius:18px;
  --radius2:26px;
  --max:1180px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;color:var(--ink);background:var(--bg);line-height:1.55}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}

.skip{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip:focus{left:16px;top:16px;width:auto;height:auto;padding:10px 12px;background:#fff;border-radius:14px;box-shadow:var(--shadow);z-index:9999}

.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.25);font-weight:850;cursor:pointer}
.btn:hover{filter:brightness(1.02)}
.btn.orange{border:none;background:linear-gradient(135deg,var(--orange),var(--orange-dark));color:#fff;box-shadow:0 12px 26px rgba(249,115,22,.25)}
.btn.blue{border:none;background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:#fff;box-shadow:0 12px 26px rgba(11,79,203,.22)}
.btn.ghost{border:1px solid rgba(255,255,255,.28);background:rgba(255,255,255,.06);color:#fff}

header{background:linear-gradient(180deg,var(--blue-dark),var(--blue));color:#fff;position:sticky;top:0;z-index:50}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 0}
.brand{display:flex;align-items:center;gap:10px}
.brand img{height:38px}
.nav{display:flex;align-items:center;gap:16px;flex-wrap:wrap;font-weight:850}
.nav a{opacity:.95}
.nav a:hover{opacity:1;text-decoration:underline;text-underline-offset:6px}
.header-accent{height:8px;background:linear-gradient(90deg,var(--orange),rgba(249,115,22,0))}

.mega{position:relative}
.mega > button{padding:10px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.06);color:#fff;font-weight:850;cursor:pointer}
.mega-panel{
  position:absolute;left:0;top:52px;
  width:min(1040px, calc(100vw - 40px));
  background:#fff;color:var(--ink);
  border:1px solid var(--border);
  border-radius:18px;
  box-shadow:0 22px 70px rgba(2,6,23,.22);
  padding:14px;
  display:none;
}
.mega.open .mega-panel{display:block}
.mega-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.mega-top input{width:min(420px, 100%);padding:10px 12px;border-radius:999px;border:1px solid rgba(15,23,42,.14);outline:none}
.mega-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;max-height:420px;overflow:auto;padding-right:6px}
.mega-link{
  padding:10px 10px;border-radius:14px;border:1px solid rgba(15,23,42,.10);
  background:rgba(244,247,251,.85);font-weight:850
}
.mega-link:hover{border-color:rgba(249,115,22,.28);background:rgba(249,115,22,.08)}
.mega-link small{display:block;margin-top:2px;font-size:12px;color:var(--muted);font-weight:650}

.hero{position:relative;color:#fff;background:linear-gradient(180deg,var(--blue),var(--blue-dark));overflow:hidden}
.hero-bg{position:absolute;inset:0;background:url("../img/hero.png") center/cover no-repeat;opacity:.95}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(900px 460px at 15% 30%, rgba(255,255,255,.18), transparent 60%),radial-gradient(900px 460px at 80% 10%, rgba(249,115,22,.20), transparent 60%);pointer-events:none}
.hero-inner{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:26px;padding:34px 0 26px;align-items:center}
.hero h1{margin:0 0 10px;font-size:44px;line-height:1.06;letter-spacing:-.02em}
.hero p{margin:0 0 16px;opacity:.95;font-weight:650}
.hero-illustration{border-radius:22px;overflow:hidden;border:1px solid rgba(255,255,255,.18);box-shadow:0 24px 60px rgba(2,6,23,.28)}
.hero-cta{background:#fff;color:var(--ink);border-radius:var(--radius2);box-shadow:0 26px 70px rgba(2,6,23,.25);padding:18px}

.badges{display:flex;gap:10px;flex-wrap:wrap;margin:12px 0 0}
.badge{font-size:12px;font-weight:900;padding:8px 10px;border-radius:999px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22)}
.badge.orange{background:rgba(249,115,22,.18);border-color:rgba(249,115,22,.22)}

label{display:block;font-size:12px;font-weight:900;color:#334155;margin:0 0 6px}
input,select,textarea{width:100%;padding:12px 12px;border:1px solid rgba(15,23,42,.14);border-radius:14px;font-size:15px;outline:none}
textarea{min-height:96px;resize:vertical}
input:focus,select:focus,textarea:focus{border-color:rgba(11,79,203,.55);box-shadow:0 0 0 4px rgba(11,79,203,.12)}
.form-gap{display:grid;gap:10px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form-note{margin-top:10px;font-size:12px;color:#475569;font-weight:650}
.step{display:none}
.step.active{display:block}
.stepper{display:flex;gap:8px;margin:2px 0 12px}
.dot{width:10px;height:10px;border-radius:999px;background:rgba(15,23,42,.18)}
.dot.active{background:var(--orange)}

.section{padding:40px 0}
.section h2{margin:0 0 14px;font-size:24px;letter-spacing:-.01em}
.muted{color:var(--muted);font-weight:650}

.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px}
.kpi{background:rgba(255,255,255,.94);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;display:flex;gap:12px;align-items:center}
.icon{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;background:rgba(11,79,203,.10);border:1px solid rgba(11,79,203,.14);font-weight:900;color:var(--blue)}
.kpi strong{display:block}
.kpi span{display:block;color:var(--muted);font-weight:700;font-size:12px;margin-top:2px}

.card-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.cat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px}
.cat .thumb{height:56px;border-radius:16px;background:linear-gradient(135deg, rgba(11,79,203,.10), rgba(249,115,22,.12));border:1px solid rgba(15,23,42,.10);margin-bottom:10px;display:grid;place-items:center;font-weight:900;color:#0b4fcb}
.cat strong{display:block}
.cat:hover{border-color:rgba(249,115,22,.28)}

.stats{background:#fff;border:1px solid var(--border);border-radius:var(--radius2);padding:18px}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;text-align:center}
.stat{padding:12px;border-radius:18px;background:rgba(244,247,251,.85);border:1px solid rgba(15,23,42,.08)}
.stat .num{font-size:34px;font-weight:950;color:var(--orange)}
.stat .lbl{font-weight:850}
.stat .sub{font-size:12px;color:var(--muted);font-weight:700;margin-top:6px}

.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.review{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px}
.stars{color:var(--orange);letter-spacing:1px;font-weight:900}
.review .who{margin-top:10px;font-weight:900}
.review .meta{color:var(--muted);font-weight:700;font-size:12px}

.faq{display:grid;gap:10px}
details{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px}
summary{cursor:pointer;font-weight:900}
details p{margin:10px 0 0;color:var(--muted);font-weight:650}

.seo{background:#fff;border:1px solid var(--border);border-radius:var(--radius2);padding:18px}
.seo h3{margin:18px 0 8px}
.seo p{color:var(--muted);font-weight:650}
.seo ul{color:var(--muted);font-weight:650}

footer{background:linear-gradient(180deg,var(--blue-dark),#042a72);color:#fff;padding:34px 0 26px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:16px}
footer a{opacity:.92}
footer a:hover{opacity:1;text-decoration:underline;text-underline-offset:6px}
.footer-small{margin-top:16px;font-size:12px;opacity:.85}
.social{display:flex;gap:10px;margin-top:10px}
.social a{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.06)}

@media (max-width:980px){
  .hero-inner{grid-template-columns:1fr}
  .hero h1{font-size:38px}
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .kpis{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .mega-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:520px){
  .form-row{grid-template-columns:1fr}
  .mega-grid{grid-template-columns:1fr}
}

.cat .thumbimg{width:100%;height:70px;object-fit:cover;border-radius:16px;border:1px solid rgba(15,23,42,.10);margin-bottom:10px;background:#f6f8fb}

.seo-boxes{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:14px}
.seo-box{background:rgba(244,247,251,.75);border:1px solid rgba(15,23,42,.10);border-radius:18px;padding:14px}
.seo-box h3{margin:8px 0 6px}
.seo-box ul{margin:10px 0 0;padding-left:18px}
.seo-box li{margin:4px 0}
.seo-badge{display:inline-flex;align-items:center;font-size:12px;font-weight:950;padding:6px 10px;border-radius:999px;background:rgba(249,115,22,.14);border:1px solid rgba(249,115,22,.20);color:#7a3406}
.seo-callout{margin-top:14px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px;border-radius:18px;background:linear-gradient(135deg, rgba(11,79,203,.08), rgba(249,115,22,.10));border:1px solid rgba(15,23,42,.10)}
@media (max-width:980px){.seo-boxes{grid-template-columns:1fr}}

/* Category pages */
.cat-hero{padding:26px 0 10px; background:linear-gradient(180deg, rgba(11,79,203,.08), rgba(255,255,255,0)); border-bottom:1px solid rgba(15,23,42,.08)}
.cat-hero-inner{display:grid; grid-template-columns:1.15fr .85fr; gap:18px; align-items:center}
.cat-hero .lead{font-size:16px; color:rgba(15,23,42,.75); margin:10px 0 12px}
.cat-hero-media img{width:100%; height:auto; border-radius:18px; border:1px solid rgba(15,23,42,.10); background:#f6f8fb}
.crumbs{font-size:13px; color:rgba(15,23,42,.65); margin-bottom:8px; display:flex; gap:8px; flex-wrap:wrap; align-items:center}
.crumbs a{color:inherit; text-decoration:none}
.crumbs span{opacity:.5}
.hero-actions{display:flex; gap:10px; flex-wrap:wrap; margin:12px 0}
.btn.ghost{background:transparent; border:1px solid rgba(15,23,42,.14); color:#0f172a}
.hero-badges{display:flex; gap:8px; flex-wrap:wrap; margin-top:10px}

/* Layout */
.cat-layout{display:grid; grid-template-columns:1fr 360px; gap:16px; align-items:start}
.cat-main .section-card{margin-bottom:14px}
.cat-aside .card{margin-bottom:14px}
@media (max-width:980px){
  .cat-hero-inner{grid-template-columns:1fr}
  .cat-layout{grid-template-columns:1fr}
}

/* Cards & utilities */
.card{background:rgba(255,255,255,.9); border:1px solid rgba(15,23,42,.10); border-radius:18px; padding:14px}
.section-card h2{margin:0 0 10px}
.grid-2{display:grid; grid-template-columns:repeat(2,1fr); gap:12px}
@media (max-width:700px){.grid-2{grid-template-columns:1fr}}
.callout{margin:12px 0; padding:12px; border-radius:16px; background:linear-gradient(135deg, rgba(249,115,22,.10), rgba(11,79,203,.08)); border:1px solid rgba(15,23,42,.10)}
.divider{height:1px; background:rgba(15,23,42,.10); margin:12px 0}
.sticky{position:sticky; top:14px}

/* TOC */
.toc-title{font-weight:900; margin-bottom:8px}
.toc a{display:block; padding:8px 10px; border-radius:12px; text-decoration:none; color:#0f172a; border:1px solid rgba(15,23,42,.08); margin:6px 0; background:rgba(244,247,251,.6)}
.toc a:hover{background:rgba(11,79,203,.08)}

/* CTA */
.cta-banner{display:flex; align-items:center; justify-content:space-between; gap:12px; padding:14px; border-radius:18px; border:1px solid rgba(15,23,42,.10); background:linear-gradient(135deg, rgba(11,79,203,.10), rgba(249,115,22,.10))}
.cta-banner span{display:block; color:rgba(15,23,42,.70); margin-top:2px}

/* Steps */
.steps{display:grid; grid-template-columns:repeat(2,1fr); gap:12px}
.step-card{display:flex; gap:10px; align-items:flex-start; padding:12px; border-radius:16px; border:1px solid rgba(15,23,42,.10); background:rgba(244,247,251,.6)}
.step-nr{width:34px; height:34px; border-radius:12px; display:flex; align-items:center; justify-content:center; font-weight:950; background:rgba(249,115,22,.14); border:1px solid rgba(249,115,22,.20); color:#7a3406}
@media (max-width:700px){.steps{grid-template-columns:1fr}}

/* Checklist */
.checklist{padding-left:18px}
.checklist li{margin:8px 0}

/* Pills */
.pill-grid{display:flex; flex-wrap:wrap; gap:8px}
.pill{display:inline-flex; align-items:center; padding:8px 10px; border-radius:999px; text-decoration:none; border:1px solid rgba(15,23,42,.12); background:rgba(255,255,255,.8); color:#0f172a}
.pill:hover{background:rgba(11,79,203,.08)}

/* Related mini cards */
.mini-grid{display:grid; grid-template-columns:1fr; gap:10px; margin-top:10px}
.mini-card{display:flex; flex-direction:column; gap:2px; padding:10px 12px; border-radius:16px; text-decoration:none; border:1px solid rgba(15,23,42,.10); background:rgba(244,247,251,.55); color:#0f172a}
.mini-card span{color:rgba(15,23,42,.65); font-size:13px}
.mini-card:hover{background:rgba(11,79,203,.08)}

/* FAQ */
.faq-item{border:1px solid rgba(15,23,42,.10); border-radius:16px; padding:10px 12px; background:rgba(255,255,255,.85); margin:10px 0}
.faq-item summary{cursor:pointer; font-weight:900}
.faq-item p{margin:10px 0 0; color:rgba(15,23,42,.75)}

.section-card .lead{font-size:16px; color:rgba(15,23,42,.78); margin:6px 0 12px}

.form-card{padding:18px 18px 16px}
.form-card-head{margin-bottom:10px}
.form-card-head h2{margin:0 0 6px;font-size:22px;letter-spacing:-.01em}
.form-card-head .muted{font-weight:650}
.form-card .btn{cursor:pointer}
@media (max-width:900px){
  .form-row{grid-template-columns:1fr}
}

.all-communes{margin-top:12px}
.all-communes summary{cursor:pointer; user-select:none; padding:10px 12px; border-radius:12px; background:rgba(15,23,42,.04); list-style:none}
.all-communes summary::-webkit-details-marker{display:none}
.all-communes summary .muted{font-weight:700; margin-left:6px; opacity:.75}

/* Right column: keep TOC + related categories together without overlapping */
.cat-aside .aside-sticky{
  position: sticky;
  top: 14px;
  z-index: 20;
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-height: calc(100vh - 24px);
  overflow: auto;
  padding-bottom: 10px;
}
.cat-aside .aside-sticky .card{flex: 0 0 auto}
@media (max-width: 980px){
  .cat-aside .aside-sticky{
    position: static;
    max-height: none;
    overflow: visible;
  }
}
