/* ============================================================
   PREMIUM TAXI v4 – style.css
   Design language: Editorial luxury · dark-gold · high-contrast CTAs
   ============================================================ */

/* ── Design tokens ──────────────────────────────── */
:root {
  --bg:       #080808;
  --bg-2:     #0e0e0e;
  --bg-3:     #141414;
  --bg-4:     #1a1a1a;
  --surface:  #1e1e1e;
  --surf-2:   #262626;

  --border:      rgba(255,255,255,0.07);
  --border-2:    rgba(255,255,255,0.14);
  --border-gold: rgba(201,169,110,0.35);

  --text:   #f2ede5;
  --text-2: #9c9088;
  --text-3: #5c524a;

  --gold:      #c9a96e;
  --gold-lt:   #e8cc96;
  --gold-dk:   #a8843d;
  --glow-sm:   rgba(201,169,110,0.12);
  --glow-md:   rgba(201,169,110,0.22);
  --glow-lg:   rgba(201,169,110,0.35);

  --red:   #e05555;
  --green: #27c76e;
  --blue:  #4a8cff;
  --amber: #f0a030;

  --r-sm:  4px;
  --r-md:  10px;
  --r-lg:  18px;

  --shadow-sm: 0 2px 12px rgba(0,0,0,0.4);
  --shadow-md: 0 8px 36px rgba(0,0,0,0.55);
  --shadow-lg: 0 16px 60px rgba(0,0,0,0.7);
  --glow-card: 0 0 50px rgba(201,169,110,0.12);

  --t:     0.2s ease;
  --t-med: 0.35s ease;

  --font-d: 'Cormorant Garamond', Georgia, serif;
  --font-b: 'DM Sans', system-ui, sans-serif;

  --max-w: 1240px;
}

[data-theme="light"] {
  --bg:      #f4f1ec;
  --bg-2:    #ece9e3;
  --bg-3:    #e4e0d8;
  --bg-4:    #dedad1;
  --surface: #ffffff;
  --surf-2:  #f8f5f0;
  --border:     rgba(0,0,0,0.07);
  --border-2:   rgba(0,0,0,0.13);
  --border-gold:rgba(160,120,64,0.35);
  --text:   #18130e;
  --text-2: #6a5e52;
  --text-3: #9e9088;
  --gold:      #a07840;
  --gold-lt:   #8a6030;
  --glow-sm:   rgba(160,120,64,0.08);
  --glow-md:   rgba(160,120,64,0.16);
  --glow-lg:   rgba(160,120,64,0.28);
  --shadow-sm: 0 2px 12px rgba(0,0,0,0.08);
  --shadow-md: 0 8px 36px rgba(0,0,0,0.1);
  --shadow-lg: 0 16px 60px rgba(0,0,0,0.14);
  --glow-card: 0 0 50px rgba(160,120,64,0.08);
}

/* ── Reset ──────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; scroll-padding-top:76px; }
body {
  font-family:var(--font-b); background:var(--bg); color:var(--text);
  line-height:1.65; overflow-x:hidden;
  transition:background var(--t-med), color var(--t-med);
}
h1,h2,h3,h4 { font-family:var(--font-d); font-weight:300; line-height:1.1; }
a { color:inherit; text-decoration:none; }
ul,ol { list-style:none; }
button { font-family:var(--font-b); cursor:pointer; }
em { font-style:italic; color:var(--gold); }
strong { font-weight:500; }

.container { width:min(var(--max-w), 94vw); margin-inline:auto; }
.section { padding:100px 0; }
.amber { color:var(--amber); font-weight:600; }

/* ── Section header ─────────────────────────────── */
.sec-head { text-align:center; margin-bottom:64px; }
.sec-tag {
  display:inline-block; font-size:0.66rem; font-weight:500;
  letter-spacing:0.24em; text-transform:uppercase;
  color:var(--gold); border:1px solid var(--border-gold);
  padding:4px 14px; border-radius:100px; margin-bottom:18px;
}
.sec-head h2 { font-size:clamp(2rem,5vw,3.8rem); margin-bottom:14px; }
.sec-sub { font-size:1rem; color:var(--text-2); max-width:520px; margin:0 auto; }

/* ── Buttons ────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:9px;
  font-size:0.84rem; font-weight:500;
  letter-spacing:0.07em; text-transform:uppercase;
  padding:14px 30px; border-radius:var(--r-sm);
  border:none; transition:all var(--t); white-space:nowrap;
}
.btn-call {
  background:var(--gold); color:#080808;
}
.btn-call:hover { background:var(--gold-lt); transform:translateY(-2px); box-shadow:0 10px 32px var(--glow-lg); }

.btn-calc {
  background:transparent; color:var(--text);
  border:1px solid var(--border-2);
}
.btn-calc:hover { border-color:var(--gold); color:var(--gold); transform:translateY(-2px); }

.btn-cta-big {
  background:transparent; color:var(--gold);
  border:1px solid var(--gold);
  font-family:var(--font-d); font-size:1.6rem; font-weight:300;
  padding:20px 56px;
}
.btn-cta-big:hover { background:var(--gold); color:#080808; box-shadow:0 0 70px var(--glow-lg); transform:translateY(-3px); }

.btn-lg { font-size:0.9rem; padding:16px 36px; }
.btn-full { width:100%; justify-content:center; }

/* ── Pulse dot ──────────────────────────────────── */
.pulse-dot {
  width:8px; height:8px; border-radius:50%;
  background:var(--green); flex-shrink:0; position:relative; display:inline-block;
}
.pulse-dot::after {
  content:''; position:absolute; inset:-4px; border-radius:50%;
  background:rgba(39,199,110,0.4); animation:pulse 1.6s ease-out infinite;
}
.pulse-dot--amber { background:var(--amber); }
.pulse-dot--amber::after { background:rgba(240,160,48,0.4); }
@keyframes pulse { 0%{transform:scale(0.7);opacity:1} 100%{transform:scale(2.6);opacity:0} }

/* ════════════════════════════
   COOKIE BANNER
════════════════════════════ */
.cookie-banner {
  position:fixed; bottom:20px; left:50%; transform:translateX(-50%);
  z-index:9000; width:min(740px,95vw);
  background:var(--surface); border:1px solid var(--border-2);
  border-radius:var(--r-lg); box-shadow:var(--shadow-lg);
  backdrop-filter:blur(20px); padding:16px 20px;
  transition:transform 0.4s cubic-bezier(0.22,1,0.36,1), opacity 0.4s;
}
.cookie-banner.is-hidden { transform:translateX(-50%) translateY(140%); opacity:0; pointer-events:none; }
.cookie-inner { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.cookie-icon { font-size:1.3rem; flex-shrink:0; }
.cookie-inner p { flex:1; font-size:0.8rem; color:var(--text-2); }
.cookie-inner a { color:var(--gold); border-bottom:1px solid var(--glow-sm); }
.cookie-actions { display:flex; gap:8px; flex-shrink:0; }
.btn-cookie-decline {
  background:none; border:1px solid var(--border); color:var(--text-2);
  font-size:0.75rem; padding:7px 14px; border-radius:var(--r-sm);
  transition:border-color var(--t);
}
.btn-cookie-decline:hover { border-color:var(--border-2); }
.btn-cookie-accept {
  background:var(--gold); border:none; color:#080808;
  font-size:0.75rem; font-weight:500; padding:7px 14px; border-radius:var(--r-sm);
  transition:background var(--t);
}
.btn-cookie-accept:hover { background:var(--gold-lt); }

/* ════════════════════════════
   HEADER
════════════════════════════ */
.site-header {
  position:fixed; top:0; left:0; right:0; z-index:800;
  transition:background var(--t-med), box-shadow var(--t-med);
}
.site-header.is-scrolled {
  background:rgba(8,8,8,0.92); backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px); box-shadow:0 1px 0 var(--border);
}
[data-theme="light"] .site-header.is-scrolled { background:rgba(244,241,236,0.93); }

.nav-wrap {
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 4vw;
}

.logo { display:flex; align-items:center; gap:10px; }
.logo-gem { color:var(--gold); display:inline-block; animation:gem-spin 10s linear infinite; }
@keyframes gem-spin { to { transform:rotate(360deg); } }
.logo-name {
  font-size:0.76rem; font-weight:500; letter-spacing:0.22em; text-transform:uppercase;
}

.nav-links { display:flex; gap:32px; }
.nav-links a {
  font-size:0.74rem; font-weight:400; letter-spacing:0.12em;
  text-transform:uppercase; color:var(--text-2); transition:color var(--t);
}
.nav-links a:hover { color:var(--gold); }

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

.theme-toggle {
  background:none; border:1px solid var(--border); border-radius:100px;
  width:38px; height:38px; display:flex; align-items:center; justify-content:center;
  color:var(--text); font-size:0.88rem;
  transition:border-color var(--t), transform var(--t);
}
.theme-toggle:hover { border-color:var(--gold); transform:scale(1.06); }
[data-theme="dark"]  .th-light { display:none; }
[data-theme="light"] .th-dark  { display:none; }

.nav-cta {
  display:flex; align-items:center; gap:7px;
  background:var(--gold); color:#080808;
  font-size:0.72rem; font-weight:500; letter-spacing:0.1em; text-transform:uppercase;
  padding:9px 18px; border-radius:var(--r-sm);
  transition:background var(--t), transform var(--t);
}
.nav-cta:hover { background:var(--gold-lt); transform:translateY(-1px); }

.hamburger {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; padding:4px;
}
.hamburger span {
  display:block; width:22px; height:1.5px; background:var(--text);
  transition:transform 0.3s, opacity 0.3s;
}
.hamburger.is-open span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
.hamburger.is-open span:nth-child(2) { opacity:0; }
.hamburger.is-open span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); }

/* ════════════════════════════
   HERO
════════════════════════════ */
.hero {
  min-height:100dvh; display:flex; flex-direction:column;
  justify-content:center; position:relative; overflow:hidden;
  padding:120px 4vw 80px;
}

/* Background canvas */
.hero-canvas { position:absolute; inset:0; pointer-events:none; }

.hc-grid {
  position:absolute; inset:0;
  background-image:linear-gradient(var(--border) 1px,transparent 1px),
    linear-gradient(90deg,var(--border) 1px,transparent 1px);
  background-size:90px 90px;
  mask-image:radial-gradient(ellipse 90% 80% at 50% 40%, black 20%, transparent 100%);
  opacity:0.6;
}
.hc-orb {
  position:absolute; border-radius:50%; filter:blur(110px); pointer-events:none;
}
.hc-orb--a { width:700px;height:700px;top:-200px;left:-150px;background:radial-gradient(circle,rgba(201,169,110,0.14) 0%,transparent 65%);animation:orb-a 12s ease-in-out infinite; }
.hc-orb--b { width:500px;height:500px;bottom:-100px;right:-100px;background:radial-gradient(circle,rgba(201,169,110,0.10) 0%,transparent 65%);animation:orb-b 9s ease-in-out infinite; }
.hc-orb--c { width:300px;height:300px;top:40%;right:25%;background:radial-gradient(circle,rgba(201,169,110,0.06) 0%,transparent 65%);animation:orb-c 14s ease-in-out infinite; }
@keyframes orb-a { 0%,100%{transform:translate(0,0)} 50%{transform:translate(40px,50px)} }
@keyframes orb-b { 0%,100%{transform:translate(0,0)} 50%{transform:translate(-30px,-25px)} }
@keyframes orb-c { 0%,100%{transform:translate(0,0)} 50%{transform:translate(20px,-30px)} }

.hc-line {
  position:absolute; background:linear-gradient(90deg,transparent,var(--gold),transparent);
  height:1px; opacity:0.18; pointer-events:none;
}
.hc-line--1 { top:30%; left:0; right:0; animation:line-sweep 6s ease-in-out infinite; }
.hc-line--2 { top:65%; left:0; right:0; animation:line-sweep 8s 2s ease-in-out infinite; }
@keyframes line-sweep { 0%,100%{opacity:0.08} 50%{opacity:0.22} }

/* Hero layout: two columns */
.hero-body {
  position:relative; z-index:1;
  display:grid; grid-template-columns:1fr 460px; gap:60px; align-items:center;
  width:min(var(--max-w),94vw); margin:0 auto;
}

.hero-tag {
  display:inline-block; font-size:0.68rem; font-weight:500;
  letter-spacing:0.22em; text-transform:uppercase; color:var(--gold);
  border:1px solid var(--border-gold); padding:4px 14px; border-radius:100px;
  margin-bottom:20px;
  animation:fade-up 0.9s 0.1s cubic-bezier(0.22,1,0.36,1) both;
}

.hero-h1 {
  font-size:clamp(3rem,8vw,6.5rem); font-weight:300; letter-spacing:-0.02em;
  margin-bottom:22px;
  animation:fade-up 0.9s 0.18s cubic-bezier(0.22,1,0.36,1) both;
}
.hero-h1-em {
  display:block; color:var(--gold); font-style:italic;
}

.hero-lead {
  font-size:1.05rem; color:var(--text-2); max-width:460px;
  margin-bottom:36px; line-height:1.7;
  animation:fade-up 0.9s 0.26s cubic-bezier(0.22,1,0.36,1) both;
}
.hero-lead strong { color:var(--text); }

.hero-btns {
  display:flex; gap:14px; flex-wrap:wrap; margin-bottom:40px;
  animation:fade-up 0.9s 0.34s cubic-bezier(0.22,1,0.36,1) both;
}

/* Trust row */
.trust-row {
  display:flex; flex-wrap:wrap; gap:20px;
  animation:fade-up 0.9s 0.42s cubic-bezier(0.22,1,0.36,1) both;
}
.trust-item {
  display:flex; align-items:center; gap:8px;
  font-size:0.8rem; color:var(--text-2);
}
.trust-icon { font-size:1rem; }

/* Price ticker card */
.price-ticker {
  background:var(--surface); border:1px solid var(--border-gold);
  border-radius:var(--r-lg); padding:26px;
  box-shadow:var(--glow-card);
  animation:fade-up 0.9s 0.22s cubic-bezier(0.22,1,0.36,1) both;
  position:relative; overflow:hidden;
}
.price-ticker::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);
}

.ticker-header {
  display:flex; justify-content:space-between; align-items:center; margin-bottom:18px;
}
.ticker-label {
  font-size:0.67rem; font-weight:500; letter-spacing:0.18em;
  text-transform:uppercase; color:var(--text-3);
}
.ticker-live {
  display:flex; align-items:center; gap:6px;
  font-size:0.62rem; font-weight:700; letter-spacing:0.18em; color:var(--green);
}
.ticker-dot {
  width:7px; height:7px; border-radius:50%; background:var(--green);
  animation:pulse 1.4s ease-out infinite;
}

.ticker-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:4px; margin-bottom:18px;
}
.ticker-item {
  display:flex; flex-direction:column; align-items:center;
  background:var(--surf-2); border:1px solid var(--border);
  border-radius:var(--r-sm); padding:12px 6px; gap:3px;
}
.ticker-item--accent { border-color:var(--border-gold); background:rgba(201,169,110,0.06); }
.ticker-name { font-size:0.6rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--text-3); }
.ticker-val  { font-family:var(--font-d); font-size:1.5rem; font-weight:300; color:var(--gold); }
.ticker-unit { font-size:0.62rem; color:var(--text-3); }

.ticker-tariff { display:flex; flex-direction:column; gap:8px; margin-bottom:14px; }
.tt-row {
  display:flex; justify-content:space-between; align-items:center;
  font-size:0.82rem; color:var(--text-2);
  padding:6px 10px; border-radius:var(--r-sm);
  background:var(--surf-2); border:1px solid var(--border);
}
.tt-row--night { background:rgba(74,140,255,0.04); border-color:rgba(74,140,255,0.15); }
.tt-row strong { color:var(--gold); font-family:var(--font-d); font-size:0.95rem; font-weight:400; }
.tt-sep { height:1px; background:var(--border); margin:2px 0; }
.ticker-note { font-size:0.65rem; color:var(--text-3); text-align:center; }

.hero-scroll {
  position:absolute; bottom:28px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center;
}
.scroll-chevron {
  width:24px; height:24px; border-right:1.5px solid var(--gold);
  border-bottom:1.5px solid var(--gold); transform:rotate(45deg);
  opacity:0.5; animation:chevron-bounce 2s ease-in-out infinite;
}
@keyframes chevron-bounce { 0%,100%{transform:rotate(45deg) translateY(0)} 50%{transform:rotate(45deg) translateY(6px)} }

@keyframes fade-up { from{opacity:0;transform:translateY(32px)} to{opacity:1;transform:translateY(0)} }

/* ════════════════════════════
   EVENTS BAR
════════════════════════════ */
.events-bar {
  background:linear-gradient(90deg,rgba(240,160,48,0.08),rgba(201,169,110,0.06),rgba(240,160,48,0.08));
  border-top:1px solid rgba(240,160,48,0.22); border-bottom:1px solid rgba(240,160,48,0.22);
  padding:12px 0; overflow:hidden;
  transition:max-height 0.4s ease, padding 0.4s ease, opacity 0.3s;
}
.events-bar.is-dismissed { max-height:0; padding:0; opacity:0; border:none; pointer-events:none; }
.eb-inner { display:flex; align-items:flex-start; gap:12px; }
.eb-icon  { font-size:1rem; flex-shrink:0; color:var(--amber); margin-top:1px; }
.eb-text  { flex:1; font-size:0.8rem; color:var(--text-2); line-height:1.5; }
.eb-text strong { color:var(--text); }
.eb-text a { color:var(--gold); border-bottom:1px solid var(--glow-sm); transition:color var(--t); }
.eb-text a:hover { color:var(--gold-lt); }
.eb-close { background:none; border:none; color:var(--text-3); padding:2px 6px; transition:color var(--t); }
.eb-close:hover { color:var(--text); }

/* ════════════════════════════
   USLUGE
════════════════════════════ */
.usluge { background:var(--bg-2); }
.service-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }

.svc-card {
  position:relative; background:var(--surface); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:32px 26px;
  transition:border-color var(--t), transform var(--t-med), box-shadow var(--t-med);
  overflow:hidden;
}
.svc-card:hover { border-color:var(--border-2); transform:translateY(-5px); box-shadow:var(--shadow-md); }

.svc-card--hero {
  border-color:var(--border-gold);
  box-shadow:var(--glow-card);
}
.svc-card--hero:hover { box-shadow:0 0 70px rgba(201,169,110,0.25); }
.svc-card__glow {
  position:absolute; inset:0; border-radius:var(--r-lg);
  background:radial-gradient(ellipse 80% 60% at 50% -20%, rgba(201,169,110,0.12), transparent);
  pointer-events:none;
}
.svc-card--event { border-color:rgba(240,160,48,0.2); }
.svc-card--event:hover { border-color:rgba(240,160,48,0.45); }

.svc-badge {
  position:absolute; top:-11px; left:18px;
  background:var(--gold); color:#080808;
  font-size:0.6rem; font-weight:700; letter-spacing:0.15em; text-transform:uppercase;
  padding:3px 12px; border-radius:100px;
}
.svc-icon { width:50px; height:50px; margin-bottom:18px; }
.svc-card h3 { font-family:var(--font-d); font-size:1.5rem; font-weight:400; margin-bottom:4px; }
.svc-time { font-size:0.76rem; color:var(--gold); letter-spacing:0.06em; margin-bottom:18px; }

.svc-tariff { display:flex; flex-direction:column; gap:7px; margin-bottom:16px; }
.svc-tariff div { display:flex; justify-content:space-between; font-size:0.83rem; }
.svc-tariff dt { color:var(--text-2); }
.svc-tariff dd { font-family:var(--font-d); font-size:0.98rem; font-weight:400; color:var(--gold); }

.svc-note { font-size:0.75rem; color:var(--text-3); font-style:italic; margin-bottom:16px; }
.svc-link { font-size:0.78rem; font-weight:500; color:var(--gold); letter-spacing:0.06em; transition:letter-spacing var(--t); }
.svc-link:hover { letter-spacing:0.1em; }

.svc-event-desc { font-size:0.85rem; color:var(--text-2); margin-bottom:20px; line-height:1.55; }
.svc-call-btn {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(240,160,48,0.1); border:1px solid rgba(240,160,48,0.35);
  color:var(--amber); font-size:0.78rem; font-weight:500;
  padding:10px 18px; border-radius:var(--r-sm);
  transition:background var(--t);
}
.svc-call-btn:hover { background:rgba(240,160,48,0.18); }

/* ════════════════════════════
   ZASTO
════════════════════════════ */
.zasto { background:var(--bg); }
.usp-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.usp-item {
  padding:28px; border-radius:var(--r-md);
  border:1px solid var(--border); background:var(--bg-3);
  transition:border-color var(--t), transform var(--t-med);
}
.usp-item:hover { border-color:var(--border-gold); transform:translateY(-3px); }
.usp-num {
  font-family:var(--font-d); font-size:2.5rem; font-weight:300;
  color:rgba(201,169,110,0.25); line-height:1; margin-bottom:12px;
  transition:color var(--t);
}
.usp-item:hover .usp-num { color:rgba(201,169,110,0.55); }
.usp-item h3 { font-family:var(--font-d); font-size:1.2rem; font-weight:400; margin-bottom:8px; }
.usp-item p { font-size:0.86rem; color:var(--text-2); line-height:1.6; }

/* ════════════════════════════
   KALKULATOR
════════════════════════════ */
.kalkulator { background:var(--bg-2); }
.calc-layout { display:grid; grid-template-columns:420px 1fr; gap:28px; align-items:start; }

/* Panel */
.calc-panel { display:flex; flex-direction:column; gap:14px; }

.fuel-bar {
  display:flex; justify-content:space-between; align-items:center;
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--r-md); padding:12px 18px;
}
.fb-item { display:flex; flex-direction:column; align-items:center; gap:2px; }
.fb-lbl { font-size:0.6rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--text-3); }
.fb-val { font-family:var(--font-d); font-size:1rem; color:var(--text); }
.fb-item--gold .fb-val { color:var(--gold); }
.fb-sep { width:1px; height:28px; background:var(--border); }

.fieldset { border:none; }
.fld-legend { display:block; font-size:0.7rem; font-weight:500; letter-spacing:0.08em; text-transform:uppercase; color:var(--text-2); margin-bottom:7px; }
.shift-toggle { display:flex; border:1px solid var(--border); border-radius:var(--r-sm); overflow:hidden; }
.shift-btn { flex:1; background:none; border:none; color:var(--text-2); font-size:0.78rem; font-weight:500; padding:11px 6px; transition:background var(--t), color var(--t); }
.shift-sub { font-size:0.68rem; opacity:0.7; }
.shift-btn--on { background:var(--gold); color:#080808; }

.form-grp { display:flex; flex-direction:column; gap:7px; }
.form-lbl { font-size:0.7rem; font-weight:500; letter-spacing:0.08em; text-transform:uppercase; color:var(--text-2); }
.input-row { display:flex; gap:8px; }
.ac-wrap { position:relative; flex:1; }

.form-inp {
  width:100%; background:var(--surface); border:1px solid var(--border);
  border-radius:var(--r-sm); color:var(--text); font-family:var(--font-b);
  font-size:0.9rem; padding:11px 13px; outline:none;
  transition:border-color var(--t);
}
.form-inp:focus { border-color:var(--gold); }
.form-inp::placeholder { color:var(--text-3); font-size:0.84rem; }

.btn-gps {
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--r-sm); color:var(--gold);
  width:44px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  transition:border-color var(--t), background var(--t);
}
.btn-gps:hover { border-color:var(--gold); background:var(--glow-sm); }
.btn-gps.is-loading { animation:spin 1s linear infinite; }
@keyframes spin { to{transform:rotate(360deg)} }

/* Autocomplete */
.ac-drop {
  position:absolute; top:calc(100% + 4px); left:0; right:0; z-index:300;
  background:var(--surf-2); border:1px solid var(--border-2);
  border-radius:var(--r-sm); overflow:hidden;
  box-shadow:var(--shadow-md); display:none;
}
.ac-drop.is-open { display:block; }
.ac-item {
  display:flex; align-items:flex-start; gap:9px;
  padding:10px 12px; font-size:0.82rem; color:var(--text-2);
  border-bottom:1px solid var(--border); cursor:pointer;
  transition:background var(--t), color var(--t);
}
.ac-item:last-child { border-bottom:none; }
.ac-item:hover,.ac-item.is-focused { background:var(--glow-sm); color:var(--text); }
.ac-icon { color:var(--gold); flex-shrink:0; font-size:0.82rem; margin-top:1px; }
.ac-name { font-weight:500; display:block; }
.ac-detail { font-size:0.72rem; color:var(--text-3); display:block; }

/* Stops */
.stops-hdr { display:flex; align-items:center; justify-content:space-between; }
.stops-badge {
  display:inline-flex; align-items:center; justify-content:center;
  background:var(--gold); color:#080808;
  font-size:0.58rem; font-weight:700;
  min-width:17px; height:17px; padding:0 5px;
  border-radius:100px; margin-left:5px; vertical-align:middle;
}
.btn-add-stop {
  display:flex; align-items:center; gap:6px;
  background:none; border:1px dashed var(--border);
  border-radius:var(--r-sm); color:var(--text-2);
  font-size:0.73rem; padding:6px 11px;
  transition:border-color var(--t), color var(--t), background var(--t);
}
.btn-add-stop:hover { border-color:var(--gold); color:var(--gold); background:var(--glow-sm); }
#stops-container { display:flex; flex-direction:column; gap:8px; margin-top:4px; }

.stop-row { display:flex; align-items:center; gap:8px; animation:slide-in 0.25s cubic-bezier(0.22,1,0.36,1) both; }
@keyframes slide-in { from{opacity:0;transform:translateY(-6px)} to{opacity:1;transform:translateY(0)} }
.stop-num {
  width:22px; height:22px; border-radius:50%;
  background:var(--surf-2); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-size:0.62rem; color:var(--text-3); flex-shrink:0;
}
.stop-input-wrap { flex:1; position:relative; }
.btn-rm-stop {
  background:none; border:1px solid var(--border);
  border-radius:var(--r-sm); color:var(--text-3);
  width:34px; height:38px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  transition:border-color var(--t), color var(--t);
}
.btn-rm-stop:hover { border-color:var(--red); color:var(--red); }

/* Hints */
.hints { display:flex; flex-direction:column; gap:5px; padding:2px 0; }
.hint { display:flex; align-items:center; gap:8px; font-size:0.77rem; color:var(--text-3); transition:color var(--t); }
.hint--on { color:var(--text-2); }
.hd { width:7px; height:7px; border-radius:50%; flex-shrink:0; opacity:0.3; transition:opacity var(--t), box-shadow var(--t); }
.hint--on .hd { opacity:1; }
.hint--on .hd--gold  { box-shadow:0 0 8px var(--gold); }
.hint--on .hd--blue  { box-shadow:0 0 8px var(--blue); }
.hint--on .hd--red   { box-shadow:0 0 8px var(--red); }
.hint--on .hd--green { box-shadow:0 0 8px var(--green); }
.hd--gold  { background:var(--gold); }
.hd--blue  { background:var(--blue); }
.hd--red   { background:var(--red); }
.hd--green { background:var(--green); }

/* Calculate button */
.btn-calc-go {
  display:flex; align-items:center; justify-content:center; gap:10px;
  width:100%; background:var(--gold); color:#080808;
  font-size:0.88rem; font-weight:600; letter-spacing:0.06em;
  padding:15px; border:none; border-radius:var(--r-sm);
  transition:background var(--t), transform var(--t), box-shadow var(--t), opacity var(--t);
}
.btn-calc-go:not(:disabled):hover { background:var(--gold-lt); transform:translateY(-2px); box-shadow:0 10px 32px var(--glow-lg); }
.btn-calc-go:disabled { opacity:0.35; cursor:not-allowed; }

/* Result box */
.result-box {
  background:var(--surface); border:1px solid var(--border-gold);
  border-radius:var(--r-md); padding:20px;
  display:flex; flex-direction:column; gap:10px;
  animation:fade-up 0.35s cubic-bezier(0.22,1,0.36,1) both;
}
.result-box[hidden] { display:none; }
.rb-head { display:flex; justify-content:space-between; align-items:center; margin-bottom:4px; }
.rb-title { font-size:0.68rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--text-3); }
.rb-badge { font-size:0.6rem; font-weight:700; letter-spacing:0.14em; text-transform:uppercase; color:var(--gold); background:var(--glow-sm); border:1px solid var(--border-gold); padding:2px 10px; border-radius:100px; }
.rb-list { display:flex; flex-direction:column; gap:7px; }
.rb-row { display:flex; justify-content:space-between; align-items:baseline; font-size:0.84rem; }
.rb-row dt { color:var(--text-2); }
.rb-row dd { font-weight:500; }
.rb-row[hidden] { display:none; }
.rb-total { display:flex; justify-content:space-between; align-items:baseline; padding-top:10px; margin-top:2px; border-top:1px solid var(--border); font-size:0.9rem; font-weight:500; }
.rb-total strong { font-family:var(--font-d); font-size:1.8rem; font-weight:300; color:var(--gold); }
.rb-notices { display:flex; flex-direction:column; gap:6px; }
.rb-notice { display:flex; align-items:flex-start; gap:7px; font-size:0.74rem; padding:8px 10px; border-radius:var(--r-sm); line-height:1.5; }
.rb-notice svg { flex-shrink:0; margin-top:1px; }
.rb-notice--warn { background:rgba(224,85,85,0.08); border:1px solid rgba(224,85,85,0.25); color:var(--red); }
.rb-notice--warn[hidden] { display:none; }
.rb-notice--info { background:rgba(240,160,48,0.06); border:1px solid rgba(240,160,48,0.2); color:var(--text-2); }
.rb-notice--info a { color:var(--gold); border-bottom:1px solid var(--glow-sm); }
.btn-reset { display:flex; align-items:center; gap:6px; background:none; border:1px solid var(--border); color:var(--text-2); font-size:0.73rem; padding:7px 12px; border-radius:var(--r-sm); align-self:flex-start; transition:border-color var(--t), color var(--t); }
.btn-reset:hover { border-color:var(--border-2); color:var(--text); }

/* Map */
.calc-map-wrap { position:relative; border-radius:var(--r-md); overflow:hidden; border:1px solid var(--border); height:580px; }
#map { width:100%; height:100%; }
.map-status { position:absolute; bottom:12px; left:50%; transform:translateX(-50%); background:var(--surface); border:1px solid var(--border); color:var(--text-2); font-size:0.72rem; padding:6px 16px; border-radius:100px; z-index:10; pointer-events:none; white-space:nowrap; backdrop-filter:blur(12px); max-width:92%; }

.leaflet-container { background:var(--bg-2) !important; }
[data-theme="dark"] .leaflet-tile-pane { filter:invert(1) hue-rotate(180deg) brightness(0.82) saturate(0.65); }
.leaflet-popup-content-wrapper { background:var(--surface) !important; color:var(--text) !important; border:1px solid var(--border) !important; box-shadow:var(--shadow-md) !important; border-radius:var(--r-sm) !important; }
.leaflet-popup-tip { background:var(--surface) !important; }
.leaflet-control-zoom a { background:var(--surface) !important; color:var(--text) !important; border-color:var(--border) !important; }
.leaflet-control-zoom a:hover { background:var(--surf-2) !important; }

/* ════════════════════════════
   CTA BAND
════════════════════════════ */
.cta-band {
  background:var(--gold); padding:28px 4vw;
}
.cta-band__inner { display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.cta-band__tag { display:block; font-size:0.65rem; font-weight:700; letter-spacing:0.2em; text-transform:uppercase; color:rgba(0,0,0,0.55); margin-bottom:4px; }
.cta-band p { font-size:1rem; font-weight:500; color:#080808; }
.cta-band .btn-call { background:#080808; color:var(--gold); }
.cta-band .btn-call:hover { background:#1a1a1a; }
.cta-band .btn-call .pulse-dot { background:var(--green); }

/* ════════════════════════════
   O NAMA
════════════════════════════ */
.o-nama { background:var(--bg-3); }
.onama-layout { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.onama-left .sec-tag { display:inline-block; margin-bottom:16px; }
.onama-left h2 { font-size:clamp(2rem,4vw,3.2rem); margin-bottom:20px; }
.onama-left p { font-size:0.93rem; color:var(--text-2); margin-bottom:12px; }

.dynamic-prices-note {
  display:flex; gap:13px; align-items:flex-start; margin-top:22px;
  background:rgba(240,160,48,0.06); border:1px solid rgba(240,160,48,0.2);
  border-radius:var(--r-md); padding:16px;
}
.dynamic-prices-note span { font-size:1.1rem; flex-shrink:0; color:var(--amber); margin-top:2px; }
.dynamic-prices-note strong { display:block; font-family:var(--font-d); font-size:1.05rem; font-weight:400; margin-bottom:4px; }
.dynamic-prices-note p { font-size:0.82rem; color:var(--text-2); margin:0; }

.features { display:flex; flex-direction:column; gap:24px; }
.feat { display:flex; gap:14px; align-items:flex-start; }
.feat-gem { color:var(--gold); flex-shrink:0; font-size:0.9rem; margin-top:4px; }
.feat strong { display:block; font-family:var(--font-d); font-size:1.1rem; font-weight:400; margin-bottom:3px; }
.feat p { font-size:0.83rem; color:var(--text-2); }

/* ════════════════════════════
   HERO CTA
════════════════════════════ */
.cta-hero { position:relative; padding:100px 4vw; background:var(--bg); text-align:center; overflow:hidden; }
.cta-hero__glow { position:absolute; inset:0; background:radial-gradient(ellipse 50% 50% at 50% 50%, rgba(201,169,110,0.1) 0%, transparent 70%); pointer-events:none; }
.cta-hero__inner { position:relative; z-index:1; }
.cta-hero h2 { font-size:clamp(2.4rem,6vw,5.5rem); margin-bottom:14px; }
.cta-hero p { font-size:1rem; color:var(--text-2); margin-bottom:36px; }
.cta-hero__sub { margin-top:20px; font-size:0.85rem; color:var(--text-3); }
.cta-hero__sub a { color:var(--gold); border-bottom:1px solid var(--glow-sm); }

/* ════════════════════════════
   UVJETI
════════════════════════════ */
.uvjeti { background:var(--bg-2); }
.uvjeti-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.uvj-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-md); padding:24px; }
.uvj-card--amber { border-color:rgba(240,160,48,0.28); background:rgba(240,160,48,0.03); }
.uvj-card h3 { font-family:var(--font-d); font-size:1.05rem; font-weight:500; color:var(--gold); margin-bottom:10px; }
.uvj-card--amber h3 { color:var(--amber); }
.uvj-card p { font-size:0.82rem; color:var(--text-2); line-height:1.7; }

/* ════════════════════════════
   FOOTER
════════════════════════════ */
.site-footer { background:var(--bg-3); border-top:1px solid var(--border); padding:50px 0 32px; }
.footer-inner { display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:40px; }
.footer-brand { display:flex; flex-direction:column; gap:6px; }
.footer-brand .logo-gem { color:var(--gold); margin-right:8px; }
.footer-brand .logo-name { font-size:0.77rem; font-weight:500; letter-spacing:0.2em; text-transform:uppercase; }
.footer-brand p { font-size:0.74rem; color:var(--text-3); margin-top:2px; }
.footer-nav { display:flex; flex-direction:column; gap:8px; align-items:center; }
.footer-nav a { font-size:0.72rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--text-3); transition:color var(--t); }
.footer-nav a:hover { color:var(--gold); }
.footer-right { text-align:right; display:flex; flex-direction:column; gap:5px; }
.footer-tel { font-family:var(--font-d); font-size:1.1rem; color:var(--gold); transition:color var(--t); }
.footer-tel:hover { color:var(--gold-lt); }
.footer-copy { font-size:0.72rem; color:var(--text-3); }
.footer-fuel { font-size:0.65rem; color:var(--text-3); }

/* ════════════════════════════
   SCROLL REVEAL
════════════════════════════ */
.reveal { opacity:0; transform:translateY(24px); transition:opacity 0.65s ease, transform 0.65s ease; }
.reveal.is-visible { opacity:1; transform:translateY(0); }

/* ════════════════════════════
   MOBILE NAV
════════════════════════════ */
@media (max-width: 900px) {
  .nav-links {
    position:fixed; top:0; right:0; width:280px; height:100dvh;
    background:var(--bg-2); border-left:1px solid var(--border);
    flex-direction:column; align-items:flex-start;
    padding:88px 34px 40px; gap:20px;
    transform:translateX(100%); transition:transform 0.3s ease; z-index:700;
  }
  .nav-links.is-open { transform:translateX(0); }
  .nav-links a { font-size:1rem; }
  .hamburger { display:flex; z-index:750; }
  .nav-backdrop { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.5); z-index:690; }
  .nav-backdrop.is-open { display:block; }
}

/* ════════════════════════════
   RESPONSIVE
════════════════════════════ */
@media (max-width: 1100px) {
  .hero-body { grid-template-columns:1fr; max-width:680px; }
  .hero-right { order:-1; }
  .price-ticker { max-width:480px; }
  .calc-layout { grid-template-columns:1fr; }
  .calc-map-wrap { height:420px; order:-1; }
}
@media (max-width: 900px) {
  .service-grid { grid-template-columns:1fr; }
  .usp-grid { grid-template-columns:repeat(2,1fr); }
  .uvjeti-grid { grid-template-columns:1fr; }
  .onama-layout { grid-template-columns:1fr; gap:40px; }
  .footer-inner { grid-template-columns:1fr; text-align:center; }
  .footer-brand,.footer-right { align-items:center; }
  .footer-right { text-align:center; }
}
@media (max-width: 640px) {
  .section { padding:64px 0; }
  .hero-btns { flex-direction:column; align-items:flex-start; }
  .usp-grid { grid-template-columns:1fr; }
  .cta-band__inner { flex-direction:column; text-align:center; }
  .hero-h1 { font-size:clamp(2.6rem,11vw,4rem); }
  .calc-map-wrap { height:320px; }
  .ticker-grid { grid-template-columns:repeat(3,1fr); }
}
@media (max-width: 460px) {
  .cookie-inner { flex-direction:column; align-items:flex-start; }
  .btn-cta-big { font-size:1.1rem; padding:16px 28px; }
}
