:root{
  --msp-green:#2E7D32;
  --msp-red:#C62828;
  --ink:#0b1220;
  --muted:#5b6b84;
  --line:rgba(11,18,32,.10);
  --soft:rgba(11,18,32,.06);
  --radius:18px;
  --shadow: 0 18px 50px rgba(2,6,23,.10);
  --shadow-soft: 0 12px 32px rgba(2,6,23,.08);
  --max: 1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Helvetica, Arial;
  color:var(--ink);
  background: radial-gradient(1200px 600px at 50% -10%, rgba(46,125,50,.10), #ffffff 60%) , #f6f8fb;
  font-size: 17px;
}

.container{max-width:var(--max);margin:0 auto;padding:20px}
.topbar{padding:8px 0 0}
h1{margin:14px 0 6px;font-size:30px;letter-spacing:-.02em}
.subtitle{margin:0 0 14px;color:var(--muted);font-size:15px}
.subtitle-note{color:rgba(91,107,132,.9)}
.msp-brand{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.msp-brand__logo{
  display:inline-flex;align-items:baseline;gap:0;
  font-weight:900;font-size:20px;letter-spacing:-.02em;
  color:var(--ink);text-decoration:none;
}
.msp-brand__logo span{color:var(--msp-green)}
.msp-brand__pill{
  display:inline-flex;align-items:center;
  padding:6px 10px;border-radius:999px;
  background:rgba(46,125,50,.10);
  border:1px solid rgba(46,125,50,.20);
  color:var(--msp-green);
  font-weight:700;font-size:12px;
}

/* Ads */
.ad-slot{
  margin:14px 0 0;
  border:1px solid var(--line);
  background:#fff;
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-soft);
  padding:10px;
}
.ad-slot.bottom{margin-top:18px}
.ad-slot img{display:block;width:100%;height:auto}

/* Search card */
.search-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:16px;
  box-shadow:var(--shadow);
}

.grid{
  display:grid;
  grid-template-columns:1fr 1fr 160px;
  gap:12px;
  align-items:end;
}
.grid.grid-4{grid-template-columns:1fr 1fr 170px 170px;}
@media (max-width:780px){
  .grid{grid-template-columns:1fr}
  .grid.grid-4{grid-template-columns:1fr}
}

label span{
  display:block;
  font-size:14px;
  color:var(--muted);
  margin:0 0 6px;
}

/* Autocomplete villes */
.with-suggest{position:relative}
.suggest{
  position:absolute;
  left:0;
  right:0;
  top:100%;
  margin-top:6px;
  z-index:50;
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  box-shadow:var(--shadow-soft);
  overflow:auto;
  max-height:260px;
}
.suggest .suggest-note{
  padding:8px 12px;
  font-size:12px;
  color:var(--muted);
  border-bottom:1px solid var(--line);
}
.suggest .suggest-item{
  padding:10px 12px;
  cursor:pointer;
  font-size:15px;
  color:var(--ink);
}
.suggest .suggest-item:hover,
.suggest .suggest-item[aria-selected="true"]{
  background:rgba(46,125,50,.10);
}
input{
  width:100%;
  padding:12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(11,18,32,.02);
  color:var(--ink);
  outline:none;
  font-size:17px;
}
input:focus{
  border-color: rgba(46,125,50,.55);
  box-shadow: 0 0 0 4px rgba(46,125,50,.12);
}

button{
  width:100%;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid transparent;
  background:var(--msp-green);
  color:#fff;
  font-weight:800;
  cursor:pointer;
  box-shadow: 0 10px 24px rgba(46,125,50,.18);
  font-size:16px;
}
button:active{transform:translateY(1px)}
button:hover{filter:brightness(.98)}
.btn-secondary{
  background:rgba(11,18,32,.02);
  border:1px solid var(--line);
  color:var(--ink);
  box-shadow:none;
}
.btn-secondary:hover{border-color:rgba(46,125,50,.35)}
.btn-secondary:disabled{
  opacity:.6;
  cursor:not-allowed;
}

#btnLoc{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
}
#btnLoc .gps-ico{width:18px;height:18px;fill:currentColor;flex:0 0 auto}

.row{
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:space-between;
  margin-top:12px;
  flex-wrap:wrap
}
.toggle{
  display:flex;
  gap:10px;
  align-items:center;
  color:var(--muted);
  font-size:13px
}
.meta{color:var(--muted);font-size:13px}
.hint{margin:10px 0 0;color:var(--muted);font-size:13px}

.hint-mini{margin-top:6px;font-size:12px}

/* Filters */
.filters{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
  margin-top:12px;
}

.chip{
  width:auto;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--ink);
  box-shadow:none;
  font-weight:800;
  font-size:13px;
}
.chip:hover{border-color:rgba(46,125,50,.35)}
.chip[aria-pressed="true"]{
  background:rgba(46,125,50,.12);
  border-color:rgba(46,125,50,.35);
  color:var(--msp-green);
}

.garde-panel{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:end;
}
.garde-panel label span{font-size:12px;margin-bottom:4px}
.garde-panel input{padding:10px;font-size:14px;border-radius:12px}

.chip-link{
  display:inline-flex;
  align-items:center;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid rgba(46,125,50,.35);
  background:rgba(46,125,50,.08);
  color:var(--msp-green);
  text-decoration:none;
  font-weight:800;
  font-size:13px;
}
.chip-link:hover{filter:brightness(.98)}

/* Results */
.results{
  margin-top:16px;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px
}
@media (max-width:980px){.results{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:620px){.results{grid-template-columns:1fr}}

.card{
  border:1px solid var(--line);
  background:#fff;
  border-radius:var(--radius);
  padding:14px;
  box-shadow:var(--shadow-soft)
}
.card h3{margin:0 0 8px;font-size:16px;letter-spacing:-.01em}

.badges{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 10px}
.badge{
  display:inline-flex;
  align-items:center;
  padding:4px 8px;
  border-radius:999px;
  font-size:11px;
  font-weight:900;
  letter-spacing:.01em;
  border:1px solid var(--line);
  background:rgba(11,18,32,.02);
  color:var(--ink);
}
.badge.green{background:rgba(46,125,50,.10);border-color:rgba(46,125,50,.22);color:var(--msp-green)}
.badge.red{background:rgba(198,40,40,.08);border-color:rgba(198,40,40,.22);color:var(--msp-red)}
.lines{margin:0;padding:0;list-style:none;color:var(--muted);font-size:13px}
.lines li{margin:6px 0}

.actions{
  margin-top:10px;
  display:flex;
  gap:10px;
  flex-wrap:wrap
}
.actions a{
  display:inline-block;
  padding:8px 10px;
  border-radius:12px;
  border:1px solid var(--line);
  color:var(--ink);
  text-decoration:none;
  font-size:13px;
  background:rgba(11,18,32,.01);
}
.actions a:hover{border-color:rgba(46,125,50,.35)}

.footer{padding-bottom:40px;color:var(--muted)}

/* --- Home button --- */
.msp-home{
  display:inline-flex;
  align-items:center;
  padding:8px 10px;
  border-radius:12px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--ink);
  text-decoration:none;
  font-weight:800;
  font-size:13px;
}
.msp-home:hover{ border-color: rgba(46,125,50,.35); }


.msp-network{
  margin-top:10px;
  padding-top:10px;
  border-top:1px dashed rgba(11,18,32,.14);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  font-weight:800;
  font-size:14px;
}
.msp-net-ico{
  width:28px;
  height:28px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  border:1px solid rgba(11,18,32,.15);
}
.msp-net-ico.ok{
  color:var(--msp-green);
  background:rgba(46,125,50,.10);
  border-color:rgba(46,125,50,.22);
}
.msp-net-ico.ko{
  color:#C62828;
  background:rgba(198,40,40,.08);
  border-color:rgba(198,40,40,.22);
}


.msp-modal-overlay{
  position:fixed; inset:0;
  background:rgba(0,0,0,.45);
  display:flex; align-items:center; justify-content:center;
  z-index:9999;
  padding:16px;
}
.msp-modal{
  background:#fff;
  width:min(520px, 100%);
  border-radius:18px;
  padding:18px 18px 14px;
  box-shadow:0 18px 50px rgba(0,0,0,.18);
  position:relative;
}
.msp-modal h3{ margin:0 0 8px; font-size:18px; }
.msp-modal p{ margin:0 0 14px; line-height:1.4; }
.msp-modal-actions{
  display:flex; gap:10px; flex-wrap:wrap;
}
.msp-modal-close{
  position:absolute; top:10px; right:10px;
  width:34px; height:34px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  font-size:18px;
  cursor:pointer;
}


.editorial{margin-top:14px}
.editorial-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:16px;
  box-shadow:var(--shadow-soft);
}
.editorial-card h2{margin:0 0 10px;font-size:18px;letter-spacing:-.01em}
.editorial-card h3{margin:0 0 6px;font-size:15px}
.editorial-card p{margin:10px 0;color:var(--muted);line-height:1.6;font-size:15px}
.editorial-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-top:10px
}
@media (max-width:900px){.editorial-grid{grid-template-columns:1fr}}
.editorial-box{
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:12px;
  background:rgba(11,18,32,.01);
}
.editorial-box ul{margin:8px 0 0;padding-left:18px;color:var(--muted);line-height:1.6;font-size:15px}
.editorial-note{margin-top:12px;font-size:13px;color:var(--muted)}
.faq{
  margin-top:12px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:10px 12px;
  background:#fff;
}
.faq summary{cursor:pointer;font-weight:900}
.faq-body{margin-top:10px}
