/* ============================================================
   FillTheRig — Location Hubs Stylesheet
   Styles for /locations/{city}-trucking-guide/ pages
   and /locations/ archive index
   ============================================================ */

/* Breadcrumbs */
.breadcrumbs {
    background: var(--color-bg-alt);
    border-bottom: 1px solid var(--color-border);
    padding: var(--sp-sm) 0;
}
.breadcrumb-list {
    list-style: none;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--sp-xs) var(--sp-sm);
    font-size: 0.85rem;
    color: var(--color-text-muted);
}
.breadcrumb-list a {
    color: var(--color-text-muted);
    text-decoration: none;
    transition: color var(--transition);
}
.breadcrumb-list a:hover { color: var(--color-accent); }
.breadcrumb-list [aria-current="page"] { color: var(--color-text); }
.breadcrumb-list span[aria-hidden] { color: var(--color-text-dim); }

/* Hero */
.location-hero {
    padding: var(--sp-4xl) 0 var(--sp-3xl);
    text-align: center;
}
.location-hero h1 {
    font-family: var(--font-display);
    font-size: clamp(1.8rem, 4.5vw, 3rem);
    font-weight: 700;
    line-height: 1.1;
    margin: var(--sp-sm) 0 var(--sp-md);
    color: var(--color-white);
}
.hero-meta {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--sp-sm);
    margin-top: var(--sp-lg);
}
.hero-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-xs);
    background: rgba(255, 107, 26, 0.12);
    border: 1px solid var(--color-accent);
    color: var(--color-accent);
    padding: var(--sp-xs) var(--sp-md);
    border-radius: var(--radius-full);
    font-size: 0.85rem;
    font-weight: 600;
}

/* Live Opportunity Box */
.live-opportunity-section { padding-top: var(--sp-2xl); }
.live-box {
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
}
.live-box-header {
    display: flex;
    align-items: center;
    gap: var(--sp-sm);
    flex-wrap: wrap;
    padding: var(--sp-md) var(--sp-lg);
    background: var(--color-surface);
    border-bottom: 1px solid var(--color-border);
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--color-white);
}
.live-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--color-success);
    box-shadow: 0 0 8px var(--color-success);
    animation: pulse-live 2s ease-in-out infinite;
    flex-shrink: 0;
}
@keyframes pulse-live {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}
.live-updated {
    margin-left: auto;
    font-size: 0.8rem;
    color: var(--color-text-muted);
    display: flex;
    align-items: center;
    gap: var(--sp-xs);
}
.live-box-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
}
.live-job-row {
    display: flex;
    align-items: center;
    gap: var(--sp-sm);
    padding: var(--sp-md) var(--sp-lg);
    border-bottom: 1px solid var(--color-border);
    border-right: 1px solid var(--color-border);
    transition: background var(--transition);
}
.live-job-row:hover { background: var(--color-surface); }
.live-job-icon { font-size: 1.25rem; flex-shrink: 0; }
.live-job-label { flex: 1; font-size: 0.9rem; color: var(--color-text); }
.live-job-count {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--color-accent);
    background: rgba(255, 107, 26, 0.1);
    padding: 2px 10px;
    border-radius: var(--radius-full);
    white-space: nowrap;
}
.live-box-footer {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--sp-md);
    padding: var(--sp-md) var(--sp-lg);
    background: var(--color-surface);
    border-top: 1px solid var(--color-border);
}
.live-note {
    font-size: 0.78rem;
    color: var(--color-text-dim);
    display: flex;
    align-items: center;
    gap: var(--sp-xs);
}

/* Salary Table */
.salary-section { padding: var(--sp-3xl) 0; }
.salary-table-wrap { overflow-x: auto; margin-top: var(--sp-xl); }
.salary-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.95rem;
    background: var(--color-bg-card);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-md);
}
.salary-table thead th {
    background: var(--color-surface);
    color: var(--color-text-muted);
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: var(--sp-md) var(--sp-lg);
    text-align: left;
    border-bottom: 2px solid var(--color-border);
}
.salary-table tbody td {
    padding: var(--sp-md) var(--sp-lg);
    border-bottom: 1px solid var(--color-border);
    color: var(--color-text);
}
.salary-table tbody tr:last-child td { border-bottom: none; }
.salary-table tbody tr:hover { background: var(--color-surface); }
.salary-highlight td { background: rgba(255, 107, 26, 0.05); }
.salary-endorsement td { background: rgba(45, 140, 255, 0.05); }
.salary-value {
    font-family: var(--font-display);
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--color-accent);
}
.cdl-badge {
    display: inline-block;
    padding: 2px 10px;
    border-radius: var(--radius-full);
    font-size: 0.75rem;
    font-weight: 700;
    background: rgba(45, 140, 255, 0.15);
    color: var(--color-blue);
    border: 1px solid rgba(45, 140, 255, 0.3);
}
.cdl-badge-b {
    background: rgba(255, 107, 26, 0.1);
    color: var(--color-accent);
    border-color: rgba(255, 107, 26, 0.3);
}
.salary-footnote {
    font-size: 0.8rem;
    color: var(--color-text-dim);
    padding: var(--sp-md) var(--sp-lg);
    background: var(--color-bg-alt);
}

/* Freight Corridors */
.corridors-section { padding: var(--sp-3xl) 0; }
.corridors-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-2xl);
}
@media (max-width: 768px) { .corridors-grid { grid-template-columns: 1fr; } }
.corridors-title {
    font-family: var(--font-display);
    font-size: 1.4rem;
    color: var(--color-white);
    margin-bottom: var(--sp-sm);
    display: flex;
    align-items: center;
    gap: var(--sp-sm);
}
.corridors-title i { color: var(--color-accent); }
.corridors-desc { color: var(--color-text-muted); font-size: 0.9rem; margin-bottom: var(--sp-lg); }
.corridor-list { list-style: none; display: flex; flex-direction: column; gap: var(--sp-sm); }
.corridor-list li {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-sm);
    font-size: 0.9rem;
    color: var(--color-text);
    padding: var(--sp-sm) var(--sp-md);
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    transition: border-color var(--transition);
}
.corridor-list li:hover { border-color: var(--color-accent); }
.corridor-list li i { color: var(--color-accent); margin-top: 3px; flex-shrink: 0; }

/* Why Drive Here */
.why-section { padding: var(--sp-3xl) 0; }
.why-content { max-width: 900px; margin: 0 auto; }
.why-text {
    font-size: 1.05rem;
    line-height: 1.8;
    color: var(--color-text-muted);
    margin-bottom: var(--sp-xl);
}
.why-highlights { list-style: none; display: flex; flex-direction: column; gap: var(--sp-md); }
.why-highlights li {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-md);
    font-size: 0.95rem;
    color: var(--color-text);
}
.why-highlights li i { color: var(--color-success); margin-top: 3px; flex-shrink: 0; }

/* Top Carriers */
.carriers-section { padding: var(--sp-3xl) 0; }
.carriers-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: var(--sp-md);
    margin-top: var(--sp-xl);
}
.carrier-card {
    display: flex;
    align-items: center;
    gap: var(--sp-sm);
    padding: var(--sp-md) var(--sp-lg);
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: 0.9rem;
    color: var(--color-text);
    transition: border-color var(--transition), transform var(--transition);
}
.carrier-card:hover { border-color: var(--color-accent); transform: translateY(-2px); }
.carrier-card i { color: var(--color-accent); flex-shrink: 0; }
.carriers-cta {
    margin-top: var(--sp-2xl);
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--sp-md);
}
.carriers-cta p { color: var(--color-text-muted); font-size: 0.95rem; }

/* Endorsements */
.endorsements-section { padding: var(--sp-3xl) 0; }
.endorsements-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: var(--sp-lg);
    margin-top: var(--sp-xl);
}
.endorsement-card {
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--sp-lg);
    text-align: center;
    transition: border-color var(--transition), transform var(--transition);
}
.endorsement-card:hover { border-color: var(--color-blue); transform: translateY(-3px); }
.endorsement-card i {
    font-size: 2rem;
    color: var(--color-blue);
    display: block;
    margin-bottom: var(--sp-md);
}
.endorsement-card h3 {
    font-family: var(--font-display);
    font-size: 1rem;
    color: var(--color-white);
    margin-bottom: var(--sp-sm);
}
.endorsement-card p { font-size: 0.82rem; color: var(--color-text-muted); line-height: 1.5; }

/* CDL Requirements */
.cdl-requirements-section { padding: var(--sp-3xl) 0; }
.req-grid {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: var(--sp-2xl);
    align-items: start;
}
@media (max-width: 900px) { .req-grid { grid-template-columns: 1fr; } }
.req-col-main h2 {
    font-family: var(--font-display);
    font-size: 1.6rem;
    color: var(--color-white);
    margin-bottom: var(--sp-md);
    display: flex;
    align-items: center;
    gap: var(--sp-sm);
}
.req-col-main h2 i { color: var(--color-accent); }
.req-col-main h3 {
    font-family: var(--font-display);
    font-size: 1.1rem;
    color: var(--color-text-muted);
    margin: var(--sp-lg) 0 var(--sp-md);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.req-note {
    font-size: 0.9rem;
    color: var(--color-text-muted);
    line-height: 1.7;
    padding: var(--sp-md) var(--sp-lg);
    background: rgba(45, 140, 255, 0.07);
    border-left: 3px solid var(--color-blue);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    margin-bottom: var(--sp-lg);
}
.req-list { list-style: none; display: flex; flex-direction: column; gap: var(--sp-sm); }
.req-list li {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-sm);
    font-size: 0.9rem;
    color: var(--color-text);
}
.req-list li i { color: var(--color-success); margin-top: 3px; }
.req-cta-box {
    background: linear-gradient(135deg, var(--color-accent-dark), var(--color-accent));
    border-radius: var(--radius-xl);
    padding: var(--sp-xl);
    text-align: center;
    box-shadow: var(--shadow-glow);
}
.req-cta-box h3 {
    font-family: var(--font-display);
    font-size: 1.4rem;
    color: var(--color-white);
    margin-bottom: var(--sp-sm);
}
.req-cta-box p { color: rgba(255, 255, 255, 0.85); font-size: 0.9rem; margin-bottom: var(--sp-lg); }
.req-cta-bullets {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: var(--sp-sm);
    margin-top: var(--sp-md);
    text-align: left;
}
.req-cta-bullets li {
    display: flex;
    align-items: center;
    gap: var(--sp-sm);
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.9);
}
.req-cta-bullets li i { color: var(--color-white); }

/* Nearby Markets */
.nearby-section { padding: var(--sp-3xl) 0; }
.nearby-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: var(--sp-md);
    margin-top: var(--sp-xl);
}
.nearby-card {
    display: flex;
    flex-direction: column;
    gap: var(--sp-xs);
    padding: var(--sp-lg);
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    text-decoration: none;
    transition: border-color var(--transition), transform var(--transition);
}
.nearby-card:hover { border-color: var(--color-accent); transform: translateY(-3px); }
.nearby-city {
    font-family: var(--font-display);
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--color-white);
}
.nearby-state {
    font-size: 0.8rem;
    color: var(--color-text-dim);
    text-transform: uppercase;
    letter-spacing: 0.1em;
}
.nearby-salary {
    font-size: 0.88rem;
    color: var(--color-accent);
    font-weight: 600;
    margin-top: var(--sp-xs);
}
.nearby-label {
    font-size: 0.8rem;
    color: var(--color-blue);
    margin-top: auto;
    padding-top: var(--sp-sm);
    display: flex;
    align-items: center;
    gap: var(--sp-xs);
}

/* Archive: Location Hubs Index */
.location-region { margin-bottom: var(--sp-3xl); }
.region-title {
    font-family: var(--font-display);
    font-size: 1.3rem;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: var(--sp-lg);
    display: flex;
    align-items: center;
    gap: var(--sp-sm);
    border-bottom: 1px solid var(--color-border);
    padding-bottom: var(--sp-md);
}
.region-title i { color: var(--color-accent); }
.location-archive-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: var(--sp-md);
}
.location-archive-card {
    display: flex;
    flex-direction: column;
    gap: var(--sp-sm);
    padding: var(--sp-lg);
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    text-decoration: none;
    transition: border-color var(--transition), transform var(--transition), box-shadow var(--transition);
}
.location-archive-card:hover {
    border-color: var(--color-accent);
    transform: translateY(-3px);
    box-shadow: var(--shadow-glow);
}
.lac-header { display: flex; align-items: baseline; justify-content: space-between; }
.lac-city {
    font-family: var(--font-display);
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--color-white);
}
.lac-state {
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-text-dim);
}
.lac-rank {
    font-size: 0.78rem;
    color: var(--color-blue);
    line-height: 1.3;
}
.lac-salary {
    display: flex;
    align-items: baseline;
    gap: var(--sp-xs);
    margin-top: var(--sp-xs);
}
.lac-salary-label {
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-dim);
}
.lac-salary-value {
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-accent);
}
.lac-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: auto;
    padding-top: var(--sp-sm);
    border-top: 1px solid var(--color-border);
}
.lac-jobs {
    font-size: 0.8rem;
    color: var(--color-text-muted);
    display: flex;
    align-items: center;
    gap: var(--sp-xs);
}
.lac-link {
    font-size: 0.8rem;
    color: var(--color-blue);
    display: flex;
    align-items: center;
    gap: var(--sp-xs);
}

/* ============================================================
   FOOTER LOCATIONS ROW
   ============================================================ */
.footer-locations-row {
    border-top: 1px solid var(--color-border);
    padding: var(--sp-xl) 0;
    margin-top: var(--sp-xl);
}
.footer-locations-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--sp-sm);
    margin-bottom: var(--sp-lg);
}
.footer-locations-title {
    font-family: var(--font-display);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--color-text-muted);
    display: flex;
    align-items: center;
    gap: var(--sp-sm);
}
.footer-locations-title i { color: var(--color-accent); }
.footer-locations-all {
    font-size: 0.8rem;
    color: var(--color-blue);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: var(--sp-xs);
    transition: color var(--transition);
}
.footer-locations-all:hover { color: var(--color-blue-hover); }

/* Auto-generated group layout */
.footer-locations-auto {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: var(--sp-lg) var(--sp-xl);
}
.footer-locations-region {
    display: block;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-text-dim);
    margin-bottom: var(--sp-sm);
    font-weight: 600;
}
.footer-locations-group ul {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.footer-locations-group ul a {
    font-size: 0.82rem;
    color: var(--color-text-muted);
    text-decoration: none;
    transition: color var(--transition);
}
.footer-locations-group ul a:hover { color: var(--color-accent); }

/* WP Nav Menu fallback — when menu assigned via WordPress admin */
.footer-locations-list {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-xs) var(--sp-md);
    padding: 0;
    margin: 0;
}
.footer-locations-list li a {
    font-size: 0.82rem;
    color: var(--color-text-muted);
    text-decoration: none;
    transition: color var(--transition);
}
.footer-locations-list li a:hover { color: var(--color-accent); }

/* Sub-menu (if using WP menu with sub-items) */
.footer-locations-list .sub-menu {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-xs) var(--sp-md);
    padding: 0;
    margin: var(--sp-xs) 0 0;
}
.footer-locations-list .sub-menu a { font-size: 0.78rem; }

@media (max-width: 600px) {
    .footer-locations-auto {
        grid-template-columns: repeat(2, 1fr);
    }
}
