/* ==========================================================================
   Afford IT – Custom Styles
   Palette: all accents derived from brand orange #ed4e00
   ========================================================================== */

/* ---------- Root Variables ---------- */
:root {
    /* Orange scale (lightest → darkest) */
    --afford-orange-lt:    #ff8c45;   /* light orange  */
    --afford-orange:       #ed4e00;   /* brand orange  */
    --afford-orange-dk:    #c43d00;   /* dark orange   */
    --afford-orange-xdk:   #9c3000;   /* deeper orange */
    --afford-orange-black: #1a0800;   /* near-black warm — replaces navy */

    /* Semantic aliases */
    --afford-primary:      #c43d00;   /* "primary" role (dark orange) */
    --afford-primary-dark: #9c3000;
    --afford-accent:       #ed4e00;   /* main accent */
    --afford-accent-dark:  #c43d00;
    --afford-accent-light: #ff8c45;

    /* Backgrounds */
    --afford-dark-bg:      #1a0800;   /* hero / dark-section bg */
    --afford-tint:         #fff5f0;   /* pale orange tint for accordions etc. */
}

/* ---------- Base ---------- */
body {
    font-family: 'Inter', system-ui, -apple-system, sans-serif;
    color: #1e293b;
}

/* Extra spacing utility */
.py-6  { padding-top: 5rem !important; padding-bottom: 5rem !important; }
.pt-6  { padding-top: 5rem !important; }
.pb-6  { padding-bottom: 5rem !important; }

/* ---------- Bootstrap Primary → Dark Orange ---------- */
.btn-primary,
.btn-primary:focus {
    background-color: var(--afford-primary) !important;
    border-color: var(--afford-primary) !important;
    color: #fff !important;
}
.btn-primary:hover,
.btn-primary:active {
    background-color: var(--afford-primary-dark) !important;
    border-color: var(--afford-primary-dark) !important;
    color: #fff !important;
}
.btn-outline-primary {
    color: var(--afford-orange) !important;
    border-color: var(--afford-orange) !important;
}
.btn-outline-primary:hover {
    background-color: var(--afford-orange) !important;
    color: #fff !important;
}
.bg-primary    { background-color: var(--afford-primary) !important; }
.text-primary  { color: var(--afford-orange) !important; }
.border-primary { border-color: var(--afford-orange) !important; }

/* ---------- Bootstrap Warning → Brand Orange ---------- */
.btn-warning,
.btn-warning:focus {
    background-color: var(--afford-orange) !important;
    border-color: var(--afford-orange) !important;
    color: #ffffff !important;
}
.btn-warning:hover,
.btn-warning:active {
    background-color: var(--afford-orange-dk) !important;
    border-color: var(--afford-orange-dk) !important;
    color: #ffffff !important;
}
.text-warning   { color: var(--afford-orange) !important; }
.bg-warning     { background-color: var(--afford-orange) !important; }
.border-warning { border-color: var(--afford-orange) !important; }

/* ---------- Hero Section (main page) ---------- */
.hero-section {
    background: url('../images/hero.jpg') center center / cover no-repeat;
    min-height: 85vh;
    position: relative;
    overflow: hidden;
}

/* Dark gradient overlay — heavy on the left where text lives, fades to lighter on the right */
.hero-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(
        100deg,
        rgba(26, 8, 0, 0.88) 0%,
        rgba(26, 8, 0, 0.75) 45%,
        rgba(26, 8, 0, 0.35) 70%,
        rgba(26, 8, 0, 0.15) 100%
    );
    pointer-events: none;
}

/* Fallback gradient when image hasn't loaded yet */
.hero-section.hero-no-img {
    background: linear-gradient(135deg, #1a0800 0%, #9c3000 50%, #ed4e00 100%);
}

.hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.9rem;
}

/* Hero contact card */
.hero-card {
    backdrop-filter: blur(8px);
}

/* ---------- Suburb Hero (suburb pages) ---------- */
.suburb-hero {
    background: linear-gradient(135deg, #1a0800 0%, #9c3000 50%, #ed4e00 100%);
    min-height: 55vh;
    display: flex;
    align-items: center;
    position: relative;
    overflow: hidden;
}

.suburb-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle at 10% 90%, rgba(255,255,255,0.03) 0%, transparent 50%);
    pointer-events: none;
}

/* ---------- Service Cards ---------- */
.service-icon {
    width: 80px;
    height: 80px;
    /* Three-stop gradient across the orange palette */
    background: linear-gradient(135deg, var(--afford-orange) 0%, var(--afford-primary) 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 2rem;
}

.service-card {
    transition: transform 0.25s ease, box-shadow 0.25s ease;
    border-radius: 16px !important;
}

.service-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 20px 40px rgba(237, 78, 0, 0.12) !important;
}

/* ---------- Stat Cards ---------- */
.stat-card { border-radius: 16px !important; }

/* ---------- Why Afford IT icons ---------- */
.why-icon {
    width: 52px;
    height: 52px;
    background-color: var(--afford-orange);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

/* ---------- Suburb Links (footer / LGA pages) ---------- */
.suburb-link {
    color: var(--afford-primary);
    text-decoration: none;
    font-size: 0.85rem;
    line-height: 1.8;
    display: block;
    transition: color 0.15s;
}

.suburb-link:hover {
    color: var(--afford-orange);
    text-decoration: underline;
}

/* LGA pages – suburb grid cards */
.suburb-grid-link {
    display: block;
    padding: 0.45rem 0.75rem;
    border-radius: 6px;
    font-size: 0.875rem;
    color: #1e293b;
    text-decoration: none;
    background: #fff;
    border: 1px solid #e2e8f0;
    transition: background 0.15s, color 0.15s, border-color 0.15s;
}

.suburb-grid-link:hover {
    background: var(--afford-orange);
    color: #fff;
    border-color: var(--afford-orange);
}

/* ---------- LGA Cards (index page) ---------- */
.lga-card {
    border-radius: 12px !important;
    transition: transform 0.2s, box-shadow 0.2s;
    text-decoration: none;
    color: inherit;
}

.lga-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 30px rgba(237, 78, 0, 0.15) !important;
    color: inherit;
}

/* ---------- Social Icons ---------- */
.social-icon-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.10);
    color: #fff !important;
    font-size: 1rem;
    text-decoration: none;
    transition: background 0.2s, color 0.2s;
    flex-shrink: 0;
}

.social-icon-link:hover {
    background: var(--afford-orange);
    color: #fff !important;
}

/* Navbar social icons — borderless, small */
.navbar-social a {
    color: rgba(255, 255, 255, 0.55);
    font-size: 1rem;
    padding: 0.2rem 0.3rem;
    text-decoration: none;
    transition: color 0.15s;
    line-height: 1;
}

.navbar-social a:hover { color: var(--afford-orange); }

/* ---------- Footer ---------- */
footer a {
    color: rgba(255, 255, 255, 0.65);
    text-decoration: none;
    font-size: 0.875rem;
    transition: color 0.15s;
}

footer a:hover {
    color: var(--afford-orange-lt);
}

/* ---------- Buttons ---------- */
.btn-afford {
    background-color: var(--afford-orange);
    border-color: var(--afford-orange);
    color: #fff;
    font-weight: 600;
}

.btn-afford:hover {
    background-color: var(--afford-orange-dk);
    border-color: var(--afford-orange-dk);
    color: #fff;
}

/* ---------- Breadcrumb on dark bg ---------- */
.breadcrumb-light .breadcrumb-item a                          { color: rgba(255,255,255,0.75); }
.breadcrumb-light .breadcrumb-item.active                     { color: rgba(255,255,255,0.95); }
.breadcrumb-light .breadcrumb-item + .breadcrumb-item::before { color: rgba(255,255,255,0.4); }

/* ---------- Accordion ---------- */
.accordion-button:not(.collapsed) {
    color: var(--afford-orange-dk);
    background: var(--afford-tint);
}
.accordion-button:focus           { box-shadow: none; }
.accordion-button:not(.collapsed)::after {
    filter: hue-rotate(180deg) saturate(3); /* tint arrow orange */
}

/* ---------- Remove green — replace with orange shades ---------- */
/* Checklist icons in service cards */
.service-card .bi-check-circle-fill { color: var(--afford-orange-lt) !important; }
/* Checklist icons in suburb pages "why" section */
.bi-check-circle-fill               { color: var(--afford-orange-lt) !important; }

/* Success stat card → deeper orange */
.bg-success { background-color: var(--afford-orange-xdk) !important; }

/* ---------- Responsive tweaks ---------- */
@media (max-width: 767.98px) {
    .hero-section  { min-height: auto; padding: 4rem 0; }
    .suburb-hero   { min-height: auto; padding: 3rem 0; }
    .display-4     { font-size: 2rem; }
}
