:root {
    --navy: #102a43;
    --navy-deep: #071b2d;
    --blue: #0874c9;
    --blue-dark: #055c9f;
    --green: #77b82a;
    --ink: #17212b;
    --muted: #657585;
    --line: #dbe3ea;
    --light: #f3f7fa;
    --white: #fff;
    --shadow: 0 18px 50px rgba(15, 42, 67, .1);
}

html { scroll-behavior: smooth; }
body { color: var(--ink); font-family: "Segoe UI", Arial, sans-serif; line-height: 1.65; }
a { color: var(--blue); text-decoration: none; }
a:hover { color: var(--blue-dark); }
h1, h2, h3, h4 { color: var(--navy); font-weight: 750; letter-spacing: -.025em; }
.btn { border-radius: .45rem; font-weight: 700; padding: .7rem 1.15rem; }
.btn-lg { padding: .9rem 1.4rem; }
.btn-primary { background: var(--blue); border-color: var(--blue); }
.btn-primary:hover { background: var(--blue-dark); border-color: var(--blue-dark); }
.btn-outline-primary { color: var(--blue); border-color: var(--blue); }
.topbar { background: var(--navy-deep); color: #c7d8e8; font-size: .82rem; }
.topbar a { color: #fff; font-weight: 700; }
.navbar { min-height: 90px; }
.navbar-brand { color: var(--navy); line-height: 1; }
.navbar-brand small { color: var(--blue); display: block; font-size: .62rem; letter-spacing: .22em; margin-top: 4px; }
.brand-mark { align-items: center; background: var(--blue); border-radius: .4rem; color: #fff; display: inline-flex; font-size: .9rem; font-weight: 800; height: 40px; justify-content: center; width: 40px; }
.site-logo { background: #fff; display: block; height: auto; max-width: 100%; width: 500px; }
.login-logo { background: #fff; display: block; height: auto; max-width: 300px; width: 100%; }
.nav-link { color: var(--navy); font-weight: 650; margin: 0 .35rem; }
.nav-link.active { color: var(--blue) !important; }
.hero { background: var(--navy-deep); color: #fff; overflow: hidden; position: relative; }
.hero::before { background: linear-gradient(90deg, rgba(7,27,45,.98) 0%, rgba(7,27,45,.86) 47%, rgba(7,27,45,.52) 100%), linear-gradient(0deg, rgba(7,27,45,.85), rgba(7,27,45,.08) 42%), url("../images/services/golf-cart-sales.jpg") center right / cover no-repeat; content: ""; inset: 0; position: absolute; }
.hero::after { background: linear-gradient(135deg, rgba(8,116,201,.22), transparent 38%), linear-gradient(0deg, rgba(119,184,42,.16), transparent 34%); content: ""; inset: 0; position: absolute; }
.hero .container { position: relative; z-index: 1; }
.hero-layout { padding: 5rem 0; }
.min-vh-75 { min-height: 75vh; }
.min-vh-60 { min-height: 60vh; }
.eyebrow { color: #9ed7ff; display: block; font-size: .78rem; font-weight: 800; letter-spacing: .16em; margin-bottom: .8rem; text-transform: uppercase; }
.hero h1, .star-hero h1 { color: #fff; font-size: clamp(3rem, 6.3vw, 5.25rem); line-height: 1; max-width: 760px; text-wrap: balance; }
.hero h1 span, .star-hero h1 span { color: #86c638; }
.hero .lead { color: #d8e7f2; font-size: clamp(1.1rem, 1.8vw, 1.35rem); max-width: 720px; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 1.8rem; }
.hero-actions .btn { min-width: 175px; }
.hero-proof { border-top: 1px solid rgba(255,255,255,.24); display: grid; gap: 1rem; grid-template-columns: repeat(3, minmax(0, 1fr)); margin-top: 2.4rem; max-width: 780px; padding-top: 1.4rem; }
.hero-proof span { color: #c7d8e8; font-size: .88rem; line-height: 1.35; }
.hero-proof strong { color: #fff; display: block; font-size: .78rem; letter-spacing: .1em; margin-bottom: .18rem; text-transform: uppercase; }
.hero-trust { display: flex; flex-wrap: wrap; gap: 1.7rem; }
.hero-trust span { color: #d8e5ef; font-size: .85rem; font-weight: 750; letter-spacing: .08em; text-transform: uppercase; }
.hero-feature { background: rgba(4, 20, 33, .9); border: 1px solid rgba(158,215,255,.34); border-radius: .8rem; box-shadow: 0 30px 70px rgba(0,0,0,.28); color: #fff; margin-left: auto; max-width: 390px; padding: 1.25rem; }
.hero-feature img { background: #fff; border-radius: .55rem; display: block; height: auto; width: 100%; }
.hero-feature h2 { color: #fff; font-size: 1.55rem; margin-top: 1.15rem; text-shadow: 0 2px 12px rgba(0,0,0,.35); }
.hero-feature p { color: #e5f0f8; margin-bottom: .75rem; }
.hero-feature a { color: #55baff; font-weight: 800; }
.hero-feature a:hover { color: #9ed7ff; }
.hero-card-label { background: var(--green); border-radius: 2rem; color: #173500; display: inline-block; font-size: .7rem; font-weight: 800; letter-spacing: .08em; margin-bottom: 1rem; padding: .35rem .7rem; text-transform: uppercase; }
.section-pad { padding: 6rem 0; }
.section-heading { max-width: 680px; }
.section-heading h2 { font-size: clamp(2rem, 4vw, 3.2rem); }
.section-heading p { color: var(--muted); font-size: 1.08rem; }
.service-card { border: 1px solid var(--line); border-radius: .75rem; display: flex; flex-direction: column; overflow: hidden; transition: transform .2s, box-shadow .2s; }
.service-card:hover { box-shadow: var(--shadow); transform: translateY(-4px); }
.service-image { display: block; height: 180px; object-fit: cover; width: 100%; }
.service-card-body { display: flex; flex: 1; flex-direction: column; padding: 1.75rem 2rem 2rem; }
.service-card h3 { font-size: 1.25rem; margin-bottom: .65rem; }
.service-card p { color: var(--muted); }
.service-card a { font-weight: 750; margin-top: auto; }
.inventory-card { background: #fff; border: 1px solid var(--line); border-radius: .8rem; box-shadow: 0 8px 25px rgba(15,42,67,.05); overflow: hidden; position: relative; transition: transform .2s, box-shadow .2s; }
.inventory-card:hover { box-shadow: var(--shadow); transform: translateY(-4px); }
.inventory-image { background: #e9f0f5; height: 245px; position: relative; }
.inventory-image img { height: 100%; object-fit: cover; width: 100%; }
.status-overlay { left: 1rem; position: absolute; top: 1rem; }
.price { color: var(--blue); font-size: 1.5rem; font-weight: 800; }
.cta-panel { align-items: center; background: linear-gradient(120deg, var(--blue), var(--navy)); border-radius: 1rem; color: #d7e8f5; display: flex; gap: 2rem; justify-content: space-between; padding: 3.5rem; }
.cta-panel h2 { color: #fff; max-width: 700px; }
.site-footer { background: var(--navy-deep); color: #9fb3c5; }
.site-footer a { color: #d6e3ed; display: block; margin-bottom: .4rem; }
.footer-bottom { background: #04131f; color: #7f97aa; font-size: .85rem; }
.footer-bottom a { color: #b9ccda; margin-bottom: 0; }
.page-hero { background: linear-gradient(120deg, var(--navy-deep), var(--navy)); color: #d0dfeb; padding: 5rem 0; }
.inventory-hero, .parts-hero, .service-hero, .contact-hero { min-height: 390px; position: relative; }
.inventory-hero { background: linear-gradient(90deg, rgba(4,18,31,.98) 0%, rgba(4,18,31,.9) 43%, rgba(4,18,31,.5) 72%, rgba(4,18,31,.75) 100%), url("../images/site/inventory-star-sirius-hero.png") center right / cover no-repeat; }
.parts-hero { background: linear-gradient(90deg, rgba(4,18,31,.98) 0%, rgba(4,18,31,.9) 43%, rgba(4,18,31,.5) 72%, rgba(4,18,31,.76) 100%), url("../images/site/parts-hero.png") center right / cover no-repeat; }
.service-hero { background: linear-gradient(90deg, rgba(4,18,31,.98) 0%, rgba(4,18,31,.9) 43%, rgba(4,18,31,.48) 72%, rgba(4,18,31,.72) 100%), url("../images/site/service-hero.png") center right / cover no-repeat; }
.contact-hero { background: linear-gradient(90deg, rgba(4,18,31,.98) 0%, rgba(4,18,31,.9) 43%, rgba(4,18,31,.5) 72%, rgba(4,18,31,.72) 100%), url("../images/site/contact-hero.png") center right / cover no-repeat; }
.inventory-hero .container, .parts-hero .container, .service-hero .container, .contact-hero .container { position: relative; z-index: 1; }
.inventory-hero .eyebrow, .parts-hero .eyebrow, .service-hero .eyebrow, .contact-hero .eyebrow { color: #9ed7ff; }
.inventory-hero h1, .inventory-hero p, .parts-hero h1, .parts-hero p, .service-hero h1, .service-hero p, .contact-hero h1, .contact-hero p { text-shadow: 0 3px 18px rgba(0,0,0,.45); }
.page-hero h1 { color: #fff; font-size: clamp(2.5rem, 5vw, 4.5rem); }
.page-hero p { font-size: 1.12rem; margin-bottom: 0; max-width: 650px; }
.policy-content { margin: 0 auto; max-width: 900px; }
.policy-content h2 { border-top: 1px solid var(--line); font-size: 1.7rem; margin-top: 2.75rem; padding-top: 2rem; }
.policy-content h3 { font-size: 1.2rem; margin-top: 2rem; }
.policy-content p, .policy-content li { color: #445363; }
.policy-content ul { padding-left: 1.4rem; }
.policy-content li { margin-bottom: .45rem; padding-left: .25rem; }
.policy-contact { background: var(--light); border-left: 4px solid var(--green); border-radius: .4rem; margin-top: 3rem; padding: 1.75rem 2rem; }
.policy-contact h2 { border-top: 0; margin-top: 0; padding-top: 0; }
.policy-contact p:last-child { margin-bottom: 0; }
.filter-panel, .form-card, .admin-panel { background: #fff; border: 1px solid var(--line); border-radius: .8rem; box-shadow: var(--shadow); padding: 2rem; }
.form-control, .form-select { border-color: #c9d5df; border-radius: .4rem; min-height: 46px; }
.form-control:focus, .form-select:focus { border-color: var(--blue); box-shadow: 0 0 0 .2rem rgba(8,116,201,.13); }
.form-label { color: var(--navy); font-size: .88rem; font-weight: 700; }
.empty-state { background: var(--light); border: 1px dashed #b4c6d5; border-radius: .8rem; padding: 3rem; text-align: center; }
.back-link { font-weight: 700; }
.detail-gallery { position: relative; }
.detail-main-image { background: var(--light); border-radius: .8rem; height: 500px; overflow: hidden; }
.detail-main-image img { height: 100%; object-fit: contain; width: 100%; }
.gallery-arrow { align-items: center; background: rgba(7, 27, 45, .72); border: 0; border-radius: 50%; color: #fff; display: flex; font-size: 2.3rem; font-weight: 500; height: 48px; justify-content: center; line-height: 1; padding: 0 0 .18rem; position: absolute; top: 50%; transform: translateY(-50%); transition: background .2s, transform .2s; width: 48px; }
.gallery-arrow:hover, .gallery-arrow:focus { background: var(--blue); transform: translateY(-50%) scale(1.04); }
.gallery-arrow-prev { left: 1rem; }
.gallery-arrow-next { right: 1rem; }
.thumbnail-row { display: flex; gap: .8rem; margin-top: 1rem; overflow-x: auto; }
.thumbnail-row button { background: var(--light); border: 2px solid transparent; border-radius: .4rem; height: 80px; padding: 0; width: 110px; }
.thumbnail-row button:hover, .thumbnail-row button:focus, .thumbnail-row button.active { border-color: var(--blue); }
.thumbnail-row img { height: 100%; object-fit: cover; width: 100%; }
.detail-price { color: var(--blue); font-size: 2.3rem; font-weight: 800; }
.spec-grid { display: grid; gap: 1px; grid-template-columns: repeat(2, 1fr); background: var(--line); border: 1px solid var(--line); }
.spec-grid div { background: #fff; padding: .9rem; }
.spec-grid span, .contact-list span { color: var(--muted); display: block; font-size: .72rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.spec-grid strong { color: var(--navy); }
.feature-list { list-style: none; padding: 0; }
.feature-list li { border-bottom: 1px solid var(--line); padding: .7rem 0 .7rem 1.7rem; position: relative; }
.feature-list li::before { color: var(--green); content: "\2713"; font-weight: 900; left: 0; position: absolute; }
.parts-grid { display: grid; gap: 1px; grid-template-columns: repeat(5, 1fr); background: var(--line); border: 1px solid var(--line); }
.parts-grid div { background: #fff; min-height: 145px; padding: 1.5rem; }
.parts-grid span, .model-card span { color: var(--blue); font-size: .7rem; font-weight: 850; letter-spacing: .12em; }
.parts-grid h3 { font-size: 1.05rem; margin-top: 2rem; }
.star-hero { background: linear-gradient(90deg, rgba(4,18,31,.92) 0%, rgba(4,18,31,.72) 45%, rgba(4,18,31,.2) 100%), var(--star-hero-image), linear-gradient(115deg, #06243d, #07598f); background-position: center; background-size: cover; color: #d4e7f4; }
.star-hero .lead { color: #e2eef6; font-size: clamp(1.1rem, 1.8vw, 1.35rem); max-width: 680px; text-shadow: 0 2px 14px rgba(0,0,0,.35); }
.mini-feature { background: var(--light); border-left: 4px solid var(--green); min-height: 170px; padding: 1.5rem; }
.mini-feature h3 { font-size: 1.15rem; }
.model-card { background: #fff; border: 1px solid var(--line); border-radius: .8rem; overflow: hidden; }
.model-image { background: #e8f0f5; height: 220px; }
.model-image img { height: 100%; object-fit: contain; width: 100%; }
.contact-list div { border-bottom: 1px solid var(--line); padding: 1rem 0; }
.contact-list strong { color: var(--navy); display: block; margin-top: .2rem; }
.selected-cart { background: var(--light); border-left: 4px solid var(--green); border-radius: .4rem; padding: 1rem 1.2rem; }
.selected-cart strong, .selected-cart span:last-child { display: block; }
.selected-cart strong { color: var(--navy); font-size: 1.15rem; }
.selected-cart span:last-child { color: var(--muted); margin-top: .2rem; }
.contact-map { border-radius: .8rem; height: 260px; overflow: hidden; }
.contact-map iframe { border: 0; height: 100%; width: 100%; }
.login-page { align-items: center; background: linear-gradient(135deg, var(--navy-deep), var(--navy)); display: flex; justify-content: center; min-height: 100vh; padding: 1.5rem; }
.login-card { background: #fff; border-radius: 1rem; box-shadow: 0 30px 80px rgba(0,0,0,.3); max-width: 460px; padding: 2.5rem; width: 100%; }
.admin-body { background: #f1f5f8; }
.admin-nav { background: var(--navy-deep); min-height: 68px; }
.admin-nav .admin-brand { color: #fff; font-size: 1.15rem; font-weight: 800; letter-spacing: -.01em; }
.admin-nav .admin-brand:hover, .admin-nav .admin-brand:focus { color: #fff; }
.admin-logo { background: #fff; border-radius: .3rem; display: block; height: 42px; object-fit: contain; padding: .2rem; width: 180px; }
.admin-nav .admin-brand span { color: #8fd2ff; font-size: .75rem; letter-spacing: .1em; text-transform: uppercase; }
.admin-nav .nav-link { color: #d9e8f3; margin: 0 .2rem; }
.admin-nav .nav-link:hover, .admin-nav .nav-link:focus { color: #fff; }
.admin-nav .nav-link.active { color: #fff !important; text-decoration: underline; text-decoration-color: #50b6ff; text-decoration-thickness: 3px; text-underline-offset: 7px; }
.request-tabs .nav-link.active { color: #fff !important; }
.user-status { min-width: 72px; }
.metric-card { background: #fff; border: 1px solid var(--line); border-radius: .7rem; box-shadow: 0 8px 20px rgba(15,42,67,.05); color: var(--ink); display: block; padding: 1.5rem; }
.metric-card span { color: var(--muted); display: block; font-size: .82rem; font-weight: 750; text-transform: uppercase; }
.metric-card strong { color: var(--navy); display: block; font-size: 2.5rem; line-height: 1.2; margin: .5rem 0; }
.metric-card small { color: var(--blue); font-weight: 700; }
.admin-cart-cell { align-items: center; display: flex; gap: .8rem; min-width: 260px; }
.admin-cart-cell img { background: var(--light); border-radius: .3rem; height: 55px; object-fit: cover; width: 75px; }
.admin-cart-cell small { color: var(--muted); display: block; }
.request-table td { min-width: 140px; vertical-align: top; }
.request-table td:nth-child(3), .request-table td:nth-child(4) { max-width: 320px; }
.pickup-schedule-form { display: grid; gap: .45rem; min-width: 220px; }
.pickup-schedule-form .route-order-input { max-width: 78px; }
.calendar-toolbar { align-items: center; display: flex; justify-content: space-between; margin-bottom: 1.25rem; }
.pickup-calendar-scroll { overflow-x: auto; }
.pickup-calendar { display: grid; gap: 1px; grid-template-columns: repeat(7, minmax(130px, 1fr)); min-width: 910px; background: var(--line); border: 1px solid var(--line); overflow: hidden; }
.calendar-weekday { background: var(--navy); color: #fff; font-size: .75rem; font-weight: 800; letter-spacing: .08em; padding: .55rem; text-align: center; text-transform: uppercase; }
.calendar-day { background: #fff; min-height: 145px; padding: .55rem; }
.calendar-day.is-outside { background: #f5f7f9; color: #8795a1; }
.calendar-day.is-today { box-shadow: inset 0 0 0 3px var(--blue); }
.calendar-date { align-items: center; display: flex; font-weight: 800; justify-content: space-between; margin-bottom: .45rem; }
.calendar-date a { align-items: center; background: var(--light); border-radius: 50%; display: inline-flex; font-size: 1rem; height: 24px; justify-content: center; width: 24px; }
.calendar-pickup { background: #e8f4fc; border-left: 3px solid var(--blue); border-radius: .25rem; font-size: .76rem; line-height: 1.3; margin-bottom: .4rem; padding: .45rem; }
.calendar-pickup strong, .calendar-pickup small { display: block; }
.calendar-pickup small { color: var(--muted); margin-top: .15rem; }
.calendar-route-link { display: block; font-size: .72rem; font-weight: 700; margin-top: .5rem; }
.route-print-page { background: #eef2f5; color: #111; }
.route-header { align-items: flex-start; border-bottom: 3px solid var(--navy); display: flex; justify-content: space-between; padding-bottom: 1rem; }
.route-summary { font-weight: 800; padding: 1rem 0; }
.route-stop { background: #fff; border: 1px solid #bfc9d2; display: grid; grid-template-columns: 60px 1fr; margin-bottom: 1rem; page-break-inside: avoid; }
.route-stop-number { align-items: center; background: var(--navy); color: #fff; display: flex; font-size: 1.8rem; font-weight: 800; justify-content: center; }
.route-stop-content { padding: 1rem 1.25rem; }
.route-columns { display: grid; gap: 1rem; grid-template-columns: 1.5fr 1fr 1fr; margin-top: 1rem; }
.route-columns span, .route-service span { color: var(--muted); display: block; font-size: .68rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.route-columns strong { display: block; }
.route-service { border-top: 1px solid var(--line); margin-top: 1rem; padding-top: .75rem; }
.route-checks { border-top: 1px dashed #9aa8b3; display: flex; gap: 2rem; margin-top: .9rem; padding-top: .75rem; }
.request-cart-details { background: var(--light); border-left: 3px solid var(--blue); border-radius: .3rem; padding: .75rem; }
.request-cart-details strong, .request-cart-details small, .request-cart-details a { display: block; }
.request-cart-details small { color: var(--muted); margin: .35rem 0; }
.admin-image-grid { display: flex; flex-wrap: wrap; gap: 1rem; }
.admin-image-grid div { border: 1px solid var(--line); border-radius: .4rem; overflow: hidden; text-align: center; }
.admin-image-grid img { display: block; height: 110px; object-fit: cover; width: 150px; }
.admin-image-grid a { display: block; font-size: .8rem; padding: .35rem; }
.admin-guide-accordion { display: grid; gap: 1rem; }
.admin-guide-item { border: 1px solid var(--line) !important; border-radius: .7rem !important; box-shadow: 0 8px 20px rgba(15,42,67,.05); overflow: hidden; }
.admin-guide-item .accordion-button { align-items: flex-start; gap: 1rem; padding: 1.25rem 1.5rem; }
.admin-guide-item .accordion-button strong, .admin-guide-item .accordion-button small { display: block; }
.admin-guide-item .accordion-button strong { color: var(--navy); font-size: 1.08rem; }
.admin-guide-item .accordion-button small { color: var(--muted); font-size: .9rem; font-weight: 500; line-height: 1.45; margin-top: .25rem; }
.admin-guide-item .accordion-button:not(.collapsed) { background: #eef7fd; box-shadow: none; }
.admin-guide-steps { counter-reset: guide-step; list-style: none; padding-left: 0; }
.admin-guide-steps li { border-bottom: 1px solid var(--line); counter-increment: guide-step; padding: .85rem 0 .85rem 2.8rem; position: relative; }
.admin-guide-steps li::before { align-items: center; background: var(--blue); border-radius: 50%; color: #fff; content: counter(guide-step); display: inline-flex; font-size: .82rem; font-weight: 800; height: 28px; justify-content: center; left: 0; position: absolute; top: .8rem; width: 28px; }
.admin-guide-tips { list-style: none; padding-left: 0; }
.admin-guide-tips li { border-bottom: 1px solid var(--line); padding: .65rem 0 .65rem 1.5rem; position: relative; }
.admin-guide-tips li::before { color: var(--green); content: "\2713"; font-weight: 900; left: 0; position: absolute; }
.help-sidebar { position: sticky; top: 1rem; }

@media (min-width: 992px) {
    .admin-nav { min-height: 68px; }
    .admin-nav .navbar-collapse { padding: 0; }
}
@media (max-width: 991px) {
    .navbar-collapse { padding: 1rem 0; }
    .hero-layout { padding: 3rem 0; }
    .hero-feature { margin-left: 0; max-width: 520px; }
    .parts-grid { grid-template-columns: repeat(2, 1fr); }
    .cta-panel { align-items: flex-start; flex-direction: column; }
}
@media (max-width: 1199px) {
    .navbar { min-height: 84px; }
    .navbar-brand { max-width: calc(100% - 70px); }
    .navbar-collapse { padding: 1rem 0; }
}
@media (max-width: 575px) {
    .navbar { min-height: 76px; }
    .site-logo { width: 300px; }
    .section-pad { padding: 4rem 0; }
    .hero h1, .star-hero h1 { font-size: 2.85rem; }
    .hero-actions .btn { width: 100%; }
    .hero-proof { grid-template-columns: 1fr; }
    .hero-feature img { height: auto; }
    .parts-grid { grid-template-columns: 1fr; }
    .detail-main-image { height: 330px; }
    .gallery-arrow { font-size: 1.9rem; height: 40px; width: 40px; }
    .gallery-arrow-prev { left: .65rem; }
    .gallery-arrow-next { right: .65rem; }
    .cta-panel, .form-card, .filter-panel, .admin-panel { padding: 1.4rem; }
}
@media (max-width: 767px) {
    .route-header { gap: 1rem; }
    .route-columns { grid-template-columns: 1fr; }
    .route-checks { flex-direction: column; gap: .35rem; }
}
@media print {
    @page { margin: .45in; }
    .route-print-page { background: #fff; font-size: 10pt; }
    .route-print-actions { display: none !important; }
    .route-print-page .container { max-width: none; padding: 0 !important; }
    .route-header { margin-bottom: .15in; }
    .route-stop { margin-bottom: .12in; }
    .route-stop-content { padding: .12in .16in; }
    .route-stop-number { print-color-adjust: exact; -webkit-print-color-adjust: exact; }
    .route-columns { gap: .12in; margin-top: .08in; }
    .route-service, .route-checks { margin-top: .08in; padding-top: .06in; }
    .route-checks { gap: .2in; }
    .route-stop a { color: #111; text-decoration: none; }
}
