/* =========================================================================
   Najam Vozila — 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
   ====================================================================== */

/* 1. TOKENS ------------------------------------------------------------- */
:root{
	/* Brand palette (Customizer overrides --color-primary/-accent/-text + their *-hover). */
	--color-primary:#0E1726;        /* deep graphite-navy: dark surfaces, header, primary brand */
	--color-accent:#FF5A1F;         /* vivid orange: CTAs + active states */
	--color-text:#111827;           /* near-black body text on light */
	--color-primary-hover:#0E1726cc;
	--color-accent-hover:#FF5A1Fdd;

	/* Accent for inline link/text on white (AA-compliant, slightly darkened orange — 5.2:1 on #fff). */
	--color-accent-ink:#C53B16;

	--color-muted:#5b6472;
	--color-surface:#f4f5f7;        /* light section wash */
	--color-border:#e3e6ea;
	--color-white:#ffffff;
	--color-star:#FF5A1F;
	--color-success:#16a34a;

	/* Premium-dark surface family (header / hero / footer / dark CTA). */
	--color-dark:#0E1726;           /* primary dark surface */
	--color-dark-2:#0A1019;         /* deeper dark (gradients, footer floor, top bar) */
	--color-on-dark:#eef1f6;        /* light text on dark surfaces */
	--color-on-dark-muted:#9aa6b6;  /* muted light text on dark */
	--color-dark-border:#26303f;    /* 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;
	--lh-tight:1.08; --lh-snug:1.28; --lh-normal:1.65;

	/* Tight tracking for the premium display headings. */
	--track-display:-.035em;

	--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;
	--radius-sm:6px; --radius:10px; --radius-lg:16px; --radius-full:999px;
	--shadow-sm:0 1px 2px rgba(14,23,38,.07);
	--shadow:0 6px 22px rgba(14,23,38,.10);
	--shadow-lg:0 18px 44px rgba(14,23,38,.18);
	--transition:200ms ease;
	--header-h:74px;

	--font:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Oxygen-Sans,Ubuntu,Cantarell,'Helvetica Neue',sans-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-white);-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;}
h1,h2,h3,h4{line-height:var(--lh-tight);font-weight:var(--fw-black);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);letter-spacing:-.02em;}
h4{font-size:var(--text-lg);letter-spacing:-.02em;}
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;}
.section--surface{background:var(--color-surface);}
.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 ------------------------------------------------------------ */
.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-full);font-weight:var(--fw-bold);
	font-size:var(--text-base);letter-spacing:.01em;border:2px 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 — vivid orange; near-black label for AA contrast (5.69:1 on #FF5A1F; white would be only 3.12:1). */
.btn--primary{background:var(--color-accent);color:var(--color-text);box-shadow:0 6px 18px rgba(255,90,31,.36);}
.btn--primary:hover{background:var(--color-accent-hover);box-shadow:0 10px 26px rgba(255,90,31,.46);}
.btn--secondary{background:var(--color-primary);color:var(--color-on-dark);}
.btn--secondary:hover{background:var(--color-primary-hover);}
.btn--ghost{background:transparent;border-color:var(--color-border);color:var(--color-text);}
.btn--ghost:hover{background:var(--color-surface);border-color:var(--color-primary);color:var(--color-primary);}
/* Outline action ON a dark surface — light hairline, light text; fills white on hover. */
.btn--on-dark{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.55);color:var(--color-on-dark);}
.btn--on-dark:hover{background:#fff;border-color:#fff;color:var(--color-primary);}
.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 ------------------------------------------------------------- */
.topbar{background:var(--color-dark-2);color:var(--color-on-dark);font-size:var(--text-sm);border-bottom:1px solid var(--color-dark-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-on-dark);display:inline-flex;align-items:center;gap:var(--space-2);}
.topbar a:hover{color:#fff;}
.topbar svg{width:1em;height:1em;}
.topbar__afterhours{color:var(--color-accent);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.
   Premium dark header: graphite-navy surface with light text. */
.site-header{position:sticky;top:0;z-index:100;background:var(--color-dark);color:var(--color-on-dark);box-shadow:0 1px 0 var(--color-dark-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-black);letter-spacing:var(--track-display);margin:0;}
.site-title a{color:#fff;}
.site-title a:hover{color:#fff;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-on-dark);font-weight:var(--fw-medium);white-space:nowrap;display:block;padding:var(--space-2) 0;}
.main-nav a:hover{color:#fff;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);}
.nv-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){
	.nv-header-cta{display:none;}
}
@media(min-width:768px) and (max-width:959px){
	.nv-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-on-dark);display:block;transition:var(--transition);}
@media(max-width:959px){
	.main-nav{position:fixed;inset:var(--header-h) 0 auto 0;background:var(--color-dark);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-dark-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-on-dark);}
	.main-nav .sub-menu a:hover{background:transparent;color:#fff;}
}
@media(min-width:960px){.menu-toggle{display:none;}}

/* 6. HERO --------------------------------------------------------------- */
/* Default hero: premium-dark graphite band with light text (a confident,
   automotive feel — distinct from the old airy light hero). */
.hero{position:relative;overflow:hidden;color:var(--color-on-dark);
	background:radial-gradient(1100px 620px at 88% -15%,rgba(255,90,31,.18) 0%,rgba(255,90,31,0) 55%),linear-gradient(160deg,var(--color-dark) 0%,var(--color-dark-2) 100%);}
.hero--has-media{background:var(--color-dark-2);}
.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(115deg,rgba(10,16,25,.92) 0%,rgba(14,23,38,.62) 55%,rgba(14,23,38,.38) 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--has-form .hero__inner{grid-template-columns:1.05fr .95fr;min-height:560px;}
	.hero:not(.hero--has-form) .hero__inner{min-height:440px;justify-items:center;text-align:center;}
}
.hero__content{color:var(--color-on-dark);max-width:600px;}
.hero--has-media .hero__content{color:#fff;}
.hero__eyebrow{display:inline-block;background:var(--color-accent);color:var(--color-text);font-weight:var(--fw-bold);font-size:var(--text-sm);letter-spacing:.04em;text-transform:uppercase;padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);margin-bottom:var(--space-6);box-shadow:0 6px 18px rgba(255,90,31,.34);}
.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:#fff;}
.hero__subtitle{font-size:var(--text-lg);line-height:var(--lh-snug);margin-bottom:var(--space-8);color:var(--color-on-dark-muted);max-width:48ch;}
.hero--has-media .hero__subtitle{color:rgba(255,255,255,.88);}
.hero__ctas{display:flex;flex-wrap:wrap;gap:var(--space-4);align-items:center;}
/* On the dark hero band the "Nazovi" outline button uses the on-dark treatment. */
.hero__call{color:var(--color-on-dark);border-color:rgba(255,255,255,.55);background:rgba(255,255,255,.06);}
.hero__call:hover{background:#fff;color:var(--color-primary);border-color:#fff;}
.hero--has-media .hero__call{color:#fff;border-color:rgba(255,255,255,.7);background:rgba(255,255,255,.08);}
.hero--has-media .hero__call:hover{background:#fff;color:var(--color-primary);border-color:#fff;}
.hero__text-link{display:inline-flex;align-items:center;gap:var(--space-2);color:#fff;font-weight:var(--fw-semibold);}
.hero--has-media .hero__text-link{color:#fff;}

/* 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:4px 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-accent);box-shadow:0 0 0 3px rgba(255,90,31,.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:nv-spin .7s linear infinite;}
@keyframes nv-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-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-color:#d3d8df;}
.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-accent);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-accent);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 -------------------------------------------------------- */
.cta-banner{background:radial-gradient(700px 360px at 80% -30%,rgba(255,90,31,.22) 0%,rgba(255,90,31,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-radius:var(--radius-lg);padding:var(--space-12);text-align:center;margin:var(--space-12) auto;}
.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-accent);}
.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(14,23,38,.78);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:#6b7686!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-accent);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 — orange CTA energy on a dark base. */
.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(0,0,0,.28);}
.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:56px;height:4px;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;}
