/* e-mairie.fr — clean institutional theme */
:root{
  --accent:#0a6cb0;
  --ink:#15202b; --ink-soft:#475569; --muted:#64748b;
  --bg:#f6f8fb; --card:#ffffff; --line:#e3e9f0;
  --ok:#157a52; --ok-bg:#e7f6ee; --closed:#b04242;
  --radius:16px; --shadow:0 1px 2px rgba(16,32,64,.04),0 8px 24px rgba(16,32,64,.06);
  --maxw:1080px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.55;font-size:17px;-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
h1,h2,h3{line-height:1.2;margin:0 0 .4em}
.ic{width:22px;height:22px;flex:none}
.ic-sm{width:16px;height:16px;vertical-align:-2px}
.muted{color:var(--muted)}
.btn{display:inline-flex;align-items:center;gap:.5em;background:var(--accent);color:#fff;
  padding:.7em 1.15em;border-radius:999px;font-weight:600;border:1px solid transparent;transition:.15s}
.btn:hover{filter:brightness(1.06);text-decoration:none}
.btn.ghost{background:transparent;color:var(--accent);border-color:var(--line);background:#fff}
.btn.big{font-size:1.15rem;padding:.85em 1.6em}

/* Demo banner */
.demo-banner{background:#fff7e6;color:#7a5a14;border-bottom:1px solid #f0e0b8;
  font-size:.82rem;text-align:center;padding:7px 16px}

/* Commune hero */
.hero{background:linear-gradient(160deg,var(--accent),color-mix(in srgb,var(--accent) 70%,#082a4a));color:#fff;
  padding:34px 0 40px}
.hero-in{display:flex;gap:22px;align-items:center;flex-wrap:wrap}
.crest{width:74px;height:74px;border-radius:18px;background:rgba(255,255,255,.16);
  display:grid;place-items:center;font-size:2rem;font-weight:800;border:1px solid rgba(255,255,255,.25);flex:none}
.hero-txt{flex:1;min-width:240px}
.kicker{margin:0 0 4px;text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;opacity:.85}
.hero h1{font-size:clamp(1.7rem,4vw,2.5rem);margin:0 0 .25em}
.tagline{margin:.2em 0 1em;opacity:.92;max-width:48ch}
.hero-actions{display:flex;gap:10px;flex-wrap:wrap}
.hero .btn{background:#fff;color:var(--accent)}
.hero .btn.ghost{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.35)}
.open-badge{align-self:flex-start;font-weight:700;font-size:.9rem;padding:.45em .9em;border-radius:999px;
  background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.3)}
.open-badge.open{background:var(--ok-bg);color:var(--ok);border-color:transparent}
.open-badge.shut{background:#fdeaea;color:var(--closed);border-color:transparent}

/* Cards */
main{padding:28px 0 10px}
.grid-top{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:-30px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px 22px;box-shadow:var(--shadow)}
.card h3{display:flex;align-items:center;gap:.5em;font-size:1.08rem;color:var(--ink);margin-bottom:.7em}
.card h3 .ic{color:var(--accent)}
.contact-item{display:flex;gap:.6em;align-items:flex-start;color:var(--ink);padding:.4em 0;border-bottom:1px solid var(--line)}
.contact-item:last-of-type{border-bottom:0}
.contact-item .ic{color:var(--accent)}
.contact-item:hover{text-decoration:none;color:var(--accent)}
.maire,.pop{margin:.6em 0 0;color:var(--ink-soft);font-size:.92rem}
.pop{font-size:.85rem;color:var(--muted)}

.hours-table{width:100%;border-collapse:collapse}
.hours-table th,.hours-table td{text-align:left;padding:.42em 0;border-bottom:1px solid var(--line);font-weight:500}
.hours-table tr:last-child th,.hours-table tr:last-child td{border-bottom:0}
.hours-table th{color:var(--ink-soft);font-weight:600;width:40%}
.hours-table td.closed{color:var(--muted)}
.hours-table tr.today th,.hours-table tr.today td{color:var(--accent);font-weight:700}

.sec-title{margin:34px 0 14px;font-size:1.3rem}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}
.cards .card dl{margin:0}
.row{padding:.5em 0;border-bottom:1px solid var(--line)}
.row:last-child{border-bottom:0}
.row dt{font-weight:600;font-size:.86rem;color:var(--ink-soft);margin:0}
.row dd{margin:.15em 0 0;color:var(--ink)}
.note{margin:.8em 0 0;font-size:.86rem;color:var(--muted);background:#f1f5fa;padding:.6em .8em;border-radius:10px}
.cardlink{display:inline-flex;align-items:center;gap:.35em;margin-top:.8em;font-weight:600;font-size:.9rem}

/* Map */
.mapwrap{margin:30px 0 10px;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff;box-shadow:var(--shadow)}
.mapwrap iframe{width:100%;height:340px;border:0;display:block}
.maplink{display:block;padding:.7em 1em;font-weight:600;font-size:.9rem;border-top:1px solid var(--line)}

/* Footer */
.site-foot{margin-top:40px;padding:26px 0;border-top:1px solid var(--line);background:#fff}
.site-foot p{margin:.2em 0;font-size:.88rem}

/* Landing */
.landing{background:var(--bg)}
.lhero{background:linear-gradient(160deg,#0a6cb0,#0a3f70);color:#fff;padding:54px 0 60px}
.brand{display:flex;align-items:center;gap:.5em;font-weight:800;font-size:1.1rem;opacity:.95;margin:0 0 18px}
.lhero h1{font-size:clamp(2rem,5vw,3.2rem);margin:0 0 .35em;letter-spacing:-.01em}
.lhero .hl{color:#aee0ff}
.lead{font-size:1.12rem;max-width:60ch;opacity:.95}
.lead code,.steps code{background:rgba(255,255,255,.16);padding:.06em .4em;border-radius:6px;font-size:.92em}
.how code{background:#e7eef6;color:var(--ink)}
.lhero .btn{background:#fff;color:var(--accent)}
.lhero .btn.ghost{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.35)}
.live{margin-top:24px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.live .muted{color:rgba(255,255,255,.8)}
.commune-chip{display:inline-flex;align-items:center;gap:.5em;background:rgba(255,255,255,.14);color:#fff;
  padding:.45em .9em;border-radius:999px;font-weight:600;font-size:.92rem}
.commune-chip:hover{background:rgba(255,255,255,.24);text-decoration:none}
.commune-chip .dot{width:9px;height:9px;border-radius:50%}
.features{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;padding-top:46px;padding-bottom:10px}
.feature{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
.fic{width:46px;height:46px;border-radius:12px;background:#e9f2fb;color:var(--accent);display:grid;place-items:center;margin-bottom:12px}
.feature h3{font-size:1.05rem;margin-bottom:.3em}
.feature p{margin:0;color:var(--ink-soft);font-size:.95rem}
.how{padding-top:36px}
.steps{list-style:none;padding:0;margin:14px 0 0;display:grid;gap:14px}
.steps li{display:flex;gap:14px;align-items:baseline;background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.steps li span{flex:none;width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-weight:700;font-size:.9rem}
.cta{text-align:center;padding:52px 20px 60px}
.cta h2{font-size:1.6rem}
.cta p{color:var(--ink-soft);margin-bottom:1.2em}

@media (max-width:720px){
  body{font-size:16px}
  .grid-top{grid-template-columns:1fr;margin-top:-20px}
  .mapwrap iframe{height:260px}
}
@media (prefers-reduced-motion:no-preference){.btn{transition:.15s}}
