:root{
  --bg:#06080B;
  --panel:#111823;
  --panel2:#0F151E;
  --text:#EAF0F6;
  --muted:#9AA6B2;
  --border:rgba(255,255,255,.08);

  /* MAIN (plava) */
  --accent:#1E90FF;
  --accent2:#4DA3FF;

  --shadow: 0 18px 60px rgba(0,0,0,.55);
  --radius:22px;
  --max:1180px;
}

* { box-sizing: border-box; }
img, video { max-width: 100%; height: auto; display: block; }
html, body { overflow-x: hidden; }
.container { width: min(1120px, calc(100% - 32px)); margin: 0 auto; }

html {
  scroll-behavior: auto;
}
body{
  margin:0;
  color:var(--text);
  background:var(--bg);
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  overflow-x:hidden;
  padding-top: 50px;
}

a{color:inherit; text-decoration:none}
.container{max-width:var(--max); margin:0 auto; padding:0 20px}
.muted{color:var(--muted)}

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:12px 16px;
  border-radius:16px;
  font-weight:650;
  font-size:14px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.03);
  color:var(--text);
  transition:.15s ease;
  cursor:pointer;
  white-space:nowrap;
}

.btn:hover{
  transform:translateY(-1px);
  background:rgba(255,255,255,.05);
  border-color:rgba(255,255,255,.14)
}

.btnPrimary{
  border:1px solid rgba(30,144,255,.55);
  background: linear-gradient(135deg, rgba(30,144,255,.98), rgba(77,163,255,.95));
  box-shadow:
    0 16px 40px rgba(30,144,255,.22),
    0 0 0 1px rgba(30,144,255,.18) inset;
  color:#fff;
}

.btnPrimary:hover{
  box-shadow:
    0 18px 46px rgba(30,144,255,.30),
    0 0 0 1px rgba(30,144,255,.24) inset;
}

.btnSecondary{
  background: rgba(10,14,20,.55);
  border-color: rgba(255,255,255,.22);
  box-shadow: 0 12px 30px rgba(0,0,0,.35);
  backdrop-filter: blur(12px);
}

.btnSecondary:hover{
  background: rgba(10,14,20,.68);
  border-color: rgba(255,255,255,.30);
  box-shadow: 0 16px 38px rgba(0,0,0,.45);
}

.chip{
  display:inline-flex; align-items:center; gap:10px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(10,14,20,.55);
  backdrop-filter: blur(10px);
  font-size:13px;
}

.dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 18px rgba(30,144,255,.65)
}

.card{
  border-radius:26px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(17,24,35,.55);
  box-shadow: 0 22px 70px rgba(0,0,0,.45);
  overflow:hidden;
}

.cardPad{padding:22px}

.page{
  position: relative;
  border-top: 0 !important;
  padding:34px 0 54px;
  background:
    radial-gradient(900px 450px at 10% 0%, rgba(30,144,255,.10), transparent 60%),
    radial-gradient(900px 450px at 90% 0%, rgba(77,163,255,.08), transparent 60%);
}

.grid3{display:grid; grid-template-columns:repeat(3,1fr); gap:12px}

/* Header */
header{
  position: fixed; top:0; left: 0; z-index:1000;
  width: 100%;
  transform: translateY(0);
  transition: transform 0.35s ease;
  will-change: transform;
  background:rgba(6,8,11,.55);
  backdrop-filter: blur(14px);
  border-bottom:1px solid rgba(255,255,255,.06);
}

header.nav-hidden {
  transform: translateY(-110%);
}

header.nav-show {
  animation: navReveal 0.45s cubic-bezier(.22,.68,0,1.15);
}

@keyframes navReveal {
  0% {
    transform: translateY(-110%);
  }
  70% {
    transform: translateY(8px);
  }
  100% {
    transform: translateY(0);
  }
}

.nav{display:flex; align-items:center; justify-content:space-between; height:74px}

.logo{
  display:flex; align-items:center; gap:10px;
  font-family:"Bebas Neue", Impact, sans-serif;
  letter-spacing:.08em;
  font-size:26px;
  line-height:1;
}

.logoMark{
  width:12px; height:12px; border-radius:3px;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  box-shadow:0 0 24px rgba(30,144,255,.55);
  transform:rotate(12deg);
}

nav ul{list-style:none; display:flex; gap:16px; margin:0; padding:0; align-items:center}

nav a{
  font-size:14px;
  color:rgba(234,240,246,.88);
  padding:10px 10px;
  border-radius:12px;
  transition:.15s ease;
}

nav a:hover{background:rgba(255,255,255,.04); color:var(--text)}
nav a.active{background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08)}

.ctaRow{display:flex; align-items:center; gap:12px}

.hamburger {
  display: none;
  width: 46px;
  height: 46px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 16px;
  background: rgba(255,255,255,.04);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  align-items: center;
  justify-content: center;
  position: relative;
  cursor: pointer;
  transition:
    background .25s ease,
    border-color .25s ease,
    box-shadow .25s ease,
    transform .18s ease;
  flex: 0 0 auto;
  z-index: 1201;
}

.hamburger:hover {
  background: rgba(255,255,255,.08);
  border-color: rgba(77,163,255,.34);
  box-shadow: 0 10px 28px rgba(0,0,0,.28), 0 0 0 1px rgba(30,144,255,.10);
}

.hamburger:active {
  transform: scale(.96);
}

.hamburger span {
  position: absolute;
  left: 50%;
  width: 18px;
  height: 2px;
  border-radius: 999px;
  background: #fff;
  transform: translateX(-50%);
  transition:
    transform .30s cubic-bezier(.22,.68,0,1.2),
    opacity .20s ease,
    top .30s ease,
    width .25s ease,
    background .25s ease;
}

.hamburger span:nth-child(1) {
  top: 15px;
}

.hamburger span:nth-child(2) {
  top: 22px;
  width: 14px;
}

.hamburger span:nth-child(3) {
  top: 29px;
}

.hamburger:hover span:nth-child(2) {
  width: 18px;
}

.hamburger.open span:nth-child(1) {
  top: 22px;
  transform: translateX(-50%) rotate(45deg);
}

.hamburger.open span:nth-child(2) {
  opacity: 0;
  width: 0;
}

.hamburger.open span:nth-child(3) {
  top: 22px;
  transform: translateX(-50%) rotate(-45deg);
}

/* mobile prikaz */
@media (max-width: 980px) {
  .hamburger {
    display: inline-flex;
  }

  .ctaRow .btn,
  .ctaRow .iconBtn {
    display: none;
  }

  header nav {
    display: none;
  }
}

@media (max-width: 560px) {
  .hamburger {
    width: 44px;
    height: 44px;
    border-radius: 14px;
  }

  .hamburger span:nth-child(1) { top: 14px; }
  .hamburger span:nth-child(2) { top: 21px; }
  .hamburger span:nth-child(3) { top: 28px; }
}

.drawer{
  display:none;
  inset:74px 30px auto 16px;
  transform: translateY(-8px);
  transition:
    opacity .22s ease,
    transform .22s cubic-bezier(.22,.68,0,1.2),
    visibility .22s ease;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(17,24,35,.92);
  backdrop-filter: blur(16px);
  box-shadow: 0 28px 70px rgba(0,0,0,.60);
  padding:10px;
  z-index:60;
}

.drawer.open {
  opacity: 1;
  display: block;
  visibility: visible;
  transform: translateY(0);
}
.drawer a{display:block; padding:12px; border-radius:14px}
.drawer a:hover{background:rgba(255,255,255,.04)}



/* Footer */
footer{padding:34px 0 40px; border-top:1px solid rgba(255,255,255,.06)}
.footerGrid{display:grid; grid-template-columns:1.2fr 1fr 1fr; gap:18px}
.footerTitle{font-weight:700; margin:0 0 8px}
.copy{margin-top:18px; font-size:12px; color:rgba(154,166,178,.9); display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap}

/* HERO */
.hero{
  position:relative;
  min-height: calc(100svh - 72px);
  display:flex;
  align-items:stretch;
  overflow:hidden;
  border-bottom: 0 !important;
}

.heroBg{
  position:absolute; inset:0;
  background:
    radial-gradient(900px 520px at 10% 0%, rgba(30,144,255,.14), transparent 60%),
    radial-gradient(900px 520px at 90% 10%, rgba(77,163,255,.08), transparent 60%),
    linear-gradient(90deg, rgba(6,8,11,.92) 0%, rgba(6,8,11,.78) 45%, rgba(6,8,11,.28) 100%),
    url("assets/2023-08-05.webp") center/cover no-repeat;
  filter:saturate(1.06) contrast(1.06);
  transform:scale(1.02);
  z-index:1;
}

.heroTexture{
  position:absolute; inset:0;
  background: repeating-linear-gradient(45deg, rgba(255,255,255,.03) 0 6px, rgba(255,255,255,.01) 6px 12px);
  opacity:.10;
  mix-blend-mode:overlay;
  pointer-events:none;
  z-index:1;
}

.heroInner{
  position:relative;
  width:100%;
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:16px;
  align-items:center;
  padding:44px 0;
  z-index:3;
}

.hero,
.heroInner,
.heroGrid,
.page,
.section,
.container {
  box-sizing: border-box;
}

@media (max-width: 900px) {
  .container,
  .section,
  .heroInner,
  .page {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  .hero {
    min-height: auto;
    padding-top: 110px;
    padding-bottom: 40px;
  }

  .heroGrid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 22px;
    align-items: start;
  }

  .heroContent,
  .heroForm,
  .floatPanel {
    width: 100%;
    max-width: 100%;
    margin: 0;
  }
}

.hTitle{
  font-family:"Bebas Neue", Impact, sans-serif;
  letter-spacing:.05em;
  font-size:74px;
  line-height:.9;
  margin:14px 0 14px;
  text-shadow: 0 22px 70px rgba(0,0,0,.65);
}

.lead{
  margin:0;
  color:rgba(234,240,246,.92);
  line-height:1.7;
  max-width:70ch;
  text-shadow: 0 10px 30px rgba(0,0,0,.55);
}

.floatPanel{
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.10);
  background: rgba(12,16,22,.58);
  backdrop-filter: blur(16px);
  box-shadow: var(--shadow);
  overflow:hidden;
}

.floatTop{padding:18px; border-bottom:1px solid rgba(255,255,255,.06)}
.floatTop b{display:block; font-size:15px}
.floatTop p{margin:8px 0 0; font-size:13px; line-height:1.6; color:rgba(154,166,178,.95)}

.vinRow{padding:14px 18px 18px; display:flex; gap:10px; align-items:center}

.vinRow input{
  width:100%;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(6,8,11,.55);
  padding:12px 12px;
  color:var(--text);
  outline:none;
  font-size:14px;
}

.vinRow input::placeholder{color:rgba(154,166,178,.8)}

.miniGrid{display:grid; grid-template-columns:1fr 1fr; gap:10px; padding:0 18px 18px}

.mini{
  border:1px solid rgba(255,255,255,.06);
  border-radius:18px;
  background: rgba(6,8,11,.35);
  padding:12px;
}

.mini strong{
  display:block;
  font-family:"Bebas Neue";
  letter-spacing:.05em;
  font-size:34px;
  line-height:1;
}

.mini span{font-size:12px; color:rgba(154,166,178,.95)}

.hero::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:-2px;
  height:320px;
  background: linear-gradient(
    to bottom,
    rgba(6,8,11,0) 0%,
    rgba(6,8,11,.55) 35%,
    rgba(6,8,11,.85) 70%,
    rgba(6,8,11,1) 100%
  );
  pointer-events:none;
  z-index:2;
}

.page::before{
  content:"";
  position:absolute;
  left:0; right:0; top:-2px;
  height:220px;
  background: linear-gradient(
    to bottom,
    rgba(6,8,11,1) 0%,
    rgba(6,8,11,.85) 35%,
    rgba(6,8,11,0) 100%
  );
  pointer-events:none;
  z-index:0;
}

.page > .container{ position: relative; z-index: 1; }

/* Responsive */
@media(max-width:980px){
  nav ul{display:none}
  .hamburger{display:inline-block}
  .heroInner{grid-template-columns:1fr}
  .hTitle{font-size:60px}
  .grid3{grid-template-columns:1fr}
  .footerGrid{grid-template-columns:1fr}
}

@media(max-width:560px){
  .hTitle{font-size:50px}
}

/* Contact page extras */
.h2{
  font-family:"Bebas Neue", Impact, sans-serif;
  letter-spacing:.06em;
  font-size:34px;
  line-height:1;
  margin:0 0 6px;
}

.link{
  color: rgba(234,240,246,.95);
  text-decoration: underline;
  text-decoration-color: rgba(77,163,255,.65);
  text-underline-offset: 3px;
}
.link:hover{ color:#fff; text-decoration-color: rgba(77,163,255,.95); }

.contactGrid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:12px;
  align-items:stretch;
}

.form{ display:grid; gap:12px; }
.formRow{ display:grid; grid-template-columns: 1fr 1fr; gap:12px; }

.field label{
  display:block;
  font-size:12px;
  color: rgba(154,166,178,.95);
  margin:0 0 6px;
}

.field input, .field textarea{
  width:100%;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(6,8,11,.45);
  padding:12px 12px;
  color:var(--text);
  outline:none;
  font-size:14px;
}

.field input:focus, .field textarea:focus{
  border-color: rgba(77,163,255,.45);
  box-shadow: 0 0 0 4px rgba(30,144,255,.12);
}

.field select{
  width:100%;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(6,8,11,.45);
  padding:12px 12px;
  color:var(--text);
  outline:none;
  font-size:14px;
}

.field select:focus{
  border-color: rgba(77,163,255,.45);
  box-shadow: 0 0 0 4px rgba(30,144,255,.12);
}

.formActions{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  margin-top:4px;
}

/* Map card */
.mapCard{ display:flex; flex-direction:column; overflow:hidden; }
.mapTop{
  padding:16px 18px;
  border-bottom:1px solid rgba(255,255,255,.06);
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:12px;
}
.mapFrame{
  width:100%;
  height:420px;
  border:0;
  border-radius:18px;
  overflow:hidden;
  filter: invert(1) hue-rotate(180deg) saturate(0.9) contrast(1.05) brightness(0.95);
  background:#0b1220;
}
.mapBottom{
  padding:16px 18px;
  border-top:1px solid rgba(255,255,255,.06);
  display:flex;
  gap:12px;
  align-items:flex-start;
  justify-content:space-between;
}
.mapHint{ max-width: 56ch; }

/* About page extras */
.aboutHero{
  position:relative;
  border-radius:26px;
  border:1px solid rgba(255,255,255,.08);
  overflow:hidden;
  background: rgba(17,24,35,.35);
  box-shadow: 0 22px 70px rgba(0,0,0,.45);
}

.aboutHeroBg{
  position:absolute; inset:0;
  background:
    radial-gradient(900px 480px at 10% 0%, rgba(30,144,255,.18), transparent 60%),
    radial-gradient(900px 480px at 90% 0%, rgba(77,163,255,.10), transparent 60%),
    linear-gradient(90deg, rgba(6,8,11,.78) 0%, rgba(6,8,11,.55) 45%, rgba(6,8,11,.20) 100%);
  pointer-events:none;
}

.aboutHeroInner{
  position:relative;
  z-index:1;
  padding:22px;
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:12px;
  align-items:stretch;
}

.aboutStats .cardPad{height:100%}

.statsGrid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
}

.stat{
  border:1px solid rgba(255,255,255,.06);
  border-radius:18px;
  background: rgba(6,8,11,.35);
  padding:14px;
}
.stat strong{
  display:block;
  font-family:"Bebas Neue";
  letter-spacing:.06em;
  font-size:44px;
  line-height:1;
}
.stat span{font-size:12px; color:rgba(154,166,178,.95)}

.aboutNote{
  margin-top:12px;
  border-top:1px solid rgba(255,255,255,.06);
  padding-top:12px;
}

.aboutList{
  margin:10px 0 0;
  padding-left:18px;
  color:rgba(154,166,178,.95);
  line-height:1.7;
}
.aboutList b{ color: rgba(234,240,246,.92); }

.aboutSplit{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:14px;
  align-items:start;
}

.pillRow{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:12px;
}

.pill{
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(10,14,20,.45);
  font-size:13px;
  color: rgba(234,240,246,.92);
}

.aboutSteps{display:grid; gap:10px}
.step{
  display:grid;
  grid-template-columns: 54px 1fr;
  gap:12px;
  border:1px solid rgba(255,255,255,.06);
  border-radius:18px;
  background: rgba(6,8,11,.35);
  padding:14px;
}

.stepNum{
  font-family:"Bebas Neue";
  letter-spacing:.06em;
  font-size:34px;
  line-height:1;
  color: rgba(77,163,255,.95);
}

.timeline{
  margin-top:12px;
  display:grid;
  gap:10px;
}

.tlItem{
  display:grid;
  grid-template-columns: 18px 1fr;
  gap:12px;
  align-items:start;
  padding:12px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.06);
  background: rgba(6,8,11,.35);
}

.tlDot{
  width:10px; height:10px;
  border-radius:50%;
  background: var(--accent);
  box-shadow:0 0 18px rgba(30,144,255,.55);
  margin-top:6px;
}

.iconBtn{
  width:42px; height:42px;
  display:inline-flex; align-items:center; justify-content:center;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.03);
  transition:.15s ease;
}
.iconBtn:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.22);
  box-shadow: 0 18px 46px rgba(30,144,255,.18);
}
.icon{
  width:18px; height:18px;
  fill: rgba(234,240,246,.92);
}
.iconBtn:hover .icon{
  fill: rgba(77,163,255,.95);
}

/* Services page */
.sectionTop{ margin-top:6px; }

.serviceHero{
  position:relative;
  border-radius:26px;
  border:1px solid rgba(255,255,255,.08);
  overflow:hidden;
  background: rgba(17,24,35,.35);
  box-shadow: 0 22px 70px rgba(0,0,0,.45);
}

.serviceHeroBg{
  position:absolute; inset:0;
  background:
    radial-gradient(900px 480px at 10% 0%, rgba(30,144,255,.18), transparent 60%),
    radial-gradient(900px 480px at 90% 0%, rgba(77,163,255,.10), transparent 60%),
    linear-gradient(90deg, rgba(6,8,11,.78) 0%, rgba(6,8,11,.55) 45%, rgba(6,8,11,.20) 100%);
  pointer-events:none;
}

.serviceHeroInner{
  position:relative;
  z-index:1;
  padding:22px;
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:12px;
  align-items:stretch;
}

.serviceShots{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
}
.shot{
  border-radius:22px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(6,8,11,.35);
  box-shadow: 0 18px 60px rgba(0,0,0,.35);
}
.shot:nth-child(1){ grid-column: 1 / -1; }
.shot img{ width:100%; height:100%; display:block; object-fit:cover; min-height:140px; }

.servicesGrid{
  display:grid;
  grid-template-columns: repeat(2, 2fr);
  gap:12px;
  margin-top:12px;
}

.serviceCard{
  border-radius:26px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(17,24,35,.55);
  box-shadow: 0 22px 70px rgba(0,0,0,.45);
  overflow:hidden;
  display:grid;
  grid-template-columns: 2.95fr 3.05fr;
}

.serviceMedia{
  position:relative;
  min-height: 240px;
  background: rgba(6,8,11,.35);
}
.serviceMedia img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  filter:saturate(1.05) contrast(1.05);
}
.serviceMedia::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(90deg, rgba(6,8,11,.10), rgba(6,8,11,.55));
  pointer-events:none;
}

.serviceTag{
  position:absolute;
  left:14px; top:14px;
  padding:8px 12px;
  border-radius:999px;
  font-size:12px;
  font-weight:700;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(10,14,20,.55);
  backdrop-filter: blur(10px);
}

.serviceBody{ padding:18px; display:flex; flex-direction:column; gap:20px; }
.serviceHead{
  display:flex;
  justify-content:space-between;
  gap:12px;
  font-size: 23px;
  font-weight: bold;
  align-items:baseline;
}
.price{
  font-size:13px;
  color: rgba(154,166,178,.95);
  white-space:nowrap;
}
.serviceMeta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:2px;
}
.miniPill{
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(6,8,11,.35);
  font-size:12px;
  color: rgba(234,240,246,.88);
}
.serviceActions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:auto;
}

.serviceCta{
  display:flex;
  gap:14px;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
}

/* Modal */
.modal{
  position:fixed;
  inset:0;
  z-index:9999;
  display:none;
}
.modal.open{ display:block; }

.modalBackdrop{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.65);
  backdrop-filter: blur(6px);
}

/* Details modal (image + text, services) */
.modal.modalDetails .modalDialog{
  position:relative;
  max-width: 980px;
  margin: 6vh auto;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(17,24,35,.92);
  backdrop-filter: blur(16px);
  box-shadow: 0 28px 70px rgba(0,0,0,.65);
  overflow:hidden;
}

.modal.modalDetails .modalClose{
  position:absolute;
  top:12px; right:12px;
  width:42px; height:42px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  color:#fff;
  cursor:pointer;
  z-index:2;
}

.modal.modalDetails .modalGrid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  min-height: 420px;
}
.modal.modalDetails .modalMedia{ background: rgba(6,8,11,.55); }
.modal.modalDetails .modalMedia img{ width:100%; height:100%; object-fit:cover; display:block; }

/* Form modal (Admin: header/body/footer scroll) */
.modal.modalForm .modalDialog{
  position:relative;
  margin: 12px auto;
  width: min(980px, calc(100vw - 24px));
  height: calc(100vh - 24px);
  max-height: calc(100vh - 24px);
  display:flex;
  flex-direction:column;
  overflow:hidden;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(12,16,22,.92);
  box-shadow: 0 28px 70px rgba(0,0,0,.60);
}

.modal.modalForm .modalClose{
  position:static;
  width:42px; height:42px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  color:var(--text);
  cursor:pointer;
}

.modal.modalForm .modalHeader{
  flex: 0 0 auto;
  padding: 14px 18px 10px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: rgba(6,8,11,.92);
  backdrop-filter: blur(10px);
}
.modal.modalForm .modalHeaderTop{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.modal.modalForm .modalSub{
  margin: 8px 0 0;
  opacity:.9;
}

.modal.modalForm .modalBody{
  flex: 1 1 auto;
  overflow:auto;
  padding: 14px 18px 16px;
  scrollbar-width:none;
}
.modal.modalForm .modalBody::-webkit-scrollbar{ width:0; height:0; }

.modal.modalForm .modalFooter{
  flex: 0 0 auto;
  padding: 12px 18px 14px;
  border-top: 1px solid rgba(255,255,255,.08);
  background: rgba(6,8,11,.92);
  backdrop-filter: blur(10px);
}

/* Services details modal (stack layout) */
.modalDetails .modalDialog{
  width: min(980px, calc(100vw - 28px));
  border-radius: 22px;
  overflow:hidden;
}

.modalDetails .modalStack{
  display:grid;
  grid-template-columns: 1fr;
}

.modalDetails .modalMediaTop{
  background: rgba(255,255,255,.03);
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.modalDetails .modalMediaTop img{
  width:100%;
  height: min(46vh, 380px);
  display:block;
  object-fit:cover;
}

.modalDetails .modalBody{
  padding: 18px 18px 20px;
}

.modalTitle{
  font-family:"Bebas Neue", Impact, sans-serif;
  letter-spacing:.06em;
  font-size:40px;
  margin:0;
}

/* Admin + Servisna knjiga */
.adminTop{display:flex; align-items:flex-start; justify-content:space-between; gap:12px; flex-wrap:wrap;}
.adminTopActions{display:flex; gap:10px; flex-wrap:wrap;}

.adminGrid{
  display:grid;
  grid-template-columns: .95fr 1.05fr;
  gap:12px;
  align-items:start;
}
.adminList{overflow:hidden;}
.adminListTop{
  padding:14px 14px 10px;
  border-bottom:1px solid rgba(255,255,255,.06);
  display:flex;
  gap:10px;
  align-items:center;
  justify-content:space-between;
}
.adminSearch{
  width:220px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(6,8,11,.45);
  padding:10px 10px;
  color:var(--text);
  outline:none;
  font-size:13px;
}
.adminSearch::placeholder{color:rgba(154,166,178,.8)}

.vinList{display:grid; gap:8px; padding:12px;}
.vinRowBtn{
  border:1px solid rgba(255,255,255,.08);
  background: rgba(6,8,11,.35);
  border-radius:16px;
  padding:12px;
  text-align:left;
  color:var(--text);
  cursor:pointer;
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:10px;
  transition:.15s ease;
}
.vinRowBtn:hover{transform:translateY(-1px); border-color:rgba(255,255,255,.14)}
.vinRowBtn.active{border-color: rgba(77,163,255,.35); box-shadow: 0 0 0 4px rgba(30,144,255,.10);}

.adminDetailTop{display:flex; align-items:flex-start; justify-content:space-between; gap:12px; flex-wrap:wrap;}
.svcList{display:grid; gap:12px; margin-top:10px;}
.svcCard{
  border:1px solid rgba(255,255,255,.08);
  background: rgba(6,8,11,.35);
  border-radius:18px;
  padding:14px;
}
.svcTop{display:flex; align-items:flex-start; justify-content:space-between; gap:10px; flex-wrap:wrap;}
.svcTop b{font-size:15px;}

.pinBox{
  min-width:120px;
  text-align:center;
  font-family:"Bebas Neue", Impact, sans-serif;
  font-size:34px;
  letter-spacing:.12em;
  padding:10px 14px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(6,8,11,.45);
}

.imgThumbs{display:flex; gap:10px; flex-wrap:wrap; margin-top:12px;}
.imgThumbBtn{
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.02);
  border-radius:16px;
  padding:0;
  overflow:hidden;
  cursor:pointer;
  width:140px;
  height:92px;
}
.imgThumbBtn img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

/* Admin tables */
.lineTable{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  overflow:hidden;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(6,8,11,.35);
}
.lineTable thead th{
  text-align:left;
  padding:10px 12px;
  font-size:13px;
  color: rgba(234,240,246,.92);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.lineTable td{
  padding:8px 10px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.lineTable tr:last-child td{ border-bottom:0; }
.lineInput{
  width:100%;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(6,8,11,.45);
  color:var(--text);
  padding:10px 10px;
  outline:none;
  font-size:14px;
}
.lineInput:focus{
  border-color: rgba(77,163,255,.45);
  box-shadow: 0 0 0 4px rgba(30,144,255,.12);
}

.svcImages{
  display:grid;
  gap:10px;
  margin-top:10px;
}
.imgRow{
  display:grid;
  grid-template-columns: auto 1fr auto;
  gap:12px;
  align-items:center;
  padding:12px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.02);
  gap: 12px;
}
.imgThumb{
  width:72px;
  height:48px;
  border-radius:12px;
  object-fit:cover;
  border:1px solid rgba(255,255,255,.08);
}

/* Service preview */
.svcMeta{
  margin-top:8px;
  font-size:13px;
  opacity:.9;
  line-height:1.4;
}

.svcBadges{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:10px;
}

.svcBadge{
  font-size:12px;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  color: rgba(234,240,246,.9);
}

.svcBadge b{
  color:var(--accent);
  font-weight:700;
}

/* Service details modal */
.detailWrap{
  display:grid;
  gap:14px;
}

.detailSection{
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(6,8,11,.35);
  border-radius:18px;
  overflow:hidden;
}

.detailHead{
  padding: 12px 14px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  background: rgba(6,8,11,.55);
}

.detailHead h4{
  margin:0;
  font-size:14px;
  letter-spacing:.04em;
  text-transform:uppercase;
  opacity:.95;
}

.detailBody{
  padding: 12px 14px 14px;
}

.detailTextBox{
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  border-radius:14px;
  padding: 12px 12px;
  line-height:1.75;
  white-space:pre-wrap;
}

.detailTable{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  overflow:hidden;
  border-radius:14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.02);
}

.detailTable th{
  text-align:left;
  padding: 10px 12px;
  font-size:13px;
  opacity:.9;
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: rgba(6,8,11,.35);
}

.detailTable td{
  padding: 10px 12px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  vertical-align:top;
}
.detailTable tr:last-child td{ border-bottom:0; }

.badgeCount{
  font-size:12px;
  opacity:.8;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  padding: 6px 10px;
  border-radius:999px;
}

.detailImgs{
  display:grid;
  gap:10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.detailImgBtn{
  display:block;
  padding:0;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.02);
  border-radius:16px;
  overflow:hidden;
  cursor:pointer;
  text-align:left;
}

.detailImgBtn img{
  width:100%;
  height:210px;
  object-fit:cover;
  display:block;
  border:0;
  background:transparent;
}

.detailImgMeta{
  padding: 10px 12px 12px;
  border-top: 1px solid rgba(255,255,255,.08);
}

.detailImgMeta b{ display:block; }
.detailImgMeta .muted{ font-size:12px; margin-top:4px; }

#imgModal .modalDialog{
  background: rgba(12,16,22,.95);
}
#imgModal .modalBody{
  padding:14px;
}
#imgModal .modalMedia{
  margin-top:10px;
  border-radius:18px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.10);
}
#imgModal #imgFull{
  display:block;
  width:100%;
  height:auto;
  border-radius:0;
  border:0 !important;
  background:transparent;
}

.numCell{
  width:52px;
  opacity:.75;
}

#svcModal{ z-index:10000; }
#imgModal{ z-index:20000; }

/* Gallery */
.galleryGrid{
  display:grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap:12px;
}

.galleryItem{
  display:block;
  padding:0;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.02);
  border-radius:18px;
  overflow:hidden;
  cursor:pointer;
  aspect-ratio: 1 / 1;
  transition:.15s ease;
}

.galleryItem:hover{
  transform:translateY(-2px);
  border-color:rgba(255,255,255,.14);
}

.galleryItem img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.galleryFilters{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.filterBtn{
  color: #4DA3FF;
}

.galleryModalGrid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  min-height:420px;
}

.galleryModalMedia{
  background:rgba(6,8,11,.55);
}

.galleryModalMedia img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.galleryModalBody{
  padding:22px;
}

#o-nama{
  scroll-margin-top:95px;
}

/* Responsive */
@media(max-width:980px){
  .contactGrid{ grid-template-columns: 1fr; }
  .formRow{ grid-template-columns: 1fr; }
  .mapFrame{ height:320px; border-radius:16px; }
  .mapBottom{ flex-direction:column; align-items:stretch; }
  .aboutHeroInner{ grid-template-columns: 1fr; }
  .aboutSplit{ grid-template-columns: 1fr; }
  .serviceHeroInner{ grid-template-columns: 1fr; }
  .servicesGrid{ grid-template-columns: 1fr; }
  .serviceCard{ grid-template-columns: 1fr; }
  .serviceMedia{ min-height:220px; }
  .modal.modalDetails .modalDialog{ margin: 10vh 16px; }
  .modal.modalDetails .modalGrid{ grid-template-columns: 1fr; }
  .modal.modalDetails .modalMedia{ height:44vh; }
  .modal.modalForm .modalDialog{
    margin: 10px auto;
    width: calc(100vw - 16px);
    height: calc(100vh - 16px);
    max-height: calc(100vh - 16px);
  }
  .adminGrid{ grid-template-columns: 1fr; }
  .adminSearch{ width:100%; }
  .detailImgs{ grid-template-columns: 1fr; }
  .galleryGrid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .galleryModalGrid{ grid-template-columns: 1fr; }
  .galleryModalMedia img{ height:300px; }
  nav ul{ display:none; }
  .hamburger{ display:inline-block; }
  .heroInner{ grid-template-columns: 1fr !important; }
  .floatPanel{ position:static; width:100%; }
  .hTitle{ font-size:60px; }
  .grid3{ grid-template-columns: 1fr; }
  .footerGrid{ grid-template-columns: 1fr; }
  header .ctaRow .btn{ display:none; }
  header .ctaRow .iconBtn{ display:none; }
  header .ctaRow .hamburger{ display:inline-flex; }
  header .ctaRow .btnPrimary{ display:inline-flex; padding:10px 12px; font-size:14px; }
  .modalDialog{ width:calc(100% - 24px); max-width:560px; margin:12px auto; border-radius:18px; }
  .modalGrid{ grid-template-columns: 1fr !important; }
  .modalMedia img{ width:100%; height:220px; object-fit:cover; border-radius:16px; }
}

@media(max-width:640px){
  .galleryGrid{ grid-template-columns: 1fr 1fr; gap:10px; }
  .galleryItem{ border-radius:14px; }
  .galleryModalBody{ padding:16px; }
}

@media(max-width:560px){
  .hTitle{ font-size:50px; }
}

@media (max-width: 768px) {
  .imgRow {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .imgRow img {
    width: 100%;
    height: auto;
  }

  .imgRow > div {
    font-size: 14px;
  }

  .imgRow button {
    width: 100%;
    min-height: 44px;
  }
}