/* CAV — design Mint & Moss (din Brief_Design). Reconstruit pe tokenuri, nu copiat din mockup. */
:root{
  --moss:#1f4d3a; --mint:#3fae7d; --warm:#e8a33d; --coral:#e76f51;
  --bg:#f6f4ee; --card:#ffffff; --ink:#22312b; --muted:#647269; --line:#e4e1d7;
  --st-op:#2e9e6b;     /* operational = verde plin */
  --st-soon:#e8a33d;   /* se va deschide = chihlimbar */
  --st-none:#c7c7be;   /* fara CAV = gri */
  --cat-cav:#2e9e6b;
  --r:14px; --sh:0 2px 10px rgba(31,77,58,.08);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--bg);overflow:hidden}
h1,h2,h3,.brand,.chip,.btn{font-family:'Outfit','Inter',sans-serif}

/* layout */
.app{display:grid;grid-template-rows:auto auto 1fr auto;height:100vh}
header{background:var(--moss);color:#fff;display:flex;align-items:center;gap:14px;padding:10px 18px;flex-wrap:wrap}
.brand{font-weight:700;font-size:18px;display:flex;align-items:center;gap:8px}
.brand .dot{width:14px;height:14px;border-radius:50%;background:var(--warm);display:inline-block}
.tagline{font-size:11px;opacity:.78;font-weight:400}
header .search{margin-left:auto;position:relative}
header .search input{border:0;border-radius:20px;padding:8px 14px 8px 32px;width:230px;max-width:46vw;font-size:13px;background:rgba(255,255,255,.14);color:#fff}
header .search input::placeholder{color:rgba(255,255,255,.7)}
header .search svg{position:absolute;left:10px;top:8px;opacity:.7}
.search-results{position:absolute;top:38px;left:0;right:0;background:#fff;color:var(--ink);border-radius:10px;box-shadow:var(--sh);overflow:hidden;z-index:1200;max-height:280px;overflow-y:auto}
.search-results div{padding:8px 12px;font-size:13px;cursor:pointer;border-bottom:1px solid var(--line)}
.search-results div:hover{background:#eef6f1}

/* control bar (shop style) */
.controls{background:#fff;border-bottom:1px solid var(--line);padding:10px 18px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;z-index:600}
.crumb{font-size:13px;color:var(--muted);display:flex;gap:6px;align-items:center}
.crumb a{color:var(--moss);cursor:pointer;text-decoration:none;font-weight:600}
.crumb span.sep{opacity:.4}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-left:6px}
.chip{font-size:12.5px;border:1.5px solid var(--line);background:#fff;color:var(--ink);border-radius:20px;padding:5px 12px;cursor:pointer;display:flex;align-items:center;gap:6px;transition:.15s;font-weight:600}
.chip .cdot{width:9px;height:9px;border-radius:50%;background:var(--cat-cav)}
.chip.active{background:var(--cat-cav);color:#fff;border-color:var(--cat-cav)}
.chip.soon{opacity:.5;cursor:not-allowed;font-weight:500}
.chip.soon .cdot{background:var(--muted)}
.spacer{flex:1}
.btn{border:0;border-radius:20px;padding:7px 14px;font-size:13px;font-weight:600;cursor:pointer;background:var(--warm);color:#3a2a00;display:flex;align-items:center;gap:6px}
.btn.ghost{background:#eef6f1;color:var(--moss)}
.btn.mode{background:var(--moss);color:#fff}

/* map + panel */
.stage{position:relative}
#map{position:absolute;inset:0}
.legend{position:absolute;left:12px;bottom:12px;background:#fff;border-radius:10px;box-shadow:var(--sh);padding:10px 12px;font-size:12px;z-index:500}
.legend b{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:6px}
.legend .row{display:flex;align-items:center;gap:7px;margin:3px 0}
.legend .sw{width:13px;height:13px;border-radius:3px}

/* side panel (news + selected card) */
.panel{position:absolute;top:12px;right:12px;width:330px;max-width:calc(100vw - 24px);z-index:500;display:flex;flex-direction:column;gap:12px;max-height:calc(100% - 24px);overflow-y:auto}
.box{background:#fff;border-radius:var(--r);box-shadow:var(--sh);overflow:hidden}
.box h3{margin:0;padding:12px 14px;font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);border-bottom:1px solid var(--line)}
.news a{display:block;padding:9px 14px;font-size:13px;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--line)}
.news a:hover{background:#f3f8f5}
.news .date{color:var(--muted);font-size:11px}
.card-body{padding:14px}
.card-body .title{font-family:'Outfit';font-size:18px;font-weight:700;margin:0 0 4px}
.badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;margin-bottom:8px}
.badge.op{background:#e1f3ea;color:var(--st-op)} .badge.soon{background:#fbeed2;color:#8a6314}
.kv{font-size:12.5px;color:var(--muted);margin:5px 0;line-height:1.4}
.kv b{color:var(--ink);font-weight:600}
.card-actions{display:flex;gap:8px;margin-top:12px}
.card-actions a{flex:1;text-align:center}
.muted-soon{font-size:12px;color:var(--muted);font-style:italic;margin-top:8px}
.close{float:right;cursor:pointer;color:var(--muted);font-size:18px;line-height:1}

footer{background:#fff;border-top:1px solid var(--line);padding:7px 18px;font-size:11px;color:var(--muted);display:flex;gap:14px;flex-wrap:wrap;align-items:center}
footer a{color:var(--moss);text-decoration:none}
footer .sep{opacity:.4}

/* header news link */
.hdr-link{color:#fff;text-decoration:none;font-size:13px;font-weight:600;opacity:.92;border:1px solid rgba(255,255,255,.3);border-radius:18px;padding:5px 12px;font-family:'Outfit'}
.hdr-link:hover{background:rgba(255,255,255,.14)}
.news-empty{padding:11px 14px;font-size:12.5px;color:var(--muted);font-style:italic}

/* news modal */
.modal{position:fixed;inset:0;background:rgba(20,30,25,.45);z-index:2000;display:flex;align-items:center;justify-content:center;padding:18px}
.modal-card{background:#fff;border-radius:16px;max-width:560px;width:100%;max-height:80vh;overflow-y:auto;padding:22px 24px;box-shadow:0 12px 40px rgba(0,0,0,.25)}
.modal-card h2{font-family:'Outfit';font-size:21px;margin:6px 0 10px;color:var(--ink)}
.modal-card p{font-size:14.5px;line-height:1.6;color:#3a463f}
.modal-card .nm-date{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}

/* leaflet pin */
.cav-pin{border:2.5px solid #fff;border-radius:50%;box-shadow:0 1px 4px rgba(0,0,0,.4)}
.leaflet-popup-content{font-family:'Inter';font-size:13px}

@media (max-width:680px){
  .panel{position:static;width:auto;order:3;max-height:42vh;margin:8px}
  .app{grid-template-rows:auto auto 1fr auto auto}
  header .search input{width:150px}
  .tagline{display:none}
}
@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
