:root {
    --sp-primary: #173f5f;
    --sp-primary-dark: #0d2d46;
    --sp-accent: #f59e0b;
    --sp-accent-dark: #d97706;
    --sp-success: #0f9d76;
    --sp-danger: #dc3545;
    --sp-ink: #172033;
    --sp-muted: #667085;
    --sp-bg: #f5f7fb;
    --sp-surface: #ffffff;
    --sp-border: #e4e8ef;
    --sp-shadow: 0 18px 45px rgba(23, 63, 95, .10);
}

html { scroll-behavior: smooth; }
body {
    background: var(--sp-bg);
    color: var(--sp-ink);
    font-family: "Plus Jakarta Sans", "Segoe UI", system-ui, sans-serif;
    font-size: 14px;
    line-height: 1.6;
}
h1, h2, h3, h4, h5, h6 {
    color: var(--sp-ink);
    font-family: "Plus Jakarta Sans", "Segoe UI", system-ui, sans-serif !important;
    font-weight: 700;
    letter-spacing: -.025em;
    line-height: 1.3;
    text-transform: none;
}
h1, .h1 { font-size: clamp(1.85rem, 3vw, 2.55rem) !important; }
h2, .h2 { font-size: clamp(1.55rem, 2.5vw, 2.1rem) !important; }
h3, .h3 { font-size: clamp(1.3rem, 2vw, 1.65rem) !important; }
h4, .h4 { font-size: 1.2rem !important; }
h5, .h5 { font-size: 1.05rem !important; }
h6, .h6 { font-size: .92rem !important; }
p, li, label, input, select, textarea, button { font-family: "Plus Jakarta Sans", "Segoe UI", system-ui, sans-serif !important; }
main p, main li { font-size: .9rem !important; }
a { text-decoration: none; }
.navbar {
    background: rgba(255, 255, 255, .96) !important;
    border: 0;
    border-bottom: 1px solid var(--sp-border);
    box-shadow: 0 8px 30px rgba(23, 63, 95, .06);
    padding: .8rem 0;
    backdrop-filter: blur(14px);
}
.navbar-brand { align-items: center; display: inline-flex; padding: 0; }
.navbar-brand img { height: 76px; max-width: 180px; object-fit: contain; width: auto; }
.nav-link {
    border: 0 !important;
    border-radius: .65rem;
    color: #344054 !important;
    font-size: .86rem;
    font-weight: 600;
    margin: 0 .1rem;
}
.nav-link:hover, .nav-link.active {
    background: #eef4f8;
    color: var(--sp-primary) !important;
}
.hero-section {
    background:
        radial-gradient(circle at 88% 18%, color-mix(in srgb, var(--sp-accent) 22%, transparent), transparent 28%),
        linear-gradient(135deg, #f4f8ff 0%, #fff 62%);
    border: 0;
    overflow: hidden;
    padding: 4.5rem 0;
    position: relative;
}
.hero-shell { align-items: center; display: grid; gap: clamp(2rem, 6vw, 6rem); grid-template-columns: minmax(0, 1.15fr) minmax(340px, .85fr); min-width: 0; }
.hero-copy { max-width: 720px; min-width: 0; position: relative; z-index: 2; }
.hero-kicker { align-items: center; background: #fff; border: 1px solid #dce5f1; border-radius: 999px; color: var(--sp-primary); display: inline-flex; font-size: .78rem; font-weight: 700; gap: .5rem; letter-spacing: .02em; margin-bottom: 1.25rem; padding: .55rem .85rem; box-shadow: 0 8px 24px rgba(23,63,95,.08); }
.hero-kicker i { color: var(--sp-accent); }
.hero-section h1 { color: var(--sp-primary-dark); font-size: clamp(2.6rem, 4.5vw, 4.4rem) !important; letter-spacing: -.055em; line-height: 1.05; margin-bottom: 1.2rem; max-width: 680px; overflow-wrap: anywhere; }
.hero-section h1 span { color: var(--sp-accent); }
.hero-section .hero-intro { color: var(--sp-muted); font-size: 1.02rem !important; line-height: 1.75; margin-bottom: 1.65rem; max-width: 650px; }
.hero-search-form { background: rgba(255,255,255,.96); border: 1px solid #dfe6ef; border-radius: 1.15rem; box-shadow: 0 22px 55px rgba(23,63,95,.13); padding: .75rem; }
.hero-search-main { align-items: center; display: grid; gap: .65rem; grid-template-columns: auto minmax(0,1fr) auto; }
.hero-search-main > i { color: var(--sp-primary); font-size: 1rem; margin-left: .65rem; }
.hero-search-main input { border: 0; color: var(--sp-ink); font-size: .92rem; min-width: 0; outline: 0; padding: .8rem .25rem; width: 100%; }
.hero-search-main button { align-items: center; background: var(--sp-accent); border: 0; border-radius: .75rem; color: #fff; display: inline-flex; font-size: .85rem; font-weight: 700; gap: .55rem; padding: .9rem 1.15rem; white-space: nowrap; }
.hero-search-main button:hover { background: var(--sp-primary-dark); }
.hero-search-filters { border-top: 1px solid #edf0f5; display: grid; gap: .55rem; grid-template-columns: repeat(3,minmax(0,1fr)); margin-top: .65rem; padding-top: .65rem; }
.hero-search-filters label { align-items: center; background: #f7f9fc; border: 1px solid #e7ebf1; border-radius: .7rem; display: flex; gap: .45rem; margin: 0; padding: 0 .7rem; }
.hero-search-filters label i { color: var(--sp-primary); font-size: .78rem; }
.hero-search-filters input, .hero-search-filters select { background: transparent; border: 0; color: #475467; font-size: .8rem; min-width: 0; outline: 0; padding: .72rem 0; width: 100%; }
.hero-trust { align-items: center; color: #475467; display: flex; flex-wrap: wrap; font-size: .78rem; font-weight: 600; gap: 1.1rem; margin-top: 1.25rem; }
.hero-trust i { color: var(--sp-success); margin-right: .3rem; }
.hero-visual { height: 390px; position: relative; }
.hero-visual-glow { background: color-mix(in srgb, var(--sp-accent) 22%, #fff); border-radius: 50%; filter: blur(1px); height: 320px; position: absolute; right: 4%; top: 7%; width: 320px; }
.hero-gear { color: var(--sp-primary); filter: drop-shadow(0 18px 28px rgba(23,63,95,.16)); line-height: 1; position: absolute; }
.hero-gear-large { font-size: 12.5rem; right: 12%; top: 23%; transform: rotate(-12deg); }
.hero-gear-small { color: var(--sp-accent); font-size: 5rem; right: 2%; top: 12%; transform: rotate(15deg); }
.hero-part-card { align-items: center; backdrop-filter: blur(12px); background: rgba(255,255,255,.94); border: 1px solid rgba(255,255,255,.9); border-radius: 1rem; box-shadow: 0 20px 45px rgba(23,63,95,.14); display: flex; gap: .8rem; padding: .85rem 1rem; position: absolute; z-index: 2; }
.hero-part-card-main { left: 0; top: 14%; }
.hero-part-card-dealers { bottom: 9%; right: 1%; }
.hero-part-icon { align-items: center; background: #edf2ff; border-radius: .75rem; color: var(--sp-primary); display: flex; height: 42px; justify-content: center; width: 42px; }
.hero-part-card small { color: var(--sp-muted); display: block; font-size: .67rem; margin-bottom: .12rem; }
.hero-part-card strong { color: var(--sp-primary-dark); display: block; font-size: .82rem; }
.hero-category-pill { align-items: center; background: var(--sp-primary-dark); border-radius: 999px; bottom: 18%; color: #fff; display: flex; font-size: .75rem; gap: .55rem; left: 4%; padding: .65rem .9rem; position: absolute; z-index: 3; }
.hero-category-pill i { color: var(--sp-accent); }
.card-cartoon, .login-bg {
    background: var(--sp-surface);
    border: 1px solid var(--sp-border) !important;
    border-radius: 1.1rem !important;
    box-shadow: var(--sp-shadow) !important;
    overflow: hidden;
    transition: transform .2s ease, box-shadow .2s ease;
}
.card-cartoon:hover {
    box-shadow: 0 22px 55px rgba(23, 63, 95, .14) !important;
    transform: translateY(-4px) !important;
}
.auth-alert { align-items: flex-start; border: 1px solid #fecaca; border-radius: .8rem; display: flex; gap: .75rem; margin: 1rem 0 1.25rem; padding: .9rem 1rem; }
.auth-alert > i { font-size: 1rem; margin-top: .18rem; }
.auth-alert strong { display: block; font-size: .84rem; margin-bottom: .2rem; }
.auth-alert p, .auth-alert ul { font-size: .78rem !important; line-height: 1.5; margin: 0; }
.auth-alert ul { padding-left: 1.1rem; }
.auth-form .is-invalid { border-color: #dc3545 !important; }
.auth-form .invalid-feedback { font-size: .74rem; margin-top: .35rem; }
.otp-verification-section { padding: 4rem 0; }
.otp-verification-card { background: #fff; border: 1px solid var(--sp-border); border-radius: 1.25rem; box-shadow: var(--sp-shadow); margin: 0 auto; max-width: 520px; padding: 2.5rem; text-align: center; }
.otp-verification-icon { align-items: center; background: #eef0ff; border-radius: 50%; color: var(--sp-primary); display: flex; font-size: 1.5rem; height: 68px; justify-content: center; margin: 0 auto 1rem; width: 68px; }
.otp-kicker { color: var(--sp-accent); display: block; font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.otp-verification-card h2 { margin: .4rem 0 .65rem; }
.otp-verification-card > p { color: var(--sp-muted); font-size: .85rem !important; }
.otp-form { margin-top: 1.5rem; text-align: left; }
.otp-form label { color: var(--sp-primary-dark); display: block; font-size: .78rem; font-weight: 700; margin-bottom: .45rem; }
.otp-input { font-size: 1.45rem !important; font-weight: 700; letter-spacing: .55rem; padding: .9rem 1rem !important; text-align: center; }
.otp-submit { gap: .55rem; margin-top: 1rem; width: 100%; }
.otp-resend { align-items: center; color: var(--sp-muted); display: flex; font-size: .76rem; gap: .4rem; justify-content: center; margin-top: 1.25rem; }
.otp-resend form { margin: 0; }
.otp-resend button { background: none; border: 0; color: var(--sp-primary); font-size: .76rem; font-weight: 700; padding: 0; }
@media (max-width: 575px) {
    .otp-verification-section { padding: 2.25rem 0; }
    .otp-verification-card { padding: 1.5rem 1rem; }
}
.btn-cartoon, .btn-primary-cartoon, .btn-danger-cartoon, .btn-success-cartoon,
.btn-dark-cartoon, .btn-white-cartoon, .thm-btn-two {
    border: 0 !important;
    border-radius: .7rem !important;
    box-shadow: none !important;
    font-family: inherit !important;
    font-size: .86rem !important;
    font-weight: 600 !important;
    letter-spacing: 0 !important;
    padding: .7rem 1.15rem !important;
    text-transform: none !important;
    transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.btn-cartoon:hover, .thm-btn-two:hover {
    box-shadow: 0 9px 20px rgba(23, 63, 95, .18) !important;
    transform: translateY(-1px) !important;
}
.btn-primary-cartoon, .btn-danger-cartoon, .thm-btn-two, .btn-primary { background: var(--sp-accent) !important; border-color: var(--sp-accent) !important; color: #fff !important; }
.btn-primary-cartoon:hover, .btn-danger-cartoon:hover, .thm-btn-two:hover, .btn-primary:hover { background: var(--sp-primary-dark) !important; border-color: var(--sp-primary-dark) !important; }
.btn-success-cartoon { background: var(--sp-success) !important; color: #fff !important; }
.btn-dark-cartoon { background: var(--sp-primary-dark) !important; color: #fff !important; }
.btn-white-cartoon { background: #fff !important; color: var(--sp-primary) !important; border: 1px solid var(--sp-border) !important; }
.form-control, .form-select {
    background-color: #fff;
    border: 1px solid #d6dce5 !important;
    border-radius: .7rem !important;
    font-weight: 500 !important;
    font-size: .88rem !important;
    min-height: 46px;
}
.form-control:focus, .form-select:focus {
    border-color: var(--sp-primary) !important;
    box-shadow: 0 0 0 .2rem rgba(23, 63, 95, .12) !important;
}
.section-title { font-size: clamp(1.5rem, 2.5vw, 2rem) !important; }
.section-title::after {
    background: var(--sp-accent);
    border: 0 !important;
    border-radius: 999px;
    height: 4px;
    width: 55px;
}
.badge-cartoon, .badge {
    border: 0 !important;
    border-radius: 999px !important;
    font-size: .78rem !important;
    font-weight: 650;
}
.page-header-modern {
    background: linear-gradient(120deg, var(--sp-primary-dark) 0%, var(--sp-primary) 72%, var(--sp-accent) 145%);
    color: #fff;
    overflow: hidden;
    padding: 2rem 0;
    position: relative;
}
.page-header-pattern {
    background-image:
        radial-gradient(circle at 15% 40%, rgba(255,255,255,.12) 0 2px, transparent 3px),
        linear-gradient(115deg, transparent 0 58%, rgba(255,255,255,.06) 58% 59%, transparent 59% 100%);
    background-size: 32px 32px, 100% 100%;
    inset: 0;
    opacity: .55;
    position: absolute;
}
.page-header-modern::after {
    background: rgba(255,255,255,.06);
    border-radius: 50%;
    content: "";
    height: 220px;
    position: absolute;
    right: 8%;
    top: -155px;
    width: 220px;
}
.page-header-content { align-items: center; display: flex; justify-content: space-between; position: relative; z-index: 1; }
.page-header-copy { align-items: center; display: flex; gap: 1rem; }
.page-header-icon {
    align-items: center;
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.2);
    border-radius: .9rem;
    display: flex;
    flex: 0 0 52px;
    font-size: 1.05rem;
    height: 52px;
    justify-content: center;
}
.page-breadcrumb { align-items: center; display: flex; gap: .55rem; list-style: none; margin: 0 0 .35rem; padding: 0; }
.page-breadcrumb li { color: rgba(255,255,255,.62); font-size: .7rem !important; font-weight: 500; }
.page-breadcrumb li + li::before { color: rgba(255,255,255,.38); content: "/"; margin-right: .55rem; }
.page-breadcrumb a { color: rgba(255,255,255,.82); }
.page-breadcrumb a:hover { color: #fff; }
.page-breadcrumb i { font-size: .62rem; margin-right: .25rem; }
.page-header-modern h1 { color: #fff; font-size: clamp(1.45rem, 2.5vw, 1.9rem) !important; letter-spacing: -.03em; margin: 0; }
.page-header-modern p { color: rgba(255,255,255,.68) !important; font-size: .78rem !important; margin: .3rem 0 0; }
.page-header-home { align-items: center; border: 1px solid rgba(255,255,255,.2); border-radius: 50%; color: #fff; display: flex; height: 38px; justify-content: center; width: 38px; }
.page-header-home:hover { background: #fff; color: var(--sp-primary); }

/* Normalize older module pages that still use the legacy inner banner markup. */
.inner-banner {
    background: linear-gradient(120deg, var(--sp-primary-dark), var(--sp-primary)) !important;
    min-height: 140px !important;
    overflow: hidden;
    padding: 1.8rem 0 !important;
    position: relative;
}
.inner-banner-img { inset: 0 !important; opacity: .06 !important; position: absolute !important; }
.inner-banner-df { align-items: flex-start !important; display: flex !important; flex-direction: column !important; justify-content: center !important; min-height: 84px !important; position: relative; z-index: 1; }
.inner-banner-taitel, .inner-banner h1 { color: #fff !important; font-size: clamp(1.45rem, 2.5vw, 1.9rem) !important; margin: 0 0 .45rem !important; padding: 0 !important; }
.inner-banner .breadcrumb { background: transparent !important; margin: 0 !important; padding: 0 !important; }
.inner-banner .breadcrumb-item, .inner-banner .breadcrumb-item a { color: rgba(255,255,255,.7) !important; font-size: .7rem !important; }
.inner-banner .breadcrumb-item.active { color: #fff !important; }
.inner-banner .breadcrumb-item + .breadcrumb-item::before { color: rgba(255,255,255,.4) !important; }
.login { padding: 4rem 0; }
.login-bg { padding: 2rem; }
.login-form-item { margin-bottom: 1rem; }
.login-form-inner { position: relative; }
.login-form-inner .icon { bottom: 12px; cursor: pointer; position: absolute; right: 15px; }
.login-img img { border-radius: 1rem; height: 100%; object-fit: cover; width: 100%; }
.footer-cta { background: #f5f6fc; padding: 0 0 2.5rem; }
.footer-cta-inner {
    align-items: center;
    background: linear-gradient(125deg, var(--sp-primary) 0%, var(--sp-primary-dark) 100%);
    border-radius: 1.25rem;
    box-shadow: 0 24px 60px rgba(24,25,95,.18);
    color: #fff;
    display: grid;
    gap: 1.2rem;
    grid-template-columns: auto minmax(0, 1fr) auto;
    padding: 1.6rem 1.8rem;
}
.footer-cta-icon { align-items: center; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.18); border-radius: .9rem; display: flex; font-size: 1.1rem; height: 48px; justify-content: center; width: 48px; }
.footer-cta-copy span { color: rgba(255,255,255,.68); display: block; font-size: .72rem; font-weight: 700; letter-spacing: .08em; margin-bottom: .35rem; text-transform: uppercase; }
.footer-cta-copy h2 { color: #fff; font-size: 1.15rem !important; letter-spacing: -.015em; margin: 0; max-width: 650px; }
.footer-cta-actions { align-items: center; display: flex; gap: .6rem; }
.footer-cta-actions a { border-radius: .65rem; font-size: .78rem; font-weight: 700; padding: .68rem .9rem; white-space: nowrap; }
.footer-cta-primary { background: #fff; color: var(--sp-primary-dark); }
.footer-cta-primary:hover { background: #f2f2ff; color: var(--sp-primary); }
.footer-cta-secondary { border: 1px solid rgba(255,255,255,.32); color: #fff; }
.footer-cta-secondary:hover { background: rgba(255,255,255,.1); color: #fff; }
footer.site-footer {
    background: #11133f;
    border: 0;
    color: #c4c7dc;
    margin-top: 0;
    padding: 3.25rem 0 1.25rem;
}
.footer-main { display: grid; gap: 4rem; grid-template-columns: minmax(280px, .9fr) minmax(480px, 1.35fr); }
.footer-company { max-width: 390px; }
.footer-brand { align-items: center; color: #fff; display: inline-flex; gap: .85rem; }
.footer-brand img { background: #fff; border-radius: 50%; height: 62px; object-fit: contain; padding: 2px; width: 62px; }
.footer-brand span, .footer-brand strong, .footer-brand small { display: block; }
.footer-brand strong { color: #fff; font-size: .94rem; font-weight: 700; }
.footer-brand small { color: #858ba9; font-size: .68rem; font-weight: 500; margin-top: .15rem; }
.footer-about { color: #a8acc4 !important; font-size: .8rem !important; line-height: 1.75; margin: 1.15rem 0 0; max-width: 360px; }

.home-about-section { background: #f7f8ff; padding: 2rem 0 3rem; }
.home-about-card { align-items: center; background: #fff; border: 3px solid #111; border-radius: 20px; box-shadow: 7px 7px 0 #111; display: grid; gap: 1.5rem; grid-template-columns: 84px 1fr 220px; padding: 2rem; }
.home-about-mark { align-items: center; background: var(--sp-primary); border: 2px solid #111; border-radius: 18px; color: #fff; display: flex; font-size: 2rem; height: 78px; justify-content: center; width: 78px; }
.home-about-kicker { color: var(--sp-primary); display: block; font-size: .73rem; font-weight: 800; letter-spacing: .1em; margin-bottom: .45rem; text-transform: uppercase; }
.home-about-copy h2 { color: var(--sp-primary-dark); font-size: clamp(1.45rem, 2.4vw, 2.15rem) !important; margin-bottom: .65rem; }
.home-about-copy p { color: #596078; font-size: .9rem; line-height: 1.75; margin-bottom: 1rem; }
.home-about-link { align-items: center; color: var(--sp-primary); display: inline-flex; font-size: .84rem; font-weight: 800; gap: .55rem; text-decoration: none; }
.home-about-link:hover { color: var(--sp-primary-dark); gap: .8rem; }
.home-about-fact { background: #f1f2ff; border: 2px solid var(--sp-primary); border-radius: 14px; padding: 1.25rem; }
.home-about-fact strong { color: var(--sp-primary); display: block; font-size: 1.25rem; margin-bottom: .35rem; }
.home-about-fact span { color: #555d78; font-size: .78rem; line-height: 1.5; }
.office-bearers-section { background: linear-gradient(180deg, #f7f8ff 0%, #eef1fb 100%); padding: .5rem 0 4rem; }
.office-bearers-heading { border-top: 1px solid #d9deeb; margin-bottom: 2rem; padding-top: 2.25rem; text-align: center; }
.office-bearers-heading > span { color: var(--sp-primary); display: block; font-size: .72rem; font-weight: 800; letter-spacing: .12em; margin-bottom: .4rem; text-transform: uppercase; }
.office-bearers-heading h2 { color: var(--sp-primary-dark); font-size: clamp(1.7rem, 3vw, 2.4rem) !important; margin: 0 0 .45rem; }
.office-bearers-heading p { color: #667085; font-size: .88rem; margin: 0 auto; max-width: 570px; }
.office-bearers-grid { display: grid; gap: 18px; grid-template-columns: repeat(6, minmax(0, 1fr)); }
.office-bearer-card { background: #fff; border: 1px solid #d9e0eb; border-radius: 18px; box-shadow: 0 10px 28px rgba(29, 48, 79, .1); display: flex; flex-direction: column; min-width: 0; overflow: hidden; padding: 16px 12px 15px; position: relative; text-align: center; transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease; }
.office-bearer-card::before { background: linear-gradient(90deg, var(--sp-primary), var(--sp-accent)); content: ""; height: 4px; left: 0; position: absolute; right: 0; top: 0; }
.office-bearer-card:hover { border-color: rgba(47,49,147,.35); box-shadow: 0 16px 34px rgba(29, 48, 79, .17); transform: translateY(-5px); }
.office-bearer-photo { aspect-ratio: 1; background: #eef3f8; border: 5px solid #f0f3f9; border-radius: 50%; box-shadow: 0 0 0 2px rgba(47,49,147,.12); margin: 3px auto 15px; max-width: 150px; overflow: hidden; width: 100%; }
.office-bearer-photo img { height: 100%; object-fit: cover; object-position: center; width: 100%; }
.office-bearer-info { align-items: center; display: flex; flex: 1; flex-direction: column; justify-content: space-between; min-height: 82px; }
.office-bearer-card h3 { color: #102a43; font-size: .8rem !important; font-weight: 800; line-height: 1.4; margin: 0 0 .8rem; overflow-wrap: normal; text-transform: uppercase; word-break: normal; }
.office-bearer-role { background: #f0f1ff; border: 1px solid #d9dcff; border-radius: 999px; color: var(--sp-primary); display: inline-flex; font-size: .7rem; font-weight: 700; justify-content: center; line-height: 1.3; padding: .45rem .7rem; width: fit-content; }
.content-page-section { background: #f7f8fc; padding: 3rem 0 4rem; }
.content-page-card { background: #fff; border: 2px solid #111; border-radius: 18px; box-shadow: 7px 7px 0 #111; margin: 0 auto; max-width: 1000px; padding: clamp(1.5rem, 4vw, 3rem); }
.content-page-heading { align-items: center; border-bottom: 2px solid #e5e7ef; display: flex; gap: 1rem; margin-bottom: 1.8rem; padding-bottom: 1.4rem; }
.content-page-icon { align-items: center; background: var(--sp-primary); border-radius: 12px; color: #fff; display: flex; flex: 0 0 54px; font-size: 1.2rem; height: 54px; justify-content: center; }
.content-page-heading span { color: var(--sp-primary); font-size: .72rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.content-page-heading h2 { color: var(--sp-primary-dark); font-size: clamp(1.35rem, 3vw, 2rem) !important; margin: .25rem 0 0; }
.content-page-body, .legal-content { color: #454c60; font-size: .94rem; line-height: 1.85; }
.content-page-body p, .legal-content p { margin-bottom: 1.15rem; }
.content-page-body h3, .content-page-body h4, .legal-content h3, .legal-content h4 { color: var(--sp-primary-dark); margin: 1.7rem 0 .7rem; }
.legal-content ul, .content-page-body ul { padding-left: 1.3rem; }
.legal-content li, .content-page-body li { margin-bottom: .55rem; }
.content-page-actions { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 2rem; }
.content-primary-link, .content-secondary-link { border: 2px solid #111; border-radius: 9px; display: inline-flex; font-size: .83rem; font-weight: 800; padding: .75rem 1rem; text-decoration: none; }
.content-primary-link { background: var(--sp-primary); color: #fff; }
.content-primary-link:hover { color: #fff; }
.content-secondary-link { background: #fff; color: var(--sp-primary-dark); }
.contact-page-grid { display: grid; gap: 1.5rem; grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr); }
.contact-page-grid .content-page-card { margin: 0; }
.contact-detail-list { display: grid; gap: 1rem; }
.contact-detail-list > div { align-items: flex-start; background: #f7f8fc; border: 1px solid #e1e5ef; border-radius: 12px; display: flex; gap: .85rem; padding: 1rem; }
.contact-detail-list i { color: var(--sp-primary); margin-top: .25rem; width: 18px; }
.contact-detail-list a { color: var(--sp-primary-dark); font-weight: 700; text-decoration: none; }
.contact-map-card { border: 2px solid #111; border-radius: 18px; box-shadow: 7px 7px 0 #111; min-height: 430px; overflow: hidden; }
.contact-map-card iframe { border: 0; height: 100%; min-height: 430px; width: 100%; }
@media (max-width: 900px) {
    .home-about-card { grid-template-columns: 64px 1fr; }
    .home-about-mark { height: 60px; width: 60px; }
    .home-about-fact { grid-column: 1 / -1; }
    .office-bearers-grid { gap: 18px; grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .office-bearer-photo { max-width: 170px; }
    .contact-page-grid { grid-template-columns: 1fr; }
}
@media (max-width: 575px) {
    .home-about-section { padding: 1.3rem 0 2.2rem; }
    .home-about-card { display: block; padding: 1.35rem; }
    .home-about-mark { margin-bottom: 1rem; }
    .home-about-fact { margin-top: 1.2rem; }
    .office-bearers-section { padding: .25rem 0 2.75rem; }
    .office-bearers-heading { margin-bottom: 1.4rem; padding-top: 1.8rem; }
    .office-bearers-heading p { font-size: .8rem; padding: 0 .6rem; }
    .office-bearers-grid { gap: 12px; grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .office-bearer-card { border-radius: 14px; padding: 12px 8px 12px; }
    .office-bearer-photo { border-width: 4px; margin-bottom: 12px; max-width: 142px; }
    .office-bearer-info { min-height: 78px; }
    .office-bearer-card h3 { font-size: .72rem !important; line-height: 1.35; margin-bottom: .65rem; }
    .office-bearer-role { font-size: .64rem; padding: .4rem .55rem; }
    .content-page-section { padding: 2rem 0 3rem; }
    .content-page-card { border-radius: 13px; box-shadow: 4px 4px 0 #111; }
}
@media (max-width: 360px) {
    .office-bearers-grid { grid-template-columns: 1fr; }
    .office-bearer-card { margin: 0 auto; max-width: 240px; width: 100%; }
    .office-bearer-photo { max-width: 160px; }
}
.footer-contact { display: flex; flex-wrap: wrap; gap: .55rem 1rem; margin-top: 1rem; }
.footer-contact a { color: #c8cbdd; font-size: .76rem; }
.footer-contact i { color: #8f93ff; margin-right: .4rem; }
.footer-navigation { display: grid; gap: 2rem; grid-template-columns: repeat(3, 1fr); padding-top: .4rem; }
.site-footer h6 { color: #fff; font-size: .72rem !important; letter-spacing: .09em; margin-bottom: 1rem; text-transform: uppercase; }
.footer-links { list-style: none; margin: 0; padding: 0; }
.footer-links li { margin-bottom: .65rem; }
.footer-links a { color: #a8acc4; font-size: .78rem; font-weight: 500; transition: color .15s ease, transform .15s ease; }
.footer-links a:hover { color: #fff !important; display: inline-block; transform: translateX(3px); }
.footer-bottom { align-items: center; border-top: 1px solid rgba(255,255,255,.09); display: flex; font-size: .72rem; justify-content: space-between; margin-top: 2.5rem; padding-top: 1.15rem; }
.footer-bottom p { color: #858ba9 !important; font-size: .72rem !important; margin: 0; }
.footer-trust { align-items: center; color: #858ba9; display: flex; gap: 1.3rem; }
.footer-trust i { color: #8f93ff; margin-right: .35rem; }
.invalid-feedback { font-weight: 600; }
.pricing-section {
    background:
        radial-gradient(circle at 10% 15%, rgba(74, 77, 196, .12), transparent 28%),
        linear-gradient(180deg, #f8f9ff 0%, #fff 100%);
    border-bottom: 1px solid var(--sp-border);
    border-top: 1px solid var(--sp-border);
    padding: 2.75rem 0;
}
.pricing-heading { margin: 0 auto 1.4rem; max-width: 680px; text-align: center; }
.pricing-kicker {
    background: rgba(47, 49, 147, .09);
    border-radius: 999px;
    color: var(--sp-primary);
    display: inline-block;
    font-size: .74rem;
    font-weight: 700;
    letter-spacing: .08em;
    margin-bottom: .55rem;
    padding: .35rem .7rem;
    text-transform: uppercase;
}
.pricing-heading h2 { color: var(--sp-primary-dark); margin-bottom: .65rem; }
.pricing-heading p { color: var(--sp-muted); margin: 0; }
.pricing-card {
    background: #fff;
    border: 1px solid #e2e5f3;
    border-radius: 1.15rem;
    box-shadow: 0 14px 40px rgba(24, 25, 95, .07);
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 1.35rem;
    position: relative;
    transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}
.pricing-card:hover { border-color: rgba(47,49,147,.35); box-shadow: 0 22px 55px rgba(24,25,95,.12); transform: translateY(-5px); }
.pricing-card.featured { border: 2px solid var(--sp-primary); box-shadow: 0 20px 55px rgba(47,49,147,.15); }
.popular-badge {
    background: var(--sp-primary);
    border-radius: 999px;
    color: #fff;
    font-size: .7rem;
    font-weight: 700;
    padding: .4rem .75rem;
    position: absolute;
    right: 1.25rem;
    top: 1.25rem;
}
.pricing-card-top { align-items: flex-start; display: flex; gap: .85rem; padding-right: 4.5rem; }
.plan-icon { align-items: center; background: rgba(47,49,147,.09); border-radius: .75rem; color: var(--sp-primary); display: flex; flex: 0 0 42px; height: 42px; justify-content: center; }
.pricing-card-top h3 { color: var(--sp-primary-dark); margin: .05rem 0 .3rem; }
.pricing-card-top p { color: var(--sp-muted); font-size: .8rem !important; line-height: 1.5; margin: 0; }
.plan-price { align-items: baseline; color: var(--sp-primary-dark); display: flex; margin: 1rem 0 .75rem; }
.plan-price .currency { font-size: 1.1rem; font-weight: 700; margin-right: .15rem; }
.plan-price strong { font-size: 2.35rem; letter-spacing: -.05em; line-height: 1; }
.plan-price .period { color: var(--sp-muted); font-size: .78rem; margin-left: .35rem; }
.pricing-divider { background: var(--sp-border); height: 1px; margin-bottom: .8rem; }
.plan-features { display: grid; gap: .55rem; list-style: none; margin: 0 0 1rem; padding: 0; }
.plan-features li { align-items: flex-start; color: #485266; display: flex; font-size: .82rem !important; gap: .65rem; }
.plan-features i { align-items: center; background: rgba(22,133,107,.11); border-radius: 50%; color: #16856b; display: flex; flex: 0 0 20px; font-size: .62rem; height: 20px; justify-content: center; margin-top: .05rem; }
.pricing-button { align-items: center; background: var(--sp-accent); border-radius: .7rem; color: #fff; display: flex; font-size: .82rem; font-weight: 700; justify-content: space-between; margin-top: auto; padding: .75rem .9rem; }
.pricing-button:hover { background: var(--sp-primary-dark); color: #fff; }
.pricing-footer { align-items: center; color: var(--sp-muted); display: flex; font-size: .8rem; justify-content: space-between; margin-top: 1rem; }
.pricing-footer a { color: var(--sp-primary); font-weight: 700; }
.pricing-footer i { margin-right: .35rem; }
.home-action-section {
    background: #f4f6fb;
    padding: 2.5rem 0;
}
.home-action-grid {
    display: grid;
    gap: 1.5rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.home-action-card {
    border-radius: 1.4rem;
    box-shadow: 0 20px 55px rgba(24, 25, 95, .1);
    display: flex;
    flex-direction: column;
    min-height: 410px;
    overflow: hidden;
    padding: 1.8rem;
    position: relative;
}
.home-action-card::after {
    border: 1px solid currentColor;
    border-radius: 50%;
    content: "";
    height: 230px;
    opacity: .08;
    position: absolute;
    right: -95px;
    top: -95px;
    width: 230px;
}
.home-action-dealer {
    background: linear-gradient(145deg, #191b63 0%, #3437aa 100%);
    color: #fff;
}
.home-action-customer {
    background: #fff;
    border: 1px solid #e0e5f1;
    color: var(--sp-primary-dark);
}
.home-action-icon {
    align-items: center;
    background: rgba(255,255,255,.13);
    border: 1px solid rgba(255,255,255,.18);
    border-radius: 1rem;
    display: flex;
    font-size: 1.3rem;
    height: 54px;
    justify-content: center;
    margin-bottom: .9rem;
    width: 54px;
}
.home-action-customer .home-action-icon {
    background: #eef0ff;
    border-color: #dfe2ff;
    color: var(--sp-primary);
}
.home-action-kicker {
    font-size: .72rem;
    font-weight: 800;
    letter-spacing: .1em;
    margin-bottom: .65rem;
    text-transform: uppercase;
}
.home-action-dealer .home-action-kicker { color: #bfc2ff; }
.home-action-customer .home-action-kicker { color: var(--sp-accent); }
.home-action-card h2 {
    color: inherit;
    font-size: clamp(1.65rem, 2.5vw, 2.2rem);
    line-height: 1.15;
    margin-bottom: .65rem;
    max-width: 520px;
}
.home-action-card > p {
    color: inherit;
    font-size: .92rem !important;
    line-height: 1.6;
    margin-bottom: .9rem;
    opacity: .76;
}
.home-action-benefits {
    display: grid;
    gap: .55rem;
    list-style: none;
    margin: 0 0 1rem;
    padding: 0;
}
.home-action-benefits li { align-items: center; display: flex; font-size: .84rem; gap: .65rem; }
.home-action-benefits i {
    align-items: center;
    background: rgba(255,255,255,.14);
    border-radius: 50%;
    display: flex;
    font-size: .55rem;
    height: 20px;
    justify-content: center;
    width: 20px;
}
.home-action-steps {
    display: grid;
    gap: .5rem;
    margin-bottom: 1rem;
}
.home-action-steps span {
    align-items: center;
    background: #f7f8fc;
    border: 1px solid #e7eaf3;
    border-radius: .75rem;
    color: #424b62;
    display: flex;
    font-size: .82rem;
    gap: .75rem;
    padding: .72rem .85rem;
}
.home-action-steps strong { color: var(--sp-primary); font-size: .7rem; letter-spacing: .04em; }
.home-action-button {
    align-items: center;
    border-radius: .8rem;
    display: flex;
    font-size: .82rem;
    font-weight: 800;
    justify-content: space-between;
    margin-top: auto;
    padding: .9rem 1rem;
    transition: transform .2s ease, background .2s ease;
}
.home-action-button:hover { transform: translateY(-2px); }
.home-action-button-light { background: #fff; color: var(--sp-primary-dark); }
.home-action-button-light:hover { background: #eef0ff; color: var(--sp-primary); }
.home-action-button-primary { background: var(--sp-primary); color: #fff; }
.home-action-button-primary:hover { background: var(--sp-primary-dark); color: #fff; }
.featured-parts-section { padding: 2.75rem 0; }
.featured-parts-section .section-title { margin-bottom: 1.25rem !important; }
.featured-parts-section .row { --bs-gutter-y: 1rem; }
.dealer-profile-hero {
    background:
        radial-gradient(circle at 85% 15%, rgba(132, 137, 255, .28), transparent 28%),
        linear-gradient(135deg, #17195f 0%, #3437aa 100%);
    color: #fff;
    padding: 2.25rem 0 2.75rem;
}
.dealer-profile-back { color: rgba(255,255,255,.72); display: inline-flex; font-size: .78rem; gap: .45rem; margin-bottom: 1.4rem; }
.dealer-profile-back:hover { color: #fff; }
.dealer-profile-hero-grid { align-items: center; display: flex; gap: 2rem; justify-content: space-between; }
.dealer-profile-identity { align-items: center; display: flex; gap: 1.25rem; min-width: 0; }
.dealer-profile-identity > div:last-child { min-width: 0; }
.dealer-profile-avatar { align-items: center; background: #fff; border: 4px solid rgba(255,255,255,.18); border-radius: 1.2rem; color: var(--sp-primary); display: flex; flex: 0 0 104px; font-size: 2rem; height: 104px; justify-content: center; overflow: hidden; width: 104px; }
.dealer-profile-avatar img { height: 100%; object-fit: cover; width: 100%; }
.dealer-verified { color: #c9cbff; display: block; font-size: .72rem; font-weight: 800; letter-spacing: .07em; margin-bottom: .45rem; text-transform: uppercase; }
.dealer-verified i { color: #5ee6b1; margin-right: .3rem; }
.dealer-profile-identity h1 { color: #fff; font-size: clamp(1.8rem, 4vw, 2.65rem); margin: 0 0 .25rem; overflow-wrap: anywhere; }
.dealer-profile-identity p { color: rgba(255,255,255,.72) !important; margin: 0 0 .45rem; }
.dealer-location { color: rgba(255,255,255,.78); font-size: .82rem; }
.dealer-profile-actions { align-items: flex-end; display: flex; flex-direction: column; gap: .8rem; }
.dealer-profile-actions > span { color: rgba(255,255,255,.72); font-size: .78rem; }
.dealer-call-button { background: #fff; border-radius: .8rem; color: var(--sp-primary-dark); font-size: .82rem; font-weight: 800; padding: .85rem 1.1rem; }
.dealer-call-button:hover { background: #eef0ff; color: var(--sp-primary); }
.dealer-profile-content { background: #f4f6fb; padding: 2.5rem 0 4rem; }
.dealer-profile-summary { display: grid; gap: 1.25rem; grid-template-columns: minmax(0, 1.65fr) minmax(280px, .75fr); margin-bottom: 2.5rem; }
.dealer-about-card, .dealer-trust-card { background: #fff; border: 1px solid #e2e6f0; border-radius: 1.15rem; box-shadow: 0 14px 40px rgba(24,25,95,.07); min-width: 0; padding: 1.7rem; }
.dealer-card-kicker, .dealer-parts-heading span { color: var(--sp-accent); display: block; font-size: .69rem; font-weight: 800; letter-spacing: .09em; margin-bottom: .4rem; text-transform: uppercase; }
.dealer-about-card h2 { color: var(--sp-primary-dark); font-size: 1.45rem; margin-bottom: .55rem; }
.dealer-about-card > p, .dealer-trust-card > p { color: var(--sp-muted); font-size: .84rem !important; line-height: 1.65; }
.dealer-detail-grid { display: grid; gap: .75rem; grid-template-columns: repeat(2, minmax(0, 1fr)); margin-top: 1.25rem; }
.dealer-detail-grid > div { align-items: flex-start; background: #f7f8fc; border-radius: .75rem; display: flex; font-size: .78rem; gap: .65rem; padding: .8rem; }
.dealer-detail-grid i { color: var(--sp-primary); margin-top: .15rem; }
.dealer-detail-grid small { color: var(--sp-muted); display: block; font-size: .65rem; margin-bottom: .15rem; text-transform: uppercase; }
.dealer-trust-card { background: linear-gradient(150deg, #292c91, #17195f); color: #fff; }
.dealer-trust-icon { align-items: center; background: rgba(255,255,255,.12); border-radius: .85rem; display: flex; height: 46px; justify-content: center; margin-bottom: 1rem; width: 46px; }
.dealer-trust-card h3 { color: #fff; font-size: 1.2rem; }
.dealer-trust-card > p { color: rgba(255,255,255,.68) !important; }
.dealer-trust-card ul { display: grid; gap: .6rem; list-style: none; margin: 1rem 0 0; padding: 0; }
.dealer-trust-card li { font-size: .78rem; }
.dealer-trust-card li i { color: #5ee6b1; margin-right: .45rem; }
.dealer-parts-heading { align-items: flex-end; display: flex; justify-content: space-between; margin-bottom: 1.25rem; }
.dealer-parts-heading h2 { color: var(--sp-primary-dark); font-size: 1.6rem; margin: 0; }
.dealer-parts-heading > a { color: var(--sp-primary); font-size: .8rem; font-weight: 700; }
.dealer-part-card { background: #fff; border: 1px solid #e2e6f0; border-radius: 1rem; box-shadow: 0 12px 34px rgba(24,25,95,.07); height: 100%; overflow: hidden; transition: transform .2s ease, box-shadow .2s ease; }
.dealer-part-card:hover { box-shadow: 0 18px 42px rgba(24,25,95,.12); transform: translateY(-4px); }
.dealer-part-image { background: #f8f9fc; display: block; height: 180px; padding: .5rem; }
.dealer-part-image img { height: 100%; object-fit: contain; width: 100%; }
.dealer-part-body { display: flex; flex-direction: column; min-height: 190px; padding: 1rem; }
.dealer-part-body > span { color: var(--sp-accent); font-size: .66rem; font-weight: 800; text-transform: uppercase; }
.dealer-part-body h3 { color: var(--sp-primary-dark); font-size: .94rem; margin: .35rem 0; }
.dealer-part-body p { color: var(--sp-muted); font-size: .76rem !important; margin: 0 0 .45rem; }
.dealer-part-body strong { color: #e53445; font-size: 1rem; margin-top: auto; }
.dealer-part-link { align-items: center; background: var(--sp-primary); border-radius: .6rem; color: #fff; display: flex; font-size: .75rem; font-weight: 700; justify-content: space-between; margin-top: .8rem; padding: .65rem .75rem; }
.dealer-part-link:hover { background: var(--sp-primary-dark); color: #fff; }
.dealer-empty-state { background: #fff; border: 1px dashed #ccd2e1; border-radius: 1rem; color: var(--sp-muted); padding: 3rem; text-align: center; }
.dealer-empty-state i { color: var(--sp-primary); font-size: 2rem; margin-bottom: .75rem; }
.dealer-empty-state h3 { color: var(--sp-primary-dark); }
.table { border: 0 !important; }
.table thead th { background: #edf3f7; border: 0; color: #344054; font-size: .78rem; }
.table tbody td { font-size: .84rem; }
.pagination .page-link { border-color: var(--sp-border); color: var(--sp-primary); }
.pagination .active > .page-link { background: var(--sp-primary); border-color: var(--sp-primary); }
@media (max-width: 991px) {
    .navbar-collapse { padding: 1rem 0; }
    .navbar-brand img { height: 64px; }
    .hero-section { padding: 3.5rem 0; }
    .hero-shell { gap: 2.5rem; grid-template-columns: 1fr; }
    .hero-copy { margin: 0 auto; text-align: center; }
    .hero-section h1, .hero-section .hero-intro { margin-left: auto; margin-right: auto; }
    .hero-trust { justify-content: center; }
    .hero-visual { height: 330px; margin: 0 auto; max-width: 520px; width: 100%; }
    .footer-cta-inner { grid-template-columns: auto 1fr; }
    .footer-cta-actions { grid-column: 2; }
    .footer-main { gap: 2.5rem; grid-template-columns: 1fr; }
    .footer-company { max-width: 520px; }
}
@media (max-width: 575px) {
    body { font-size: 13.5px; }
    h1, .h1 { font-size: 1.75rem !important; }
    h2, .h2 { font-size: 1.45rem !important; }
    h3, .h3 { font-size: 1.25rem !important; }
    .hero-section { padding: 2.5rem 0 2rem; text-align: center; }
    .hero-section h1 { font-size: 2rem !important; letter-spacing: -.04em; line-height: 1.12; max-width: 340px; }
    .hero-kicker { font-size: .68rem; }
    .hero-search-form { border-radius: 1rem; max-width: 100%; padding: .65rem; width: 100%; }
    .hero-search-main { grid-template-columns: auto minmax(0,1fr); }
    .hero-search-main button { grid-column: 1 / -1; justify-content: center; width: 100%; }
    .hero-search-filters { grid-template-columns: 1fr; }
    .hero-trust { gap: .55rem 1rem; }
    .hero-visual { height: 245px; margin-top: -.25rem; }
    .hero-visual-glow { height: 210px; right: 13%; width: 210px; }
    .hero-gear-large { font-size: 8.5rem; right: 20%; top: 22%; }
    .hero-gear-small { font-size: 3.5rem; right: 11%; top: 9%; }
    .hero-part-card { padding: .65rem .75rem; }
    .hero-part-card-main { left: 0; top: 8%; }
    .hero-part-card-dealers { bottom: 5%; right: 0; }
    .hero-part-icon { height: 34px; width: 34px; }
    .hero-category-pill { bottom: 10%; left: 0; }
    .page-header-modern { padding: 1.55rem 0; }
    .page-header-icon { display: none; }
    .page-header-home { display: none; }
    .page-header-modern h1 { font-size: 1.45rem !important; }
    .login-bg { padding: 1rem; }
    .card-cartoon { border-radius: .85rem !important; }
    .footer-cta { padding-bottom: 1.5rem; }
    .footer-cta-inner { display: block; padding: 1.35rem; }
    .footer-cta-icon { margin-bottom: .9rem; }
    .footer-cta-actions { align-items: stretch; flex-direction: column; margin-top: 1rem; }
    .footer-cta-actions a { text-align: center; }
    .footer-navigation { gap: 1.5rem; grid-template-columns: 1fr 1fr; }
    .footer-bottom { align-items: flex-start; flex-direction: column; gap: .75rem; }
    .footer-trust { align-items: flex-start; flex-direction: column; gap: .4rem; }
    .pricing-section { padding: 2.5rem 0; }
    .pricing-footer { align-items: flex-start; flex-direction: column; gap: .65rem; }
    .home-action-grid { grid-template-columns: 1fr; }
    .home-action-card { min-height: 0; }
    .dealer-profile-summary { grid-template-columns: 1fr; }
}
@media (max-width: 575px) {
    .home-action-section { padding: 2rem 0; }
    .home-action-card { border-radius: 1rem; padding: 1.3rem; }
    .home-action-card h2 { font-size: 1.55rem; }
    .home-action-button { padding: .82rem .9rem; }
    .featured-parts-section { padding: 2.25rem 0; }
    .dealer-profile-hero { padding: 1.5rem 0 2rem; }
    .dealer-profile-hero .container, .dealer-profile-content .container { max-width: 100%; }
    .dealer-profile-hero-grid { align-items: flex-start; flex-direction: column; gap: 1.25rem; }
    .dealer-profile-identity { align-items: flex-start; gap: .85rem; width: 100%; }
    .dealer-profile-avatar { flex-basis: 72px; height: 72px; width: 72px; }
    .dealer-profile-identity h1 { font-size: 1.55rem !important; line-height: 1.15; }
    .dealer-profile-actions { align-items: stretch; width: 100%; }
    .dealer-call-button { text-align: center; }
    .dealer-profile-content { padding: 1.5rem 0 2.5rem; }
    .dealer-about-card, .dealer-trust-card { padding: 1.25rem; }
    .dealer-detail-grid { grid-template-columns: 1fr; }
    .dealer-parts-heading { align-items: flex-start; flex-direction: column; gap: .5rem; }
    .dealer-parts-heading h2 { overflow-wrap: anywhere; }
    .dealer-part-image { height: 190px; }
    .dealer-part-body { min-height: 175px; padding: 1rem; }
}

/* Responsive parts catalogue shared by public and dealer pages */
.parts-catalogue { background: #fff; border: 1px solid #d9dee8; border-radius: 14px; box-shadow: 0 12px 32px rgba(24,25,95,.08); overflow: hidden; }
.parts-catalogue-head,
.parts-catalogue-row { display: grid; grid-template-columns: 92px minmax(230px,1.6fr) minmax(105px,.48fr) minmax(145px,.65fr) minmax(125px,.58fr); }
.parts-catalogue-head { background: linear-gradient(90deg,#ffd21c,#ffc400); border-bottom: 3px solid var(--sp-primary); color: #111; font-size: .78rem; font-weight: 800; letter-spacing: .02em; }
.parts-catalogue-head span { align-items: center; border-right: 1px solid rgba(0,0,0,.08); display: flex; min-height: 48px; padding: .75rem .85rem; }
.parts-catalogue-head span:last-child { border-right: 0; justify-content: center; }
.parts-catalogue-row { align-items: stretch; border-bottom: 1px solid #e0e4ec; min-height: 118px; transition: background .18s ease; }
.parts-catalogue-row:nth-child(even) { background: #fffaf0; }
.parts-catalogue-row:last-child { border-bottom: 0; }
.parts-catalogue-row:hover { background: #f3f4ff; }
.parts-catalogue-row > div { border-right: 1px solid #e0e4ec; min-width: 0; padding: .75rem .85rem; }
.parts-catalogue-row > div:last-child { border-right: 0; }
.parts-catalogue-image { align-items: center; display: flex; justify-content: center; }
.parts-catalogue-image a { align-items: center; background: #fff; border: 1px solid #dce1eb; border-radius: 9px; display: flex; height: 78px; justify-content: center; overflow: hidden; padding: 4px; width: 78px; }
.parts-catalogue-image img { height: 100%; object-fit: contain; width: 100%; }
.parts-catalogue-product { display: flex; flex-direction: column; justify-content: center; }
.parts-catalogue-category { color: #b50082; font-size: .64rem; font-weight: 800; letter-spacing: .06em; margin-bottom: .25rem; text-transform: uppercase; }
.parts-catalogue-name { color: var(--sp-primary-dark); font-size: .9rem; font-weight: 800; line-height: 1.35; text-decoration: none; }
.parts-catalogue-name:hover { color: var(--sp-primary); }
.parts-catalogue-meta { display: flex; flex-wrap: wrap; gap: .25rem .7rem; margin-top: .4rem; }
.parts-catalogue-meta span { color: #667085; font-size: .67rem; line-height: 1.35; }
.parts-catalogue-meta i { color: var(--sp-primary); margin-right: .2rem; }
.parts-catalogue-price,
.parts-catalogue-availability,
.parts-catalogue-action { align-items: flex-start; display: flex; flex-direction: column; justify-content: center; }
.parts-catalogue-price strong { color: #16812b; font-size: 1.05rem; line-height: 1; }
.parts-catalogue-price small,
.parts-catalogue-availability small { color: #7a8193; font-size: .64rem; margin-top: .4rem; }
.parts-status { align-items: center; border-radius: 999px; display: inline-flex; font-size: .67rem; font-weight: 800; gap: .3rem; line-height: 1.25; padding: .42rem .62rem; }
.parts-status.is-available { background: #e9f8ee; color: #14772a; }
.parts-status.is-inactive { background: #eef0f4; color: #667085; }
.parts-catalogue-action { align-items: center; }
.parts-view-button { align-items: center; background: var(--sp-primary); border: 2px solid var(--sp-primary-dark); border-radius: 8px; box-shadow: 3px 3px 0 var(--sp-primary-dark); color: #fff; display: inline-flex; font-size: .68rem; font-weight: 800; gap: .4rem; justify-content: center; padding: .58rem .7rem; text-decoration: none; white-space: nowrap; }
.parts-view-button:hover { box-shadow: 4px 4px 0 var(--sp-primary-dark); color: #fff; transform: translate(-1px,-1px); }
.parts-call-button { align-items: center; background: #16812b; border: 2px solid #0b551a; border-radius: 8px; box-shadow: 3px 3px 0 #0b551a; color: #fff; display: inline-flex; font-size: .72rem; font-weight: 800; gap: .45rem; justify-content: center; min-width: 92px; padding: .58rem .8rem; text-decoration: none; white-space: nowrap; }
.parts-call-button:hover { background: #117024; box-shadow: 4px 4px 0 #0b551a; color: #fff; transform: translate(-1px,-1px); }
.parts-call-button.is-disabled { background: #a7adb8; border-color: #777f8c; box-shadow: 3px 3px 0 #777f8c; cursor: not-allowed; }
.parts-manage-actions { display: flex; flex-wrap: wrap; gap: .4rem; justify-content: center; }
.parts-manage-actions form { margin: 0; }
.parts-icon-button { align-items: center; border: 1px solid transparent; border-radius: 7px; display: inline-flex; height: 34px; justify-content: center; width: 34px; }
.parts-icon-button.is-edit { background: #e9eaff; border-color: #cfd1ff; color: var(--sp-primary); }
.parts-icon-button.is-pause { background: #fff3cd; border-color: #ffe08a; color: #8a6400; }
.parts-icon-button.is-enable { background: #e7f8ed; border-color: #bce8ca; color: #14772a; }
.parts-icon-button.is-delete { background: #ffebee; border-color: #ffc9d0; color: #c32738; }
.parts-catalogue-empty { align-items: center; display: flex; flex-direction: column; padding: 3.5rem 1.5rem; text-align: center; }
.parts-catalogue-empty > i { color: #c3c8d5; font-size: 3rem; margin-bottom: 1rem; }
.parts-catalogue-empty h3 { color: var(--sp-primary-dark); margin-bottom: .35rem; }
.parts-catalogue-empty p { color: #737b8f; margin-bottom: .8rem; }
.parts-catalogue-empty a { color: var(--sp-primary); font-size: .8rem; font-weight: 800; }
.parts-pagination { margin-top: 1.5rem; }
.parts-pagination-nav { align-items: center; display: flex; gap: .75rem; justify-content: space-between; }
.parts-page-numbers { display: flex; gap: .35rem; }
.parts-page-button,
.parts-page-number { align-items: center; background: #fff; border: 1px solid #d7dce7; border-radius: 8px; color: var(--sp-primary-dark); display: inline-flex; font-size: .72rem; font-weight: 700; gap: .4rem; justify-content: center; min-height: 38px; padding: .55rem .75rem; text-decoration: none; }
.parts-page-number { min-width: 38px; padding: .45rem; }
.parts-page-number.is-current { background: var(--sp-primary); border-color: var(--sp-primary); color: #fff; }
.parts-page-button:hover,
.parts-page-number:hover { border-color: var(--sp-primary); color: var(--sp-primary); }
.parts-page-button.is-disabled { background: #f0f2f6; color: #a0a6b3; cursor: not-allowed; }
.parts-page-ellipsis { align-items: center; color: #7a8193; display: flex; padding: 0 .2rem; }

@media (max-width: 1100px) {
    .parts-catalogue-head,
    .parts-catalogue-row { grid-template-columns: 86px minmax(210px,1.4fr) minmax(90px,.45fr) minmax(130px,.65fr) minmax(112px,.55fr); }
    .parts-catalogue-row > div,
    .parts-catalogue-head span { padding-left: .65rem; padding-right: .65rem; }
}

@media (max-width: 900px) {
    .parts-catalogue-head { display: none; }
    .parts-catalogue { background: transparent; border: 0; border-radius: 0; box-shadow: none; overflow: visible; }
    .parts-catalogue-body { display: grid; gap: 12px; grid-template-columns: repeat(2,minmax(0,1fr)); }
    .parts-catalogue-row { background: #fff !important; border: 1px solid #dbe0ea; border-radius: 14px; box-shadow: 0 9px 24px rgba(24,25,95,.08); display: grid; grid-template-columns: 88px minmax(0,1fr); min-height: 0; overflow: hidden; padding: .85rem; }
    .parts-catalogue-row > div { border: 0; padding: 0; }
    .parts-catalogue-image { grid-row: 1 / span 2; justify-content: flex-start; padding-right: .75rem !important; }
    .parts-catalogue-image a { height: 78px; width: 78px; }
    .parts-catalogue-product { justify-content: flex-start; }
    .parts-catalogue-price { align-items: flex-start; border-top: 1px solid #eceef3 !important; grid-column: 1; margin-top: .75rem; padding-top: .75rem !important; }
    .parts-catalogue-availability { align-items: flex-start; border-top: 1px solid #eceef3 !important; grid-column: 2; margin-top: .75rem; padding-top: .75rem !important; }
    .parts-catalogue-action { align-items: stretch; grid-column: 1 / -1; margin-top: .8rem; }
    .parts-view-button { width: 100%; }
    .parts-call-button { width: 100%; }
    .parts-manage-actions { justify-content: flex-start; }
}

@media (max-width: 575px) {
    .parts-catalogue-body { grid-template-columns: 1fr; }
    .parts-catalogue-row { grid-template-columns: 92px minmax(0,1fr); }
    .parts-catalogue-image a { height: 82px; width: 82px; }
    .parts-pagination-nav { gap: .4rem; }
    .parts-page-button { font-size: 0; min-width: 40px; padding: .5rem; }
    .parts-page-button i { font-size: .72rem; }
    .parts-page-numbers { gap: .25rem; }
    .parts-page-number { min-height: 36px; min-width: 34px; }
}

/* Verified dealers list using the shared catalogue visual language */
.dealers-catalogue { background: #fff; border: 1px solid #d9dee8; border-radius: 14px; box-shadow: 0 12px 32px rgba(24,25,95,.08); overflow: hidden; }
.dealers-catalogue-head,
.dealers-catalogue-row { display: grid; grid-template-columns: 92px minmax(190px,1.1fr) minmax(230px,1.35fr) minmax(120px,.5fr) minmax(135px,.58fr); }
.dealers-catalogue-head { background: linear-gradient(90deg,#ffd21c,#ffc400); border-bottom: 3px solid var(--sp-primary); color: #111; font-size: .78rem; font-weight: 800; letter-spacing: .02em; }
.dealers-catalogue-head span { align-items: center; border-right: 1px solid rgba(0,0,0,.08); display: flex; min-height: 48px; padding: .75rem .85rem; }
.dealers-catalogue-head span:last-child { border-right: 0; justify-content: center; }
.dealers-catalogue-row { border-bottom: 1px solid #e0e4ec; min-height: 118px; transition: background .18s ease; }
.dealers-catalogue-row:nth-child(even) { background: #fffaf0; }
.dealers-catalogue-row:last-child { border-bottom: 0; }
.dealers-catalogue-row:hover { background: #f3f4ff; }
.dealers-catalogue-row > div { border-right: 1px solid #e0e4ec; min-width: 0; padding: .75rem .85rem; }
.dealers-catalogue-row > div:last-child { border-right: 0; }
.dealers-catalogue-image,
.dealers-catalogue-dealer,
.dealers-catalogue-shop,
.dealers-catalogue-parts,
.dealers-catalogue-action { align-items: flex-start; display: flex; flex-direction: column; justify-content: center; }
.dealers-catalogue-image { align-items: center; }
.dealers-catalogue-image a { align-items: center; background: #f5f6ff; border: 1px solid #dce1eb; border-radius: 9px; color: var(--sp-primary); display: flex; font-size: 1.45rem; height: 78px; justify-content: center; overflow: hidden; padding: 4px; width: 78px; }
.dealers-catalogue-image img { height: 100%; object-fit: cover; width: 100%; }
.dealers-verified { color: #16812b; font-size: .62rem; font-weight: 800; letter-spacing: .05em; margin-bottom: .25rem; text-transform: uppercase; }
.dealers-catalogue-name { color: var(--sp-primary-dark); font-size: .92rem; font-weight: 800; line-height: 1.35; overflow-wrap: anywhere; }
.dealers-catalogue-name:hover { color: var(--sp-primary); }
.dealers-catalogue-dealer small,
.dealers-catalogue-shop small,
.dealers-catalogue-parts small { color: #737b8f; font-size: .66rem; line-height: 1.4; margin-top: .4rem; }
.dealers-catalogue-dealer i,
.dealers-catalogue-shop i { color: var(--sp-primary); margin-right: .25rem; }
.dealers-catalogue-shop strong { color: #20253b; font-size: .78rem; line-height: 1.4; overflow-wrap: anywhere; }
.dealers-catalogue-parts strong { color: #16812b; font-size: 1.2rem; line-height: 1; }
.dealers-catalogue-action { align-items: center; }

@media (max-width: 900px) {
    .dealers-catalogue-head { display: none; }
    .dealers-catalogue { background: transparent; border: 0; border-radius: 0; box-shadow: none; overflow: visible; }
    .dealers-catalogue-body { display: grid; gap: 12px; grid-template-columns: repeat(2,minmax(0,1fr)); }
    .dealers-catalogue-row { background: #fff !important; border: 1px solid #dbe0ea; border-radius: 14px; box-shadow: 0 9px 24px rgba(24,25,95,.08); display: grid; grid-template-columns: 88px minmax(0,1fr); min-height: 0; overflow: hidden; padding: .85rem; }
    .dealers-catalogue-row > div { border: 0; padding: 0; }
    .dealers-catalogue-image { grid-row: 1 / span 2; justify-content: flex-start; padding-right: .75rem !important; }
    .dealers-catalogue-image a { height: 78px; width: 78px; }
    .dealers-catalogue-shop { border-top: 1px solid #eceef3 !important; grid-column: 1 / -1; margin-top: .75rem; padding-top: .75rem !important; }
    .dealers-catalogue-parts { border-top: 1px solid #eceef3 !important; grid-column: 1; margin-top: .75rem; padding-top: .75rem !important; }
    .dealers-catalogue-action { align-items: stretch; grid-column: 2; margin-top: .75rem; }
    .dealers-catalogue-action .parts-view-button { width: 100%; }
}

@media (max-width: 575px) {
    .dealers-catalogue-body { grid-template-columns: 1fr; }
    .dealers-catalogue-row { grid-template-columns: 92px minmax(0,1fr); }
    .dealers-catalogue-image a { height: 82px; width: 82px; }
}

/* Consumer requests displayed directly on the dealer dashboard */
.dealer-dashboard-section-head { align-items: flex-end; display: flex; gap: 1rem; justify-content: space-between; margin-bottom: 1rem; }
.dealer-dashboard-section-head span { color: #b50082; display: block; font-size: .66rem; font-weight: 800; letter-spacing: .08em; margin-bottom: .25rem; text-transform: uppercase; }
.dealer-dashboard-section-head h3 { color: var(--sp-primary-dark); font-size: 1.45rem; margin: 0; }
.dealer-dashboard-section-head > a { color: var(--sp-primary); font-size: .75rem; font-weight: 800; }
.dealer-request-table { background: #fff; border: 1px solid #d9dee8; border-radius: 14px; box-shadow: 0 12px 32px rgba(24,25,95,.08); overflow: hidden; }
.dealer-request-table-head,
.dealer-request-table-row { display: grid; grid-template-columns: minmax(160px,.8fr) minmax(260px,1.55fr) minmax(100px,.45fr) minmax(125px,.55fr) minmax(115px,.5fr); }
.dealer-request-table-head { background: linear-gradient(90deg,#ffd21c,#ffc400); border-bottom: 3px solid var(--sp-primary); color: #111; font-size: .76rem; font-weight: 800; }
.dealer-request-table-head span { align-items: center; border-right: 1px solid rgba(0,0,0,.08); display: flex; min-height: 48px; padding: .75rem; }
.dealer-request-table-head span:last-child { border-right: 0; justify-content: center; }
.dealer-request-table-row { border-bottom: 1px solid #e0e4ec; min-height: 94px; }
.dealer-request-table-row:nth-child(even) { background: #fffaf0; }
.dealer-request-table-row:last-child { border-bottom: 0; }
.dealer-request-table-row > div { border-right: 1px solid #e0e4ec; display: flex; flex-direction: column; justify-content: center; min-width: 0; padding: .75rem; }
.dealer-request-table-row > div:last-child { border-right: 0; }
.dealer-request-table-row strong { color: #20253b; font-size: .77rem; line-height: 1.4; overflow-wrap: anywhere; }
.dealer-request-table-row small { color: #737b8f; font-size: .65rem; line-height: 1.4; margin-top: .3rem; }
.dealer-request-table-row small i { color: var(--sp-primary); margin-right: .2rem; }
.dealer-request-action { align-items: center; }

@media (max-width: 900px) {
    .dealer-request-table-head { display: none; }
    .dealer-request-table { background: transparent; border: 0; border-radius: 0; box-shadow: none; overflow: visible; }
    .dealer-request-table-body { display: grid; gap: 12px; grid-template-columns: repeat(2,minmax(0,1fr)); }
    .dealer-request-table-row { background: #fff !important; border: 1px solid #dbe0ea; border-radius: 14px; box-shadow: 0 9px 24px rgba(24,25,95,.08); display: grid; grid-template-columns: 1fr 1fr; min-height: 0; overflow: hidden; padding: .9rem; }
    .dealer-request-table-row > div { border: 0; padding: 0; }
    .dealer-request-table-row > div:nth-child(2) { grid-column: 1 / -1; grid-row: 1; margin-bottom: .75rem; }
    .dealer-request-table-row > div:nth-child(1),
    .dealer-request-table-row > div:nth-child(3),
    .dealer-request-table-row > div:nth-child(4) { border-top: 1px solid #eceef3; padding-top: .7rem; }
    .dealer-request-action { align-items: stretch; grid-column: 1 / -1; margin-top: .75rem; }
}

@media (max-width: 575px) {
    .dealer-dashboard-section-head { align-items: flex-start; flex-direction: column; }
    .dealer-request-table-body { grid-template-columns: 1fr; }
}

/* Professional standalone consumer requests page */
.requests-page-hero { background: radial-gradient(circle at 85% 12%,rgba(132,137,255,.25),transparent 28%),linear-gradient(135deg,#17195f,#3437aa); color: #fff; padding: 2.35rem 0; }
.requests-page-hero-content { align-items: center; display: grid; gap: 1.15rem; grid-template-columns: auto minmax(0,1fr) auto; }
.requests-page-hero-icon { align-items: center; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.2); border-radius: 1rem; display: flex; font-size: 1.45rem; height: 62px; justify-content: center; width: 62px; }
.requests-page-hero-content > div:nth-child(2) > span { color: #c9cbff; display: block; font-size: .67rem; font-weight: 800; letter-spacing: .09em; margin-bottom: .3rem; text-transform: uppercase; }
.requests-page-hero h1 { color: #fff; font-size: clamp(1.65rem,3vw,2.25rem); margin: 0 0 .3rem; }
.requests-page-hero p { color: rgba(255,255,255,.72) !important; font-size: .82rem !important; margin: 0; }
.requests-page-total { align-items: flex-end; display: flex; flex-direction: column; }
.requests-page-total strong { color: #fff; font-size: 2rem; line-height: 1; }
.requests-page-total span { color: #c9cbff; font-size: .68rem; font-weight: 700; margin-top: .35rem; text-transform: uppercase; }
.requests-page-content { background: #f4f6fb; min-height: 55vh; padding: 2.25rem 0 4rem; }
.requests-page-toolbar { align-items: flex-end; display: flex; gap: 1rem; justify-content: space-between; margin-bottom: 1.15rem; }
.requests-page-toolbar > div:first-child > span { color: #b50082; display: block; font-size: .66rem; font-weight: 800; letter-spacing: .08em; margin-bottom: .25rem; text-transform: uppercase; }
.requests-page-toolbar h2 { color: var(--sp-primary-dark); font-size: 1.45rem; margin: 0; }
.requests-page-note { align-items: center; background: #e9f8ee; border: 1px solid #c8ead2; border-radius: 999px; color: #14772a; display: inline-flex; font-size: .67rem; font-weight: 700; gap: .4rem; padding: .5rem .75rem; }
.consumer-request-list { background: #fff; border: 1px solid #d9dee8; border-radius: 14px; box-shadow: 0 12px 32px rgba(24,25,95,.08); overflow: hidden; }
.consumer-request-head,
.consumer-request-row { display: grid; grid-template-columns: minmax(190px,.9fr) minmax(290px,1.45fr) minmax(180px,.78fr) minmax(135px,.58fr) minmax(145px,.6fr); }
.consumer-request-head { background: linear-gradient(90deg,#ffd21c,#ffc400); border-bottom: 3px solid var(--sp-primary); color: #111; font-size: .76rem; font-weight: 800; }
.consumer-request-head span { align-items: center; border-right: 1px solid rgba(0,0,0,.08); display: flex; min-height: 50px; padding: .75rem; }
.consumer-request-head span:last-child { border-right: 0; justify-content: center; }
.consumer-request-row { border-bottom: 1px solid #e0e4ec; min-height: 132px; transition: background .18s ease; }
.consumer-request-row:nth-child(even) { background: #fffaf0; }
.consumer-request-row:last-child { border-bottom: 0; }
.consumer-request-row:hover { background: #f3f4ff; }
.consumer-request-row > div { border-right: 1px solid #e0e4ec; min-width: 0; padding: .85rem; }
.consumer-request-row > div:last-child { border-right: 0; }
.consumer-request-customer { align-items: center; display: flex; gap: .7rem; }
.consumer-request-avatar { align-items: center; background: linear-gradient(145deg,#e9eaff,#cfd1ff); border: 1px solid #c4c7f8; border-radius: 50%; color: var(--sp-primary); display: flex; flex: 0 0 42px; font-size: .92rem; font-weight: 900; height: 42px; justify-content: center; width: 42px; }
.consumer-request-customer > div:last-child,
.consumer-request-requirement,
.consumer-request-status,
.consumer-request-action { display: flex; flex-direction: column; justify-content: center; min-width: 0; }
.consumer-request-customer strong,
.consumer-request-requirement > strong { color: #20253b; font-size: .78rem; line-height: 1.4; overflow-wrap: anywhere; }
.consumer-request-customer small,
.consumer-request-requirement small,
.consumer-request-status small { color: #737b8f; font-size: .63rem; line-height: 1.45; margin-top: .25rem; overflow-wrap: anywhere; }
.consumer-request-customer small i,
.consumer-request-requirement small i { color: var(--sp-primary); margin-right: .2rem; }
.consumer-request-part-label { color: #b50082; font-size: .6rem; font-weight: 800; letter-spacing: .06em; margin-bottom: .25rem; text-transform: uppercase; }
.consumer-request-details { align-content: center; display: grid; gap: .55rem .8rem; grid-template-columns: repeat(2,minmax(0,1fr)); }
.consumer-request-details > div small { color: #8a91a1; display: block; font-size: .58rem; margin-bottom: .15rem; text-transform: uppercase; }
.consumer-request-details > div strong { color: #20253b; font-size: .76rem; }
.request-urgency { align-items: center; border-radius: 999px; display: inline-flex; font-size: .6rem; font-weight: 800; gap: .25rem; grid-column: 1 / -1; justify-self: start; padding: .38rem .55rem; text-transform: uppercase; }
.request-urgency.is-high { background: #ffebee; color: #bd2435; }
.request-urgency.is-medium { background: #fff5d8; color: #876200; }
.request-urgency.is-normal { background: #e8f4ff; color: #17669a; }
.consumer-request-status { align-items: flex-start; }
.request-approved { align-items: center; background: #e9f8ee; border-radius: 999px; color: #14772a; display: inline-flex; font-size: .62rem; font-weight: 800; gap: .3rem; margin-bottom: .55rem; padding: .4rem .58rem; }
.consumer-request-status > strong { color: #20253b; font-size: .72rem; }
.consumer-request-action { align-items: center; }
.consumer-request-action .parts-call-button { min-width: 115px; }

@media (max-width: 1050px) {
    .consumer-request-head,
    .consumer-request-row { grid-template-columns: minmax(175px,.9fr) minmax(245px,1.3fr) minmax(165px,.75fr) minmax(125px,.55fr) minmax(125px,.55fr); }
}

@media (max-width: 900px) {
    .consumer-request-head { display: none; }
    .consumer-request-list { background: transparent; border: 0; border-radius: 0; box-shadow: none; overflow: visible; }
    .consumer-request-body { display: grid; gap: 12px; grid-template-columns: repeat(2,minmax(0,1fr)); }
    .consumer-request-row { background: #fff !important; border: 1px solid #dbe0ea; border-radius: 14px; box-shadow: 0 9px 24px rgba(24,25,95,.08); display: grid; grid-template-columns: 1fr 1fr; min-height: 0; overflow: hidden; padding: 1rem; }
    .consumer-request-row > div { border: 0; padding: 0; }
    .consumer-request-customer { grid-column: 1 / -1; padding-bottom: .75rem !important; }
    .consumer-request-requirement { border-top: 1px solid #eceef3 !important; grid-column: 1 / -1; padding-top: .75rem !important; }
    .consumer-request-details,
    .consumer-request-status { border-top: 1px solid #eceef3 !important; margin-top: .75rem; padding-top: .75rem !important; }
    .consumer-request-action { align-items: stretch; grid-column: 1 / -1; margin-top: .8rem; }
    .consumer-request-action .parts-call-button { width: 100%; }
}

@media (max-width: 575px) {
    .requests-page-hero-content { align-items: flex-start; grid-template-columns: auto minmax(0,1fr); }
    .requests-page-total { align-items: flex-start; grid-column: 2; }
    .requests-page-toolbar { align-items: flex-start; flex-direction: column; }
    .requests-page-note { border-radius: .65rem; }
    .consumer-request-body { grid-template-columns: 1fr; }
}
