/* ============ DDS — Dubrovački demokratski sabor ============ */
:root{
  --blue:#0090d8;        /* brend svijetlo plava (iz logoa) */
  --navy:#003060;        /* brend tamna navy (iz logoa) */
  --navy-2:#00254a;
  --ink:#1a2330;
  --muted:#5a6675;
  --line:#e4e9ef;
  --bg:#ffffff;
  --bg-soft:#f4f8fb;
  --radius:14px;
  --shadow:0 4px 20px rgba(0,48,96,.08);
  --shadow-lg:0 14px 40px rgba(0,48,96,.14);
  --container:1180px;
  --ease-out:cubic-bezier(.215,.61,.355,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--ink);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--blue);text-decoration:none;transition:color .15s ease}
a:hover{color:var(--navy)}
.container{max-width:var(--container);margin:0 auto;padding:0 22px}
h1,h2,h3,h4{line-height:1.2;color:var(--navy);font-weight:800;margin:0 0 .5em}
h1{font-size:clamp(1.9rem,4vw,2.9rem)}
h2{font-size:clamp(1.5rem,3vw,2.1rem)}
h3{font-size:1.25rem}
p{margin:0 0 1em}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:74px}
.brand img{height:40px;width:auto}
.nav-menu{display:flex;align-items:center;gap:4px;list-style:none;margin:0;padding:0}
.nav-menu>li{position:relative}
.nav-menu>li>a{display:flex;align-items:center;gap:5px;padding:10px 14px;border-radius:10px;color:var(--navy);font-weight:600;font-size:.96rem}
.nav-menu>li>a:hover,.nav-menu>li>a.active{background:var(--bg-soft);color:var(--blue)}
.caret{font-size:.7em;opacity:.7}
.nav-menu .sub{position:absolute;top:calc(100% + 6px);left:0;min-width:260px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);list-style:none;margin:0;padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.2s var(--ease-out)}
.nav-menu .has-sub:hover .sub,.nav-menu .has-sub:focus-within .sub{opacity:1;visibility:visible;transform:translateY(0)}
.nav-menu .sub a{display:block;padding:9px 12px;border-radius:8px;color:var(--ink);font-size:.92rem;font-weight:500}
.nav-menu .sub a:hover{background:var(--bg-soft);color:var(--blue)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:26px;height:2.5px;background:var(--navy);border-radius:2px;transition:.25s var(--ease-out)}
body.menu-open .burger span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ---------- Page hero ---------- */
.page-hero{background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;padding:56px 0}
.page-hero h1{color:#fff;margin:0}
.page-hero .crumb{font-size:.85rem;opacity:.85;margin-bottom:10px}
.page-hero .crumb a{color:#fff;opacity:.9}

/* ---------- Sections ---------- */
section{padding:64px 0}
.section-soft{background:var(--bg-soft)}
.lead{font-size:1.15rem;color:var(--muted);max-width:760px}

/* ---------- Home hero ---------- */
.home-hero{position:relative;background:linear-gradient(120deg,var(--navy) 0%,var(--navy-2) 45%,var(--blue) 130%);color:#fff;padding:88px 0;overflow:hidden}
.home-hero h1{color:#fff;max-width:880px}
.home-hero p{font-size:1.2rem;opacity:.92;max-width:680px}
.home-hero .btn{margin-top:18px}
/* full-cover hero s pozadinskom slikom */
.hero-cover{display:flex;align-items:center;min-height:calc(100vh - 74px);padding:0}
.hero-cover .hero-bg{position:absolute;inset:0;z-index:0}
.hero-cover .hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-cover::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(120deg,rgba(0,25,50,.34) 0%,rgba(0,35,70,.22) 55%,rgba(0,80,140,.16) 100%)}
.hero-cover .hero-inner{position:relative;z-index:2;padding-top:40px;padding-bottom:40px}
.hero-cover h1{font-size:clamp(2.1rem,5vw,3.6rem);text-shadow:0 2px 18px rgba(0,15,35,.65),0 1px 4px rgba(0,15,35,.5)}
.hero-cover p{font-size:clamp(1.05rem,2.2vw,1.35rem);margin-top:14px}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px}
.hero-cta .btn{margin-top:0}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--blue);color:#fff;padding:13px 26px;border-radius:999px;font-weight:700;font-size:.96rem;border:0;cursor:pointer;transition:transform .15s var(--ease-out),box-shadow .15s var(--ease-out),background .15s ease}
.btn:hover{background:#0a7fbe;color:#fff;transform:translateY(-2px);box-shadow:0 10px 24px rgba(0,144,216,.32)}
.btn:active{transform:translateY(0)}
.btn-ghost{background:transparent;border:2px solid rgba(255,255,255,.6);color:#fff}
.btn-ghost:hover{background:#fff;color:var(--navy)}
.btn-navy{background:var(--navy)}
.btn-navy:hover{background:var(--navy-2)}

/* ---------- Election cards (home) ---------- */
.elect-grid{display:grid;gap:30px}
.elect{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.15fr);gap:0;background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);transition:transform .25s var(--ease-out),box-shadow .25s var(--ease-out)}
.elect:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.elect:nth-child(even){grid-template-columns:minmax(0,1.15fr) minmax(0,1fr)}
.elect:nth-child(even) .elect-media{order:2}
.elect-media{background:var(--bg-soft);min-height:280px;overflow:hidden}
.elect-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease-out)}
.elect:hover .elect-media img{transform:scale(1.04)}
.elect-body{padding:34px 36px;display:flex;flex-direction:column;justify-content:center}
.elect-body h2{color:var(--navy)}
.elect-body p{color:var(--muted);font-size:1rem}
.elect-body .btn{align-self:flex-start;margin-top:8px}

/* ---------- Content (articles) ---------- */
.content{max-width:860px;margin:0 auto}
.content p{margin:0 0 1.1em}
.content strong{color:var(--navy)}

/* ---------- Financijski izvještaji ---------- */
.fin-years{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px}
.fin-year{display:block;background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px 26px;box-shadow:var(--shadow);transition:transform .2s var(--ease-out),box-shadow .2s var(--ease-out),border-color .2s}
.fin-year:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--blue)}
.fin-year .yr{font-size:2.2rem;font-weight:800;color:var(--blue);line-height:1}
.fin-year .ttl{color:var(--navy);font-weight:700;margin-top:8px}
.fin-year .cnt{color:var(--muted);font-size:.88rem;margin-top:6px}
.fin-section{margin:34px 0 10px;color:var(--navy);font-size:1.15rem;font-weight:800;padding-bottom:8px;border-bottom:2px solid var(--line)}
.doc-list{list-style:none;margin:0 0 8px;padding:0}
.doc-list li{list-style:none;margin:0 0 10px}
.doc-list li::marker{content:""}
.doc-list li:last-child{margin-bottom:0}
.doc{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 18px;box-shadow:var(--shadow);transition:transform .15s var(--ease-out),box-shadow .15s,border-color .15s}
.doc:hover{transform:translateX(4px);border-color:var(--blue);box-shadow:var(--shadow-lg)}
.doc .ic{flex:0 0 auto;width:40px;height:40px;border-radius:9px;background:var(--bg-soft);display:grid;place-items:center;color:var(--blue)}
.doc .ic svg{width:22px;height:22px}
.doc .tx{flex:1 1 auto;min-width:0}
.doc .tx b{display:block;color:var(--navy);font-weight:600;font-size:.97rem}
.doc.missing{opacity:.6}
.doc.missing .badge{background:#fdecec;color:#c0392b;font-size:.72rem;padding:2px 8px;border-radius:99px;font-weight:700}
.doc .dl{flex:0 0 auto;color:var(--blue);font-weight:700;font-size:.86rem;white-space:nowrap}

/* ---------- Kontakt ---------- */
.kontakt-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.office-block{display:grid;grid-template-columns:1fr 1.3fr;gap:30px;align-items:stretch}
.office-block .office{display:flex;flex-direction:column;justify-content:center}
.office-block .map-wrap{min-height:320px}
.office{background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px;box-shadow:var(--shadow)}
.office h3{color:var(--blue)}
.info-row{display:flex;gap:10px;margin:6px 0;color:var(--muted)}
.cform label{display:block;font-weight:600;color:var(--navy);margin:14px 0 6px;font-size:.92rem}
.cform input,.cform textarea{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;font:inherit;background:#fff;transition:border-color .15s,box-shadow .15s}
.cform input:focus,.cform textarea:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,144,216,.14)}
.map-wrap{border-radius:16px;overflow:hidden;box-shadow:var(--shadow);min-height:300px}
.map-wrap iframe{width:100%;height:100%;min-height:340px;border:0;display:block}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy);color:#cfdded;padding:54px 0 22px;margin-top:20px}
.foot-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:36px;align-items:start}
.foot-logo img{height:48px;background:#fff;padding:8px 14px;border-radius:10px}
.foot-col p{margin:0;font-size:.94rem;line-height:1.8}
.foot-col strong{color:#fff}
.site-footer a{color:#9fd2ee}
.site-footer a:hover{color:#fff}
.foot-legal{margin-top:30px;padding-top:18px;border-top:1px solid rgba(255,255,255,.14);font-size:.86rem;color:#9fb4ca}
.foot-bottom{margin-top:14px;font-size:.82rem;color:#8098b0}

/* ---------- Back to top ---------- */
.to-top{position:fixed;right:22px;bottom:22px;width:46px;height:46px;border-radius:50%;background:var(--navy);color:#fff;border:0;font-size:1.2rem;cursor:pointer;box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(10px);transition:.25s var(--ease-out);z-index:90}
.to-top.show{opacity:1;visibility:visible;transform:translateY(0)}
.to-top:hover{background:var(--blue)}

/* ---------- Lightbox ---------- */
.lb-overlay{position:fixed;inset:0;background:rgba(0,20,40,.92);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;visibility:hidden;transition:opacity .25s var(--ease-out)}
.lb-overlay.open{opacity:1;visibility:visible}
.lb-overlay img{max-width:92vw;max-height:90vh;border-radius:8px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.lb-close{position:absolute;top:20px;right:26px;color:#fff;font-size:2.2rem;cursor:pointer;line-height:1;background:none;border:0}

/* ---------- Scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(24px)}
.reveal.in{opacity:1;transform:none;transition:opacity .6s var(--ease-out),transform .6s var(--ease-out)}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* ---------- Cookie consent ---------- */
.cc-bar{position:fixed;left:18px;right:18px;bottom:18px;max-width:560px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);padding:20px 22px;z-index:1100;transform:translateY(140%);transition:transform .4s var(--ease-out)}
.cc-bar.show{transform:none}
.cc-bar p{font-size:.9rem;color:var(--muted);margin:0 0 14px}
.cc-actions{display:flex;gap:10px;flex-wrap:wrap}
.cc-actions .btn{padding:10px 20px;font-size:.9rem}
.cc-actions .btn-min{background:transparent;color:var(--navy);border:1px solid var(--line)}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .elect,.elect:nth-child(even){grid-template-columns:1fr}
  .elect:nth-child(even) .elect-media{order:0}
  .kontakt-grid{grid-template-columns:1fr}
  .office-block{grid-template-columns:1fr;gap:20px}
  .foot-grid{grid-template-columns:1fr;gap:24px;text-align:center}
  .foot-logo img{margin:0 auto}
}
@media(max-width:780px){
  .burger{display:flex}
  .nav-menu{position:fixed;inset:74px 0 0 auto;width:min(82vw,340px);height:calc(100vh - 74px);background:#fff;flex-direction:column;align-items:stretch;gap:0;padding:14px;box-shadow:var(--shadow-lg);transform:translateX(110%);transition:transform .3s var(--ease-out);overflow-y:auto}
  body.menu-open .nav-menu{transform:none}
  .nav-menu>li>a{padding:14px;border-radius:10px;font-size:1.02rem}
  .nav-menu .sub{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;border-left:2px solid var(--line);border-radius:0;margin:2px 0 6px 14px;padding:0}
  .nav-menu .caret{margin-left:auto}
  section{padding:48px 0}
  .home-hero{padding:64px 0}
}
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal{opacity:1!important;transform:none!important;transition:none!important}
  .elect:hover,.fin-year:hover,.doc:hover,.btn:hover{transform:none!important}
}
