/* ==========================================================================
   S-A-Web Custom Stylesheet
   Bootstrap 5 overrides + site-specific components
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. CSS Custom Properties
   -------------------------------------------------------------------------- */
:root {
    --saw-primary:          #c0392b;
    --saw-primary-hover:    #e74c3c;
    --saw-primary-dark:     #922b21;
    --saw-primary-alpha:    rgba(192, 57, 43, 0.15);

    --saw-bg:               #0d0d17;
    --saw-bg-2:             #141420;
    --saw-bg-3:             #1c1c2e;
    --saw-bg-card:          #1e1e30;
    --saw-bg-card-hover:    #232338;

    --saw-text:             #e4e4f0;
    --saw-text-muted:       #7a7a9a;
    --saw-text-light:       #b0b0c8;
    --saw-border:           #2a2a44;
    --saw-border-hover:     #c0392b;

    --saw-topbar-bg:        #0a0a12;
    --saw-topbar-text:      #6a6a8a;

    --saw-shadow-sm:        0 2px 12px rgba(0, 0, 0, .4);
    --saw-shadow-md:        0 8px 32px rgba(0, 0, 0, .5);
    --saw-shadow-lg:        0 16px 48px rgba(0, 0, 0, .6);
    --saw-shadow-glow:      0 0 24px rgba(192, 57, 43, .35);

    --saw-radius:           10px;
    --saw-radius-lg:        16px;
    --saw-radius-xl:        24px;

    --saw-transition:       0.25s ease;

    --saw-section-py:       5rem;
    --saw-section-py-sm:    3rem;
}

/* --------------------------------------------------------------------------
   2. Bootstrap Overrides
   -------------------------------------------------------------------------- */
body {
    background-color: var(--saw-bg);
    color: var(--saw-text);
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    -webkit-font-smoothing: antialiased;
}

a {
    color: var(--saw-primary);
    text-decoration: none;
    transition: color var(--saw-transition);
}

a:hover {
    color: var(--saw-primary-hover);
}

/* Primary colour overrides */
.btn-primary {
    --bs-btn-bg:             var(--saw-primary);
    --bs-btn-border-color:   var(--saw-primary);
    --bs-btn-hover-bg:       var(--saw-primary-hover);
    --bs-btn-hover-border-color: var(--saw-primary-hover);
    --bs-btn-active-bg:      var(--saw-primary-dark);
    --bs-btn-focus-shadow-rgb: 192, 57, 43;
    font-weight: 600;
    letter-spacing: 0.02em;
}

.btn-outline-primary {
    --bs-btn-color:          var(--saw-primary);
    --bs-btn-border-color:   var(--saw-primary);
    --bs-btn-hover-bg:       var(--saw-primary);
    --bs-btn-hover-border-color: var(--saw-primary);
    --bs-btn-active-bg:      var(--saw-primary-dark);
    font-weight: 600;
}

.btn-outline-secondary {
    --bs-btn-color:          var(--saw-text-muted);
    --bs-btn-border-color:   var(--saw-border);
    --bs-btn-hover-bg:       var(--saw-bg-card-hover);
    --bs-btn-hover-color:    var(--saw-text);
    --bs-btn-hover-border-color: var(--saw-text-muted);
}

.text-primary { color: var(--saw-primary) !important; }

.form-control,
.form-select {
    background-color: var(--saw-bg-card);
    border-color:     var(--saw-border);
    color:            var(--saw-text);
    transition:       border-color var(--saw-transition), box-shadow var(--saw-transition);
}

.form-control::placeholder { color: var(--saw-text-muted); }

.form-control:focus,
.form-select:focus {
    background-color: var(--saw-bg-card-hover);
    border-color:     var(--saw-primary);
    color:            var(--saw-text);
    box-shadow:       0 0 0 0.2rem rgba(192, 57, 43, 0.25);
}

.form-label { color: var(--saw-text-light); font-weight: 500; }

.alert-success {
    background-color: rgba(39, 174, 96, 0.15);
    border-color:     rgba(39, 174, 96, 0.4);
    color:            #2ecc71;
}

.alert-danger {
    background-color: rgba(192, 57, 43, 0.15);
    border-color:     rgba(192, 57, 43, 0.4);
    color:            #e74c3c;
}

.accordion-item {
    background-color: var(--saw-bg-card);
    border-color:     var(--saw-border);
}

.accordion-button {
    background-color: var(--saw-bg-card);
    color:            var(--saw-text);
}

.accordion-button:not(.collapsed) {
    background-color: var(--saw-bg-card-hover);
    color:            var(--saw-primary);
    box-shadow:       inset 0 -1px 0 var(--saw-border);
}

.accordion-button::after {
    filter: invert(1) sepia(1) saturate(3) hue-rotate(315deg);
}

.accordion-button:focus {
    box-shadow: 0 0 0 0.2rem var(--saw-primary-alpha);
}

.breadcrumb-item a { color: rgba(255,255,255,.6); }
.breadcrumb-item.active { color: rgba(255,255,255,.9); }
.breadcrumb-item + .breadcrumb-item::before { color: rgba(255,255,255,.4); }

/* --------------------------------------------------------------------------
   3. Top Bar
   -------------------------------------------------------------------------- */
.saw-topbar {
    background-color: var(--saw-topbar-bg);
    border-bottom: 1px solid var(--saw-border);
    font-size: .8125rem;
}

.saw-topbar-link {
    color: var(--saw-topbar-text);
    transition: color var(--saw-transition);
}

.saw-topbar-link:hover { color: var(--saw-text); }

/* --------------------------------------------------------------------------
   4. Navbar
   -------------------------------------------------------------------------- */
.saw-navbar {
    background-color: rgba(13, 13, 23, 0.95);
    border-bottom: 1px solid var(--saw-border);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    padding-top: .75rem;
    padding-bottom: .75rem;
    transition: background-color var(--saw-transition), box-shadow var(--saw-transition);
}

.saw-navbar.scrolled {
    background-color: var(--saw-bg);
    box-shadow: 0 2px 20px rgba(0, 0, 0, .5);
}

.saw-navbar .navbar-brand img { height: 40px; width: auto; }

.saw-navbar .nav-link {
    color: var(--saw-text-light);
    font-size: .9rem;
    font-weight: 500;
    padding-left: .85rem !important;
    padding-right: .85rem !important;
    transition: color var(--saw-transition);
    position: relative;
}

.saw-navbar .nav-link::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: .85rem;
    right: .85rem;
    height: 2px;
    background: var(--saw-primary);
    transform: scaleX(0);
    transition: transform var(--saw-transition);
    border-radius: 1px;
}

.saw-navbar .nav-link:hover,
.saw-navbar .nav-link.active {
    color: #fff;
}

.saw-navbar .nav-link:hover::after,
.saw-navbar .nav-link.active::after {
    transform: scaleX(1);
}

.saw-navbar .navbar-toggler {
    border-color: var(--saw-border);
}

.saw-navbar .navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28228, 228, 240, 0.8%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

@media (max-width: 991.98px) {
    .saw-navbar .navbar-collapse {
        background-color: var(--saw-bg-2);
        border-top: 1px solid var(--saw-border);
        padding: 1rem;
        border-radius: 0 0 var(--saw-radius) var(--saw-radius);
    }
    .saw-navbar .nav-link::after { display: none; }
    .saw-navbar .nav-link { padding: .5rem .75rem !important; border-radius: 6px; }
    .saw-navbar .nav-link:hover { background-color: var(--saw-bg-3); }
    .saw-navbar .ms-lg-2 { margin-top: .5rem; }
}

/* --------------------------------------------------------------------------
   5. Hero Section
   -------------------------------------------------------------------------- */
.saw-hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    overflow: hidden;
    background-color: var(--saw-bg);
}

.saw-hero-canvas {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: .6;
}

.saw-hero-overlay {
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 30% 60%, rgba(192, 57, 43, 0.12) 0%, transparent 65%),
                linear-gradient(180deg, rgba(13,13,23,0) 60%, var(--saw-bg) 100%);
    pointer-events: none;
}

.saw-hero-content {
    position: relative;
    z-index: 2;
    padding-top: 5rem;
    padding-bottom: 5rem;
}

.saw-hero-eyebrow {
    font-size: .85rem;
    font-weight: 600;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--saw-primary);
    margin-bottom: 1.25rem;
}

.saw-hero-title {
    font-size: clamp(2.5rem, 6vw, 4.5rem);
    font-weight: 900;
    line-height: 1.1;
    letter-spacing: -.02em;
    color: #fff;
    margin-bottom: 1.5rem;
}

.saw-hero-subtitle {
    font-size: clamp(1rem, 2vw, 1.2rem);
    color: var(--saw-text-light);
    line-height: 1.7;
    margin-bottom: 2rem;
}

.saw-btn-hero {
    font-weight: 700;
    letter-spacing: .04em;
}

.saw-hero-scroll {
    position: absolute;
    bottom: 2rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2;
    color: var(--saw-text-muted);
    font-size: 1.2rem;
    animation: saw-bounce 2s infinite;
    transition: color var(--saw-transition);
}

.saw-hero-scroll:hover { color: var(--saw-primary); }

@keyframes saw-bounce {
    0%, 100% { transform: translateX(-50%) translateY(0); }
    50%       { transform: translateX(-50%) translateY(8px); }
}

/* --------------------------------------------------------------------------
   6. Section Layout Utilities
   -------------------------------------------------------------------------- */
.saw-section {
    padding: var(--saw-section-py) 0;
}

.saw-section-sm,
.saw-section-alt {
    padding: var(--saw-section-py) 0;
}

.saw-section-sm {
    padding: var(--saw-section-py-sm) 0;
}

.saw-section-alt {
    background-color: var(--saw-bg-2);
}

.saw-eyebrow {
    font-size: .8125rem;
    font-weight: 700;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--saw-primary);
    margin-bottom: .75rem;
}

.saw-section-title {
    font-size: clamp(1.75rem, 4vw, 2.75rem);
    font-weight: 800;
    letter-spacing: -.02em;
    color: #fff;
    line-height: 1.15;
    margin-bottom: 1rem;
}

.saw-section-lead,
.saw-section-text {
    color: var(--saw-text-light);
    line-height: 1.75;
}

.saw-section-lead {
    font-size: 1.1rem;
    max-width: 680px;
    margin-left: auto;
    margin-right: auto;
}

/* --------------------------------------------------------------------------
   7. About Section
   -------------------------------------------------------------------------- */
.saw-stats-row {
    border-top: 1px solid var(--saw-border);
    padding-top: 1.5rem;
}

.saw-stat-number {
    font-size: 2.25rem;
    font-weight: 900;
    color: var(--saw-primary);
    line-height: 1;
}

.saw-stat-plus {
    font-size: 1.25rem;
    vertical-align: top;
    margin-top: .25rem;
    display: inline-block;
    color: var(--saw-primary);
}

.saw-stat-label {
    font-size: .8rem;
    color: var(--saw-text-muted);
    text-transform: uppercase;
    letter-spacing: .1em;
    margin-top: .35rem;
}

.saw-about-graphic {
    padding: 2rem;
}

/* --------------------------------------------------------------------------
   8. Service Cards
   -------------------------------------------------------------------------- */
.saw-service-card {
    background-color: var(--saw-bg-card);
    border: 1px solid var(--saw-border);
    border-radius: var(--saw-radius-lg);
    padding: 2.5rem 2rem;
    transition: border-color var(--saw-transition), box-shadow var(--saw-transition), transform var(--saw-transition);
}

.saw-service-card:hover {
    border-color: var(--saw-primary);
    box-shadow: var(--saw-shadow-glow), var(--saw-shadow-md);
    transform: translateY(-4px);
}

.saw-service-card--featured {
    border-color: var(--saw-primary);
    background: linear-gradient(145deg, var(--saw-bg-card) 0%, rgba(192, 57, 43, 0.08) 100%);
}

.saw-service-icon {
    font-size: 2.5rem;
    color: var(--saw-primary);
    margin-bottom: 1.25rem;
}

.saw-service-title {
    font-size: 1.25rem;
    font-weight: 700;
    color: #fff;
    margin-bottom: 1rem;
}

/* --------------------------------------------------------------------------
   9. Network / Site Cards
   -------------------------------------------------------------------------- */

/* Photo thumbnail at top of each network card */
.saw-site-thumb {
    display: block;
    position: relative;
    aspect-ratio: 16 / 9;
    background-size: cover;
    background-position: center;
    background-color: var(--saw-bg-3);
    overflow: hidden;
    border-radius: var(--saw-radius-lg) var(--saw-radius-lg) 0 0;
    text-decoration: none;
}

/* Category badge pinned to top-left of thumbnail */
.saw-site-thumb-badge {
    position: absolute;
    top: .65rem;
    left: .65rem;
    z-index: 1;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}

/* Dark overlay + visit icon revealed on hover */
.saw-site-thumb-overlay {
    position: absolute;
    inset: 0;
    background: rgba(192, 57, 43, 0.6);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.8rem;
    color: #fff;
    opacity: 0;
    transition: opacity var(--saw-transition);
}

.saw-site-thumb:hover .saw-site-thumb-overlay,
.saw-site-card:hover .saw-site-thumb-overlay {
    opacity: 1;
}
.saw-filter-bar {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: .5rem;
}

.saw-filter-btn {
    background-color: var(--saw-bg-card);
    border: 1px solid var(--saw-border);
    color: var(--saw-text-muted);
    border-radius: 50px;
    padding: .45rem 1.25rem;
    font-size: .875rem;
    font-weight: 600;
    transition: all var(--saw-transition);
    cursor: pointer;
}

.saw-filter-btn:hover,
.saw-filter-btn.active {
    background-color: var(--saw-primary);
    border-color:     var(--saw-primary);
    color:            #fff;
    box-shadow:       0 4px 16px rgba(192, 57, 43, .4);
}

.saw-site-card {
    background-color: var(--saw-bg-card);
    border: 1px solid var(--saw-border);
    border-radius: var(--saw-radius-lg);
    overflow: hidden;
    transition: border-color var(--saw-transition), box-shadow var(--saw-transition), transform var(--saw-transition);
}

.saw-site-card:hover {
    border-color: var(--saw-primary);
    box-shadow: var(--saw-shadow-md);
    transform: translateY(-4px);
}

.saw-site-card-head {
    padding: 1.5rem 1.5rem 0;
}

.saw-site-card-body {
    padding: .75rem 1.5rem;
    color: var(--saw-text-light);
    font-size: .9rem;
    line-height: 1.65;
}

.saw-site-card-foot {
    padding: 0 1.5rem 1.5rem;
}

.saw-site-name {
    font-size: 1.1rem;
    font-weight: 700;
    color: #fff;
    margin: .5rem 0 .35rem;
}

.saw-site-domain {
    font-size: .8125rem;
    color: var(--saw-text-muted);
    margin-bottom: 0;
}

.saw-site-domain a { color: var(--saw-text-muted); }
.saw-site-domain a:hover { color: var(--saw-primary); }

/* Badges */
.saw-badge {
    display: inline-flex;
    align-items: center;
    font-size: .7125rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    padding: .3em .75em;
    border-radius: 50px;
    border: 1px solid transparent;
}

.saw-badge-sm { font-size: .65rem; padding: .2em .6em; }

.saw-badge-danger    { background-color: rgba(192,57,43,.15);  color: #e74c3c;  border-color: rgba(192,57,43,.3);  }
.saw-badge-warning   { background-color: rgba(230,126,34,.15); color: #e67e22;  border-color: rgba(230,126,34,.3); }
.saw-badge-info      { background-color: rgba(52,152,219,.15); color: #3498db;  border-color: rgba(52,152,219,.3); }
.saw-badge-fight     { background-color: rgba(149,165,166,.15);color: #95a5a6;  border-color: rgba(149,165,166,.3);}
.saw-badge-secondary { background-color: rgba(108,117,125,.15);color: #9aa5af;  border-color: rgba(108,117,125,.3);}

/* --------------------------------------------------------------------------
   10. Featured Models
   -------------------------------------------------------------------------- */
.saw-model-card {
    border-radius: var(--saw-radius-lg);
    overflow: hidden;
    border: 1px solid var(--saw-border);
    transition: border-color var(--saw-transition), box-shadow var(--saw-transition), transform var(--saw-transition);
}

.saw-model-card:hover {
    border-color: var(--saw-primary);
    box-shadow: var(--saw-shadow-md);
    transform: translateY(-5px);
}

/* Photo area — square crop with background-image */
.saw-model-photo {
    position: relative;
    aspect-ratio: 3 / 4;
    background-size: cover;
    background-position: center top;
    background-color: var(--saw-bg-card);
    overflow: hidden;
}

/* Gradient overlay always present at bottom for legibility */
.saw-model-photo::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(13,13,23,.85) 0%, transparent 55%);
    pointer-events: none;
}

/* Social links overlay — slides up on hover */
.saw-model-overlay {
    position: absolute;
    inset: 0;
    background: rgba(192, 57, 43, 0.55);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity var(--saw-transition);
    z-index: 1;
}

.saw-model-card:hover .saw-model-overlay {
    opacity: 1;
}

.saw-model-socials a {
    color: #fff;
    font-size: 1.3rem;
    transition: transform var(--saw-transition);
}

.saw-model-socials a:hover {
    transform: scale(1.2);
    color: #fff;
}

/* Name / site beneath the photo */
.saw-model-info {
    background-color: var(--saw-bg-card);
    padding: .85rem 1rem;
    border-top: 1px solid var(--saw-border);
}

.saw-model-name {
    font-size: .95rem;
    font-weight: 700;
    color: #fff;
    margin-bottom: .15rem;
}

.saw-model-site {
    font-size: .78rem;
    color: var(--saw-primary);
    margin-bottom: 0;
}

/* --------------------------------------------------------------------------
   11. Testimonial
   -------------------------------------------------------------------------- */
.saw-testimonial {
    background: linear-gradient(135deg, var(--saw-primary-dark) 0%, var(--saw-primary) 100%);
}

.saw-quote-icon {
    font-size: 3rem;
    color: rgba(255,255,255,.3);
}

.saw-testimonial-text {
    font-size: clamp(1.1rem, 2.5vw, 1.4rem);
    font-style: italic;
    color: rgba(255,255,255,.92);
    line-height: 1.7;
    margin-bottom: 0;
}

.saw-testimonial-author {
    font-size: .9rem;
    font-weight: 600;
    color: rgba(255,255,255,.7);
    font-style: normal;
}

/* --------------------------------------------------------------------------
   12. Contact Section
   -------------------------------------------------------------------------- */
.saw-contact-info { display: flex; flex-direction: column; gap: 1.75rem; }

.saw-contact-item {
    display: flex;
    align-items: flex-start;
    gap: 1.25rem;
}

.saw-contact-icon {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    background: var(--saw-primary-alpha);
    border: 1px solid rgba(192,57,43,.3);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    color: var(--saw-primary);
}

.saw-contact-item h3 {
    font-size: .9rem;
    font-weight: 700;
    color: var(--saw-text-muted);
    text-transform: uppercase;
    letter-spacing: .1em;
    margin-bottom: .35rem;
}

.saw-contact-item address,
.saw-contact-item p,
.saw-contact-item a {
    font-size: .95rem;
    color: var(--saw-text-light);
    margin-bottom: 0;
    font-style: normal;
    line-height: 1.65;
}

.saw-contact-item a:hover { color: var(--saw-primary); }

.saw-map-wrapper iframe {
    filter: brightness(.85) contrast(1.05) saturate(.8);
}

.saw-contact-form .btn-primary { font-size: 1.05rem; font-weight: 700; }

/* --------------------------------------------------------------------------
   13. Page Hero (billing / terms pages)
   -------------------------------------------------------------------------- */
.saw-page-hero {
    position: relative;
    min-height: 40vh;
    display: flex;
    align-items: center;
    background-color: var(--saw-bg-2);
    border-bottom: 1px solid var(--saw-border);
    overflow: hidden;
}

.saw-page-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse at 70% 50%, rgba(192,57,43,.12) 0%, transparent 60%),
        repeating-linear-gradient(
            45deg,
            rgba(255,255,255,.015) 0px, rgba(255,255,255,.015) 1px,
            transparent 1px, transparent 40px
        );
    pointer-events: none;
}

.saw-page-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(13,13,23,.6) 0%, transparent 100%);
}

.saw-page-hero-content {
    position: relative;
    z-index: 1;
    padding: 5rem 1rem;
}

.saw-page-hero-title {
    font-size: clamp(2rem, 5vw, 3.5rem);
    font-weight: 900;
    color: #fff;
    letter-spacing: -.02em;
    margin-bottom: .75rem;
}

.saw-page-hero-subtitle {
    color: rgba(255,255,255,.6);
    font-style: italic;
    font-size: 1.05rem;
    margin-bottom: 1.5rem;
}

/* --------------------------------------------------------------------------
   14. Billing Page Components
   -------------------------------------------------------------------------- */
.saw-billing-card {
    background-color: var(--saw-bg-card);
    border: 1px solid var(--saw-border);
    border-radius: var(--saw-radius-lg);
    padding: 2.25rem 2rem;
    transition: border-color var(--saw-transition), box-shadow var(--saw-transition);
}

.saw-billing-card:hover {
    border-color: var(--saw-primary);
    box-shadow: var(--saw-shadow-md);
}

.saw-billing-card--featured {
    border-color: var(--saw-primary);
    background: linear-gradient(145deg, var(--saw-bg-card) 0%, rgba(192,57,43,.06) 100%);
}

.saw-billing-icon {
    font-size: 2.25rem;
    color: var(--saw-primary);
    margin-bottom: 1.25rem;
}

.saw-billing-title {
    font-size: 1.2rem;
    font-weight: 700;
    color: #fff;
    margin-bottom: 1rem;
}

.saw-billing-note {
    font-size: .85rem;
    color: var(--saw-text-muted);
    background-color: var(--saw-bg-3);
    border: 1px solid var(--saw-border);
    border-radius: var(--saw-radius);
    padding: .75rem 1rem;
    margin-bottom: 0;
}

.saw-billing-note a { color: var(--saw-primary); }

/* Site rows in billing list */
.saw-billing-site-row {
    background-color: var(--saw-bg-card);
    border: 1px solid var(--saw-border);
    border-radius: var(--saw-radius-lg);
    padding: 1.5rem;
    transition: border-color var(--saw-transition), box-shadow var(--saw-transition);
}

.saw-billing-site-row:hover {
    border-color: var(--saw-border-hover);
    box-shadow: var(--saw-shadow-sm);
}

.saw-billing-site-thumb {
    width: 90px;
    height: 70px;
    border-radius: var(--saw-radius);
    background-size: cover;
    background-position: center;
    background-color: var(--saw-bg-3);
    border: 1px solid var(--saw-border);
    flex-shrink: 0;
}

.saw-billing-site-name {
    font-size: 1.05rem;
    font-weight: 700;
    color: #fff;
}

.saw-billing-site-domain {
    font-size: .8125rem;
    color: var(--saw-text-muted);
    margin-bottom: .5rem;
}

.saw-billing-site-domain a { color: var(--saw-text-muted); }
.saw-billing-site-domain a:hover { color: var(--saw-primary); }

.saw-billing-site-desc {
    font-size: .875rem;
    color: var(--saw-text-light);
    line-height: 1.6;
}

/* --------------------------------------------------------------------------
   15. Terms & Conditions
   -------------------------------------------------------------------------- */
.saw-tc-notice {
    background: rgba(192,57,43,.12);
    border: 1px solid rgba(192,57,43,.35);
    border-radius: var(--saw-radius);
    padding: 1.25rem 1.5rem;
    color: var(--saw-text-light);
    font-size: .95rem;
    line-height: 1.65;
}

.saw-tc-notice strong { color: #fff; }

.saw-tc-item {
    background-color: var(--saw-bg-card);
    border: 1px solid var(--saw-border) !important;
    border-radius: var(--saw-radius) !important;
    margin-bottom: .5rem;
    overflow: hidden;
}

.saw-tc-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.75rem;
    height: 1.75rem;
    background: var(--saw-primary-alpha);
    color: var(--saw-primary);
    border-radius: 6px;
    font-size: .8rem;
    font-weight: 800;
    flex-shrink: 0;
}

.saw-tc-body p { color: var(--saw-text-light); line-height: 1.75; margin-bottom: 0; }

/* --------------------------------------------------------------------------
   16. Callout / CTA sections
   -------------------------------------------------------------------------- */
.saw-callout { text-align: center; }

.saw-callout-icon {
    font-size: 3rem;
    color: var(--saw-primary);
    display: block;
}

/* --------------------------------------------------------------------------
   17. Footer
   -------------------------------------------------------------------------- */
.saw-footer {
    background-color: var(--saw-topbar-bg);
    border-top: 1px solid var(--saw-border);
}

.saw-footer-logo { height: 36px; width: auto; }

.saw-footer-heading {
    font-size: .8125rem;
    font-weight: 700;
    letter-spacing: .15em;
    text-transform: uppercase;
    color: var(--saw-text-muted);
    margin-bottom: 1rem;
}

.saw-footer-links li { margin-bottom: .5rem; }

.saw-footer-links a {
    color: var(--saw-text-muted);
    font-size: .9rem;
    transition: color var(--saw-transition);
}

.saw-footer-links a:hover { color: var(--saw-primary); }

.saw-footer-text { color: var(--saw-text-muted); font-size: .9rem; line-height: 1.7; }

.saw-footer-address {
    font-size: .9rem;
    font-style: normal;
    color: var(--saw-text-muted);
}

.saw-footer-address p { margin-bottom: .6rem; }

.saw-footer-address a { color: var(--saw-text-muted); }
.saw-footer-address a:hover { color: var(--saw-primary); }

.saw-footer-divider {
    border-color: var(--saw-border);
    margin: 0;
}

.saw-footer-legal {
    font-size: .8rem;
    color: var(--saw-text-muted);
}

a.saw-footer-legal { transition: color var(--saw-transition); }
a.saw-footer-legal:hover { color: var(--saw-text); }

.saw-social-links a {
    color: var(--saw-text-muted);
    font-size: 1.1rem;
    transition: color var(--saw-transition), transform var(--saw-transition);
    display: inline-block;
}

.saw-social-links a:hover {
    color: var(--saw-primary);
    transform: translateY(-2px);
}

/* --------------------------------------------------------------------------
   18. Back-to-top
   -------------------------------------------------------------------------- */
.saw-back-to-top {
    position: fixed;
    bottom: 2rem;
    right: 2rem;
    z-index: 1030;
    width: 44px;
    height: 44px;
    background-color: var(--saw-primary);
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .9rem;
    box-shadow: 0 4px 16px rgba(192,57,43,.5);
    opacity: 0;
    visibility: hidden;
    transform: translateY(12px);
    transition: opacity var(--saw-transition), visibility var(--saw-transition), transform var(--saw-transition);
}

.saw-back-to-top:hover { background-color: var(--saw-primary-hover); color: #fff; }

.saw-back-to-top.visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

/* --------------------------------------------------------------------------
   19. 404 Page
   -------------------------------------------------------------------------- */
.saw-error-page {
    background-color: var(--saw-bg);
}

.saw-error-code {
    font-size: clamp(6rem, 20vw, 12rem);
    font-weight: 900;
    line-height: 1;
    color: transparent;
    -webkit-text-stroke: 2px var(--saw-primary);
    opacity: .2;
    pointer-events: none;
    user-select: none;
}

.saw-error-title {
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    font-weight: 800;
    color: #fff;
    margin-bottom: 1rem;
}

.saw-error-text {
    color: var(--saw-text-muted);
    font-size: 1.1rem;
    margin-bottom: 0;
}

/* --------------------------------------------------------------------------
   20. Utilities
   -------------------------------------------------------------------------- */
.not-italic { font-style: normal; }

/* Smooth scroll for in-page anchors */
@media (prefers-reduced-motion: no-preference) {
    html { scroll-behavior: smooth; }
}

/* Fade-in animation for network grid items */
.saw-network-item {
    transition: opacity .35s ease, transform .35s ease;
}

.saw-network-item.hidden {
    opacity: 0;
    transform: scale(.96);
    pointer-events: none;
    /* keep layout space while filtering */
    height: 0;
    overflow: hidden;
    margin: 0;
    padding: 0;
}
