:root {
    --pps-blue: #00ADEE;
    --pps-blue-dark: #008FC6;
    --pps-red: #e02127;
    --pps-black: #0b0b0d;
    --pps-ink: #1e293b;
    --pps-muted: #667085;
    --pps-line: #e7edf3;
    --pps-soft: #f7f8fa;
    --pps-white: #ffffff;
    --pps-radius: 16px;
    --pps-shadow: 0 18px 45px rgba(15, 23, 42, .08);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body.pps-front-body { margin: 0; background: #fff; color: var(--pps-ink); font-family: Arial, Helvetica, sans-serif; line-height: 1.55; }
body.pps-front-body a { color: inherit; }
.pps-site-header { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,.98); border-bottom: 1px solid rgba(231,237,243,.95); box-shadow: 0 6px 22px rgba(15,23,42,.04); }
.pps-header-inner { max-width: 1180px; margin: 0 auto; min-height: 82px; padding: 15px clamp(18px,4vw,42px); display: flex; align-items: center; justify-content: space-between; gap: 28px; }
.pps-logo-link { display: inline-flex; align-items: center; text-decoration: none; }
.pps-logo-link img { display: block; width: min(260px, 58vw); height: auto; max-height: 54px; object-fit: contain; }
.pps-public-nav { display: flex; align-items: center; justify-content: flex-end; gap: 28px; }
.pps-public-nav a { color: #111827; text-decoration: none; font-size: 15px; font-weight: 700; letter-spacing: .01em; transition: color .18s ease; }
.pps-public-nav a:hover, .pps-public-nav a.is-active { color: var(--pps-blue-dark); }
.pps-cart-count { display: inline-flex; align-items: center; justify-content: center; min-width: 21px; height: 21px; margin-left: 6px; border-radius: 999px; background: var(--pps-red); color: #fff; font-size: 12px; line-height: 1; }
.pps-nav-toggle { display: none; width: 44px; height: 44px; border: 1px solid var(--pps-line); border-radius: 8px; background: #fff; padding: 10px; }
.pps-nav-toggle span { display: block; height: 2px; margin: 5px 0; background: #111827; }
.pps-main { min-height: 62vh; }
.pps-original-hero { min-height: clamp(440px, 66vh, 720px); display: grid; place-items: center; text-align: center; padding: clamp(54px, 10vw, 120px) 18px; background: linear-gradient(0deg, rgba(255,255,255,.84), rgba(255,255,255,.76)), radial-gradient(circle at 20% 18%, rgba(9,169,223,.15), transparent 34%), radial-gradient(circle at 78% 24%, rgba(224,33,39,.08), transparent 25%), #f5f8fa; position: relative; overflow: hidden; }
.pps-original-hero:before, .pps-original-hero:after { content: ""; position: absolute; width: 240px; height: 240px; border-radius: 999px; border: 32px solid rgba(9,169,223,.12); pointer-events: none; }
.pps-original-hero:before { left: -86px; bottom: -76px; }
.pps-original-hero:after { right: -110px; top: -92px; border-color: rgba(224,33,39,.08); }
.pps-original-hero-inner { max-width: 860px; position: relative; z-index: 1; }
.pps-original-kicker, .pps-eyebrow, .pps-card-kicker, .pps-product-type { display: inline-flex; color: var(--pps-blue-dark); font-size: 13px; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }
.pps-original-hero h1 { margin: 12px 0 8px; color: #111; font-size: clamp(3.1rem, 8.4vw, 7.4rem); line-height: .9; font-weight: 900; letter-spacing: -.055em; }
.pps-original-hero h2 { margin: 0 0 22px; color: var(--pps-red); font-size: clamp(1.15rem, 2.5vw, 2rem); line-height: 1.12; font-weight: 800; }
.pps-original-hero p { max-width: 720px; margin: 0 auto 30px; color: #475569; font-size: clamp(1rem, 1.35vw, 1.18rem); }
.pps-button-row { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.pps-center-buttons { justify-content: center; }
.pps-btn, button.pps-btn, input[type="submit"].pps-btn, .pps-action, .pps-school-card span, .pps-product-card a, .pps-cart-actions a, .pps-cart-actions button { display: inline-flex; align-items: center; justify-content: center; min-height: 46px; padding: 12px 20px; border-radius: 4px; border: 2px solid transparent; text-decoration: none; font-weight: 800; cursor: pointer; font-family: inherit; }
.pps-btn-primary, .pps-action, .pps-cart-actions button, input[type="submit"].pps-btn { background: var(--pps-red); color: #fff; border-color: var(--pps-red); }
.pps-btn-outline { background: #fff; color: var(--pps-black); border-color: #111827; }
.pps-btn:hover, .pps-action:hover { transform: translateY(-1px); }
.pps-section, .pps-page-hero, .pps-shop-hero, .pps-lock-hero, .pps-product-detail, .pps-cart-page, .pps-checkout-page { max-width: 1180px; margin: 0 auto; padding: clamp(34px, 6vw, 76px) clamp(18px, 4vw, 42px); }
.pps-page-hero { text-align: center; padding-top: clamp(42px, 6vw, 82px); padding-bottom: clamp(24px, 4vw, 42px); }
.pps-page-hero h1 { margin: 8px 0 8px; color: #111; font-size: clamp(2.2rem, 5.4vw, 4.6rem); line-height: .95; letter-spacing: -.045em; }
.pps-page-hero p { max-width: 720px; margin: 0 auto; color: var(--pps-muted); font-size: 1.08rem; }
.pps-section-header { display: flex; align-items: flex-end; justify-content: space-between; gap: 28px; margin-bottom: 28px; }
.pps-section-header-centered { text-align: center; justify-content: center; }
.pps-section-header h2, .pps-copy-columns h2 { margin: 8px 0 0; color: #111827; font-size: clamp(1.9rem, 3.6vw, 3.2rem); line-height: 1; letter-spacing: -.04em; }
.pps-section-header p { color: var(--pps-muted); margin: 10px auto 0; max-width: 720px; }
.pps-copy-columns { display: grid; grid-template-columns: minmax(220px, .85fr) 1.15fr; gap: clamp(28px, 7vw, 90px); align-items: start; }
.pps-copy-columns p { color: #475569; margin-top: 0; font-size: 1.05rem; }
.pps-service-cards, .pps-process-steps, .pps-school-grid, .pps-product-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 20px; }
.pps-service-cards article, .pps-process-steps article, .pps-school-card, .pps-product-card, .pps-form-card, .pps-card, .form-card, .admin-panel { background: #fff; border: 1px solid var(--pps-line); border-radius: var(--pps-radius); padding: 24px; box-shadow: 0 12px 34px rgba(15,23,42,.04); }
.pps-service-cards h3, .pps-process-steps strong, .pps-school-card h3, .pps-product-card h3 { margin: 0 0 10px; color: #111827; font-size: 1.18rem; line-height: 1.2; }
.pps-service-cards p, .pps-process-steps p, .pps-school-card p, .pps-product-card p { margin: 0; color: var(--pps-muted); }
.pps-process-steps span { color: var(--pps-red); font-size: 1.5rem; font-weight: 900; display: block; margin-bottom: 14px; }
.pps-home-school-cta { border-top: 1px solid var(--pps-line); }
.pps-school-directory-hero { text-align: center; }
.pps-school-toolbar { max-width: 760px; margin: 26px auto 0; }
.pps-school-search { position: relative; display: flex; align-items: center; gap: 10px; max-width: 620px; margin: 0 auto; }
.pps-school-search input { width: 100%; min-height: 54px; border: 1px solid #d8e2ec; border-radius: 999px; padding: 0 130px 0 22px; font-size: 1rem; outline: none; box-shadow: 0 10px 28px rgba(15,23,42,.05); }
.pps-school-search input:focus { border-color: var(--pps-blue); box-shadow: 0 0 0 4px rgba(9,169,223,.12); }
.pps-school-search button { position: absolute; right: 6px; top: 6px; bottom: 6px; min-height: 42px; border-radius: 999px; padding: 0 20px; }
.pps-school-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.pps-school-card { color: inherit; text-decoration: none; display: block; transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease; }
.pps-school-card:hover { transform: translateY(-3px); border-color: rgba(9,169,223,.35); box-shadow: var(--pps-shadow); }
.pps-school-logo,
.pps-school-logo-placeholder,
.pps-school-initials {
    width: 58px;
    height: 58px;
    min-width: 58px;
    min-height: 58px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    font-weight: 900;
    margin: 0 0 16px;
}

.pps-school-logo {
    background: #fff;
    border: 1px solid var(--pps-line);
    overflow: hidden;
    padding: 7px;
    flex: 0 0 58px;
    aspect-ratio: 1 / 1;
}

.pps-school-logo-image {
    display: block;
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
}

.pps-school-logo-placeholder,
.pps-school-initials { background: rgba(9,169,223,.11); color: var(--pps-blue-dark); }
.pps-school-card span { margin-top: 18px; background: #fff; color: var(--pps-red); border-color: rgba(224,33,39,.22); padding: 8px 13px; min-height: 0; font-size: .92rem; }
.pps-no-results { display: none; text-align: center; padding: 28px; color: var(--pps-muted); }
.pps-pagination { margin-top: 30px; }
.pps-flash { max-width: 980px; margin: 18px auto 0; padding: 13px 16px; border-radius: 12px; font-weight: 700; }
.pps-flash-success { background: #ecfdf3; color: #027a48; }
.pps-flash-error { background: #fff1f3; color: #b42318; }
.pps-shop-toolbar, .pps-product-layout, .pps-cart-layout, .pps-checkout-layout { display: grid; grid-template-columns: minmax(0, 1fr); gap: 22px; }
.pps-product-card img, .pps-product-image img { width: 100%; height: auto; border-radius: 12px; background: #f4f6f8; }
.pps-form-card label, .stack-form label, form label { display: grid; gap: 8px; color: #334155; font-weight: 700; margin-bottom: 14px; }
.pps-form-card input, .pps-form-card select, .pps-form-card textarea, .stack-form input, .stack-form select, .stack-form textarea, form input, form select, form textarea { width: 100%; min-height: 44px; border: 1px solid #d8e2ec; border-radius: 10px; padding: 10px 12px; font: inherit; }
.pps-site-footer { margin-top: 42px; border-top: 1px solid var(--pps-line); background: #fbfcfd; padding: 36px clamp(18px,4vw,42px); display: flex; justify-content: space-between; gap: 26px; align-items: flex-start; }
.pps-footer-brand img { display: block; width: min(250px, 72vw); max-height: 62px; object-fit: contain; margin-bottom: 12px; }
.pps-footer-brand p, .pps-footer-grid p { color: var(--pps-muted); margin: 0; }
.pps-footer-grid { display: flex; gap: 32px; }
.pps-footer-grid strong { display: block; color: #111827; }
@media (max-width: 900px) {
    .pps-nav-toggle { display: block; }
    .pps-public-nav { position: absolute; left: 18px; right: 18px; top: 78px; display: none; flex-direction: column; align-items: stretch; gap: 0; padding: 12px; background: #fff; border: 1px solid var(--pps-line); border-radius: 14px; box-shadow: var(--pps-shadow); }
    .pps-public-nav.is-open { display: flex; }
    .pps-public-nav a { padding: 13px 12px; border-radius: 10px; }
    .pps-copy-columns, .pps-service-cards, .pps-process-steps, .pps-school-grid, .pps-product-grid { grid-template-columns: 1fr; }
    .pps-site-footer { flex-direction: column; }
    .pps-footer-grid { flex-direction: column; gap: 12px; }
    .pps-school-search input { padding-right: 22px; border-radius: 14px; }
    .pps-school-search { display:block; }
    .pps-school-search button { position: static; width: 100%; margin-top: 10px; }
    .pps-original-hero h1 { font-size: clamp(3rem, 16vw, 5.2rem); }
}

/* =========================================================
   Printspace Frontend Button Uniformity Override
   Added to standardise all customer-facing buttons.
   ========================================================= */

:root {
    --pps-button-red: #e5232f;
    --pps-button-red-dark: #c91824;
    --pps-button-navy: #071f3d;
    --pps-button-border: #d9e1ec;
    --pps-button-muted: #6b7280;
}

/* Base button reset */
.pps-btn,
a.pps-btn,
button.pps-btn,
input[type="submit"].pps-btn,
.btn,
a.btn,
button.btn,
input[type="submit"].btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 44px;
    padding: 11px 18px;
    border-radius: 999px;
    border: 1px solid var(--pps-button-red);
    background: var(--pps-button-red);
    color: #ffffff !important;
    font-weight: 700;
    font-size: 14px;
    line-height: 1.1;
    text-decoration: none !important;
    cursor: pointer;
    transition: background-color .18s ease, border-color .18s ease, color .18s ease, transform .18s ease, box-shadow .18s ease;
    box-shadow: none;
}

/* Primary buttons */
.pps-btn-primary,
a.pps-btn-primary,
button.pps-btn-primary,
.btn:not(.secondary),
a.btn:not(.secondary),
button.btn:not(.secondary) {
    background: var(--pps-button-red);
    border-color: var(--pps-button-red);
    color: #ffffff !important;
}

/* Primary hover */
.pps-btn:hover,
a.pps-btn:hover,
button.pps-btn:hover,
.btn:hover,
a.btn:hover,
button.btn:hover {
    background: var(--pps-button-red-dark);
    border-color: var(--pps-button-red-dark);
    color: #ffffff !important;
    transform: translateY(-1px);
}

/* Secondary buttons */
.pps-btn-light,
.pps-btn-secondary,
.btn.secondary,
a.btn.secondary,
button.btn.secondary {
    background: #ffffff;
    border-color: var(--pps-button-border);
    color: var(--pps-button-navy) !important;
}

/* Secondary hover */
.pps-btn-light:hover,
.pps-btn-secondary:hover,
.btn.secondary:hover,
a.btn.secondary:hover,
button.btn.secondary:hover {
    background: #f6f8fb;
    border-color: #c8d2df;
    color: var(--pps-button-navy) !important;
}

/* Full-width button helper */
.pps-btn-full {
    width: 100%;
}

/* Remove / destructive text action */
.pps-link-danger,
button.pps-link-danger,
a.pps-link-danger {
    appearance: none;
    background: transparent !important;
    border: 0 !important;
    color: var(--pps-button-red) !important;
    padding: 0;
    min-height: auto;
    border-radius: 0;
    font-weight: 700;
    font-size: 14px;
    text-decoration: underline;
    text-underline-offset: 3px;
    box-shadow: none;
    cursor: pointer;
}

.pps-link-danger:hover,
button.pps-link-danger:hover,
a.pps-link-danger:hover {
    background: transparent !important;
    color: var(--pps-button-red-dark) !important;
    transform: none;
}

/* Disabled states */
.pps-btn:disabled,
.btn:disabled,
button:disabled,
input[type="submit"]:disabled,
.pps-btn.is-disabled,
.btn.is-disabled {
    background: #d1d5db !important;
    border-color: #d1d5db !important;
    color: #ffffff !important;
    cursor: not-allowed;
    transform: none;
    opacity: .8;
}

/* Mobile button comfort */
@media (max-width: 640px) {
    .pps-btn,
    a.pps-btn,
    button.pps-btn,
    .btn,
    a.btn,
    button.btn {
        width: 100%;
        min-height: 46px;
    }

    .pps-link-danger,
    button.pps-link-danger,
    a.pps-link-danger {
        width: auto;
    }
}

/* =========================================================
   School Card Label/Button Uniformity
   Makes school card spans match the primary button style.
   ========================================================= */

.pps-school-card span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 8px 14px;
    border-radius: 999px;
    background: var(--pps-button-red, #e5232f);
    border: 1px solid var(--pps-button-red, #e5232f);
    color: #ffffff !important;
    font-weight: 700;
    font-size: 13px;
    line-height: 1.1;
    text-decoration: none;
}

.pps-school-card:hover span {
    background: var(--pps-button-red-dark, #c91824);
    border-color: var(--pps-button-red-dark, #c91824);
    color: #ffffff !important;
}

/* =========================================================
   School Access Page Layout
   Clean desktop/mobile layout for private portal access.
   ========================================================= */

.pps-access-page {
    width: min(100%, 1120px);
    margin: 0 auto;
    padding: clamp(32px, 6vw, 72px) 20px;
    display: grid;
    place-items: center;
}

.pps-access-card {
    width: min(100%, 720px);
    background: #ffffff;
    border: 1px solid #e5eaf1;
    border-radius: 28px;
    padding: clamp(24px, 5vw, 48px);
    box-shadow: 0 18px 50px rgba(7, 31, 61, 0.08);
}

.pps-access-intro {
    text-align: center;
    margin-bottom: 28px;
}

.pps-access-intro h1 {
    margin: 8px 0 10px;
    color: #071f3d;
    font-size: clamp(30px, 5vw, 48px);
    line-height: 1.05;
    letter-spacing: -0.03em;
}

.pps-access-intro p {
    max-width: 540px;
    margin: 0 auto;
    color: #5b6676;
    font-size: 16px;
    line-height: 1.65;
}

.pps-access-form {
    display: grid;
    gap: 12px;
    margin: 0 auto 28px;
    max-width: 460px;
}

.pps-access-form label {
    color: #071f3d;
    font-weight: 800;
    font-size: 14px;
}

.pps-access-form input {
    width: 100%;
    min-height: 52px;
    border-radius: 16px;
    border: 1px solid #d9e1ec;
    background: #ffffff;
    padding: 0 16px;
    color: #071f3d;
    font-size: 16px;
    outline: none;
}

.pps-access-form input:focus {
    border-color: #e5232f;
    box-shadow: 0 0 0 4px rgba(229, 35, 47, 0.1);
}

.pps-access-help {
    margin-top: 28px;
    padding: 22px;
    border-radius: 22px;
    background: #f7f9fc;
    border: 1px solid #e8edf4;
}

.pps-access-help h2 {
    margin: 0 0 12px;
    color: #071f3d;
    font-size: 18px;
}

.pps-access-help ol {
    margin: 0;
    padding-left: 20px;
    color: #5b6676;
    line-height: 1.75;
}

.pps-access-actions {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 16px;
    margin-top: 24px;
}

.pps-access-actions a {
    color: #071f3d;
    font-weight: 700;
    text-decoration: underline;
    text-underline-offset: 4px;
}

.pps-notice {
    max-width: 460px;
    margin: 0 auto 18px;
    padding: 12px 14px;
    border-radius: 14px;
    font-size: 14px;
    font-weight: 700;
}

.pps-notice-success {
    background: #ecfdf3;
    color: #027a48;
    border: 1px solid #abefc6;
}

.pps-notice-error {
    background: #fff1f3;
    color: #c01048;
    border: 1px solid #fecdd6;
}

@media (max-width: 640px) {
    .pps-access-page {
        padding: 24px 14px 40px;
        align-items: start;
    }

    .pps-access-card {
        border-radius: 22px;
        padding: 22px 16px;
    }

    .pps-access-intro {
        text-align: left;
        margin-bottom: 22px;
    }

    .pps-access-intro p {
        margin: 0;
    }

    .pps-access-help {
        padding: 18px;
    }

    .pps-access-actions {
        flex-direction: column;
        align-items: center;
        gap: 10px;
    }
}

/* Center School Access Code label on portal access page */
.pps-access-form label {
    text-align: center;
}

/* =========================================================
   School Access Page Layout
   Clean desktop/mobile layout for private portal access.
   ========================================================= */

.pps-access-page {
    width: min(100%, 1120px);
    margin: 0 auto;
    padding: clamp(32px, 6vw, 72px) 20px;
    display: grid;
    place-items: center;
}

.pps-access-card {
    width: min(100%, 720px);
    background: #ffffff;
    border: 1px solid #e5eaf1;
    border-radius: 28px;
    padding: clamp(24px, 5vw, 48px);
    box-shadow: 0 18px 50px rgba(7, 31, 61, 0.08);
}

.pps-access-intro {
    text-align: center;
    margin-bottom: 28px;
}

.pps-access-intro h1 {
    margin: 8px 0 10px;
    color: #071f3d;
    font-size: clamp(30px, 5vw, 48px);
    line-height: 1.05;
    letter-spacing: -0.03em;
}

.pps-access-intro p {
    max-width: 540px;
    margin: 0 auto;
    color: #5b6676;
    font-size: 16px;
    line-height: 1.65;
}

.pps-access-form {
    display: grid;
    gap: 12px;
    margin: 0 auto 28px;
    max-width: 460px;
}

.pps-access-form label {
    color: #071f3d;
    font-weight: 800;
    font-size: 14px;
}

.pps-access-form input {
    width: 100%;
    min-height: 52px;
    border-radius: 16px;
    border: 1px solid #d9e1ec;
    background: #ffffff;
    padding: 0 16px;
    color: #071f3d;
    font-size: 16px;
    outline: none;
}

.pps-access-form input:focus {
    border-color: #e5232f;
    box-shadow: 0 0 0 4px rgba(229, 35, 47, 0.1);
}

.pps-access-help {
    margin-top: 28px;
    padding: 22px;
    border-radius: 22px;
    background: #f7f9fc;
    border: 1px solid #e8edf4;
}

.pps-access-help h2 {
    margin: 0 0 12px;
    color: #071f3d;
    font-size: 18px;
}

.pps-access-help ol {
    margin: 0;
    padding-left: 20px;
    color: #5b6676;
    line-height: 1.75;
}

.pps-access-actions {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 16px;
    margin-top: 24px;
}

.pps-access-actions a {
    color: #071f3d;
    font-weight: 700;
    text-decoration: underline;
    text-underline-offset: 4px;
}

.pps-notice {
    max-width: 460px;
    margin: 0 auto 18px;
    padding: 12px 14px;
    border-radius: 14px;
    font-size: 14px;
    font-weight: 700;
}

.pps-notice-success {
    background: #ecfdf3;
    color: #027a48;
    border: 1px solid #abefc6;
}

.pps-notice-error {
    background: #fff1f3;
    color: #c01048;
    border: 1px solid #fecdd6;
}

@media (max-width: 640px) {
    .pps-access-page {
        padding: 24px 14px 40px;
        align-items: start;
    }

    .pps-access-card {
        border-radius: 22px;
        padding: 22px 16px;
    }

    .pps-access-intro {
        text-align: left;
        margin-bottom: 22px;
    }

    .pps-access-intro p {
        margin: 0;
    }

    .pps-access-help {
        padding: 18px;
    }

    .pps-access-actions {
        flex-direction: column;
        align-items: center;
        gap: 10px;
    }
}

/* =========================================================
   Static Support / Policy Pages
   FAQ, Contact, Terms, Privacy, Cookie Notice
   ========================================================= */

.pps-content-card {
    width: min(100%, 960px);
    margin-left: auto;
    margin-right: auto;
    background: #ffffff;
    border: 1px solid #e5eaf1;
    border-radius: 28px;
    padding: clamp(24px, 5vw, 44px);
    box-shadow: 0 18px 50px rgba(7, 31, 61, 0.06);
}

.pps-policy-content {
    color: #4b5563;
    line-height: 1.75;
}

.pps-policy-content h2 {
    margin: 28px 0 8px;
    color: #071f3d;
    font-size: 22px;
    line-height: 1.25;
}

.pps-policy-content h2:first-child {
    margin-top: 0;
}

.pps-policy-content p {
    margin: 0 0 14px;
}

.pps-faq-list {
    display: grid;
    gap: 18px;
}

.pps-faq-list article {
    padding-bottom: 18px;
    border-bottom: 1px solid #e8edf4;
}

.pps-faq-list article:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.pps-faq-list h2 {
    margin: 0 0 8px;
    color: #071f3d;
    font-size: 20px;
}

.pps-faq-list p {
    margin: 0;
    color: #5b6676;
    line-height: 1.65;
}

.pps-contact-grid {
    width: min(100%, 1120px);
    margin-left: auto;
    margin-right: auto;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
}

.pps-contact-grid .pps-content-card {
    width: 100%;
    margin: 0;
}

.pps-check-list {
    margin: 0;
    padding-left: 20px;
    color: #5b6676;
    line-height: 1.75;
}

.pps-contact-card p {
    color: #5b6676;
    line-height: 1.7;
}

.pps-footer-policy-links {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 10px 18px;
    margin-top: 18px;
    padding-top: 18px;
    border-top: 1px solid rgba(7, 31, 61, 0.12);
    font-size: 14px;
}

.pps-footer-policy-links a {
    color: #071f3d;
    font-weight: 700;
    text-decoration: none;
}

.pps-footer-policy-links a:hover {
    color: #e5232f;
    text-decoration: underline;
    text-underline-offset: 4px;
}

@media (max-width: 900px) {
    .pps-contact-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .pps-content-card {
        border-radius: 22px;
        padding: 22px 16px;
    }

    .pps-policy-content h2,
    .pps-faq-list h2 {
        font-size: 19px;
    }

    .pps-footer-policy-links {
        flex-direction: column;
        align-items: center;
        gap: 10px;
    }
}
/* =========================================================
   Static Pages Restyle
   Cleaner, lighter support / policy page styling.
   ========================================================= */

.pps-content-card {
    width: min(100%, 900px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    padding: clamp(20px, 4vw, 36px) 20px !important;
    box-shadow: none !important;
}

.pps-policy-content {
    color: #425066 !important;
    font-size: 16px !important;
    line-height: 1.75 !important;
}

.pps-policy-content h2 {
    margin: 34px 0 10px !important;
    padding-top: 22px !important;
    border-top: 1px solid #e6ecf3 !important;
    color: #071f3d !important;
    font-size: clamp(20px, 2vw, 24px) !important;
    line-height: 1.25 !important;
    letter-spacing: -0.015em !important;
}

.pps-policy-content h2:first-child {
    margin-top: 0 !important;
    padding-top: 0 !important;
    border-top: 0 !important;
}

.pps-policy-content p {
    max-width: 760px !important;
    margin: 0 0 14px !important;
}

/* FAQ becomes clean rows instead of a heavy card */
.pps-faq-list {
    display: grid !important;
    gap: 0 !important;
    max-width: 860px !important;
    margin: 0 auto !important;
}

.pps-faq-list article {
    padding: 22px 0 !important;
    border-bottom: 1px solid #e6ecf3 !important;
}

.pps-faq-list article:first-child {
    padding-top: 0 !important;
}

.pps-faq-list article:last-child {
    border-bottom: 0 !important;
}

.pps-faq-list h2 {
    margin: 0 0 8px !important;
    color: #071f3d !important;
    font-size: clamp(18px, 2vw, 22px) !important;
    line-height: 1.3 !important;
    letter-spacing: -0.015em !important;
}

.pps-faq-list p {
    max-width: 740px !important;
    margin: 0 !important;
    color: #566276 !important;
    line-height: 1.7 !important;
}

/* Contact page: lighter panels */
.pps-contact-grid {
    width: min(100%, 1080px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 18px !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
}

.pps-contact-grid .pps-content-card {
    width: 100% !important;
    margin: 0 !important;
    padding: 24px !important;
    background: #ffffff !important;
    border: 1px solid #e6ecf3 !important;
    border-radius: 22px !important;
    box-shadow: 0 10px 30px rgba(7, 31, 61, 0.04) !important;
}

.pps-contact-grid h2 {
    margin: 0 0 12px !important;
    color: #071f3d !important;
    font-size: 20px !important;
}

.pps-check-list {
    margin: 0 !important;
    padding-left: 20px !important;
    color: #566276 !important;
    line-height: 1.75 !important;
}

.pps-contact-card p {
    color: #566276 !important;
    line-height: 1.7 !important;
}

/* Footer links: make subtle, not another big section */
.pps-footer-policy-links {
    display: flex !important;
    justify-content: center !important;
    flex-wrap: wrap !important;
    gap: 8px 18px !important;
    margin-top: 18px !important;
    padding-top: 16px !important;
    border-top: 1px solid rgba(7, 31, 61, 0.1) !important;
    font-size: 13px !important;
}

.pps-footer-policy-links a {
    color: rgba(7, 31, 61, 0.72) !important;
    font-weight: 600 !important;
    text-decoration: none !important;
}

.pps-footer-policy-links a:hover {
    color: #e5232f !important;
    text-decoration: underline !important;
    text-underline-offset: 4px !important;
}

/* Mobile cleanup */
@media (max-width: 900px) {
    .pps-contact-grid {
        grid-template-columns: 1fr !important;
        width: min(100%, 720px) !important;
    }
}

@media (max-width: 640px) {
    .pps-content-card {
        padding: 16px 14px 28px !important;
    }

    .pps-policy-content {
        font-size: 15px !important;
        line-height: 1.7 !important;
    }

    .pps-policy-content h2 {
        margin-top: 28px !important;
        padding-top: 18px !important;
    }

    .pps-faq-list article {
        padding: 18px 0 !important;
    }

    .pps-contact-grid {
        padding-left: 14px !important;
        padding-right: 14px !important;
    }

    .pps-contact-grid .pps-content-card {
        padding: 20px 16px !important;
        border-radius: 18px !important;
    }

    .pps-footer-policy-links {
        gap: 8px 14px !important;
        font-size: 13px !important;
    }
}

/* =========================================================
   Footer Policy Links - Cleaner Subtle Style
   Keeps FAQ / Contact / Terms / Privacy / Cookies quiet.
   ========================================================= */

.pps-footer-policy-links {
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 0 !important;
    margin: 12px auto 0 !important;
    padding: 10px 0 0 !important;
    border-top: 1px solid rgba(7, 31, 61, 0.08) !important;
    font-size: 12px !important;
    line-height: 1.4 !important;
}

.pps-footer-policy-links a {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    color: rgba(7, 31, 61, 0.58) !important;
    font-weight: 500 !important;
    text-decoration: none !important;
    padding: 4px 9px !important;
}

.pps-footer-policy-links a:not(:last-child)::after {
    content: "·" !important;
    position: absolute !important;
    right: -2px !important;
    color: rgba(7, 31, 61, 0.32) !important;
}

.pps-footer-policy-links a:hover {
    color: #e5232f !important;
    text-decoration: none !important;
}

@media (max-width: 640px) {
    .pps-footer-policy-links {
        max-width: 280px !important;
        gap: 2px 0 !important;
        margin-top: 14px !important;
        padding-top: 12px !important;
    }

    .pps-footer-policy-links a {
        padding: 4px 8px !important;
        font-size: 12px !important;
    }
}

/* =========================================================
   Footer Two-Row Layout
   Brand left, footer grid right, policy links beneath.
   ========================================================= */

.pps-footer {
    display: grid !important;
    grid-template-columns: minmax(220px, 1fr) auto !important;
    grid-template-areas:
        "brand grid"
        "policy policy" !important;
    align-items: start !important;
    gap: 24px 40px !important;
}

.pps-footer-brand {
    grid-area: brand !important;
    align-self: start !important;
}

.pps-footer-grid {
    grid-area: grid !important;
    justify-self: end !important;
    align-self: start !important;
}

.pps-footer-policy-links {
    grid-area: policy !important;
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 0 !important;
    margin: 4px auto 0 !important;
    padding: 18px 0 0 !important;
    border-top: 1px solid rgba(7, 31, 61, 0.10) !important;
    font-size: 12px !important;
    line-height: 1.4 !important;
}

.pps-footer-policy-links a {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    color: rgba(7, 31, 61, 0.58) !important;
    font-weight: 500 !important;
    text-decoration: none !important;
    padding: 4px 10px !important;
}

.pps-footer-policy-links a:not(:last-child)::after {
    content: "·" !important;
    position: absolute !important;
    right: -2px !important;
    color: rgba(7, 31, 61, 0.32) !important;
}

.pps-footer-policy-links a:hover {
    color: #e5232f !important;
    text-decoration: none !important;
}

/* Mobile footer stacks naturally */
@media (max-width: 760px) {
    .pps-footer {
        grid-template-columns: 1fr !important;
        grid-template-areas:
            "brand"
            "grid"
            "policy" !important;
        gap: 22px !important;
        text-align: center !important;
    }

    .pps-footer-brand,
    .pps-footer-grid {
        justify-self: center !important;
    }

    .pps-footer-policy-links {
        max-width: 320px !important;
        margin-top: 0 !important;
        padding-top: 16px !important;
    }

    .pps-footer-policy-links a {
        font-size: 12px !important;
        padding: 4px 8px !important;
    }
}

/* Footer copyright line */
.pps-footer-copyright {
    grid-column: 1 / -1 !important;
    width: 100% !important;
    text-align: center !important;
    margin-top: -8px !important;
    color: rgba(7, 31, 61, 0.46) !important;
    font-size: 12px !important;
    line-height: 1.5 !important;
}

@media (max-width: 760px) {
    .pps-footer-copyright {
        margin-top: -10px !important;
    }
}

/* =========================================================
   Site Footer Two-Row Layout
   Row 1: brand left, footer grid right
   Row 2: policy links + copyright beneath
   ========================================================= */

.pps-site-footer {
    display: grid !important;
    grid-template-columns: minmax(240px, 1fr) auto !important;
    grid-template-areas:
        "brand grid"
        "policy policy"
        "copyright copyright" !important;
    align-items: start !important;
    gap: 22px 44px !important;
}

.pps-site-footer .pps-footer-brand {
    grid-area: brand !important;
    justify-self: start !important;
}

.pps-site-footer .pps-footer-grid {
    grid-area: grid !important;
    justify-self: end !important;
}

.pps-site-footer .pps-footer-policy-links {
    grid-area: policy !important;
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 0 !important;
    margin: 0 !important;
    padding: 18px 0 0 !important;
    border-top: 1px solid rgba(7, 31, 61, 0.10) !important;
}

.pps-site-footer .pps-footer-copyright {
    grid-area: copyright !important;
    width: 100% !important;
    text-align: center !important;
    margin: -6px 0 0 !important;
}

/* Mobile footer stacks cleanly */
@media (max-width: 760px) {
    .pps-site-footer {
        grid-template-columns: 1fr !important;
        grid-template-areas:
            "brand"
            "grid"
            "policy"
            "copyright" !important;
        gap: 20px !important;
        text-align: center !important;
    }

    .pps-site-footer .pps-footer-brand,
    .pps-site-footer .pps-footer-grid {
        justify-self: center !important;
    }

    .pps-site-footer .pps-footer-policy-links {
        max-width: 320px !important;
        margin-left: auto !important;
        margin-right: auto !important;
        padding-top: 16px !important;
    }

    .pps-site-footer .pps-footer-copyright {
        margin-top: -8px !important;
    }
}

/* =========================================================
   Clean Footer Layout
   Row 1: brand left, footer links right
   Row 2: policy links + copyright below
   ========================================================= */

.pps-site-footer {
    display: block !important;
    padding: clamp(32px, 5vw, 56px) 20px 24px !important;
    background: #ffffff !important;
    border-top: 1px solid #e8edf4 !important;
}

.pps-footer-main-row {
    width: min(100%, 1120px) !important;
    margin: 0 auto !important;
    display: grid !important;
    grid-template-columns: minmax(260px, 1fr) auto !important;
    gap: 32px 56px !important;
    align-items: start !important;
}

.pps-footer-brand {
    max-width: 360px !important;
    text-align: left !important;
}

.pps-footer-brand img {
    width: min(260px, 100%) !important;
    height: auto !important;
    display: block !important;
    margin: 0 0 14px !important;
}

.pps-footer-brand p {
    margin: 0 !important;
    color: #566276 !important;
    line-height: 1.65 !important;
    font-size: 14px !important;
}

.pps-footer-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(120px, auto)) !important;
    gap: 28px 48px !important;
    justify-content: end !important;
    text-align: left !important;
}

.pps-footer-grid h3 {
    margin: 0 0 10px !important;
    color: #071f3d !important;
    font-size: 13px !important;
    line-height: 1.2 !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: .08em !important;
}

.pps-footer-grid a {
    display: block !important;
    margin: 7px 0 !important;
    color: #566276 !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
}

.pps-footer-grid a:hover {
    color: #e5232f !important;
}

.pps-footer-policy-row {
    width: min(100%, 1120px) !important;
    margin: 28px auto 0 !important;
    padding-top: 18px !important;
    border-top: 1px solid rgba(7, 31, 61, 0.10) !important;
    text-align: center !important;
}

.pps-footer-policy-links {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    font-size: 12px !important;
    line-height: 1.4 !important;
}

.pps-footer-policy-links a {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    color: rgba(7, 31, 61, 0.58) !important;
    font-weight: 500 !important;
    text-decoration: none !important;
    padding: 4px 10px !important;
}

.pps-footer-policy-links a:not(:last-child)::after {
    content: "·" !important;
    position: absolute !important;
    right: -2px !important;
    color: rgba(7, 31, 61, 0.32) !important;
}

.pps-footer-policy-links a:hover {
    color: #e5232f !important;
}

.pps-footer-copyright {
    margin: 8px 0 0 !important;
    color: rgba(7, 31, 61, 0.46) !important;
    font-size: 12px !important;
    line-height: 1.5 !important;
    text-align: center !important;
}

@media (max-width: 760px) {
    .pps-footer-main-row {
        grid-template-columns: 1fr !important;
        justify-items: center !important;
        text-align: center !important;
    }

    .pps-footer-brand {
        text-align: center !important;
    }

    .pps-footer-brand img {
        margin-left: auto !important;
        margin-right: auto !important;
    }

    .pps-footer-grid {
        justify-content: center !important;
        text-align: center !important;
        grid-template-columns: repeat(2, minmax(110px, auto)) !important;
        gap: 24px !important;
    }

    .pps-footer-policy-row {
        margin-top: 24px !important;
    }

    .pps-footer-policy-links {
        max-width: 320px !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }
}

@media (max-width: 440px) {
    .pps-footer-grid {
        grid-template-columns: 1fr !important;
    }
}

/* =========================================================
   FINAL FOOTER STRUCTURE OVERRIDE
   Row 1: brand left, footer grid right
   Row 2: policy links and copyright beneath
   ========================================================= */

footer.pps-site-footer {
    display: block !important;
    width: 100% !important;
    padding: clamp(34px, 5vw, 56px) 20px 24px !important;
    background: #ffffff !important;
    border-top: 1px solid #e8edf4 !important;
}

footer.pps-site-footer .pps-footer-inner {
    width: min(100%, 1120px) !important;
    margin: 0 auto !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 26px !important;
}

footer.pps-site-footer .pps-footer-main-row {
    width: 100% !important;
    display: grid !important;
    grid-template-columns: minmax(260px, 1fr) auto !important;
    gap: 32px 56px !important;
    align-items: start !important;
}

footer.pps-site-footer .pps-footer-brand {
    max-width: 370px !important;
    justify-self: start !important;
    text-align: left !important;
}

footer.pps-site-footer .pps-footer-brand img {
    display: block !important;
    width: min(260px, 100%) !important;
    max-width: 260px !important;
    height: auto !important;
    margin: 0 0 14px !important;
}

footer.pps-site-footer .pps-footer-brand p {
    margin: 0 !important;
    color: #566276 !important;
    font-size: 14px !important;
    line-height: 1.65 !important;
}

footer.pps-site-footer .pps-footer-grid {
    justify-self: end !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(130px, auto)) !important;
    gap: 28px 52px !important;
    text-align: left !important;
}

footer.pps-site-footer .pps-footer-grid h3 {
    margin: 0 0 10px !important;
    color: #071f3d !important;
    font-size: 13px !important;
    line-height: 1.2 !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: .08em !important;
}

footer.pps-site-footer .pps-footer-grid a {
    display: block !important;
    margin: 7px 0 !important;
    color: #566276 !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
}

footer.pps-site-footer .pps-footer-grid a:hover {
    color: #e5232f !important;
}

footer.pps-site-footer .pps-footer-policy-row {
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 8px !important;
    padding-top: 18px !important;
    border-top: 1px solid rgba(7, 31, 61, 0.10) !important;
    text-align: center !important;
}

footer.pps-site-footer .pps-footer-policy-links {
    width: auto !important;
    max-width: 100% !important;
    display: flex !important;
    flex-direction: row !important;
    justify-content: center !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    font-size: 12px !important;
    line-height: 1.4 !important;
}

footer.pps-site-footer .pps-footer-policy-links a {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    color: rgba(7, 31, 61, 0.58) !important;
    font-weight: 500 !important;
    text-decoration: none !important;
    padding: 4px 10px !important;
}

footer.pps-site-footer .pps-footer-policy-links a:not(:last-child)::after {
    content: "·" !important;
    position: absolute !important;
    right: -2px !important;
    color: rgba(7, 31, 61, 0.32) !important;
}

footer.pps-site-footer .pps-footer-policy-links a:hover {
    color: #e5232f !important;
}

footer.pps-site-footer .pps-footer-copyright {
    width: 100% !important;
    margin: 0 !important;
    color: rgba(7, 31, 61, 0.46) !important;
    font-size: 12px !important;
    line-height: 1.5 !important;
    text-align: center !important;
}

@media (max-width: 760px) {
    footer.pps-site-footer {
        padding: 32px 16px 24px !important;
    }

    footer.pps-site-footer .pps-footer-main-row {
        grid-template-columns: 1fr !important;
        gap: 24px !important;
        justify-items: center !important;
    }

    footer.pps-site-footer .pps-footer-brand {
        max-width: 360px !important;
        text-align: center !important;
        justify-self: center !important;
    }

    footer.pps-site-footer .pps-footer-brand img {
        margin-left: auto !important;
        margin-right: auto !important;
    }

    footer.pps-site-footer .pps-footer-grid {
        justify-self: center !important;
        grid-template-columns: repeat(2, minmax(110px, auto)) !important;
        gap: 24px !important;
        text-align: center !important;
    }

    footer.pps-site-footer .pps-footer-policy-links {
        max-width: 320px !important;
    }
}

@media (max-width: 440px) {
    footer.pps-site-footer .pps-footer-grid {
        grid-template-columns: 1fr !important;
    }
}

/* =========================================================
   Footer Row Fix
   Keeps footer brand and footer grid on the same row.
   Policy links and copyright remain below.
   ========================================================= */

footer.pps-site-footer .pps-footer-main-row {
    width: 100% !important;
    display: flex !important;
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: flex-start !important;
    gap: 48px !important;
}

footer.pps-site-footer .pps-footer-brand {
    flex: 0 1 380px !important;
    max-width: 380px !important;
    text-align: left !important;
}

footer.pps-site-footer .pps-footer-grid {
    flex: 0 0 auto !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(130px, auto)) !important;
    gap: 28px 52px !important;
    justify-content: end !important;
    text-align: left !important;
}

/* Keep policy row clearly beneath both columns */
footer.pps-site-footer .pps-footer-policy-row {
    width: 100% !important;
    clear: both !important;
}

/* Only stack brand and grid on small mobile */
@media (max-width: 640px) {
    footer.pps-site-footer .pps-footer-main-row {
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 24px !important;
        text-align: center !important;
    }

    footer.pps-site-footer .pps-footer-brand {
        flex: none !important;
        max-width: 360px !important;
        text-align: center !important;
    }

    footer.pps-site-footer .pps-footer-grid {
        flex: none !important;
        justify-content: center !important;
        text-align: center !important;
        grid-template-columns: repeat(2, minmax(110px, auto)) !important;
        gap: 24px !important;
    }
}

@media (max-width: 440px) {
    footer.pps-site-footer .pps-footer-grid {
        grid-template-columns: 1fr !important;
    }
}

/* Footer small contact note */
footer.pps-site-footer .pps-footer-small {
    margin-top: 6px !important;
    color: rgba(7, 31, 61, 0.52) !important;
    font-size: 12px !important;
    line-height: 1.4 !important;
}

/* =========================================================
   HARD FINAL FOOTER REBUILD
   Row 1: brand left, phone grid right
   Row 2: policy links
   Row 3: copyright
   ========================================================= */

footer.pps-site-footer {
    display: block !important;
    width: 100% !important;
    padding: 44px 20px 24px !important;
    background: #ffffff !important;
    border-top: 1px solid #e8edf4 !important;
}

footer.pps-site-footer .pps-footer-inner {
    width: min(100%, 1120px) !important;
    margin: 0 auto !important;
    display: block !important;
}

footer.pps-site-footer .pps-footer-main-row {
    width: 100% !important;
    display: flex !important;
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: flex-start !important;
    gap: 48px !important;
}

footer.pps-site-footer .pps-footer-brand {
    flex: 0 1 380px !important;
    max-width: 380px !important;
    text-align: left !important;
}

footer.pps-site-footer .pps-footer-brand img {
    display: block !important;
    width: 260px !important;
    max-width: 100% !important;
    height: auto !important;
    margin: 0 0 14px !important;
}

footer.pps-site-footer .pps-footer-brand p {
    margin: 0 !important;
    color: #566276 !important;
    font-size: 14px !important;
    line-height: 1.65 !important;
}

footer.pps-site-footer .pps-footer-grid {
    flex: 0 0 auto !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(150px, auto)) !important;
    gap: 28px 54px !important;
    align-items: start !important;
    justify-content: end !important;
    text-align: left !important;
}

footer.pps-site-footer .pps-footer-grid h3 {
    margin: 0 0 10px !important;
    color: #071f3d !important;
    font-size: 13px !important;
    line-height: 1.2 !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: .08em !important;
}

footer.pps-site-footer .pps-footer-grid p {
    margin: 4px 0 !important;
    color: #566276 !important;
    font-size: 14px !important;
    line-height: 1.45 !important;
}

footer.pps-site-footer .pps-footer-grid a {
    color: #566276 !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
}

footer.pps-site-footer .pps-footer-grid a:hover {
    color: #e5232f !important;
}

footer.pps-site-footer .pps-footer-small {
    color: rgba(7, 31, 61, 0.52) !important;
    font-size: 12px !important;
    margin-top: 7px !important;
}

footer.pps-site-footer .pps-footer-policy-row {
    width: 100% !important;
    margin-top: 28px !important;
    padding-top: 18px !important;
    border-top: 1px solid rgba(7, 31, 61, 0.10) !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 8px !important;
    text-align: center !important;
}

footer.pps-site-footer .pps-footer-policy-links {
    display: flex !important;
    flex-direction: row !important;
    justify-content: center !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    font-size: 12px !important;
    line-height: 1.4 !important;
}

footer.pps-site-footer .pps-footer-policy-links a {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    color: rgba(7, 31, 61, 0.58) !important;
    font-weight: 500 !important;
    text-decoration: none !important;
    padding: 4px 10px !important;
}

footer.pps-site-footer .pps-footer-policy-links a:not(:last-child)::after {
    content: "·" !important;
    position: absolute !important;
    right: -2px !important;
    color: rgba(7, 31, 61, 0.32) !important;
}

footer.pps-site-footer .pps-footer-policy-links a:hover {
    color: #e5232f !important;
}

footer.pps-site-footer .pps-footer-copyright {
    width: 100% !important;
    margin: 0 !important;
    color: rgba(7, 31, 61, 0.46) !important;
    font-size: 12px !important;
    line-height: 1.5 !important;
    text-align: center !important;
}

@media (max-width: 760px) {
    footer.pps-site-footer {
        padding: 34px 16px 24px !important;
    }

    footer.pps-site-footer .pps-footer-main-row {
        flex-direction: column !important;
        align-items: center !important;
        gap: 24px !important;
        text-align: center !important;
    }

    footer.pps-site-footer .pps-footer-brand {
        flex: none !important;
        max-width: 360px !important;
        text-align: center !important;
    }

    footer.pps-site-footer .pps-footer-brand img {
        margin-left: auto !important;
        margin-right: auto !important;
    }

    footer.pps-site-footer .pps-footer-grid {
        width: 100% !important;
        justify-content: center !important;
        grid-template-columns: repeat(2, minmax(130px, auto)) !important;
        gap: 24px !important;
        text-align: center !important;
    }

    footer.pps-site-footer .pps-footer-policy-links {
        max-width: 320px !important;
    }
}

@media (max-width: 440px) {
    footer.pps-site-footer .pps-footer-grid {
        grid-template-columns: 1fr !important;
    }
}

/* =========================================================
   Clean Footer Rebuild
   New isolated class names. No !important.
   ========================================================= */

.pps-clean-footer {
    background: #ffffff;
    border-top: 1px solid #e8edf4;
    padding: 44px 20px 24px;
}

.pps-clean-footer__inner {
    width: min(100%, 1120px);
    margin: 0 auto;
}

.pps-clean-footer__top {
    display: grid;
    grid-template-columns: minmax(260px, 360px) minmax(0, 1fr);
    gap: 48px;
    align-items: start;
}

.pps-clean-footer__brand img {
    display: block;
    width: 260px;
    max-width: 100%;
    height: auto;
    margin-bottom: 14px;
}

.pps-clean-footer__brand p {
    max-width: 340px;
    margin: 0;
    color: #566276;
    font-size: 14px;
    line-height: 1.65;
}

.pps-clean-footer__contacts {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, auto));
    gap: 28px 36px;
    justify-content: end;
    align-items: start;
}

.pps-clean-footer__contact-card {
    min-width: 145px;
}

.pps-clean-footer__contact-card h3 {
    margin: 0 0 10px;
    color: #071f3d;
    font-size: 12px;
    line-height: 1.2;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.pps-clean-footer__contact-card p {
    margin: 4px 0;
    color: #566276;
    font-size: 14px;
    line-height: 1.5;
}

.pps-clean-footer__contact-card strong {
    color: #071f3d;
    font-weight: 800;
}

.pps-clean-footer__contact-card a {
    display: inline-block;
    margin-top: 2px;
    color: #566276;
    font-size: 14px;
    font-weight: 700;
    text-decoration: none;
}

.pps-clean-footer__contact-card a:hover {
    color: #e5232f;
}

.pps-clean-footer__contact-card span {
    display: block;
    margin-top: 7px;
    color: rgba(7, 31, 61, 0.52);
    font-size: 12px;
    line-height: 1.4;
}

.pps-clean-footer__address {
    max-width: 260px;
}

.pps-clean-footer__bottom {
    margin-top: 30px;
    padding-top: 18px;
    border-top: 1px solid rgba(7, 31, 61, 0.10);
    text-align: center;
}

.pps-clean-footer__links {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 0;
    margin: 0;
    padding: 0;
}

.pps-clean-footer__links a {
    position: relative;
    display: inline-flex;
    align-items: center;
    color: rgba(7, 31, 61, 0.58);
    font-size: 12px;
    font-weight: 500;
    line-height: 1.4;
    text-decoration: none;
    padding: 4px 10px;
}

.pps-clean-footer__links a:not(:last-child)::after {
    content: "·";
    position: absolute;
    right: -2px;
    color: rgba(7, 31, 61, 0.32);
}

.pps-clean-footer__links a:hover {
    color: #e5232f;
}

.pps-clean-footer__copyright {
    margin: 8px 0 0;
    color: rgba(7, 31, 61, 0.46);
    font-size: 12px;
    line-height: 1.5;
}

@media (max-width: 900px) {
    .pps-clean-footer__top {
        grid-template-columns: 1fr;
        gap: 30px;
    }

    .pps-clean-footer__brand {
        text-align: center;
    }

    .pps-clean-footer__brand img {
        margin-left: auto;
        margin-right: auto;
    }

    .pps-clean-footer__brand p {
        margin-left: auto;
        margin-right: auto;
    }

    .pps-clean-footer__contacts {
        justify-content: center;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        text-align: center;
    }

    .pps-clean-footer__address {
        max-width: none;
    }
}

@media (max-width: 640px) {
    .pps-clean-footer {
        padding: 34px 16px 24px;
    }

    .pps-clean-footer__contacts {
        grid-template-columns: 1fr;
        gap: 22px;
    }

    .pps-clean-footer__contact-card {
        min-width: 0;
    }

    .pps-clean-footer__links {
        max-width: 320px;
        margin-left: auto;
        margin-right: auto;
    }

    .pps-clean-footer__links a {
        padding: 4px 8px;
    }
}

/* =========================================================
   Footer V3
   Clean isolated footer. No !important.
   ========================================================= */

.pps-footer-v3 {
    margin-top: 48px;
    background: #ffffff;
    border-top: 1px solid #e8edf4;
    padding: 44px 20px 24px;
}

.pps-footer-v3__inner {
    width: min(100%, 1120px);
    margin: 0 auto;
}

.pps-footer-v3__main {
    display: grid;
    grid-template-columns: minmax(260px, 360px) minmax(0, 1fr);
    gap: 48px;
    align-items: start;
}

.pps-footer-v3__brand img {
    display: block;
    width: 260px;
    max-width: 100%;
    height: auto;
    margin-bottom: 14px;
}

.pps-footer-v3__brand p {
    max-width: 340px;
    margin: 0;
    color: #566276;
    font-size: 14px;
    line-height: 1.65;
}

.pps-footer-v3__info {
    display: grid;
    gap: 22px;
    justify-items: end;
}

.pps-footer-v3__contacts {
    display: grid;
    grid-template-columns: repeat(2, minmax(150px, auto));
    gap: 28px 44px;
    text-align: left;
}

.pps-footer-v3__contact span,
.pps-footer-v3__address span {
    display: block;
    margin-bottom: 8px;
    color: #071f3d;
    font-size: 12px;
    line-height: 1.2;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.pps-footer-v3__contact strong {
    display: block;
    margin-bottom: 3px;
    color: #071f3d;
    font-size: 14px;
    line-height: 1.35;
    font-weight: 800;
}

.pps-footer-v3__contact a {
    display: inline-block;
    color: #566276;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.45;
    text-decoration: none;
}

.pps-footer-v3__contact a:hover {
    color: #e5232f;
}

.pps-footer-v3__contact small {
    display: block;
    margin-top: 6px;
    color: rgba(7, 31, 61, .54);
    font-size: 12px;
    line-height: 1.4;
}

.pps-footer-v3__address {
    width: min(100%, 392px);
    text-align: left;
}

.pps-footer-v3__address p {
    margin: 3px 0;
    color: #566276;
    font-size: 14px;
    line-height: 1.55;
}

.pps-footer-v3__bottom {
    margin-top: 30px;
    padding-top: 18px;
    border-top: 1px solid rgba(7, 31, 61, .1);
    text-align: center;
}

.pps-footer-v3__links {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 0;
}

.pps-footer-v3__links a {
    position: relative;
    display: inline-flex;
    align-items: center;
    color: rgba(7, 31, 61, .58);
    font-size: 12px;
    font-weight: 500;
    line-height: 1.4;
    text-decoration: none;
    padding: 4px 10px;
}

.pps-footer-v3__links a:not(:last-child)::after {
    content: "·";
    position: absolute;
    right: -2px;
    color: rgba(7, 31, 61, .32);
}

.pps-footer-v3__links a:hover {
    color: #e5232f;
}

.pps-footer-v3__copyright {
    margin: 8px 0 0;
    color: rgba(7, 31, 61, .46);
    font-size: 12px;
    line-height: 1.5;
}

@media (max-width: 900px) {
    .pps-footer-v3__main {
        grid-template-columns: 1fr;
        gap: 30px;
    }

    .pps-footer-v3__brand {
        text-align: center;
    }

    .pps-footer-v3__brand img,
    .pps-footer-v3__brand p {
        margin-left: auto;
        margin-right: auto;
    }

    .pps-footer-v3__info {
        justify-items: center;
    }

    .pps-footer-v3__contacts {
        text-align: center;
    }

    .pps-footer-v3__address {
        text-align: center;
    }
}

@media (max-width: 640px) {
    .pps-footer-v3 {
        padding: 34px 16px 24px;
    }

    .pps-footer-v3__contacts {
        grid-template-columns: 1fr;
        gap: 22px;
    }

    .pps-footer-v3__links {
        max-width: 320px;
        margin-left: auto;
        margin-right: auto;
    }

    .pps-footer-v3__links a {
        padding: 4px 8px;
    }
}

/* =========================================================
   Clean Footer
   Single footer system. No !important.
   ========================================================= */

.pps-clean-footer {
    margin-top: 56px;
    background: #ffffff;
    border-top: 1px solid #e8edf4;
    padding: 46px 20px 24px;
}

.pps-clean-footer__inner {
    width: min(100%, 1180px);
    margin: 0 auto;
}

.pps-clean-footer__main {
    display: grid;
    grid-template-columns: minmax(260px, 370px) minmax(0, 1fr);
    gap: 56px;
    align-items: start;
}

.pps-clean-footer__brand img {
    display: block;
    width: min(260px, 100%);
    height: auto;
    margin-bottom: 14px;
}

.pps-clean-footer__brand p {
    max-width: 340px;
    margin: 0;
    color: #566276;
    font-size: 14px;
    line-height: 1.65;
}

.pps-clean-footer__details {
    display: grid;
    grid-template-columns: minmax(220px, auto) minmax(240px, 360px);
    gap: 42px;
    justify-content: end;
    align-items: start;
}

.pps-clean-footer__contact-group h3,
.pps-clean-footer__address h3 {
    margin: 0 0 12px;
    color: #071f3d;
    font-size: 12px;
    font-weight: 800;
    line-height: 1.2;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.pps-clean-footer__contact {
    margin-bottom: 12px;
}

.pps-clean-footer__contact:last-child {
    margin-bottom: 0;
}

.pps-clean-footer__contact strong {
    display: block;
    margin-bottom: 2px;
    color: #071f3d;
    font-size: 14px;
    font-weight: 800;
    line-height: 1.35;
}

.pps-clean-footer__contact a {
    color: #566276;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.45;
    text-decoration: none;
}

.pps-clean-footer__contact a:hover {
    color: #e5232f;
}

.pps-clean-footer__contact span {
    display: block;
    margin-top: 4px;
    color: rgba(7, 31, 61, .54);
    font-size: 12px;
    line-height: 1.4;
}

.pps-clean-footer__address p {
    margin: 3px 0;
    color: #566276;
    font-size: 14px;
    line-height: 1.55;
}

.pps-clean-footer__bottom {
    margin-top: 32px;
    padding-top: 18px;
    border-top: 1px solid rgba(7, 31, 61, .1);
    text-align: center;
}

.pps-clean-footer__links {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0;
}

.pps-clean-footer__links a {
    position: relative;
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    color: rgba(7, 31, 61, .58);
    font-size: 12px;
    font-weight: 500;
    line-height: 1.4;
    text-decoration: none;
}

.pps-clean-footer__links a:not(:last-child)::after {
    content: "·";
    position: absolute;
    right: -2px;
    color: rgba(7, 31, 61, .32);
}

.pps-clean-footer__links a:hover {
    color: #e5232f;
}

.pps-clean-footer__copyright {
    margin: 8px 0 0;
    color: rgba(7, 31, 61, .46);
    font-size: 12px;
    line-height: 1.5;
}

@media (max-width: 900px) {
    .pps-clean-footer__main {
        grid-template-columns: 1fr;
        gap: 30px;
    }

    .pps-clean-footer__brand {
        text-align: center;
    }

    .pps-clean-footer__brand img,
    .pps-clean-footer__brand p {
        margin-left: auto;
        margin-right: auto;
    }

    .pps-clean-footer__details {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
        justify-content: center;
        text-align: center;
    }
}

@media (max-width: 640px) {
    .pps-clean-footer {
        padding: 34px 16px 24px;
    }

    .pps-clean-footer__details {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .pps-clean-footer__links {
        max-width: 320px;
        margin-left: auto;
        margin-right: auto;
    }

    .pps-clean-footer__links a {
        padding: 4px 8px;
    }
}

/* === Product catalogue V2 start === */
.pps-storefront-hero {
    max-width: 1240px;
    margin: 0 auto;
    padding: clamp(38px, 6vw, 82px) clamp(18px, 4vw, 42px) clamp(24px, 4vw, 44px);
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 28px;
    border-bottom: 1px solid var(--pps-line);
}

.pps-storefront-hero h1 {
    margin: 8px 0 10px;
    max-width: 780px;
    color: #111827;
    font-size: clamp(2.4rem, 5vw, 4.7rem);
    line-height: .94;
    letter-spacing: -.06em;
}

.pps-storefront-hero p {
    max-width: 680px;
    margin: 0;
    color: var(--pps-muted);
    font-size: 1.05rem;
}

.pps-storefront-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.pps-catalogue-section {
    max-width: 1240px;
}

.pps-catalogue-section .pps-section-header {
    margin-bottom: 26px;
}

.pps-catalogue-section .pps-section-header h2 {
    margin-bottom: 6px;
}

.pps-catalogue-group + .pps-catalogue-group {
    margin-top: clamp(34px, 5vw, 58px);
}

.pps-catalogue-heading {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 16px;
}

.pps-catalogue-heading h3 {
    margin: 0;
    color: #111827;
    font-size: clamp(1.25rem, 2vw, 1.75rem);
    line-height: 1.1;
    letter-spacing: -.035em;
}

.pps-catalogue-heading span {
    color: var(--pps-muted);
    font-size: .9rem;
    font-weight: 800;
}

.pps-catalogue-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
}

.pps-catalogue-card {
    display: flex;
    min-width: 0;
    flex-direction: column;
    overflow: hidden;
    background: #fff;
    border: 1px solid rgba(226, 232, 240, .95);
    border-radius: 18px;
    color: inherit;
    text-decoration: none;
    box-shadow: 0 10px 26px rgba(15, 23, 42, .045);
    transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

.pps-catalogue-card:hover {
    transform: translateY(-3px);
    border-color: rgba(0, 173, 238, .34);
    box-shadow: 0 20px 42px rgba(15, 23, 42, .09);
}

.pps-catalogue-media {
    position: relative;
    display: grid;
    place-items: center;
    height: 245px;
    background:
        radial-gradient(circle at 20% 10%, rgba(0, 173, 238, .12), transparent 32%),
        linear-gradient(180deg, #f8fafc, #eef3f7);
    overflow: hidden;
}

.pps-catalogue-media img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 28px 22px 24px;
}

.pps-catalogue-tag {
    position: absolute;
    top: 12px;
    left: 12px;
    z-index: 2;
    max-width: calc(100% - 24px);
    padding: 6px 9px;
    border-radius: 999px;
    background: rgba(255, 255, 255, .92);
    color: var(--pps-blue-dark);
    font-size: .68rem;
    font-weight: 900;
    line-height: 1;
    letter-spacing: .08em;
    text-transform: uppercase;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    box-shadow: 0 8px 18px rgba(15, 23, 42, .08);
}

.pps-catalogue-placeholder {
    display: grid;
    place-items: center;
    width: 100%;
    height: 100%;
    min-height: 220px;
}

.pps-catalogue-placeholder span {
    display: grid;
    place-items: center;
    width: 76px;
    height: 76px;
    border-radius: 999px;
    background: #fff;
    color: var(--pps-blue-dark);
    font-weight: 900;
    box-shadow: 0 14px 30px rgba(15, 23, 42, .08);
}

.pps-catalogue-body {
    display: flex;
    flex: 1;
    flex-direction: column;
    padding: 16px;
}

.pps-catalogue-body h3 {
    margin: 0;
    min-height: 2.7em;
    color: #111827;
    font-size: 1.02rem;
    line-height: 1.28;
    letter-spacing: -.018em;
}

.pps-catalogue-meta {
    margin-top: 8px;
    color: #64748b;
    font-size: .86rem;
    font-weight: 700;
}

.pps-catalogue-footer {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 12px;
    margin-top: auto;
    padding-top: 16px;
}

.pps-catalogue-footer small {
    display: block;
    margin-bottom: 3px;
    color: #64748b;
    font-size: .7rem;
    font-weight: 900;
    letter-spacing: .09em;
    line-height: 1;
    text-transform: uppercase;
}

.pps-catalogue-footer strong {
    color: #111827;
    font-size: 1.28rem;
    line-height: 1;
    letter-spacing: -.04em;
}

.pps-catalogue-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 36px;
    padding: 8px 11px;
    border-radius: 999px;
    background: #111827;
    color: #fff;
    font-size: .78rem;
    font-weight: 900;
    white-space: nowrap;
}

.pps-catalogue-card:hover .pps-catalogue-cta {
    background: var(--pps-red);
}

.pps-product-page-v2 {
    max-width: 1240px;
    margin: 0 auto;
    padding: clamp(36px, 6vw, 82px) clamp(18px, 4vw, 42px);
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(360px, .95fr);
    gap: clamp(28px, 5vw, 64px);
    align-items: start;
}

.pps-product-display {
    position: sticky;
    top: 108px;
    display: grid;
    place-items: center;
    min-height: 560px;
    border: 1px solid rgba(226, 232, 240, .95);
    border-radius: 26px;
    background:
        radial-gradient(circle at 20% 10%, rgba(0, 173, 238, .12), transparent 34%),
        linear-gradient(180deg, #f8fafc, #eef3f7);
    box-shadow: 0 18px 46px rgba(15, 23, 42, .065);
    overflow: hidden;
}

.pps-product-display img {
    width: 100%;
    height: 100%;
    max-height: 560px;
    object-fit: contain;
    padding: clamp(28px, 5vw, 58px);
}

.pps-product-purchase-card {
    padding: clamp(22px, 3vw, 32px);
    border: 1px solid rgba(226, 232, 240, .95);
    border-radius: 24px;
    background: #fff;
    box-shadow: 0 16px 42px rgba(15, 23, 42, .055);
}

.pps-product-purchase-card h1 {
    margin: 10px 0 12px;
    color: #111827;
    font-size: clamp(2rem, 4vw, 3.6rem);
    line-height: .96;
    letter-spacing: -.055em;
}

.pps-product-purchase-card p {
    color: #475569;
}

.pps-product-price-box {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 16px;
    margin: 22px 0;
    padding: 18px 0;
    border-top: 1px solid var(--pps-line);
    border-bottom: 1px solid var(--pps-line);
}

.pps-product-price-box span {
    color: #64748b;
    font-size: .76rem;
    font-weight: 900;
    letter-spacing: .09em;
    text-transform: uppercase;
}

.pps-product-price-box strong {
    color: #111827;
    font-size: clamp(2rem, 4vw, 3rem);
    line-height: 1;
    letter-spacing: -.055em;
}

.pps-product-form-v2 {
    display: grid;
    gap: 14px;
}

.pps-product-form-v2 label {
    margin: 0;
    color: #334155;
    font-weight: 850;
}

.pps-product-form-v2 select,
.pps-product-form-v2 input {
    min-height: 48px;
    border-radius: 12px;
}

.pps-product-standard-note {
    display: grid;
    gap: 2px;
    padding: 13px 14px;
    border-radius: 14px;
    background: #f8fafc;
    color: #64748b;
}

.pps-product-standard-note strong {
    color: #111827;
}

.pps-btn-full {
    width: 100%;
}

@media (max-width: 1100px) {
    .pps-catalogue-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 860px) {
    .pps-storefront-hero,
    .pps-product-page-v2 {
        grid-template-columns: 1fr;
        display: grid;
    }

    .pps-catalogue-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .pps-product-display {
        position: relative;
        top: auto;
        min-height: 420px;
    }
}

@media (max-width: 560px) {
    .pps-storefront-actions {
        width: 100%;
    }

    .pps-storefront-actions > * {
        width: 100%;
        justify-content: center;
    }

    .pps-catalogue-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .pps-catalogue-media {
        height: 230px;
    }

    .pps-catalogue-heading {
        display: grid;
        gap: 4px;
    }

    .pps-catalogue-body h3 {
        min-height: 0;
    }

    .pps-product-display {
        min-height: 340px;
    }

    .pps-product-display img {
        max-height: 340px;
    }
}
/* === Product catalogue V2 end === */

/* === Login and customer account start === */
.pps-auth-page,
.pps-account-page {
    max-width: 1120px;
    margin: 0 auto;
    padding: clamp(42px, 7vw, 88px) clamp(18px, 4vw, 42px);
}

.pps-auth-card {
    max-width: 480px;
    margin: 0 auto;
    padding: clamp(24px, 4vw, 38px);
    border: 1px solid var(--pps-line);
    border-radius: 24px;
    background: #fff;
    box-shadow: 0 18px 46px rgba(15, 23, 42, .075);
}

.pps-auth-card h1,
.pps-account-header h1 {
    margin: 10px 0 10px;
    color: #111827;
    font-size: clamp(2rem, 4vw, 3.4rem);
    line-height: .98;
    letter-spacing: -.055em;
}

.pps-auth-card p,
.pps-account-header p {
    color: var(--pps-muted);
}

.pps-auth-form {
    display: grid;
    gap: 12px;
    margin-top: 22px;
}

.pps-auth-form label {
    margin: 0;
    color: #334155;
    font-weight: 850;
}

.pps-auth-form input {
    min-height: 48px;
    border-radius: 12px;
}

.pps-check-row {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    font-size: .95rem;
}

.pps-check-row input {
    min-height: auto;
}

.pps-auth-links {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    flex-wrap: wrap;
    margin-top: 18px;
}

.pps-auth-links a,
.pps-field-error {
    font-size: .9rem;
}

.pps-field-error {
    color: #b91c1c;
    font-weight: 700;
}

.pps-form-notice {
    margin-top: 16px;
    padding: 12px 14px;
    border-radius: 14px;
    background: #ecfdf3;
    color: #027a48;
    font-weight: 800;
}

.pps-nav-form {
    display: inline-flex;
}

.pps-nav-form button {
    border: 0;
    background: transparent;
    color: inherit;
    font: inherit;
    font-weight: 800;
    cursor: pointer;
}

.pps-account-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 22px;
    margin-bottom: 24px;
}

.pps-account-card {
    display: grid;
    gap: 12px;
}

.pps-account-order {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    align-items: center;
    gap: 18px;
    padding: 18px;
    border: 1px solid var(--pps-line);
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 10px 28px rgba(15, 23, 42, .045);
}

.pps-account-order div {
    display: grid;
    gap: 3px;
}

.pps-account-order strong {
    color: #111827;
}

.pps-account-order span,
.pps-account-order small {
    color: var(--pps-muted);
}

.pps-account-status {
    display: inline-flex;
    justify-content: center;
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(0, 173, 238, .09);
    color: var(--pps-blue-dark) !important;
    font-size: .78rem;
    font-weight: 900;
    text-transform: capitalize;
}

@media (max-width: 720px) {
    .pps-account-header,
    .pps-account-order {
        grid-template-columns: 1fr;
        align-items: stretch;
    }

    .pps-account-order .pps-link-button {
        justify-content: center;
    }
}
/* === Login and customer account end === */

/* === Shared public nav form style start === */
.pps-public-nav .pps-nav-form,
.pps-public-nav .pps-logout-form {
    display: inline-flex;
    align-items: center;
    margin: 0;
}

.pps-public-nav .pps-nav-form button,
.pps-public-nav .pps-logout-form button,
.pps-public-nav .pps-logout-button {
    appearance: none;
    border: 0;
    background: transparent;
    color: #111827;
    text-decoration: none;
    font: inherit;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: .01em;
    line-height: inherit;
    padding: 0;
    cursor: pointer;
    transition: color .18s ease;
}

.pps-public-nav .pps-nav-form button:hover,
.pps-public-nav .pps-logout-form button:hover,
.pps-public-nav .pps-logout-button:hover {
    color: var(--pps-blue-dark);
}

@media (max-width: 760px) {
    .pps-public-nav .pps-nav-form,
    .pps-public-nav .pps-logout-form {
        width: 100%;
    }

    .pps-public-nav .pps-nav-form button,
    .pps-public-nav .pps-logout-form button,
    .pps-public-nav .pps-logout-button {
        width: 100%;
        padding: 13px 12px;
        border-radius: 10px;
        text-align: left;
    }
}
/* === Shared public nav form style end === */

.pps-access-school-logo {
    width: 112px;
    height: 112px;
    margin: 0 auto 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(229, 231, 235, .95);
    border-radius: 24px;
    background: #fff;
    box-shadow: 0 14px 30px rgba(15, 23, 42, .08);
}

.pps-access-school-logo img {
    max-width: 86px;
    max-height: 86px;
    object-fit: contain;
}
