/* ==========================================================================
   Dentalreise — Design Tokens + Components  v2
   ========================================================================== */

@import url("https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;1,9..144,300;1,9..144,400;1,9..144,500&family=Inter:wght@400;500;600;700&display=swap");

/* ── Tokens ─────────────────────────────────────────────────────────────── */
:root {
  --blue-50:  #EAF2FB; --blue-100: #CFE0F4; --blue-200: #A2C2E8;
  --blue-300: #6B9DD8; --blue-400: #3F7BC4; --blue-500: #1F5FAE;
  --blue-600: #174B8C; --blue-700: #0F386A;

  --aqua-100: #C2EAEF; --aqua-200: #93D8E0; --aqua-300: #5FC3CF;
  --aqua-400: #2BA8B8; --aqua-500: #1E8A99; --aqua-600: #156977;

  --navy-50: #ECF0F5; --navy-100: #C9D2DF; --navy-200: #8E9DB5;
  --navy-300: #586C8A; --navy-400: #324868;
  --navy-500: #1B2E4B; --navy-600: #132238; --navy-700: #0C1828;

  --cream-50: #FFFFFF; --cream-100: #F6F9FC;
  --cream-200: #ECF2F8; --cream-300: #DCE5EE;

  --n0: #fff; --n50: #F4F6F9; --n100: #E7EAF0; --n200: #CFD5DF;
  --n300: #A4ADBC; --n400: #7B8493; --n500: #5A6273; --n600: #3F4655; --n700: #2A3040;

  --hot:     #E85D30;
  --hot-bg:  #FFF0EA;
  --hot-dim: rgba(232,93,48,.12);

  --success: #2E8B57; --success-bg: #E2F2EA;

  --bg:          var(--cream-100);
  --bg-elevated: #fff;
  --bg-sunken:   var(--cream-200);
  --fg:          var(--navy-700);
  --fg-muted:    var(--n500);
  --fg-subtle:   var(--n400);
  --border:      var(--n200);
  --border-sub:  var(--cream-300);

  --font-display: "Fraunces", Georgia, serif;
  --font-body:    "Inter", -apple-system, sans-serif;

  --sz-xs: .75rem; --sz-sm: .875rem; --sz-base: 1rem; --sz-md: 1.125rem;
  --sz-lg: 1.25rem; --sz-xl: 1.5rem; --sz-2xl: 1.875rem; --sz-3xl: 2.25rem;
  --sz-4xl: 3rem; --sz-5xl: 3.75rem; --sz-6xl: 4.75rem;

  --r-sm: 6px; --r-md: 10px; --r-lg: 16px; --r-xl: 24px;
  --r-2xl: 32px; --r-full: 9999px;

  --sh-xs: 0 1px 2px rgba(11,23,48,.04);
  --sh-sm: 0 2px 8px rgba(11,23,48,.07), 0 1px 2px rgba(11,23,48,.04);
  --sh-md: 0 6px 24px rgba(11,23,48,.10), 0 2px 4px rgba(11,23,48,.05);
  --sh-lg: 0 16px 48px rgba(11,23,48,.12), 0 4px 8px rgba(11,23,48,.05);
  --sh-xl: 0 32px 80px rgba(11,23,48,.14), 0 8px 20px rgba(11,23,48,.07);

  --container: 1200px; --container-narrow: 880px; --gutter: 1.5rem;
  --ease: cubic-bezier(0.22,.61,.36,1); --dur: 220ms;
}

/* ── Reset ──────────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-family:var(--font-body);color:var(--fg);background:var(--bg);scroll-behavior:smooth}
body{font-size:var(--sz-base);line-height:1.5;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:none;background:transparent}
a{color:inherit;text-decoration:none}
ul{list-style:none}
input,textarea,select{font-family:inherit}

/* ── Layout ─────────────────────────────────────────────────────────────── */
.c{width:100%;max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}
.c--narrow{max-width:var(--container-narrow)}
.g{display:grid;gap:1.5rem}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.row{display:flex;align-items:center;gap:.75rem}
.col{display:flex;flex-direction:column;gap:1rem}
.wrap{flex-wrap:wrap}
.jc{justify-content:center}
.jb{justify-content:space-between}
.tc{text-align:center}

/* ── Typography ─────────────────────────────────────────────────────────── */
.eyebrow{
  font-size:var(--sz-xs);font-weight:700;letter-spacing:.13em;
  text-transform:uppercase;color:var(--blue-500);
}
.ew{display:inline-flex;align-items:center;gap:10px;margin-bottom:1rem}
.ew::before{content:'';width:24px;height:1.5px;background:currentColor;opacity:.5;flex-shrink:0}

.display{
  font-family:var(--font-display);font-size:var(--sz-6xl);
  font-weight:300;line-height:1.07;letter-spacing:-.025em;
  font-variation-settings:"opsz" 144;
}
.h1{font-family:var(--font-display);font-size:var(--sz-5xl);font-weight:300;line-height:1.1;letter-spacing:-.02em;font-variation-settings:"opsz" 96}
.h2{font-family:var(--font-display);font-size:var(--sz-4xl);font-weight:300;line-height:1.15;letter-spacing:-.02em;font-variation-settings:"opsz" 72}
.h3{font-family:var(--font-display);font-size:var(--sz-3xl);font-weight:400;line-height:1.2;font-variation-settings:"opsz" 48}
.h4{font-size:var(--sz-xl);font-weight:600;line-height:1.3}
.lead{font-size:var(--sz-lg);line-height:1.7;color:var(--fg-muted)}
.quote{font-family:var(--font-display);font-size:var(--sz-2xl);font-style:italic;line-height:1.6;font-variation-settings:"opsz" 24}

/* ── Buttons ─────────────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:13px 22px;border-radius:var(--r-full);font-size:var(--sz-base);
  font-weight:600;letter-spacing:-.005em;white-space:nowrap;
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease),
    transform 120ms var(--ease),box-shadow var(--dur) var(--ease);
}
.btn:active{transform:scale(.97)}
.btn--lg{padding:16px 30px;font-size:var(--sz-md)}
.btn--sm{padding:9px 16px;font-size:var(--sz-sm)}
.btn--full{width:100%;justify-content:center}

.btn--primary{background:var(--blue-500);color:#fff;box-shadow:0 1px 3px rgba(11,23,48,.25),inset 0 -1px 0 rgba(0,0,0,.1)}
.btn--primary:hover{background:var(--blue-600);box-shadow:var(--sh-md)}
.btn--secondary{background:transparent;color:var(--navy-500);border:1.5px solid var(--navy-400)}
.btn--secondary:hover{background:var(--navy-500);color:#fff}
.btn--ghost{background:transparent;color:var(--fg);padding-left:8px;padding-right:8px}
.btn--ghost:hover{color:var(--blue-600)}
.btn--white{background:#fff;color:var(--blue-600)}
.btn--white:hover{background:var(--blue-50)}
.btn--outline-white{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.35)}
.btn--outline-white:hover{background:rgba(255,255,255,.1)}
.btn--hot{background:var(--hot);color:#fff;box-shadow:0 1px 3px rgba(232,93,48,.35)}
.btn--hot:hover{background:#d04f22;box-shadow:var(--sh-md)}

/* ── Cards ───────────────────────────────────────────────────────────────── */
.card{background:var(--bg-elevated);border:1px solid var(--border-sub);border-radius:var(--r-lg);box-shadow:var(--sh-sm);overflow:hidden}
.card--lift{transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.card--lift:hover{transform:translateY(-3px);box-shadow:var(--sh-lg)}

/* ── Chips ───────────────────────────────────────────────────────────────── */
.chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--r-full);background:var(--blue-100);color:var(--blue-700);font-size:var(--sz-xs);font-weight:700;white-space:nowrap}
.chip--aqua{background:var(--aqua-100);color:var(--aqua-600)}
.chip--out{background:transparent;border:1px solid var(--border);color:var(--fg-muted)}
.chip--hot{background:var(--hot-bg);color:var(--hot)}
.chip--success{background:var(--success-bg);color:var(--success)}

/* ── Trust badges ────────────────────────────────────────────────────────── */
.trust{display:inline-flex;align-items:center;gap:.5rem;padding:7px 14px;border-radius:var(--r-full);border:1px solid var(--navy-100);background:var(--navy-50);color:var(--navy-400);font-size:var(--sz-sm);font-weight:500}

/* ── Inputs ──────────────────────────────────────────────────────────────── */
.field{display:flex;flex-direction:column;gap:5px}
.field label{font-size:var(--sz-sm);font-weight:600;color:var(--fg)}
.inp,.txta,.sel{
  width:100%;padding:12px 15px;border:1.5px solid var(--border);
  border-radius:var(--r-md);background:#fff;font-size:var(--sz-base);color:var(--fg);
  transition:border-color var(--dur),box-shadow var(--dur);appearance:none;
}
.inp:focus,.txta:focus,.sel:focus{outline:none;border-color:var(--blue-500);box-shadow:0 0 0 4px var(--blue-50)}
.txta{min-height:120px;resize:vertical}
.sel{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235A6273' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:40px;cursor:pointer;
}

/* Upload zone */
.upload-zone{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.75rem;padding:40px 24px;border:2px dashed var(--border);border-radius:var(--r-lg);
  background:var(--cream-100);cursor:pointer;
  transition:border-color var(--dur),background var(--dur);text-align:center;
}
.upload-zone:hover{border-color:var(--blue-400);background:var(--blue-50)}
.upload-zone-icon{width:48px;height:48px;border-radius:50%;background:var(--blue-100);display:flex;align-items:center;justify-content:center;color:var(--blue-500)}
.upload-zone-label{font-weight:600;font-size:var(--sz-md);color:var(--fg)}
.upload-zone-sub{font-size:var(--sz-sm);color:var(--fg-muted)}

/* ── Sections ────────────────────────────────────────────────────────────── */
.sec{padding:6rem 0}
.sec--sm{padding:4rem 0}
.sec--xs{padding:2.5rem 0}
.sec--cream{background:var(--cream-200)}
.sec--dark{background:var(--navy-500);color:#fff}
.sec--dark .h2,.sec--dark .h3,.sec--dark .display{color:#fff}
.sec--dark .lead{color:rgba(255,255,255,.72)}
.sec--grad{background:linear-gradient(145deg,var(--navy-600) 0%,var(--navy-500) 60%,#1a3a60 100%);color:#fff}
.sec--grad .h2,.sec--grad .display{color:#fff}
.sec--grad .lead{color:rgba(255,255,255,.72)}

/* ── Header ──────────────────────────────────────────────────────────────── */
.header{
  position:sticky;top:0;z-index:200;
  background:rgba(246,249,252,.9);
  backdrop-filter:saturate(180%) blur(16px);
  -webkit-backdrop-filter:saturate(180%) blur(16px);
  border-bottom:1px solid rgba(220,229,238,.8);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:76px;gap:1.5rem}
.logo-link{display:flex;align-items:center;gap:11px;flex-shrink:0}
.logo-name{font-family:var(--font-display);font-size:21px;font-weight:400;color:var(--navy-500);letter-spacing:-.02em;line-height:1;font-variation-settings:"opsz" 24}
.logo-tag{font-size:8.5px;font-weight:700;letter-spacing:.2em;color:var(--blue-500);margin-top:4px}
.nav{display:flex;align-items:center;gap:2rem}
.nav a{font-size:var(--sz-sm);font-weight:500;color:var(--fg);transition:color var(--dur)}
.nav a:hover,.nav a.is-active{color:var(--blue-600)}
.nav a.is-active{border-bottom:1.5px solid var(--blue-500)}
.h-actions{display:flex;align-items:center;gap:.75rem;flex-shrink:0}
.h-phone{display:flex;align-items:center;gap:6px;font-size:var(--sz-sm);font-weight:500;color:var(--navy-500)}
.burger{display:none;flex-direction:column;justify-content:center;gap:5px;padding:6px;cursor:pointer;width:40px;height:40px;background:transparent;border:none;flex-shrink:0}
.burger span{display:block;width:100%;height:2px;background:var(--fg);border-radius:2px;transition:transform .3s,opacity .3s}

/* ── Footer ──────────────────────────────────────────────────────────────── */
.footer{background:var(--navy-700);color:rgba(255,255,255,.65);padding:5rem 0 2.5rem}
.footer a{transition:color var(--dur)}
.footer a:hover{color:#fff}
.f-eyebrow{font-size:var(--sz-xs);font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--aqua-300);margin-bottom:1rem}
.f-links{display:flex;flex-direction:column;gap:10px;font-size:14px}
.f-hr{height:1px;background:rgba(255,255,255,.1);border:0;margin:3rem 0 1.5rem}
.f-bottom{display:flex;justify-content:space-between;font-size:13px;opacity:.55;flex-wrap:wrap;gap:1rem}
.f-bl{display:flex;gap:1.5rem}

/* ── Hot / Trending badge ────────────────────────────────────────────────── */
@keyframes pulse-ring {
  0%   { transform:scale(.95); box-shadow:0 0 0 0 rgba(232,93,48,.5) }
  70%  { transform:scale(1);   box-shadow:0 0 0 8px rgba(232,93,48,0) }
  100% { transform:scale(.95); box-shadow:0 0 0 0 rgba(232,93,48,0) }
}
@keyframes blink {
  0%,100%{opacity:1} 50%{opacity:.4}
}
.badge-hot{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 12px;border-radius:var(--r-full);
  background:var(--hot);color:#fff;
  font-size:var(--sz-xs);font-weight:700;letter-spacing:.06em;
  box-shadow:0 2px 8px rgba(232,93,48,.35);
}
.badge-hot .dot{
  width:7px;height:7px;border-radius:50%;background:#fff;
  animation:blink 1.4s ease-in-out infinite;flex-shrink:0;
}
.dest-hot-ribbon{
  position:absolute;top:0;left:0;right:0;
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:9px 16px;background:var(--hot);color:#fff;
  font-size:var(--sz-xs);font-weight:700;letter-spacing:.08em;z-index:5;
}
.dest-hot-ribbon .dot{width:6px;height:6px;border-radius:50%;background:#fff;animation:blink 1.2s ease-in-out infinite}

/* ── Hero ────────────────────────────────────────────────────────────────── */
.hero{padding:72px 0 100px;background:var(--cream-100);position:relative;overflow:hidden}
.hero::before{
  content:'';position:absolute;top:-160px;right:-80px;
  width:640px;height:640px;border-radius:50%;
  background:radial-gradient(circle,rgba(31,95,174,.07) 0%,transparent 70%);
  pointer-events:none;
}
.hero-g{display:grid;grid-template-columns:1.1fr 1fr;gap:72px;align-items:center}
.hero-img-wrap{position:relative}
.hero-photo{border-radius:var(--r-2xl);overflow:hidden;aspect-ratio:4/5;box-shadow:var(--sh-xl)}
.hero-photo img{width:100%;height:100%;object-fit:cover;transition:transform 6s ease}
.hero-photo:hover img{transform:scale(1.03)}
.hero-quote{
  position:absolute;bottom:-28px;left:-36px;
  background:#fff;padding:20px 22px;border-radius:var(--r-lg);box-shadow:var(--sh-lg);
  max-width:268px;border:1px solid var(--border-sub);
}
.hero-stars{display:flex;gap:2px;color:var(--aqua-400);margin-bottom:8px}
.hero-qt{font-family:var(--font-display);font-style:italic;font-size:15px;line-height:1.5;color:var(--fg);font-variation-settings:"opsz" 16}
.hero-qa{margin-top:8px;font-size:12px;color:var(--fg-muted)}
.hero-save{
  position:absolute;top:20px;right:-28px;
  background:linear-gradient(135deg,var(--blue-500),var(--blue-700));
  color:#fff;padding:16px 18px;border-radius:var(--r-lg);box-shadow:var(--sh-lg);
  text-align:center;
}
.hero-save-lbl{font-size:10px;letter-spacing:.12em;font-weight:700;opacity:.8;margin-bottom:4px}
.hero-save-num{font-family:var(--font-display);font-size:38px;font-weight:400;line-height:1;font-variation-settings:"opsz" 48}
.accent-text{
  background:linear-gradient(135deg,var(--blue-500),var(--aqua-400));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

/* ── Page intro (inner pages) ────────────────────────────────────────────── */
.page-intro{padding:60px 0 40px;background:linear-gradient(180deg,var(--cream-200) 0%,var(--cream-100) 100%);border-bottom:1px solid var(--border-sub)}

/* ── Destination cards ───────────────────────────────────────────────────── */
.dest-img{position:relative;aspect-ratio:4/3;overflow:hidden}
.dest-img > img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.dest-flag img{width:20px;height:14px;border-radius:2px;flex-shrink:0;display:block}
.card--lift:hover .dest-img img{transform:scale(1.05)}
.dest-img::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:50%;
  background:linear-gradient(to top,rgba(11,23,48,.35),transparent);
  pointer-events:none;
}
.dest-flag{
  position:absolute;top:44px;left:14px;
  display:flex;align-items:center;gap:7px;padding:5px 11px;
  background:rgba(255,255,255,.96);border-radius:var(--r-full);z-index:4;
  box-shadow:var(--sh-xs);
}
.dest-flag img{border-radius:2px}
.dest-flag span{font-size:13px;font-weight:700;color:var(--navy-500)}
.dest-savings{
  position:absolute;bottom:14px;right:14px;
  background:linear-gradient(135deg,var(--blue-500),var(--blue-700));
  color:#fff;padding:5px 12px;border-radius:var(--r-full);
  font-size:var(--sz-xs);font-weight:700;z-index:4;box-shadow:var(--sh-sm);
}
.dest-body{padding:20px 24px 24px}
.dest-city{font-size:var(--sz-sm);color:var(--fg-muted);margin-bottom:4px}
.dest-link{
  display:inline-flex;align-items:center;gap:4px;
  font-size:var(--sz-sm);font-weight:600;color:var(--blue-600);margin-top:14px;
  transition:gap var(--dur);
}
.dest-link:hover{gap:8px}

/* Serbia highlight card */
.dest-card--hot{border:2px solid var(--hot);box-shadow:0 0 0 4px rgba(232,93,48,.1),var(--sh-md)}

/* ── Process steps ───────────────────────────────────────────────────────── */
.step-circle{
  width:56px;height:56px;border-radius:50%;
  background:#fff;border:2px solid var(--blue-200);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;color:var(--blue-600);flex-shrink:0;
}
.step-n{font-family:var(--font-display);font-size:13px;font-weight:600;color:var(--blue-400);letter-spacing:.1em;margin-bottom:6px;font-variation-settings:"opsz" 14}

/* Process page - large list */
.proc-item{display:grid;grid-template-columns:100px 1fr;gap:32px;padding:44px 0;border-top:1px solid var(--border-sub)}
.proc-item:first-child{border-top:none;padding-top:0}
.proc-num{font-family:var(--font-display);font-size:54px;font-weight:300;font-style:italic;color:var(--blue-300);line-height:1;font-variation-settings:"opsz" 64}
.proc-meta{display:flex;align-items:center;gap:7px;margin-bottom:12px;font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-muted)}

/* ── Pricing ─────────────────────────────────────────────────────────────── */
.ptab-nav{
  display:flex;border-bottom:1px solid var(--border);margin-bottom:0;
  background:var(--cream-100);border-radius:var(--r-lg) var(--r-lg) 0 0;overflow:hidden;
}
.ptab-btn{
  flex:1;padding:16px;font-size:var(--sz-sm);font-weight:600;color:var(--fg-muted);
  background:transparent;border-bottom:2px solid transparent;
  transition:color var(--dur),border-color var(--dur),background var(--dur);
  display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;
}
.ptab-btn img{border-radius:2px}
.ptab-btn:hover{color:var(--fg)}
.ptab-btn.is-active{color:var(--blue-600);border-bottom-color:var(--blue-500);background:#fff}
.ptab-panel{display:none}
.ptab-panel.is-active{display:block}

.p-table{width:100%;border-collapse:collapse}
.p-table th{
  text-align:left;padding:18px 28px;font-size:12px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;color:var(--fg-muted);
  background:var(--cream-200);
}
.p-table th.ar{text-align:right}
.p-table td{padding:18px 28px;border-top:1px solid var(--border-sub)}
.p-table td.ar{text-align:right}
.p-table tr:hover td{background:var(--cream-100)}
.p-treat{font-family:var(--font-display);font-size:17px;font-weight:400;font-variation-settings:"opsz" 18}
.p-ch{color:var(--fg-muted);text-decoration:line-through;font-size:var(--sz-sm)}
.p-us{font-weight:700;color:var(--navy-500);font-size:17px}

/* Multi-country table */
.p4-table{width:100%;border-collapse:collapse}
.p4-table th{padding:16px 20px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-muted);background:var(--cream-200);border-bottom:1px solid var(--border)}
.p4-table th.ar{text-align:right}
.p4-table td{padding:16px 20px;border-top:1px solid var(--border-sub);vertical-align:middle}
.p4-table td.ar{text-align:right}
.p4-table tr:hover td{background:var(--cream-100)}
.p4-table td.p-ch{color:var(--fg-muted);text-decoration:line-through;font-size:var(--sz-sm)}
.p4-col-rs{background:rgba(232,93,48,.03)}
.p4-head-rs{color:var(--hot)!important}

/* ── Stats / about ───────────────────────────────────────────────────────── */
.stat-n{font-family:var(--font-display);font-size:44px;font-weight:300;color:var(--blue-500);line-height:1;margin-bottom:8px;font-variation-settings:"opsz" 48}
.stat-l{font-size:14px;color:var(--fg-muted)}

/* ── Booking / form ──────────────────────────────────────────────────────── */
.booking-wrap{background:var(--cream-200);padding:64px 0 96px}
.booking-g{display:grid;grid-template-columns:1fr 1.25fr;gap:64px;align-items:start}
.booking-sticky{position:sticky;top:96px}
.b-benefit{display:flex;align-items:flex-start;gap:14px}
.b-icon{flex-shrink:0;margin-top:2px;color:var(--blue-500)}
.b-t{font-weight:600;margin-bottom:3px}
.b-d{font-size:14px;color:var(--fg-muted)}
.step-bars{display:flex;gap:6px;margin-bottom:28px}
.sbar{flex:1;height:4px;border-radius:2px;background:var(--cream-300);transition:background var(--dur)}
.sbar.on{background:var(--blue-500)}
.s-lbl{font-size:13px;color:var(--fg-muted);margin-bottom:8px}
.radio-row{
  display:flex;align-items:center;gap:12px;padding:14px 16px;
  border:1.5px solid var(--border);border-radius:var(--r-md);cursor:pointer;
  transition:border-color var(--dur),background var(--dur);
}
.radio-row:hover{border-color:var(--blue-300);background:var(--blue-50)}
.radio-row input{accent-color:var(--blue-500)}
.radio-lbl{font-weight:500}
.f-nav{display:flex;gap:10px;margin-top:28px;align-items:center}

/* Pre-screen card */
.ps-card{background:var(--navy-500);color:#fff;border:none;border-radius:var(--r-2xl)}
.ps-grid{display:grid;grid-template-columns:1fr 1fr;align-items:stretch}
.ps-content{padding:64px 56px}
.ps-photo{position:relative;min-height:480px}
.ps-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:0 var(--r-2xl) var(--r-2xl) 0}
.loc-item{display:flex;align-items:flex-start;gap:14px}
.loc-icon{
  width:42px;height:42px;border-radius:8px;flex-shrink:0;
  background:rgba(43,168,184,.15);display:flex;align-items:center;justify-content:center;
  color:var(--aqua-300);
}

/* CTA strip */
.cta-strip{padding:96px 0;background:linear-gradient(135deg,var(--blue-500) 0%,var(--navy-600) 100%);color:#fff;text-align:center}
.cta-strip .h2{color:#fff;margin-bottom:16px}
.cta-strip .lead{color:rgba(255,255,255,.82);max-width:560px;margin:0 auto 32px}

/* Testimonials */
.tcard{padding:28px 32px}
.t-stars{display:flex;gap:2px;color:var(--aqua-400);margin-bottom:18px}
.t-author{display:flex;align-items:center;gap:12px;margin-top:20px}
.t-avatar{width:42px;height:42px;border-radius:50%;object-fit:cover}
.t-name{font-weight:600;font-size:14px}
.t-meta{font-size:13px;color:var(--fg-muted)}

/* Gegenofferte */
.gegen-hero{
  padding:72px 0 80px;
  background:linear-gradient(145deg,var(--navy-600) 0%,var(--blue-600) 50%,var(--navy-500) 100%);
  color:#fff;
}
.gegen-g{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.gegen-bubble{
  background:rgba(255,255,255,.07);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.12);border-radius:var(--r-2xl);padding:36px;
}
.gegen-steps li{
  display:flex;align-items:flex-start;gap:14px;padding:14px 0;
  border-bottom:1px solid rgba(255,255,255,.1);font-size:15px;
}
.gegen-steps li:last-child{border-bottom:none}
.g-num{
  width:28px;height:28px;border-radius:50%;background:rgba(43,168,184,.25);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  font-size:12px;font-weight:700;color:var(--aqua-300);
}

/* Serbia highlight section */
.srbия-why{background:linear-gradient(135deg,var(--hot-bg) 0%,#fff5f0 100%);border:1px solid rgba(232,93,48,.2);border-radius:var(--r-2xl);padding:40px 48px;position:relative;overflow:hidden}
.srbия-why::before{
  content:'';position:absolute;top:-40px;right:-40px;
  width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,rgba(232,93,48,.1),transparent 70%);
}
.serbien-num{
  font-family:var(--font-display);font-size:56px;font-weight:300;
  color:var(--hot);line-height:1;font-variation-settings:"opsz" 64;
}

/* Page visibility */
.page{display:none}
.page.on{display:block}

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media(max-width:1024px){
  .hero-g{gap:48px}
  .hero-quote{left:-12px;bottom:-16px}
  .hero-save{right:-12px}
  .ps-content{padding:48px 40px}
  .gegen-g{gap:40px}
}
@media(max-width:900px){
  .g3,.g4{grid-template-columns:1fr}
  .g2{grid-template-columns:1fr}
  .hero-g{grid-template-columns:1fr}
  .hero-img-wrap{order:-1}
  .hero-photo{aspect-ratio:16/9}
  .hero-quote{display:none}
  .hero-save{right:20px;top:16px}
  .ps-grid{grid-template-columns:1fr}
  .ps-photo{min-height:260px}
  .ps-photo img{border-radius:0 0 var(--r-2xl) var(--r-2xl)}
  .booking-g{grid-template-columns:1fr}
  .booking-sticky{position:static}
  .gegen-g{grid-template-columns:1fr}
}
@media(max-width:768px){
  .display{font-size:var(--sz-4xl)}
  .h1{font-size:var(--sz-3xl)}
  .h2{font-size:var(--sz-2xl)}
  .h3{font-size:var(--sz-xl)}
  .lead{font-size:var(--sz-base)}
  .hero,.gegen-hero{padding:48px 0 64px}
  .sec{padding:4rem 0}
  .cta-strip{padding:4rem 0}
  .ps-content{padding:40px 24px}
  .srbия-why{padding:28px 24px}
  .nav{display:none}
  .burger{display:flex}
  .h-phone{display:none}
  .h-cta{display:none}
  .p4-table th,.p4-table td{padding:12px 12px}
  .p-table th,.p-table td{padding:14px 16px}
  .proc-item{grid-template-columns:70px 1fr;gap:16px}
  .booking-g,.gegen-g{gap:40px}
  .f-inner{grid-template-columns:1fr 1fr!important;gap:32px!important}
}
@media(max-width:480px){
  :root{--gutter:1rem}
  .g2{grid-template-columns:1fr}
  .f-inner{grid-template-columns:1fr!important}
  .hero-save{display:none}
  .ptab-nav{flex-wrap:wrap}
  .ptab-btn{flex:none;padding:12px 16px}
  /* Buttons: kein erzwungenes nowrap auf kleinen Screens */
  .btn{white-space:normal;text-align:center}
  .btn--lg{padding:13px 20px;font-size:var(--sz-base)}
  /* Voller Breite für Buttons in Cards */
  .ps-content .btn,.go-form-body .btn{width:100%;justify-content:center}
  /* Preiskarten padding reduzieren */
  .card{padding:20px!important}
}

/* Flag inline */
.flag-sm{display:inline-block;vertical-align:middle;width:20px;height:14px;object-fit:cover;border-radius:2px;margin-right:5px}

/* ── Nav Dropdown ── */
.nav-dropdown{position:relative;display:flex;align-items:center;}
.nav-dropdown-toggle{
  background:none;border:none;font:inherit;
  font-size:var(--sz-sm);font-weight:500;
  color:var(--fg);cursor:pointer;
  display:flex;align-items:center;gap:4px;
  padding:0;line-height:1;
}
.nav-dropdown-toggle:hover{color:var(--blue-600);}
.nav-dropdown-menu{
  position:absolute;top:100%;left:50%;
  transform:translateX(-50%) translateY(6px);
  background:#fff;border:1px solid var(--border-sub);
  border-radius:var(--r-lg);box-shadow:0 8px 32px rgba(0,0,0,.12);
  min-width:200px;padding:20px 8px 8px;
  opacity:0;pointer-events:none;
  transition:opacity .15s ease,transform .15s ease;
  z-index:200;
}
.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown:focus-within .nav-dropdown-menu{
  opacity:1;pointer-events:all;
  transform:translateX(-50%) translateY(0);
}
.nav-dropdown-menu a{
  display:block;padding:9px 14px;border-radius:8px;
  color:var(--fg);text-decoration:none;
  font-size:14px;font-weight:500;
  transition:background .1s;
}
.nav-dropdown-menu a:hover{background:var(--n100);}

/* ══════════════════════════════════════════════
   MOBILE DRAWER  (nav-drawer.js)
══════════════════════════════════════════════ */
#nd-overlay{
  position:fixed;inset:0;
  background:rgba(11,23,48,.58);
  backdrop-filter:blur(3px);
  -webkit-backdrop-filter:blur(3px);
  z-index:399;
  opacity:0;pointer-events:none;
  transition:opacity .32s;
}
#nd-overlay.open{opacity:1;pointer-events:all}

#nd-drawer{
  position:fixed;top:0;left:0;bottom:0;
  width:320px;max-width:90vw;
  background:#fff;
  z-index:400;
  transform:translateX(-100%);
  transition:transform .38s cubic-bezier(0.22,.61,.36,1);
  display:flex;flex-direction:column;
  box-shadow:12px 0 60px rgba(11,23,48,.28);
  overflow:hidden;
}
#nd-drawer.open{transform:translateX(0)}

/* Header */
.nd-hd{
  background:linear-gradient(145deg,#0C1828 0%,#1B2E4B 50%,#1F5FAE 100%);
  padding:22px 20px 20px;
  display:flex;align-items:center;justify-content:space-between;
  flex-shrink:0;position:relative;
  overflow:hidden;
}
.nd-hd::after{
  content:'';position:absolute;
  top:-40px;right:-40px;
  width:160px;height:160px;border-radius:50%;
  background:radial-gradient(circle,rgba(43,168,184,.2) 0%,transparent 70%);
  pointer-events:none;
}
.nd-hd-logo{display:flex;align-items:center;gap:12px;position:relative;z-index:1}
.nd-hd-name{
  font-family:var(--font-display);font-size:20px;font-weight:300;
  color:#fff;letter-spacing:-.01em;font-variation-settings:"opsz" 24;
}
.nd-hd-tag{font-size:8px;font-weight:700;letter-spacing:.18em;color:#5FC3CF;margin-top:3px}
.nd-close{
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);
  color:rgba(255,255,255,.8);cursor:pointer;
  padding:8px;border-radius:10px;display:flex;
  transition:background .15s;position:relative;z-index:1;
}
.nd-close:hover{background:rgba(255,255,255,.2)}

/* Body / Links */
.nd-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px 0}
.nd-link{
  display:flex;align-items:center;gap:10px;
  padding:15px 22px;
  font-size:15px;font-weight:600;color:var(--navy-600);
  border-bottom:1px solid var(--cream-300);
  transition:background .15s,color .15s;
  white-space:nowrap;
}
.nd-link:hover{background:var(--blue-50);color:var(--blue-600)}
.nd-dest-label{
  padding:12px 22px 6px;
  font-size:10px;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--blue-500);
  background:var(--cream-100);
  border-bottom:1px solid var(--cream-300);
}
.nd-dest{
  padding-left:32px;
  font-size:14px;font-weight:600;
  background:var(--cream-100);
}

/* Footer */
.nd-ft{
  padding:18px 20px 20px;
  border-top:2px solid var(--border-sub);
  background:var(--cream-100);
  display:flex;flex-direction:column;gap:10px;
  flex-shrink:0;
}
.nd-phone{
  display:flex;align-items:center;gap:8px;
  font-size:14px;font-weight:600;color:var(--navy-600);
  padding:10px 14px;background:#fff;
  border:1px solid var(--border-sub);border-radius:var(--r-md);
  transition:background .15s;
}
.nd-phone:hover{background:var(--cream-200)}
.nd-cta-btn{
  display:block;text-align:center;
  padding:13px 20px;
  background:linear-gradient(135deg,var(--blue-500),var(--navy-600));
  color:#fff;border-radius:var(--r-full);
  font-size:15px;font-weight:700;letter-spacing:-.01em;
  transition:opacity .15s,transform 120ms;
}
.nd-cta-btn:hover{opacity:.92;transform:translateY(-1px)}
.nd-gegen-btn{
  display:block;text-align:center;
  padding:11px 20px;
  background:rgba(232,93,48,.1);
  color:var(--hot);border-radius:var(--r-full);
  font-size:14px;font-weight:700;
  border:1.5px solid rgba(232,93,48,.25);
  transition:background .15s;
}
.nd-gegen-btn:hover{background:rgba(232,93,48,.18)}
