
:root{
  --green1:#14532d;
  --green2:#166534;
  --green3:#15803d;

  --success:#16a34a;
  --danger:#dc2626;

  --bg:#f5f5f5;

  --radius:18px;
  --shadow:0 10px 30px rgba(0,0,0,.08);
}

*{
  margin:0;
  padding:0;
  box-sizing:border-box;
}

html{
  height:100%;
}

body{
  background:var(--bg);
  font-family:Segoe UI,sans-serif;
  overflow-x:hidden;
  min-height:100%;
  display:flex;
  flex-direction:column;
}

.page-main{
  flex:1 0 auto;
}

/* =========================
   NAVBAR
========================= */

.countdown-bar{
  background:linear-gradient(90deg,#0f3d26,#166534,#15803d);
  color:#fff;
  padding:10px 0;
  font-size:14px;
  text-align:center;
  box-shadow:0 4px 12px rgba(0,0,0,.12);
}

.countdown-bar #countdownClock{
  font-weight:700;
  font-variant-numeric:tabular-nums;
  margin-left:8px;
}

.eco-navbar{
  background:linear-gradient(
    135deg,
    var(--green1),
    var(--green2),
    var(--green3)
  );

  padding:12px 0;

  box-shadow:0 8px 25px rgba(0,0,0,.18);
}

.eco-brand{
  color:#fff !important;
  text-decoration:none;
}

.eco-logo{
  width:52px;
  height:52px;

  border-radius:16px;

  background:rgba(255,255,255,.15);

  display:flex;
  align-items:center;
  justify-content:center;

  font-size:24px;

  backdrop-filter:blur(10px);
}

.eco-title{
  font-size:22px;
  font-weight:700;
}

.eco-subtitle{
  color:rgba(255,255,255,.75);
  font-size:15px;
}

.nav-eco-bar{
  min-height:52px;
  display:flex;
  flex-direction:row;
  align-items:center;
  justify-content:flex-end;
}

/* Desktop: naslov u centru prozora; ikone samo desno (ne sire se preko celog reda) */
.nav-eco-brand{
  z-index:1;
  width:max-content;
  max-width:min(720px, calc(100vw - 200px));
  pointer-events:auto;
}

.nav-eco-actions{
  position:relative;
  z-index:2;
  display:flex;
  flex:0 0 auto;
  min-width:0;
  justify-content:flex-end;
  align-items:center;
  gap:4px;
  margin-left:auto;
}

/* =========================
   ACTIONS
========================= */

.action-btn{
  width:48px;
  height:48px;

  border:none;
  border-radius:15px;

  background:rgba(255,255,255,.15);

  color:#fff;

  display:flex;
  align-items:center;
  justify-content:center;

  font-size:18px;

  transition:.3s;

  backdrop-filter:blur(10px);
}

.action-btn:hover{
  background:#fff;
  color:#166534;

  transform:translateY(-2px);
}

#userMenuWrap .dropdown-toggle::after{
  display:none;
}

#userMenuWrap .dropdown-menu{
  top: calc(100% + 8px);
  border-radius:14px;
  border:none;
  box-shadow:0 12px 40px rgba(0,0,0,.15);
  padding:8px;
  min-width:220px;
}

#userMenuWrap .dropdown-item{
  border-radius:10px;
  padding:10px 14px;
}

#userMenuWrap .dropdown-item:active{
  background:#dcfce7;
  color:#14532d;
}

/* =========================
   SEARCH PANEL
========================= */

.nav-action-wrap{
  position:relative;
}

.search-panel{
  position:absolute;
  top:calc(100% + 10px);
  right:0;
  left:auto;

  width:280px;

  background:#fff;

  border-radius:16px;

  padding:12px 12px 10px;

  display:none;

  box-shadow:0 20px 50px rgba(0,0,0,.18);

  z-index:999;
}

.search-panel.active{
  display:block;
}

.search-input{
  position:relative;
}

.search-input i{
  position:absolute;
  top:50%;
  left:12px;
  transform:translateY(-50%);

  color:#16a34a;

  font-size:14px;
}

.search-input input{
  width:100%;

  border:none;

  background:#f3f4f6;

  border-radius:12px;

  padding:10px 12px 10px 38px;

  outline:none;

  font-size:14px;
}

.search-input input:focus{
  background:#ecfdf5;
}

.search-filters{
  display:flex;
  flex-direction:column;
  gap:4px;

  margin-top:10px;

  padding-top:8px;

  border-top:1px solid #eef0f2;
}

.search-filters .form-check{
  display:flex;

  align-items:center;

  gap:10px;

  margin-bottom:0;

  padding:5px 8px;

  background:#f9fafb;

  border-radius:8px;

  min-height:0;
}

.search-filters .form-check-input{
  float:none;

  margin:0;

  flex-shrink:0;
}

.search-filters .form-check-label{
  padding:0;

  margin:0;

  font-size:13px;

  line-height:1.25;

  cursor:pointer;

  color:#374151;
}

.mz-toolbar label,
.mz-search-field label{
  font-size:12px;
  font-weight:600;
  color:#334155;
  margin-bottom:6px;
}

.mz-input-icon{
  position:absolute;
  left:12px;
  top:50%;
  transform:translateY(-50%);
  color:#16a34a;
  pointer-events:none;
  z-index:2;
  font-size:14px;
}

.mz-search-input{
  padding-left:2.35rem !important;
}

.mz-list-row{
  cursor:pointer;
  transition:background .15s;
}

.mz-list-row:hover{
  background:#f0fdf4 !important;
}

.mz-list-row.mz-row-active{
  background:#dcfce7 !important;
  outline:2px solid #16a34a;
  outline-offset:-2px;
}

.mz-td-multiline{
  white-space:pre-line;
  word-break:break-word;
  vertical-align:top;
  max-width:min(280px,32vw);
}

.mz-btn-plus{
  width:40px;
  height:40px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0;
  border-radius:12px;
}

#mzEditModal{
  z-index:4000 !important;
}

/* =========================
   GRID MENU
========================= */

.grid-panel{
  position:absolute;
  top:calc(100% + 10px);
  right:0;
  left:auto;

  width:220px;

  background:#fff;

  border-radius:18px;

  padding:10px;

  display:none;

  box-shadow:0 20px 50px rgba(0,0,0,.18);

  z-index:999;
}

.grid-panel.active{
  display:block;
}

.grid-btn{
  width:100%;

  border:none;

  background:#f5f5f5;

  border-radius:10px;

  padding:8px 10px;

  margin-bottom:6px;

  font-size:13px;

  line-height:1.25;

  transition:.3s;
}

.grid-btn:last-of-type{
  margin-bottom:0;
}

.grid-btn:hover{
  background:#dcfce7;
}

.cover-preview-wrap img{
  max-height:130px;
  width:auto;
  max-width:100%;
  object-fit:cover;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.08);
}

/* Detaljni panel depone */
#detailContent .detail-cover{
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(0,0,0,.08);
  background:#f3f4f6;
}

#detailContent .detail-cover-img{
  display:block;
  width:100%;
  max-height:280px;
  object-fit:cover;
}

#detailContent .detail-info .detail-pair,
#detailContent .detail-extra .detail-pair{
  display:grid;
  gap:4px;
  align-content:start;
}

#detailContent .detail-fields-label{
  font-size:11px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.04em;
  color:#64748b;
}

#detailContent .detail-fields-val{
  font-size:14px;
  color:#111827;
  word-break:break-word;
}

#detailContent .detail-text-block .detail-text-body{
  font-size:14px;
  line-height:1.55;
  color:#374151;
  white-space:pre-wrap;
}

#detailContent .detail-gallery-sec-title{
  font-size:13px;
  font-weight:700;
  color:#166534;
  padding-bottom:6px;
  border-bottom:1px solid #e5e7eb;
}

#detailContent .detail-img-square{
  aspect-ratio:1/1;
  border-radius:12px;
  overflow:hidden;
  border:1px solid #d1d5db;
  cursor:pointer;
  background:#f3f4f6;
  transition:transform .15s ease, box-shadow .15s ease;
}

#detailContent .detail-img-square:hover{
  transform:scale(1.02);
  box-shadow:0 6px 16px rgba(0,0,0,.1);
}

#detailContent .detail-img-square img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

/* =========================
   STAT BOX
========================= */

.stat-card{
  border:none;

  border-radius:var(--radius);

  box-shadow:var(--shadow);

  transition:.3s;

  cursor:pointer;

  position:relative;

  overflow:hidden;
}

.stat-card:hover{
  transform:translateY(-5px);
}

.stat-card i{
  position:absolute;
  right:20px;
  top:20px;

  font-size:35px;

  opacity:.12;
}

/* =========================
   DEPONIJA CARD
========================= */

.deponija-card{
  background:#fff;

  border-radius:var(--radius);

  overflow:hidden;

  box-shadow:var(--shadow);

  transition:.3s;

  cursor:pointer;

  position:relative;

  height:100%;
}

.deponija-card:hover{
  transform:translateY(-5px);
}

.status-bar{
  width:8px;

  position:absolute;
  top:0;
  left:0;
  bottom:0;
}

.status-clean{
  background:var(--success);
}

.status-dirty{
  background:var(--danger);
}

.thumb{
  width:100%;
  height:220px;

  object-fit:cover;
}

.card-meta-row{
  font-size:0.875rem;
  color:#64748b;
}

.card-opis-clamp{
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:2;
  overflow:hidden;
  word-break:break-word;
  line-height:1.45;
  min-height:0;
  margin-bottom:0;
}

.badge-clean{
  background:rgba(22,163,74,.12);
  color:var(--success);
}

.badge-dirty{
  background:rgba(220,38,38,.12);
  color:var(--danger);
}

/* =========================
   PANELS
========================= */

.overlay{
  position:fixed;
  inset:0;

  background:rgba(0,0,0,.45);

  z-index:1500;

  display:none;
}

.overlay.show{
  display:block;
}

.slide-panel{
  position:fixed;
  top:0;
  left:-100%;

  width:100%;
  max-width:500px;

  height:100vh;

  background:#fff;

  overflow-y:auto;

  z-index:2000;

  transition:.4s;

  box-shadow:0 0 40px rgba(0,0,0,.3);
}

.slide-panel.open{
  left:0;
}

.panel-header{
  background:#166534;

  color:#fff;

  padding:16px;

  position:sticky;
  top:0;

  z-index:2;
}

/* =========================
   FULLSCREEN
========================= */

.fullscreen-view{
  position:fixed;
  inset:0;

  background:rgba(0,0,0,.95);

  display:none;

  align-items:center;
  justify-content:center;

  z-index:4000;
}

.fullscreen-view.show{
  display:flex;
}

/* Pregled svih deponeja na mapi */
.map-overview-overlay{
  position:fixed;
  inset:0;
  z-index:3500;
  background:#0f172a;
  display:none;
}

.map-overview-overlay.show{
  display:block;
}

body.map-overview-open{
  overflow:hidden;
}

body.map-overview-open .overlay.show{
  z-index:3600;
}

body.map-overview-open .slide-panel.open{
  z-index:3650;
}

body.map-overview-open .fullscreen-modal.show {
  z-index: 3700;  /* iznad .slide-panel (3650) i mape (3500) */
}

.map-overview-map{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
}

.map-overview-close{
  position:fixed;
  top:50%;
  right:16px;
  transform:translateY(-50%);
  z-index:4001;
  width:44px;
  height:44px;
  border:none;
  border-radius:50%;
  background:rgba(255,255,255,.95);
  color:#0f172a;
  font-size:20px;
  line-height:1;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 4px 20px rgba(0,0,0,.25);
}

.map-overview-close:hover{
  background:#fff;
}

.leaflet-div-icon.dep-overview-marker-outer{
  background:transparent!important;
  border:none!important;
}

.dep-overview-pin{
  width:26px;
  height:26px;
  border-radius:50% 50% 50% 0;
  transform:rotate(-45deg);
  border:2px solid #fff;
  box-shadow:0 2px 10px rgba(0,0,0,.4);
  margin:2px 0 0 2px;
}

.dep-overview-pin--clean{
  background:#16a34a;
}

.dep-overview-pin--dirty{
  background:#dc2626;
}

.fullscreen-view img{
  max-width:90%;
  max-height:90%;

  border-radius:16px;
}

.close-fullscreen{
  position:absolute;
  top:20px;
  right:30px;

  color:#fff;
  font-size:35px;

  cursor:pointer;
}

.nav-arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);

  color:#fff;
  font-size:38px;

  cursor:pointer;
}

.left-arrow{
  left:30px;
}

.right-arrow{
  right:30px;
}

/* =========================
   FORM
========================= */

.fullscreen-modal{
  position:fixed;
  inset:0;

  background:#fff;

  overflow-y:auto;

  z-index:3000;

  display:none;
}

.fullscreen-modal.show{
  display:block;
}

.map{
  height:300px;
  border-radius:16px;
}

.image-preview{
  display:flex;
  gap:10px;
  flex-wrap:wrap;

  margin-top:10px;
}

.preview-item{
  position:relative;
}

.preview-item img{
  width:110px;
  height:90px;

  object-fit:cover;

  border-radius:12px;

  cursor:grab;
}

.remove-image{
  position:absolute;
  top:-5px;
  right:-5px;

  width:22px;
  height:22px;

  border:none;
  border-radius:50%;

  background:red;
  color:#fff;
}

.site-footer{
  flex-shrink:0;
  margin-top:auto;
  background:linear-gradient(90deg,#0f3d26,#166534,#15803d);
  color:#fff;
  padding:10px 0;
  font-size:14px;
  text-align:center;
  letter-spacing:.5px;
  box-shadow:0 -4px 12px rgba(0,0,0,.12);
}

.site-footer a,
.site-footer button.site-footer-link{
  color:#fff;
  text-decoration:underline;
  text-underline-offset:2px;
  background:none;
  border:none;
  padding:0;
  font:inherit;
  cursor:pointer;
}

.site-footer a:hover,
.site-footer button.site-footer-link:hover{
  color:rgba(255,255,255,.9);
}

#privacyModal .legal-wrap{
  max-width:820px;
  margin:0 auto;
}

#privacyModal .legal-card{
  background:#fff;
  border-radius:18px;
  box-shadow:0 10px 30px rgba(0,0,0,.08);
  padding:2rem 1.75rem;
}

#privacyModal .legal-card h1{
  font-size:1.5rem;
  color:var(--green1);
  margin-bottom:.25rem;
}

#privacyModal .legal-meta{
  font-size:.9rem;
  color:#64748b;
  margin-bottom:1.75rem;
}

#privacyModal .legal-card h2{
  font-size:1.1rem;
  color:var(--green2);
  margin-top:1.75rem;
  margin-bottom:.6rem;
}

#privacyModal .legal-card p,
#privacyModal .legal-card li{
  font-size:.95rem;
  line-height:1.65;
  color:#1e293b;
}

#privacyModal .legal-card ul{
  padding-left:1.25rem;
}

.privacy-modal-header{
  position:sticky;
  top:0;
  z-index:2;
  background:linear-gradient(90deg,#0f3d26,#166534,#15803d);
  color:#fff;
  padding:14px 16px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  box-shadow:0 4px 12px rgba(0,0,0,.12);
}

.privacy-modal-header h5{
  margin:0;
  font-size:1.1rem;
}

/* =========================
   MOBILE
========================= */

@media(max-width:768px){

  /* Grid kolona nema smisla na telefonu — kartice su ionako jedna ispod druge */
  #gridActionWrap{
    display:none !important;
  }

  /* Redosled ikona: mapa, jezik, pretraga, pa korisnik (pretraga uz nalog, ne na kraju reda) */
  #mapOverviewWrap{
    order:1;
  }

  #toggleLang{
    order:2;
  }

  #searchActionWrap{
    order:3;
  }

  #loginBtn{
    order:4;
  }

  #userMenuWrap{
    order:5;
  }

  .search-panel{
    right:0;
    left:auto;
    max-width:min(300px, calc(100vw - 24px));
  }

  #searchActionWrap .search-panel{
    right:0;
    left:auto;
    transform:translateX(0);
    max-width:min(300px, calc(100vw - 20px));
  }

  /* Telefon: naslov u prvom redu (bez absolutnog centra), ikone u drugom redu desno, manje */
  .nav-eco-bar{
    flex-direction:column;
    align-items:stretch;
    gap:5px;
    min-height:0;
    padding:0;
  }

  .eco-navbar{
    padding: 8px;
  }

  .nav-eco-brand{
    position:static !important;
    top:auto !important;
    left:auto !important;
    transform:none !important;
    width:100%;
    max-width:100%;
    margin-left:auto;
    margin-right:auto;
    padding:0 4px;
    justify-content:center !important;
    flex-direction:row !important;
    flex-wrap:nowrap !important;
    align-items:center !important;
    gap:6px !important;
    text-align:center;
    z-index:1;
  }

  .nav-eco-brand .eco-logo{
    display:flex !important;
    width:30px;
    height:30px;
    min-width:30px;
    border-radius:8px;
    font-size:14px;
    flex-shrink:0;
  }

  .nav-eco-brand .text-start{
    text-align:left !important;
    align-items:flex-start !important;
    min-width:0;
    flex:1 1 auto;
  }

  .nav-eco-actions{
    width:100%;
    justify-content:flex-end;
    flex-wrap:nowrap;
    gap:6px !important;
    margin-left:0;
    padding-left:4px;
    padding-right:4px;
  }

  .nav-eco-actions .action-btn{
    width:34px;
    height:34px;
    border-radius:12px;
    font-size:15px;
  }

  .nav-eco-actions .action-btn.px-3{
    width:auto;
    min-height:34px;
    padding-left:8px !important;
    padding-right:8px !important;
    font-size:12px;
    font-weight:600;
  }

  .eco-title{
    font-size:13px;
    line-height:1.25;
    display:block;
  }

  .eco-subtitle{
    font-size:9px;
    line-height:1.2;
    display:block;
  }

  .eco-countdown-label{
    font-size:20px !important;
  }
  .eco-countdown-label #countdownClock{
    display: block;
  }

  .thumb{
    height:180px;
  }

  .slide-panel{
    max-width:100%;
  }

}

.bg-image {
    position: fixed;
    inset: 0;
    background: url('uploads/background.jpg') center/cover no-repeat;
    background-position: center top;
    opacity: 0.2;
    filter: blur(0px) brightness(0.5) contrast(1.2);
    transform: scale(1.1);
    z-index: -1;
}

