/* =============================================================
   POWER PRIME — Editorial Premium Design System v2
   ============================================================= */

/* ---------- TOKENS ---------- */
:root {
    --ink: #0B1220;
    --navy: #0F2342;
    --navy-soft: #1B3358;
    --champagne: #C9A15F;
    --champagne-soft: #E4C793;
    --paper: #F5F1E8;
    --paper-soft: #FBF8F2;
    --line: #E4DDCF;
    --line-strong: #CFC7B5;
    --muted: #6F6A5F;
    --muted-soft: #9A9588;
    --white: #FFFFFF;

    --font-display: 'Fraunces', 'Georgia', serif;
    --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

    --radius-sm: 4px;
    --radius-md: 10px;
    --radius-lg: 20px;

    --shadow-sm: 0 2px 8px rgba(11, 18, 32, 0.04);
    --shadow-md: 0 12px 40px rgba(11, 18, 32, 0.08);
    --shadow-lg: 0 28px 80px rgba(11, 18, 32, 0.14);

    --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ---------- RESET & BASE ---------- */
*, *::before, *::after { box-sizing: border-box; }

html {
    scroll-behavior: smooth;
    overflow-x: hidden; /* fallback */
    overflow-x: clip;   /* preferred — does not break position: sticky */
}

body {
    font-family: var(--font-sans);
    font-size: 17px;
    line-height: 1.6;
    color: var(--ink);
    background: var(--paper-soft);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    margin: 0;
    overflow-x: hidden; /* fallback */
    overflow-x: clip;
    width: 100%;
    max-width: 100vw;
    position: relative;
}

/* Universal media safety — no element can blow past its container */
img, picture, video, iframe, svg, canvas, embed, object {
    max-width: 100%;
    height: auto;
}
iframe { width: 100%; }
table { max-width: 100%; }
pre, code { max-width: 100%; overflow-x: auto; word-wrap: break-word; }

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-display);
    font-weight: 400;
    font-variation-settings: "opsz" 144, "SOFT" 30, "WONK" 0;
    letter-spacing: -0.02em;
    line-height: 1.08;
    color: var(--ink);
    margin: 0 0 0.5em;
}

h1 { font-size: clamp(2.5rem, 5.5vw, 5rem); }
h2 { font-size: clamp(2rem, 3.8vw, 3.25rem); }
h3 { font-size: clamp(1.35rem, 2vw, 1.75rem); }
h4 { font-size: 1.25rem; }

p { margin: 0 0 1.1em; }

a { color: inherit; text-decoration: none; transition: color 0.3s var(--ease); }
a:hover { color: var(--champagne); }

img { max-width: 100%; display: block; }

ul, ol { padding: 0; margin: 0; list-style: none; }

::selection { background: var(--champagne); color: var(--navy); }

/* ---------- LAYOUT ---------- */
.container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 32px;
}
@media (max-width: 768px) {
    .container { padding: 0 20px; }
}
@media (max-width: 480px) {
    .container { padding: 0 16px; }
}

.container-narrow {
    max-width: 880px;
    margin: 0 auto;
    padding: 0 32px;
}

.section {
    padding: clamp(72px, 10vw, 140px) 0;
}

.section-sm {
    padding: clamp(48px, 7vw, 96px) 0;
}

.bg-paper { background: var(--paper); }
.bg-paper-soft { background: var(--paper-soft); }
.bg-navy { background: var(--navy); color: var(--paper-soft); }
.bg-ink { background: var(--ink); color: var(--paper-soft); }
.bg-white { background: var(--white); }

.bg-navy h1, .bg-navy h2, .bg-navy h3, .bg-navy h4,
.bg-ink h1, .bg-ink h2, .bg-ink h3, .bg-ink h4 { color: var(--paper-soft); }

.text-center { text-align: center; }

/* ---------- TYPOGRAPHY UTILITIES ---------- */
.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    font-family: var(--font-sans);
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--muted);
    margin-bottom: 28px;
}

.eyebrow::before {
    content: '';
    width: 32px;
    height: 1px;
    background: var(--champagne);
}

.eyebrow-center {
    justify-content: center;
}

.eyebrow-center::before {
    display: none;
}

.eyebrow-num {
    color: var(--champagne);
    font-family: var(--font-display);
    font-style: italic;
    font-size: 14px;
    letter-spacing: 0;
    text-transform: none;
    margin-right: 4px;
}

.display {
    font-family: var(--font-display);
    font-size: clamp(3rem, 7vw, 6.5rem);
    line-height: 1;
    letter-spacing: -0.03em;
    font-weight: 400;
}

.display em,
h1 em, h2 em {
    font-style: italic;
    font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1;
    color: var(--champagne);
}

.lede {
    font-size: 1.25rem;
    line-height: 1.55;
    color: var(--muted);
    max-width: 58ch;
}

.muted { color: var(--muted); }

/* ---------- BUTTONS ---------- */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 16px 32px;
    font-family: var(--font-sans);
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 0.04em;
    border-radius: 999px;
    border: 1px solid transparent;
    cursor: pointer;
    transition: all 0.35s var(--ease);
    text-decoration: none;
    line-height: 1;
    white-space: nowrap;
}

.btn-primary {
    background: var(--navy);
    color: var(--paper-soft);
}
.btn-primary:hover {
    background: var(--ink);
    color: var(--champagne);
    transform: translateY(-1px);
}

.btn-gold {
    background: var(--champagne);
    color: var(--ink);
}
.btn-gold:hover {
    background: var(--navy);
    color: var(--champagne);
}

.btn-ghost {
    background: transparent;
    color: var(--ink);
    border-color: var(--line-strong);
}
.btn-ghost:hover {
    background: var(--ink);
    color: var(--paper-soft);
    border-color: var(--ink);
}

.btn-ghost-light {
    background: transparent;
    color: var(--paper-soft);
    border-color: rgba(245, 241, 232, 0.3);
}
.btn-ghost-light:hover {
    background: var(--champagne);
    color: var(--ink);
    border-color: var(--champagne);
}

.btn-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--ink);
    padding-bottom: 4px;
    border-bottom: 1px solid var(--ink);
    transition: all 0.3s var(--ease);
}
.btn-link:hover {
    color: var(--champagne);
    border-color: var(--champagne);
    gap: 14px;
}

.btn-link i { font-size: 11px; transition: transform 0.3s var(--ease); }
.btn-link:hover i { transform: translateX(4px); }

/* ---------- ISO STRIP ---------- */
.iso-strip {
    background: linear-gradient(90deg, var(--navy) 0%, var(--navy-soft) 50%, var(--navy) 100%);
    color: var(--paper-soft);
    font-size: 12px;
    letter-spacing: 0.08em;
    position: relative;
    overflow: hidden;
}

.iso-strip::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent, rgba(201, 161, 95, 0.12), transparent);
    background-size: 200% 100%;
    animation: iso-shimmer 8s linear infinite;
    pointer-events: none;
}

@keyframes iso-shimmer {
    0% { background-position: -100% 0; }
    100% { background-position: 100% 0; }
}

.iso-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 9px 32px;
    gap: 24px;
    flex-wrap: wrap;
    position: relative;
    z-index: 1;
}

.iso-left {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
}

.iso-left > i {
    color: var(--champagne);
    font-size: 14px;
}

.iso-label {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 13px;
    color: var(--champagne-soft);
    letter-spacing: 0;
    text-transform: none;
}

.iso-badges {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.iso-badge {
    display: inline-block;
    padding: 3px 10px;
    border: 1px solid rgba(201, 161, 95, 0.35);
    border-radius: 999px;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.12em;
    color: var(--paper-soft);
    background: rgba(201, 161, 95, 0.06);
    transition: 0.35s var(--ease);
}

.iso-badge:hover {
    background: var(--champagne);
    color: var(--ink);
    border-color: var(--champagne);
}

.iso-sep {
    color: rgba(201, 161, 95, 0.4);
    font-weight: 300;
}

.iso-right i {
    color: var(--champagne);
    margin-right: 8px;
}

@media (max-width: 900px) {
    .iso-inner {
        flex-direction: column !important;
        text-align: center !important;
        padding: 8px 16px !important;
        gap: 6px !important;
    }
    .iso-left { justify-content: center !important; gap: 8px !important; flex-wrap: wrap !important; }
    .iso-badges { gap: 6px !important; justify-content: center !important; }
    .iso-badge { font-size: 9.5px !important; padding: 2px 8px !important; letter-spacing: .08em !important; }
    .iso-right { font-size: 10.5px !important; letter-spacing: .04em !important; }
    .iso-strip { font-size: 11px; }
}
@media (max-width: 480px) {
    .iso-right { display: none !important; } /* drop the second line on tiny phones */
    .iso-label { display: none !important; } /* drop "ISO Certified" prefix */
}

/* ---------- HEADER ---------- */
.topbar {
    background: var(--ink);
    color: var(--paper-soft);
    font-size: 12px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}
.topbar-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 0;
    gap: 16px;
    flex-wrap: wrap;
}
.topbar a { color: var(--paper-soft); transition: color .25s var(--ease); }
.topbar a:hover { color: var(--champagne); }
.topbar-left { display: flex; align-items: center; flex-wrap: wrap; gap: 8px 20px; }
.topbar-left span { display: inline-flex; align-items: center; }
.topbar-left span a, .topbar-left span { color: var(--paper-soft); }
.topbar-left i, .topbar-right i { margin-right: 6px; color: var(--champagne); }
.topbar-right { white-space: nowrap; }

@media (max-width: 900px) {
    .topbar { font-size: 11px !important; letter-spacing: .06em !important; }
    .topbar-inner { flex-direction: column !important; gap: 6px !important; text-align: center !important; padding: 8px 12px !important; }
    .topbar-left { justify-content: center !important; gap: 6px 14px !important; flex-wrap: wrap !important; }
    .topbar-right { display: none !important; }
}
@media (max-width: 480px) {
    .topbar-left span:nth-child(3) { display: none !important; } /* drop email on tiny phones */
    .topbar-left { gap: 4px 10px !important; }
    .topbar { font-size: 10.5px !important; }
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: var(--paper-soft);
    border-bottom: 1px solid var(--line);
    transition: background 0.35s var(--ease), box-shadow 0.35s var(--ease);
}
.site-header.scrolled {
    background: rgba(251, 248, 242, 0.96);
    backdrop-filter: saturate(140%) blur(12px);
    -webkit-backdrop-filter: saturate(140%) blur(12px);
    box-shadow: 0 4px 18px rgba(11, 18, 32, .06);
}

.main-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
    height: 96px;
    min-width: 0;
}

.logo { flex: 0 0 auto; min-width: 0; font-family: var(--font-display); font-weight: 400; font-size: 22px; color: var(--ink); }
.logo a { display: inline-flex; align-items: center; gap: 12px; }
.logo .logo-img {
    height: 64px;
    width: auto;
    max-width: 100%;
    object-fit: contain;
    display: block;
    transition: height 0.4s var(--ease);
}
.site-header.scrolled .logo .logo-img { height: 52px; }
.logo .logo-fallback { display: none; }
.logo .mark { color: var(--champagne); font-weight: 700; letter-spacing: 0.04em; }
.logo strong { font-weight: 800; letter-spacing: 0.04em; color: var(--navy); }

.main-navigation { display: flex; align-items: center; flex: 1 1 auto; justify-content: center; min-width: 0; }
.site-header .mobile-menu-close,
.site-header .mobile-cta { display: none !important; }

.nav-menu {
    display: flex;
    align-items: center;
    gap: 32px;
    margin: 0;
    padding: 0;
    list-style: none;
}
.nav-menu > li { position: relative; }
.nav-menu > li > a {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
    letter-spacing: 0.02em;
    color: var(--ink);
    padding: 6px 0;
    font-weight: 500;
    white-space: nowrap;
}
.nav-menu > li > a::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 1.5px;
    background: var(--champagne);
    transition: width 0.35s var(--ease);
}
.nav-menu > li > a:hover,
.nav-menu > li.current-menu-item > a { color: var(--navy); }
.nav-menu > li > a:hover::after,
.nav-menu > li.current-menu-item > a::after,
.nav-menu > li.current-menu-parent > a::after { width: 100%; }

.dd-caret { font-size: 9px; opacity: .6; transition: transform .3s var(--ease); }
.has-dropdown:hover .dd-caret,
.has-dropdown.is-open .dd-caret { transform: rotate(180deg); }

.dropdown {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(6px);
    min-width: 220px;
    background: var(--white);
    border: 1px solid var(--line);
    padding: 10px 0;
    margin: 0;
    list-style: none;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: 0.25s var(--ease);
    box-shadow: var(--shadow-md);
    z-index: 10;
    border-radius: 4px;
}
.has-dropdown:hover .dropdown,
.has-dropdown:focus-within .dropdown {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
}
.dropdown li a {
    display: block;
    padding: 10px 22px;
    font-size: 14px;
    color: var(--ink);
    white-space: nowrap;
}
.dropdown li a:hover { background: var(--paper); color: var(--champagne); }

.header-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 16px;
    flex: 0 0 auto;
}
.header-actions .btn {
    padding: 12px 22px;
    font-size: 12px;
    letter-spacing: 0.16em;
    white-space: nowrap;
}

.site-header .mobile-menu-toggle {
    display: none;
    width: 44px;
    height: 44px;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    color: var(--ink);
    cursor: pointer;
    background: none;
    border: 1px solid transparent;
    border-radius: 4px;
    padding: 0;
    transition: background .2s var(--ease), border-color .2s var(--ease);
    flex-shrink: 0;
}
.mobile-menu-toggle:hover { background: var(--paper); border-color: var(--line); }

.mobile-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(11, 18, 32, .55);
    backdrop-filter: blur(2px);
    border: none;
    padding: 0;
    z-index: 998;
    opacity: 0;
    visibility: hidden;
    transition: opacity .3s var(--ease), visibility .3s var(--ease);
    cursor: pointer;
}
.mobile-overlay.is-active {
    opacity: 1;
    visibility: visible;
}
body.menu-open { overflow: hidden; }

/* ---------- TABLET (between desktop and mobile) ---------- */
@media (max-width: 1180px) {
    .main-header { gap: 20px; height: 88px; }
    .logo .logo-img { height: 56px; }
    .nav-menu { gap: 22px; }
    .nav-menu > li > a { font-size: 13.5px; }
    .header-actions .btn { padding: 11px 18px; font-size: 11.5px; letter-spacing: .14em; }
}

/* ---------- MOBILE / TABLET DRAWER ---------- */
@media (max-width: 1024px) {
    .site-header .mobile-menu-toggle { display: inline-flex !important; }
    .mobile-overlay { display: block; }
    .site-header .desktop-cta { display: none !important; }
    .site-header .mobile-menu-close,
    .site-header .mobile-cta { display: inline-flex !important; }
    .main-header { height: 78px; gap: 16px; }
    .logo .logo-img { height: 50px; }
    .site-header.scrolled .logo .logo-img { height: 44px; }

    .main-navigation {
        position: fixed;
        top: 0;
        right: 0;
        bottom: 0;
        left: auto;
        width: min(360px, 88vw);
        background: var(--paper-soft);
        transform: translateX(100%);
        opacity: 1;
        visibility: visible;
        transition: transform 0.4s var(--ease);
        padding: 78px 28px 32px;
        flex-direction: column;
        justify-content: flex-start;
        align-items: stretch;
        overflow-y: auto;
        z-index: 999;
        box-shadow: -16px 0 40px rgba(11, 18, 32, .12);
    }
    .main-navigation.open { transform: translateX(0); }

    .mobile-menu-close {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        position: absolute;
        top: 18px;
        right: 18px;
        width: 40px;
        height: 40px;
        background: none;
        border: 1px solid var(--line);
        border-radius: 50%;
        font-size: 18px;
        color: var(--ink);
        cursor: pointer;
        transition: background .2s var(--ease), color .2s var(--ease);
    }
    .mobile-menu-close:hover { background: var(--ink); color: var(--paper-soft); border-color: var(--ink); }

    .nav-menu {
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        width: 100%;
        border-top: 1px solid var(--line);
    }
    .nav-menu > li {
        border-bottom: 1px solid var(--line);
    }
    .nav-menu > li > a {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 18px 4px;
        font-size: 17px;
        font-family: var(--font-display);
        font-weight: 500;
        color: var(--ink);
        white-space: normal;
    }
    .nav-menu > li > a::after { display: none; }
    .dd-caret { font-size: 11px; opacity: .8; }

    .dropdown {
        position: static;
        transform: none;
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        box-shadow: none;
        border: none;
        background: transparent;
        padding: 0 0 14px 14px;
        max-height: 0;
        overflow: hidden;
        transition: max-height .35s var(--ease), padding .35s var(--ease);
    }
    .has-dropdown.is-open .dropdown { max-height: 400px; padding: 0 0 14px 14px; }
    .dropdown li a {
        padding: 10px 4px;
        font-size: 15px;
        color: var(--muted);
    }
    .dropdown li a:hover { color: var(--champagne); background: transparent; }

    .mobile-cta {
        display: inline-flex;
        justify-content: center;
        margin-top: 24px;
        width: 100%;
        padding: 16px 24px;
        font-size: 13px;
    }
}

@media (max-width: 480px) {
    .main-header { height: 66px; }
    .logo .logo-img { height: 40px; }
    .site-header.scrolled .logo .logo-img { height: 36px; }
}

/* ============================================================
   GLOBAL MOBILE SAFETY NET — collapse all multi-column grids
   on phones, prevent any horizontal overflow.
   ============================================================ */
@media (max-width: 768px) {
    /* Any grid that the page-specific rule didn't already collapse */
    .stats-strip,
    .pillars-grid,
    .promise-grid,
    .sectors-bento,
    .services-grid,
    .service-grid,
    .insights-grid,
    .partners-grid,
    .culture-grid,
    .values-grid,
    .ladder,
    .case-metrics,
    .career-hero-stats,
    .pipeline,
    .dept-grid,
    .footer-top,
    .compliance-grid,
    .timeline-grid,
    .testimonial-grid,
    .work-grid,
    .why-grid,
    .map-grid,
    .faq-grid,
    .cta-grid,
    .stats-grid {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }
    /* Sections with 2 columns can stay 2 on tablet but break on phone */
    h1 { font-size: clamp(2rem, 8vw, 2.6rem); }
    h2 { font-size: clamp(1.6rem, 6vw, 2rem); }
    h3 { font-size: clamp(1.15rem, 4.5vw, 1.4rem); }
    section { padding-left: 0; padding-right: 0; }
    /* Force any direct .container child to never spill */
    .container > * { max-width: 100%; }
    /* Tables become scrollable inside their wrapper */
    table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }
    /* Stop section padding from going huge on small viewports */
    section, .section { padding-top: 56px; padding-bottom: 56px; }
}

@media (max-width: 600px) {
    .stats-strip { grid-template-columns: repeat(2, 1fr) !important; }
    .career-hero-stats { grid-template-columns: repeat(2, 1fr) !important; }
}

/* Drawer width — never wider than viewport on tiny phones */
@media (max-width: 380px) {
    .main-navigation { width: 100vw !important; max-width: 100vw !important; }
}

/* ---------- HERO ---------- */
.hero {
    position: relative;
    padding: clamp(60px, 8vw, 120px) 0 clamp(80px, 10vw, 140px);
    overflow: hidden;
}

.hero-grid {
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    gap: 80px;
    align-items: center;
}

.hero-content { max-width: 620px; }

.hero-title {
    font-size: clamp(3rem, 6.8vw, 6rem);
    line-height: 0.98;
    letter-spacing: -0.035em;
    margin-bottom: 32px;
}

.hero-title em { color: var(--champagne); }

.hero-lede {
    font-size: 1.15rem;
    line-height: 1.65;
    color: var(--muted);
    max-width: 52ch;
    margin-bottom: 40px;
}

.hero-actions { display: flex; gap: 16px; flex-wrap: wrap; }

.hero-visual {
    position: relative;
    aspect-ratio: 4/5;
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
}

.hero-visual img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 1.2s var(--ease);
}

.hero:hover .hero-visual img { transform: scale(1.04); }

.hero-stats {
    position: absolute;
    left: -40px;
    bottom: 32px;
    background: var(--paper-soft);
    padding: 28px 32px;
    box-shadow: var(--shadow-md);
    border-radius: var(--radius-sm);
    border-left: 3px solid var(--champagne);
    z-index: 3;
}

.hero-stats .num {
    font-family: var(--font-display);
    font-size: 3rem;
    line-height: 1;
    color: var(--navy);
}

.hero-stats .label {
    font-size: 12px;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--muted);
}

.hero-scroll {
    position: absolute;
    right: 32px;
    bottom: 20px;
    font-size: 11px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--muted);
    writing-mode: vertical-rl;
    transform: rotate(180deg);
}

@media (max-width: 900px) {
    .hero-grid { grid-template-columns: 1fr; gap: 56px; }
    .hero-visual { aspect-ratio: 4/3; }
    .hero-stats { left: 16px; bottom: 16px; padding: 20px 22px; }
    .hero-stats .num { font-size: 2.2rem; }
    .hero-scroll { display: none; }
}

/* ---------- HERO SLIDER (cinematic, fullscreen) ---------- */
.hero-slider-section {
    position: relative;
    overflow: hidden;
    background: var(--ink);
}

.hero-slider { position: relative; }

.hero-slider .slick-list, .hero-slider .slick-track { height: 100%; }

.hero-slide {
    position: relative;
    min-height: 78vh;
    display: flex !important;
    align-items: center;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    overflow: hidden;
}

.hero-slide::after {
    content: '';
    position: absolute;
    inset: 0;
    background:
        linear-gradient(100deg, rgba(11, 18, 32, 0.88) 0%, rgba(11, 18, 32, 0.55) 45%, rgba(11, 18, 32, 0.25) 100%),
        radial-gradient(ellipse at 80% 20%, rgba(201, 161, 95, 0.18), transparent 60%);
    z-index: 1;
}

.hero-slide-overlay {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(to bottom, transparent 55%, rgba(11, 18, 32, 0.55) 100%);
    z-index: 2;
    pointer-events: none;
}

.hero-slide-inner {
    position: relative;
    z-index: 3;
    width: 100%;
    padding-top: 60px;
    padding-bottom: 100px;
}

.hero-slide-copy {
    max-width: 720px;
    color: var(--paper-soft);
}

.hero-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 8px 18px;
    border: 1px solid rgba(201, 161, 95, 0.5);
    background: rgba(11, 18, 32, 0.35);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border-radius: 999px;
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--champagne-soft);
    margin-bottom: 28px;
    opacity: 0;
    transform: translateY(20px);
    animation: heroFadeUp 0.9s var(--ease) 0.15s forwards;
}

.hero-eyebrow i { color: var(--champagne); font-size: 12px; }

.hero-slide-title {
    font-family: var(--font-display);
    font-size: clamp(2.75rem, 6.2vw, 5.5rem);
    line-height: 0.98;
    letter-spacing: -0.035em;
    color: var(--paper-soft);
    margin: 0 0 28px;
    opacity: 0;
    transform: translateY(30px);
    animation: heroFadeUp 1s var(--ease) 0.3s forwards;
    max-width: 16ch;
}

.hero-slide-title em {
    font-style: italic;
    color: var(--champagne);
    font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1;
}

.hero-slide-lede {
    font-size: 1.15rem;
    line-height: 1.65;
    color: rgba(245, 241, 232, 0.85);
    max-width: 56ch;
    margin-bottom: 36px;
    opacity: 0;
    transform: translateY(20px);
    animation: heroFadeUp 1s var(--ease) 0.45s forwards;
}

.hero-slide-actions {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    opacity: 0;
    transform: translateY(20px);
    animation: heroFadeUp 1s var(--ease) 0.6s forwards;
}

@keyframes heroFadeUp {
    to { opacity: 1; transform: translateY(0); }
}

/* reset animation on new active slide */
.hero-slider .slick-slide .hero-eyebrow,
.hero-slider .slick-slide .hero-slide-title,
.hero-slider .slick-slide .hero-slide-lede,
.hero-slider .slick-slide .hero-slide-actions {
    animation: none;
    opacity: 0;
    transform: translateY(20px);
}

.hero-slider .slick-slide.slick-active .hero-eyebrow { animation: heroFadeUp 0.9s var(--ease) 0.15s forwards; }
.hero-slider .slick-slide.slick-active .hero-slide-title { animation: heroFadeUp 1s var(--ease) 0.3s forwards; }
.hero-slider .slick-slide.slick-active .hero-slide-lede { animation: heroFadeUp 1s var(--ease) 0.45s forwards; }
.hero-slider .slick-slide.slick-active .hero-slide-actions { animation: heroFadeUp 1s var(--ease) 0.6s forwards; }

/* Ken-Burns zoom on active slide */
.hero-slider .hero-slide {
    transition: transform 8s linear;
    transform: scale(1);
}
.hero-slider .slick-slide.slick-active .hero-slide {
    transform: scale(1.08);
}

/* Custom slick arrows */
.hero-slider .slick-arrow {
    position: absolute;
    z-index: 5;
    top: 50%;
    width: 58px;
    height: 58px;
    border-radius: 50%;
    background: rgba(11, 18, 32, 0.45);
    border: 1px solid rgba(245, 241, 232, 0.2);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    color: var(--paper-soft);
    font-size: 0;
    cursor: pointer;
    transition: 0.3s var(--ease);
    transform: translateY(-50%);
}

.hero-slider .slick-arrow:hover {
    background: var(--champagne);
    border-color: var(--champagne);
    color: var(--ink);
}

.hero-slider .slick-prev { left: 28px; }
.hero-slider .slick-next { right: 28px; }

.hero-slider .slick-arrow::before {
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    font-size: 16px;
    color: inherit;
    opacity: 1;
}

.hero-slider .slick-prev::before { content: "\f060"; }
.hero-slider .slick-next::before { content: "\f061"; }

/* Custom slick dots (under slider) */
.hero-slider .slick-dots {
    position: absolute;
    bottom: 32px;
    left: 50%;
    transform: translateX(-50%);
    display: flex !important;
    justify-content: center;
    gap: 10px;
    z-index: 5;
    padding: 0;
    margin: 0;
}

.hero-slider .slick-dots li {
    width: auto;
    height: auto;
    margin: 0;
}

.hero-slider .slick-dots li button {
    width: 36px;
    height: 3px;
    padding: 0;
    border-radius: 2px;
    background: rgba(245, 241, 232, 0.35);
    border: none;
    cursor: pointer;
    transition: 0.3s var(--ease);
}

.hero-slider .slick-dots li button::before { display: none; }

.hero-slider .slick-dots li.slick-active button {
    background: var(--champagne);
    width: 56px;
}

/* Floating stats card overlapping hero bottom */
.hero-float-stats {
    position: absolute;
    right: max(32px, calc((100% - 1216px) / 2));
    bottom: -50px;
    z-index: 6;
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 32px;
    padding: 28px 40px;
    background: var(--paper-soft);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
    border-top: 3px solid var(--champagne);
    min-width: 440px;
}

.hero-float-stats .float-stat {
    display: flex;
    flex-direction: column;
    gap: 6px;
    text-align: center;
}

.hero-float-stats .float-num {
    font-family: var(--font-display);
    font-size: 2.5rem;
    line-height: 1;
    color: var(--navy);
}

.hero-float-stats .float-num em { color: var(--champagne); font-style: italic; }

.hero-float-stats .float-label {
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--muted);
}

.hero-float-stats .float-divider {
    width: 1px;
    height: 52px;
    background: var(--line-strong);
}

@media (max-width: 1024px) {
    .hero-float-stats { right: 24px; min-width: 380px; padding: 22px 28px; }
    .hero-float-stats .float-num { font-size: 2rem; }
}

@media (max-width: 768px) {
    .hero-slide { min-height: 72vh; }
    .hero-slide-inner { padding-top: 40px; padding-bottom: 120px; }
    .hero-float-stats {
        position: static;
        margin: -40px auto 32px;
        width: calc(100% - 32px);
        min-width: 0;
        padding: 20px 22px;
        gap: 18px;
    }
    .hero-slider .slick-arrow { width: 44px; height: 44px; }
    .hero-slider .slick-prev { left: 12px; }
    .hero-slider .slick-next { right: 12px; }
}

/* ---------- CLIENT MARQUEE ---------- */
.client-strip {
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    padding: 28px 0;
    background: var(--paper);
}

.client-marquee {
    display: flex;
    gap: 80px;
    align-items: center;
    overflow: hidden;
}

.client-marquee span {
    flex: 0 0 auto;
    font-family: var(--font-display);
    font-size: 1.5rem;
    color: var(--muted-soft);
    letter-spacing: -0.01em;
    font-style: italic;
}

.client-marquee span:not(:last-child)::after {
    content: '—';
    margin-left: 80px;
    color: var(--line-strong);
}

/* ---------- SECTION HEADER ---------- */
.section-header {
    margin-bottom: 72px;
}

.section-header.center {
    text-align: center;
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
}

.section-title {
    font-size: clamp(2rem, 4vw, 3.5rem);
    margin-bottom: 20px;
}

.section-sub {
    font-size: 1.0625rem;
    color: var(--muted);
    max-width: 58ch;
}

.center .section-sub { margin-left: auto; margin-right: auto; }

/* ---------- ABOUT (editorial split) ---------- */
.about-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 100px;
    align-items: center;
}

.about-media {
    position: relative;
}

.about-media .primary-img {
    aspect-ratio: 4/5;
    width: 100%;
    object-fit: cover;
    border-radius: var(--radius-md);
}

.about-media .accent-block {
    position: absolute;
    right: -40px;
    top: -40px;
    width: 160px;
    height: 160px;
    background: var(--champagne);
    border-radius: var(--radius-md);
    z-index: -1;
}

.exp-badge {
    position: absolute;
    left: -36px;
    bottom: 40px;
    background: var(--ink);
    color: var(--paper-soft);
    padding: 28px 32px;
    border-radius: var(--radius-sm);
    max-width: 220px;
}
.exp-badge .count {
    font-family: var(--font-display);
    font-size: 3rem;
    line-height: 1;
    color: var(--champagne);
    display: block;
    margin-bottom: 6px;
}
.exp-badge .text {
    font-size: 12px;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--paper-soft);
}

.about-copy h2 { margin-bottom: 28px; }

.check-list { margin: 32px 0; }
.check-list li {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 14px 0;
    border-bottom: 1px solid var(--line);
    font-size: 15px;
    font-weight: 500;
}
.check-list li:last-child { border-bottom: none; }
.check-list i {
    color: var(--champagne);
    margin-top: 4px;
    font-size: 14px;
}

@media (max-width: 900px) {
    .about-split { grid-template-columns: 1fr; gap: 60px; }
    .about-media .accent-block { right: -16px; top: -16px; width: 80px; height: 80px; }
    .exp-badge { left: 16px; bottom: 16px; padding: 20px; }
    .exp-badge .count { font-size: 2rem; }
}

/* ---------- EDITORIAL SERVICES ---------- */
.services-editorial {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 32px;
}

.service-tile {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-md);
    aspect-ratio: 4/5;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 48px;
    color: var(--paper-soft);
    isolation: isolate;
}

.service-tile::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--bg, #0F2342) center/cover no-repeat;
    z-index: -2;
    transition: transform 0.9s var(--ease);
}

.service-tile::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(11, 18, 32, 0.1) 0%, rgba(11, 18, 32, 0.75) 100%);
    z-index: -1;
}

.service-tile:hover::before { transform: scale(1.05); }

.service-tile .cat {
    font-size: 12px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--champagne);
    margin-bottom: 16px;
}

.service-tile h3 {
    color: var(--paper-soft);
    font-size: clamp(1.75rem, 2.8vw, 2.5rem);
    margin-bottom: 16px;
}

.service-tile p {
    color: rgba(245, 241, 232, 0.8);
    max-width: 34ch;
    margin-bottom: 28px;
}

.service-tile .btn-link {
    color: var(--paper-soft);
    border-color: rgba(245, 241, 232, 0.4);
    align-self: flex-start;
}
.service-tile .btn-link:hover {
    color: var(--champagne);
    border-color: var(--champagne);
}

@media (max-width: 768px) {
    .services-editorial { grid-template-columns: 1fr; }
    .service-tile { padding: 32px; }
}

/* ---------- SECTORS BENTO ---------- */
.sectors-bento {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2px;
    background: var(--line);
    border: 1px solid var(--line);
}

.sector-card {
    background: var(--paper-soft);
    padding: 48px 32px;
    transition: all 0.4s var(--ease);
    display: flex;
    flex-direction: column;
    gap: 18px;
    min-height: 280px;
    position: relative;
    overflow: hidden;
}

.sector-card:hover {
    background: var(--ink);
    color: var(--paper-soft);
}

.sector-card .icon {
    font-size: 32px;
    color: var(--champagne);
    transition: transform 0.4s var(--ease);
}

.sector-card:hover .icon { transform: translateY(-4px); }

.sector-card h4 {
    font-size: 1.35rem;
    margin: 0;
    color: inherit;
}

.sector-card .num {
    position: absolute;
    top: 24px;
    right: 28px;
    font-family: var(--font-display);
    font-style: italic;
    font-size: 14px;
    color: var(--muted-soft);
}

.sector-card:hover .num { color: var(--champagne); }

@media (max-width: 900px) {
    .sectors-bento { grid-template-columns: repeat(2, 1fr); }
}

/* ---------- DIFFERENTIATORS (numbered rows) ---------- */
.differentiators .diff-row {
    display: grid;
    grid-template-columns: 100px 1fr 2fr;
    gap: 48px;
    padding: 48px 0;
    border-bottom: 1px solid var(--line);
    align-items: start;
}

.differentiators .diff-row:first-child { border-top: 1px solid var(--line); }

.diff-num {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 1.5rem;
    color: var(--champagne);
}

.diff-title {
    font-family: var(--font-display);
    font-size: clamp(1.5rem, 2.4vw, 2.25rem);
    line-height: 1.1;
    margin: 0;
}

.diff-desc {
    color: var(--muted);
    font-size: 1.0625rem;
    line-height: 1.7;
    margin: 0;
}

@media (max-width: 768px) {
    .differentiators .diff-row { grid-template-columns: 1fr; gap: 16px; padding: 32px 0; }
}

/* ---------- PROJECTS / WORK GRID ---------- */
.work-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 32px;
}

.work-item {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-sm);
}

.work-item.large { grid-column: span 4; aspect-ratio: 16/10; }
.work-item.small { grid-column: span 2; aspect-ratio: 4/5; }
.work-item.med { grid-column: span 3; aspect-ratio: 4/3; }

.work-item .work-img {
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    transition: transform 1.2s var(--ease);
}

.work-item:hover .work-img { transform: scale(1.06); }

.work-item .caption {
    position: absolute;
    left: 24px;
    bottom: 24px;
    right: 24px;
    color: var(--paper-soft);
    z-index: 2;
}

.work-item::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 40%, rgba(11, 18, 32, 0.75));
    z-index: 1;
}

.work-item .cat {
    font-size: 12px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--champagne);
    margin-bottom: 8px;
    display: block;
}

.work-item h4 {
    font-size: clamp(1.1rem, 1.8vw, 1.5rem);
    color: var(--paper-soft);
    margin: 0;
}

@media (max-width: 900px) {
    .work-grid { grid-template-columns: 1fr; }
    .work-item.large, .work-item.small, .work-item.med { grid-column: span 1; aspect-ratio: 4/3; }
}

/* ---------- TESTIMONIALS (quote large) ---------- */
.testimonials {
    background: var(--navy);
    color: var(--paper-soft);
    position: relative;
    overflow: hidden;
}

.testimonials::before {
    content: '"';
    position: absolute;
    top: -40px;
    left: 40px;
    font-family: var(--font-display);
    font-size: 26rem;
    line-height: 1;
    color: rgba(201, 161, 95, 0.08);
    pointer-events: none;
}

.testimonials .eyebrow { color: var(--champagne-soft); }
.testimonials .eyebrow::before { background: var(--champagne); }

.testimonials-slider .testimonial-slide {
    padding: 0 0 40px;
}

.testimonial-quote {
    font-family: var(--font-display);
    font-size: clamp(1.5rem, 3vw, 2.25rem);
    line-height: 1.35;
    letter-spacing: -0.01em;
    color: var(--paper-soft);
    margin-bottom: 40px;
    max-width: 28ch;
}

.testimonial-meta {
    display: flex;
    align-items: center;
    gap: 20px;
}

.testimonial-meta .avatar {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--champagne);
    color: var(--ink);
    display: grid;
    place-items: center;
    font-family: var(--font-display);
    font-size: 1.25rem;
}

.testimonial-meta h4 {
    color: var(--paper-soft);
    margin: 0;
    font-size: 1rem;
    font-family: var(--font-sans);
    font-weight: 500;
}

.testimonial-meta span {
    color: var(--muted-soft);
    font-size: 13px;
    letter-spacing: 0.05em;
}

.testimonials-slider .slick-dots {
    bottom: 0;
    text-align: left;
    padding-left: 0;
}

.testimonials-slider .slick-dots li button::before {
    color: var(--paper-soft);
    opacity: 0.3;
    font-size: 8px;
}

.testimonials-slider .slick-dots li.slick-active button::before {
    color: var(--champagne);
    opacity: 1;
}

/* ---------- STATS STRIP ---------- */
.stats-section { padding-top: 120px; } /* leaves room for floating hero stats */

.stats-strip {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
}

.stat {
    padding: 48px 32px;
    border-left: 1px solid var(--line);
    position: relative;
    overflow: hidden;
    transition: 0.4s var(--ease);
}

.stat:first-child { border-left: none; }

.stat .num {
    font-family: var(--font-display);
    font-size: clamp(2.5rem, 4vw, 3.75rem);
    line-height: 1;
    color: var(--navy);
    margin-bottom: 12px;
    display: block;
}

.stat .num em { color: var(--champagne); font-style: italic; }

.stat .label {
    font-size: 12px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--muted);
}

/* animated stats with icons */
.stats-animated .stat {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 56px 32px;
    text-align: left;
}

.stats-animated .stat::before {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    height: 3px;
    width: 0;
    background: var(--champagne);
    transition: width 0.8s var(--ease);
}

.stats-animated .stat.counted::before { width: 100%; }

.stats-animated .stat:hover {
    background: var(--paper);
    transform: translateY(-2px);
}

.stats-animated .stat-icon {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: var(--paper);
    color: var(--champagne);
    display: grid;
    place-items: center;
    font-size: 20px;
    margin-bottom: 20px;
    transition: 0.4s var(--ease);
}

.stats-animated .stat:hover .stat-icon {
    background: var(--champagne);
    color: var(--ink);
    transform: rotate(-8deg) scale(1.06);
}

.stats-animated .counter {
    transition: color 0.4s var(--ease);
}

.stats-animated .stat.counted .counter {
    color: var(--navy);
}

@media (max-width: 700px) {
    .stats-strip { grid-template-columns: repeat(2, 1fr); }
    .stat { border-left: none; border-top: 1px solid var(--line); }
    .stat:nth-child(-n+2) { border-top: none; }
    .stat:nth-child(2n) { border-left: 1px solid var(--line); }
}

/* ---------- CTA ---------- */
.cta-band {
    background: var(--ink);
    color: var(--paper-soft);
    padding: clamp(80px, 10vw, 140px) 0;
    position: relative;
    overflow: hidden;
}

.cta-band::before {
    content: '';
    position: absolute;
    right: -10%;
    top: -20%;
    width: 500px;
    height: 500px;
    background: radial-gradient(circle, rgba(201, 161, 95, 0.12), transparent 70%);
    pointer-events: none;
}

.cta-band h2 {
    font-size: clamp(2.25rem, 5vw, 4rem);
    color: var(--paper-soft);
    margin-bottom: 20px;
    max-width: 18ch;
}

.cta-band p {
    color: var(--muted-soft);
    max-width: 52ch;
    margin-bottom: 32px;
}

/* ---------- PAGE HERO (inner pages) ---------- */
.page-hero {
    padding: clamp(90px, 12vw, 160px) 0 clamp(70px, 9vw, 110px);
    background: var(--paper);
    border-bottom: 1px solid var(--line);
    position: relative;
}

.page-hero .eyebrow { color: var(--champagne); }
.page-hero h1 {
    font-size: clamp(2.5rem, 5.5vw, 4.5rem);
    max-width: 14ch;
    margin: 0;
}

.page-hero-dark {
    background: var(--ink);
    color: var(--paper-soft);
    border-bottom: none;
}

.page-hero-dark h1 { color: var(--paper-soft); }

/* ---------- LEADERSHIP ---------- */
.leader-row {
    display: grid;
    grid-template-columns: 1fr 1.3fr;
    gap: 80px;
    align-items: center;
    padding: 80px 0;
    border-bottom: 1px solid var(--line);
}
.leader-row:last-child { border-bottom: none; }
.leader-row.reverse { grid-template-columns: 1.3fr 1fr; }
.leader-row.reverse .leader-media { order: 2; }

.leader-media img {
    width: 100%;
    aspect-ratio: 3/4;
    object-fit: cover;
    border-radius: var(--radius-md);
}

.leader-copy .quote {
    font-family: var(--font-display);
    font-size: clamp(1.25rem, 2.4vw, 1.875rem);
    line-height: 1.4;
    color: var(--ink);
    margin-bottom: 32px;
}

.leader-copy .quote::before {
    content: '"';
    font-family: var(--font-display);
    display: block;
    font-size: 4rem;
    line-height: 0.5;
    color: var(--champagne);
    margin-bottom: 20px;
}

.leader-meta h4 {
    font-family: var(--font-sans);
    font-size: 1rem;
    font-weight: 600;
    margin: 0 0 4px;
    color: var(--ink);
}

.leader-meta span {
    font-size: 13px;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--champagne);
}

@media (max-width: 900px) {
    .leader-row, .leader-row.reverse { grid-template-columns: 1fr; gap: 40px; padding: 48px 0; }
    .leader-row.reverse .leader-media { order: 0; }
}

/* ---------- VISION MISSION CARDS ---------- */
.vm-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 32px;
}

.vm-card {
    background: var(--paper-soft);
    padding: 56px 48px;
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    transition: 0.4s var(--ease);
    position: relative;
}

.vm-card:hover {
    background: var(--ink);
    color: var(--paper-soft);
    transform: translateY(-4px);
    border-color: var(--ink);
}

.vm-card:hover h3 { color: var(--paper-soft); }

.vm-card .icon {
    width: 64px;
    height: 64px;
    background: var(--champagne);
    color: var(--ink);
    display: grid;
    place-items: center;
    font-size: 24px;
    border-radius: 50%;
    margin-bottom: 32px;
}

.vm-card h3 { margin-bottom: 16px; }

.values-row {
    display: flex;
    flex-wrap: wrap;
    gap: 16px 40px;
    margin-top: 64px;
    justify-content: center;
}

.value-item {
    display: flex;
    align-items: center;
    gap: 10px;
    font-family: var(--font-display);
    font-style: italic;
    font-size: 1.35rem;
    color: var(--ink);
}

.value-item i { color: var(--champagne); font-size: 14px; }

@media (max-width: 700px) {
    .vm-grid { grid-template-columns: 1fr; }
    .vm-card { padding: 40px 28px; }
}

/* ---------- SERVICES PAGE CARDS ---------- */
.service-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
}

.service-card {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-sm);
    background: var(--paper-soft);
    border: 1px solid var(--line);
    transition: 0.4s var(--ease);
}

.service-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-md);
    border-color: var(--champagne);
}

.service-card .card-img {
    height: 260px;
    background-size: cover;
    background-position: center;
    position: relative;
}

.service-card .card-img::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 60%, rgba(11, 18, 32, 0.25));
}

.service-card .card-body {
    padding: 32px;
}

.service-card .num {
    font-family: var(--font-display);
    font-style: italic;
    color: var(--champagne);
    font-size: 14px;
    margin-bottom: 12px;
}

.service-card h3 {
    font-size: 1.5rem;
    margin-bottom: 12px;
}

.service-card p {
    color: var(--muted);
    font-size: 15px;
    margin-bottom: 24px;
}

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

/* ---------- PROCESS TIMELINE ---------- */
.process {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0;
    position: relative;
}

.process::before {
    content: '';
    position: absolute;
    top: 32px;
    left: 10%;
    right: 10%;
    height: 1px;
    background: var(--line-strong);
}

.process-step {
    text-align: center;
    padding: 0 16px;
    position: relative;
}

.process-step .num {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: var(--paper-soft);
    border: 1px solid var(--line-strong);
    display: grid;
    place-items: center;
    font-family: var(--font-display);
    font-style: italic;
    font-size: 1.35rem;
    color: var(--navy);
    margin: 0 auto 24px;
    position: relative;
    z-index: 2;
    transition: 0.3s var(--ease);
}

.process-step:hover .num {
    background: var(--champagne);
    color: var(--ink);
    border-color: var(--champagne);
}

.process-step h4 { font-size: 1.125rem; margin-bottom: 12px; }
.process-step p { color: var(--muted); font-size: 14px; }

@media (max-width: 900px) {
    .process { grid-template-columns: repeat(2, 1fr); gap: 48px 24px; }
    .process::before { display: none; }
}
@media (max-width: 480px) { .process { grid-template-columns: 1fr; } }

/* ---------- NEXT CTA ---------- */
.next-cta {
    background: var(--ink);
    color: var(--paper-soft);
}

.next-cta .next-link {
    display: block;
    padding: 72px 0;
    color: var(--paper-soft);
    transition: 0.4s var(--ease);
    text-align: center;
}

.next-cta .next-link:hover { background: rgba(201, 161, 95, 0.06); color: var(--champagne); }

.next-cta .eyebrow { color: var(--champagne-soft); justify-content: center; }
.next-cta .eyebrow::before { background: var(--champagne); }

.next-cta h2 {
    color: var(--paper-soft);
    font-size: clamp(2rem, 4vw, 3rem);
    margin: 0;
}

.next-cta .next-link:hover h2 { color: var(--champagne); }

/* ---------- CONTACT ---------- */
.contact-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
}

.contact-details { margin-top: 48px; }
.detail-item {
    display: flex;
    align-items: flex-start;
    gap: 20px;
    padding: 20px 0;
    border-bottom: 1px solid var(--line);
}
.detail-item:last-child { border-bottom: none; }
.detail-item .icon {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--paper);
    color: var(--champagne);
    display: grid;
    place-items: center;
    font-size: 15px;
    flex-shrink: 0;
}
.detail-item .info span {
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--muted);
    display: block;
    margin-bottom: 4px;
}
.detail-item .info a {
    font-family: var(--font-display);
    font-size: 1.25rem;
    color: var(--ink);
}
.detail-item .info a:hover { color: var(--champagne); }

.form-box {
    background: var(--paper);
    padding: 56px 48px;
    border-radius: var(--radius-md);
    border: 1px solid var(--line);
}

.form-box h3 { margin-bottom: 32px; font-size: 1.75rem; }

.form-group { margin-bottom: 20px; }

.form-group input,
.form-group select,
.form-group textarea {
    width: 100%;
    padding: 16px 18px;
    border: 1px solid var(--line);
    background: var(--paper-soft);
    border-radius: var(--radius-sm);
    font-family: var(--font-sans);
    font-size: 15px;
    color: var(--ink);
    transition: 0.3s var(--ease);
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
    outline: none;
    border-color: var(--champagne);
    background: var(--white);
}

.form-group textarea { resize: vertical; min-height: 120px; }

.w-100 { width: 100%; }

@media (max-width: 900px) {
    .contact-split { grid-template-columns: 1fr; gap: 56px; }
    .form-box { padding: 36px 24px; }
}

/* ---------- LOCATIONS TABS ---------- */
.tab-nav {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-bottom: 48px;
    flex-wrap: wrap;
}

.tab-btn {
    padding: 12px 28px;
    background: transparent;
    border: 1px solid var(--line-strong);
    border-radius: 999px;
    font-family: var(--font-sans);
    font-size: 13px;
    letter-spacing: 0.08em;
    cursor: pointer;
    color: var(--muted);
    transition: 0.3s var(--ease);
}

.tab-btn:hover, .tab-btn.active {
    background: var(--ink);
    color: var(--paper-soft);
    border-color: var(--ink);
}

.tab-content { display: none; }
.tab-content.active { display: block; }

.tab-content .row {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 64px;
    align-items: center;
}

.map-img {
    width: 100%;
    border-radius: var(--radius-md);
}

.address-col h3 {
    font-size: 1.875rem;
    margin-bottom: 20px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--line);
}

.address-col p { color: var(--muted); margin-bottom: 12px; }
.address-col strong { color: var(--ink); font-weight: 500; }

@media (max-width: 768px) { .tab-content .row { grid-template-columns: 1fr; gap: 32px; } }

/* ---------- INSIGHTS GRID ---------- */
.insights-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 48px 32px;
}

.insight-card {
    display: flex;
    flex-direction: column;
    gap: 20px;
    transition: 0.3s var(--ease);
}

.insight-card .insight-img {
    display: block;
    height: 260px;
    background-size: cover;
    background-position: center;
    border-radius: var(--radius-sm);
    overflow: hidden;
    transition: transform 0.6s var(--ease);
}

.insight-card:hover .insight-img { transform: translateY(-4px); }

.insight-meta {
    display: flex;
    gap: 16px;
    font-size: 12px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--muted);
}

.insight-meta .cat { color: var(--champagne); }

.insight-card h3 {
    font-size: 1.5rem;
    line-height: 1.2;
    margin: 0;
}

.insight-card h3 a { color: var(--ink); }
.insight-card:hover h3 a { color: var(--champagne); }

.insight-card p {
    color: var(--muted);
    font-size: 15px;
    margin: 0;
}

.pagination {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 80px;
}

.pagination .page-numbers {
    display: grid;
    place-items: center;
    min-width: 44px;
    height: 44px;
    padding: 0 14px;
    border: 1px solid var(--line-strong);
    border-radius: 999px;
    font-size: 14px;
    color: var(--muted);
}

.pagination .page-numbers.current,
.pagination .page-numbers:hover {
    background: var(--ink);
    color: var(--paper-soft);
    border-color: var(--ink);
}

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

/* ---------- SINGLE POST ---------- */
.single-post-wrap { max-width: 760px; margin: 0 auto; }

.post-meta {
    display: flex;
    gap: 24px;
    font-size: 13px;
    letter-spacing: 0.08em;
    color: var(--muted);
    padding: 24px 0;
    border-bottom: 1px solid var(--line);
    margin-bottom: 48px;
    text-transform: uppercase;
}

.post-meta i { color: var(--champagne); margin-right: 6px; }

.post-content {
    font-size: 1.125rem;
    line-height: 1.75;
}

.post-content p { margin-bottom: 1.5em; }

.post-content h2,
.post-content h3 { margin-top: 2em; }

.post-content blockquote {
    border-left: 3px solid var(--champagne);
    padding: 12px 0 12px 32px;
    font-family: var(--font-display);
    font-size: 1.5rem;
    line-height: 1.4;
    font-style: italic;
    color: var(--ink);
    margin: 2em 0;
}

.post-content img { border-radius: var(--radius-md); margin: 2em 0; }

.post-nav {
    display: flex;
    justify-content: space-between;
    gap: 24px;
    padding: 40px 0;
    margin-top: 64px;
    border-top: 1px solid var(--line);
    font-size: 14px;
    letter-spacing: 0.06em;
}

.post-nav .next { margin-left: auto; text-align: right; }

/* ---------- 404 ---------- */
.error-404 {
    text-align: center;
    padding: 140px 0;
    background: var(--paper);
}

.error-404 .big-404 {
    font-family: var(--font-display);
    font-size: clamp(6rem, 18vw, 14rem);
    line-height: 0.85;
    color: var(--ink);
    margin: 32px 0 24px;
    letter-spacing: -0.05em;
}

.error-404 .big-404 em { color: var(--champagne); font-style: italic; }

/* ---------- FOOTER ---------- */
.site-footer {
    background: var(--ink);
    color: var(--paper-soft);
    padding: 100px 0 40px;
    position: relative;
}

.footer-top {
    display: grid;
    grid-template-columns: 1.5fr 1fr 1fr 1fr;
    gap: 64px;
    padding-bottom: 72px;
    border-bottom: 1px solid rgba(245, 241, 232, 0.1);
}

.footer-brand h2 {
    font-family: var(--font-display);
    font-size: 2.5rem;
    color: var(--paper-soft);
    margin-bottom: 20px;
}

.footer-brand h2 em { color: var(--champagne); font-style: italic; }

.footer-brand .footer-logo {
    display: inline-block;
    margin-bottom: 22px;
}

.footer-brand .footer-logo img {
    height: 64px;
    width: auto;
    filter: brightness(0) invert(1);
    opacity: 0.95;
    transition: 0.3s var(--ease);
}

.footer-brand .footer-logo:hover img { opacity: 1; }

.footer-col .cert-sub {
    color: var(--muted-soft);
    font-size: 12px;
    line-height: 1.6;
    margin-top: 16px;
    max-width: 28ch;
}

.map-embed {
    border-radius: var(--radius-md);
    display: block;
    width: 100%;
}

.location-single .row {
    display: grid;
    grid-template-columns: 1.3fr 1fr;
    gap: 64px;
    align-items: stretch;
}

.location-single .address-col {
    padding: 8px 0;
}

@media (max-width: 900px) {
    .location-single .row { grid-template-columns: 1fr; gap: 32px; }
}

.footer-brand p {
    color: var(--muted-soft);
    max-width: 38ch;
    font-size: 15px;
    margin-bottom: 28px;
}

.social-icons {
    display: flex;
    gap: 12px;
}

.social-icons a {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1px solid rgba(245, 241, 232, 0.2);
    display: grid;
    place-items: center;
    font-size: 14px;
    color: var(--paper-soft);
    transition: 0.3s var(--ease);
}

.social-icons a:hover {
    background: var(--champagne);
    border-color: var(--champagne);
    color: var(--ink);
}

.footer-col h4 {
    font-family: var(--font-sans);
    font-size: 12px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--champagne);
    margin-bottom: 24px;
    font-weight: 500;
}

.footer-links li { margin-bottom: 12px; }

.footer-links a {
    color: var(--paper-soft);
    font-size: 15px;
    transition: 0.3s var(--ease);
}

.footer-links a:hover { color: var(--champagne); padding-left: 6px; }

.footer-col .cert-badge {
    display: inline-block;
    padding: 6px 12px;
    margin: 0 6px 6px 0;
    border: 1px solid rgba(245, 241, 232, 0.2);
    border-radius: 4px;
    font-size: 12px;
    letter-spacing: 0.1em;
    color: var(--muted-soft);
}

.footer-col .location-item { margin-bottom: 18px; }
.footer-col .location-item h5 {
    font-family: var(--font-sans);
    font-size: 14px;
    font-weight: 500;
    margin: 0 0 4px;
    color: var(--paper-soft);
}
.footer-col .location-item p { margin: 0; color: var(--muted-soft); font-size: 14px; }

.footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 40px;
    font-size: 13px;
    color: var(--muted-soft);
    flex-wrap: wrap;
    gap: 16px;
}

.footer-bottom a { color: var(--muted-soft); }
.footer-bottom a:hover { color: var(--champagne); }

@media (max-width: 900px) {
    .footer-top { grid-template-columns: 1fr 1fr; gap: 48px; }
}
@media (max-width: 600px) {
    .footer-top { grid-template-columns: 1fr; }
    .footer-bottom { flex-direction: column; text-align: center; }
}

/* ---------- UTILITIES ---------- */
.mt-4 { margin-top: 32px; }
.mb-4 { margin-bottom: 32px; }
.mt-6 { margin-top: 48px; }
.mb-6 { margin-bottom: 48px; }

/* ---------- ANIMATIONS ---------- */
@keyframes fadeUp {
    from { opacity: 0; transform: translateY(24px); }
    to   { opacity: 1; transform: translateY(0); }
}

.reveal { opacity: 0; transform: translateY(24px); transition: 0.9s var(--ease); }
.reveal.in { opacity: 1; transform: translateY(0); }

/* =========================================================
   PREMIUM HOMEPAGE — additional sections
   ========================================================= */

/* ---------- PROMISE PILLARS ---------- */
.promise-section {
    padding: clamp(96px, 12vw, 140px) 0 clamp(48px, 6vw, 72px);
    background: var(--paper-soft);
    position: relative;
    z-index: 5;
}

.promise-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
}

.promise-card {
    position: relative;
    padding: 44px 36px 40px;
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    transition: 0.45s var(--ease);
    overflow: hidden;
    isolation: isolate;
}

.promise-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(160deg, rgba(201, 161, 95, 0.10), transparent 60%);
    opacity: 0;
    transition: opacity 0.45s var(--ease);
    z-index: -1;
}

.promise-card:hover {
    transform: translateY(-6px);
    border-color: var(--champagne);
    box-shadow: var(--shadow-md);
}

.promise-card:hover::before { opacity: 1; }

.promise-icon {
    width: 56px;
    height: 56px;
    border-radius: 14px;
    background: linear-gradient(140deg, var(--champagne), var(--champagne-soft));
    color: var(--ink);
    display: grid;
    place-items: center;
    font-size: 22px;
    margin-bottom: 28px;
    box-shadow: 0 8px 24px rgba(201, 161, 95, 0.25);
    transition: 0.45s var(--ease);
}

.promise-card:hover .promise-icon {
    transform: rotate(-8deg) scale(1.06);
    box-shadow: 0 14px 32px rgba(201, 161, 95, 0.4);
}

.promise-num {
    position: absolute;
    top: 28px;
    right: 32px;
    font-family: var(--font-display);
    font-style: italic;
    font-size: 1.3rem;
    color: var(--line-strong);
    transition: color 0.45s var(--ease);
}

.promise-card:hover .promise-num { color: var(--champagne); }

.promise-card h3 {
    font-size: 1.5rem;
    margin-bottom: 14px;
}

.promise-card p {
    color: var(--muted);
    font-size: 15px;
    line-height: 1.65;
    margin: 0;
}

@media (max-width: 900px) {
    .promise-grid { grid-template-columns: 1fr; gap: 18px; }
    .promise-section { padding-top: 80px; }
}

/* ---------- ABOUT MICRO CARD ---------- */
.media-micro-card {
    position: absolute;
    right: -28px;
    bottom: 120px;
    background: var(--white);
    padding: 18px 22px;
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-md);
    display: flex;
    align-items: center;
    gap: 14px;
    border-right: 3px solid var(--champagne);
    z-index: 3;
}

.media-micro-card i {
    color: var(--champagne);
    font-size: 26px;
}

.media-micro-card strong {
    display: block;
    font-family: var(--font-display);
    font-size: 1.5rem;
    color: var(--navy);
    line-height: 1;
    margin-bottom: 4px;
}

.media-micro-card span {
    font-size: 11px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--muted);
}

.about-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 16px 32px;
    align-items: center;
}

@media (max-width: 900px) {
    .media-micro-card { right: 8px; bottom: auto; top: 16px; padding: 12px 16px; }
    .media-micro-card strong { font-size: 1.15rem; }
}

/* ---------- SERVICES TABS ---------- */
.svc-tabs {
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}

.svc-tab-nav {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    background: var(--paper-soft);
    border-bottom: 1px solid var(--line);
}

.svc-tab-btn {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 26px 36px;
    background: transparent;
    border: none;
    cursor: pointer;
    font-family: var(--font-display);
    font-size: 1.35rem;
    color: var(--muted);
    text-align: left;
    border-bottom: 3px solid transparent;
    transition: 0.35s var(--ease);
    position: relative;
}

.svc-tab-btn + .svc-tab-btn { border-left: 1px solid var(--line); }

.svc-tab-btn:hover {
    color: var(--ink);
    background: rgba(201, 161, 95, 0.06);
}

.svc-tab-btn.active {
    color: var(--ink);
    background: var(--white);
    border-bottom-color: var(--champagne);
}

.svc-tab-num {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 1rem;
    color: var(--champagne);
}

.svc-tab-panel {
    display: none;
    animation: svcFade 0.5s var(--ease);
}

.svc-tab-panel.active { display: block; }

@keyframes svcFade {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}

.svc-panel-grid {
    display: grid;
    grid-template-columns: 0.85fr 1.15fr;
    align-items: stretch;
}

.svc-panel-media {
    position: relative;
    min-height: 520px;
    background-size: cover;
    background-position: center;
    overflow: hidden;
}

.svc-panel-media::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(140deg, rgba(11, 18, 32, 0.45), transparent 60%);
}

.svc-panel-caption {
    position: absolute;
    top: 28px;
    left: 28px;
    z-index: 2;
    font-size: 11px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--paper-soft);
    background: rgba(11, 18, 32, 0.55);
    padding: 8px 14px;
    border-radius: 999px;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}

.svc-panel-copy {
    padding: 56px 56px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.svc-panel-copy h3 {
    font-size: clamp(1.5rem, 2.4vw, 2rem);
    line-height: 1.2;
    margin-bottom: 18px;
}

.svc-panel-copy p {
    color: var(--muted);
    font-size: 1.0625rem;
    line-height: 1.65;
    max-width: 56ch;
    margin-bottom: 28px;
}

.svc-trades {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px 28px;
    margin-bottom: 36px;
}

.svc-trades li {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 14px;
    font-weight: 500;
    padding: 10px 0;
    border-bottom: 1px dashed var(--line);
}

.svc-trades li i {
    width: 28px;
    height: 28px;
    border-radius: 6px;
    background: var(--paper);
    color: var(--champagne);
    display: grid;
    place-items: center;
    font-size: 12px;
    flex-shrink: 0;
    transition: 0.3s var(--ease);
}

.svc-trades li:hover i {
    background: var(--champagne);
    color: var(--ink);
    transform: rotate(-6deg);
}

@media (max-width: 900px) {
    .svc-tab-btn { padding: 18px 20px; font-size: 1.05rem; flex-direction: column; align-items: flex-start; gap: 4px; }
    .svc-panel-grid { grid-template-columns: 1fr; }
    .svc-panel-media { min-height: 240px; }
    .svc-panel-copy { padding: 36px 28px; }
    .svc-trades { grid-template-columns: 1fr; }
}

/* ---------- SECTORS BENTO — hover detail ---------- */
.sector-card {
    cursor: default;
}

.sector-card .sector-detail {
    margin: 0;
    color: var(--muted);
    font-size: 13px;
    line-height: 1.55;
    max-width: 28ch;
    opacity: 0;
    max-height: 0;
    overflow: hidden;
    transition: opacity 0.35s var(--ease), max-height 0.4s var(--ease), color 0.35s var(--ease);
}

.sector-card:hover .sector-detail {
    opacity: 1;
    max-height: 120px;
    color: rgba(245, 241, 232, 0.85);
}

/* ---------- INTERACTIVE TIMELINE ---------- */
.process-section {
    background: var(--ink);
    color: var(--paper-soft);
    position: relative;
    overflow: hidden;
}

.process-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 80% 10%, rgba(201, 161, 95, 0.12), transparent 50%);
    pointer-events: none;
}

.process-section .section-title { color: var(--paper-soft); }

.timeline {
    position: relative;
    margin-top: 48px;
}

.timeline-track {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0;
    position: relative;
}

.timeline-track::before {
    content: '';
    position: absolute;
    top: 32px;
    left: 10%;
    right: 10%;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(201, 161, 95, 0.4), transparent);
    z-index: 1;
}

.timeline-step {
    position: relative;
    text-align: center;
    padding: 0 14px;
    cursor: pointer;
    transition: 0.4s var(--ease);
}

.timeline-dot {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: rgba(245, 241, 232, 0.05);
    border: 1px solid rgba(245, 241, 232, 0.2);
    display: grid;
    place-items: center;
    margin: 0 auto 28px;
    position: relative;
    z-index: 2;
    transition: 0.4s var(--ease);
}

.timeline-dot span {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 1.1rem;
    color: var(--champagne-soft);
    transition: color 0.4s var(--ease);
}

.timeline-step:hover .timeline-dot,
.timeline-step.active .timeline-dot {
    background: var(--champagne);
    border-color: var(--champagne);
    transform: scale(1.06);
    box-shadow: 0 0 0 8px rgba(201, 161, 95, 0.12);
}

.timeline-step:hover .timeline-dot span,
.timeline-step.active .timeline-dot span {
    color: var(--ink);
}

.timeline-card h4 {
    color: var(--paper-soft);
    font-size: 1.1rem;
    margin-bottom: 10px;
    transition: color 0.3s var(--ease);
}

.timeline-card p {
    color: rgba(245, 241, 232, 0.7);
    font-size: 13.5px;
    line-height: 1.6;
    margin: 0;
}

.timeline-step:hover .timeline-card h4,
.timeline-step.active .timeline-card h4 { color: var(--champagne); }

@media (max-width: 900px) {
    .timeline-track { grid-template-columns: 1fr; gap: 28px; text-align: left; }
    .timeline-track::before { display: none; }
    .timeline-step { display: grid; grid-template-columns: 64px 1fr; gap: 20px; align-items: start; padding: 0; }
    .timeline-dot { margin: 0; }
    .timeline-card { text-align: left; }
}

/* ---------- COMPLIANCE SHOWCASE ---------- */
.compliance-section { background: var(--paper-soft); }

.compliance-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    align-items: stretch;
}

.comp-card {
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    padding: 40px 36px;
    transition: 0.45s var(--ease);
    position: relative;
    overflow: hidden;
}

.comp-card::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    height: 3px;
    width: 0;
    background: var(--champagne);
    transition: width 0.5s var(--ease);
}

.comp-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-md);
    border-color: rgba(201, 161, 95, 0.4);
}

.comp-card:hover::after { width: 100%; }

.comp-card.featured {
    background: var(--ink);
    color: var(--paper-soft);
    border-color: var(--ink);
    transform: translateY(-12px);
    box-shadow: var(--shadow-lg);
}

.comp-card.featured h4 { color: var(--paper-soft); }
.comp-card.featured p { color: rgba(245, 241, 232, 0.78); }
.comp-card.featured .comp-points li { color: var(--paper-soft); }
.comp-card.featured .comp-badge { background: linear-gradient(135deg, var(--champagne), #B98D49); color: var(--ink); }

.comp-badge {
    display: inline-flex;
    align-items: baseline;
    gap: 4px;
    padding: 12px 20px;
    background: var(--paper);
    border-radius: 12px;
    font-family: var(--font-display);
    margin-bottom: 28px;
    font-weight: 500;
}

.comp-iso {
    font-size: 14px;
    letter-spacing: 0.15em;
    color: var(--muted);
    font-style: italic;
}

.comp-card.featured .comp-iso { color: rgba(11, 18, 32, 0.6); }

.comp-code {
    font-size: 1.75rem;
    color: var(--navy);
    line-height: 1;
    font-weight: 600;
    letter-spacing: -0.02em;
}

.comp-card.featured .comp-code { color: var(--ink); }

.comp-year {
    font-size: 13px;
    color: var(--muted);
}

.comp-card.featured .comp-year { color: rgba(11, 18, 32, 0.65); }

.comp-card h4 {
    font-size: 1.4rem;
    margin-bottom: 14px;
}

.comp-card p {
    color: var(--muted);
    font-size: 15px;
    line-height: 1.65;
    margin-bottom: 24px;
}

.comp-points {
    border-top: 1px solid rgba(244, 218, 175, 0.18);
    padding-top: 18px;
}

.comp-card:not(.featured) .comp-points { border-top-color: var(--line); }

.comp-points li {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 8px 0;
    font-size: 13.5px;
    font-weight: 500;
    color: var(--ink);
}

.comp-points li i { color: var(--champagne); font-size: 11px; }

@media (max-width: 900px) {
    .compliance-grid { grid-template-columns: 1fr; }
    .comp-card.featured { transform: none; }
}

/* ---------- WORK FILTERS ---------- */
.work-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 48px;
    justify-content: center;
}

.work-filter {
    padding: 11px 24px;
    background: transparent;
    border: 1px solid var(--line-strong);
    border-radius: 999px;
    font-family: var(--font-sans);
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.06em;
    color: var(--muted);
    cursor: pointer;
    transition: 0.3s var(--ease);
}

.work-filter:hover {
    color: var(--ink);
    border-color: var(--ink);
}

.work-filter.active {
    background: var(--ink);
    color: var(--paper-soft);
    border-color: var(--ink);
}

.work-item.is-hidden {
    display: none !important;
}

.work-item .work-meta {
    display: block;
    margin-top: 8px;
    font-size: 12px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: rgba(245, 241, 232, 0.7);
}

/* ---------- COVERAGE / MAP ---------- */
.coverage-section { background: var(--paper); }

.coverage-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
}

.coverage-list {
    margin: 28px 0 36px;
}

.coverage-list li {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 14px 0;
    border-bottom: 1px solid var(--line);
    font-size: 15px;
    line-height: 1.55;
}

.coverage-list li i {
    color: var(--champagne);
    margin-top: 4px;
    font-size: 15px;
}

.coverage-list strong {
    color: var(--ink);
    font-weight: 600;
    margin-right: 4px;
}

.coverage-map {
    position: relative;
}

.map-card {
    position: relative;
    aspect-ratio: 4/5;
    background: linear-gradient(135deg, var(--paper-soft), var(--white));
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-md);
    padding: 32px;
    overflow: hidden;
}

.qatar-outline {
    position: absolute;
    inset: 8% 12%;
    width: 76%;
    height: 84%;
}

.map-pins {
    position: absolute;
    inset: 0;
    z-index: 2;
}

.pin {
    position: absolute;
    left: var(--x);
    top: var(--y);
    transform: translate(-50%, -50%);
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: var(--champagne);
    box-shadow: 0 0 0 0 rgba(201, 161, 95, 0.6);
    animation: pinPulse 2.4s ease-out infinite;
    cursor: pointer;
}

.pin::after {
    content: attr(data-label);
    position: absolute;
    left: 50%;
    bottom: calc(100% + 8px);
    transform: translateX(-50%);
    background: var(--ink);
    color: var(--paper-soft);
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 5px 10px;
    border-radius: 4px;
    white-space: nowrap;
    opacity: 0;
    transition: 0.3s var(--ease);
    pointer-events: none;
}

.pin:hover::after { opacity: 1; transform: translateX(-50%) translateY(-2px); }

.pin-primary {
    width: 18px;
    height: 18px;
    background: var(--navy);
    border: 3px solid var(--champagne);
    box-shadow: 0 0 0 0 rgba(15, 35, 66, 0.45);
    z-index: 2;
}

@keyframes pinPulse {
    0% { box-shadow: 0 0 0 0 rgba(201, 161, 95, 0.55); }
    70% { box-shadow: 0 0 0 14px rgba(201, 161, 95, 0); }
    100% { box-shadow: 0 0 0 0 rgba(201, 161, 95, 0); }
}

.map-legend {
    position: absolute;
    bottom: 24px;
    left: 24px;
    right: 24px;
    display: flex;
    justify-content: space-between;
    gap: 12px;
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--muted);
    z-index: 3;
}

.legend-item { display: inline-flex; align-items: center; gap: 8px; }

.legend-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--champagne);
    display: inline-block;
}

.legend-dot-primary {
    background: var(--navy);
    border: 2px solid var(--champagne);
}

@media (max-width: 900px) {
    .coverage-grid { grid-template-columns: 1fr; gap: 48px; }
    .map-card { aspect-ratio: 1/1; }
}

/* ---------- FAQ ACCORDION ---------- */
.faq-section { background: var(--paper-soft); }

.faq-grid {
    display: grid;
    grid-template-columns: 0.85fr 1.15fr;
    gap: 80px;
    align-items: start;
}

.faq-intro h2 { margin-bottom: 20px; }

.faq-list { display: flex; flex-direction: column; gap: 12px; }

.faq-item {
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: 0.3s var(--ease);
}

.faq-item:hover {
    border-color: var(--line-strong);
}

.faq-item.active {
    border-color: var(--champagne);
    box-shadow: var(--shadow-sm);
}

.faq-q {
    width: 100%;
    background: transparent;
    border: none;
    padding: 24px 28px;
    text-align: left;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 24px;
    font-family: var(--font-display);
    font-size: 1.15rem;
    color: var(--ink);
    line-height: 1.35;
    transition: 0.3s var(--ease);
}

.faq-q:hover { color: var(--champagne); }

.faq-q i {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--paper);
    color: var(--champagne);
    display: grid;
    place-items: center;
    font-size: 13px;
    flex-shrink: 0;
    transition: 0.4s var(--ease);
}

.faq-item.active .faq-q i {
    background: var(--champagne);
    color: var(--ink);
    transform: rotate(45deg);
}

.faq-a {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.5s var(--ease);
}

.faq-item.active .faq-a { max-height: 320px; }

.faq-a p {
    padding: 0 28px 26px;
    margin: 0;
    color: var(--muted);
    font-size: 15px;
    line-height: 1.7;
}

@media (max-width: 900px) {
    .faq-grid { grid-template-columns: 1fr; gap: 40px; }
    .faq-q { font-size: 1.05rem; padding: 20px 22px; }
}

/* ---------- INSIGHTS PREVIEW ---------- */
.insights-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 24px;
    margin-bottom: 56px;
    flex-wrap: wrap;
}

.insights-head h2 { margin-bottom: 0; }

.insights-preview {
    grid-template-columns: repeat(3, 1fr);
}

@media (max-width: 900px) {
    .insights-head { align-items: flex-start; }
    .insights-preview { grid-template-columns: 1fr; }
}

/* ---------- ENHANCED CTA ---------- */
.cta-inner {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 64px;
    align-items: center;
}

.cta-actions {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
}

.cta-badges {
    display: grid;
    gap: 14px;
}

.cta-badge {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 18px 22px;
    background: rgba(245, 241, 232, 0.04);
    border: 1px solid rgba(245, 241, 232, 0.1);
    border-radius: var(--radius-sm);
    color: var(--paper-soft);
    font-size: 13px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    transition: 0.35s var(--ease);
}

.cta-badge i {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--champagne);
    color: var(--ink);
    display: grid;
    place-items: center;
    font-size: 14px;
    flex-shrink: 0;
}

.cta-badge:hover {
    background: rgba(201, 161, 95, 0.1);
    border-color: rgba(201, 161, 95, 0.5);
    transform: translateX(4px);
}

@media (max-width: 900px) {
    .cta-inner { grid-template-columns: 1fr; gap: 40px; }
}

/* =========================================================
   PREMIUM INNER PAGES — Hero, Milestones, Culture, etc.
   ========================================================= */

/* ---------- RICH PAGE HERO ---------- */
.page-hero-rich {
    padding: clamp(80px, 10vw, 120px) 0 clamp(60px, 8vw, 100px);
    position: relative;
    overflow: hidden;
}

.page-hero-rich::before {
    content: '';
    position: absolute;
    top: -120px;
    right: -120px;
    width: 360px;
    height: 360px;
    background: radial-gradient(circle, rgba(201, 161, 95, 0.18), transparent 65%);
    pointer-events: none;
}

.page-hero-grid {
    display: grid;
    grid-template-columns: 1.2fr 0.95fr;
    gap: 72px;
    align-items: center;
}

.page-hero-copy h1 {
    font-size: clamp(2.5rem, 5.5vw, 4.5rem);
    line-height: 1;
    letter-spacing: -0.035em;
    margin-bottom: 24px;
    max-width: 16ch;
}

.page-hero-lede {
    font-size: 1.15rem;
    line-height: 1.65;
    color: var(--muted);
    max-width: 56ch;
    margin-bottom: 28px;
}

.page-hero-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 24px;
    font-size: 13px;
    letter-spacing: 0.06em;
    color: var(--muted);
    padding-top: 24px;
    border-top: 1px solid var(--line);
}

.page-hero-meta span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.page-hero-meta i { color: var(--champagne); font-size: 13px; }

.page-hero-media {
    position: relative;
    aspect-ratio: 4/5;
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
}

.page-hero-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 1.2s var(--ease);
}

.page-hero-media:hover img { transform: scale(1.04); }

.hero-media-tag {
    position: absolute;
    bottom: 24px;
    left: 24px;
    right: 24px;
    background: rgba(11, 18, 32, 0.55);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    color: var(--paper-soft);
    padding: 14px 18px;
    border-radius: var(--radius-sm);
    font-family: var(--font-display);
    font-style: italic;
    font-size: 1rem;
    border-left: 3px solid var(--champagne);
}

.hero-media-tag i { color: var(--champagne); margin-right: 8px; }

@media (max-width: 900px) {
    .page-hero-grid { grid-template-columns: 1fr; gap: 40px; }
    .page-hero-media { aspect-ratio: 4/3; }
}

/* ---------- MILESTONES ---------- */
.milestones {
    position: relative;
    margin: 0;
    padding: 0;
    list-style: none;
}

.milestones::before {
    content: '';
    position: absolute;
    left: 110px;
    top: 12px;
    bottom: 12px;
    width: 2px;
    background: linear-gradient(180deg, var(--champagne), var(--line));
}

.milestone {
    display: grid;
    grid-template-columns: 130px 1fr;
    gap: 40px;
    align-items: flex-start;
    padding: 24px 0;
    position: relative;
}

.milestone-year {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 1.5rem;
    color: var(--navy);
    text-align: right;
    padding-right: 20px;
    line-height: 1.1;
    position: relative;
}

.milestone-year::after {
    content: '';
    position: absolute;
    right: -7px;
    top: 8px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--paper-soft);
    border: 3px solid var(--champagne);
    z-index: 2;
    transition: 0.3s var(--ease);
}

.milestone:hover .milestone-year::after {
    background: var(--champagne);
    transform: scale(1.2);
    box-shadow: 0 0 0 6px rgba(201, 161, 95, 0.18);
}

.milestone-today .milestone-year { color: var(--champagne); }
.milestone-today .milestone-year::after { background: var(--champagne); box-shadow: 0 0 0 6px rgba(201, 161, 95, 0.2); }

.milestone-body {
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    padding: 24px 28px;
    transition: 0.35s var(--ease);
}

.milestone:hover .milestone-body {
    transform: translateX(6px);
    box-shadow: var(--shadow-md);
    border-color: var(--champagne);
}

.milestone-body h4 { font-size: 1.25rem; margin-bottom: 8px; }
.milestone-body p { color: var(--muted); margin: 0; line-height: 1.65; font-size: 15px; }

@media (max-width: 700px) {
    .milestones::before { left: 14px; }
    .milestone { grid-template-columns: 1fr; gap: 12px; padding-left: 36px; }
    .milestone-year { text-align: left; padding-right: 0; }
    .milestone-year::after { left: -28px; right: auto; }
}

/* ---------- VALUES GRID ---------- */
.values-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 16px;
    margin-top: 64px;
}

.value-card {
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    padding: 32px 24px;
    text-align: center;
    transition: 0.35s var(--ease);
}

.value-card:hover {
    transform: translateY(-6px);
    border-color: var(--champagne);
    box-shadow: var(--shadow-md);
}

.value-icon {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--paper);
    color: var(--champagne);
    display: grid;
    place-items: center;
    margin: 0 auto 18px;
    font-size: 22px;
    transition: 0.4s var(--ease);
}

.value-card:hover .value-icon {
    background: var(--champagne);
    color: var(--ink);
    transform: rotate(-8deg) scale(1.05);
}

.value-card h4 { font-size: 1.05rem; margin-bottom: 6px; }
.value-card p { color: var(--muted); font-size: 13px; line-height: 1.55; margin: 0; }

@media (max-width: 900px) {
    .values-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
    .values-grid { grid-template-columns: 1fr; }
}

/* ---------- CULTURE GALLERY ---------- */
.culture-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-auto-rows: 220px;
    gap: 16px;
}

.culture-item {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-md);
    margin: 0;
    cursor: pointer;
}

.culture-tall { grid-row: span 2; }
.culture-wide { grid-column: span 2; }

.culture-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.9s var(--ease);
}

.culture-item:hover img { transform: scale(1.06); }

.culture-item::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 40%, rgba(11, 18, 32, 0.85));
    z-index: 1;
}

.culture-item figcaption {
    position: absolute;
    bottom: 20px;
    left: 22px;
    right: 22px;
    color: var(--paper-soft);
    z-index: 2;
    font-size: 13px;
    line-height: 1.5;
}

.culture-item figcaption span {
    display: block;
    font-family: var(--font-display);
    font-style: italic;
    font-size: 1.2rem;
    color: var(--champagne);
    margin-bottom: 4px;
}

@media (max-width: 900px) {
    .culture-grid { grid-template-columns: repeat(2, 1fr); }
    .culture-tall { grid-row: auto; }
    .culture-wide { grid-column: auto; }
}

/* ---------- PARTNERS GRID — premium logo tiles ---------- */
.partners-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 14px;
}

.partner-tile {
    --brand: var(--champagne);
    position: relative;
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    padding: 36px 20px 32px;
    text-align: center;
    transition: 0.5s var(--ease);
    cursor: default;
    overflow: hidden;
    isolation: isolate;
    min-height: 120px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
}

.partner-tile::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--brand);
    transform: scaleX(0.35);
    transform-origin: center;
    transition: transform 0.5s var(--ease);
    opacity: 0.85;
}

.partner-tile::after {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 50% 100%, color-mix(in srgb, var(--brand) 14%, transparent), transparent 70%);
    opacity: 0;
    transition: opacity 0.5s var(--ease);
    z-index: -1;
}

.partner-tile:hover {
    transform: translateY(-4px);
    border-color: var(--brand);
    box-shadow: 0 16px 44px rgba(11, 18, 32, 0.08);
}

.partner-tile:hover::before { transform: scaleX(1); }
.partner-tile:hover::after { opacity: 1; }

.partner-name {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 1.05rem;
    letter-spacing: -0.01em;
    color: var(--ink);
    line-height: 1.1;
}

.partner-tag {
    font-size: 10px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--brand);
    font-weight: 600;
    opacity: 0.85;
}

.partner-mark {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    background: var(--brand);
    color: var(--white);
    display: grid;
    place-items: center;
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 1rem;
    letter-spacing: 0;
    margin-bottom: 4px;
    transition: transform 0.5s var(--ease);
    box-shadow: 0 6px 18px color-mix(in srgb, var(--brand) 30%, transparent);
}

.partner-tile:hover .partner-mark {
    transform: rotate(-6deg) scale(1.06);
}

@media (max-width: 1100px) {
    .partners-grid { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 700px) {
    .partners-grid { grid-template-columns: repeat(2, 1fr); }
    .partner-tile { min-height: 100px; padding: 24px 14px; }
}

/* ---------- QATAR MAP — admin-region style ---------- */
.map-card {
    aspect-ratio: 1/1;
    background:
        radial-gradient(circle at 30% 25%, rgba(173, 216, 230, 0.55), rgba(173, 216, 230, 0.85) 40%, rgba(140, 195, 220, 0.95));
    overflow: hidden;
}

.map-card .qatar-svg {
    position: absolute;
    inset: 4% 8%;
    width: 84%;
    height: 92%;
    z-index: 1;
}

.map-card .qatar-land {
    fill: #FFFFFF;
    stroke: rgba(120, 140, 160, 0.55);
    stroke-width: 1.4;
    stroke-linejoin: round;
    filter: drop-shadow(0 6px 16px rgba(15, 35, 66, 0.18));
}

.map-card .qatar-region {
    fill: none;
    stroke: rgba(120, 140, 160, 0.55);
    stroke-width: 0.9;
    stroke-linejoin: round;
}

.map-card .qatar-saudi {
    fill: rgba(220, 220, 220, 0.55);
    stroke: rgba(120, 140, 160, 0.45);
    stroke-width: 1;
    stroke-dasharray: 4 3;
}

.map-card .qatar-label {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 11px;
    fill: var(--ink);
    pointer-events: none;
}

.map-compass {
    position: absolute;
    top: 18px;
    right: 18px;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    border: 1px solid var(--line-strong);
    display: grid;
    place-items: center;
    font-family: var(--font-display);
    font-style: italic;
    font-size: 12px;
    color: var(--muted);
    background: var(--white);
    z-index: 3;
}

.map-compass::before {
    content: '';
    position: absolute;
    top: 2px;
    left: 50%;
    transform: translateX(-50%);
    width: 2px;
    height: 6px;
    background: var(--champagne);
}

.map-scale {
    position: absolute;
    bottom: 72px;
    left: 22px;
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 10px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--muted-soft);
    z-index: 3;
}

.map-scale::before {
    content: '';
    width: 48px;
    height: 2px;
    background: linear-gradient(90deg, var(--ink) 50%, transparent 50%);
    background-size: 12px 2px;
}

/* Pin label styling — red dots with always-visible city labels */
.pin {
    width: 14px;
    height: 14px;
    background: radial-gradient(circle at 30% 30%, #ff5252, #c62828);
    box-shadow: 0 2px 6px rgba(180, 0, 0, 0.45), inset 0 -2px 3px rgba(0,0,0,0.25);
    z-index: 2;
}

.pin::before {
    content: '';
    position: absolute;
    inset: -6px;
    border-radius: 50%;
    background: rgba(220, 60, 60, 0.32);
    animation: pinPulse 2.4s ease-out infinite;
    z-index: -1;
}

.pin::after {
    content: attr(data-label);
    position: absolute;
    left: 50%;
    bottom: calc(100% + 6px);
    transform: translateX(-50%);
    font-family: var(--font-display);
    font-style: italic;
    font-size: 12px;
    color: var(--ink);
    background: transparent;
    padding: 0;
    border-radius: 0;
    white-space: nowrap;
    opacity: 1;
    pointer-events: none;
    text-shadow: 0 1px 2px rgba(255,255,255,0.95), 0 0 6px rgba(255,255,255,0.6);
    letter-spacing: 0;
    text-transform: none;
}

.pin:hover::after {
    color: var(--navy);
    transform: translateX(-50%) translateY(-2px);
}

.pin-primary {
    width: 18px;
    height: 18px;
    background: radial-gradient(circle at 30% 30%, #ffd56a, var(--champagne));
    border: 3px solid var(--navy);
    box-shadow: 0 0 0 3px rgba(15, 35, 66, 0.15), 0 4px 10px rgba(15, 35, 66, 0.4);
    z-index: 3;
}

.pin-primary::before {
    background: rgba(15, 35, 66, 0.25);
    animation-duration: 3s;
}

.pin-primary::after {
    color: var(--navy);
    font-weight: 600;
    font-style: normal;
    font-family: var(--font-sans);
    font-size: 11px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

@keyframes pinPulse {
    0% { transform: scale(0.8); opacity: 0.8; }
    100% { transform: scale(2.2); opacity: 0; }
}

/* =========================================================
   PREMIUM ANIMATIONS — aesthetic layer
   ========================================================= */

@keyframes float-soft {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-8px); }
}

@keyframes sheen {
    0% { background-position: -200% 50%; }
    100% { background-position: 200% 50%; }
}

@keyframes gradient-drift {
    0%, 100% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
}

@keyframes halo-pulse {
    0%, 100% { opacity: 0.28; transform: scale(1); }
    50% { opacity: 0.55; transform: scale(1.06); }
}

/* Staggered reveal delays for grid items */
.reveal-stagger > * {
    opacity: 0;
    transform: translateY(18px);
    transition: 0.8s var(--ease);
}

.reveal-stagger.in > *:nth-child(1) { transition-delay: 0.00s; }
.reveal-stagger.in > *:nth-child(2) { transition-delay: 0.06s; }
.reveal-stagger.in > *:nth-child(3) { transition-delay: 0.12s; }
.reveal-stagger.in > *:nth-child(4) { transition-delay: 0.18s; }
.reveal-stagger.in > *:nth-child(5) { transition-delay: 0.24s; }
.reveal-stagger.in > *:nth-child(6) { transition-delay: 0.30s; }
.reveal-stagger.in > *:nth-child(7) { transition-delay: 0.36s; }
.reveal-stagger.in > *:nth-child(8) { transition-delay: 0.42s; }
.reveal-stagger.in > *:nth-child(9) { transition-delay: 0.48s; }
.reveal-stagger.in > *:nth-child(10) { transition-delay: 0.54s; }
.reveal-stagger.in > *:nth-child(11) { transition-delay: 0.60s; }
.reveal-stagger.in > *:nth-child(12) { transition-delay: 0.66s; }
.reveal-stagger.in > *:nth-child(n+13) { transition-delay: 0.72s; }

.reveal-stagger.in > * { opacity: 1; transform: translateY(0); }

/* Float on hover for media */
.float-on-hover:hover img,
.float-on-hover:hover .work-img {
    animation: float-soft 3s ease-in-out infinite;
}

/* Shimmer for accent bars */
.shimmer-bar {
    background: linear-gradient(90deg,
        transparent 0%,
        color-mix(in srgb, var(--champagne) 40%, transparent) 50%,
        transparent 100%);
    background-size: 200% 100%;
    animation: sheen 6s linear infinite;
}

/* Stats strip — animated gradient underline + micro-float icons */
.stats-animated .stat-icon {
    animation: float-soft 4s ease-in-out infinite;
    animation-delay: calc(var(--i, 0) * 0.4s);
}

.stats-animated .stat:nth-child(1) .stat-icon { --i: 0; }
.stats-animated .stat:nth-child(2) .stat-icon { --i: 1; }
.stats-animated .stat:nth-child(3) .stat-icon { --i: 2; }
.stats-animated .stat:nth-child(4) .stat-icon { --i: 3; }

/* Float stat card — gentle hover lift */
.hero-float-stats {
    transition: transform 0.5s var(--ease), box-shadow 0.5s var(--ease);
}
.hero-float-stats:hover {
    transform: translateY(-4px);
    box-shadow: 0 32px 80px rgba(11, 18, 32, 0.18);
}

/* Work items — richer caption + progress */
.work-item .caption h4 { transition: color 0.4s var(--ease); }
.work-item:hover .caption h4 { color: var(--champagne); }
.work-item::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, transparent, rgba(201,161,95,0.16), transparent);
    transform: translateX(-100%);
    z-index: 2;
    transition: transform 0.9s var(--ease);
}
.work-item:hover::before { transform: translateX(100%); }

.work-location {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--champagne-soft);
    margin-top: 8px;
}

.work-location i { font-size: 10px; }

/* Promise card gradient shift */
.promise-card .promise-icon {
    background-size: 200% 200%;
    animation: gradient-drift 8s ease-in-out infinite;
}

/* ---------- CARD TAGS ---------- */
.card-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 16px;
}

.card-tags li {
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--muted);
    padding: 4px 10px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: var(--paper-soft);
}

/* ---------- MOBILISATION PIPELINE ---------- */
.pipeline {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 0;
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    overflow: hidden;
    background: var(--white);
}

.pipeline-step {
    padding: 36px 24px;
    border-right: 1px solid var(--line);
    position: relative;
    transition: 0.4s var(--ease);
    background: var(--white);
}

.pipeline-step:last-child { border-right: none; }

.pipeline-step:hover {
    background: var(--paper-soft);
    transform: translateY(-3px);
}

.pipeline-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    background: linear-gradient(140deg, var(--paper), var(--paper-soft));
    color: var(--champagne);
    display: grid;
    place-items: center;
    font-size: 18px;
    margin-bottom: 20px;
    transition: 0.4s var(--ease);
}

.pipeline-step:hover .pipeline-icon {
    background: var(--champagne);
    color: var(--ink);
    transform: rotate(-6deg);
}

.pipeline-step h4 {
    font-size: 1.05rem;
    margin-bottom: 8px;
}

.pipeline-step p {
    font-size: 13px;
    color: var(--muted);
    line-height: 1.6;
    margin: 0;
}

@media (max-width: 1100px) {
    .pipeline { grid-template-columns: repeat(3, 1fr); }
    .pipeline-step:nth-child(3n) { border-right: none; }
    .pipeline-step:nth-child(n+4) { border-top: 1px solid var(--line); }
    /* For 5-step pipelines, ensure clean borders */
}
@media (max-width: 700px) {
    .pipeline { grid-template-columns: 1fr; }
    .pipeline-step { border-right: none; border-top: 1px solid var(--line); }
    .pipeline-step:first-child { border-top: none; }
}

/* ---------- STANDARDS ---------- */
.standards-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
}

.standard-card {
    position: relative;
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    padding: 36px 32px;
    transition: 0.35s var(--ease);
    overflow: hidden;
}

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

.standard-num {
    position: absolute;
    top: 24px;
    right: 28px;
    font-family: var(--font-display);
    font-style: italic;
    font-size: 1.3rem;
    color: var(--line-strong);
    transition: 0.35s var(--ease);
}

.standard-card:hover .standard-num { color: var(--champagne); }

.standard-card h4 {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 1.25rem;
    margin-bottom: 12px;
}

.standard-card h4 i { color: var(--champagne); font-size: 1rem; }

.standard-card p {
    color: var(--muted);
    font-size: 15px;
    line-height: 1.65;
    margin: 0;
}

@media (max-width: 700px) {
    .standards-grid { grid-template-columns: 1fr; }
}

/* ---------- CASE SECTION ---------- */
.case-section { background: var(--ink); color: var(--paper-soft); }

.case-section .eyebrow { color: var(--champagne-soft); }
.case-section .eyebrow::before { background: var(--champagne); }
.case-section h2 { color: var(--paper-soft); }
.case-section .lede { color: rgba(245, 241, 232, 0.78); }

.case-grid {
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    gap: 64px;
    align-items: center;
}

.case-media {
    position: relative;
    aspect-ratio: 4/5;
    border-radius: var(--radius-md);
    background-size: cover;
    background-position: center;
    overflow: hidden;
}

.case-media::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 50%, rgba(11, 18, 32, 0.5));
}

.case-label {
    position: absolute;
    top: 24px;
    left: 24px;
    z-index: 2;
    background: rgba(11, 18, 32, 0.55);
    padding: 8px 14px;
    border-radius: 999px;
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--paper-soft);
    border: 1px solid rgba(201, 161, 95, 0.35);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.case-metrics {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin: 32px 0 8px;
    padding: 28px 0;
    border-top: 1px solid rgba(245, 241, 232, 0.12);
    border-bottom: 1px solid rgba(245, 241, 232, 0.12);
}

.case-metric strong {
    display: block;
    font-family: var(--font-display);
    font-size: 2rem;
    color: var(--champagne);
    line-height: 1;
    margin-bottom: 6px;
}

.case-metric span {
    font-size: 11px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: rgba(245, 241, 232, 0.7);
}

@media (max-width: 900px) {
    .case-grid { grid-template-columns: 1fr; gap: 40px; }
    .case-metrics { grid-template-columns: repeat(2, 1fr); }
}

/* ---------- SENIORITY LADDER ---------- */
.ladder {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}

.ladder-step {
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    padding: 36px 28px;
    transition: 0.4s var(--ease);
    position: relative;
}

.ladder-step:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-md);
    border-color: var(--champagne);
}

.ladder-exec {
    background: var(--ink);
    color: var(--paper-soft);
    border-color: var(--ink);
}

.ladder-exec h4, .ladder-exec .ladder-tag { color: var(--paper-soft); }
.ladder-exec p { color: rgba(245, 241, 232, 0.78); }
.ladder-exec .ladder-points li { color: var(--paper-soft); border-color: rgba(245, 241, 232, 0.1); }
.ladder-exec .ladder-tag { background: rgba(201, 161, 95, 0.2); color: var(--champagne); }

.ladder-tag {
    display: inline-block;
    padding: 5px 12px;
    background: var(--paper);
    color: var(--champagne);
    border-radius: 999px;
    font-size: 10px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    font-weight: 600;
    margin-bottom: 18px;
}

.ladder-step h4 { font-size: 1.2rem; margin-bottom: 12px; }
.ladder-step p { color: var(--muted); font-size: 14px; line-height: 1.6; margin-bottom: 18px; }

.ladder-points li {
    padding: 10px 0;
    border-top: 1px solid var(--line);
    font-size: 13px;
    color: var(--ink);
}

.ladder-points li:first-child { border-top: none; padding-top: 0; }

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

/* ---------- ENGAGEMENT MODELS ---------- */
.models-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

.model-card {
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    padding: 40px 36px;
    position: relative;
    transition: 0.4s var(--ease);
}

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

.model-featured {
    background: var(--ink);
    color: var(--paper-soft);
    border-color: var(--ink);
    transform: translateY(-12px);
    box-shadow: var(--shadow-lg);
}

.model-featured h3, .model-featured .model-rate { color: var(--paper-soft); }
.model-featured > p { color: rgba(245, 241, 232, 0.78); }
.model-featured .model-features li { color: var(--paper-soft); }
.model-featured .model-tag { background: var(--champagne); color: var(--ink); }

.model-tag {
    position: absolute;
    top: -12px;
    left: 28px;
    padding: 6px 14px;
    background: var(--paper);
    color: var(--champagne);
    border-radius: 999px;
    font-size: 10px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    font-weight: 600;
    border: 1px solid var(--line);
}

.model-card h3 { font-size: 1.45rem; margin-bottom: 8px; }

.model-rate {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 0.95rem;
    color: var(--champagne);
    margin-bottom: 18px;
}

.model-card > p {
    color: var(--muted);
    font-size: 14.5px;
    line-height: 1.65;
    margin-bottom: 24px;
}

.model-features {
    border-top: 1px solid rgba(244, 218, 175, 0.18);
    padding-top: 18px;
}

.model-card:not(.model-featured) .model-features { border-top-color: var(--line); }

.model-features li {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 8px 0;
    font-size: 13.5px;
    color: var(--ink);
}

.model-features li i { color: var(--champagne); font-size: 11px; }

@media (max-width: 1000px) {
    .models-grid { grid-template-columns: 1fr; }
    .model-featured { transform: none; }
}

/* ---------- INDUSTRY TAGS ---------- */
.industry-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: center;
}

.industry-tag {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 12px 22px;
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: 999px;
    font-size: 14px;
    color: var(--ink);
    transition: 0.35s var(--ease);
    cursor: default;
}

.industry-tag i { color: var(--champagne); font-size: 13px; transition: 0.3s var(--ease); }

.industry-tag:hover {
    background: var(--ink);
    color: var(--paper-soft);
    border-color: var(--ink);
    transform: translateY(-2px);
}

.industry-tag:hover i { color: var(--champagne); }

/* ---------- COMPARE TABLE (Why Us) ---------- */
.compare-table {
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}

.compare-head, .compare-row {
    display: grid;
    grid-template-columns: 1.2fr 1fr 1.2fr;
    align-items: center;
}

.compare-head {
    background: var(--ink);
    color: var(--paper-soft);
    padding: 0;
}

.compare-head .compare-col {
    padding: 22px 28px;
    font-size: 12px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    font-weight: 600;
}

.compare-head .compare-col-strong { color: var(--champagne); }

.compare-row {
    border-top: 1px solid var(--line);
    transition: background 0.3s var(--ease);
}

.compare-row:hover { background: var(--paper-soft); }

.compare-col {
    padding: 22px 28px;
    font-size: 14.5px;
    line-height: 1.55;
}

.compare-col:first-child {
    font-weight: 600;
    color: var(--ink);
    border-right: 1px solid var(--line);
}

.compare-col-weak {
    color: var(--muted);
    font-style: italic;
    border-right: 1px solid var(--line);
}

.compare-col-strong {
    color: var(--ink);
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 10px;
}

.compare-col-strong i {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: var(--champagne);
    color: var(--ink);
    display: grid;
    place-items: center;
    font-size: 10px;
    flex-shrink: 0;
}

.differentiators-rich .diff-row { padding: 56px 0; }

@media (max-width: 800px) {
    .compare-head, .compare-row { grid-template-columns: 1fr; }
    .compare-col, .compare-col:first-child, .compare-col-weak { border-right: none; }
    .compare-col { padding: 16px 22px; }
    .compare-col:first-child { background: var(--paper); padding-bottom: 8px; padding-top: 18px; }
    .compare-head { display: none; }
}

/* ---------- DEPARTMENTS ---------- */
.dept-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}

.dept-card {
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    padding: 32px 28px;
    transition: 0.4s var(--ease);
    position: relative;
    overflow: hidden;
}

.dept-card::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    height: 3px;
    width: 0;
    background: var(--champagne);
    transition: width 0.5s var(--ease);
}

.dept-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-md);
    border-color: rgba(201, 161, 95, 0.4);
}

.dept-card:hover::after { width: 100%; }

.dept-icon {
    width: 52px;
    height: 52px;
    border-radius: 12px;
    background: linear-gradient(140deg, var(--champagne), var(--champagne-soft));
    color: var(--ink);
    display: grid;
    place-items: center;
    font-size: 20px;
    margin-bottom: 20px;
    transition: 0.4s var(--ease);
}

.dept-card:hover .dept-icon { transform: rotate(-8deg) scale(1.06); }

.dept-card h4 { font-size: 1.15rem; margin-bottom: 8px; }
.dept-card p { color: var(--muted); font-size: 14px; line-height: 1.55; margin-bottom: 18px; }

.dept-card a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 500;
    color: var(--ink);
    border-bottom: 1px solid var(--line-strong);
    padding-bottom: 4px;
    transition: 0.3s var(--ease);
}

.dept-card a:hover {
    color: var(--champagne);
    border-color: var(--champagne);
    gap: 12px;
}

.dept-card a i { font-size: 10px; }

@media (max-width: 1000px) { .dept-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 500px) { .dept-grid { grid-template-columns: 1fr; } }

/* ---------- CONTACT FORM ENHANCEMENTS ---------- */
.form-sub {
    color: var(--muted);
    margin: -16px 0 24px;
    font-size: 14.5px;
}

.form-note {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px 14px;
    margin: 0 0 22px;
    background: var(--paper-soft);
    border-left: 3px solid var(--champagne);
    border-radius: var(--radius-sm);
    font-size: 13px;
    color: var(--muted);
    line-height: 1.5;
}

.form-note i { color: var(--champagne); font-size: 13px; margin-top: 2px; }

.form-alert {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 16px 18px;
    margin: 0 0 22px;
    border-radius: var(--radius-sm);
    font-size: 14px;
    line-height: 1.5;
    border: 1px solid;
}

.form-alert i { font-size: 16px; margin-top: 2px; flex-shrink: 0; }

.form-alert-success {
    background: rgba(46, 125, 50, 0.06);
    border-color: rgba(46, 125, 50, 0.3);
    color: #2e7d32;
}

.form-alert-error {
    background: rgba(214, 56, 56, 0.06);
    border-color: rgba(214, 56, 56, 0.3);
    color: #b91c1c;
}

.form-alert-error a { color: inherit; text-decoration: underline; }

.pp-honeypot {
    position: absolute !important;
    left: -9999px !important;
    width: 1px !important;
    height: 1px !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

/* =============================================================
   CAREER PORTAL — public + candidate + admin
   ============================================================= */

/* ---------- Career hero ---------- */
.career-hero {
    position: relative;
    padding: clamp(80px, 10vw, 130px) 0 clamp(60px, 8vw, 100px);
    background:
        linear-gradient(135deg, rgba(11,18,32,0.92), rgba(15,35,66,0.85)),
        url('https://images.pexels.com/photos/1216544/pexels-photo-1216544.jpeg?auto=compress&cs=tinysrgb&w=1920') center/cover no-repeat;
    color: var(--paper-soft);
    overflow: hidden;
}

.career-hero::after {
    content: '';
    position: absolute;
    top: -100px;
    right: -100px;
    width: 360px;
    height: 360px;
    background: radial-gradient(circle, rgba(201,161,95,0.22), transparent 65%);
    pointer-events: none;
}

.career-hero h1 { color: var(--paper-soft); font-size: clamp(2.5rem, 6vw, 4.6rem); max-width: 16ch; }
.career-hero .career-hero-lede { color: rgba(245,241,232,0.85); max-width: 56ch; font-size: 1.15rem; line-height: 1.65; margin: 24px 0 36px; }
.career-hero .eyebrow { color: var(--champagne-soft); }
.career-hero .eyebrow::before { background: var(--champagne); }

.career-hero-actions { display: flex; gap: 14px; flex-wrap: wrap; }

.career-hero-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    margin-top: 56px;
    padding-top: 36px;
    border-top: 1px solid rgba(245,241,232,0.12);
}
.career-hero-stat strong {
    display: block;
    font-family: var(--font-display);
    font-size: 2.2rem;
    color: var(--champagne);
    line-height: 1;
    margin-bottom: 6px;
}
.career-hero-stat span {
    font-size: 11px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: rgba(245,241,232,0.7);
}
@media (max-width: 700px) { .career-hero-stats { grid-template-columns: repeat(2, 1fr); } }

/* ---------- Job filters bar ---------- */
.job-filters-bar {
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    padding: 24px;
    box-shadow: var(--shadow-sm);
    display: grid;
    grid-template-columns: 1.5fr 1fr 1fr 1fr auto;
    gap: 12px;
    align-items: center;
    margin-bottom: 32px;
}
.job-filters-bar .field {
    display: flex; align-items: center; gap: 10px;
    background: var(--paper-soft); border: 1px solid var(--line);
    border-radius: var(--radius-sm); padding: 10px 14px;
}
.job-filters-bar .field i { color: var(--champagne); font-size: 13px; }
.job-filters-bar input,
.job-filters-bar select {
    border: none; background: transparent; outline: none;
    font-family: var(--font-sans); font-size: 14px; color: var(--ink); flex: 1; min-width: 0;
}
.job-filters-bar .btn { padding: 13px 24px; }
@media (max-width: 1000px) { .job-filters-bar { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px)  { .job-filters-bar { grid-template-columns: 1fr; } }

/* ---------- Job list layout ---------- */
.career-grid {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 36px;
    align-items: flex-start;
}
.career-side {
    position: sticky; top: 120px;
    background: var(--white); border: 1px solid var(--line);
    border-radius: var(--radius-md); padding: 28px;
}
.career-side h4 {
    font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
    color: var(--champagne); margin-bottom: 16px; font-family: var(--font-sans); font-weight: 600;
}
.facet { margin-bottom: 24px; padding-bottom: 22px; border-bottom: 1px solid var(--line); }
.facet:last-child { border-bottom: none; padding-bottom: 0; margin-bottom: 0; }
.facet h5 { font-family: var(--font-sans); font-size: 13px; margin: 0 0 12px; color: var(--ink); font-weight: 600; }
.facet label {
    display: flex; justify-content: space-between; align-items: center; gap: 10px;
    padding: 8px 0; font-size: 13.5px; color: var(--muted); cursor: pointer; transition: 0.2s var(--ease);
}
.facet label:hover { color: var(--ink); }
.facet label .count { color: var(--muted-soft); font-size: 12px; }
.facet input[type="checkbox"], .facet input[type="radio"] { accent-color: var(--champagne); margin-right: 6px; }
.facet .range-inputs { display: flex; gap: 8px; }
.facet .range-inputs input { width: 100%; padding: 8px 10px; border: 1px solid var(--line); border-radius: 6px; font-size: 13px; }

.results-head {
    display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: 12px; margin-bottom: 20px;
}
.results-head .results-count { color: var(--muted); font-size: 14px; }
.results-head .results-count strong { color: var(--ink); font-weight: 600; }
.results-head .sort-by { display: flex; align-items: center; gap: 10px; font-size: 13px; color: var(--muted); }
.results-head .sort-by select {
    border: 1px solid var(--line); background: var(--white); border-radius: 6px;
    padding: 8px 12px; font-family: var(--font-sans); font-size: 13px; color: var(--ink);
}

/* ---------- Job card ---------- */
.job-list { display: flex; flex-direction: column; gap: 16px; }
.job-card {
    position: relative;
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    padding: 26px 28px;
    transition: 0.35s var(--ease);
    overflow: hidden;
}
.job-card::before {
    content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--champagne);
    transform: scaleY(0); transform-origin: top; transition: transform 0.35s var(--ease);
}
.job-card:hover { transform: translateY(-2px); border-color: var(--line-strong); box-shadow: var(--shadow-md); }
.job-card:hover::before { transform: scaleY(1); }
.job-card.urgent { border-color: rgba(214, 56, 56, 0.4); background: linear-gradient(180deg, rgba(214,56,56,0.03), var(--white)); }
.job-card.urgent::before { background: #d63838; transform: scaleY(1); }

.job-card-head {
    display: flex; justify-content: space-between; align-items: flex-start;
    gap: 16px; margin-bottom: 14px;
}
.job-card-title h3 {
    font-size: 1.35rem; line-height: 1.2; margin: 0 0 6px;
    font-family: var(--font-display); font-weight: 500;
}
.job-card-title h3 a { color: var(--ink); }
.job-card-title h3 a:hover { color: var(--champagne); }
.job-card-cat {
    font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
    color: var(--champagne); font-weight: 600;
}
.job-card-ref { font-size: 12px; color: var(--muted-soft); margin-top: 4px; }

.urgent-badge {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 5px 11px; background: #d63838; color: var(--white);
    border-radius: 999px; font-size: 10px; letter-spacing: 0.14em;
    text-transform: uppercase; font-weight: 600;
    animation: halo-pulse 2s ease-in-out infinite;
}

.job-card-meta {
    display: flex; flex-wrap: wrap; gap: 14px 24px;
    color: var(--muted); font-size: 13px; margin-bottom: 18px;
}
.job-card-meta span { display: inline-flex; align-items: center; gap: 8px; }
.job-card-meta i { color: var(--champagne); font-size: 12px; }

.job-card-foot {
    display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: 14px;
    padding-top: 18px; border-top: 1px solid var(--line);
}
.job-card-foot .apply-actions { display: flex; gap: 10px; align-items: center; }
.job-card-foot .deadline {
    font-size: 12px; color: var(--muted); display: inline-flex; align-items: center; gap: 6px;
}
.job-card-foot .deadline i { color: var(--champagne); }

.icon-btn {
    width: 38px; height: 38px; border-radius: 50%;
    border: 1px solid var(--line-strong); background: var(--white);
    display: grid; place-items: center; cursor: pointer; color: var(--muted);
    transition: 0.3s var(--ease); font-size: 13px;
}
.icon-btn:hover { background: var(--ink); border-color: var(--ink); color: var(--paper-soft); }
.icon-btn.active { background: var(--champagne); border-color: var(--champagne); color: var(--ink); }

.share-menu {
    position: relative;
}
.share-popover {
    position: absolute; right: 0; top: calc(100% + 10px); z-index: 10;
    background: var(--white); border: 1px solid var(--line); border-radius: var(--radius-sm);
    padding: 8px; min-width: 200px; box-shadow: var(--shadow-md);
    opacity: 0; visibility: hidden; transform: translateY(6px); transition: 0.3s var(--ease);
}
.share-menu.open .share-popover { opacity: 1; visibility: visible; transform: translateY(0); }
.share-popover a {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 14px; font-size: 13px; color: var(--ink); border-radius: 6px;
}
.share-popover a:hover { background: var(--paper-soft); color: var(--champagne); }
.share-popover i { width: 18px; text-align: center; }

@media (max-width: 900px) {
    .career-grid { grid-template-columns: 1fr; }
    .career-side { position: static; }
}

/* ---------- Job detail page ---------- */
.job-detail-grid {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: 56px;
    align-items: flex-start;
}
.job-detail-main h2 {
    font-size: 1.5rem; margin: 36px 0 18px;
    padding-bottom: 12px; border-bottom: 1px solid var(--line);
}
.job-detail-main ul { padding-left: 22px; list-style: disc; }
.job-detail-main ul li { padding: 6px 0; color: var(--ink); }
.job-detail-main p { color: var(--muted); line-height: 1.75; margin-bottom: 1.2em; }

.job-detail-side {
    position: sticky; top: 120px;
    background: var(--white); border: 1px solid var(--line);
    border-radius: var(--radius-md); padding: 32px; box-shadow: var(--shadow-sm);
}
.job-detail-side .salary-block {
    background: linear-gradient(140deg, var(--champagne), var(--champagne-soft));
    color: var(--ink); border-radius: var(--radius-sm);
    padding: 20px 22px; margin-bottom: 24px;
}
.job-detail-side .salary-block strong {
    display: block; font-family: var(--font-display); font-size: 1.6rem; line-height: 1; margin-bottom: 4px;
}
.job-detail-side .salary-block span {
    font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(11,18,32,0.7);
}
.job-detail-meta { display: flex; flex-direction: column; gap: 10px; margin-bottom: 24px; }
.job-detail-meta .row {
    display: flex; justify-content: space-between; align-items: center; padding: 10px 0;
    border-bottom: 1px dashed var(--line); font-size: 13.5px;
}
.job-detail-meta .row:last-child { border-bottom: none; }
.job-detail-meta .row span:first-child { color: var(--muted); }
.job-detail-meta .row span:last-child { color: var(--ink); font-weight: 500; }
.job-detail-actions { display: flex; flex-direction: column; gap: 10px; }
.job-detail-actions .btn { width: 100%; }

.job-share-row { display: flex; gap: 10px; justify-content: center; margin-top: 18px; padding-top: 18px; border-top: 1px solid var(--line); }
.job-share-row a {
    width: 38px; height: 38px; border-radius: 50%;
    background: var(--paper); color: var(--champagne); display: grid; place-items: center;
    transition: 0.3s var(--ease); font-size: 14px;
}
.job-share-row a:hover { background: var(--champagne); color: var(--ink); transform: translateY(-2px); }

@media (max-width: 1000px) {
    .job-detail-grid { grid-template-columns: 1fr; }
    .job-detail-side { position: static; }
}

/* ---------- Application form (multi-step) ---------- */
.app-form-wrap {
    background: var(--white); border: 1px solid var(--line);
    border-radius: var(--radius-md); padding: 40px 44px; box-shadow: var(--shadow-sm);
    max-width: 880px; margin: 0 auto;
}
.app-steps {
    display: flex; gap: 6px; margin-bottom: 32px; padding-bottom: 24px;
    border-bottom: 1px solid var(--line);
}
.app-step {
    flex: 1; text-align: center; padding: 12px 8px;
    border-radius: var(--radius-sm); font-size: 12px; letter-spacing: 0.06em;
    color: var(--muted); cursor: pointer; transition: 0.3s var(--ease);
    position: relative;
}
.app-step .step-num {
    display: inline-grid; place-items: center; width: 28px; height: 28px;
    border-radius: 50%; background: var(--paper); color: var(--muted-soft);
    font-family: var(--font-display); font-style: italic; font-size: 13px;
    margin-bottom: 6px; transition: 0.3s var(--ease);
}
.app-step.active { color: var(--ink); }
.app-step.active .step-num { background: var(--champagne); color: var(--ink); }
.app-step.done .step-num { background: var(--navy); color: var(--paper-soft); }
.app-step.done .step-num::before { content: "\f00c"; font-family: "Font Awesome 6 Free"; font-weight: 900; }
.app-step.done .step-num span { display: none; }

.app-pane { display: none; }
.app-pane.active { display: block; animation: svcFade 0.4s var(--ease); }
.app-pane h3 { font-size: 1.35rem; margin-bottom: 6px; }
.app-pane .pane-sub { color: var(--muted); font-size: 14px; margin-bottom: 24px; }

.app-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.app-form-grid .full { grid-column: 1 / -1; }
.app-form-grid label { display: block; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); margin-bottom: 6px; font-weight: 600; }
.app-form-grid input, .app-form-grid select, .app-form-grid textarea {
    width: 100%; padding: 14px 16px; border: 1px solid var(--line);
    background: var(--paper-soft); border-radius: var(--radius-sm);
    font-family: var(--font-sans); font-size: 14px; color: var(--ink); transition: 0.25s var(--ease);
}
.app-form-grid input:focus, .app-form-grid select:focus, .app-form-grid textarea:focus {
    outline: none; border-color: var(--champagne); background: var(--white);
}

.uploader {
    border: 2px dashed var(--line-strong); border-radius: var(--radius-md);
    padding: 28px 24px; text-align: center; cursor: pointer; transition: 0.3s var(--ease);
    background: var(--paper-soft);
}
.uploader:hover, .uploader.drag-over {
    border-color: var(--champagne); background: rgba(201,161,95,0.06);
}
.uploader i { font-size: 24px; color: var(--champagne); margin-bottom: 10px; display: block; }
.uploader strong { display: block; font-size: 14px; color: var(--ink); margin-bottom: 4px; }
.uploader span { font-size: 12px; color: var(--muted); }
.uploader input { display: none; }
.uploader-list { margin-top: 16px; display: flex; flex-direction: column; gap: 8px; text-align: left; }
.uploader-file {
    display: flex; align-items: center; justify-content: space-between; gap: 12px;
    padding: 10px 14px; background: var(--white); border: 1px solid var(--line);
    border-radius: var(--radius-sm); font-size: 13px;
}
.uploader-file .name { display: flex; align-items: center; gap: 10px; }
.uploader-file .name i { color: var(--champagne); }
.uploader-file .remove { color: #d63838; cursor: pointer; }

.app-actions {
    display: flex; justify-content: space-between; align-items: center;
    margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--line);
}

.consent-box {
    background: var(--paper-soft); border: 1px solid var(--line);
    border-radius: var(--radius-sm); padding: 18px 22px; margin: 16px 0 24px;
}
.consent-box label {
    display: flex; align-items: flex-start; gap: 12px; font-size: 13.5px; color: var(--muted); cursor: pointer;
    text-transform: none; letter-spacing: 0; margin-bottom: 10px;
}
.consent-box input { accent-color: var(--champagne); margin-top: 2px; }

@media (max-width: 700px) { .app-form-wrap { padding: 28px 22px; } .app-form-grid { grid-template-columns: 1fr; } }

/* ---------- Why join cards ---------- */
.why-join-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
}
.why-join-card {
    background: var(--white); border: 1px solid var(--line);
    border-radius: var(--radius-md); padding: 36px 32px; transition: 0.35s var(--ease);
}
.why-join-card:hover { transform: translateY(-4px); border-color: var(--champagne); box-shadow: var(--shadow-md); }
.why-join-card i {
    width: 52px; height: 52px; border-radius: 14px;
    background: linear-gradient(140deg, var(--champagne), var(--champagne-soft));
    color: var(--ink); display: grid; place-items: center; font-size: 20px; margin-bottom: 22px;
    box-shadow: 0 8px 22px rgba(201,161,95,0.25);
}
.why-join-card h4 { font-size: 1.25rem; margin-bottom: 10px; }
.why-join-card p { color: var(--muted); font-size: 14.5px; line-height: 1.65; margin: 0; }
@media (max-width: 900px) { .why-join-grid { grid-template-columns: 1fr; } }

/* ---------- Recruitment process strip ---------- */
.process-strip {
    display: grid; grid-template-columns: repeat(6, 1fr); gap: 1px;
    background: var(--line); border: 1px solid var(--line); border-radius: var(--radius-md); overflow: hidden;
}
.process-strip-step {
    background: var(--white); padding: 28px 22px; text-align: center; transition: 0.3s var(--ease);
}
.process-strip-step:hover { background: var(--paper-soft); }
.process-strip-step .num {
    display: inline-grid; place-items: center; width: 44px; height: 44px;
    border-radius: 50%; background: var(--paper); color: var(--champagne);
    font-family: var(--font-display); font-style: italic; font-size: 1rem;
    margin-bottom: 16px; transition: 0.3s var(--ease);
}
.process-strip-step:hover .num { background: var(--champagne); color: var(--ink); }
.process-strip-step h5 { font-size: 0.95rem; margin-bottom: 6px; }
.process-strip-step p { color: var(--muted); font-size: 12px; line-height: 1.5; margin: 0; }
@media (max-width: 1000px) { .process-strip { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 600px)  { .process-strip { grid-template-columns: repeat(2, 1fr); } }

/* ---------- Candidate dashboard ---------- */
.dash-shell {
    display: grid; grid-template-columns: 280px 1fr; gap: 32px;
    align-items: flex-start;
}
.dash-side {
    position: sticky; top: 120px;
    background: var(--white); border: 1px solid var(--line);
    border-radius: var(--radius-md); padding: 28px;
}
.dash-user {
    display: flex; flex-direction: column; align-items: center; text-align: center;
    padding-bottom: 22px; border-bottom: 1px solid var(--line); margin-bottom: 22px;
}
.dash-user .avatar {
    width: 84px; height: 84px; border-radius: 50%;
    background: linear-gradient(140deg, var(--champagne), var(--champagne-soft));
    color: var(--ink); display: grid; place-items: center;
    font-family: var(--font-display); font-size: 1.8rem; margin-bottom: 14px;
    box-shadow: 0 10px 24px rgba(201,161,95,0.3);
}
.dash-user h4 { font-size: 1.1rem; margin: 0 0 4px; }
.dash-user .role { font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); }
.dash-user .availability {
    margin-top: 12px; padding: 6px 14px; border-radius: 999px; font-size: 11px;
    letter-spacing: 0.12em; text-transform: uppercase; font-weight: 600;
    background: rgba(46,125,50,0.08); color: #2e7d32; border: 1px solid rgba(46,125,50,0.2);
}

.profile-completion { padding: 14px 0; margin-bottom: 22px; border-bottom: 1px solid var(--line); }
.profile-completion .label { display: flex; justify-content: space-between; font-size: 12px; color: var(--muted); margin-bottom: 8px; }
.profile-completion .label strong { color: var(--ink); }
.profile-completion .bar { background: var(--paper); border-radius: 999px; height: 6px; overflow: hidden; }
.profile-completion .bar span {
    display: block; height: 100%;
    background: linear-gradient(90deg, var(--champagne), var(--champagne-soft));
    transition: width 0.6s var(--ease);
}

.dash-nav { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 4px; }
.dash-nav li a {
    display: flex; align-items: center; gap: 12px; padding: 10px 12px; border-radius: 8px;
    color: var(--muted); font-size: 14px; transition: 0.25s var(--ease);
}
.dash-nav li a i { width: 18px; color: var(--muted-soft); transition: 0.25s var(--ease); }
.dash-nav li a:hover { background: var(--paper-soft); color: var(--ink); }
.dash-nav li a:hover i { color: var(--champagne); }
.dash-nav li.active a { background: var(--ink); color: var(--paper-soft); }
.dash-nav li.active a i { color: var(--champagne); }
.dash-nav li a .badge {
    margin-left: auto; background: var(--champagne); color: var(--ink);
    font-size: 11px; padding: 2px 8px; border-radius: 999px; font-weight: 600;
}

.dash-main { display: flex; flex-direction: column; gap: 24px; }

.dash-stat-row {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
}
.dash-stat {
    background: var(--white); border: 1px solid var(--line);
    border-radius: var(--radius-md); padding: 22px 24px; transition: 0.3s var(--ease); position: relative;
}
.dash-stat:hover { transform: translateY(-3px); border-color: var(--champagne); box-shadow: var(--shadow-sm); }
.dash-stat .icon {
    width: 40px; height: 40px; border-radius: 10px;
    background: var(--paper); color: var(--champagne);
    display: grid; place-items: center; font-size: 16px; margin-bottom: 14px;
}
.dash-stat strong {
    display: block; font-family: var(--font-display); font-size: 1.8rem;
    color: var(--navy); line-height: 1; margin-bottom: 6px;
}
.dash-stat span { font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); }
@media (max-width: 1100px) { .dash-stat-row { grid-template-columns: repeat(2, 1fr); } }

.dash-card {
    background: var(--white); border: 1px solid var(--line);
    border-radius: var(--radius-md); padding: 28px;
}
.dash-card h3 {
    font-size: 1.15rem; margin: 0 0 18px;
    display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px;
}
.dash-card h3 .link { font-family: var(--font-sans); font-size: 12px; letter-spacing: 0.08em; color: var(--champagne); text-transform: uppercase; }

.app-list { display: flex; flex-direction: column; gap: 12px; }
.app-row {
    display: grid;
    grid-template-columns: 1fr 140px 160px 100px;
    gap: 16px; align-items: center;
    padding: 14px 18px; background: var(--paper-soft);
    border: 1px solid var(--line); border-radius: var(--radius-sm);
    transition: 0.25s var(--ease);
}
.app-row:hover { background: var(--white); border-color: var(--line-strong); }
.app-row .role-cell strong { display: block; font-size: 14px; color: var(--ink); margin-bottom: 4px; }
.app-row .role-cell .ref { font-size: 11px; color: var(--muted-soft); letter-spacing: 0.06em; }
.app-row .meta { font-size: 12px; color: var(--muted); }
.app-row .pill {
    display: inline-block; padding: 5px 12px; border-radius: 999px;
    font-size: 11px; letter-spacing: 0.1em; font-weight: 600; text-transform: uppercase;
}
.pill-new       { background: rgba(201,161,95,0.12); color: var(--champagne); }
.pill-review    { background: rgba(15,35,66,0.08); color: var(--navy); }
.pill-shortlist { background: rgba(46,125,50,0.1); color: #2e7d32; }
.pill-interview { background: rgba(75,46,131,0.1); color: #4B2E83; }
.pill-selected  { background: rgba(46,125,50,0.15); color: #2e7d32; font-weight: 700; }
.pill-offer     { background: linear-gradient(140deg, var(--champagne), var(--champagne-soft)); color: var(--ink); }
.pill-hired     { background: var(--navy); color: var(--paper-soft); }
.pill-rejected  { background: rgba(214,56,56,0.1); color: #b91c1c; }
.pill-archived  { background: rgba(107,107,107,0.1); color: #6B6B6B; }

@media (max-width: 800px) {
    .app-row { grid-template-columns: 1fr; }
}

/* Status timeline */
.status-timeline {
    display: flex; gap: 0; align-items: center; padding: 18px 0; flex-wrap: wrap;
}
.status-step {
    flex: 1; min-width: 90px; text-align: center; position: relative;
}
.status-step:not(:last-child)::after {
    content: ''; position: absolute; right: -50%; top: 14px; width: 100%; height: 2px;
    background: var(--line); z-index: 0;
}
.status-step.done:not(:last-child)::after { background: var(--champagne); }
.status-step .dot {
    width: 28px; height: 28px; border-radius: 50%;
    background: var(--paper); border: 2px solid var(--line-strong);
    display: grid; place-items: center; margin: 0 auto 8px;
    font-size: 11px; color: var(--muted); position: relative; z-index: 1; transition: 0.3s var(--ease);
}
.status-step.done .dot { background: var(--champagne); border-color: var(--champagne); color: var(--ink); }
.status-step.done .dot::before { content: "\f00c"; font-family: "Font Awesome 6 Free"; font-weight: 900; }
.status-step.current .dot {
    background: var(--navy); border-color: var(--navy); color: var(--paper-soft);
    box-shadow: 0 0 0 4px rgba(15,35,66,0.12);
}
.status-step .label { font-size: 11px; letter-spacing: 0.08em; color: var(--muted); text-transform: uppercase; }
.status-step.done .label, .status-step.current .label { color: var(--ink); font-weight: 600; }

/* ---------- Admin pipeline kanban ---------- */
.pipeline-board {
    display: grid; grid-template-columns: repeat(6, minmax(260px, 1fr));
    gap: 16px; overflow-x: auto; padding-bottom: 16px;
}
.pipeline-col {
    background: var(--paper-soft); border: 1px solid var(--line);
    border-radius: var(--radius-md); padding: 16px; min-height: 480px;
}
.pipeline-col h4 {
    display: flex; justify-content: space-between; align-items: center;
    font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink);
    margin: 0 0 14px; padding-bottom: 12px; border-bottom: 2px solid var(--champagne); font-weight: 600;
    font-family: var(--font-sans);
}
.pipeline-col h4 .num {
    background: var(--white); color: var(--champagne); padding: 3px 10px;
    border-radius: 999px; font-size: 11px; font-weight: 700; letter-spacing: 0;
}
.pipeline-card {
    background: var(--white); border: 1px solid var(--line);
    border-radius: var(--radius-sm); padding: 14px; margin-bottom: 10px;
    cursor: grab; transition: 0.25s var(--ease); position: relative;
}
.pipeline-card:hover { border-color: var(--champagne); box-shadow: var(--shadow-sm); transform: translateY(-2px); }
.pipeline-card .name { font-weight: 600; font-size: 13.5px; margin-bottom: 4px; color: var(--ink); }
.pipeline-card .role { font-size: 11px; color: var(--muted); margin-bottom: 10px; }
.pipeline-card .tags { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 8px; }
.pipeline-card .tag {
    font-size: 9.5px; letter-spacing: 0.1em; text-transform: uppercase;
    padding: 2px 6px; border-radius: 4px; background: var(--paper); color: var(--muted);
}
.pipeline-card .tag.tag-gold { background: var(--champagne); color: var(--ink); }
.pipeline-card .tag.tag-red  { background: rgba(214,56,56,0.12); color: #b91c1c; }
.pipeline-card .meta {
    display: flex; justify-content: space-between; align-items: center;
    font-size: 11px; color: var(--muted-soft); padding-top: 8px;
    border-top: 1px solid var(--line);
}
.pipeline-card .stars { color: var(--champagne); }

/* ---------- Admin shell ---------- */
.admin-shell {
    display: grid; grid-template-columns: 240px 1fr;
    min-height: 100vh; background: var(--paper-soft);
}
.admin-side {
    background: var(--ink); color: var(--paper-soft);
    padding: 28px 22px; position: sticky; top: 0; height: 100vh; overflow-y: auto;
}
.admin-side .brand {
    display: flex; align-items: center; gap: 10px; padding-bottom: 22px; margin-bottom: 22px;
    border-bottom: 1px solid rgba(245,241,232,0.1);
    font-family: var(--font-display); font-style: italic; color: var(--champagne);
}
.admin-side .brand img { height: 36px; filter: brightness(0) invert(1); }
.admin-nav { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 4px; }
.admin-nav .group {
    margin: 14px 0 6px; font-size: 10px; letter-spacing: 0.18em;
    text-transform: uppercase; color: var(--muted-soft); padding: 0 12px;
}
.admin-nav a {
    display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: 6px;
    font-size: 13.5px; color: rgba(245,241,232,0.75); transition: 0.25s var(--ease);
}
.admin-nav a i { width: 16px; font-size: 13px; opacity: 0.8; }
.admin-nav a:hover { background: rgba(245,241,232,0.08); color: var(--paper-soft); }
.admin-nav a.active { background: var(--champagne); color: var(--ink); }
.admin-nav a.active i { color: var(--ink); opacity: 1; }
.admin-nav a .badge {
    margin-left: auto; background: var(--champagne); color: var(--ink);
    font-size: 10px; padding: 2px 7px; border-radius: 999px; font-weight: 700;
}
.admin-nav a.active .badge { background: var(--ink); color: var(--champagne); }

.admin-main { padding: 28px 36px; min-width: 0; }
.admin-topbar {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 28px; gap: 16px; flex-wrap: wrap;
}
.admin-topbar h1 {
    font-size: 1.6rem; margin: 0; font-family: var(--font-display); font-weight: 500;
}
.admin-topbar .topbar-actions { display: flex; gap: 10px; align-items: center; }
.admin-topbar .search {
    display: flex; align-items: center; gap: 8px; background: var(--white);
    border: 1px solid var(--line); border-radius: 999px; padding: 9px 16px; min-width: 280px;
}
.admin-topbar .search input { border: none; outline: none; flex: 1; font-size: 13px; }
.admin-topbar .search i { color: var(--muted); font-size: 13px; }

.admin-stats { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; margin-bottom: 24px; }
.admin-stat {
    background: var(--white); border: 1px solid var(--line);
    border-radius: var(--radius-md); padding: 20px 22px; transition: 0.3s var(--ease);
    position: relative; overflow: hidden;
}
.admin-stat::after {
    content: ''; position: absolute; right: -20px; bottom: -20px;
    width: 70px; height: 70px; border-radius: 50%;
    background: radial-gradient(circle, color-mix(in srgb, var(--brand,#C9A15F) 16%, transparent), transparent);
}
.admin-stat:hover { transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.admin-stat .top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
.admin-stat .top i {
    width: 32px; height: 32px; border-radius: 8px;
    background: var(--paper); color: var(--brand,#C9A15F);
    display: grid; place-items: center; font-size: 13px;
}
.admin-stat .delta { font-size: 11px; color: #2e7d32; font-weight: 600; }
.admin-stat .delta.down { color: #b91c1c; }
.admin-stat strong {
    display: block; font-family: var(--font-display); font-size: 1.85rem;
    line-height: 1; color: var(--navy); margin-bottom: 4px;
}
.admin-stat span { font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); }

@media (max-width: 1300px) { .admin-stats { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 900px)  {
    .admin-shell { grid-template-columns: 1fr; }
    .admin-side { position: static; height: auto; }
    .admin-stats { grid-template-columns: repeat(2, 1fr); }
    .pipeline-board { grid-template-columns: repeat(3, minmax(240px, 1fr)); }
}

.admin-table {
    width: 100%; background: var(--white); border: 1px solid var(--line);
    border-radius: var(--radius-md); overflow: hidden; border-collapse: collapse;
}
.admin-table th {
    background: var(--paper-soft); text-align: left; padding: 14px 18px;
    font-family: var(--font-sans); font-size: 11px; letter-spacing: 0.14em;
    text-transform: uppercase; color: var(--muted); font-weight: 600;
    border-bottom: 1px solid var(--line);
}
.admin-table td { padding: 16px 18px; border-bottom: 1px solid var(--line); font-size: 13.5px; }
.admin-table tr:last-child td { border-bottom: none; }
.admin-table tr:hover td { background: var(--paper-soft); }
.admin-table .row-name strong { display: block; color: var(--ink); margin-bottom: 3px; }
.admin-table .row-name small { color: var(--muted-soft); font-size: 11px; }

.admin-card {
    background: var(--white); border: 1px solid var(--line);
    border-radius: var(--radius-md); padding: 24px 28px; margin-bottom: 24px;
}
.admin-card h3 {
    font-size: 1.05rem; margin: 0 0 16px; display: flex; justify-content: space-between; align-items: center;
    font-family: var(--font-sans); font-weight: 600; letter-spacing: -0.01em;
}
.admin-card h3 .link {
    font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
    color: var(--champagne); font-weight: 600;
}

/* ---------- Auth (login/register) ---------- */
.auth-shell {
    min-height: 80vh; display: grid; grid-template-columns: 1fr 1fr; align-items: stretch;
}
.auth-side {
    background:
        linear-gradient(135deg, rgba(11,18,32,0.92), rgba(15,35,66,0.85)),
        url('https://images.pexels.com/photos/3184339/pexels-photo-3184339.jpeg?auto=compress&cs=tinysrgb&w=1200') center/cover;
    color: var(--paper-soft); padding: 64px 56px; display: flex; flex-direction: column; justify-content: center;
}
.auth-side h2 { color: var(--paper-soft); font-size: clamp(2rem, 4vw, 2.8rem); margin-bottom: 18px; }
.auth-side p { color: rgba(245,241,232,0.85); line-height: 1.7; }
.auth-side ul { margin-top: 24px; }
.auth-side ul li { display: flex; align-items: center; gap: 12px; padding: 8px 0; color: rgba(245,241,232,0.9); }
.auth-side ul li i { color: var(--champagne); }

.auth-form { padding: 64px 56px; display: flex; flex-direction: column; justify-content: center; max-width: 520px; margin: 0 auto; }
.auth-form h3 { font-size: 1.6rem; margin-bottom: 8px; }
.auth-form .auth-sub { color: var(--muted); margin-bottom: 28px; }
.auth-form .form-group { margin-bottom: 16px; }
.auth-tabs { display: flex; border-bottom: 1px solid var(--line); margin-bottom: 28px; gap: 6px; }
.auth-tab {
    padding: 12px 18px; background: transparent; border: none; font-size: 13px;
    color: var(--muted); border-bottom: 2px solid transparent; cursor: pointer;
    letter-spacing: 0.06em; font-weight: 500;
}
.auth-tab.active { color: var(--ink); border-bottom-color: var(--champagne); }
.auth-foot { font-size: 13px; color: var(--muted); text-align: center; margin-top: 18px; }
.auth-foot a { color: var(--champagne); }

@media (max-width: 900px) { .auth-shell { grid-template-columns: 1fr; } .auth-side { padding: 40px 32px; } .auth-form { padding: 40px 32px; } }

/* ---------- Misc career page ---------- */
.cat-tile {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    padding: 28px 16px; background: var(--white); border: 1px solid var(--line);
    border-radius: var(--radius-md); text-align: center; color: var(--ink);
    transition: 0.35s var(--ease); cursor: pointer;
}
.cat-tile:hover { transform: translateY(-4px); border-color: var(--champagne); }
.cat-tile i {
    width: 50px; height: 50px; border-radius: 14px;
    background: var(--paper); color: var(--champagne);
    display: grid; place-items: center; font-size: 20px; margin-bottom: 14px;
    transition: 0.3s var(--ease);
}
.cat-tile:hover i { background: var(--champagne); color: var(--ink); transform: rotate(-5deg); }
.cat-tile strong { display: block; font-size: 14px; margin-bottom: 4px; }
.cat-tile span { font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); }
.categories-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 14px; }
@media (max-width: 1000px) { .categories-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 600px)  { .categories-grid { grid-template-columns: repeat(2, 1fr); } }

/* Saved/applied highlight */
.icon-btn.saved { color: var(--champagne); border-color: var(--champagne); }

.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.form-row .form-group { margin-bottom: 0; }
.form-row { margin-bottom: 20px; }

.form-check {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 13px;
    color: var(--muted);
    margin: 4px 0 18px;
    cursor: pointer;
}

.form-check input { accent-color: var(--champagne); }

.contact-socials {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-top: 32px;
    padding-top: 28px;
    border-top: 1px solid var(--line);
}

.contact-socials-label {
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--muted);
    margin-right: 6px;
}

.contact-socials a {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1px solid var(--line-strong);
    display: grid;
    place-items: center;
    color: var(--ink);
    font-size: 14px;
    transition: 0.3s var(--ease);
}

.contact-socials a:hover {
    background: var(--champagne);
    border-color: var(--champagne);
    color: var(--ink);
    transform: translateY(-2px);
}

@media (max-width: 600px) {
    .form-row { grid-template-columns: 1fr; }
}

/* ---------- SLICK OVERRIDES ---------- */
.slick-slider { margin-bottom: 0; }
.slick-dots { bottom: -40px; }
.slick-dots li button::before { font-size: 8px; color: var(--muted); opacity: 0.4; }
.slick-dots li.slick-active button::before { color: var(--champagne); opacity: 1; }
