body {
    font-size: .875rem;
}

.feather {
    width: 16px;
    height: 16px;
    vertical-align: text-bottom;
}

/*
 * Sidebar
 */

.sidebar {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    z-index: 100; /* Behind the navbar */
    padding: 48px 0 0; /* Height of navbar */
    box-shadow: inset -1px 0 0 rgba(0, 0, 0, .1);
}

.sidebar-sticky {
    position: relative;
    top: 0;
    height: calc(100vh - 48px);
    padding-top: .5rem;
    overflow-x: hidden;
    overflow-y: auto; /* Scrollable contents if viewport is shorter than content. */
}

.sidebar-sticky img{
    padding-left:0.5rem;
    width: 70%;
}

.sidebar-sticky .btn{
    margin-left:0.5rem;
    margin-bottom: 2rem;
}

.mobilenav img{
    width: 20%;
}

.mobilemenu a{
    color:white;
    font-size: 1.3em;
}

@supports ((position: -webkit-sticky) or (position: sticky)) {
    .sidebar-sticky {
        position: -webkit-sticky;
        position: sticky;
    }
}

.sidebar .nav-link {
    font-weight: 500;
    color: #333;
}

.sidebar .nav-link .feather {
    margin-right: 4px;
    color: #999;
}

.sidebar .nav-link.active {
    color: #007bff;
}

.sidebar .nav-link:hover .feather,
.sidebar .nav-link.active .feather {
    color: inherit;
}

.sidebar-heading {
    font-size: .75rem;
    text-transform: uppercase;
}

/*
 * Content
 */

[role="main"] {
    padding-top: 48px; /* Space for fixed navbar */
}

/*
 * Navbar
 */

.navbar-brand {
    padding-top: .75rem;
    padding-bottom: .75rem;
    font-size: 1rem;
    background-color: rgba(0, 0, 0, .25);
    box-shadow: inset -1px 0 0 rgba(0, 0, 0, .25);
}

.navbar .form-control {
    padding: .75rem 1rem;
    border-width: 0;
    border-radius: 0;
}

.form-control-dark {
    color: #fff;
    background-color: rgba(255, 255, 255, .1);
    border-color: rgba(255, 255, 255, .1);
}

.form-control-dark:focus {
    border-color: transparent;
    box-shadow: 0 0 0 3px rgba(255, 255, 255, .25);
}
/* Set the size of the div element that contains the map */
#map {
    height: 400px;
    /* The height is 400 pixels */
    width: 100%;
    /* The width is the width of the web page */
}

@media only screen and (min-width: 768px) {
    .mobilenav{
        display: none;
    }

}

.table-borderless table, tr,td{
    border:none
}
.accordion {
    padding: 5px 0px 10px 0px;
}
.collapse {
    padding: 5px 0px 10px 0px;
}
.depositwindow{
    padding: 5px 0px 5px 0px;
    background-color: rgba(240,231,255,0.15);
    border: 2px solid blue;
    border-radius: 5px;
}
.carousel-control-next,
.carousel-control-prev /*, .carousel-indicators */ {
    filter: invert(100%);
}

.configuratorpriceheading{
    font-size: 2em;

}

.surveyitem{
    padding: 1px 1px 1px 1px;
}
.surveyitem label{

}
.surveyscreen span{
    font-weight: bold;
}
.surveyquestion{
    padding: 2px 2px 2px 2px;
}
.visibledevice {display:none;}
.visibledesktop {display:block;}

@media (max-width : 450px) {
    .visibledevice {display:block;}
    .visibledesktop {display:none;}
}

.nav-pills .nav-link {
    border: 1px solid #007bff;
    color: #007bff;
    transition: all 0.2s ease-in-out;
}

.nav-pills .nav-link:hover {
    background-color: #e9f2ff;
    color: #0056b3;
}

.nav-pills .nav-link.active {
    background-color: #007bff;
    color: #fff;
}
/* Make all navbar text fully black */
.navbar.navbar-light .navbar-nav .nav-link,
.navbar.navbar-light .navbar-brand,
.navbar.navbar-light .dropdown-item {
    color: #000 !important;
}
/* Add horizontal spacing between navbar items */
.navbar-nav .nav-item {
    margin: 0 12px;   /* adjust value as needed */
}

/* Hero section: center content nicely */
.hero {
    min-height: 50vh;                /* take up half the viewport height */
    display: flex;
    align-items: center;
    justify-content: center;
    padding-top: 2rem;
    padding-bottom: 2rem;
}

/* Limit width for nicer reading */
.hero-inner {
    max-width: 720px;
    margin: 0 auto;
}

/* Title styling: centered, slightly grey, modern sizing */
.hero-title {
    font-size: clamp(2.2rem, 3vw, 3rem);
    font-weight: 600;
    color: #4b4b4b;                  /* slightly grey */
    letter-spacing: 0.02em;
    margin-bottom: 0.75rem;
}

/* Subtitles: softer grey, more organic flow with title */
.hero-subtitle {
    font-size: 1rem;
    color: #6c757d;                  /* Bootstrap-ish muted grey */
    line-height: 1.6;
    margin: 0 auto 0.25rem;
}

/* Optional: a bit more breathing room below hero before logos */
.featured {
    margin-top: 2rem;
    margin-bottom: 2rem;
}
/* --- Brand section title --- */
.brand-section {
    margin-bottom: 2rem;
}

.brand-title {
    font-size: 1.8rem;
    font-weight: 600;
    color: #444;
    margin-bottom: .3rem;
}

.brand-subtitle {
    font-size: 1rem;
    color: #777;
    margin-bottom: 1.5rem;
}

/* --- Brand grid improvements --- */
.brand-grid a {
    display: inline-block;
    margin: 15px 25px;
    transition: transform 0.25s ease, filter 0.25s ease;
}

/* Logo size consistency (optional but helpful) */
.brand-grid img {
    max-height: 280px;                 /* adjust as needed */
    width: auto;
}

/* --- Pop effect on hover --- */
.brand-grid a:hover img {
    transform: scale(1.08);
    filter: drop-shadow(0 4px 10px rgba(0,0,0,0.15));
}

/* Slight hover raise */
.brand-grid a:hover {
    transform: translateY(-3px);
}
/* ---------------------------
   Hero backdrop with overlay
------------------------------ */
.hero-with-backdrop {
    position: relative;
    min-height: 60vh;
    padding: 4rem 1rem;
    display: flex;
    align-items: center;
    justify-content: center;

    background-image: url("https://futuremobility-public.s3.eu-central-1.amazonaws.com/futuremobility_backdrop26_merlijntonen.jpeg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;

    border-radius: 12px; /* optional, looks cleaner */
    overflow: hidden;
}

/* Dark overlay to ensure readability */
.hero-with-backdrop::before {
    content: "";
    position: absolute;
    inset: 0;

    /* 70% opacity backdrop */
    background: rgba(0, 0, 0, 0.05); /* adjust if needed */

    backdrop-filter: brightness(0.8) blur(2px); /* optional but modern */
}

/* Keep hero text above overlay */
.hero-with-backdrop .hero-inner {
    position: relative;
    z-index: 2;
}

/* Text styles */
.hero-title {
    font-size: clamp(2.2rem, 3vw, 3rem);
    font-weight: 600;
    color: #f5f5f5;       /* white or very light grey for contrast */
    margin-bottom: 0.75rem;
    margin-top: 0.75rem;
    letter-spacing: 0.02em;
}
.hero-semititle {
    font-size: clamp(1.7rem, 3vw, 3rem);
    font-weight: 400;
    color: #f5f5f5;       /* white or very light grey for contrast */
    margin-bottom: 2rem;
    margin-top: 4rem;
    letter-spacing: 0.02em;
}

.hero-subtitle {
    color: #e0e0e0;
    max-width: 700px;
    margin: 0 auto 0.25rem;
    font-size: 1.05rem;
    line-height: 1.6;
}

body {
    padding-top: 70px; /* Adjust if your navbar is taller */
}
.brand-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr); /* max 3 per row */
    gap: 30px 40px;                        /* spacing between cards */
    justify-items: center;
}

@media (max-width: 992px) {
    .brand-grid {
        grid-template-columns: repeat(2, 1fr); /* 2 per row on tablets */
    }
}

@media (max-width: 576px) {
    .brand-grid {
        grid-template-columns: repeat(1, 1fr); /* 1 per row on phones */
    }
}
/* =============================
   NEWS CARD EXCLUSIVE STYLES
   Only cards with .news-card
   inside .news-card-section
   get these styles
============================= */

.news-card-section .news-card {
    border-radius: 12px;
    border: none;
    overflow: hidden;
    box-shadow: 0 4px 15px rgba(0,0,0,0.08);
    transition: transform .25s ease, box-shadow .25s ease;
}

.news-card-section .news-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 25px rgba(0,0,0,0.12);
}

.news-card-section .news-card .card-img-top {
    height: 180px;
    object-fit: cover;
}

.news-card-section .news-card .card-title {
    font-size: 1.15rem;
    font-weight: 600;
    color: #444;
    margin-bottom: 0.75rem;
    transition: color .25s ease;
}

.news-card-section .news-card:hover .card-title {
    color: #007bff;
}

.news-card-section .news-card .stretched-link {
    font-size: 0.9rem;
    color: #007bff;
    opacity: 0.8;
    text-decoration: none;
}

.news-card-section .news-card .stretched-link:hover {
    opacity: 1;
    text-decoration: underline;
}
/* ==========================
   CONTACT PAGE LAYOUT
========================== */

.contact-page {
    max-width: 1100px;
    margin: 0 auto;
    padding-top: 2rem;
    padding-bottom: 3rem;
}

/* Hero / titel */
.contact-hero {
    margin-bottom: 2.5rem;
}

.contact-title {
    font-size: clamp(2rem, 3vw, 2.6rem);
    font-weight: 600;
    color: #404040;
    letter-spacing: 0.03em;
    margin-bottom: 0.5rem;
}

.contact-subtitle {
    font-size: 1rem;
    color: #6c757d;
    max-width: 600px;
    margin: 0 auto;
    line-height: 1.6;
}

/* Contact info card */
.contact-info-wrapper {
    margin-bottom: 3rem;
}

.contact-info-card {
    border: none;
    border-radius: 14px;
    box-shadow: 0 6px 20px rgba(0,0,0,0.08);
    padding: 1.5rem 1.75rem;
}

.contact-info-title {
    font-size: 1.3rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 0.75rem;
}

.contact-info-text {
    margin: 0;
    color: #555;
    line-height: 1.7;
}

/* ==========================
   TEAM CARDS – ONLY HERE
========================== */

.team-section {
    margin-top: 2rem;
}

.team-title {
    text-align: center;
    font-size: 1.6rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 2rem;
}

/* scope specifiek: alleen in .team-card-section */
.team-card-section .team-card {
    border: none;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 4px 15px rgba(0,0,0,0.08);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
    background-color: #ffffff;
}

.team-card-section .team-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.12);
}

.team-card-section .team-card .card-img-top {
    height: 220px;
    object-fit: cover;
}

.team-card-section .team-card .card-body {
    text-align: center;
    padding: 1rem 1.25rem 1.25rem;
}

.team-card-section .team-card .team-name {
    font-weight: 600;
    color: #444;
    font-size: 1rem;
}
/* ==========================
   NAXEON BRAND PAGE
========================== */

.naxeon-page {
    max-width: 1200px;
    margin: 0 auto;
    padding-top: 2.5rem;
    padding-bottom: 3rem;
}

/* Hero */
.naxeon-hero {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;

    padding: 3rem 2.5rem;
    margin-bottom: 3rem;

    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
}

.naxeon-hero-text {
    flex: 1 1 320px;
    max-width: 540px;
}

.naxeon-badge {
    display: inline-block;
    padding: 0.3rem 0.75rem;
    border-radius: 999px;
    background-color: rgba(0, 0, 0, 0.06);
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #555;
    margin-bottom: 0.75rem;
}

.naxeon-hero-title {
    font-size: clamp(2.4rem, 4vw, 3rem);
    font-weight: 600;
    letter-spacing: 0.02em;
    color: #333;
    margin-bottom: 0.5rem;
}

.naxeon-hero-subtitle {
    font-size: 1.05rem;
    color: #555;
    line-height: 1.6;
    margin-bottom: 0.5rem;
}

.naxeon-hero-subcopy {
    font-size: 0.98rem;
    color: #777;
    margin-bottom: 1.5rem;
}

.naxeon-cta {
    padding: 0.65rem 1.4rem;
    border-radius: 999px;
    font-size: 0.95rem;
}

/* Hero image */
.naxeon-hero-image-wrap {
    flex: 1 1 280px;
    display: flex;
    justify-content: center;
}

.naxeon-hero-image {
    max-width: 420px;
    border-radius: 16px;
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.25);
}

/* Sections */
.naxeon-section {
    margin-bottom: 3rem;
}

.naxeon-section-title {
    font-size: 1.6rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 1rem;
}

.naxeon-text {
    font-size: 0.98rem;
    color: #555;
    line-height: 1.7;
    margin-bottom: 0.75rem;
}

.naxeon-image {
    border-radius: 16px;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.18);
}

/* Feature lists */
.naxeon-feature-list {
    list-style: none;
    padding-left: 0;
    margin: 1rem 0 0;
}

.naxeon-feature-list li {
    position: relative;
    padding-left: 1.4rem;
    margin-bottom: 0.5rem;
    color: #555;
    font-size: 0.95rem;
}

.naxeon-feature-list li::before {
    content: "";
    position: absolute;
    left: 0.4rem;
    top: 0.55rem;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background-color: #007aff; /* Apple-ish blauw */
}

/* Spec cards */
.naxeon-spec-card {
    border-radius: 16px;
    padding: 1.5rem 1.75rem;
    background-color: #ffffff;
    box-shadow: 0 6px 22px rgba(0,0,0,0.08);
    height: 100%;
}

.naxeon-spec-title {
    font-size: 1.2rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 0.75rem;
}

.naxeon-spec-list {
    list-style: none;
    padding-left: 0;
    margin: 0;
}

.naxeon-spec-list li {
    font-size: 0.95rem;
    color: #555;
    margin-bottom: 0.4rem;
}

/* Responsive tweaks */
@media (max-width: 767.98px) {
    .naxeon-hero {
        padding: 2.2rem 1.5rem;
    }

    .naxeon-hero-image {
        max-width: 100%;
        margin-top: 0.5rem;
    }
}
/* ==========================
   VEHICLE CONFIGURATOR
========================== */

.configurator-page {
    max-width: 1200px;
    margin: 0 auto;
    padding-top: 1.5rem;
    padding-bottom: 4rem;
}

/* Haal extra padding van main weg */
.configurator-main {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* HERO (laat zoals je ‘m had, eventueel iets compacter) */
.configurator-hero {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    padding: 2rem 1.8rem;
    margin-bottom: 1.8rem;

    border-radius: 18px;
    background: linear-gradient(135deg, #f5f5f7, #e8edf4);
}

/* TOOLBAR */
.configurator-toolbar {
    margin-bottom: 1rem;
}

.configurator-toolbar-title {
    font-size: 0.95rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #666;
    margin-right: 0.5rem;
}

.configurator-result-count {
    font-size: 0.9rem;
    color: #555;
}

.configurator-filter-toggle {
    font-size: 0.9rem;
    color: #333;
}

.configurator-filter-toggle i {
    margin-right: 0.25rem;
}

/* FILTER CARD */
.configurator-filter-card {
    border-radius: 16px;
    padding: 1.3rem 1.4rem;
    background-color: #ffffff;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.06);
}

.configurator-filter-title {
    font-size: 1.05rem;
    font-weight: 600;
    color: #333;
    margin: 0;
}

.configurator-filter-reset {
    color: #888;
    text-decoration: none;
}

.configurator-filter-reset:hover {
    text-decoration: underline;
}

.configurator-filter-label {
    font-size: 0.9rem;
    font-weight: 500;
    color: #555;
}

.configurator-filter-group {
    margin-top: 1rem;
    margin-bottom: 1rem;
}

/* Checkboxes */
.configurator-filter-card .form-check {
    margin-bottom: 0.25rem;
}

.configurator-filter-card .form-check-label {
    font-size: 0.9rem;
    color: #555;
}

/* Filterknop */
.configurator-filter-btn {
    margin-top: 0.75rem;
    border-radius: 999px;
    font-size: 0.9rem;
}

/* GRID & CARDS (wat je al had, met 3-per-rij aanpassing) */
.configurator-vehicle-grid {
    margin-top: 0.5rem;
}

.configurator-card {
    border: none;
    border-radius: 16px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.07);
    overflow: hidden;
    transition: transform 0.25s ease, box-shadow 0.25s ease;
    background-color: #ffffff;
}

.configurator-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.12);
}

/* ... rest van je configurator-card styles mag blijven zoals je ze al had */

.configurator-main {
    padding-left: 0 !important;
    padding-right: 0; /* optioneel */
}

/* ==========================
   ULTRAVIOLETTE BRAND PAGE
========================== */

.uv-page {
    max-width: 1200px;
    margin: 0 auto;
    padding-top: 2.5rem;
    padding-bottom: 3rem;
}

/* Hero */
.uv-hero {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;

    padding: 3rem 2.5rem;
    margin-bottom: 3rem;

    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
}

.uv-hero-text {
    flex: 1 1 320px;
    max-width: 560px;
}

.uv-badge {
    display: inline-block;
    padding: 0.3rem 0.75rem;
    border-radius: 999px;
    background-color: rgba(0, 0, 0, 0.06);
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #555;
    margin-bottom: 0.75rem;
}

.uv-hero-title {
    font-size: clamp(2.4rem, 4vw, 3rem);
    font-weight: 600;
    letter-spacing: 0.02em;
    color: #333;
    margin-bottom: 0.5rem;
}

.uv-hero-subtitle {
    font-size: 1.05rem;
    color: #555;
    line-height: 1.6;
    margin-bottom: 1.25rem;
}

.uv-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.uv-cta,
.uv-cta-secondary {
    padding: 0.65rem 1.4rem;
    border-radius: 999px;
    font-size: 0.95rem;
}

.uv-hero-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.25rem;
}

.uv-chip {
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    background: rgba(0,0,0,0.05);
    color: #555;
    font-size: 0.85rem;
}

/* Hero image */
.uv-hero-image-wrap {
    flex: 1 1 280px;
    display: flex;
    justify-content: center;
}

.uv-hero-image {
    max-width: 460px;
    border-radius: 16px;
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.25);
}

/* Sections */
.uv-section {
    margin-bottom: 3rem;
}

.uv-section-title {
    font-size: 1.6rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 1rem;
}

.uv-text {
    font-size: 0.98rem;
    color: #555;
    line-height: 1.7;
    margin-bottom: 0.75rem;
}

.uv-image {
    border-radius: 16px;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.18);
}

/* Feature list */
.uv-feature-list {
    list-style: none;
    padding-left: 0;
    margin: 1rem 0 0;
}

.uv-feature-list li {
    position: relative;
    padding-left: 1.4rem;
    margin-bottom: 0.5rem;
    color: #555;
    font-size: 0.95rem;
}

.uv-feature-list li::before {
    content: "";
    position: absolute;
    left: 0.4rem;
    top: 0.55rem;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background-color: #007aff; /* Apple-ish blauw */
}

/* Model cards */
.uv-model-card {
    border-radius: 16px;
    padding: 1.5rem 1.75rem;
    background-color: #ffffff;
    box-shadow: 0 6px 22px rgba(0,0,0,0.08);
    height: 100%;
}

.uv-model-header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.5rem;
}

.uv-model-title {
    font-size: 1.25rem;
    font-weight: 600;
    color: #333;
    margin: 0;
}

.uv-model-tag {
    font-size: 0.85rem;
    color: #666;
    background: rgba(0,0,0,0.06);
    padding: 0.3rem 0.6rem;
    border-radius: 999px;
}

.uv-model-actions {
    margin-top: 1.25rem;
}

/* Small info cards */
.uv-info-card {
    border-radius: 16px;
    padding: 1.5rem 1.5rem;
    background: #ffffff;
    box-shadow: 0 6px 18px rgba(0,0,0,0.07);
    height: 100%;
}

.uv-info-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 0.5rem;
}

/* CTA strip */
.uv-cta-strip {
    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
    padding: 2.5rem 2rem;
}

.uv-cta-strip-inner {
    max-width: 720px;
    margin: 0 auto;
    text-align: center;
}

/* Responsive tweaks */
@media (max-width: 767.98px) {
    .uv-hero {
        padding: 2.2rem 1.5rem;
    }

    .uv-hero-image {
        max-width: 100%;
        margin-top: 0.5rem;
    }
}
/* ==========================
   UBCO BRAND PAGE
========================== */

.ubco-page {
    max-width: 1200px;
    margin: 0 auto;
    padding-top: 2.5rem;
    padding-bottom: 3rem;
}

/* Hero */
.ubco-hero {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;

    padding: 3rem 2.5rem;
    margin-bottom: 3rem;

    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
}

.ubco-hero-text {
    flex: 1 1 320px;
    max-width: 580px;
}

.ubco-badge {
    display: inline-block;
    padding: 0.3rem 0.75rem;
    border-radius: 999px;
    background-color: rgba(0, 0, 0, 0.06);
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #555;
    margin-bottom: 0.75rem;
}

.ubco-hero-title {
    font-size: clamp(2.1rem, 3.6vw, 2.8rem);
    font-weight: 600;
    letter-spacing: 0.02em;
    color: #333;
    margin-bottom: 0.6rem;
}

.ubco-hero-subtitle {
    font-size: 1.05rem;
    color: #555;
    line-height: 1.6;
    margin-bottom: 1.25rem;
}

.ubco-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.ubco-cta,
.ubco-cta-secondary {
    padding: 0.65rem 1.4rem;
    border-radius: 999px;
    font-size: 0.95rem;
}

.ubco-hero-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.25rem;
}

.ubco-chip {
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    background: rgba(0,0,0,0.05);
    color: #555;
    font-size: 0.85rem;
}

.ubco-hero-image-wrap {
    flex: 1 1 280px;
    display: flex;
    justify-content: center;
}

.ubco-hero-image {
    max-width: 480px;
    border-radius: 16px;
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.25);
}

/* Sections */
.ubco-section {
    margin-bottom: 3rem;
}

.ubco-section-title {
    font-size: 1.6rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 1rem;
}

.ubco-text {
    font-size: 0.98rem;
    color: #555;
    line-height: 1.7;
    margin-bottom: 0.75rem;
}

.ubco-muted {
    color: #777;
}

.ubco-image {
    border-radius: 16px;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.18);
}

/* Info cards */
.ubco-info-card {
    border-radius: 16px;
    padding: 1.5rem 1.5rem;
    background: #ffffff;
    box-shadow: 0 6px 18px rgba(0,0,0,0.07);
    height: 100%;
}

.ubco-info-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 0.5rem;
}

/* Accessories */
.ubco-accessory-card {
    border-radius: 16px;
    padding: 1.5rem 1.5rem;
    background: #ffffff;
    box-shadow: 0 6px 18px rgba(0,0,0,0.07);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.ubco-accessory-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 26px rgba(0,0,0,0.12);
}

.ubco-accessory-icon {
    font-size: 1.7rem;
    margin-bottom: 0.75rem;
}

.ubco-accessory-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 0.5rem;
}

/* CTA strip */
.ubco-spec-strip {
    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
    padding: 2.5rem 2rem;
}

.ubco-spec-strip-inner {
    max-width: 720px;
    margin: 0 auto;
}

/* Responsive */
@media (max-width: 767.98px) {
    .ubco-hero {
        padding: 2.2rem 1.5rem;
    }
    .ubco-hero-image {
        max-width: 100%;
        margin-top: 0.5rem;
    }
}
/* ==========================
   ZERO BRAND PAGES
========================== */
.zero-page {
    max-width: 1200px;
    margin: 0 auto;
    padding-top: 2.5rem;
    padding-bottom: 3rem;
}

.zero-hero, .zero-model-hero {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;

    padding: 3rem 2.5rem;
    margin-bottom: 3rem;

    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
}

.zero-hero-text { flex: 1 1 320px; max-width: 620px; }

.zero-badge {
    display: inline-block;
    padding: .3rem .75rem;
    border-radius: 999px;
    background: rgba(0,0,0,.06);
    font-size: .8rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #555;
    margin-bottom: .75rem;
}

.zero-hero-title {
    font-size: clamp(2.2rem, 4vw, 3rem);
    font-weight: 600;
    letter-spacing: .02em;
    color: #333;
    margin-bottom: .5rem;
}

.zero-hero-subtitle {
    font-size: 1.05rem;
    color: #555;
    line-height: 1.6;
    margin-bottom: 1.25rem;
}

.zero-hero-actions { display:flex; flex-wrap:wrap; gap:.75rem; margin-bottom:1rem; }
.zero-cta, .zero-cta-secondary { padding:.65rem 1.4rem; border-radius:999px; font-size:.95rem; }

.zero-hero-chips { display:flex; flex-wrap:wrap; gap:.5rem; }
.zero-chip { padding:.35rem .7rem; border-radius:999px; background: rgba(0,0,0,.05); color:#555; font-size:.85rem; }

.zero-hero-image-wrap { flex: 1 1 280px; display:flex; justify-content:center; }
.zero-hero-image { max-width: 480px; border-radius: 16px; box-shadow: 0 18px 40px rgba(0,0,0,.25); }

.zero-section { margin-bottom: 3rem; }
.zero-section-title { font-size: 1.6rem; font-weight: 600; color:#333; margin-bottom: 1rem; }
.zero-text { font-size: .98rem; color:#555; line-height: 1.7; margin-bottom: .75rem; }
.zero-muted { color:#777; }

.zero-info-card, .zero-spec-card {
    border-radius: 16px;
    padding: 1.5rem 1.5rem;
    background: #fff;
    box-shadow: 0 6px 18px rgba(0,0,0,.07);
    height: 100%;
}
.zero-info-title { font-size: 1.1rem; font-weight: 600; color:#333; margin-bottom:.5rem; }

.zero-feature-list { list-style:none; padding-left:0; margin:1rem 0 0; }
.zero-feature-list li { position:relative; padding-left:1.4rem; margin-bottom:.5rem; color:#555; font-size:.95rem; }
.zero-feature-list li::before {
    content:""; position:absolute; left:.4rem; top:.55rem;
    width:6px; height:6px; border-radius:50%; background:#007aff;
}

/* Model directory cards */
.zero-model-link { text-decoration:none; color:inherit; }
.zero-model-card {
    border-radius: 16px;
    padding: 1.5rem 1.5rem;
    background: #fff;
    box-shadow: 0 6px 18px rgba(0,0,0,.07);
    transition: transform .25s ease, box-shadow .25s ease;
}
.zero-model-card:hover { transform: translateY(-4px); box-shadow: 0 12px 26px rgba(0,0,0,.12); }
.zero-model-top { display:flex; justify-content:space-between; gap:1rem; align-items:baseline; margin-bottom:.5rem; }
.zero-model-title { font-size: 1.25rem; font-weight: 600; color:#333; margin:0; }
.zero-model-tag { font-size:.85rem; color:#666; background: rgba(0,0,0,.06); padding:.3rem .6rem; border-radius:999px; }
.zero-model-cta { margin-top: 1rem; font-weight: 600; color:#007aff; }

.zero-cta-strip {
    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
    padding: 2.5rem 2rem;
}
.zero-cta-strip-inner { max-width: 820px; margin: 0 auto; text-align:center; }

.zero-model-nav { display:flex; flex-wrap:wrap; gap:.75rem; justify-content:center; }
.zero-mini-link {
    padding:.45rem .9rem; border-radius:999px; background: rgba(0,0,0,.05);
    color:#333; text-decoration:none; font-size:.9rem;
}
.zero-mini-link:hover { text-decoration: underline; }

@media (max-width: 767.98px) {
    .zero-hero, .zero-model-hero { padding: 2.2rem 1.5rem; }
    .zero-hero-image { max-width: 100%; margin-top: .5rem; }
}
/* ==========================
   ZERO LS1 PAGE (Scoped)
========================== */

.zero-ls1-page {}

/* Hero */
.zero-ls1-hero {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;

    padding: 3rem 2.5rem;
    margin-bottom: 3rem;

    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
}

.zero-ls1-hero-text {
    flex: 1 1 320px;
    max-width: 560px;
}

.zero-ls1-badge {
    display: inline-block;
    padding: .3rem .75rem;
    border-radius: 999px;
    background: rgba(0,0,0,.06);
    font-size: .8rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #555;
    margin-bottom: .75rem;
}

.zero-ls1-title {
    font-size: clamp(2.6rem, 4.6vw, 3.2rem);
    font-weight: 600;
    letter-spacing: .02em;
    color: #333;
    margin-bottom: .5rem;
}

.zero-ls1-subtitle {
    font-size: 1.05rem;
    color: #555;
    line-height: 1.6;
    margin-bottom: 1.25rem;
}

.zero-ls1-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    margin-bottom: 1rem;
}

.zero-ls1-cta,
.zero-ls1-cta-secondary {
    padding: .65rem 1.4rem;
    border-radius: 999px;
    font-size: .95rem;
}

.zero-ls1-chips {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}

.zero-ls1-chip {
    padding: .35rem .7rem;
    border-radius: 999px;
    background: rgba(0,0,0,.05);
    color: #555;
    font-size: .85rem;
}

.zero-ls1-image-wrap {
    flex: 1 1 280px;
    display: flex;
    justify-content: center;
}

.zero-ls1-image {
    max-width: 480px;
    border-radius: 16px;
    box-shadow: 0 18px 40px rgba(0,0,0,.25);
}

/* Sections */
.zero-ls1-section {
    margin-bottom: 3rem;
}

.zero-ls1-section-title {
    font-size: 1.6rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 1rem;
}

.zero-ls1-text {
    font-size: .98rem;
    color: #555;
    line-height: 1.7;
    margin-bottom: .75rem;
}

/* Cards */
.zero-ls1-card,
.zero-ls1-spec-card {
    border-radius: 16px;
    padding: 1.5rem 1.5rem;
    background: #fff;
    box-shadow: 0 6px 18px rgba(0,0,0,.07);
    height: 100%;
}

.zero-ls1-card-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: #333;
    margin-bottom: .5rem;
}

/* Lists */
.zero-ls1-list {
    list-style: none;
    padding-left: 0;
    margin: 1rem 0 0;
}

.zero-ls1-list li {
    position: relative;
    padding-left: 1.4rem;
    margin-bottom: .5rem;
    color: #555;
    font-size: .95rem;
}

.zero-ls1-list li::before {
    content: "";
    position: absolute;
    left: .4rem;
    top: .55rem;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background-color: #007aff;
}

/* Inline image */
.zero-ls1-inline-image {
    border-radius: 16px;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.18);
}

/* Mini nav */
.zero-ls1-mini-nav {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    margin-top: 1rem;
}

.zero-ls1-mini-link {
    padding: .45rem .9rem;
    border-radius: 999px;
    background: rgba(0,0,0,.05);
    color: #333;
    text-decoration: none;
    font-size: .9rem;
}

.zero-ls1-mini-link:hover {
    text-decoration: underline;
}

/* CTA strip */
.zero-ls1-cta-strip {
    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
    padding: 2.5rem 2rem;
}

.zero-ls1-cta-inner {
    max-width: 820px;
    margin: 0 auto;
    text-align: center;
}

@media (max-width: 767.98px) {
    .zero-ls1-hero {
        padding: 2.2rem 1.5rem;
    }
    .zero-ls1-image {
        max-width: 100%;
        margin-top: .5rem;
    }
}

/* ==========================
   LS1 vs NQiX 500 comparison
   Scoped
========================== */

.ls1-compare {
    margin-top: 2.5rem;
}

.ls1-compare-header {
    margin-bottom: 1.25rem;
}

.ls1-compare-subtitle {
    max-width: 820px;
    margin: 0 auto;
    color: #777;
}

/* Table shell */
.ls1-compare-table {
    border-radius: 18px;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 10px 30px rgba(0,0,0,0.07);
}

/* Rows */
.ls1-compare-row {
    display: grid;
    grid-template-columns: 1.2fr 1fr 1fr;
    border-top: 1px solid rgba(0,0,0,0.06);
}

.ls1-compare-row:first-child {
    border-top: none;
}

/* Cells */
.ls1-compare-cell {
    padding: 1rem 1.1rem;
    display: flex;
    align-items: center;
    gap: 0.6rem;
}

.ls1-compare-feature {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.25rem;
    color: #333;
    font-weight: 600;
}

.ls1-compare-hint {
    font-weight: 400;
    font-size: 0.9rem;
    color: #777;
    line-height: 1.4;
}

/* Header row */
.ls1-compare-head {
    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    position: sticky;
    top: 0;
    z-index: 2;
}

.ls1-compare-brand {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.15rem;
}

.ls1-compare-brand-title {
    font-weight: 700;
    color: #333;
    letter-spacing: 0.02em;
}

.ls1-compare-brand-note {
    font-size: 0.85rem;
    color: #666;
}

/* Highlight column (LS1) */
.ls1-compare-cell.is-highlight,
.ls1-compare-brand.is-highlight {
    background: rgba(0, 122, 255, 0.06);
}

/* Icons */
.ls1-compare-icon {
    width: 30px;
    height: 30px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 30px;
    font-size: 1.1rem;
}

.ls1-compare-icon.yes {
    background: rgba(40, 167, 69, 0.12);
    color: #1e7e34;
}

.ls1-compare-icon.maybe {
    background: rgba(108, 117, 125, 0.12);
    color: #5a6268;
}

.ls1-compare-text {
    color: #444;
    font-weight: 500;
}

/* Pills */
.ls1-compare-pill {
    margin-left: auto;
    padding: 0.25rem 0.55rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 600;
    background: rgba(0,0,0,0.06);
    color: #555;
}

/* Responsive: stack to cards */
@media (max-width: 767.98px) {
    .ls1-compare-row {
        grid-template-columns: 1fr;
    }

    .ls1-compare-head {
        position: relative;
        top: auto;
    }

    .ls1-compare-cell {
        border-top: 1px solid rgba(0,0,0,0.06);
    }

    .ls1-compare-row .ls1-compare-cell:first-child {
        border-top: none;
    }

    .ls1-compare-cell.is-highlight,
    .ls1-compare-brand.is-highlight {
        background: transparent;
    }

    /* On mobile, add subtle separators */
    .ls1-compare-row {
        border-top: 10px solid rgba(0,0,0,0.03);
    }
}
/* ==========================
   ZERO XB PAGE (Scoped)
========================== */

.zero-xb-hero {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;

    padding: 3rem 2.5rem;
    margin-bottom: 3rem;

    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
}

.zero-xb-hero-text { flex: 1 1 320px; max-width: 560px; }

.zero-xb-badge {
    display: inline-block;
    padding: .3rem .75rem;
    border-radius: 999px;
    background: rgba(0,0,0,.06);
    font-size: .8rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #555;
    margin-bottom: .75rem;
}

.zero-xb-title {
    font-size: clamp(2.6rem, 4.6vw, 3.2rem);
    font-weight: 600;
    letter-spacing: .02em;
    color: #333;
    margin-bottom: .5rem;
}

.zero-xb-subtitle {
    font-size: 1.05rem;
    color: #555;
    line-height: 1.6;
    margin-bottom: 1.25rem;
}

.zero-xb-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    margin-bottom: 1rem;
}

.zero-xb-cta,
.zero-xb-cta-secondary {
    padding: .65rem 1.4rem;
    border-radius: 999px;
    font-size: .95rem;
}

.zero-xb-chips { display:flex; flex-wrap:wrap; gap:.5rem; }
.zero-xb-chip {
    padding: .35rem .7rem;
    border-radius: 999px;
    background: rgba(0,0,0,.05);
    color: #555;
    font-size: .85rem;
}

.zero-xb-image-wrap { flex: 1 1 280px; display:flex; justify-content:center; }
.zero-xb-image {
    max-width: 480px;
    border-radius: 16px;
    box-shadow: 0 18px 40px rgba(0,0,0,.25);
}

.zero-xb-section { margin-bottom: 3rem; }

.zero-xb-section-title {
    font-size: 1.6rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 1rem;
}

.zero-xb-text {
    font-size: .98rem;
    color: #555;
    line-height: 1.7;
    margin-bottom: .75rem;
}

.zero-xb-card,
.zero-xb-spec-card {
    border-radius: 16px;
    padding: 1.5rem 1.5rem;
    background: #fff;
    box-shadow: 0 6px 18px rgba(0,0,0,.07);
    height: 100%;
}

.zero-xb-card-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: #333;
    margin-bottom: .5rem;
}

.zero-xb-list { list-style:none; padding-left:0; margin:1rem 0 0; }
.zero-xb-list li {
    position: relative;
    padding-left: 1.4rem;
    margin-bottom: .5rem;
    color: #555;
    font-size: .95rem;
}
.zero-xb-list li::before {
    content:"";
    position:absolute;
    left:.4rem; top:.55rem;
    width:6px; height:6px;
    border-radius:50%;
    background:#007aff;
}

.zero-xb-inline-image {
    border-radius: 16px;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.18);
}

/* Mini nav */
.zero-xb-mini-nav { display:flex; flex-wrap:wrap; gap:.75rem; margin-top: 1rem; }
.zero-xb-mini-link {
    padding: .45rem .9rem;
    border-radius: 999px;
    background: rgba(0,0,0,.05);
    color:#333;
    text-decoration:none;
    font-size:.9rem;
}
.zero-xb-mini-link:hover { text-decoration: underline; }

/* CTA strip */
.zero-xb-cta-strip {
    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
    padding: 2.5rem 2rem;
}
.zero-xb-cta-inner {
    max-width: 820px;
    margin: 0 auto;
    text-align: center;
}

/* ==========================
   XB Comparison tool (Scoped)
========================== */

.xb-compare { margin-top: 2.5rem; }

.xb-compare-header { margin-bottom: 1.25rem; }
.xb-compare-subtitle {
    max-width: 920px;
    margin: 0 auto;
    color: #777;
}

/* Table shell */
.xb-compare-table {
    border-radius: 18px;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 10px 30px rgba(0,0,0,0.07);
}

/* 5 columns: feature + 4 products */
.xb-compare-row {
    display: grid;
    grid-template-columns: 1.2fr 1fr 1fr 1fr 1fr;
    border-top: 1px solid rgba(0,0,0,0.06);
}
.xb-compare-row:first-child { border-top: none; }

.xb-compare-cell {
    padding: 1rem 1.1rem;
    display: flex;
    align-items: center;
    gap: 0.6rem;
}

/* Feature column */
.xb-compare-feature {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.25rem;
    color: #333;
    font-weight: 600;
}
.xb-compare-hint {
    font-weight: 400;
    font-size: 0.9rem;
    color: #777;
    line-height: 1.4;
}

/* Header row */
.xb-compare-head {
    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
}

/* Product header cells */
.xb-compare-brand {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.15rem;
}
.xb-compare-brand-title {
    font-weight: 700;
    color: #333;
    letter-spacing: 0.02em;
}
.xb-compare-brand-note {
    font-size: 0.85rem;
    color: #666;
}

/* Highlight column (XB) */
.xb-compare-cell.is-highlight,
.xb-compare-brand.is-highlight {
    background: rgba(0, 122, 255, 0.06);
}

.xb-compare-text {
    color: #444;
    font-weight: 500;
}

/* Icons */
.xb-compare-icon {
    width: 30px; height: 30px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 30px;
    font-size: 1.1rem;
}
.xb-compare-icon.yes { background: rgba(40,167,69,0.12); color:#1e7e34; }
.xb-compare-icon.maybe { background: rgba(108,117,125,0.12); color:#5a6268; }

/* Pills */
.xb-compare-pill {
    padding: 0.25rem 0.55rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 600;
    background: rgba(0,0,0,0.06);
    color: #555;
}

/* Responsive */
@media (max-width: 991.98px) {
    .xb-compare-row {
        grid-template-columns: 1fr; /* stack */
    }
    .xb-compare-cell { border-top: 1px solid rgba(0,0,0,0.06); }
    .xb-compare-row { border-top: 10px solid rgba(0,0,0,0.03); }
    .xb-compare-cell.is-highlight,
    .xb-compare-brand.is-highlight { background: transparent; }
}

@media (max-width: 767.98px) {
    .zero-xb-hero { padding: 2.2rem 1.5rem; }
    .zero-xb-image { max-width: 100%; margin-top: .5rem; }
}
/* ==========================
   ZERO XE PAGE (Scoped)
========================== */

.zero-xe-hero {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;

    padding: 3rem 2.5rem;
    margin-bottom: 3rem;

    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
}

.zero-xe-hero-text { flex: 1 1 320px; max-width: 560px; }

.zero-xe-badge {
    display: inline-block;
    padding: .3rem .75rem;
    border-radius: 999px;
    background: rgba(0,0,0,.06);
    font-size: .8rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #555;
    margin-bottom: .75rem;
}

.zero-xe-title {
    font-size: clamp(2.6rem, 4.6vw, 3.2rem);
    font-weight: 600;
    letter-spacing: .02em;
    color: #333;
    margin-bottom: .5rem;
}

.zero-xe-subtitle {
    font-size: 1.05rem;
    color: #555;
    line-height: 1.6;
    margin-bottom: 1.25rem;
}

.zero-xe-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    margin-bottom: 1rem;
}

.zero-xe-cta,
.zero-xe-cta-secondary {
    padding: .65rem 1.4rem;
    border-radius: 999px;
    font-size: .95rem;
}

.zero-xe-chips { display:flex; flex-wrap:wrap; gap:.5rem; }
.zero-xe-chip {
    padding: .35rem .7rem;
    border-radius: 999px;
    background: rgba(0,0,0,.05);
    color: #555;
    font-size: .85rem;
}

.zero-xe-image-wrap { flex: 1 1 280px; display:flex; justify-content:center; }
.zero-xe-image {
    max-width: 480px;
    border-radius: 16px;
    box-shadow: 0 18px 40px rgba(0,0,0,.25);
}

.zero-xe-section { margin-bottom: 3rem; }

.zero-xe-section-title {
    font-size: 1.6rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 1rem;
}

.zero-xe-text {
    font-size: .98rem;
    color: #555;
    line-height: 1.7;
    margin-bottom: .75rem;
}

.zero-xe-card,
.zero-xe-spec-card {
    border-radius: 16px;
    padding: 1.5rem 1.5rem;
    background: #fff;
    box-shadow: 0 6px 18px rgba(0,0,0,.07);
    height: 100%;
}

.zero-xe-card-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: #333;
    margin-bottom: .5rem;
}

.zero-xe-list { list-style:none; padding-left:0; margin:1rem 0 0; }
.zero-xe-list li {
    position: relative;
    padding-left: 1.4rem;
    margin-bottom: .5rem;
    color: #555;
    font-size: .95rem;
}
.zero-xe-list li::before {
    content:"";
    position:absolute;
    left:.4rem; top:.55rem;
    width:6px; height:6px;
    border-radius:50%;
    background:#007aff;
}

.zero-xe-inline-image {
    border-radius: 16px;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.18);
}

/* Mini nav */
.zero-xe-mini-nav { display:flex; flex-wrap:wrap; gap:.75rem; margin-top: 1rem; }
.zero-xe-mini-link {
    padding: .45rem .9rem;
    border-radius: 999px;
    background: rgba(0,0,0,.05);
    color:#333;
    text-decoration:none;
    font-size:.9rem;
}
.zero-xe-mini-link:hover { text-decoration: underline; }

/* CTA strip */
.zero-xe-cta-strip {
    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
    padding: 2.5rem 2rem;
}
.zero-xe-cta-inner {
    max-width: 820px;
    margin: 0 auto;
    text-align: center;
}

/* ==========================
   XE Comparison tool (Scoped)
========================== */

.xe-compare { margin-top: 2.5rem; }

.xe-compare-header { margin-bottom: 1.25rem; }
.xe-compare-subtitle {
    max-width: 920px;
    margin: 0 auto;
    color: #777;
}

.xe-compare-table {
    border-radius: 18px;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 10px 30px rgba(0,0,0,0.07);
}

.xe-compare-row {
    display: grid;
    grid-template-columns: 1.2fr 1fr 1fr 1fr 1fr;
    border-top: 1px solid rgba(0,0,0,0.06);
}
.xe-compare-row:first-child { border-top: none; }

.xe-compare-cell {
    padding: 1rem 1.1rem;
    display: flex;
    align-items: center;
    gap: 0.6rem;
}

.xe-compare-feature {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.25rem;
    color: #333;
    font-weight: 600;
}
.xe-compare-hint {
    font-weight: 400;
    font-size: 0.9rem;
    color: #777;
    line-height: 1.4;
}

.xe-compare-head {
    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
}

.xe-compare-brand {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.15rem;
}
.xe-compare-brand-title {
    font-weight: 700;
    color: #333;
    letter-spacing: 0.02em;
}
.xe-compare-brand-note {
    font-size: 0.85rem;
    color: #666;
}

.xe-compare-cell.is-highlight,
.xe-compare-brand.is-highlight {
    background: rgba(0, 122, 255, 0.06);
}

.xe-compare-text { color: #444; font-weight: 500; }

.xe-compare-icon {
    width: 30px; height: 30px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 30px;
    font-size: 1.1rem;
}
.xe-compare-icon.yes { background: rgba(40,167,69,0.12); color:#1e7e34; }
.xe-compare-icon.maybe { background: rgba(108,117,125,0.12); color:#5a6268; }

.xe-compare-pill {
    padding: 0.25rem 0.55rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 600;
    background: rgba(0,0,0,0.06);
    color: #555;
}

@media (max-width: 991.98px) {
    .xe-compare-row { grid-template-columns: 1fr; }
    .xe-compare-cell { border-top: 1px solid rgba(0,0,0,0.06); }
    .xe-compare-row { border-top: 10px solid rgba(0,0,0,0.03); }
    .xe-compare-cell.is-highlight,
    .xe-compare-brand.is-highlight { background: transparent; }
}

@media (max-width: 767.98px) {
    .zero-xe-hero { padding: 2.2rem 1.5rem; }
    .zero-xe-image { max-width: 100%; margin-top: .5rem; }
}

/* ==========================
   ZERO DS PAGE (Scoped)
========================== */

.zero-ds-hero {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;

    padding: 3rem 2.5rem;
    margin-bottom: 3rem;

    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
}

.zero-ds-hero-text { flex: 1 1 320px; max-width: 580px; }

.zero-ds-badge {
    display: inline-block;
    padding: .3rem .75rem;
    border-radius: 999px;
    background: rgba(0,0,0,.06);
    font-size: .8rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #555;
    margin-bottom: .75rem;
}

.zero-ds-title {
    font-size: clamp(2.6rem, 4.6vw, 3.2rem);
    font-weight: 600;
    letter-spacing: .02em;
    color: #333;
    margin-bottom: .5rem;
}

.zero-ds-subtitle {
    font-size: 1.05rem;
    color: #555;
    line-height: 1.6;
    margin-bottom: 1.25rem;
}

.zero-ds-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    margin-bottom: 1rem;
}

.zero-ds-cta,
.zero-ds-cta-secondary {
    padding: .65rem 1.4rem;
    border-radius: 999px;
    font-size: .95rem;
}

.zero-ds-chips { display:flex; flex-wrap:wrap; gap:.5rem; }
.zero-ds-chip {
    padding: .35rem .7rem;
    border-radius: 999px;
    background: rgba(0,0,0,.05);
    color: #555;
    font-size: .85rem;
}

.zero-ds-image-wrap { flex: 1 1 280px; display:flex; justify-content:center; }
.zero-ds-image {
    max-width: 520px;
    border-radius: 16px;
    box-shadow: 0 18px 40px rgba(0,0,0,.25);
}

.zero-ds-section { margin-bottom: 3rem; }

.zero-ds-section-title {
    font-size: 1.6rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 1rem;
}

.zero-ds-text {
    font-size: .98rem;
    color: #555;
    line-height: 1.7;
    margin-bottom: .75rem;
}

.zero-ds-card,
.zero-ds-spec-card {
    border-radius: 16px;
    padding: 1.5rem 1.5rem;
    background: #fff;
    box-shadow: 0 6px 18px rgba(0,0,0,.07);
    height: 100%;
}

.zero-ds-card-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: #333;
    margin-bottom: .5rem;
}

.zero-ds-list { list-style:none; padding-left:0; margin:1rem 0 0; }
.zero-ds-list li {
    position: relative;
    padding-left: 1.4rem;
    margin-bottom: .5rem;
    color: #555;
    font-size: .95rem;
}
.zero-ds-list li::before {
    content:"";
    position:absolute;
    left:.4rem; top:.55rem;
    width:6px; height:6px;
    border-radius:50%;
    background:#007aff;
}

.zero-ds-inline-image {
    border-radius: 16px;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.18);
}

.zero-ds-mini-nav { display:flex; flex-wrap:wrap; gap:.75rem; margin-top: 1rem; }
.zero-ds-mini-link {
    padding: .45rem .9rem;
    border-radius: 999px;
    background: rgba(0,0,0,.05);
    color:#333;
    text-decoration:none;
    font-size:.9rem;
}
.zero-ds-mini-link:hover { text-decoration: underline; }

.zero-ds-cta-strip {
    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
    padding: 2.5rem 2rem;
}
.zero-ds-cta-inner {
    max-width: 820px;
    margin: 0 auto;
    text-align: center;
}

/* ==========================
   DS Comparison tool (Scoped)
========================== */

.ds-compare { margin-top: 2.5rem; }

.ds-compare-header { margin-bottom: 1.25rem; }
.ds-compare-subtitle {
    max-width: 920px;
    margin: 0 auto;
    color: #777;
}

.ds-compare-table {
    border-radius: 18px;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 10px 30px rgba(0,0,0,0.07);
}

/* feature + 4 products */
.ds-compare-row {
    display: grid;
    grid-template-columns: 1.2fr 1fr 1fr 1fr 1fr;
    border-top: 1px solid rgba(0,0,0,0.06);
}
.ds-compare-row:first-child { border-top: none; }

.ds-compare-cell {
    padding: 1rem 1.1rem;
    display: flex;
    align-items: center;
    gap: 0.6rem;
}

.ds-compare-feature {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.25rem;
    color: #333;
    font-weight: 600;
}
.ds-compare-hint {
    font-weight: 400;
    font-size: 0.9rem;
    color: #777;
    line-height: 1.4;
}

.ds-compare-head {
    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
}

.ds-compare-brand {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.15rem;
}
.ds-compare-brand-title {
    font-weight: 700;
    color: #333;
    letter-spacing: 0.02em;
}
.ds-compare-brand-note {
    font-size: 0.85rem;
    color: #666;
}

.ds-compare-cell.is-highlight,
.ds-compare-brand.is-highlight {
    background: rgba(0, 122, 255, 0.06);
}

.ds-compare-text { color: #444; font-weight: 500; }

.ds-compare-icon {
    width: 30px; height: 30px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 30px;
    font-size: 1.1rem;
}
.ds-compare-icon.yes { background: rgba(40,167,69,0.12); color:#1e7e34; }
.ds-compare-icon.maybe { background: rgba(108,117,125,0.12); color:#5a6268; }
.ds-compare-icon.no { background: rgba(220,53,69,0.12); color:#b21f2d; }

.ds-compare-pill {
    padding: 0.25rem 0.55rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 600;
    background: rgba(0,0,0,0.06);
    color: #555;
}

@media (max-width: 991.98px) {
    .ds-compare-row { grid-template-columns: 1fr; }
    .ds-compare-cell { border-top: 1px solid rgba(0,0,0,0.06); }
    .ds-compare-row { border-top: 10px solid rgba(0,0,0,0.03); }
    .ds-compare-cell.is-highlight,
    .ds-compare-brand.is-highlight { background: transparent; }
}

@media (max-width: 767.98px) {
    .zero-ds-hero { padding: 2.2rem 1.5rem; }
    .zero-ds-image { max-width: 100%; margin-top: .5rem; }
}
/* ==========================
   ZERO DSR/X PAGE (Scoped)
========================== */

.zero-dsrx-hero {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;

    padding: 3rem 2.5rem;
    margin-bottom: 3rem;

    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
}

.zero-dsrx-hero-text { flex: 1 1 320px; max-width: 600px; }

.zero-dsrx-badge {
    display: inline-block;
    padding: .3rem .75rem;
    border-radius: 999px;
    background: rgba(0,0,0,.06);
    font-size: .8rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #555;
    margin-bottom: .75rem;
}

.zero-dsrx-title {
    font-size: clamp(2.6rem, 4.6vw, 3.2rem);
    font-weight: 600;
    letter-spacing: .02em;
    color: #333;
    margin-bottom: .5rem;
}

.zero-dsrx-subtitle {
    font-size: 1.05rem;
    color: #555;
    line-height: 1.6;
    margin-bottom: 1.25rem;
}

.zero-dsrx-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    margin-bottom: 1rem;
}

.zero-dsrx-cta,
.zero-dsrx-cta-secondary {
    padding: .65rem 1.4rem;
    border-radius: 999px;
    font-size: .95rem;
}

.zero-dsrx-chips { display:flex; flex-wrap:wrap; gap:.5rem; }
.zero-dsrx-chip {
    padding: .35rem .7rem;
    border-radius: 999px;
    background: rgba(0,0,0,.05);
    color: #555;
    font-size: .85rem;
}

.zero-dsrx-image-wrap { flex: 1 1 280px; display:flex; justify-content:center; }
.zero-dsrx-image {
    max-width: 560px;
    border-radius: 16px;
    box-shadow: 0 18px 40px rgba(0,0,0,.25);
}

.zero-dsrx-section { margin-bottom: 3rem; }

.zero-dsrx-section-title {
    font-size: 1.6rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 1rem;
}

.zero-dsrx-text {
    font-size: .98rem;
    color: #555;
    line-height: 1.7;
    margin-bottom: .75rem;
}

.zero-dsrx-card,
.zero-dsrx-spec-card {
    border-radius: 16px;
    padding: 1.5rem 1.5rem;
    background: #fff;
    box-shadow: 0 6px 18px rgba(0,0,0,.07);
    height: 100%;
}

.zero-dsrx-card-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: #333;
    margin-bottom: .5rem;
}

.zero-dsrx-list { list-style:none; padding-left:0; margin:1rem 0 0; }
.zero-dsrx-list li {
    position: relative;
    padding-left: 1.4rem;
    margin-bottom: .5rem;
    color: #555;
    font-size: .95rem;
}
.zero-dsrx-list li::before {
    content:"";
    position:absolute;
    left:.4rem; top:.55rem;
    width:6px; height:6px;
    border-radius:50%;
    background:#007aff;
}

.zero-dsrx-inline-image {
    border-radius: 16px;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.18);
}

.zero-dsrx-mini-nav { display:flex; flex-wrap:wrap; gap:.75rem; margin-top: 1rem; }
.zero-dsrx-mini-link {
    padding: .45rem .9rem;
    border-radius: 999px;
    background: rgba(0,0,0,.05);
    color:#333;
    text-decoration:none;
    font-size:.9rem;
}
.zero-dsrx-mini-link:hover { text-decoration: underline; }

.zero-dsrx-cta-strip {
    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
    padding: 2.5rem 2rem;
}
.zero-dsrx-cta-inner {
    max-width: 820px;
    margin: 0 auto;
    text-align: center;
}

/* ==========================
   DSR/X Comparison tool (Scoped)
========================== */

.dsrx-compare { margin-top: 2.5rem; }

.dsrx-compare-header { margin-bottom: 1.25rem; }
.dsrx-compare-subtitle {
    max-width: 920px;
    margin: 0 auto;
    color: #777;
}

.dsrx-compare-table {
    border-radius: 18px;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 10px 30px rgba(0,0,0,0.07);
}

.dsrx-compare-row {
    display: grid;
    grid-template-columns: 1.2fr 1fr 1fr 1fr 1fr;
    border-top: 1px solid rgba(0,0,0,0.06);
}
.dsrx-compare-row:first-child { border-top: none; }

.dsrx-compare-cell {
    padding: 1rem 1.1rem;
    display: flex;
    align-items: center;
    gap: 0.6rem;
}

.dsrx-compare-feature {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.25rem;
    color: #333;
    font-weight: 600;
}
.dsrx-compare-hint {
    font-weight: 400;
    font-size: 0.9rem;
    color: #777;
    line-height: 1.4;
}

.dsrx-compare-head {
    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
}

.dsrx-compare-brand {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.15rem;
}
.dsrx-compare-brand-title {
    font-weight: 700;
    color: #333;
    letter-spacing: 0.02em;
}
.dsrx-compare-brand-note {
    font-size: 0.85rem;
    color: #666;
}

.dsrx-compare-cell.is-highlight,
.dsrx-compare-brand.is-highlight {
    background: rgba(0, 122, 255, 0.06);
}

.dsrx-compare-text { color: #444; font-weight: 500; }

.dsrx-compare-icon {
    width: 30px; height: 30px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 30px;
    font-size: 1.1rem;
}
.dsrx-compare-icon.yes { background: rgba(40,167,69,0.12); color:#1e7e34; }
.dsrx-compare-icon.maybe { background: rgba(108,117,125,0.12); color:#5a6268; }
.dsrx-compare-icon.no { background: rgba(220,53,69,0.12); color:#b21f2d; }

.dsrx-compare-pill {
    padding: 0.25rem 0.55rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 600;
    background: rgba(0,0,0,0.06);
    color: #555;
}

@media (max-width: 991.98px) {
    .dsrx-compare-row { grid-template-columns: 1fr; }
    .dsrx-compare-cell { border-top: 1px solid rgba(0,0,0,0.06); }
    .dsrx-compare-row { border-top: 10px solid rgba(0,0,0,0.03); }
    .dsrx-compare-cell.is-highlight,
    .dsrx-compare-brand.is-highlight { background: transparent; }
}

@media (max-width: 767.98px) {
    .zero-dsrx-hero { padding: 2.2rem 1.5rem; }
    .zero-dsrx-image { max-width: 100%; margin-top: .5rem; }
}
/* ==========================
   ZERO S PAGE (Scoped)
========================== */

.zero-s-hero {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;

    padding: 3rem 2.5rem;
    margin-bottom: 3rem;

    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
}

.zero-s-hero-text { flex: 1 1 320px; max-width: 600px; }

.zero-s-badge {
    display: inline-block;
    padding: .3rem .75rem;
    border-radius: 999px;
    background: rgba(0,0,0,.06);
    font-size: .8rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #555;
    margin-bottom: .75rem;
}

.zero-s-title {
    font-size: clamp(2.6rem, 4.6vw, 3.2rem);
    font-weight: 600;
    letter-spacing: .02em;
    color: #333;
    margin-bottom: .5rem;
}

.zero-s-subtitle {
    font-size: 1.05rem;
    color: #555;
    line-height: 1.6;
    margin-bottom: 1.25rem;
}

.zero-s-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    margin-bottom: 1rem;
}

.zero-s-cta,
.zero-s-cta-secondary {
    padding: .65rem 1.4rem;
    border-radius: 999px;
    font-size: .95rem;
}

.zero-s-chips { display:flex; flex-wrap:wrap; gap:.5rem; }
.zero-s-chip {
    padding: .35rem .7rem;
    border-radius: 999px;
    background: rgba(0,0,0,.05);
    color: #555;
    font-size: .85rem;
}

.zero-s-image-wrap { flex: 1 1 280px; display:flex; justify-content:center; }
.zero-s-image {
    max-width: 560px;
    border-radius: 16px;
    box-shadow: 0 18px 40px rgba(0,0,0,.25);
}

.zero-s-section { margin-bottom: 3rem; }

.zero-s-section-title {
    font-size: 1.6rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 1rem;
}

.zero-s-text {
    font-size: .98rem;
    color: #555;
    line-height: 1.7;
    margin-bottom: .75rem;
}

.zero-s-card,
.zero-s-spec-card {
    border-radius: 16px;
    padding: 1.5rem 1.5rem;
    background: #fff;
    box-shadow: 0 6px 18px rgba(0,0,0,.07);
    height: 100%;
}

.zero-s-card-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: #333;
    margin-bottom: .5rem;
}

.zero-s-list { list-style:none; padding-left:0; margin:1rem 0 0; }
.zero-s-list li {
    position: relative;
    padding-left: 1.4rem;
    margin-bottom: .5rem;
    color: #555;
    font-size: .95rem;
}
.zero-s-list li::before {
    content:"";
    position:absolute;
    left:.4rem; top:.55rem;
    width:6px; height:6px;
    border-radius:50%;
    background:#007aff;
}

.zero-s-inline-image {
    border-radius: 16px;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.18);
}

.zero-s-mini-nav { display:flex; flex-wrap:wrap; gap:.75rem; margin-top: 1rem; }
.zero-s-mini-link {
    padding: .45rem .9rem;
    border-radius: 999px;
    background: rgba(0,0,0,.05);
    color:#333;
    text-decoration:none;
    font-size:.9rem;
}
.zero-s-mini-link:hover { text-decoration: underline; }

.zero-s-cta-strip {
    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
    padding: 2.5rem 2rem;
}
.zero-s-cta-inner {
    max-width: 820px;
    margin: 0 auto;
    text-align: center;
}

@media (max-width: 767.98px) {
    .zero-s-hero { padding: 2.2rem 1.5rem; }
    .zero-s-image { max-width: 100%; margin-top: .5rem; }
}
/* ==========================
   ZERO SR/F PAGE (Scoped)
========================== */

.zero-srf-hero {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;

    padding: 3rem 2.5rem;
    margin-bottom: 3rem;

    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
}

.zero-srf-hero-text { flex: 1 1 320px; max-width: 600px; }

.zero-srf-badge {
    display: inline-block;
    padding: .3rem .75rem;
    border-radius: 999px;
    background: rgba(0,0,0,.06);
    font-size: .8rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #555;
    margin-bottom: .75rem;
}

.zero-srf-title {
    font-size: clamp(2.6rem, 4.6vw, 3.2rem);
    font-weight: 600;
    letter-spacing: .02em;
    color: #333;
    margin-bottom: .5rem;
}

.zero-srf-subtitle {
    font-size: 1.05rem;
    color: #555;
    line-height: 1.6;
    margin-bottom: 1.25rem;
}

.zero-srf-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    margin-bottom: 1rem;
}

.zero-srf-cta,
.zero-srf-cta-secondary {
    padding: .65rem 1.4rem;
    border-radius: 999px;
    font-size: .95rem;
}

.zero-srf-chips { display:flex; flex-wrap:wrap; gap:.5rem; }
.zero-srf-chip {
    padding: .35rem .7rem;
    border-radius: 999px;
    background: rgba(0,0,0,.05);
    color: #555;
    font-size: .85rem;
}

.zero-srf-image-wrap { flex: 1 1 280px; display:flex; justify-content:center; }
.zero-srf-image {
    max-width: 560px;
    border-radius: 16px;
    box-shadow: 0 18px 40px rgba(0,0,0,.25);
}

.zero-srf-section { margin-bottom: 3rem; }

.zero-srf-section-title {
    font-size: 1.6rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 1rem;
}

.zero-srf-text {
    font-size: .98rem;
    color: #555;
    line-height: 1.7;
    margin-bottom: .75rem;
}

.zero-srf-card,
.zero-srf-spec-card {
    border-radius: 16px;
    padding: 1.5rem 1.5rem;
    background: #fff;
    box-shadow: 0 6px 18px rgba(0,0,0,.07);
    height: 100%;
}

.zero-srf-card-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: #333;
    margin-bottom: .5rem;
}

.zero-srf-list { list-style:none; padding-left:0; margin:1rem 0 0; }
.zero-srf-list li {
    position: relative;
    padding-left: 1.4rem;
    margin-bottom: .5rem;
    color: #555;
    font-size: .95rem;
}
.zero-srf-list li::before {
    content:"";
    position:absolute;
    left:.4rem; top:.55rem;
    width:6px; height:6px;
    border-radius:50%;
    background:#007aff;
}

.zero-srf-inline-image {
    border-radius: 16px;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.18);
}

.zero-srf-mini-nav { display:flex; flex-wrap:wrap; gap:.75rem; margin-top: 1rem; }
.zero-srf-mini-link {
    padding: .45rem .9rem;
    border-radius: 999px;
    background: rgba(0,0,0,.05);
    color:#333;
    text-decoration:none;
    font-size:.9rem;
}
.zero-srf-mini-link:hover { text-decoration: underline; }

.zero-srf-cta-strip {
    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
    padding: 2.5rem 2rem;
}
.zero-srf-cta-inner {
    max-width: 820px;
    margin: 0 auto;
    text-align: center;
}

@media (max-width: 767.98px) {
    .zero-srf-hero { padding: 2.2rem 1.5rem; }
    .zero-srf-image { max-width: 100%; margin-top: .5rem; }
}

/* ==========================
   niu BRAND PAGES
========================== */
.niu-page {
    max-width: 1200px;
    margin: 0 auto;
    padding-top: 2.5rem;
    padding-bottom: 3rem;
}

.niu-hero, .niu-model-hero {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;

    padding: 3rem 2.5rem;
    margin-bottom: 3rem;

    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
}

.niu-hero-text { flex: 1 1 320px; max-width: 620px; }

.niu-badge {
    display: inline-block;
    padding: .3rem .75rem;
    border-radius: 999px;
    background: rgba(0,0,0,.06);
    font-size: .8rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #555;
    margin-bottom: .75rem;
}

.niu-hero-title {
    font-size: clamp(2.2rem, 4vw, 3rem);
    font-weight: 600;
    letter-spacing: .02em;
    color: #333;
    margin-bottom: .5rem;
}

.niu-hero-subtitle {
    font-size: 1.05rem;
    color: #555;
    line-height: 1.6;
    margin-bottom: 1.25rem;
}

.niu-hero-actions { display:flex; flex-wrap:wrap; gap:.75rem; margin-bottom:1rem; }
.niu-cta, .niu-cta-secondary { padding:.65rem 1.4rem; border-radius:999px; font-size:.95rem; }

.niu-hero-chips { display:flex; flex-wrap:wrap; gap:.5rem; }
.niu-chip { padding:.35rem .7rem; border-radius:999px; background: rgba(0,0,0,.05); color:#555; font-size:.85rem; }

.niu-hero-image-wrap { flex: 1 1 280px; display:flex; justify-content:center; }
.niu-hero-image { max-width: 480px; border-radius: 16px; box-shadow: 0 18px 40px rgba(0,0,0,.25); }

.niu-section { margin-bottom: 3rem; }
.niu-section-title { font-size: 1.6rem; font-weight: 600; color:#333; margin-bottom: 1rem; }
.niu-text { font-size: .98rem; color:#555; line-height: 1.7; margin-bottom: .75rem; }
.niu-muted { color:#777; }

.niu-info-card, .niu-spec-card {
    border-radius: 16px;
    padding: 1.5rem 1.5rem;
    background: #fff;
    box-shadow: 0 6px 18px rgba(0,0,0,.07);
    height: 100%;
}
.niu-info-title { font-size: 1.1rem; font-weight: 600; color:#333; margin-bottom:.5rem; }

.niu-feature-list { list-style:none; padding-left:0; margin:1rem 0 0; }
.niu-feature-list li { position:relative; padding-left:1.4rem; margin-bottom:.5rem; color:#555; font-size:.95rem; }
.niu-feature-list li::before {
    content:""; position:absolute; left:.4rem; top:.55rem;
    width:6px; height:6px; border-radius:50%; background:#007aff;
}

/* Model directory cards */
.niu-model-link { text-decoration:none; color:inherit; }
.niu-model-card {
    border-radius: 16px;
    padding: 1.5rem 1.5rem;
    background: #fff;
    box-shadow: 0 6px 18px rgba(0,0,0,.07);
    transition: transform .25s ease, box-shadow .25s ease;
}
.niu-model-card:hover { transform: translateY(-4px); box-shadow: 0 12px 26px rgba(0,0,0,.12); }
.niu-model-top { display:flex; justify-content:space-between; gap:1rem; align-items:baseline; margin-bottom:.5rem; }
.niu-model-title { font-size: 1.25rem; font-weight: 600; color:#333; margin:0; }
.niu-model-tag { font-size:.85rem; color:#666; background: rgba(0,0,0,.06); padding:.3rem .6rem; border-radius:999px; }
.niu-model-cta { margin-top: 1rem; font-weight: 600; color:#007aff; }

.niu-cta-strip {
    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
    padding: 2.5rem 2rem;
}
.niu-cta-strip-inner { max-width: 820px; margin: 0 auto; text-align:center; }

.niu-model-nav { display:flex; flex-wrap:wrap; gap:.75rem; justify-content:center; }
.niu-mini-link {
    padding:.45rem .9rem; border-radius:999px; background: rgba(0,0,0,.05);
    color:#333; text-decoration:none; font-size:.9rem;
}
.niu-mini-link:hover { text-decoration: underline; }

@media (max-width: 767.98px) {
    .niu-hero, .niu-model-hero { padding: 2.2rem 1.5rem; }
    .niu-hero-image { max-width: 100%; margin-top: .5rem; }
}

/* ==========================
   NIU Model PAGE (Scoped)
========================== */

.niu-model-hero-text { flex: 1 1 320px; max-width: 620px; }

.niu-model-badge {
    display: inline-block;
    padding: .3rem .75rem;
    border-radius: 999px;
    background: rgba(0,0,0,.06);
    font-size: .8rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #555;
    margin-bottom: .75rem;
}

.niu-model-title {
    font-size: clamp(2.6rem, 4.6vw, 3.2rem);
    font-weight: 600;
    letter-spacing: .02em;
    color: #333;
    margin-bottom: .5rem;
}

.niu-model-subtitle {
    font-size: 1.05rem;
    color: #555;
    line-height: 1.6;
    margin-bottom: 1.25rem;
}

.niu-model-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    margin-bottom: 1rem;
}

.niu-model-cta,
.niu-model-cta-secondary {
    padding: .65rem 1.4rem;
    border-radius: 999px;
    font-size: .95rem;
}

.niu-model-chips { display:flex; flex-wrap:wrap; gap:.5rem; }
.niu-model-chip {
    padding: .35rem .7rem;
    border-radius: 999px;
    background: rgba(0,0,0,.05);
    color: #555;
    font-size: .85rem;
}

.niu-model-image-wrap { flex: 1 1 280px; display:flex; justify-content:center; }
.niu-model-image {
    max-width: 560px;
    border-radius: 16px;
    box-shadow: 0 18px 40px rgba(0,0,0,.25);
}

.niu-model-section { margin-bottom: 3rem; }

.niu-model-section-title {
    font-size: 1.6rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 1rem;
}

.niu-model-text {
    font-size: .98rem;
    color: #555;
    line-height: 1.7;
    margin-bottom: .75rem;
}

.niu-model-card,
.niu-model-spec-card {
    border-radius: 16px;
    padding: 1.5rem 1.5rem;
    background: #fff;
    box-shadow: 0 6px 18px rgba(0,0,0,.07);
    height: 100%;
}

.niu-model-card-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: #333;
    margin-bottom: .5rem;
}

.niu-model-list { list-style:none; padding-left:0; margin:1rem 0 0; }
.niu-model-list li {
    position: relative;
    padding-left: 1.4rem;
    margin-bottom: .5rem;
    color: #555;
    font-size: .95rem;
}
.niu-model-list li::before {
    content:"";
    position:absolute;
    left:.4rem; top:.55rem;
    width:6px; height:6px;
    border-radius:50%;
    background:#007aff;
}

.niu-model-inline-image {
    border-radius: 16px;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.18);
}

.niu-model-mini-nav { display:flex; flex-wrap:wrap; gap:.75rem; margin-top: 1rem; }
.niu-model-mini-link {
    padding: .45rem .9rem;
    border-radius: 999px;
    background: rgba(0,0,0,.05);
    color:#333;
    text-decoration:none;
    font-size:.9rem;
}
.niu-model-mini-link:hover { text-decoration: underline; }

.niu-model-cta-strip {
    background: linear-gradient(135deg, #f5f5f7, #e9ecf1);
    border-radius: 18px;
    padding: 2.5rem 2rem;
}
.niu-model-cta-inner {
    max-width: 820px;
    margin: 0 auto;
    text-align: center;
}

@media (max-width: 767.98px) {
    .niu-model-hero { padding: 2.2rem 1.5rem; }
    .niu-model-image { max-width: 100%; margin-top: .5rem; }
}