@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap');

:root{
  --bg:#FFFFFF;
  --surface:#F4F6F9;
  --surface-2:#EBEFF5;
  --ink:#10233F;
  --ink-soft:#4A5A72;
  --primary:#1B4B8F;
  --primary-dark:#123564;
  --accent:#C89B3C;
  --line:#DCE3EC;
  --radius:10px;
  --max:1300px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:'Inter',sans-serif;
  font-size:15px;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:'Space Grotesk',sans-serif; margin:0; letter-spacing:-0.01em;}
.mono{font-family:'IBM Plex Mono',monospace;}
a{color:inherit; text-decoration:none;}
img{max-width:100%; display:block;}
.wrap{max-width:var(--max); margin:0 auto; padding:0 32px;}
a:focus-visible, button:focus-visible, summary:focus-visible{
  outline:2px solid var(--primary); outline-offset:3px; border-radius:4px;
}
@media (prefers-reduced-motion: reduce){ *{animation-duration:.001ms !important; transition-duration:.001ms !important;} }

/* Vreme + curs în topbar */
.topbar-wrap{display:flex; justify-content:space-between; align-items:center; padding:8px 32px; gap:16px; flex-wrap:wrap;}
.topbar-right{display:flex; align-items:center; gap:16px; flex-wrap:wrap;}
.topbar-divider{width:1px; height:10px; background:rgba(255,255,255,.2); display:inline-block; vertical-align:middle;}
.topbar-weather{opacity:.85;}
.topbar-rate{font-family:'IBM Plex Mono',monospace; font-size:12px; opacity:.85;}
.topbar-rate-cur{opacity:.6; font-size:10px; text-transform:uppercase; letter-spacing:.05em; margin-right:2px;}

/* Topbar */
.topbar{background:var(--primary-dark); color:#DCE6F5; font-size:13px;}
.topbar .wrap{display:flex; justify-content:space-between; align-items:center; padding:8px 32px; gap:16px; flex-wrap:wrap;}
.topbar .topbar-wrap{padding:8px 32px;}
.topbar-left{display:flex; gap:20px; flex-wrap:wrap;}
.topbar a:hover{color:#fff;}
.topbar-flag{display:inline-flex; gap:3px; margin-right:8px;}
.topbar-flag span{width:6px; height:12px; border-radius:1px;}

/* Header */
header.main{border-bottom:1px solid var(--line); background:var(--bg); position:sticky; top:0; z-index:50;}
.header-inner{display:flex; align-items:center; justify-content:space-between; padding:16px 32px; gap:24px;}
.brand{display:flex; align-items:center; gap:12px;}
.crest{
  width:46px; height:46px; border-radius:50%;
  background:linear-gradient(160deg, var(--primary), var(--primary-dark));
  display:flex; align-items:center; justify-content:center; color:#fff;
  font-family:'Space Grotesk',sans-serif; font-weight:700; font-size:18px; flex-shrink:0;
  box-shadow:0 4px 14px rgba(27,75,143,.25);
}
.brand-text .eyebrow{font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-soft); font-weight:600;}
.brand-text .name{font-size:17px; font-weight:700; line-height:1.2;}

nav.primary{display:flex; gap:6px; font-size:13.5px; font-weight:500;}
nav.primary > .nav-item{position:relative;}
nav.primary > .nav-item > a, nav.primary > .nav-item > button{
  display:flex; align-items:center; gap:4px;
  color:var(--ink-soft); padding:10px 12px; border-bottom:2px solid transparent;
  background:none; border-top:none; border-left:none; border-right:none;
  font:inherit; cursor:pointer; transition:color .15s, border-color .15s;
}
nav.primary > .nav-item:hover > a, nav.primary > .nav-item:hover > button{color:var(--ink); border-color:var(--accent);}
.dropdown{
  position:absolute; top:100%; left:0; background:#fff; border:1px solid var(--line);
  border-radius:10px; min-width:240px; padding:8px; box-shadow:0 20px 40px -20px rgba(16,35,63,.25);
  opacity:0; visibility:hidden; transform:translateY(6px); transition:opacity .15s, transform .15s, visibility .15s;
}
nav.primary > .nav-item:hover .dropdown,
nav.primary > .nav-item:focus-within .dropdown{opacity:1; visibility:visible; transform:translateY(0);}
.dropdown a{display:block; padding:9px 12px; border-radius:6px; font-size:13.5px; color:var(--ink);}
.dropdown a:hover{background:var(--surface);}

.header-actions{display:flex; align-items:center; gap:14px;}
.btn{
  display:inline-flex; align-items:center; gap:8px; padding:10px 18px; border-radius:999px;
  font-weight:600; font-size:14px; cursor:pointer; border:1px solid transparent;
  transition:transform .15s, box-shadow .15s, background .15s; white-space:nowrap;
}
.btn-primary{background:var(--primary); color:#fff;}
.btn-primary:hover{background:var(--primary-dark); box-shadow:0 6px 16px rgba(27,75,143,.28);}
.btn-ghost{border-color:var(--line); color:var(--ink); background:#fff;}
.btn-ghost:hover{border-color:var(--primary); color:var(--primary);}
.menu-toggle{display:none; width:38px; height:38px; border-radius:10px; border:1px solid var(--line); background:#fff; cursor:pointer;}

/* Mobile nav */
@media (max-width:960px){
  nav.primary{display:none; flex-direction:column; width:100%; padding:12px 0;}
  nav.primary.open{display:flex;}
  nav.primary > .nav-item{width:100%;}
  .dropdown{position:static; opacity:1; visibility:visible; transform:none; box-shadow:none; border:none; display:none; margin:4px 0 8px 12px;}
  .nav-item.open .dropdown{display:block;}
  .header-inner{flex-wrap:wrap;}
  .menu-toggle{display:block;}
}

/* Hero */
.hero{padding:0; overflow:hidden;}
.carousel{position:relative;width:100%;height:500px;overflow:hidden;}
.carousel-track{display:flex;height:100%;transition:transform .7s cubic-bezier(.4,0,.2,1);will-change:transform;}
.carousel-slide{min-width:100%;background-size:cover;background-position:center;}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.35);color:#fff;border:none;font-size:34px;width:50px;height:50px;border-radius:50%;cursor:pointer;z-index:2;display:flex;align-items:center;justify-content:center;line-height:1;transition:background .2s;padding:0;}
.carousel-btn:hover{background:rgba(0,0,0,.6);}
.carousel-prev{left:16px;}
.carousel-next{right:16px;}
.carousel-dots{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);display:flex;gap:10px;z-index:2;}
.carousel-dot{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.5);cursor:pointer;transition:background .2s,transform .2s;border:none;}
.carousel-dot.active{background:#fff;transform:scale(1.3);}
.hero-inner{display:grid; grid-template-columns:1.1fr .9fr; gap:48px; align-items:center; padding-bottom:56px;}
.hero-eyebrow{
  display:inline-flex; align-items:center; gap:8px; font-family:'IBM Plex Mono',monospace; font-size:12.5px;
  color:var(--primary); background:#fff; border:1px solid var(--line); padding:6px 12px; border-radius:999px; margin-bottom:20px;
}
.hero-eyebrow .dot{width:7px; height:7px; border-radius:50%; background:var(--accent);}
.hero h1{font-size:42px; line-height:1.1; font-weight:700; color:var(--ink); max-width:14ch;}
.hero h1 em{font-style:normal; color:var(--primary);}
.hero p.lead{margin-top:18px; font-size:16.5px; line-height:1.6; color:var(--ink-soft); max-width:48ch;}
.hero-ctas{display:flex; gap:14px; margin-top:28px; flex-wrap:wrap;}

.stat-card{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:22px 24px; box-shadow:0 20px 40px -20px rgba(16,35,63,.18);}
.stat-card h3{font-size:13px; text-transform:uppercase; letter-spacing:.06em; color:var(--ink-soft); margin-bottom:14px; font-family:'Inter',sans-serif; font-weight:600;}
.stat-list{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:12px;}
.stat-list li{display:flex; justify-content:space-between; gap:12px; font-size:13.5px; border-bottom:1px dashed var(--line); padding-bottom:10px;}
.stat-list li:last-child{border-bottom:none; padding-bottom:0;}
.stat-list a{color:var(--primary); font-weight:600;}
.stat-list a:hover{text-decoration:underline;}
.stat-date{color:var(--ink-soft); font-family:'IBM Plex Mono',monospace; font-size:11.5px; white-space:nowrap;}

.ridge{width:100%; height:56px; display:block;}

/* Sections */
section{padding:56px 0;}
.section-head{display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:28px; gap:24px; flex-wrap:wrap;}
.section-head .eyebrow-sm{font-family:'IBM Plex Mono',monospace; font-size:12px; color:var(--accent); text-transform:uppercase; letter-spacing:.08em; margin-bottom:8px; display:block;}
.section-head h2{font-size:26px; font-weight:700;}
.section-head .view-all{font-size:14px; font-weight:600; color:var(--primary); display:flex; align-items:center; gap:6px;}
.section-head .view-all:hover{text-decoration:underline;}

.news-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px;}
.news-card{border:1px solid var(--line); border-radius:var(--radius); padding:24px; background:#fff; transition:border-color .15s, transform .15s, box-shadow .15s;}
.news-card:hover{border-color:var(--primary); transform:translateY(-3px); box-shadow:0 16px 30px -18px rgba(16,35,63,.25);}
.news-date{font-family:'IBM Plex Mono',monospace; font-size:12px; color:var(--ink-soft); margin-bottom:8px; display:block;}
.news-card h3{font-size:16px; font-weight:600; line-height:1.4; margin-bottom:8px;}
.news-card p{font-size:13.5px; color:var(--ink-soft); line-height:1.55; margin:0;}
.news-card .file-link{display:inline-block; margin-top:10px; font-size:13px; font-weight:600; color:var(--primary);}

.quick-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;}
.quick-item{background:#fff; padding:26px 22px; display:flex; gap:14px; align-items:flex-start; transition:background .15s;}
.quick-item:hover{background:var(--surface);}
.quick-icon{width:40px; height:40px; border-radius:9px; background:var(--surface-2); display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--primary);}
.quick-item h3{font-size:14.5px; font-weight:600; margin-bottom:4px;}
.quick-item p{font-size:12.5px; color:var(--ink-soft); margin:0; line-height:1.5;}

.transparency{
  background:var(--primary-dark); color:#fff; border-radius:16px; padding:40px 44px;
  display:flex; justify-content:space-between; align-items:center; gap:32px; flex-wrap:wrap; position:relative; overflow:hidden;
}
.transparency::after{content:""; position:absolute; right:-60px; top:-60px; width:220px; height:220px; border-radius:50%; background:radial-gradient(circle, rgba(200,155,60,.25), transparent 70%);}
.transparency h2{font-size:22px; max-width:24ch; position:relative; z-index:1;}
.transparency p{color:#C7D6EC; margin-top:10px; font-size:14px; max-width:46ch; position:relative; z-index:1;}
.transparency .btn-primary{background:var(--accent); position:relative; z-index:1;}
.transparency .btn-primary:hover{background:#B48A32;}

/* Content page layout (pagini generice, hotarari, etc.) */
.page-layout{display:grid; grid-template-columns:260px 1fr; gap:40px; align-items:start;}
.topbar-datetime{font-variant-numeric:tabular-nums; letter-spacing:.01em;}
.side-nav{background:var(--surface); border-radius:var(--radius); padding:20px; position:sticky; top:96px;}
.side-nav h4{font-size:12px; text-transform:uppercase; letter-spacing:.06em; color:var(--ink-soft); margin-bottom:12px;}
.side-nav ul{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:2px;}
.side-nav a{display:block; padding:5px 10px; border-radius:7px; font-size:13.5px; color:var(--ink-soft);}
.side-nav a:hover, .side-nav a.active{background:#fff; color:var(--primary); font-weight:600;}
.content-card{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:32px;}
.content-card h1{font-size:26px; margin-bottom:6px;}
.update-date{font-size:11px; color:var(--ink-soft); font-family:'IBM Plex Mono',monospace; margin-bottom:24px; text-align:right;}
.content-card .prose{font-size:13.5px; line-height:1.6; color:var(--ink);}
.content-card .prose p{margin:0 0 2px;}
.content-card .prose p:last-child{margin-bottom:0;}
.content-card .prose a{color:#b45309; text-decoration:none; font-weight:600;}
.content-card .prose a:hover{text-decoration:underline; text-underline-offset:2px;}
.content-card .prose h3, .content-card .prose h4{margin-top:22px; margin-bottom:8px;}
.content-card .prose ul, .content-card .prose ol{padding-left:20px;}

.doc-list{list-style:none; margin:0; padding:0; display:flex; flex-direction:column;}
.doc-list li{border-bottom:1px solid var(--line); padding:14px 0;}
.doc-list li:last-child{border-bottom:none;}
.doc-list a{color:var(--primary); font-weight:600; font-size:14.5px;}
.doc-list a:hover{text-decoration:underline;}
.doc-year{margin-top:28px; margin-bottom:10px; font-size:15px; color:var(--ink-soft);}
.doc-year:first-child{margin-top:0;}

.year-group{margin-top:10px; border:1px solid var(--line); border-radius:8px; overflow:hidden;}
.year-group + .year-group{margin-top:8px;}
.year-toggle{width:100%; display:flex; align-items:center; gap:10px; padding:12px 16px;
  background:var(--surface); border:none; cursor:pointer; text-align:left;
  font-family:'Space Grotesk',sans-serif; font-size:15px; font-weight:700; color:var(--ink);
  transition:background .15s;}
.year-toggle:hover{background:var(--surface-2);}
.year-toggle.open{background:var(--primary); color:#fff;}
.year-toggle-label{flex:1;}
.year-toggle-count{font-size:12px; font-weight:500; opacity:.7;}
.year-chevron{flex-shrink:0; transition:transform .2s;}
.year-toggle.open .year-chevron{transform:rotate(180deg);}
.year-body{overflow-x:auto;}
.hotarari-tbl{width:100%; border-collapse:collapse; font-size:13px;}
.hotarari-tbl thead th{background:var(--surface-2); padding:9px 12px; text-align:left;
  font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.05em;
  color:var(--ink-soft); border-bottom:1px solid var(--line);}
.hotarari-tbl tbody tr{border-bottom:1px solid var(--line);}
.hotarari-tbl tbody tr:last-child{border-bottom:none;}
.hotarari-tbl tbody tr:hover{background:var(--surface);}
.hotarari-tbl td{padding:9px 12px; vertical-align:top; line-height:1.5;}
.hotarari-tbl .col-nr{font-weight:700; color:var(--primary); white-space:nowrap;}
.hotarari-tbl .col-data{white-space:nowrap; color:var(--ink-soft); font-size:12.5px;}
.hotarari-tbl .col-docs{display:flex; flex-direction:column; gap:4px;}
.hotarari-tbl .col-docs a{font-size:12px; font-weight:600; color:#b45309; white-space:nowrap;}
.hotarari-tbl .col-docs a:hover{text-decoration:underline;}

.table-modern{width:100%; border-collapse:collapse; font-size:13.5px;}
.table-modern th{text-align:left; font-size:11.5px; text-transform:uppercase; letter-spacing:.05em; color:var(--ink-soft); padding:10px 12px; border-bottom:2px solid var(--line);}
.table-modern td{padding:12px; border-bottom:1px solid var(--line); vertical-align:top;}
.table-modern tr:hover td{background:var(--surface);}

.councillor-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:16px;}
.councillor-card{display:flex; gap:14px; align-items:center; border:1px solid var(--line); border-radius:var(--radius); padding:16px; background:#fff;}
.councillor-avatar{width:75px; height:75px; border-radius:50%; background:var(--surface-2); display:flex; align-items:center; justify-content:center; font-weight:700; color:var(--primary); font-family:'Space Grotesk',sans-serif; flex-shrink:0; overflow:hidden;}
.councillor-avatar img{width:100%; height:100%; object-fit:cover;}
.councillor-card h3{font-size:14.5px; font-weight:600;}
.councillor-card p{margin:2px 0 0; font-size:12.5px; color:var(--ink-soft);}

.anunt-list{margin-top:16px; display:flex; flex-direction:column; gap:16px;}
.anunt-item{border-radius:10px; overflow:hidden; box-shadow:0 1px 4px rgba(0,0,0,.07); border:1px solid var(--line);}
.anunt-header{display:flex; align-items:center; gap:12px; padding:12px 18px; background:linear-gradient(135deg,#1e3a8a 0%,#2563eb 100%); flex-wrap:wrap;}
.anunt-data{font-size:14px; font-weight:700; color:#fff; white-space:nowrap; flex-shrink:0;}
.anunt-header-sep{width:1px; height:14px; background:rgba(255,255,255,.3); flex-shrink:0;}
.anunt-titlu{font-size:14px; font-weight:600; color:rgba(255,255,255,.92); margin:0;}
.anunt-body{padding:16px 18px; background:#fff;}
.anunt-body .prose{margin:0;}
.anunt-body .prose p{margin:0 0 4px;}
.anunt-body .prose > *:first-child{margin-top:0;}
.anunt-body .prose > *:last-child{margin-bottom:0;}

.form-grid{display:flex; flex-direction:column; gap:16px; max-width:520px;}
.form-grid label{font-size:13px; font-weight:600; color:var(--ink-soft); margin-bottom:6px; display:block;}
.form-grid input, .form-grid textarea{
  width:100%; border:1px solid var(--line); border-radius:8px; padding:11px 14px; font:inherit; font-size:14px; color:var(--ink);
}
.form-grid input:focus, .form-grid textarea:focus{outline:2px solid var(--primary); outline-offset:1px; border-color:var(--primary);}
.form-note{font-size:12.5px; color:var(--ink-soft);}
.alert{padding:12px 16px; border-radius:8px; font-size:13.5px; margin-bottom:16px;}
.alert-success{background:#EAF6EE; color:#217A46;}
.alert-error{background:#FBEAEA; color:#B3261E;}

/* Footer */
footer{background:var(--ink); color:#B9C6DA; padding:56px 0 28px; margin-top:40px;}
.footer-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px;}
.footer-brand .brand{margin-bottom:14px;}
.footer-brand .name{color:#fff;}
.footer-brand p{font-size:13px; line-height:1.6; color:#8FA0BB; max-width:32ch;}
footer h4{font-size:12.5px; text-transform:uppercase; letter-spacing:.06em; color:#7C8FAC; margin-bottom:16px; font-weight:600;}
footer ul{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px;}
footer ul a{font-size:13.5px; color:#C7D3E5;}
footer ul a:hover{color:#fff;}
.footer-bottom{margin-top:48px; padding-top:24px; border-top:1px solid rgba(255,255,255,.08); display:flex; justify-content:space-between; font-size:12.5px; color:#7C8FAC; flex-wrap:wrap; gap:10px;}

@media (max-width:960px){
  .hero-inner{grid-template-columns:1fr;}
  .news-grid{grid-template-columns:1fr 1fr;}
  .quick-grid{grid-template-columns:1fr 1fr;}
  .footer-grid{grid-template-columns:1fr 1fr; gap:32px;}
  .page-layout{grid-template-columns:1fr;}
  .side-nav{position:static;}
  .councillor-grid{grid-template-columns:1fr;}
}
@media (max-width:640px){
  .wrap{padding:0 20px;}
  .header-inner{padding:14px 20px;}
  .hero h1{font-size:30px; max-width:none;}
  .news-grid{grid-template-columns:1fr;}
  .quick-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .transparency{padding:28px 22px; flex-direction:column; align-items:flex-start;}
}

/* ---- Lightbox ---- */
.lb-overlay{
  display:none; position:fixed; inset:0;
  background:rgba(10,15,26,.93); z-index:2000;
  align-items:center; justify-content:center;
  animation:lb-in .18s ease;
}
.lb-overlay.lb-active{display:flex;}
@keyframes lb-in{from{opacity:0}to{opacity:1}}

.lb-content{
  position:relative; display:flex; flex-direction:column;
  align-items:center; max-width:92vw; max-height:92vh;
}
.lb-img{
  max-width:88vw; max-height:80vh;
  object-fit:contain; border-radius:6px;
  display:block; transition:opacity .2s;
}
.lb-img.lb-loading{opacity:0;}

.lb-footer{
  display:flex; justify-content:space-between; align-items:center;
  width:100%; padding:10px 2px 0; gap:16px;
  color:rgba(255,255,255,.65); font-size:13px; font-family:'Inter',sans-serif;
}
.lb-caption{flex:1;}
.lb-counter{white-space:nowrap; font-family:'IBM Plex Mono',monospace; font-size:12px;}

.lb-close{
  position:fixed; top:16px; right:20px;
  width:38px; height:38px; border-radius:50%;
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.15);
  color:#fff; font-size:18px; line-height:1; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:background .15s;
}
.lb-close:hover{background:rgba(255,255,255,.2);}

.lb-prev,.lb-next{
  position:fixed; top:50%; transform:translateY(-50%);
  width:44px; height:64px; border-radius:8px;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12);
  color:#fff; font-size:28px; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:background .15s;
}
.lb-prev{left:12px;}
.lb-next{right:12px;}
.lb-prev:hover,.lb-next:hover{background:rgba(255,255,255,.18);}
@media(max-width:640px){
  .lb-prev{left:4px;} .lb-next{right:4px;}
  .lb-img{max-width:96vw; max-height:70vh;}
}

/* Cursor pointer pe imaginile din galerie */
.lb-trigger{cursor:zoom-in; display:block;}
