:root{
  --navy:#0b2447;
  --navy-2:#19376d;
  --navy-3:#576cbc;
  --gold:#e6a23c;
  --gold-2:#c98a1f;
  --orange:#ff7a45;
  --ink:#1c2333;
  --muted:#5b6478;
  --paper:#fffaf3;
  --bg:#f6f3ec;
  --line:#e3dccd;
  --ok:#1f8a55;
  --err:#b1322a;
  --max:1120px;
  --radius:10px;
  --shadow:0 4px 18px rgba(11,36,71,.08);
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font:16px/1.55 system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);
  background:var(--bg);
  touch-action:manipulation;
}

img,svg{max-width:100%;height:auto;display:block}
a{color:var(--navy-2)}
a:hover{color:var(--gold-2)}

.container{max-width:var(--max);margin:0 auto;padding:0 16px;width:100%}
.main-content{padding:24px 16px 48px;min-height:60vh}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;left:-9999px;background:var(--navy);color:#fff;padding:8px 12px;z-index:9999}
.skip-link:focus{left:8px;top:8px}

.topbar{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-2) 100%);color:#fff;box-shadow:var(--shadow)}
.topbar-inner{display:flex;align-items:center;gap:16px;padding:14px 16px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:0;color:#fff;text-decoration:none;font-weight:700;font-size:1.15rem;letter-spacing:.2px}
.brand:hover{color:var(--gold)}
.brand-strong{font-weight:800}
.brand-light{font-weight:500;color:var(--gold)}

.topsearch{flex:1 1 280px;display:flex;gap:6px;max-width:520px;position:relative}
.ac-wrap{flex:1;position:relative}
.topsearch input[type=search]{width:100%;padding:9px 12px;border-radius:6px;border:1px solid transparent;font:inherit;background:#fff}
.topsearch button{padding:9px 14px;border:0;border-radius:6px;background:var(--gold);color:var(--navy);font-weight:700;cursor:pointer}
.topsearch button:hover{background:var(--gold-2);color:#fff}

.ac-list{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:0 12px 32px rgba(11,36,71,.18);list-style:none;padding:6px 0;margin:0;max-height:62vh;overflow-y:auto;z-index:1000;color:var(--ink)}
.ac-head{padding:8px 14px 4px;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);border-top:1px solid var(--line)}
.ac-head:first-child{border-top:0}
.ac-item{padding:8px 14px;cursor:pointer;display:flex;flex-direction:column;gap:1px;line-height:1.3;border-left:3px solid transparent}
.ac-item:hover,.ac-item.is-active{background:var(--paper);border-left-color:var(--gold)}
.ac-label{color:var(--navy);font-weight:600}
.ac-label mark{background:#fff3d6;color:var(--gold-2);font-weight:700;padding:0 1px;border-radius:2px}
.ac-meta{color:var(--muted);font-size:.85rem}
.ac-item.ac-kind-evenement .ac-label::before{content:"★ ";color:var(--gold-2)}
.ac-item.ac-kind-ville .ac-label::before{content:"⌖ ";color:var(--navy-3)}
.ac-item.ac-kind-cp .ac-label::before{content:"# ";color:var(--navy-3)}
.ac-item.ac-kind-departement .ac-label::before{content:"▣ ";color:var(--navy-3)}
.ac-item.ac-kind-region .ac-label::before{content:"◈ ";color:var(--navy-3)}
.ac-empty{padding:14px;color:var(--muted);font-style:italic;text-align:center}

.topnav{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.topnav a{color:#fff;text-decoration:none;font-weight:500}
.topnav a:hover{color:var(--gold)}
.topnav a.cta{background:var(--gold);color:var(--navy);font-weight:700;padding:7px 14px;border-radius:6px;transition:background .15s}
.topnav a.cta:hover{background:#fff;color:var(--navy);box-shadow:0 0 0 2px var(--gold)}

.breadcrumb{background:#fff;border-bottom:1px solid var(--line)}
.breadcrumb ol{list-style:none;padding:10px 0;margin:0;display:flex;gap:6px;flex-wrap:wrap;font-size:.92rem}
.breadcrumb li+li::before{content:"›";margin-right:6px;color:var(--muted)}
.breadcrumb a{color:var(--navy-2);text-decoration:none}
.breadcrumb a:hover{text-decoration:underline}

h1{font-size:2rem;color:var(--navy);margin:.2em 0 .4em;line-height:1.18}
h1 small{color:var(--muted);font-weight:400;font-size:.7em}
h2{font-size:1.4rem;color:var(--navy);margin:1.6em 0 .6em;border-bottom:2px solid var(--gold);padding-bottom:6px;display:inline-block}
h3{font-size:1.05rem;margin:.4em 0}
p.lead{font-size:1.05rem;color:var(--muted)}
p.lead-small{font-size:.92rem;color:var(--muted);margin:-2px 0 14px}
p.lead-small strong{color:var(--navy)}

.hero{padding:24px 0 8px}
.hero h1{font-size:2.2rem}
.hero-sub{color:var(--muted);font-size:1.1rem;max-width:680px}
.hero-search{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px;background:#fff;padding:10px;border-radius:var(--radius);box-shadow:var(--shadow);max-width:760px}
.hero-search input[type=search],.hero-search select{flex:1;min-width:160px;padding:10px 12px;border:1px solid var(--line);border-radius:6px;font:inherit;background:#fff}
.hero-search button{padding:10px 18px;border:0;border-radius:6px;background:var(--navy);color:#fff;font-weight:700;cursor:pointer}
.hero-search button:hover{background:var(--navy-2)}

.search-results{margin-top:14px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:12px;max-width:760px;box-shadow:var(--shadow)}
.search-results .sr-item{padding:8px 4px;border-bottom:1px solid var(--line)}
.search-results .sr-item:last-child{border-bottom:0}
.search-results a{color:var(--navy);font-weight:600;text-decoration:none}
.search-results a:hover{color:var(--gold-2)}
.search-results .sr-meta{font-size:.88rem;color:var(--muted)}

.map-section{margin:28px 0 8px}
.map-canvas{height:480px;width:100%;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);background:#eaeaea;touch-action:none}
.map-canvas .leaflet-container{touch-action:none}
.map-canvas.map-region,.map-canvas.map-dept{height:420px}
.map-canvas.map-ville,.map-canvas.map-event{height:360px}
.map-caption{margin:8px 0 0;text-align:center;font-size:.92rem;color:var(--muted);font-style:italic}
.leaflet-popup-content{font:14px/1.4 system-ui,-apple-system,sans-serif}
.popup-titre{font-weight:700;color:var(--navy);display:block;margin-bottom:4px}
.popup-meta{color:var(--muted);font-size:.88rem}
.popup-link{display:inline-block;margin-top:6px;color:var(--gold-2);font-weight:600;text-decoration:none}

.upcoming{margin-top:28px}
.event-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.event-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .15s,box-shadow .15s}
.event-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.event-link{display:block;padding:14px 16px;text-decoration:none;color:inherit}
.event-cat{display:inline-block;background:var(--gold);color:var(--navy);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px;padding:3px 8px;border-radius:4px;margin-bottom:8px}
.event-cat-big{background:var(--gold);color:var(--navy);font-weight:700;display:inline-block;padding:6px 14px;border-radius:4px}
.event-meta{color:var(--muted);font-size:.92rem;margin:.3em 0 0;display:flex;flex-direction:column;gap:2px}
.event-meta-big{color:var(--muted);font-size:1.05rem;margin:8px 0 6px}
.event-recurrence{margin:0;color:var(--navy);background:var(--paper);border-left:4px solid var(--gold);padding:8px 14px;border-radius:4px 4px 0 0;display:block;font-size:.98rem}
.event-recurrence strong{color:var(--gold-2)}
.event-recurrence-note{margin:0 0 18px;color:var(--muted);background:var(--paper);border-left:4px solid var(--gold);padding:6px 14px 10px;border-radius:0 0 4px 4px;font-size:.9rem;font-style:italic}
.event-date{font-weight:600;color:var(--navy-2)}
.event-rel{display:inline-block;background:var(--navy-2);color:#fff;font-weight:700;font-size:.78rem;padding:1px 8px;border-radius:10px;letter-spacing:.2px}
.event-dist{display:inline-block;background:var(--gold);color:var(--navy);font-weight:700;font-size:.78rem;padding:1px 7px;border-radius:10px;margin-left:2px;letter-spacing:.2px}

.event-card{position:relative}
.btn-fav-star{position:absolute;top:6px;right:6px;background:rgba(255,255,255,.9);border:1px solid var(--line);border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;font-size:1rem;cursor:pointer;color:var(--muted);transition:color .15s,background .15s,transform .15s;z-index:2;padding:0}
.btn-fav-star:hover{color:var(--gold-2);background:var(--paper);transform:scale(1.1)}
.btn-fav-star.is-fav{color:var(--gold-2);background:#fff7e1;border-color:var(--gold)}

.hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.btn-light{background:#fff;color:var(--navy);border:1px solid var(--line);text-decoration:none}
.btn-light:hover{background:var(--paper);color:var(--gold-2)}
.btn-geo{background:var(--gold);color:var(--navy);font-weight:700}
.btn-geo:hover{background:var(--gold-2);color:#fff}
.btn-geo:disabled{opacity:.7;cursor:default}

.near-me{margin-top:24px}
.near-me h2{margin-top:0}
.near-status{color:var(--muted);margin-bottom:14px;font-style:italic}

.btn-fav,.btn-share{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;background:#fff;border:1px solid var(--line);color:var(--navy);font:inherit;font-weight:500;border-radius:30px;cursor:pointer;transition:background .15s,border-color .15s}
.btn-fav:hover,.btn-share:hover{background:var(--paper);border-color:var(--gold)}
.btn-fav.is-fav{background:#fff7e1;border-color:var(--gold);color:var(--gold-2)}
.btn-fav.is-fav .fav-star{color:var(--gold-2)}
.fav-star{font-size:1.1rem}
.btn-share.is-copied{background:#e7f5ee;border-color:#1f8a55;color:#1f8a55}

.dept-grid a{position:relative}
.dept-count{margin-left:auto;background:var(--navy);color:#fff;border-radius:12px;padding:2px 9px;font-size:.78rem;font-weight:700;min-width:24px;text-align:center}
.dept-grid a:hover .dept-count{background:var(--gold-2)}

.sort-bar{display:flex;align-items:center;gap:8px;margin:0 0 18px;flex-wrap:wrap;font-size:.92rem}
.sort-label{color:var(--muted)}
.sort-bar a{padding:5px 12px;background:#fff;border:1px solid var(--line);border-radius:20px;text-decoration:none;color:var(--navy);transition:background .15s,color .15s}
.sort-bar a:hover{background:var(--paper);color:var(--gold-2)}
.sort-bar a.is-active{background:var(--navy);color:#fff;border-color:var(--navy)}
.sort-bar .is-disabled{padding:5px 12px;background:#f4f1ea;border:1px solid var(--line);border-radius:20px;color:#aaa;cursor:not-allowed;font-size:.92rem}

.similar-events{grid-column:1/-1;margin-top:24px}
.similar-events h2{font-size:1.3rem;border-bottom:2px solid var(--gold);padding-bottom:6px;display:inline-block}

.favoris{margin-top:18px}
.favoris-tools{margin-top:24px;text-align:center}

.btn-more{display:inline-block;margin:18px 0 0;padding:10px 22px;background:var(--navy);color:#fff;border:0;border-radius:6px;font:inherit;font-weight:600;cursor:pointer}
.btn-more:hover{background:var(--navy-2)}
.btn-more:disabled{opacity:.5;cursor:not-allowed}

.regions{margin-top:36px}
.region-grid{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}
.region-grid a{display:block;padding:12px 14px;background:#fff;border:1px solid var(--line);border-left:4px solid var(--gold);border-radius:6px;color:var(--navy);text-decoration:none;font-weight:600;transition:background .15s,border-color .15s}
.region-grid a:hover{background:var(--paper);border-left-color:var(--orange)}

.dept-grid{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}
.dept-grid a{display:flex;align-items:center;gap:10px;padding:11px 14px;background:#fff;border:1px solid var(--line);border-radius:6px;text-decoration:none;color:var(--navy);font-weight:500}
.dept-grid a:hover{background:var(--paper);color:var(--gold-2)}
.dept-cp{background:var(--navy);color:#fff;border-radius:4px;padding:3px 8px;font-size:.85rem;font-weight:700;min-width:34px;text-align:center}

.city-grid{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:8px}
.city-grid a{display:flex;justify-content:space-between;align-items:center;gap:6px;padding:9px 12px;background:#fff;border:1px solid var(--line);border-radius:6px;text-decoration:none;color:var(--navy)}
.city-grid a:hover{background:var(--paper);color:var(--gold-2)}
.city-cp{color:var(--muted);font-size:.85rem;white-space:nowrap}
.nearby-villes{margin-top:32px}
.nearby-villes h2{font-size:1.3rem;border-bottom:2px solid var(--gold);padding-bottom:6px;display:inline-block;margin-bottom:14px}
.nearby-villes .city-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr))}
.nearby-villes .city-grid a{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:10px 14px}
.nearby-villes .city-grid .city-nom{font-weight:600;font-size:.98rem;color:var(--navy);word-break:break-word;line-height:1.25}
.nearby-villes .city-grid .city-cp{font-size:.82rem;color:var(--muted);white-space:nowrap}
.nearby-villes .city-grid .city-dist{display:inline-block;margin-top:4px;font-size:.78rem;font-weight:700;color:var(--gold-2);background:var(--paper);border:1px solid var(--line);padding:1px 8px;border-radius:10px}

.event-detail{display:grid;grid-template-columns:minmax(0,2fr) minmax(220px,1fr);gap:24px;align-items:start}
.event-detail>header{grid-column:1/-1}
.event-body{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px;line-height:1.65;font-size:1.02rem}
.event-side{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.event-side h2{margin-top:0;font-size:1.1rem;border-bottom:2px solid var(--gold);display:block}
.event-infos{margin:0}
.event-infos dt{font-weight:700;color:var(--navy);margin-top:10px}
.event-infos dd{margin:2px 0 0;color:var(--ink)}
.event-detail .map-section{grid-column:1/-1}
.event-disclaimer{grid-column:1/-1;background:#fff7e6;border:1px solid #f0d294;border-left:5px solid var(--orange);border-radius:6px;padding:14px 18px;margin-top:18px;color:var(--ink);font-size:.96rem;line-height:1.55}
.event-disclaimer p{margin:0}
.event-disclaimer strong{color:var(--err)}
.event-disclaimer a{color:var(--navy-2);font-weight:600;text-decoration:underline}
.event-disclaimer a:hover{color:var(--gold-2)}

.like-row{grid-column:1/-1;display:flex;align-items:center;gap:14px;margin:24px 0 6px;flex-wrap:wrap}
.btn-like{display:inline-flex;align-items:center;gap:10px;padding:10px 18px;background:#fff;border:2px solid var(--gold);color:var(--navy);font:inherit;font-weight:600;font-size:1rem;border-radius:30px;cursor:pointer;transition:background .15s,color .15s,transform .1s}
.btn-like:hover:not(:disabled){background:var(--paper)}
.btn-like:active{transform:scale(.97)}
.btn-like .like-heart{font-size:1.3rem;color:var(--gold-2);transition:transform .25s}
.btn-like:hover:not(:disabled) .like-heart{transform:scale(1.2)}
.btn-like.is-liked{background:var(--gold);color:var(--navy)}
.btn-like.is-liked .like-heart{color:#b1322a}
.btn-like:disabled{cursor:default;opacity:.92}
.btn-like .like-count{background:rgba(11,36,71,.08);padding:2px 10px;border-radius:12px;font-weight:700;min-width:24px;text-align:center;font-size:.92rem}
.btn-like.is-liked .like-count{background:rgba(255,255,255,.4)}
.like-helper{color:var(--muted);font-size:.92rem}

.comments{grid-column:1/-1;margin-top:14px}
.comments h2{font-size:1.3rem;border-bottom:2px solid var(--gold);padding-bottom:6px;display:inline-block}
.comments h2 small{color:var(--muted);font-weight:400;font-size:.85em}
.comment-list{list-style:none;padding:0;margin:18px 0 0;display:flex;flex-direction:column;gap:12px}
.comment-item{background:#fff;border:1px solid var(--line);border-radius:8px;padding:12px 16px;transition:opacity .25s}
.comment-item.is-masked{opacity:.45}
.comment-item header{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;font-size:.9rem;color:var(--muted);margin-bottom:6px}
.comment-pseudo{color:var(--navy);font-weight:700;font-size:1rem}
.comment-date{color:var(--muted);font-size:.85rem}
.comment-body{margin:0;line-height:1.5;color:var(--ink)}
.btn-flag{margin-left:auto;background:none;border:0;color:var(--muted);font:inherit;font-size:.82rem;cursor:pointer;text-decoration:underline;padding:2px 6px}
.btn-flag:hover{color:var(--err)}
.btn-flag.is-flagged{color:var(--err);text-decoration:none;cursor:default}
.btn-flag:disabled{cursor:default}

.form-comment{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:16px 20px;margin-top:24px;display:grid;gap:12px}
.form-comment h3{margin:0 0 4px;color:var(--navy);font-size:1.05rem}
.form-comment .field{display:flex;flex-direction:column;gap:5px}
.form-comment .field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-comment label{font-weight:600;color:var(--navy);font-size:.92rem}
.form-comment label.with-counter{display:flex;justify-content:space-between;align-items:center}
.form-comment label small{color:var(--muted);font-weight:400;margin-left:2px}
.form-comment input,.form-comment textarea{padding:9px 12px;border:1px solid var(--line);border-radius:6px;font:inherit;background:#fff}
.form-comment input:focus,.form-comment textarea:focus{outline:2px solid var(--gold);border-color:var(--gold)}
.form-comment textarea{resize:vertical;min-height:90px}
.form-comment .form-actions{display:flex;justify-content:flex-end}
.form-comment .form-actions button{padding:10px 20px;background:var(--navy);color:#fff;border:0;border-radius:6px;font:inherit;font-weight:700;cursor:pointer}
.form-comment .form-actions button:hover{background:var(--navy-2)}

@media (max-width:620px){
  .form-comment .field-row{grid-template-columns:1fr}
  .like-row{justify-content:center}
}

.empty{padding:14px;background:#fff;border:1px dashed var(--line);border-radius:6px;color:var(--muted)}

.contact-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin-top:8px}
.contact-card h2{margin-top:0}
.contact-card address{font-style:normal;color:var(--navy);font-weight:600}

.legal-block{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:8px 22px 18px;margin-top:18px}
.legal-block h2{font-size:1.1rem;margin:18px 0 6px}
.legal-block h2:first-child{margin-top:8px}
.legal-block h3{font-size:1rem;color:var(--navy-2);margin:14px 0 4px}
.legal-block p{margin:4px 0 8px}
.legal-block .info-list{margin:2px 0 6px}
.legal-block .info-list li{padding:3px 0;font-size:.95rem}
.legal-block-more{margin-top:18px;padding-top:12px;border-top:1px dashed var(--line);font-size:.95rem;color:var(--muted)}
.legal-block-more a{font-weight:600}
.page-mentions h2{margin-top:1.8em}
.page-mentions h3{font-size:1.05rem;color:var(--navy-2);margin:1.2em 0 .4em;border-bottom:1px dashed var(--line);padding-bottom:4px}
.page-mentions .lead{color:var(--muted);font-style:italic}

.form-contact{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px;margin-top:24px;display:grid;gap:14px;max-width:680px}
.form-contact h2{margin-top:0}

.form-proposer{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:8px 28px 28px;margin-top:18px;max-width:860px}
.form-proposer fieldset{border:0;border-top:1px solid var(--line);padding:26px 0 12px;margin:0 0 8px}
.form-proposer fieldset:first-of-type{border-top:0;padding-top:14px}
.form-proposer [hidden]{display:none !important}
.form-proposer legend{font-size:1.12rem;font-weight:700;color:var(--navy);padding:0 12px 0 0;background:#fff;margin-bottom:6px}
.form-proposer .field{display:flex;flex-direction:column;gap:7px;margin:18px 0}
.form-proposer .field-row{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin:18px 0}
.form-proposer .field-row.row-ville-pays{grid-template-columns:3fr 1fr}
.form-proposer .field-row.row-cp-dept{grid-template-columns:180px 1fr}
.form-proposer .field-cp{max-width:180px}
.form-proposer .field-row .field{margin:0}
.form-proposer label{font-weight:600;color:var(--navy);font-size:.95rem}
.form-proposer label small{color:var(--muted);font-weight:400}
.form-proposer .hint{color:var(--muted);font-size:.85rem;margin-top:2px}
.form-proposer input,.form-proposer select,.form-proposer textarea{padding:10px 12px;border:1px solid var(--line);border-radius:6px;font:inherit;background:#fff}
.form-proposer input:focus,.form-proposer select:focus,.form-proposer textarea:focus{outline:2px solid var(--gold);border-color:var(--gold)}
.form-proposer textarea{resize:vertical;min-height:120px}
.form-proposer .form-actions{display:flex;flex-direction:column;align-items:flex-end;gap:8px;margin-top:18px;border-top:1px solid var(--line);padding-top:18px}
.form-proposer .form-actions button{padding:12px 24px;background:var(--navy);color:#fff;border:0;border-radius:6px;font:inherit;font-weight:700;cursor:pointer;font-size:1.02rem}
.form-proposer .form-actions button:hover{background:var(--navy-2)}
.form-proposer .form-actions .hint{color:var(--muted);font-size:.83rem}

.publish-notice{background:var(--paper);border:1px solid var(--gold);border-left:4px solid var(--gold);border-radius:6px;padding:14px 18px;margin:14px 0 24px}
.publish-notice h2{margin:0 0 6px;font-size:1.05rem;color:var(--navy);border:0;padding:0;display:block}
.publish-notice p{margin:4px 0}
.publish-notice ul{margin:6px 0 8px 22px;padding:0}
.publish-notice li{margin:3px 0}
.publish-notice strong{color:var(--navy-2)}

.pub-tag{display:inline-block;padding:1px 7px;border-radius:3px;font-size:.7rem;font-weight:600;margin-left:6px;vertical-align:middle;letter-spacing:.3px;text-transform:uppercase}
.pub-tag.tag-pub{background:#e7f5ee;color:#1f8a55;border:1px solid #b5dec6}
.pub-tag.tag-priv{background:#fcf1e3;color:#a86b1c;border:1px solid #f0d294}

.info-box{margin:8px 0 0;padding:8px 12px;background:#eef4ff;border-left:3px solid var(--navy-3);border-radius:4px;color:var(--navy);font-size:.92rem}
.info-box strong{color:var(--navy-2)}

.char-counter{display:inline-block;padding:1px 8px;border-radius:10px;background:#f7eedb;color:#a86b1c;font-weight:600;font-size:.8rem;border:1px solid #f0d294}
.char-counter.counter-ok{background:#e7f5ee;color:#1f8a55;border-color:#b5dec6}

.form-proposer .radio-group{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:14px 0 8px}
.form-proposer .radio-box{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border:2px solid var(--line);border-radius:8px;cursor:pointer;transition:border-color .15s,background .15s}
.form-proposer .radio-box:hover{background:var(--paper)}
.form-proposer .radio-box input[type=radio]{margin-top:3px}
.form-proposer .radio-box span{flex:1}
.form-proposer .radio-box small{display:block;color:var(--muted);font-weight:400;margin-top:2px;font-size:.85rem}
.form-proposer .radio-box:has(input:checked){border-color:var(--gold);background:var(--paper)}

.map-canvas.map-proposer{height:320px;margin-top:6px;display:flex;align-items:center;justify-content:center}
.map-proposer .map-placeholder{margin:0;color:var(--muted);font-style:italic;text-align:center;padding:20px}

.btn-link{display:inline-block;margin-top:8px;padding:6px 12px;background:none;border:1px solid var(--line);border-radius:4px;color:var(--navy-2);font:inherit;font-size:.88rem;cursor:pointer}
.btn-link:hover{background:var(--paper);color:var(--gold-2)}

@media (max-width:620px){
  .form-proposer .field-row,
  .form-proposer .field-row.row-ville-pays,
  .form-proposer .field-row.row-cp-dept{grid-template-columns:1fr}
  .form-proposer .field-row .field-cp,
  .form-proposer .field-cp{max-width:none}
  .form-proposer .radio-group{grid-template-columns:1fr}
}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-weight:600;color:var(--navy)}
.field input,.field textarea{padding:10px 12px;border:1px solid var(--line);border-radius:6px;font:inherit;background:#fff}
.field input:focus,.field textarea:focus{outline:2px solid var(--gold);border-color:var(--gold)}
.form-actions{display:flex;justify-content:flex-end}
.form-actions button{padding:11px 22px;background:var(--navy);color:#fff;border:0;border-radius:6px;font:inherit;font-weight:700;cursor:pointer}
.form-actions button:hover{background:var(--navy-2)}
.hp-field{position:absolute;left:-10000px;top:-10000px;width:1px;height:1px;opacity:0}

.alert{padding:12px 16px;border-radius:6px;margin:14px 0}
.alert-success{background:#e7f5ee;color:var(--ok);border:1px solid #b5dec6}
.alert-error{background:#fbeaea;color:var(--err);border:1px solid #ecb6b3}
.alert ul{margin:0;padding-left:20px}

.info-list{padding-left:0;list-style:none}
.info-list li{padding:5px 0;border-bottom:1px dashed var(--line)}
.info-list li:last-child{border-bottom:0}

.btn{display:inline-block;padding:10px 18px;background:var(--navy);color:#fff;text-decoration:none;border-radius:6px;font-weight:600;margin-right:10px}
.btn:hover{background:var(--navy-2);color:#fff}
.btn-secondary{background:var(--gold);color:var(--navy)}
.btn-secondary:hover{background:var(--gold-2);color:#fff}

.page-error{text-align:center;padding:60px 16px}
.page-error h1{font-size:2.8rem}

.osm-credit-inline{font-size:.85rem;color:var(--muted);background:var(--paper);border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:4px;padding:8px 14px;margin:8px 0 0;line-height:1.45}
.osm-credit-inline p{margin:0}

.site-footer{background:var(--navy);color:#dde3f0;margin-top:32px;padding:24px 0}
.footer-inner{display:flex;flex-direction:column;gap:12px;align-items:center;text-align:center}
.footer-nav{display:flex;gap:20px;flex-wrap:wrap;justify-content:center}
.footer-nav a{color:#fff;text-decoration:none}
.footer-nav a:hover{color:var(--gold)}
.footer-legal{font-size:.85rem;color:#b8c1d5}
.footer-legal p{margin:2px 0}
.footer-copy{margin:0;color:#9aa4bd;font-size:.85rem}

@media (max-width:760px){
  h1{font-size:1.6rem}
  .hero h1{font-size:1.8rem}
  .event-detail{grid-template-columns:1fr}
  .event-side{position:static}
  .topbar-inner{justify-content:center}
  .topsearch{order:3;width:100%}
  .topnav{order:2}
}
