/* =========================================================
   StorVault Theme — theme.css
   Design language: CornerStone-inspired — deep navy + gold.
   All colours are CSS custom properties overridden by the
   Customizer. Change one value → entire site updates.
   ========================================================= */

/* ── Design tokens (Customizer overrides these) ──────────── */
:root {
    /* Colours */
    --svt-primary:     #132f4c;   /* Deep navy */
    --svt-primary-dk:  #0d1f2d;   /* Darkest navy — dark sections */
    --svt-primary-lt:  #e8f2fd;   /* Light navy tint */
    --svt-secondary:   #1e5a8d;   /* Mid navy */
    --svt-accent:      #FFD600;   /* Gold */
    --svt-accent-dk:   #e6c200;   /* Darker gold */
    --svt-accent-lt:   #fff8cc;   /* Pale gold */
    --svt-text:        #111827;
    --svt-muted:       #6b7280;
    --svt-light-bg:    #f8f9fc;
    --svt-dark-bg:     #0d1f2d;
    --svt-border:      #e0e7ef;
    --svt-white:       #ffffff;
    --svt-font-heading:'Montserrat', sans-serif;
    --svt-font-body:   'Inter', sans-serif;

    /* Layout */
    --svt-container:   1200px;
    --svt-radius-sm:   6px;
    --svt-radius:      10px;
    --svt-radius-lg:   16px;
    --svt-shadow-sm:   0 1px 3px rgba(0,0,0,.08);
    --svt-shadow:      0 4px 16px rgba(0,0,0,.10);
    --svt-shadow-lg:   0 12px 40px rgba(0,0,0,.14);
    --svt-t:           .18s ease;
}

/* ── Reset ────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
    font-family: var(--svt-font-body);
    color: var(--svt-text);
    background: var(--svt-white);
    line-height: 1.6;
    font-size: 16px;
    -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--svt-secondary); text-decoration: none; transition: color var(--svt-t); }
a:hover { color: var(--svt-accent); }
ul { list-style: none; }
p { margin-bottom: 1em; }
p:last-child { margin-bottom: 0; }

/* ── Typography ───────────────────────────────────────────── */
h1, h2, h3, h4, h5 {
    font-family: var(--svt-font-heading);
    color: var(--svt-text);
    line-height: 1.15;
    font-weight: 800;
}
h1 { font-size: clamp(2.2rem, 5vw, 3.8rem); }
h2 { font-size: clamp(1.7rem, 3.5vw, 2.6rem); }
h3 { font-size: clamp(1.2rem, 2.5vw, 1.6rem); font-weight: 700; }
h4 { font-size: 1.1rem; font-weight: 700; }

/* ── Layout ───────────────────────────────────────────────── */
.svt-container {
    max-width: var(--svt-container);
    margin: 0 auto;
    padding: 0 24px;
}
.svt-section         { padding: 80px 0; }
.svt-section-sm      { padding: 56px 0; }
.svt-section-light   { background: var(--svt-light-bg); }
.svt-section-dark    { background: var(--svt-dark-bg);  color: var(--svt-white); }
.svt-section-primary { background: var(--svt-primary);  color: var(--svt-white); }
.svt-text-center { text-align: center; }

/* ── Comprehensive dark-section text overrides ────────────────────────────────
   Covers every dark-background context: ACF-selected dark/navy + hardcoded
   section classes (.svt-steps-section, .svt-features-section, etc.).
   ALL heading levels + eyebrow + subtitle become white automatically.
   Use [data-svt-text="light"] on any custom wrapper to trigger the same rules.
────────────────────────────────────────────────────────────────────────────── */
.svt-section-dark,
.svt-section-primary,
.svt-steps-section,
.svt-features-section,
.svt-faq-section-dark,
[data-svt-text="light"] {
    color: var(--svt-white);
}

/* All heading levels */
.svt-section-dark    h1, .svt-section-dark    h2, .svt-section-dark    h3,
.svt-section-dark    h4, .svt-section-dark    h5,
.svt-section-primary h1, .svt-section-primary h2, .svt-section-primary h3,
.svt-section-primary h4, .svt-section-primary h5,
.svt-steps-section   h1, .svt-steps-section   h2, .svt-steps-section   h3,
.svt-steps-section   h4, .svt-steps-section   h5,
.svt-features-section h1,.svt-features-section h2,.svt-features-section h3,
.svt-features-section h4,.svt-features-section h5,
[data-svt-text="light"] h1, [data-svt-text="light"] h2,
[data-svt-text="light"] h3, [data-svt-text="light"] h4,
[data-svt-text="light"] h5 {
    color: var(--svt-white);
}

/* Eyebrow pill — gold on dark */
.svt-section-eyebrow {
    display: inline-block;
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: var(--svt-accent);
    background: rgba(255,214,0,.12);
    padding: 4px 12px;
    border-radius: 20px;
    margin-bottom: 14px;
}
.svt-section-dark    .svt-section-eyebrow,
.svt-section-primary .svt-section-eyebrow,
.svt-steps-section   .svt-section-eyebrow,
.svt-features-section .svt-section-eyebrow,
[data-svt-text="light"] .svt-section-eyebrow { background: rgba(255,214,0,.2); }

/* Section title + subtitle */
.svt-section-title    { margin-bottom: 14px; letter-spacing: -.02em; }
.svt-section-subtitle {
    font-size: 17px;
    color: var(--svt-muted);
    max-width: 560px;
    margin-bottom: 44px;
    line-height: 1.7;
}
.svt-section-dark    .svt-section-subtitle,
.svt-section-primary .svt-section-subtitle,
.svt-steps-section   .svt-section-subtitle,
.svt-features-section .svt-section-subtitle,
[data-svt-text="light"] .svt-section-subtitle { color: rgba(255,255,255,.75); }

/* ── Light-section text stays dark (explicit safety net) ──── */
.svt-section-light h1, .svt-section-light h2, .svt-section-light h3,
.svt-section-light h4, .svt-section-light h5,
[data-svt-text="dark"] h1, [data-svt-text="dark"] h2,
[data-svt-text="dark"] h3, [data-svt-text="dark"] h4,
[data-svt-text="dark"] h5 {
    color: var(--svt-text);
}
.svt-section-light .svt-section-subtitle,
[data-svt-text="dark"] .svt-section-subtitle { color: var(--svt-muted); }

/* ── Buttons ──────────────────────────────────────────────── */
.svt-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 13px 30px;
    border-radius: var(--svt-radius-sm);
    font-family: var(--svt-font-heading);
    font-size: 14px;
    font-weight: 700;
    letter-spacing: .03em;
    cursor: pointer;
    text-decoration: none;
    border: 2px solid transparent;
    transition: all var(--svt-t);
    white-space: nowrap;
    line-height: 1.2;
}
.svt-btn-lg  { padding: 16px 38px; font-size: 15px; }
.svt-btn-sm  { padding: 9px 20px;  font-size: 13px; }
.svt-btn-full { width: 100%; }
.svt-btn:focus-visible { outline: 3px solid var(--svt-accent); outline-offset: 2px; }

/* Gold CTA — primary action on dark backgrounds */
.svt-btn-gold {
    background: var(--svt-accent);
    color: var(--svt-primary-dk);
    border-color: var(--svt-accent);
    box-shadow: 0 2px 8px rgba(255,214,0,.35);
}
.svt-btn-gold:hover {
    background: var(--svt-accent-dk);
    border-color: var(--svt-accent-dk);
    color: var(--svt-primary-dk);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(255,214,0,.40);
}

/* Primary navy button */
.svt-btn-primary {
    background: var(--svt-primary);
    color: var(--svt-white);
    border-color: var(--svt-primary);
    box-shadow: 0 2px 8px rgba(19,47,76,.25);
}
.svt-btn-primary:hover {
    background: var(--svt-primary-dk);
    border-color: var(--svt-primary-dk);
    color: var(--svt-white);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(19,47,76,.30);
}

/* Outline white — on dark backgrounds */
.svt-btn-outline-white {
    background: transparent;
    color: var(--svt-white);
    border-color: rgba(255,255,255,.55);
}
.svt-btn-outline-white:hover {
    background: rgba(255,255,255,.12);
    color: var(--svt-white);
    border-color: var(--svt-white);
}

/* Outline navy */
.svt-btn-outline-primary {
    background: transparent;
    color: var(--svt-primary);
    border-color: var(--svt-primary);
}
.svt-btn-outline-primary:hover {
    background: var(--svt-primary);
    color: var(--svt-white);
}

/* White solid — on gold/accent backgrounds */
.svt-btn-white {
    background: var(--svt-white);
    color: var(--svt-primary);
    border-color: var(--svt-white);
    font-weight: 800;
}
.svt-btn-white:hover {
    background: var(--svt-light-bg);
    color: var(--svt-primary);
}

button.svt-btn { outline: none; }

/* ── Announcement bar ─────────────────────────────────────── */
.svt-announce {
    background: var(--svt-accent);
    color: var(--svt-primary-dk);
    text-align: center;
    font-size: 13px;
    font-weight: 700;
    padding: 9px 20px;
    letter-spacing: .01em;
    position: relative;
    z-index: 1001;
}
.svt-announce a { color: var(--svt-primary-dk); text-decoration: underline; }
.svt-announce a:hover { opacity: .75; }

/* ── Top contact bar ──────────────────────────────────────── */
.svt-topbar {
    background: var(--svt-primary);
    color: rgba(255,255,255,.75);
    font-size: 13px;
    padding: 6px 0;
    border-bottom: 1px solid rgba(255,255,255,.08);
}
.svt-topbar-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}
.svt-topbar-left  { display: flex; align-items: center; gap: 20px; }
.svt-topbar-right { display: flex; align-items: center; gap: 12px; }
.svt-topbar-link {
    color: rgba(255,255,255,.8);
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-weight: 500;
    transition: color var(--svt-t);
}
.svt-topbar-link:hover { color: var(--svt-accent); }
.svt-topbar-social {
    display: flex;
    align-items: center;
    color: rgba(255,255,255,.6);
    transition: color var(--svt-t);
}
.svt-topbar-social:hover { color: var(--svt-accent); }

/* ── Main header ──────────────────────────────────────────── */
.svt-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: var(--svt-primary);
    border-bottom: 2px solid rgba(255,214,0,.15);
    transition: box-shadow var(--svt-t);
}
.svt-header.svt-scrolled { box-shadow: 0 4px 24px rgba(0,0,0,.35); }
.svt-header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    height: 72px;
}

/* Logo */
.svt-logo { display: flex; align-items: center; text-decoration: none; flex-shrink: 0; }

/* Universal logo image — no filter applied, displays naturally at any size.
   Height is controlled by --svt-logo-height (set from ACF Global Settings). */
.svt-logo-img {
    display: block;
    max-height: var(--svt-logo-height, 58px);
    width: auto;
    height: auto;
    object-fit: contain;
    object-position: left center;
}

/* Footer logo — slightly smaller */
.svt-footer-logo-img {
    display: block;
    max-height: var(--svt-logo-footer-height, 44px);
    width: auto;
    height: auto;
    object-fit: contain;
}

/* Fallback: if someone still uses the_custom_logo() elsewhere */
.svt-logo .custom-logo-link { display: flex; align-items: center; }
.svt-logo .custom-logo-link img,
.svt-logo .custom-logo {
    display: block;
    max-height: var(--svt-logo-height, 58px);
    width: auto;
    height: auto;
    object-fit: contain;
}
.svt-logo-text {
    font-family: var(--svt-font-heading);
    font-size: 20px;
    font-weight: 800;
    color: var(--svt-white);
    letter-spacing: -.02em;
}
.svt-logo-text span { color: var(--svt-accent); }

/* Desktop nav */
.svt-nav { display: flex; align-items: center; }
.svt-nav-list { display: flex; align-items: center; gap: 2px; }
.svt-nav-list li a {
    font-size: 14px;
    font-weight: 600;
    color: rgba(255,255,255,.82);
    padding: 8px 14px;
    border-radius: var(--svt-radius-sm);
    transition: color var(--svt-t), background var(--svt-t);
    white-space: nowrap;
    letter-spacing: .01em;
}
.svt-nav-list li a:hover,
.svt-nav-list li.current-menu-item > a { color: var(--svt-accent); background: rgba(255,214,0,.08); }

/* Header actions */
.svt-header-actions { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }

/* Hamburger */
.svt-hamburger {
    display: none;
    flex-direction: column;
    gap: 5px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 6px;
}
.svt-hamburger span { display: block; width: 24px; height: 2.5px; background: var(--svt-white); border-radius: 2px; transition: all var(--svt-t); }
.svt-hamburger.svt-open span:nth-child(1) { transform: translateY(7.5px) rotate(45deg); }
.svt-hamburger.svt-open span:nth-child(2) { opacity: 0; }
.svt-hamburger.svt-open span:nth-child(3) { transform: translateY(-7.5px) rotate(-45deg); }

/* Mobile menu */
.svt-mobile-menu { display: none; background: var(--svt-primary-dk); max-height: 0; overflow: hidden; transition: max-height .3s ease; }
.svt-mobile-menu.svt-open { max-height: 600px; }
.svt-mobile-menu-inner { padding: 16px 24px 28px; display: flex; flex-direction: column; gap: 4px; }
.svt-mobile-nav-list li a {
    display: block; padding: 12px 14px; font-size: 16px; font-weight: 600;
    color: rgba(255,255,255,.85); border-radius: var(--svt-radius-sm);
    border-bottom: 1px solid rgba(255,255,255,.06); transition: color var(--svt-t), background var(--svt-t);
}
.svt-mobile-nav-list li a:hover { color: var(--svt-accent); background: rgba(255,214,0,.08); }
.svt-mobile-phone {
    padding: 12px 14px; color: rgba(255,255,255,.7); font-weight: 600; font-size: 15px;
    display: flex; align-items: center; gap: 8px; margin-top: 8px;
}

/* ── Hero ─────────────────────────────────────────────────── */
.svt-hero {
    position: relative;
    min-height: 90vh;
    display: flex;
    align-items: center;
    overflow: hidden;
    background: var(--svt-primary);
}
.svt-hero-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    background-image: linear-gradient(135deg, var(--svt-primary) 0%, var(--svt-primary-dk) 100%);
    transform: scale(1.02);
    transition: transform 6s ease;
}
.svt-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(13,31,45, calc(var(--hero-overlay,60) / 100));
}
/* Gold accent line at hero bottom */
.svt-hero::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 4px;
    background: var(--svt-accent);
}
.svt-hero-inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: center;
    padding: 80px 24px;
    max-width: var(--svt-container);
    margin: 0 auto;
    width: 100%;
}
.svt-hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(255,214,0,.18);
    border: 1px solid rgba(255,214,0,.4);
    color: var(--svt-accent);
    font-size: 12px;
    font-weight: 700;
    padding: 6px 14px;
    border-radius: 20px;
    margin-bottom: 20px;
    letter-spacing: .04em;
    text-transform: uppercase;
}
.svt-hero-headline {
    color: var(--svt-white);
    font-weight: 900;
    margin-bottom: 20px;
    line-height: 1.08;
    letter-spacing: -.03em;
    text-shadow: 0 2px 20px rgba(0,0,0,.2);
}
.svt-hero-headline em { font-style: normal; color: var(--svt-accent); }
.svt-hero-sub {
    font-size: 17px;
    color: rgba(255,255,255,.82);
    margin-bottom: 36px;
    line-height: 1.65;
}
.svt-hero-ctas { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 40px; }

/* Hero stats */
.svt-hero-stats {
    display: flex;
    gap: 32px;
    flex-wrap: wrap;
    border-top: 1px solid rgba(255,255,255,.12);
    padding-top: 28px;
}
.svt-hero-stat { display: flex; flex-direction: column; gap: 3px; }
.svt-hero-stat-num {
    font-family: var(--svt-font-heading);
    font-size: 26px;
    font-weight: 900;
    color: var(--svt-accent);
    line-height: 1;
}
.svt-hero-stat-lbl { font-size: 12px; color: rgba(255,255,255,.65); font-weight: 600; text-transform: uppercase; letter-spacing: .05em; }

/* Hero image panel */
.svt-hero-image-panel { position: relative; }
.svt-hero-image {
    width: 100%;
    aspect-ratio: 4/3;
    object-fit: cover;
    border-radius: var(--svt-radius-lg);
    box-shadow: 0 30px 60px rgba(0,0,0,.4);
    border: 3px solid rgba(255,214,0,.3);
}
.svt-hero-image-badge {
    position: absolute;
    bottom: -18px;
    left: 24px;
    background: var(--svt-white);
    border-radius: var(--svt-radius);
    padding: 14px 18px;
    box-shadow: var(--svt-shadow-lg);
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 200px;
}
.svt-hero-image-badge-icon { font-size: 28px; flex-shrink: 0; }
.svt-hero-image-badge-text { display: flex; flex-direction: column; }
.svt-hero-image-badge-label { font-size: 11px; color: var(--svt-muted); font-weight: 600; text-transform: uppercase; }
.svt-hero-image-badge-value { font-size: 15px; font-weight: 800; color: var(--svt-primary); }

/* ── Features dark section ────────────────────────────────── */
.svt-features-section {
    background: var(--svt-dark-bg);
    padding: 72px 0;
}
.svt-features-section .svt-section-title { color: var(--svt-white); }
.svt-features-section .svt-text-center { margin-bottom: 52px; }

.svt-features-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 28px;
}
.svt-feature-card {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
    padding: 28px 24px;
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: var(--svt-radius);
    transition: background var(--svt-t), border-color var(--svt-t), transform var(--svt-t);
}
.svt-feature-card:hover {
    background: rgba(255,214,0,.06);
    border-color: rgba(255,214,0,.25);
    transform: translateY(-3px);
}
.svt-feature-icon {
    width: 52px;
    height: 52px;
    background: rgba(255,214,0,.15);
    border-radius: var(--svt-radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    flex-shrink: 0;
    border: 1px solid rgba(255,214,0,.3);
}
.svt-feature-title { font-size: 16px; font-weight: 700; color: var(--svt-white); font-family: var(--svt-font-heading); line-height: 1.3; }
.svt-feature-desc  { font-size: 14px; color: rgba(255,255,255,.62); line-height: 1.65; }

/* ── Units section ────────────────────────────────────────── */
.svt-units-section { padding: 80px 0; }
.svt-section-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 24px;
    margin-bottom: 44px;
    flex-wrap: wrap;
}

/* ── 3-step process ───────────────────────────────────────── */
.svt-steps-section {
    background: var(--svt-primary);
    padding: 80px 0;
}
.svt-steps-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
    margin-top: 52px;
}
.svt-step-card {
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: var(--svt-radius-lg);
    padding: 32px 28px;
    position: relative;
    transition: background var(--svt-t), transform var(--svt-t);
}
.svt-step-card:hover { background: rgba(255,255,255,.10); transform: translateY(-3px); }
.svt-step-number {
    width: 52px;
    height: 52px;
    background: var(--svt-accent);
    color: var(--svt-primary-dk);
    font-family: var(--svt-font-heading);
    font-size: 22px;
    font-weight: 900;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
    flex-shrink: 0;
}
.svt-step-icon  { font-size: 32px; margin-bottom: 14px; display: block; }
.svt-step-title { font-size: 18px; font-weight: 700; color: var(--svt-white); font-family: var(--svt-font-heading); margin-bottom: 10px; }
.svt-step-desc  { font-size: 14px; color: rgba(255,255,255,.68); line-height: 1.65; }

/* Connector line between steps */
.svt-steps-grid .svt-step-card:not(:last-child)::after {
    content: '→';
    position: absolute;
    top: 38px;
    right: -24px;
    font-size: 24px;
    color: var(--svt-accent);
    z-index: 1;
}

/* ── About section ────────────────────────────────────────── */
.svt-about-inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: center;
}
.svt-about-img {
    border-radius: var(--svt-radius-lg);
    box-shadow: var(--svt-shadow-lg);
    width: 100%;
}
.svt-about-checklist {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin: 24px 0 32px;
}
.svt-about-checklist li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 15px;
    font-weight: 500;
    color: var(--svt-text);
}
.svt-about-checklist li::before {
    content: '✓';
    width: 22px;
    height: 22px;
    background: var(--svt-accent);
    color: var(--svt-primary-dk);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 900;
    flex-shrink: 0;
    margin-top: 1px;
}

/* ── Service area strip ───────────────────────────────────── */
.svt-service-area {
    background: var(--svt-light-bg);
    border-top: 1px solid var(--svt-border);
    border-bottom: 1px solid var(--svt-border);
    padding: 28px 0;
}
.svt-service-area-inner {
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
}
.svt-service-area-label { font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--svt-muted); flex-shrink: 0; }
.svt-service-area-cities { display: flex; gap: 10px; flex-wrap: wrap; }
.svt-city-chip {
    background: var(--svt-white);
    border: 1.5px solid var(--svt-border);
    border-radius: 20px;
    padding: 4px 14px;
    font-size: 13px;
    font-weight: 600;
    color: var(--svt-primary);
    transition: border-color var(--svt-t), background var(--svt-t);
}
.svt-city-chip:hover { border-color: var(--svt-accent); background: var(--svt-accent-lt); }

/* ── CTA Banner ───────────────────────────────────────────── */
.svt-cta-banner {
    background: var(--svt-accent);
    padding: 72px 0;
    position: relative;
    overflow: hidden;
}
.svt-cta-banner::before {
    content: '';
    position: absolute;
    inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23132f4c' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
    opacity: .5;
}
.svt-cta-banner-inner {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 40px;
    flex-wrap: wrap;
}
.svt-cta-banner-headline {
    font-size: clamp(1.6rem, 3vw, 2.4rem);
    font-weight: 900;
    color: var(--svt-primary);
    margin-bottom: 10px;
    letter-spacing: -.02em;
}
.svt-cta-banner-sub  { color: rgba(19,47,76,.75); font-size: 16px; margin: 0; }
.svt-cta-banner-actions { display: flex; gap: 14px; flex-wrap: wrap; flex-shrink: 0; }

/* Pre-footer CTA (inner pages) */
.svt-pre-footer-cta { background: var(--svt-accent); padding: 52px 0; }
.svt-pre-footer-cta-inner {
    display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap;
}
.svt-pre-footer-cta h3 { font-size: 24px; color: var(--svt-primary-dk); margin-bottom: 6px; }
.svt-pre-footer-cta p  { color: rgba(19,47,76,.7); margin: 0; font-size: 15px; }

/* ── Footer ───────────────────────────────────────────────── */
.svt-footer { background: var(--svt-primary-dk); color: rgba(255,255,255,.7); padding: 64px 0 0; }
.svt-footer-grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
    gap: 44px;
    padding-bottom: 56px;
    border-bottom: 1px solid rgba(255,255,255,.08);
}
.svt-footer-logo        { display: inline-flex; margin-bottom: 14px; }
.svt-footer-logo img                   { max-height: var(--svt-logo-footer-height, 44px); width: auto; display: block; }
.svt-footer-logo img.svt-footer-logo-img--filter { filter: brightness(0) invert(1); }
.svt-footer-logo-text   { font-family: var(--svt-font-heading); font-size: 20px; font-weight: 900; color: var(--svt-white); }
.svt-footer-logo-text span { color: var(--svt-accent); }
.svt-footer-tagline     { font-size: 14px; color: rgba(255,255,255,.5); margin-bottom: 22px; line-height: 1.6; }
.svt-footer-social      { display: flex; gap: 10px; }
.svt-footer-social-link {
    width: 36px; height: 36px; border-radius: 50%;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.12);
    display: flex; align-items: center; justify-content: center;
    color: rgba(255,255,255,.65); transition: background var(--svt-t), color var(--svt-t), border-color var(--svt-t);
}
.svt-footer-social-link:hover { background: var(--svt-accent); color: var(--svt-primary-dk); border-color: var(--svt-accent); }
.svt-footer-heading {
    font-size: 11px; font-weight: 800; text-transform: uppercase;
    letter-spacing: .1em; color: rgba(255,255,255,.4); margin-bottom: 18px;
}
.svt-footer-links { display: flex; flex-direction: column; gap: 10px; }
.svt-footer-links a { font-size: 14px; color: rgba(255,255,255,.7); transition: color var(--svt-t); }
.svt-footer-links a:hover { color: var(--svt-accent); }
.svt-footer-contact { display: flex; flex-direction: column; gap: 12px; }
.svt-footer-contact li {
    display: flex; align-items: flex-start; gap: 10px; font-size: 14px; color: rgba(255,255,255,.7);
}
.svt-footer-contact a { color: rgba(255,255,255,.7); }
.svt-footer-contact a:hover { color: var(--svt-accent); }
.svt-footer-contact-icon { font-size: 15px; flex-shrink: 0; margin-top: 1px; }
.svt-footer-hours { font-size: 14px; color: rgba(255,255,255,.65); line-height: 1.9; margin-bottom: 14px; }
.svt-footer-directions {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 13px; font-weight: 700; color: var(--svt-accent);
}
.svt-footer-directions:hover { color: var(--svt-white); }
.svt-footer-bottom {
    padding: 20px 0;
    border-top: 1px solid rgba(255,255,255,.1);
    display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px;
    margin-top: 48px;
}
.svt-footer-copyright { font-size: 13px; color: rgba(255,255,255,.4); margin: 0; }
.svt-footer-legal     { display: flex; align-items: center; gap: 24px; }
.svt-footer-legal a   { font-size: 13px; font-weight: 600; color: rgba(255,255,255,.7); transition: color var(--svt-t); }
.svt-footer-legal a:hover { color: var(--svt-accent); }
.svt-footer-contact-icon svg { display: block; }

/* ── Page hero (inner pages) ──────────────────────────────── */
.svt-page-hero {
    background: var(--svt-primary);
    padding: 56px 0;
    color: var(--svt-white);
    border-bottom: 3px solid var(--svt-accent);
}
.svt-page-hero-inner { max-width: var(--svt-container); }
.svt-page-hero h1 { color: var(--svt-white); margin-bottom: 10px; font-size: clamp(1.8rem, 4vw, 2.8rem); }
.svt-page-hero p  { color: rgba(255,255,255,.75); font-size: 17px; margin: 0; }
.svt-breadcrumb {
    display: flex; align-items: center; gap: 8px; font-size: 13px;
    color: rgba(255,255,255,.55); margin-bottom: 16px; flex-wrap: wrap;
}
.svt-breadcrumb a { color: rgba(255,255,255,.65); }
.svt-breadcrumb a:hover { color: var(--svt-accent); }

/* ── FAQ (dark accordion) ─────────────────────────────────── */
.svt-faq-list { display: flex; flex-direction: column; gap: 6px; }
.svt-faq-item {
    background: var(--svt-primary);
    border-radius: var(--svt-radius);
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.08);
}
.svt-faq-question {
    width: 100%; display: flex; align-items: center; justify-content: space-between;
    padding: 18px 22px; background: none; border: none; cursor: pointer;
    font-family: var(--svt-font-heading); font-size: 15px; font-weight: 700;
    color: var(--svt-white); text-align: left; gap: 16px; transition: background var(--svt-t);
}
.svt-faq-question:hover { background: rgba(255,255,255,.05); }
.svt-faq-item.svt-open .svt-faq-question { color: var(--svt-accent); background: rgba(255,214,0,.06); }
.svt-faq-icon { font-size: 20px; flex-shrink: 0; color: var(--svt-accent); transition: transform var(--svt-t); }
.svt-faq-item.svt-open .svt-faq-icon { transform: rotate(45deg); }
.svt-faq-answer {
    padding: 0 22px; max-height: 0; overflow: hidden;
    transition: max-height .3s ease, padding .3s ease;
    font-size: 14px; color: rgba(255,255,255,.72); line-height: 1.75;
}
.svt-faq-item.svt-open .svt-faq-answer { max-height: 400px; padding: 0 22px 20px; }

/* ── Location tabs ────────────────────────────────────────── */
.svt-loc-tabs {
    display: flex;
    gap: 0;
    border: 1.5px solid var(--svt-border);
    border-radius: var(--svt-radius);
    overflow: hidden;
    margin-bottom: 36px;
    background: var(--svt-white);
}
.svt-loc-tab-btn {
    flex: 1;
    padding: 14px 20px;
    background: none;
    border: none;
    border-right: 1.5px solid var(--svt-border);
    cursor: pointer;
    font-family: var(--svt-font-heading);
    font-size: 14px;
    font-weight: 700;
    color: var(--svt-muted);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    transition: background var(--svt-t), color var(--svt-t);
    letter-spacing: .01em;
}
.svt-loc-tab-btn:last-child { border-right: none; }
.svt-loc-tab-btn:hover { background: var(--svt-light-bg); color: var(--svt-primary); }
.svt-loc-tab-btn.svt-tab-active {
    background: var(--svt-primary);
    color: var(--svt-accent);
}
.svt-loc-tab-panel { display: none; }
.svt-loc-tab-panel.svt-tab-visible { display: block; animation: svt-fadein .2s ease; }
@keyframes svt-fadein { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

/* ── Unit feature grid ────────────────────────────────────── */
.svt-unit-features-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.svt-unit-feature-card {
    background: var(--svt-light-bg);
    border: 1px solid var(--svt-border);
    border-radius: var(--svt-radius);
    padding: 24px 22px;
}
.svt-unit-feature-card h4 {
    font-size: 15px;
    font-weight: 800;
    color: var(--svt-primary);
    margin-bottom: 14px;
    padding-bottom: 10px;
    border-bottom: 2px solid var(--svt-accent);
    display: inline-block;
}
.svt-unit-feature-list { display: flex; flex-direction: column; gap: 8px; }
.svt-unit-feature-list li {
    display: flex; align-items: center; gap: 10px;
    font-size: 14px; color: var(--svt-text);
}
.svt-unit-feature-list li::before {
    content: '';
    width: 18px; height: 18px; border-radius: 50%;
    background: var(--svt-primary-lt);
    border: 2px solid var(--svt-secondary);
    flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
}

/* ── Location info card ───────────────────────────────────── */
.svt-loc-info-card {
    background: var(--svt-white);
    border: 1px solid var(--svt-border);
    border-radius: var(--svt-radius-lg);
    overflow: hidden;
    box-shadow: var(--svt-shadow);
}
.svt-loc-info-header {
    background: var(--svt-primary);
    padding: 22px 24px;
    display: flex; align-items: center; justify-content: space-between; gap: 12px;
}
.svt-loc-info-header h3 { color: var(--svt-white); font-size: 18px; margin: 0; }
.svt-loc-info-badge {
    background: #22c55e; color: #fff;
    font-size: 11px; font-weight: 700;
    padding: 3px 10px; border-radius: 20px;
}
.svt-loc-info-body { padding: 4px 0; }
.svt-loc-info-row {
    display: flex; gap: 14px; align-items: flex-start;
    padding: 14px 22px; border-bottom: 1px solid var(--svt-border); font-size: 14px;
}
.svt-loc-info-row:last-child { border-bottom: none; }
.svt-loc-info-icon { font-size: 18px; flex-shrink: 0; margin-top: 2px; }
.svt-loc-info-row strong {
    display: block; font-size: 10px; font-weight: 700;
    text-transform: uppercase; letter-spacing: .06em; color: #9ca3af; margin-bottom: 3px;
}
.svt-loc-info-row span { color: var(--svt-text); line-height: 1.5; }
.svt-loc-info-row a { color: var(--svt-text); }
.svt-loc-info-row a:hover { color: var(--svt-accent); }
.svt-loc-dir-link {
    display: inline-flex; align-items: center; gap: 4px;
    font-size: 12px; font-weight: 700; color: var(--svt-secondary) !important; margin-top: 5px;
}
.svt-loc-info-ctas {
    display: flex; gap: 10px; padding: 16px 22px;
    border-top: 1px solid var(--svt-border); background: var(--svt-light-bg);
}

/* Amenity tags */
.svt-loc-amenities { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
.svt-amenity-tag {
    background: var(--svt-primary-lt); color: var(--svt-primary);
    font-size: 12px; font-weight: 600; padding: 5px 12px; border-radius: 20px;
}

/* ── Location finder ──────────────────────────────────────── */
.svt-finder-layout { display: grid; grid-template-columns: 420px 1fr; gap: 32px; align-items: start; }
.svt-finder-cards {
    display: flex; flex-direction: column; gap: 16px;
    max-height: 680px; overflow-y: auto; padding-right: 8px;
    scrollbar-width: thin;
}
.svt-finder-cards::-webkit-scrollbar { width: 4px; }
.svt-finder-cards::-webkit-scrollbar-thumb { background: var(--svt-border); border-radius: 3px; }
.svt-loc-card {
    background: var(--svt-white); border: 1px solid rgba(0,0,0,.06);
    border-radius: 14px; overflow: hidden;
    box-shadow: 0 4px 14px rgba(0,0,0,.07);
    cursor: pointer; transition: transform var(--svt-t), box-shadow var(--svt-t);
    border-top: 3px solid var(--svt-accent);
}
.svt-loc-card:hover { transform: translateY(-4px); box-shadow: 0 12px 28px rgba(0,0,0,.12); }
.svt-loc-card-img-wrap { overflow: hidden; height: 130px; }
.svt-loc-card-img { width: 100%; height: 130px; object-fit: cover; transition: transform .4s ease; }
.svt-loc-card:hover .svt-loc-card-img { transform: scale(1.05); }
.svt-loc-card-img-placeholder { height: 90px; display: flex; align-items: center; justify-content: center; font-size: 40px; background: var(--svt-light-bg); }
.svt-loc-card-body { padding: 14px 16px; }
.svt-loc-card-name { font-size: 15px; font-weight: 700; color: var(--svt-text); margin-bottom: 6px; }
.svt-loc-card-address,
.svt-loc-card-phone { font-size: 12px; color: var(--svt-muted); margin-bottom: 4px; display: flex; align-items: center; gap: 5px; }
.svt-loc-card-avail { display: flex; align-items: center; gap: 8px; margin: 10px 0; flex-wrap: wrap; }
.svt-loc-avail-badge { font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 20px; }
.svt-avail-yes { background: #d1fae5; color: #065f46; }
.svt-avail-no  { background: #f3f4f6; color: var(--svt-muted); }
.svt-loc-total { font-size: 11px; color: #9ca3af; }
.svt-loc-card-btn { font-size: 12px; padding: 7px 14px; width: 100%; justify-content: center; margin-top: 4px; }
.svt-finder-map {
    position: sticky; top: 90px;
    border-radius: var(--svt-radius-lg); overflow: hidden;
    min-height: 500px; box-shadow: var(--svt-shadow);
    background: var(--svt-light-bg);
}
.svt-map-placeholder {
    display: flex; align-items: center; justify-content: center;
    background: var(--svt-light-bg); border-radius: var(--svt-radius-lg);
    border: 1px dashed var(--svt-border); min-height: 300px;
}
.svt-map-placeholder-inner { text-align: center; padding: 24px; }

/* ── Nearby locations row ─────────────────────────────────── */
.svt-nearby-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 20px; }
.svt-nearby-card {
    background: var(--svt-white); border: 1px solid var(--svt-border);
    border-radius: var(--svt-radius-lg); padding: 20px;
    box-shadow: var(--svt-shadow-sm); transition: box-shadow var(--svt-t), transform var(--svt-t);
}
.svt-nearby-card:hover { box-shadow: var(--svt-shadow); transform: translateY(-2px); }
.svt-nearby-card h4 { font-size: 15px; margin-bottom: 6px; }
.svt-nearby-card p  { font-size: 13px; color: var(--svt-muted); margin-bottom: 4px; }
.svt-nearby-price   { font-size: 14px; font-weight: 700; color: var(--svt-primary); margin-bottom: 14px; }

/* ── Notices ──────────────────────────────────────────────── */
.svt-notice { padding: 13px 18px; border-radius: var(--svt-radius-sm); font-size: 14px; font-weight: 500; border: 1px solid transparent; margin: 20px 0; }
.svt-notice-success { background: #d1fae5; color: #065f46; border-color: #6ee7b7; }
.svt-notice-error   { background: #fee2e2; color: #991b1b; border-color: #fca5a5; }
.svt-notice-info    { background: var(--svt-primary-lt); color: var(--svt-primary); border-color: #93c5fd; }

/* ── Forms (contact) ──────────────────────────────────────── */
.svt-form-row   { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.svt-form-group { display: flex; flex-direction: column; gap: 5px; margin-bottom: 18px; }
.svt-form-group label { font-size: 13px; font-weight: 600; color: var(--svt-text); }
.svt-form-group input,
.svt-form-group select,
.svt-form-group textarea {
    width: 100%; padding: 11px 14px;
    border: 1.5px solid var(--svt-border);
    border-radius: var(--svt-radius-sm);
    font-size: 15px; font-family: var(--svt-font-body);
    color: var(--svt-text); background: var(--svt-white);
    outline: none; transition: border-color var(--svt-t), box-shadow var(--svt-t);
}
.svt-form-group input:focus,
.svt-form-group select:focus,
.svt-form-group textarea:focus { border-color: var(--svt-primary); box-shadow: 0 0 0 3px rgba(19,47,76,.12); }
.svt-form-group textarea { resize: vertical; min-height: 120px; }

/* ── Contact page ─────────────────────────────────────────── */
.svt-contact-layout { display: grid; grid-template-columns: 1fr 1.2fr; gap: 60px; align-items: start; }
.svt-contact-info-card {
    background: var(--svt-white); border: 1px solid var(--svt-border);
    border-radius: var(--svt-radius-lg); padding: 32px; box-shadow: var(--svt-shadow-sm);
}
.svt-contact-info-item { display: flex; gap: 16px; align-items: flex-start; padding: 18px 0; border-bottom: 1px solid var(--svt-border); }
.svt-contact-info-item:last-child { border-bottom: none; }
.svt-contact-info-icon { width: 44px; height: 44px; border-radius: 50%; background: var(--svt-accent-lt); border: 2px solid var(--svt-accent); display: flex; align-items: center; justify-content: center; font-size: 20px; flex-shrink: 0; }
.svt-contact-info-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: #9ca3af; margin-bottom: 4px; }
.svt-contact-info-value { font-size: 15px; font-weight: 600; color: var(--svt-text); }
.svt-contact-info-value a { color: var(--svt-text); }
.svt-contact-info-value a:hover { color: var(--svt-accent); }
.svt-contact-form-card { background: var(--svt-white); border: 1px solid var(--svt-border); border-radius: var(--svt-radius-lg); padding: 36px; box-shadow: var(--svt-shadow-sm); }
.svt-map-wrap iframe { border: none; border-radius: var(--svt-radius-lg); }

/* ── About page ───────────────────────────────────────────── */
.svt-about-page-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }

/* ── Size guide + unit listing ────────────────────────────── */
.svt-sizes-intro { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; margin-bottom: 60px; }
.svt-size-tip { background: var(--svt-accent-lt); border-left: 4px solid var(--svt-accent); border-radius: 0 var(--svt-radius-sm) var(--svt-radius-sm) 0; padding: 14px 18px; font-size: 14px; color: var(--svt-primary); margin-top: 20px; }

/* ── StorVault listing override ───────────────────────────── */
/* Make the plugin's unit cards match the theme's gold accent */
.sv-lc-btn-rent,
.sv-btn-primary { background: var(--svt-accent) !important; color: var(--svt-primary-dk) !important; border-color: var(--svt-accent) !important; font-family: var(--svt-font-heading) !important; font-weight: 700 !important; }
.sv-lc-btn-rent:hover,
.sv-btn-primary:hover { background: var(--svt-accent-dk) !important; border-color: var(--svt-accent-dk) !important; color: var(--svt-primary-dk) !important; }
.sv-unit-card::before { background: var(--svt-accent) !important; }
.sv-avail-pill.sv-avail-yes { background: #d1fae5 !important; color: #065f46 !important; }

/* ── Responsive grid column classes ──────────────────────────
   Replaces all inline style="grid-template-columns:..." so
   media queries can override without !important fights.
──────────────────────────────────────────────────────────── */

/* Features grid column counts */
.svt-features-grid.svt-grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
.svt-features-grid.svt-grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
.svt-features-grid.svt-grid-cols-4 { grid-template-columns: repeat(4, 1fr); }
.svt-features-grid.svt-grid-cols-6 { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }

/* Gallery column counts (desktop — duplicates removed, defined near .svt-gallery-grid above) */

/* Location page grids */
.svt-loc-hero-grid {
    display: grid;
    grid-template-columns: 1fr 400px;
    min-height: 340px;
}
.svt-loc-detail-grid {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 40px;
    align-items: start;
}

/* ── 1280px ── */
@media (max-width: 1280px) {
    .svt-loc-hero-grid   { grid-template-columns: 1fr 340px; }
    .svt-loc-detail-grid { grid-template-columns: 1fr 320px; }
    .svt-features-grid.svt-grid-cols-6 { grid-template-columns: repeat(3, 1fr); }
}

/* ── 1024px ── */
@media (max-width: 1024px) {
    .svt-features-grid.svt-grid-cols-3,
    .svt-features-grid.svt-grid-cols-4 { grid-template-columns: repeat(2, 1fr); }
    .svt-features-grid.svt-grid-cols-6 { grid-template-columns: repeat(3, 1fr); }
    .svt-gallery-cols-3,
    .svt-gallery-cols-4               { grid-template-columns: repeat(2, 1fr); }
    .svt-loc-hero-grid                 { grid-template-columns: 1fr; min-height: auto; }
    .svt-loc-detail-grid               { grid-template-columns: 1fr; gap: 24px; }
}

/* ── 768px ── */
@media (max-width: 768px) {
    .svt-features-grid.svt-grid-cols-2,
    .svt-features-grid.svt-grid-cols-3,
    .svt-features-grid.svt-grid-cols-4 { grid-template-columns: repeat(2, 1fr); }
    .svt-features-grid.svt-grid-cols-6 { grid-template-columns: repeat(2, 1fr); }
    .svt-gallery-cols-2,
    .svt-gallery-cols-3,
    .svt-gallery-cols-4               { grid-template-columns: repeat(2, 1fr); }
}

/* ── 480px ── */
@media (max-width: 480px) {
    .svt-features-grid.svt-grid-cols-2,
    .svt-features-grid.svt-grid-cols-3,
    .svt-features-grid.svt-grid-cols-4,
    .svt-features-grid.svt-grid-cols-6 { grid-template-columns: 1fr; }
    .svt-gallery-cols-2,
    .svt-gallery-cols-3,
    .svt-gallery-cols-4                { grid-template-columns: 1fr; }
}

/* ── Finder / location cards (plugin-specific) ────────────── */
@media (max-width: 1100px) {
    .svt-finder-layout { grid-template-columns: 340px 1fr; }
}
@media (max-width: 1024px) {
    .svt-footer-grid       { grid-template-columns: 1fr 1fr; }
    .svt-sizes-intro       { grid-template-columns: 1fr; }
    .svt-hero-inner        { grid-template-columns: 1fr; }
    .svt-finder-layout     { grid-template-columns: 1fr; }
    .svt-finder-cards      { max-height: none; flex-direction: row; overflow-x: auto; flex-wrap: nowrap; }
    .svt-loc-card          { min-width: 280px; }
    .svt-finder-map        { position: static; min-height: 360px; }
    .svt-unit-features-grid{ grid-template-columns: 1fr; }
}

/* ── Hero info panel (shown when no image uploaded) ───────── */
.svt-hero-panel { display: flex; flex-direction: column; gap: 16px; }

.svt-hero-panel-card {
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.15);
    border-radius: 14px;
    padding: 24px;
    border-top: 3px solid var(--svt-accent);
}
.svt-hero-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 18px;
    padding-bottom: 16px;
    border-bottom: 1px solid rgba(255,255,255,.1);
    flex-wrap: wrap;
}
.svt-hero-panel-title {
    display: flex;
    align-items: center;
    gap: 10px;
}
.svt-hero-panel-icon { font-size: 24px; flex-shrink: 0; }
.svt-hero-panel-title strong {
    display: block;
    font-family: var(--svt-font-heading);
    font-size: 15px;
    font-weight: 800;
    color: var(--svt-white);
}
.svt-hero-panel-title span { font-size: 12px; color: rgba(255,255,255,.6); }
.svt-hero-panel-open {
    background: #22c55e;
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    padding: 3px 10px;
    border-radius: 20px;
    white-space: nowrap;
    flex-shrink: 0;
}
.svt-hero-panel-list {
    display: flex;
    flex-direction: column;
    gap: 9px;
    margin-bottom: 18px;
}
.svt-hero-panel-list li {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    color: rgba(255,255,255,.82);
}
.svt-hero-panel-list li span {
    color: var(--svt-accent);
    font-weight: 900;
    font-size: 13px;
    flex-shrink: 0;
    width: 16px;
}
.svt-hero-panel-phone {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
    font-weight: 700;
    color: var(--svt-accent);
    text-decoration: none;
    padding: 9px 16px;
    background: rgba(255,214,0,.12);
    border: 1px solid rgba(255,214,0,.3);
    border-radius: var(--svt-radius-sm);
    transition: background var(--svt-t);
}
.svt-hero-panel-phone:hover { background: rgba(255,214,0,.2); color: var(--svt-accent); }

.svt-hero-panel-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}
.svt-hero-panel-stat {
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: var(--svt-radius);
    padding: 16px 12px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 5px;
}
.svt-hero-panel-stat-num {
    font-family: var(--svt-font-heading);
    font-size: 20px;
    font-weight: 900;
    color: var(--svt-accent);
    line-height: 1;
}
.svt-hero-panel-stat-lbl {
    font-size: 11px;
    color: rgba(255,255,255,.55);
    text-align: center;
    line-height: 1.3;
    white-space: pre-line;
}

/* ── Customer Reviews ─────────────────────────────────────── */
.svt-reviews-section { background: var(--svt-white); }

.svt-reviews-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
.svt-review-card {
    background: var(--svt-white);
    border: 1px solid var(--svt-border);
    border-radius: var(--svt-radius-lg);
    padding: 28px 24px;
    box-shadow: var(--svt-shadow-sm);
    transition: box-shadow var(--svt-t), transform var(--svt-t);
    display: flex;
    flex-direction: column;
    border-top: 3px solid var(--svt-accent);
}
.svt-review-card:hover { box-shadow: var(--svt-shadow); transform: translateY(-3px); }

.svt-review-stars {
    color: var(--svt-accent);
    font-size: 16px;
    letter-spacing: 2px;
    margin-bottom: 14px;
}
.svt-review-text {
    font-size: 15px;
    color: #4b5563;
    line-height: 1.75;
    margin-bottom: 20px;
    font-style: italic;
    flex: 1;
}
.svt-review-author {
    display: flex;
    align-items: center;
    gap: 12px;
    padding-top: 16px;
    border-top: 1px solid var(--svt-border);
}
.svt-review-avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--svt-primary-lt);
    border: 2px solid var(--svt-border);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    flex-shrink: 0;
}
.svt-review-name { font-weight: 700; font-size: 14px; color: var(--svt-text); margin-bottom: 2px; }
.svt-review-location { font-size: 12px; color: var(--svt-muted); }

/* ── Storage types grid ───────────────────────────────────── */
.svt-types-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 24px;
}
.svt-type-card {
    background: var(--svt-white);
    border: 1px solid var(--svt-border);
    border-radius: var(--svt-radius-lg);
    padding: 28px 24px;
    transition: transform var(--svt-t), box-shadow var(--svt-t);
}
.svt-type-card:hover { transform: translateY(-4px); box-shadow: var(--svt-shadow); }
.svt-type-card-icon {
    width: 56px;
    height: 56px;
    background: rgba(255,214,0,.12);
    border: 1.5px solid rgba(255,214,0,.35);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    margin-bottom: 16px;
}
.svt-type-card-title { font-size: 17px; font-weight: 700; color: var(--svt-primary); margin-bottom: 10px; }
.svt-type-card-desc  { font-size: 14px; color: #6b7280; margin-bottom: 18px; line-height: 1.65; }
.svt-type-card-link  {
    font-size: 14px;
    font-weight: 700;
    color: var(--svt-primary);
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: gap var(--svt-t), color var(--svt-t);
    text-decoration: none;
}
.svt-type-card:hover .svt-type-card-link { gap: 12px; color: var(--svt-accent); }

/* ── Location section ─────────────────────────────────────── */
.svt-location-section { padding: 80px 0; }
.svt-location-inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: center;
}
.svt-location-desc {
    color: rgba(255,255,255,.7);
    font-size: 16px;
    margin: 0 0 28px;
    line-height: 1.7;
}
.svt-location-details { display: flex; flex-direction: column; }
.svt-location-row {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 14px 0;
    border-bottom: 1px solid rgba(255,255,255,.08);
    font-size: 14px;
}
.svt-location-row:last-child { border-bottom: none; }
.svt-location-icon { font-size: 18px; flex-shrink: 0; margin-top: 2px; }
.svt-location-row strong {
    display: block;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: rgba(255,255,255,.4);
    margin-bottom: 4px;
}
.svt-location-row span,
.svt-location-row a  { color: rgba(255,255,255,.82); line-height: 1.5; }
.svt-location-row a:hover { color: var(--svt-accent); }

.svt-location-map iframe {
    width: 100%;
    border: 0;
    border-radius: var(--svt-radius-lg);
    display: block;
}
.svt-location-map-placeholder {
    min-height: 380px;
    border: 1px dashed rgba(255,255,255,.15);
    border-radius: var(--svt-radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 40px;
    background: rgba(255,255,255,.03);
}
.svt-location-inner--no-map { grid-template-columns: 1fr; max-width: 720px; }
.svt-location-map-link-block { display: block; text-decoration: none; }
.svt-location-map-placeholder--link {
    cursor: pointer;
    transition: background .2s;
    border-color: rgba(255,255,255,.25);
}
.svt-location-map-placeholder--link:hover { background: rgba(255,255,255,.08); }

/* ── Icon field rendering (emoji / Font Awesome / SVG) ───── */
.svt-feature-icon i,
.svt-step-icon i,
.svt-type-card-icon i {
    font-size: 1em;
    line-height: 1;
    display: block;
}
/* SVG upload inside icon wrapper */
.svt-icon-svg {
    width:  100%;
    height: 100%;
    object-fit: contain;
    display: block;
}
/* FA icon colour inherits accent in dark sections */
.svt-features-section .svt-feature-icon i { color: var(--svt-accent); }
.svt-steps-section    .svt-step-icon i    { color: var(--svt-accent); }
.svt-type-card-icon   i                   { color: var(--svt-primary); }

/* ── Stats Bar ────────────────────────────────────────────── */
.svt-stats-bar { padding: 36px 0; }
.svt-stats-bar-inner {
    display: flex;
    align-items: center;
    justify-content: space-around;
    gap: 24px;
    flex-wrap: wrap;
}
.svt-stats-bar-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 5px;
    text-align: center;
}
.svt-stats-bar-num {
    font-family: var(--svt-font-heading);
    font-size: 2.4rem;
    font-weight: 900;
    line-height: 1;
}
.svt-stats-bar-lbl {
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
}

/* ── Image Gallery ────────────────────────────────────────── */
.svt-gallery-header { margin-bottom: 40px; }

/* Desktop grid */
.svt-gallery-grid {
    display: grid;
    gap: 14px;
}
.svt-gallery-cols-2 { grid-template-columns: repeat(2, 1fr); }
.svt-gallery-cols-3 { grid-template-columns: repeat(3, 1fr); }
.svt-gallery-cols-4 { grid-template-columns: repeat(4, 1fr); }
.svt-gallery-cols-5 { grid-template-columns: repeat(5, 1fr); }

.svt-gallery-item {
    display: block;
    border-radius: 10px;
    overflow: hidden;
    aspect-ratio: 4/3;
    position: relative;
    text-decoration: none;
}
.svt-gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .4s ease;
    display: block;
}
.svt-gallery-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.35);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity .25s;
    font-size: 28px;
}
.svt-gallery-item:hover img            { transform: scale(1.05); }
.svt-gallery-item:hover .svt-gallery-overlay { opacity: 1; }

/* Mobile slider — hidden on desktop */
.svt-gallery-slider { display: none; }

/* ── Gallery slider (mobile only) ────────────────────────── */
@media (max-width: 767px) {
    .svt-gallery-grid   { display: none; }   /* hide desktop grid */
    .svt-gallery-slider { display: block; position: relative; }

    .svt-gallery-slider-track {
        display: flex;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        gap: 12px;
        padding-bottom: 4px;
    }
    .svt-gallery-slider-track::-webkit-scrollbar { display: none; }

    .svt-gallery-slide {
        flex: 0 0 100%;
        scroll-snap-align: start;
        border-radius: 10px;
        overflow: hidden;
        aspect-ratio: 4/3;
    }
    .svt-gallery-slide img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        display: block;
    }

    /* Prev / Next arrows */
    .svt-gallery-btn {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        background: rgba(0,0,0,.55);
        color: #fff;
        border: none;
        border-radius: 50%;
        width: 38px;
        height: 38px;
        font-size: 18px;
        line-height: 1;
        cursor: pointer;
        display: flex;
        align-items: center;
        justify-content: center;
        z-index: 2;
        transition: background .2s;
    }
    .svt-gallery-btn:hover { background: rgba(0,0,0,.8); }
    .svt-gallery-prev { left: 8px; }
    .svt-gallery-next { right: 8px; }

    /* Dots */
    .svt-gallery-dots {
        display: flex;
        justify-content: center;
        gap: 6px;
        margin-top: 14px;
    }
    .svt-gallery-dot {
        width: 8px;
        height: 8px;
        border-radius: 50%;
        background: rgba(0,0,0,.2);
        border: none;
        padding: 0;
        cursor: pointer;
        transition: background .2s, transform .2s;
    }
    .svt-gallery-dot.active {
        background: var(--svt-primary);
        transform: scale(1.3);
    }
}

/* ── Size Guide ──────────────────────────────────────────── */
.svt-size-guide-header { margin-bottom: 44px; }

.svt-sg-grid {
    display: grid;
    gap: 24px;
}
.svt-sg-cols-1 { grid-template-columns: 1fr; max-width: 720px; margin: 0 auto; }
.svt-sg-cols-2 { grid-template-columns: repeat(2, 1fr); }
.svt-sg-cols-3 { grid-template-columns: repeat(3, 1fr); }
.svt-sg-cols-4 { grid-template-columns: repeat(4, 1fr); }

/* Card */
.svt-sg-card {
    background: #fff;
    border: 1.5px solid var(--svt-border);
    border-left: 4px solid var(--svt-primary);
    border-radius: 12px;
    padding: 22px 22px 18px;
    display: flex;
    flex-direction: column;
    gap: 14px;
    box-shadow: 0 1px 4px rgba(0,0,0,.05);
    transition: box-shadow .2s, transform .2s;
}
.svt-sg-card:hover {
    box-shadow: 0 6px 20px rgba(0,0,0,.1);
    transform: translateY(-2px);
}

/* Card top row */
.svt-sg-card-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}
.svt-sg-card-meta { display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap; }

.svt-sg-name {
    font-family: var(--svt-font-heading);
    font-size: 20px;
    font-weight: 800;
    color: var(--svt-primary);
    margin: 0;
}
.svt-sg-size {
    font-size: 14px;
    color: #9ca3af;
}
.svt-sg-size s { text-decoration-thickness: 2px; }

.svt-sg-badge {
    flex-shrink: 0;
    font-size: 12px;
    font-weight: 600;
    color: var(--svt-secondary);
    background: rgba(30,90,141,.1);
    border: 1px solid rgba(30,90,141,.2);
    border-radius: 20px;
    padding: 3px 12px;
    white-space: nowrap;
}

/* Description */
.svt-sg-desc {
    font-size: 14px;
    color: #6b7280;
    line-height: 1.7;
    margin: 0;
}

/* Divider */
.svt-sg-divider {
    border: none;
    border-top: 1px solid var(--svt-border);
    margin: 0;
}

/* Bottom row */
.svt-sg-card-bottom {
    display: flex;
    align-items: flex-start;
    gap: 18px;
    flex-wrap: wrap;
}

.svt-sg-image {
    flex-shrink: 0;
    width: 72px;
    height: 72px;
    border-radius: 8px;
    overflow: hidden;
    background: #f3f4f6;
}
.svt-sg-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.svt-sg-fits { flex: 1; min-width: 0; }
.svt-sg-fits-label {
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #9ca3af;
    margin: 0 0 8px;
}
.svt-sg-fits-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.svt-sg-fits-list li {
    font-size: 14px;
    color: var(--svt-secondary);
    padding-left: 20px;
    position: relative;
}
.svt-sg-fits-list li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: var(--svt-secondary);
    font-weight: 700;
}

.svt-sg-btn-wrap { margin-left: auto; align-self: flex-end; }
.svt-sg-btn {
    white-space: nowrap;
    background: var(--svt-primary) !important;
    font-size: 14px !important;
    padding: 10px 20px !important;
}

/* Responsive */
@media (max-width: 1024px) {
    .svt-sg-cols-3, .svt-sg-cols-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
    .svt-sg-cols-2, .svt-sg-cols-3, .svt-sg-cols-4 { grid-template-columns: 1fr; }
    .svt-sg-btn-wrap { width: 100%; }
    .svt-sg-btn { width: 100%; text-align: center; justify-content: center; }
}

/* ── Content Columns ─────────────────────────────────────── */
.svt-content-columns-header { margin-bottom: 40px; }

.svt-content-columns-grid {
    display: grid;
    gap: 40px 48px;
}
.svt-cc-cols-2 { grid-template-columns: repeat(2, 1fr); }
.svt-cc-cols-3 { grid-template-columns: repeat(3, 1fr); }
.svt-cc-cols-4 { grid-template-columns: repeat(4, 1fr); }

.svt-content-column-heading {
    font-family: var(--svt-font-heading);
    font-size: 17px;
    font-weight: 700;
    color: var(--svt-text);
    margin-bottom: 12px;
    line-height: 1.4;
}
.svt-content-column-body { font-size: 15px; line-height: 1.8; color: var(--svt-muted); }
.svt-content-column-body p  { margin-bottom: 10px; }
.svt-content-column-body ul,
.svt-content-column-body ol { margin: 0 0 12px 20px; }
.svt-content-column-body li { margin-bottom: 5px; }
.svt-content-column-body a  { color: var(--svt-secondary); }
.svt-content-column-body a:hover { color: var(--svt-primary); }
.svt-content-column-body strong { font-weight: 700; color: var(--svt-text); }

/* Dark/navy background text overrides */
[data-svt-text="light"] .svt-content-column-heading { color: var(--svt-white); }
[data-svt-text="light"] .svt-content-column-body    { color: rgba(255,255,255,.75); }

@media (max-width: 1024px) {
    .svt-cc-cols-3, .svt-cc-cols-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
    .svt-cc-cols-2, .svt-cc-cols-3, .svt-cc-cols-4 { grid-template-columns: 1fr; gap: 28px; }
}

/* ── Text Block ───────────────────────────────────────────── */
.svt-text-block-content h1,
.svt-text-block-content h2,
.svt-text-block-content h3 { margin-bottom: 16px; }
.svt-text-block-content p  { color: var(--svt-muted); line-height: 1.8; }
.svt-text-block-content ul,
.svt-text-block-content ol { margin: 16px 0 16px 24px; color: var(--svt-muted); }
.svt-text-block-content a  { color: var(--svt-secondary); font-weight: 600; }

/* ── Service Areas Grid ───────────────────────────────────── */
.svt-areas-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 20px;
}
.svt-area-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-decoration: none;
    background: var(--svt-white);
    border: 1px solid var(--svt-border);
    border-radius: var(--svt-radius-lg);
    overflow: hidden;
    transition: transform var(--svt-t), box-shadow var(--svt-t);
}
.svt-area-card:hover { transform: translateY(-4px); box-shadow: var(--svt-shadow); }
.svt-area-card-img { width: 100%; height: 120px; overflow: hidden; }
.svt-area-card-img img { width: 100%; height: 100%; object-fit: cover; }
.svt-area-card-placeholder {
    width: 100%; height: 90px;
    display: flex; align-items: center; justify-content: center;
    font-size: 36px; background: var(--svt-light-bg);
}
.svt-area-card-name {
    font-size: 14px;
    font-weight: 700;
    color: var(--svt-primary);
    padding: 12px 16px;
    text-align: center;
}

/* ── Pricing Teaser ───────────────────────────────────────── */
.svt-pricing-teaser { padding: 36px 0; }
.svt-pricing-teaser-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
    flex-wrap: wrap;
}
.svt-pricing-teaser-row {
    display: flex;
    align-items: baseline;
    gap: 16px;
    flex-wrap: wrap;
    margin-top: 6px;
}
.svt-pricing-teaser-heading {
    font-family: var(--svt-font-heading);
    font-size: 1.5rem;
    font-weight: 800;
    line-height: 1.2;
}
.svt-pricing-teaser-price {
    font-family: var(--svt-font-heading);
    font-size: 3rem;
    font-weight: 900;
    line-height: 1;
}
.svt-pricing-teaser-mo { font-size: 1rem; font-weight: 600; }

/* ── Page content (fallback) ──────────────────────────────── */
.svt-page-content { max-width: 800px; }
.svt-page-content h1,
.svt-page-content h2,
.svt-page-content h3 { margin-bottom: 16px; margin-top: 32px; }
.svt-page-content p  { color: var(--svt-muted); line-height: 1.8; margin-bottom: 16px; }
.svt-page-content ul,
.svt-page-content ol { margin: 0 0 16px 24px; color: var(--svt-muted); }

/* ═══════════════════════════════════════════════════════════════════════════
   COMPREHENSIVE RESPONSIVE — All sections
   1280 · 1024 · 768 · 480 · 360
═══════════════════════════════════════════════════════════════════════════ */

/* ── FAQ layout classes (replaces inline styles) ────────────── */
.svt-faq-layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: 48px;
    align-items: start;
}
.svt-faq-has-sidebar { grid-template-columns: 1fr 300px; }
.svt-faq-sidebar { position: sticky; top: 100px; }

/* ── 1280px ─────────────────────────────────────────────────── */
@media (max-width: 1280px) {
    .svt-hero-inner       { gap: 40px; }
    .svt-faq-has-sidebar  { grid-template-columns: 1fr 260px; }
}

/* ── 1024px — Tablet landscape ──────────────────────────────── */
@media (max-width: 1024px) {
    /* Sections */
    .svt-section    { padding: 64px 0; }
    .svt-section-sm { padding: 44px 0; }

    /* Grids */
    .svt-reviews-grid         { grid-template-columns: 1fr 1fr; }
    .svt-location-inner       { grid-template-columns: 1fr; gap: 40px; }
    .svt-pricing-teaser-inner { flex-direction: column; text-align: center; gap: 24px; }
    .svt-about-inner          { grid-template-columns: 1fr; }
    .svt-types-grid           { grid-template-columns: repeat(2, 1fr); }
    .svt-areas-grid           { grid-template-columns: repeat(3, 1fr); }

    /* FAQ sidebar stacks below accordion */
    .svt-faq-has-sidebar { grid-template-columns: 1fr; }
    .svt-faq-sidebar     { position: static; margin-top: 32px; }

    /* Hero */
    .svt-hero-panel-stats { grid-template-columns: repeat(3, 1fr); }
}

/* ── 768px — Tablet portrait / large mobile ─────────────────── */
@media (max-width: 768px) {
    /* Global */
    .svt-container { padding: 0 16px; }
    .svt-section    { padding: 48px 0; }
    .svt-section-sm { padding: 32px 0; }

    /* Typography scale */
    h1 { font-size: clamp(1.8rem, 6vw, 2.8rem); }
    h2 { font-size: clamp(1.4rem, 5vw, 2.2rem); }
    h3 { font-size: clamp(1.1rem, 4vw, 1.4rem); }

    /* ── Header ── */
    .svt-topbar      { display: none; }
    .svt-nav         { display: none; }
    .svt-hamburger   { display: flex; }
    .svt-mobile-menu { display: block; }

    /* ── Hero ── */
    .svt-hero         { min-height: auto; }
    .svt-hero-inner   { padding: 52px 16px 40px; gap: 32px; }
    .svt-hero-headline{ letter-spacing: -.02em; }
    .svt-hero-sub     { font-size: 15px; }
    .svt-hero-ctas    { flex-direction: column; gap: 10px; }
    .svt-hero-ctas .svt-btn { width: 100%; justify-content: center; }
    .svt-hero-stats   { gap: 16px; flex-wrap: wrap; }
    .svt-hero-image-panel { display: none; }

    /* Hero info panel (no-image) */
    .svt-hero-panel-stats      { grid-template-columns: repeat(3, 1fr); gap: 8px; }
    .svt-hero-panel-stat       { padding: 12px 8px; }
    .svt-hero-panel-stat-num   { font-size: 16px; }
    .svt-hero-panel-stat-lbl   { font-size: 10px; }
    .svt-hero-panel-card       { padding: 18px; }

    /* ── Features ── */
    .svt-features-grid { grid-template-columns: 1fr 1fr; }

    /* ── Steps ── */
    .svt-steps-grid { grid-template-columns: 1fr; gap: 16px; }
    .svt-steps-grid .svt-step-card::after { display: none; }

    /* ── About ── */
    .svt-about-inner     { grid-template-columns: 1fr; }
    .svt-about-page-grid { grid-template-columns: 1fr; }

    /* ── Reviews ── */
    .svt-reviews-grid { grid-template-columns: 1fr; }

    /* ── Storage types ── */
    .svt-types-grid { grid-template-columns: 1fr 1fr; }

    /* ── Stats bar ── */
    .svt-stats-bar-inner { flex-wrap: wrap; justify-content: center; gap: 24px 32px; }
    .svt-stats-bar-num   { font-size: 2rem; }

    /* ── Service area ── */
    .svt-service-area-inner   { flex-direction: column; align-items: flex-start; gap: 12px; }
    .svt-service-area-cities  { gap: 8px; }

    /* ── Location ── */
    .svt-location-inner           { grid-template-columns: 1fr; gap: 32px; }
    .svt-location-section         { padding: 48px 0; }
    .svt-location-map-placeholder { min-height: 240px; }

    /* ── Image gallery ── */
    .svt-gallery-grid { grid-template-columns: 1fr 1fr !important; gap: 10px; }

    /* ── Areas grid ── */
    .svt-areas-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }

    /* ── Pricing teaser ── */
    .svt-pricing-teaser-inner          { flex-direction: column; text-align: center; gap: 20px; }
    .svt-pricing-teaser-inner .svt-btn { width: 100%; justify-content: center; }
    .svt-pricing-teaser-row            { justify-content: center; flex-wrap: wrap; }

    /* ── CTA banner ── */
    .svt-cta-banner-inner   { flex-direction: column; text-align: center; gap: 24px; }
    .svt-cta-banner-actions { flex-direction: column; width: 100%; align-items: center; }
    .svt-cta-banner-actions .svt-btn { width: 100%; justify-content: center; }

    /* ── Pre-footer CTA ── */
    .svt-pre-footer-cta-inner { flex-direction: column; text-align: center; gap: 20px; }
    .svt-pre-footer-cta-inner .svt-btn { width: 100%; justify-content: center; }

    /* ── Section header (heading + button row) ── */
    .svt-section-header                { flex-direction: column; align-items: flex-start; gap: 16px; }
    .svt-section-header > .svt-btn    { width: 100%; justify-content: center; }

    /* ── Units section ── */
    .svt-units-section .svt-section-subtitle { max-width: 100%; }

    /* ── Contact ── */
    .svt-contact-layout { grid-template-columns: 1fr; }
    .svt-form-row       { grid-template-columns: 1fr; }

    /* ── FAQ ── */
    .svt-faq-has-sidebar { grid-template-columns: 1fr; gap: 32px; }
    .svt-faq-sidebar     { position: static; }

    /* ── Footer ── */
    .svt-footer-grid   { grid-template-columns: 1fr; }
    .svt-footer-bottom { flex-direction: column; align-items: center; text-align: center; gap: 12px; }
    .svt-footer-legal  { flex-wrap: wrap; justify-content: center; gap: 16px; }

    /* ── Page hero ── */
    .svt-page-hero    { padding: 40px 0; }
    .svt-page-hero h1 { font-size: clamp(1.6rem, 5vw, 2.2rem); }

    /* ── Loc tabs ── */
    .svt-loc-tabs { flex-direction: column; }
    .svt-loc-tab-btn { border-right: none; border-bottom: 1.5px solid var(--svt-border); }
    .svt-loc-tab-btn:last-child { border-bottom: none; }
}

/* ── 480px — Mobile ─────────────────────────────────────────── */
@media (max-width: 480px) {
    .svt-container { padding: 0 14px; }
    .svt-section    { padding: 40px 0; }

    /* Hero */
    .svt-hero-inner        { padding: 40px 14px 32px; }
    .svt-hero-badge        { font-size: 11px; }
    .svt-hero-ctas .svt-btn{ font-size: 14px; padding: 13px 20px; }
    .svt-hero-stats        { gap: 10px; }
    .svt-hero-stat-num     { font-size: 22px; }

    /* Hero panel */
    .svt-hero-panel-stats    { grid-template-columns: repeat(3, 1fr); gap: 6px; }
    .svt-hero-panel-stat-num { font-size: 14px; }

    /* Features — single col */
    .svt-features-grid { grid-template-columns: 1fr; }
    .svt-feature-card  { padding: 22px 18px; }

    /* Steps */
    .svt-step-card { padding: 22px 18px; }

    /* Storage types — single col */
    .svt-types-grid { grid-template-columns: 1fr; }

    /* Stats bar — 2 per row */
    .svt-stats-bar-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; justify-items: center; }
    .svt-stats-bar-num   { font-size: 1.8rem; }

    /* Gallery — single col */
    .svt-gallery-grid { grid-template-columns: 1fr !important; }

    /* Areas — single col */
    .svt-areas-grid { grid-template-columns: 1fr; }

    /* Reviews */
    .svt-review-card  { padding: 20px 16px; }
    .svt-review-stars { font-size: 14px; }

    /* Service area chips */
    .svt-city-chip { font-size: 12px; padding: 3px 10px; }

    /* Pricing teaser */
    .svt-pricing-teaser       { padding: 28px 0; }
    .svt-pricing-teaser-price { font-size: 2rem; }
    .svt-pricing-teaser-heading { font-size: 1.1rem; }

    /* Page hero */
    .svt-page-hero    { padding: 32px 0; }
    .svt-page-hero h1 { font-size: 1.6rem; }

    /* Section headings */
    .svt-section-title    { font-size: clamp(1.3rem, 5vw, 1.8rem); }
    .svt-section-subtitle { font-size: 15px; margin-bottom: 28px; }

    /* FAQ sidebar hidden — too narrow */
    .svt-faq-sidebar { display: none; }

    /* CTA banner */
    .svt-cta-banner { padding: 48px 0; }
    .svt-cta-banner-headline { font-size: 1.4rem; }

    /* Location */
    .svt-location-details .svt-location-row { padding: 12px 0; }

    /* Footer */
    .svt-footer { padding: 48px 0 0; }
}

/* ── 360px — Very small mobile ──────────────────────────────── */
@media (max-width: 360px) {
    .svt-container { padding: 0 12px; }

    /* Hero panel — 2-col stats */
    .svt-hero-panel-stats    { grid-template-columns: 1fr 1fr; }
    .svt-hero-panel-stat-num { font-size: 13px; }

    /* Features — single col always */
    .svt-features-grid { grid-template-columns: 1fr; }

    /* Stats bar — vertical */
    .svt-stats-bar-inner { grid-template-columns: 1fr 1fr; gap: 12px; }

    /* Buttons — ensure text doesn't overflow */
    .svt-btn { font-size: 13px; padding: 11px 16px; }
    .svt-btn-lg { font-size: 14px; padding: 13px 20px; }
}

/* ── Font Awesome icons inside section icon slots ─────────── */
.svt-feature-icon i,
.svt-step-icon i,
.svt-type-card-icon i {
    font-size: 24px;
    color: var(--svt-accent);
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

/* ── SVG / image icons inside section icon slots ──────────── */
.svt-icon-img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}
.svt-feature-icon .svt-icon-img,
.svt-type-card-icon .svt-icon-img { padding: 4px; }
.svt-step-icon .svt-icon-img      { max-width: 40px; max-height: 40px; }
