/* =========================================================================
   dugorocni-najam-vozila.com — main.css
   1. Design tokens (:root)
   2. Reset / base
   3. Layout (container, grid)
   4. Buttons + links
   5. Header / nav / top bar
   6. Hero + quote form
   7. Trust signals / Open Now
   8. Cards + silo grids
   9. FAQ accordion
   10. CTA banner
   11. Testimonials
   12. E-E-A-T (author box, fact-check, projects, credentials, awards, team, guarantees, freshness)
   13. Breadcrumbs / prose / blog
   14. Footer + mobile sticky bar
   15. Utilities / a11y / motion
   16. Conversion pack (promo bar, area checker, video facade, map embed)
   ====================================================================== */

/* 1. TOKENS ------------------------------------------------------------- */
:root{
	/* Brand palette — "executive-trust" profile. The Customizer overrides
	   --color-primary/-accent/-text (+ their *-hover). A deep wine primary and a
	   brushed-gold accent read premium and financially-serious for long-term
	   vehicle leasing; warm ivory surfaces keep it corporate and trustworthy. */
	--color-primary:#7A2233;        /* deep wine: brand, primary CTA fill, active states */
	--color-accent:#C79A3E;         /* brushed gold: decorative rules, eyebrows, hover accents */
	--color-text:#111318;           /* warm near-black body text on light */
	--color-primary-hover:#5E1926;  /* darker wine for hover (keeps white label >=4.5:1) */
	--color-accent-hover:#A97E2A;   /* darker gold for hover on gold fills */

	/* Wine is dark enough that a WHITE label clears AA on the fill
	   (white on #7A2233 ~= 9.3:1); primary-strong keeps one source of truth. */
	--color-primary-strong:#7A2233;
	/* Inline link / text ink on white — wine, AA-safe (~9.3:1 on #fff). Gold fails
	   as text on white, so inline ink stays wine; gold is decorative only. */
	--color-accent-ink:#7A2233;
	--color-primary-ink:#7A2233;

	--color-muted:#5B5560;          /* warm slate secondary text (AA on white) */
	--color-surface:#F8F4EF;        /* warm ivory section wash */
	--color-surface-2:#F3ECE3;      /* deeper sand wash (alternate band) */
	--color-border:#E6DDD2;         /* warm hairline border */
	--color-white:#ffffff;
	--color-page:#ffffff;           /* page background */
	--color-star:#C79A3E;           /* gold rating stars */
	--color-success:#2E7D5B;        /* green success cue (distinct from brand) */

	/* Dark surface family — warm near-black ink floor for the footer + the
	   mid-page feature band (split-head rhythm), with gold accents. */
	--color-dark:#1C151A;           /* warm near-black surface (footer, feature band) */
	--color-dark-2:#120C11;         /* deeper near-black (footer floor, gradients) */
	--color-on-dark:#F3ECE4;        /* warm light text on dark surfaces (>=12:1) */
	--color-on-dark-muted:#BCAEA0;  /* muted warm light on dark (>=4.5:1) */
	--color-dark-border:#3A2E33;    /* hairline borders on dark surfaces */

	--text-xs:0.75rem; --text-sm:0.875rem; --text-base:1rem; --text-lg:1.125rem;
	--text-xl:1.25rem; --text-2xl:1.5rem; --text-3xl:1.875rem; --text-4xl:2.25rem;
	--text-5xl:3rem; --text-6xl:3.75rem;

	--fw-normal:400; --fw-medium:500; --fw-semibold:600; --fw-bold:700; --fw-black:800;
	/* Serif display leading is a touch looser than the old grotesque. */
	--lh-tight:1.14; --lh-snug:1.32; --lh-normal:1.65;

	/* Transitional-serif display tracking sits at zero (serifs need no negative). */
	--track-display:0em;

	--space-1:0.25rem; --space-2:0.5rem; --space-3:0.75rem; --space-4:1rem; --space-5:1.25rem;
	--space-6:1.5rem; --space-8:2rem; --space-12:2.75rem; --space-16:3.5rem; --space-24:5.5rem;

	--width-content:720px; --width-wide:1140px;
	/* Restrained radii for a premium-trust feel. --radius-full stays a true pill. */
	--radius-sm:3px; --radius:6px; --radius-lg:10px; --radius-full:999px;
	/* Soft, low, warm-tinted shadows (premium, not punchy). */
	--shadow-sm:0 1px 2px rgba(17,19,24,.06);
	--shadow:0 8px 24px rgba(17,19,24,.10);
	--shadow-lg:0 20px 48px rgba(17,19,24,.14);
	--transition:200ms ease;
	--header-h:70px;

	/* Body stays a clean system grotesque; headings use a transitional serif. */
	--font:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Oxygen-Sans,Ubuntu,Cantarell,'Helvetica Neue',sans-serif;
	--font-display:Charter,'Bitstream Charter','Iowan Old Style','Palatino Linotype','Book Antiqua',Georgia,serif;
}

/* 2. RESET / BASE ------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;font-family:var(--font);font-size:var(--text-base);line-height:var(--lh-normal);color:var(--color-text);background:var(--color-page);-webkit-font-smoothing:antialiased;}
img{max-width:100%;height:auto;display:block;}
a{color:var(--color-accent-ink);text-decoration:none;}
a:hover{text-decoration:underline;}
/* Transitional-serif display headings — serif family, bold (700), calm tracking. */
h1,h2,h3,h4{font-family:var(--font-display);line-height:var(--lh-tight);font-weight:var(--fw-bold);color:var(--color-text);margin:0 0 var(--space-4);letter-spacing:var(--track-display);}
h1{font-size:var(--text-4xl);} h2{font-size:var(--text-3xl);} h3{font-size:var(--text-xl);}
h4{font-size:var(--text-lg);}
p{margin:0 0 var(--space-4);}
ul,ol{margin:0 0 var(--space-4);padding-left:1.25rem;}

/* 3. LAYOUT ------------------------------------------------------------- */
.container{width:100%;max-width:var(--width-wide);margin:0 auto;padding:0 var(--space-4);}
.section{padding:var(--space-16) 0;}
/* Blue-tinted band with strong dividers top & bottom to separate sections. */
.section--surface{background:var(--color-surface);border-top:2px solid var(--color-border);border-bottom:2px solid var(--color-border);}
.grid{display:grid;gap:var(--space-6);}
.grid--2{grid-template-columns:1fr;}
.grid--3{grid-template-columns:1fr;}
.grid--4{grid-template-columns:1fr;}
@media(min-width:640px){.grid--2,.grid--3,.grid--4{grid-template-columns:repeat(2,1fr);}}
@media(min-width:960px){.grid--3{grid-template-columns:repeat(3,1fr);}.grid--4{grid-template-columns:repeat(4,1fr);}}

/* 4. BUTTONS ------------------------------------------------------------ */
/* Sharp low-radius buttons (--radius ~6px); strong uppercase trade labels. */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);
	padding:var(--space-3) var(--space-6);border-radius:var(--radius);font-weight:var(--fw-bold);
	font-size:var(--text-base);letter-spacing:.03em;text-transform:uppercase;border:1px solid transparent;cursor:pointer;text-decoration:none;line-height:1.2;
	transition:transform var(--transition),background var(--transition),box-shadow var(--transition),color var(--transition);}
.btn:hover{text-decoration:none;}
@media(prefers-reduced-motion:no-preference){.btn:hover{transform:translateY(-1px);}}
/* Primary CTA — deep-blue fill, WHITE label. Uses the darkened blue so white clears AA (6.4:1). */
.btn--primary{background:var(--color-primary-strong);color:#fff;box-shadow:0 2px 8px rgba(122,34,51,.30);}
.btn--primary:hover{background:var(--color-primary-hover);box-shadow:0 5px 16px rgba(122,34,51,.34);}
/* Secondary — gold fill, ink label (ink on --color-accent gold, AA-safe). */
.btn--secondary{background:var(--color-accent);color:var(--color-text);box-shadow:0 2px 8px rgba(122,34,51,.22);}
.btn--secondary:hover{background:var(--color-accent-hover);color:var(--color-text);box-shadow:0 5px 16px rgba(122,34,51,.28);}
/* Ghost / outline on a LIGHT surface — blue hairline + blue ink, fills tint on hover. */
.btn--ghost{background:var(--color-white);border-color:var(--color-primary);border-width:2px;color:var(--color-primary-ink);}
.btn--ghost:hover{background:var(--color-surface);border-color:var(--color-primary-strong);color:var(--color-primary-strong);}
/* Outline action ON a dark navy surface — light hairline, light text; fills white on hover. */
.btn--on-dark{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.60);border-width:2px;color:var(--color-on-dark);}
.btn--on-dark:hover{background:#fff;border-color:#fff;color:var(--color-primary-strong);}
.btn--lg{padding:var(--space-4) var(--space-8);font-size:var(--text-lg);}
.btn--block{width:100%;}
.btn svg{width:1.1em;height:1.1em;}

/* 5. HEADER ------------------------------------------------------------- */
/* Light top bar — teal-tinted wash with dark ink and a hairline. */
.topbar{background:var(--color-surface);color:var(--color-text);font-size:var(--text-sm);border-bottom:1px solid var(--color-border);}
.topbar__inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:var(--space-3) var(--space-6);padding:var(--space-2) var(--space-4);}
.topbar a{color:var(--color-text);display:inline-flex;align-items:center;gap:var(--space-2);}
.topbar a:hover{color:var(--color-primary-strong);}
.topbar svg{width:1em;height:1em;}
.topbar__afterhours{color:var(--color-accent-ink);font-weight:var(--fw-semibold);}

/* z-index:100 so the header's stacking context (and its dropdown sub-menus)
   sits above all page content; the skip-link is bumped above this for a11y.
   LIGHT header: near-white surface, teal brand, dark nav, subtle bottom border. */
.site-header{position:sticky;top:0;z-index:100;background:var(--color-white);color:var(--color-text);box-shadow:0 1px 0 var(--color-border);transition:var(--transition);}
.site-header.is-shrunk{box-shadow:var(--shadow);}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);min-height:var(--header-h);}
.site-branding{display:flex;align-items:center;}
.site-title{font-size:var(--text-xl);font-weight:var(--fw-bold);letter-spacing:var(--track-display);margin:0;}
.site-title a{color:var(--color-primary-strong);}
.site-title a:hover{color:var(--color-primary-strong);text-decoration:none;}
/* Top-level nav: horizontal row (wraps to a tidy second line if many items). */
.main-nav > ul{list-style:none;display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2) var(--space-6);margin:0;padding:0;}
.main-nav li{position:relative;}
.main-nav a{color:var(--color-text);font-weight:var(--fw-medium);white-space:nowrap;display:block;padding:var(--space-2) 0;}
.main-nav a:hover{color:var(--color-primary-strong);text-decoration:underline;text-decoration-color:var(--color-accent);text-underline-offset:6px;text-decoration-thickness:2px;}
/* Caret on parent items that have a dropdown. */
.main-nav .menu-item-has-children > a::after{content:"";display:inline-block;width:.4em;height:.4em;margin-left:.45em;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:translateY(-2px) rotate(45deg);transition:transform var(--transition);}
/* Submenu = dropdown. Revealed on hover/focus on DESKTOP only (scoped below);
   on mobile it's a tap accordion (.is-open), so the hover rule must not apply. */
.main-nav .sub-menu{list-style:none;margin:0;padding:var(--space-2);position:absolute;top:100%;left:0;min-width:250px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-lg);display:none;flex-direction:column;z-index:60;}
@media(min-width:960px){
	.main-nav li:hover > .sub-menu,.main-nav li:focus-within > .sub-menu{display:flex;}
}
.main-nav .sub-menu a{white-space:normal;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-weight:var(--fw-normal);color:var(--color-text);}
.main-nav .sub-menu a:hover{background:var(--color-surface);color:var(--color-primary);text-decoration:none;}
.header-actions{display:flex;align-items:center;gap:var(--space-3);}
.dnv-header-cta{white-space:nowrap;}
.header-search form{display:flex;}
/* Mobile: the hero CTA + sticky Call/Text bar cover conversion, so drop the
   header CTA below 768px to avoid it wrapping and crowding the logo + menu. */
@media(max-width:767px){
	.dnv-header-cta{display:none;}
}
@media(min-width:768px) and (max-width:959px){
	.dnv-header-cta{padding:var(--space-2) var(--space-4);font-size:var(--text-sm);}
}
.menu-toggle{display:inline-flex;flex-direction:column;gap:4px;background:none;border:0;cursor:pointer;padding:var(--space-2);}
.menu-toggle span{width:24px;height:2px;background:var(--color-text);display:block;transition:var(--transition);}
@media(max-width:959px){
	/* Light mobile nav panel to match the light header. */
	.main-nav{position:fixed;inset:var(--header-h) 0 auto 0;background:var(--color-white);transform:translateY(-150%);transition:transform var(--transition);box-shadow:var(--shadow);max-height:calc(100vh - var(--header-h));overflow-y:auto;}
	.main-nav.is-open{transform:translateY(0);}
	.main-nav > ul{flex-direction:column;flex-wrap:nowrap;gap:0;padding:var(--space-4);align-items:stretch;}
	.main-nav li{border-bottom:1px solid var(--color-border);}
	.main-nav a{display:block;padding:var(--space-3) 0;white-space:normal;}
	.main-nav .menu-item-has-children > a::after{float:right;margin-top:.5em;}
	/* Submenus are a tap accordion on mobile: collapsed by default, shown when
	   JS adds .is-open to the parent <li>; the caret flips when open. */
	.main-nav .sub-menu{position:static;display:none;box-shadow:none;border:0;border-radius:0;padding:0 0 var(--space-2) var(--space-4);min-width:0;background:transparent;}
	.main-nav .menu-item-has-children.is-open > .sub-menu{display:flex;}
	.main-nav .menu-item-has-children.is-open > a::after{transform:rotate(-135deg);}
	.main-nav .sub-menu li{border-bottom:0;}
	.main-nav .sub-menu a{padding:var(--space-2) 0;color:var(--color-muted);}
	.main-nav .sub-menu a:hover{background:transparent;color:var(--color-primary-strong);}
}
@media(min-width:960px){.menu-toggle{display:none;}}

/* 6. HERO --------------------------------------------------------------- */
/* Default hero: LIGHT teal-tinted band with dark text (airy corporate-trust,
   the opposite of the old dark centered hero). */
.hero{position:relative;overflow:hidden;color:var(--color-text);
	background:radial-gradient(1100px 620px at 88% -10%,rgba(11,83,148,.14) 0%,rgba(11,83,148,0) 55%),linear-gradient(170deg,var(--color-surface) 0%,var(--color-white) 70%);
	border-bottom:3px solid var(--color-accent);}
/* When a media image is set it stays a real <img>; a light scrim keeps text legible. */
.hero--has-media{background:var(--color-surface);}
.hero__media{position:absolute;inset:0;z-index:0;}
.hero__media img{width:100%;height:100%;object-fit:cover;}
.hero__media::after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,rgba(255,255,255,.96) 0%,rgba(255,255,255,.82) 48%,rgba(240,253,250,.55) 100%);}
.hero__inner{position:relative;z-index:1;display:grid;gap:var(--space-8);padding:var(--space-16) 0;align-items:center;}
@media(min-width:960px){
	.hero:not(.hero--booking) .hero__inner{min-height:420px;align-content:center;}
	/* SPLIT hero: content left, booking wizard right (opposite of the old
	   centered-with-card-below layout). hero__content + booking-shell are siblings. */
	.hero--booking .hero__inner{grid-template-columns:minmax(0,1fr) minmax(0,520px);align-items:center;gap:var(--space-12);}
}
/* Single-column fallback (< 960px): intro above the wizard, left-aligned. */
.hero--booking .hero__inner{padding-bottom:var(--space-16);}
.hero--booking .hero__content{max-width:560px;}
.booking-shell{max-width:560px;}
@media(max-width:959px){
	.hero--booking .hero__content{margin-bottom:var(--space-8);}
	.booking-shell{margin:0 auto;}
}
.hero__content{color:var(--color-text);max-width:600px;}
.hero--has-media .hero__content{color:var(--color-text);}
/* Eyebrow — bold blue-tinted tab with an amber left accent (strong, uppercase). */
.hero__eyebrow{display:inline-block;background:var(--color-surface-2);color:var(--color-primary-ink);font-weight:var(--fw-bold);font-size:var(--text-sm);letter-spacing:.08em;text-transform:uppercase;padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);margin-bottom:var(--space-6);border:1px solid var(--color-border);border-left:4px solid var(--color-accent);}
.hero__title{font-size:clamp(2.25rem,5.2vw,var(--text-5xl));font-weight:var(--fw-black);letter-spacing:var(--track-display);line-height:var(--lh-tight);margin-bottom:var(--space-4);color:var(--color-text);}
.hero__subtitle{font-size:var(--text-lg);line-height:var(--lh-snug);margin-bottom:var(--space-8);color:var(--color-muted);max-width:48ch;}
.hero--has-media .hero__subtitle{color:var(--color-muted);}
.hero__ctas{display:flex;flex-wrap:wrap;gap:var(--space-4);align-items:center;}
/* On the light hero the "Nazovi" button uses the on-light ghost treatment. */
.hero__call{color:var(--color-primary-ink);border-color:var(--color-border);background:var(--color-white);}
.hero__call:hover{background:var(--color-surface);color:var(--color-primary-strong);border-color:var(--color-primary);}
.hero--has-media .hero__call{color:var(--color-primary-ink);border-color:var(--color-border);background:var(--color-white);}
.hero--has-media .hero__call:hover{background:var(--color-surface);color:var(--color-primary-strong);border-color:var(--color-primary);}
.hero__text-link{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--color-accent-ink);font-weight:var(--fw-semibold);}
.hero--has-media .hero__text-link{color:var(--color-accent-ink);}

/* Quote form */
.quote-form-wrap{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--space-8);border:1px solid var(--color-border);border-top:5px solid var(--color-accent);}
.quote-form-wrap h2{font-size:var(--text-2xl);margin-bottom:var(--space-6);}
.quote-form .field{margin-bottom:var(--space-4);}
.quote-form label{display:block;font-weight:var(--fw-semibold);font-size:var(--text-sm);margin-bottom:var(--space-2);color:var(--color-text);}
.quote-form input,.quote-form select,.quote-form textarea{width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--text-base);font-family:inherit;background:#fff;transition:border-color var(--transition),box-shadow var(--transition);}
.quote-form input:focus,.quote-form select:focus,.quote-form textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(11,83,148,.18);}
.quote-form textarea{min-height:96px;resize:vertical;}
.quote-form .btn{margin-top:var(--space-2);}
.quote-form__hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden;}
.quote-form__feedback{margin-top:var(--space-3);font-weight:var(--fw-medium);}
.quote-form__feedback.is-success{color:var(--color-success);}
.quote-form__feedback.is-error{color:#dc2626;}
.spinner{display:none;width:18px;height:18px;border:2px solid #ffffff80;border-top-color:#fff;border-radius:50%;}
.is-loading .spinner{display:inline-block;animation:dnv-spin .7s linear infinite;}
@keyframes dnv-spin{to{transform:rotate(360deg);}}
.form-fallback{background:var(--color-surface);border-radius:var(--radius);padding:var(--space-6);text-align:center;}

/* 7. TRUST / OPEN NOW --------------------------------------------------- */
.trust-bar{background:#fff;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);}
.trust-bar__inner{display:flex;flex-wrap:wrap;gap:var(--space-4) var(--space-8);align-items:center;justify-content:center;padding:var(--space-8) 0;text-align:center;}
.trust-bar__inner>*{position:relative;}
@media(min-width:768px){
	.trust-bar__inner>*+*::before{content:"";position:absolute;left:calc(var(--space-8) / -2);top:50%;transform:translateY(-50%);width:1px;height:32px;background:var(--color-border);}
}
.trust-bar .trust-badges{padding:var(--space-5) var(--space-4);border-top:1px solid var(--color-border);margin-top:var(--space-4);}
.trust-rating{display:flex;align-items:center;gap:var(--space-2);font-weight:var(--fw-semibold);}
.stars{display:inline-flex;color:var(--color-star);}
.stars svg{width:1.1em;height:1.1em;}
.trust-metric{display:flex;flex-direction:column;}
.trust-metric__value{font-size:var(--text-2xl);font-weight:var(--fw-black);color:var(--color-primary);line-height:1;}
.trust-metric__label{font-size:var(--text-sm);color:var(--color-muted);}
.trust-chip{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-sm);background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-full);padding:var(--space-1) var(--space-3);}
.trust-badges{display:flex;flex-wrap:wrap;gap:var(--space-4) var(--space-8);justify-content:center;align-items:center;}
.trust-badge{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-base);font-weight:var(--fw-semibold);color:var(--color-text);line-height:1;}
.trust-badge svg{width:20px;height:20px;flex:none;color:var(--color-success);}

.open-now{display:inline-flex;align-items:center;gap:var(--space-2);font-weight:var(--fw-semibold);font-size:var(--text-sm);}
.open-now__dot{width:9px;height:9px;border-radius:50%;background:var(--color-muted);}
.open-now.is-open .open-now__dot{background:var(--color-success);}
.open-now.is-closed .open-now__dot{background:#dc2626;}

/* 8. CARDS / SILO ------------------------------------------------------- */
.card{background:#fff;border:1px solid var(--color-border);border-left:4px solid var(--color-primary);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;transition:var(--transition);box-shadow:var(--shadow-sm);}
.card:hover{box-shadow:var(--shadow);transform:translateY(-3px);border-left-color:var(--color-accent);}
.card__media img{width:100%;aspect-ratio:3/2;object-fit:cover;}
.card__body{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-2);flex:1;}
.card__title{font-size:var(--text-xl);margin:0;letter-spacing:-.02em;}
.card__excerpt{color:var(--color-muted);font-size:var(--text-sm);margin:0;}
.card__cta{margin-top:auto;font-weight:var(--fw-bold);color:var(--color-accent-ink);display:inline-flex;align-items:center;gap:var(--space-1);}
.card__title a{color:inherit;}
.card__title a:hover{color:var(--color-accent-ink);text-decoration:none;}
.silo{margin:var(--space-12) 0;padding:var(--space-12) 0;background:var(--color-surface);border-radius:var(--radius-lg);}
.silo .container{}
.silo__heading{margin-bottom:var(--space-6);font-size:var(--text-2xl);text-align:center;}
.silo__links{display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:center;}
.silo__links a{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-full);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--fw-medium);color:var(--color-text);transition:var(--transition);}
.silo__links a:hover{background:var(--color-primary);color:var(--color-on-dark);border-color:var(--color-primary);text-decoration:none;}

/* 9. FAQ ---------------------------------------------------------------- */
.faq{padding:var(--space-16) 0;}
.faq__heading{text-align:center;margin-bottom:var(--space-8);font-size:var(--text-3xl);}
.faq__list{max-width:740px;margin:0 auto;display:flex;flex-direction:column;gap:var(--space-3);}
.faq__item{border:1px solid var(--color-border);border-radius:var(--radius);background:#fff;overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow var(--transition),border-color var(--transition);}
.faq__item:hover{border-color:#cbd2db;}
.faq__item[open]{border-color:var(--color-primary);box-shadow:var(--shadow);}
.faq__summary{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-5) var(--space-6);cursor:pointer;list-style:none;transition:background var(--transition);}
.faq__summary::-webkit-details-marker{display:none;}
.faq__summary::marker{content:"";}
.faq__item[open] .faq__summary{background:var(--color-surface);}
.faq__summary:hover .faq-question{color:var(--color-accent-ink);}
.faq-question{font-size:var(--text-lg);margin:0;font-weight:var(--fw-bold);letter-spacing:-.01em;line-height:1.4;transition:color var(--transition);}
.faq__chevron{flex:none;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-full);background:var(--color-surface);color:var(--color-primary);transition:transform var(--transition),background var(--transition),color var(--transition);}
.faq__chevron svg{width:18px;height:18px;transform:rotate(90deg);}
.faq__item[open] .faq__chevron{transform:rotate(180deg);background:var(--color-primary);color:#fff;}
.faq__answer{padding:0 var(--space-6) var(--space-6);color:var(--color-muted);font-size:var(--text-base);line-height:var(--lh-normal);}
.faq__answer p:last-child{margin-bottom:0;}

/* 10. CTA BANNER -------------------------------------------------------- */
/* Deep-navy inverted band with an amber glow — confident bold-trade contrast. */
.cta-banner{background:radial-gradient(700px 360px at 80% -30%,rgba(199,154,62,.30) 0%,rgba(199,154,62,0) 60%),linear-gradient(160deg,var(--color-dark) 0%,var(--color-dark-2) 100%);color:var(--color-on-dark);border:1px solid var(--color-dark-border);border-top:4px solid var(--color-accent);border-radius:var(--radius-lg);padding:var(--space-12);text-align:center;margin:var(--space-12) auto;}
.cta-banner .btn--primary{background:var(--color-accent);color:var(--color-text);box-shadow:none;}
.cta-banner .btn--primary:hover{background:var(--color-accent-hover);color:var(--color-text);}
.cta-banner h2{color:#fff;}
.cta-banner p{color:var(--color-on-dark-muted);margin-bottom:var(--space-6);}
.cta-banner__actions{display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:center;}

/* 11. TESTIMONIALS ------------------------------------------------------ */
.testimonials{padding:var(--space-16) 0;background:var(--color-surface);}
.testimonials__track{display:grid;gap:var(--space-6);}
.testimonial{background:#fff;border-radius:var(--radius-lg);padding:var(--space-8);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);border-left:4px solid var(--color-primary);}
.testimonial__stars{color:var(--color-star);margin-bottom:var(--space-3);display:flex;}
.testimonial__text{font-size:var(--text-lg);margin-bottom:var(--space-4);}
.testimonial__author{font-weight:var(--fw-semibold);}
.testimonial__location{color:var(--color-muted);font-size:var(--text-sm);}

/* 12. E-E-A-T ----------------------------------------------------------- */
.author-box{display:flex;flex-wrap:wrap;gap:var(--space-6);background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-8);margin:var(--space-12) 0;}
.author-box__photo img{width:96px;height:96px;border-radius:50%;object-fit:cover;}
.author-box__body{flex:1;min-width:240px;}
.author-box__eyebrow{text-transform:uppercase;letter-spacing:.05em;font-size:var(--text-xs);color:var(--color-muted);}
.author-box__name{font-size:var(--text-xl);margin:var(--space-1) 0;}
.author-box__creds{color:var(--color-accent-ink);font-weight:var(--fw-semibold);font-size:var(--text-sm);margin-bottom:var(--space-2);}
.author-box__social{display:flex;gap:var(--space-3);margin-top:var(--space-3);}
.author-box__social svg{width:1.2em;height:1.2em;}

.fact-check{position:relative;display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-muted);margin:var(--space-3) 0;}
.fact-check > svg{width:1.1em;height:1.1em;color:var(--color-success);flex:none;}
.fact-check__details{display:inline-flex;align-items:center;}
.fact-check__details summary{cursor:pointer;color:var(--color-primary);list-style:none;display:inline-flex;align-items:center;}
.fact-check__details summary::-webkit-details-marker{display:none;}
.fact-check__details summary::marker{content:"";}
.fact-check__details summary svg{width:1.1em;height:1.1em;}
/* Editorial-process note drops below the line as a popover (never pushes the row). */
.fact-check__panel{position:absolute;top:calc(100% + 6px);left:0;min-width:260px;max-width:min(420px,90vw);background:#fff;color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:var(--space-4);z-index:20;}
.fact-check__panel p{margin:0 0 var(--space-2);}
.fact-check__panel p:last-child{margin-bottom:0;}

.projects__grid{display:grid;gap:var(--space-6);grid-template-columns:1fr;}
@media(min-width:640px){.projects__grid{grid-template-columns:repeat(2,1fr);}}
@media(min-width:960px){.projects__grid{grid-template-columns:repeat(3,1fr);}}
.project-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;background:#fff;}
.project-card__images{display:grid;grid-template-columns:1fr 1fr;}
.project-card__images figure{margin:0;position:relative;}
.project-card__images figcaption{position:absolute;bottom:0;left:0;background:rgba(7,27,48,.82);color:#fff;font-size:var(--text-xs);padding:2px 8px;}
.project-card__body{padding:var(--space-6);}
.project-card__meta{font-size:var(--text-sm);color:var(--color-muted);margin-bottom:var(--space-2);}

.credentials{display:flex;flex-wrap:wrap;gap:var(--space-4);justify-content:center;padding:var(--space-8) 0;}
.credential{display:flex;align-items:center;gap:var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-3) var(--space-4);background:#fff;}
.credential svg{width:1.4em;height:1.4em;color:var(--color-primary);}
.credential__value{font-weight:var(--fw-semibold);}

.awards{display:flex;flex-wrap:wrap;gap:var(--space-8);align-items:center;justify-content:center;padding:var(--space-8) 0;}
.awards img{max-height:48px;width:auto;filter:grayscale(1);opacity:.75;transition:var(--transition);}
.awards a:hover img,.awards img:hover{filter:grayscale(0);opacity:1;}

.team-grid{display:grid;gap:var(--space-6);grid-template-columns:1fr;}
@media(min-width:640px){.team-grid{grid-template-columns:repeat(2,1fr);}}
@media(min-width:960px){.team-grid{grid-template-columns:repeat(3,1fr);}}
.team-card{text-align:center;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);}
.team-card__photo img{width:120px;height:120px;border-radius:50%;object-fit:cover;margin:0 auto var(--space-3);}

.guarantees{display:grid;gap:var(--space-6);grid-template-columns:1fr;}
@media(min-width:640px){.guarantees{grid-template-columns:repeat(3,1fr);}}
.guarantee{text-align:center;padding:var(--space-6);}
.guarantee svg{width:2.4em;height:2.4em;color:var(--color-primary);margin-bottom:var(--space-2);}

.freshness{font-size:var(--text-sm);color:var(--color-muted);margin:var(--space-3) 0;}

/* 13. BREADCRUMBS / PROSE / BLOG --------------------------------------- */
.breadcrumbs{font-size:var(--text-sm);padding:var(--space-3) 0;background:var(--color-surface);}
.breadcrumbs__list{list-style:none;display:flex;flex-wrap:wrap;gap:var(--space-2);margin:0;padding:0;}
.breadcrumbs__item+.breadcrumbs__item::before{content:"/";margin-right:var(--space-2);color:var(--color-muted);}
.content-narrow{max-width:760px;margin-left:auto;margin-right:auto;}
.prose-content{max-width:var(--width-content);margin:0 auto;padding:var(--space-12) var(--space-4);font-size:var(--text-lg);}
.prose-content.content-narrow{max-width:760px;}
.prose-content h2{font-size:var(--text-2xl);margin-top:var(--space-12);}
.prose-content h3{font-size:var(--text-xl);margin-top:var(--space-8);}
.prose-content h2:first-child,.prose-content h3:first-child{margin-top:0;}
.prose-content a{text-decoration:underline;text-underline-offset:2px;}
.prose-content img{border-radius:var(--radius);margin:var(--space-6) 0;}
.post-thumb img{border-radius:var(--radius-lg);margin-bottom:var(--space-6);}
.entry-meta{color:var(--color-muted);font-size:var(--text-sm);margin-bottom:var(--space-6);}
.post-list{display:grid;gap:var(--space-8);}
/* Native WordPress pagination (blog index, archives, search). */
.pagination{margin-top:var(--space-12);}
.pagination .nav-links{display:flex;flex-wrap:wrap;gap:var(--space-2);justify-content:center;}
.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius);font-weight:var(--fw-semibold);color:var(--color-text);transition:var(--transition);}
.pagination .page-numbers.current{background:var(--color-primary);color:#fff;border-color:var(--color-primary);}
.pagination a.page-numbers:hover{background:var(--color-surface);color:var(--color-primary);text-decoration:none;}

/* Read More (collapsible content) — JS-gated so no-JS shows everything.
   The button only appears once JS adds .is-ready (i.e. content was long
   enough to collapse), so short content never shows a dead button. */
.readmore__btn{display:none;margin-top:var(--space-6);}
.readmore--center{text-align:center;}
.readmore--right{text-align:right;}
.readmore__visible,.readmore__hidden,.readmore__inner{text-align:left;}
.js .readmore.is-ready .readmore__btn{display:inline-flex;}
.js .readmore--block.is-ready .readmore__btn{display:flex;width:100%;}
/* more-tag mode */
.js .readmore.is-collapsed .readmore__hidden{display:none;}
/* height mode */
.readmore--height{position:relative;}
.js .readmore--height.is-collapsed .readmore__inner{max-height:var(--readmore-h,480px);overflow:hidden;-webkit-mask-image:linear-gradient(180deg,#000 70%,transparent);mask-image:linear-gradient(180deg,#000 70%,transparent);}
@media(prefers-reduced-motion:no-preference){
	.js .readmore--height .readmore__inner{transition:max-height var(--transition);}
}

/* 14. FOOTER ------------------------------------------------------------ */
.site-footer{background:var(--color-dark-2);color:var(--color-on-dark-muted);padding:var(--space-16) 0 var(--space-24);margin-top:var(--space-16);}
.site-footer a{color:var(--color-on-dark);}
.site-footer a:hover{color:#fff;}
.footer-grid{display:grid;gap:var(--space-8);grid-template-columns:1fr;}
@media(min-width:768px){.footer-grid{grid-template-columns:2fr 1fr 1fr;}}
.footer-widget__title,.site-footer h3{color:#fff;font-size:var(--text-lg);margin-bottom:var(--space-4);}
.site-footer p{margin-bottom:var(--space-2);color:var(--color-on-dark-muted);}
.footer-menu,.site-footer ul{list-style:none;padding:0;margin:0;}
.footer-menu li{margin-bottom:var(--space-2);}
.footer-menu a:hover{color:#fff;text-decoration:underline;}
.footer-license{font-size:var(--text-sm);color:var(--color-on-dark-muted)!important;}
.footer-social{display:flex;gap:var(--space-3);margin-top:var(--space-4);}
.footer-social a{width:40px;height:40px;align-items:center;justify-content:center;border-radius:var(--radius-full);background:rgba(255,255,255,.08);transition:var(--transition);}
.footer-social a:hover{background:var(--color-primary);color:#fff;}
.footer-social a{display:inline-flex;}
.footer-social svg{width:1.4em;height:1.4em;}
.footer-bottom{border-top:1px solid var(--color-dark-border);margin-top:var(--space-8);padding-top:var(--space-6);font-size:var(--text-sm);text-align:center;}

/* Mobile sticky conversion bar — navy base with an amber primary CTA. */
.sticky-bar{position:fixed;left:0;right:0;bottom:0;z-index:60;display:flex;background:var(--color-dark);box-shadow:0 -4px 16px rgba(7,27,48,.36);}
.sticky-bar a{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-4);color:#fff;font-weight:var(--fw-bold);}
.sticky-bar a+a{border-left:1px solid var(--color-dark-border);}
.sticky-bar a:last-child{background:var(--color-accent);color:var(--color-text);}
.sticky-bar svg{width:1.2em;height:1.2em;}
@media(min-width:960px){.sticky-bar{display:none;}}
body.has-sticky-bar{padding-bottom:64px;}
@media(min-width:960px){body.has-sticky-bar{padding-bottom:0;}}

/* 15. UTILITIES / A11Y / MOTION ---------------------------------------- */
.skip-link{position:absolute;left:-9999px;top:0;background:#fff;color:var(--color-primary);padding:var(--space-3);z-index:1000;}
.skip-link:focus{left:var(--space-3);}
.screen-reader-text{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0;}
:focus-visible{outline:3px solid var(--color-accent);outline-offset:2px;}
.text-center{text-align:center;}
.section-head{text-align:center;max-width:720px;margin:0 auto var(--space-12);}
.section-head h1,.section-head h2{font-size:var(--text-3xl);margin-bottom:var(--space-3);}
h2.section-head{font-size:var(--text-3xl);margin:0 auto var(--space-8);max-width:720px;}
.section-head>h2::after,.section-head>h1::after,h2.section-head::after{content:"";display:block;width:64px;height:5px;border-radius:2px;background:var(--color-accent);margin:var(--space-4) auto 0;}
.section-head p{color:var(--color-muted);font-size:var(--text-lg);margin:0;}

/* Scroll reveal — only when JS is present, and only if motion allowed. */
.js .reveal{opacity:0;transform:translateY(16px);}
@media(prefers-reduced-motion:no-preference){
	.js .reveal{transition:opacity .5s ease,transform .5s ease;}
	.js .reveal.is-visible{opacity:1;transform:none;}
}
@media(prefers-reduced-motion:reduce){
	html{scroll-behavior:auto;}
	.js .reveal{opacity:1;transform:none;}
	*{animation-duration:.001ms!important;transition-duration:.001ms!important;}
}
.no-js .reveal{opacity:1;transform:none;}

/* 16. BOOKING WIZARD (3-step lead form) -------------------------------- */
.booking-form__head{text-align:center;margin-bottom:var(--space-6);}
.booking-form__title{font-size:var(--text-2xl);margin-bottom:var(--space-2);}
.booking-form__sub{color:var(--color-muted);margin:0;}

/* Step indicator */
.booking-form:not(.is-enhanced) .booking-steps{display:none;}
.booking-steps{list-style:none;display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-2);margin:0 0 var(--space-8);padding:0;}
.booking-steps__item{flex:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-2);position:relative;color:var(--color-muted);font-size:var(--text-sm);font-weight:var(--fw-semibold);text-align:center;}
.booking-steps__item:not(:first-child)::before{content:"";position:absolute;top:17px;right:50%;left:-50%;height:2px;background:var(--color-border);z-index:0;}
.booking-steps__item.is-active::before,.booking-steps__item.is-done::before{background:var(--color-primary);}
.booking-steps__num{position:relative;z-index:1;width:36px;height:36px;border-radius:var(--radius-full);background:var(--color-surface);border:2px solid var(--color-border);color:var(--color-muted);display:inline-flex;align-items:center;justify-content:center;font-weight:var(--fw-bold);}
.booking-steps__item.is-active .booking-steps__num,.booking-steps__item.is-done .booking-steps__num{background:var(--color-primary);border-color:var(--color-primary);color:#fff;}
.booking-steps__item.is-active{color:var(--color-text);}
.booking-steps__label{line-height:1.2;}
.booking-form.is-enhanced .booking-steps__item.is-done{cursor:pointer;}
@media(max-width:479px){.booking-steps__label{display:none;}}

/* Steps: stacked & fully usable without JS; one-at-a-time once enhanced. */
.booking-step+.booking-step{margin-top:var(--space-8);padding-top:var(--space-8);border-top:1px solid var(--color-border);}
.booking-form.is-enhanced .booking-step{display:none;margin-top:0;padding-top:0;border-top:0;}
.booking-form.is-enhanced .booking-step.is-active{display:block;}
.booking-step__heading{font-size:var(--text-lg);margin:var(--space-6) 0 var(--space-4);}
.booking-step__heading:first-child{margin-top:0;}

/* Field grid */
.booking-grid{display:grid;grid-template-columns:1fr;gap:var(--space-4) var(--space-5);}
@media(min-width:560px){.booking-grid{grid-template-columns:1fr 1fr;}}
.booking-grid .field{margin-bottom:0;}
.field--full{grid-column:1 / -1;}

/* Nav buttons (next/back hidden until JS enhances; submit always present) */
.booking-nav{display:flex;gap:var(--space-3);margin-top:var(--space-8);align-items:center;justify-content:space-between;flex-wrap:wrap;}
.booking-nav--end{justify-content:flex-end;}
.booking-nav__btn{display:none;}
.booking-form.is-enhanced .booking-nav__btn{display:inline-flex;}
.booking-submit{margin-left:auto;}

/* Vehicle cards */
.vehicle-grid{display:grid;grid-template-columns:1fr;gap:var(--space-4);}
@media(min-width:560px){.vehicle-grid{grid-template-columns:1fr 1fr;}}
.vehicle-card{position:relative;display:flex;flex-direction:column;border:2px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;background:#fff;transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition);}
.vehicle-card:hover{border-color:#cbd2db;box-shadow:var(--shadow-sm);}
.vehicle-card__input{position:absolute;opacity:0;width:1px;height:1px;}
.vehicle-card__media{position:relative;aspect-ratio:16/10;background:linear-gradient(135deg,var(--color-surface-2),var(--color-surface));display:flex;align-items:center;justify-content:center;color:rgba(11,83,148,.30);}
.vehicle-card__media img{width:100%;height:100%;object-fit:cover;}
.vehicle-card__tick{position:absolute;top:10px;right:10px;width:26px;height:26px;border-radius:var(--radius-full);background:var(--color-primary);color:#fff;display:none;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);}
.vehicle-card__body{padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-2);flex:1;}
.vehicle-card__title{font-weight:var(--fw-bold);font-size:var(--text-lg);letter-spacing:-.01em;}
.vehicle-card__models{color:var(--color-muted);font-size:var(--text-sm);}
.vehicle-card__chips{display:flex;flex-wrap:wrap;gap:var(--space-2);margin:var(--space-1) 0;}
.chip{font-size:var(--text-xs);font-weight:var(--fw-semibold);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:3px 10px;color:var(--color-muted);}
.vehicle-card__price{margin-top:auto;padding-top:var(--space-2);font-weight:var(--fw-black);font-size:var(--text-lg);color:var(--color-text);}
.vehicle-card.is-selected{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(11,83,148,.18);}
.vehicle-card.is-selected .vehicle-card__tick{display:inline-flex;}
.vehicle-card__input:focus-visible+.vehicle-card__media{outline:3px solid var(--color-accent);outline-offset:-3px;}

/* Extras list */
.extras-list{display:flex;flex-direction:column;gap:var(--space-3);}
.extra-card{position:relative;display:flex;align-items:center;gap:var(--space-4);border:2px solid var(--color-border);border-radius:var(--radius);padding:var(--space-4) var(--space-5);cursor:pointer;background:#fff;transition:border-color var(--transition),box-shadow var(--transition);}
.extra-card:hover{border-color:#cbd2db;}
.extra-card__input{position:absolute;opacity:0;width:1px;height:1px;}
.extra-card__check{flex:none;width:26px;height:26px;border-radius:var(--radius-sm);border:2px solid var(--color-border);display:inline-flex;align-items:center;justify-content:center;color:#fff;transition:var(--transition);}
.extra-card__check svg{opacity:0;}
.extra-card__body{display:flex;flex-direction:column;}
.extra-card__title{font-weight:var(--fw-semibold);}
.extra-card__price{color:var(--color-muted);font-size:var(--text-sm);}
.extra-card.is-selected{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(11,83,148,.14);}
.extra-card.is-selected .extra-card__check{background:var(--color-primary);border-color:var(--color-primary);}
.extra-card.is-selected .extra-card__check svg{opacity:1;}
.extra-card__input:focus-visible+.extra-card__check{outline:3px solid var(--color-accent);outline-offset:2px;}

/* =========================================================================
 * Per-city DIRECTORY (imenik) + FEATURED #1 hero badge — bold-trade
 * ====================================================================== */
.directory{padding:var(--space-16) 0;background:var(--color-surface);border-top:2px solid var(--color-border);border-bottom:2px solid var(--color-border);}
.directory__heading{text-align:center;margin-bottom:var(--space-8);font-size:var(--text-3xl);font-weight:var(--fw-black);letter-spacing:var(--track-display);}
.directory__list{display:grid;gap:var(--space-6);grid-template-columns:1fr;}
@media(min-width:680px){.directory__list{grid-template-columns:repeat(2,1fr);}}
@media(min-width:1040px){.directory__list{grid-template-columns:repeat(3,1fr);}}

.directory__card{position:relative;display:flex;flex-direction:column;gap:var(--space-3);background:var(--color-white);border:1px solid var(--color-border);border-left:5px solid var(--color-primary);border-radius:var(--radius);padding:var(--space-6);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition),border-color var(--transition);}
.directory__card:hover{box-shadow:var(--shadow);border-color:var(--color-primary);}
.directory__card--featured{border-left-color:var(--color-accent);box-shadow:var(--shadow);}
.directory__card--featured::after{content:"★";position:absolute;top:var(--space-4);right:var(--space-5);color:var(--color-accent);font-size:var(--text-lg);line-height:1;}

.directory__rank{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;flex:none;border-radius:var(--radius-sm);background:var(--color-primary);color:#fff;font-weight:var(--fw-black);font-size:var(--text-base);}
.directory__card--featured .directory__rank{background:var(--color-accent);color:var(--color-text);}
.directory__name{font-size:var(--text-lg);font-weight:var(--fw-bold);letter-spacing:-.015em;margin:0;color:var(--color-text);}

.directory__rating{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--fw-semibold);color:var(--color-text);}
.directory__star{display:inline-flex;align-items:center;justify-content:center;color:var(--color-star);}
.directory__star svg{width:1em;height:1em;}
.directory__rating-count{color:var(--color-muted);font-weight:var(--fw-normal);}

.directory__desc{margin:0;color:var(--color-muted);font-size:var(--text-sm);line-height:var(--lh-normal);}
.directory__meta{display:flex;align-items:flex-start;gap:var(--space-2);margin:0;color:var(--color-muted);font-size:var(--text-sm);}
.directory__icon{display:inline-flex;flex:none;color:var(--color-primary);margin-top:2px;}
.directory__icon svg{width:1em;height:1em;}

.directory__actions{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:auto;padding-top:var(--space-3);}
.directory__action{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:var(--fw-bold);letter-spacing:.02em;text-transform:uppercase;border:1px solid var(--color-border);background:var(--color-white);color:var(--color-primary-ink);transition:var(--transition);}
.directory__action svg{width:1em;height:1em;}
.directory__action:hover{text-decoration:none;border-color:var(--color-primary);background:var(--color-surface);color:var(--color-primary-strong);}
.directory__action--call{background:var(--color-primary-strong);border-color:var(--color-primary-strong);color:#fff;}
.directory__action--call:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover);color:#fff;}

/* FEATURED #1 hero badge — amber ribbon above the eyebrow on city pages. */
.hero__featured-badge{display:inline-flex;align-items:center;gap:var(--space-2);background:var(--color-accent);color:var(--color-text);font-weight:var(--fw-black);font-size:var(--text-sm);letter-spacing:.06em;text-transform:uppercase;padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);margin-bottom:var(--space-4);box-shadow:var(--shadow-sm);}
.hero__featured-badge svg{width:1.1em;height:1.1em;}

@media(prefers-reduced-motion:no-preference){
	.directory__card{transition:box-shadow var(--transition),border-color var(--transition),transform var(--transition);}
	.directory__card:hover{transform:translateY(-2px);}
}

/* Featured #1-spot tagline (city/area hero, under the business-name eyebrow). */
.hero__featured-tagline{display:block;margin:calc(-1 * var(--space-4)) 0 var(--space-5);color:var(--color-muted);font-size:var(--text-lg);font-weight:var(--fw-semibold);max-width:48ch;}
.hero--has-media .hero__featured-tagline{color:var(--color-on-dark-muted);}

/* =========================================================================
 * 16. CONVERSION PACK — promo bar, area checker, video facade, map embed
 * ====================================================================== */

/* Promo bar with expiry — above the topbar (header.php). Carries its OWN
   amber fill + near-black ink (the featured-badge pairing) so it is
   contrast-safe wherever it sits; main.js hides it client-side past
   data-until (cache safety). */
.promo-bar{display:block;background:var(--color-accent);color:var(--color-text);text-align:center;font-size:var(--text-sm);font-weight:var(--fw-bold);letter-spacing:.02em;}
.promo-bar__inner{display:block;padding:var(--space-2) var(--space-4);}
a.promo-bar{text-decoration:none;}
a.promo-bar:hover{background:var(--color-accent-hover);color:var(--color-text);text-decoration:underline;text-underline-offset:3px;}
/* On-dark variant (§21.4) for placements inside dark sections. */
.promo-bar--dark{background:var(--color-dark);color:var(--color-on-dark);border-top:1px solid var(--color-dark-border);border-bottom:1px solid var(--color-dark-border);}
a.promo-bar--dark:hover{background:var(--color-dark-2);color:#fff;}

/* Područja koja pokrivamo — chips + area checker (content-local-areas / [dnv_area_check]). */
.local-areas{padding:var(--space-12) 0;}
.local-areas__heading{text-align:center;margin-bottom:var(--space-6);font-size:var(--text-2xl);}
.area-chips{list-style:none;display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:center;margin:0 0 var(--space-8);padding:0;}
.area-chips li{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-full);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--fw-medium);color:var(--color-text);box-shadow:var(--shadow-sm);}
.area-check{display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:center;align-items:stretch;max-width:560px;margin:0 auto;}
.area-check__label{flex:1;min-width:220px;display:block;}
.area-check input[type="search"]{width:100%;height:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--text-base);font-family:inherit;background:#fff;color:var(--color-text);transition:border-color var(--transition),box-shadow var(--transition);}
.area-check input[type="search"]:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(11,83,148,.18);}
/* Result boxes carry their own light fill + border → readable on any section bg (§21.4). */
.area-check__result{max-width:560px;margin:var(--space-6) auto 0;padding:var(--space-5) var(--space-6);border-radius:var(--radius);border:1px solid var(--color-border);background:#fff;text-align:center;box-shadow:var(--shadow-sm);}
.area-check__result.is-yes{border-color:var(--color-success);background:rgba(11,83,148,.06);}
.area-check__msg{font-weight:var(--fw-semibold);margin:0 0 var(--space-3);color:var(--color-text);}
.area-check__result.is-yes .area-check__msg{color:var(--color-success);}

/* Video facade — click-to-load privacy embed (testimonials + projects).
   Self-contained dark navy card + blue play disc: contrast-safe on light AND dark (§21.4). */
.video-facade{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);margin-top:var(--space-4);padding:var(--space-8) var(--space-4);border-radius:var(--radius);background:linear-gradient(160deg,var(--color-dark) 0%,var(--color-dark-2) 100%);border:1px solid var(--color-dark-border);color:var(--color-on-dark);font-weight:var(--fw-semibold);font-size:var(--text-sm);text-decoration:none;transition:box-shadow var(--transition),transform var(--transition);}
.video-facade:hover{color:#fff;text-decoration:none;box-shadow:var(--shadow);}
@media(prefers-reduced-motion:no-preference){.video-facade:hover{transform:translateY(-2px);}}
.video-facade__play{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:var(--radius-full);background:var(--color-primary-strong);color:#fff;font-size:var(--text-2xl);box-shadow:var(--shadow-sm);}
.video-facade__play svg{margin-left:2px;}
.video-embed{margin-top:var(--space-4);}
.video-embed iframe{display:block;width:100%;aspect-ratio:16/9;border:0;border-radius:var(--radius);}

/* Map embed — per-page override section on area/combo pages + shared iframe sizing. */
.map-embed{padding:var(--space-12) 0;}
.map-embed iframe,.dnv-map iframe{display:block;width:100%;min-height:320px;border:0;border-radius:var(--radius-lg);}

/* -------------------------------------------------------------------------
 * Tool page (page-tool.php) — deliberately quiet chrome for linkable assets.
 * The tool itself (WPCode shortcode in the content) is the whole page.
 * ---------------------------------------------------------------------- */
.tool-header{border-bottom:1px solid var(--color-border, #e5e7eb);padding:var(--space-3, .75rem) 0;background:#fff;}
.tool-header__inner{display:flex;align-items:center;justify-content:center;}
.tool-header .custom-logo-link img{max-height:36px;width:auto;}
.tool-header__title{margin:0;font-size:var(--text-base, 1rem);font-weight:700;}
.tool-header__title a{color:var(--color-text);text-decoration:none;}
.tool-page__inner{max-width:var(--width-content, 720px);padding-top:var(--space-8, 2rem);padding-bottom:var(--space-12, 3rem);}
.tool-page__title{font-size:var(--text-2xl, 1.5rem);margin:0 0 var(--space-6, 1.5rem);}
.tool-footer{border-top:1px solid var(--color-border, #e5e7eb);padding:var(--space-6, 1.5rem) 0;margin-top:var(--space-8, 2rem);}
.tool-footer__inner{display:flex;flex-wrap:wrap;gap:var(--space-4, 1rem);justify-content:center;font-size:var(--text-sm, .875rem);color:var(--color-muted, #5C5C6E);}
.tool-footer__inner p{margin:0;}
.tool-footer__inner a{color:inherit;}


/* =========================================================================
   17. EXECUTIVE-TRUST PROFILE OVERRIDES (§6 / DESIGN-MANIFEST.json)
   Axes: transitional-serif · boxed-card hero · split-head rhythm ·
   underline cards · stacked header · no texture. Scoped to dp-* body classes
   (seeded from DNV_DESIGN_PROFILE) + hero--boxed-card so functionality is
   identical to the base build — only the look changes.
   ====================================================================== */

/* Hero title stays serif but eases to bold weight for elegance. */
.dp-type-transitional-serif .hero__title{font-weight:var(--fw-bold);}

/* Eyebrow: a gold underline label instead of a boxed tab. */
.dp-type-transitional-serif .hero__eyebrow{
	background:transparent;border:0;padding:0 0 var(--space-2);border-radius:0;
	color:var(--color-primary-ink);font-family:var(--font);font-weight:var(--fw-bold);
	letter-spacing:.14em;text-transform:uppercase;font-size:var(--text-xs);
	border-bottom:2px solid var(--color-accent);margin-bottom:var(--space-5);
}

/* --- HERO: boxed-card over a full-bleed image -------------------------- */
/* Dark cinematic scrim replaces the light wash so the floating card reads. */
.hero--boxed-card{overflow:visible;}
.hero--boxed-card.hero--has-media .hero__media::after{
	background:linear-gradient(180deg,rgba(18,12,17,.55) 0%,rgba(18,12,17,.70) 100%);
}
/* No image → a deep wine band with a soft gold glow so the card still floats. */
.hero--boxed-card:not(.hero--has-media){background:var(--color-primary);}
.hero--boxed-card:not(.hero--has-media)::before{
	content:"";position:absolute;inset:0;z-index:0;
	background:radial-gradient(120% 120% at 85% -10%,rgba(199,154,62,.28),transparent 55%);
}
/* The single floating card holding headline + CTAs + booking wizard. */
.hero--boxed-card .hero__inner{
	background:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);
	border-top:4px solid var(--color-accent);padding:var(--space-12);
	margin:var(--space-16) auto;max-width:1120px;
}
.hero--boxed-card .hero__content{color:var(--color-text);max-width:none;}
.hero--boxed-card .booking-shell{max-width:none;background:var(--color-surface);
	border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-6);}
@media(min-width:960px){
	.hero--boxed-card.hero--booking .hero__inner{
		grid-template-columns:minmax(0,1fr) minmax(0,500px);gap:var(--space-12);padding:var(--space-16);
	}
}

/* --- HEADER: stacked (utility bar → centered logo → full-width nav) ---- */
.dp-header-stacked .site-header__inner{position:relative;}
@media(min-width:960px){
	.dp-header-stacked .site-header__inner{flex-wrap:wrap;justify-content:center;row-gap:var(--space-2);padding:var(--space-3) 0;}
	.dp-header-stacked .site-branding{flex:0 0 100%;max-width:calc(100% - 320px);margin-inline:auto;display:flex;justify-content:center;text-align:center;}
	.dp-header-stacked .main-nav{flex:0 0 100%;border-top:1px solid var(--color-border);margin-top:var(--space-2);padding-top:var(--space-2);}
	.dp-header-stacked .main-nav > ul{justify-content:center;gap:var(--space-2) var(--space-8);}
	.dp-header-stacked .header-actions{position:absolute;right:0;top:var(--space-3);margin:0;}
}

/* --- SECTION RHYTHM: split-head (H2 left / intro right) + feature band -- */
@media(min-width:860px){
	.dp-rhythm-split-head .section-head:has(> p){
		text-align:left;max-width:var(--width-wide);
		display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);
		gap:var(--space-8);align-items:end;margin-bottom:var(--space-12);
	}
	.dp-rhythm-split-head .section-head:has(> p) p{margin-top:0;}
}
/* Left-anchored accent rule instead of the centered bar. */
.dp-rhythm-split-head .section-head:has(> p)>h2::after,
.dp-rhythm-split-head .section-head:has(> p)>h1::after{
	margin-left:0;margin-right:auto;width:56px;height:3px;background:var(--color-accent);
}

/* --- CARDS: underline (flat, gold bottom-rule, whitespace) ------------- */
.dp-cards-underline .card{
	background:transparent;border:0;border-radius:0;box-shadow:none;
	border-bottom:3px solid var(--color-border);padding-bottom:var(--space-4);
}
.dp-cards-underline .card:hover{transform:none;box-shadow:none;border-bottom-color:var(--color-accent);}
.dp-cards-underline .card__media img{border-radius:var(--radius-sm);}
.dp-cards-underline .card__title{font-family:var(--font-display);}

/* --- Wizard: monthly-price emphasis + trust microcopy ------------------ */
.vehicle-card__price{font-family:var(--font-display);font-weight:var(--fw-bold);color:var(--color-primary-ink);}
.booking-form__trust{margin:var(--space-4) 0 0;text-align:center;font-size:var(--text-sm);color:var(--color-muted);}
.booking-form__trust::before{content:"";display:inline-block;width:.55em;height:.55em;margin-right:.5em;border-radius:50%;background:var(--color-success);vertical-align:middle;}
