/* =====================================================================
   BLITZ X SPORTS ACADEMY — Global Stylesheet (Phase 1 Frontend)
   Brand: Black #000 / Red #E10600 / White / Blue accent #00A8E8
   Fonts: Poppins (headings), Inter (body), Montserrat (labels)
   ===================================================================== */

:root {
    --bx-black: #0a0a0a;
    --bx-ink: #14161a;
    --bx-red: #e10600;
    --bx-red-dark: #b00500;
    --bx-blue: #00a8e8;
    --bx-white: #ffffff;
    --bx-gray: #f4f5f7;
    --bx-gray-2: #e9ecef;
    --bx-muted: #6b7280;
    --bx-line: rgba(0, 0, 0, .08);

    --bx-grad: linear-gradient(135deg, #e10600 0%, #ff3d00 100%);
    --bx-grad-dark: linear-gradient(135deg, #14161a 0%, #000 100%);
    --bx-grad-blue: linear-gradient(135deg, #00a8e8 0%, #0066ff 100%);

    --bx-shadow-sm: 0 4px 14px rgba(0, 0, 0, .08);
    --bx-shadow: 0 18px 40px rgba(0, 0, 0, .12);
    --bx-shadow-red: 0 14px 30px rgba(225, 6, 0, .35);

    --bx-radius: 18px;
    --bx-radius-lg: 26px;
    --font-head: 'Poppins', sans-serif;
    --font-body: 'Inter', sans-serif;
    --font-label: 'Montserrat', sans-serif;
    --nav-h: 84px;
}

/* ------------------------------ Base ------------------------------ */
* { scroll-margin-top: var(--nav-h); }

html { scroll-behavior: smooth; }

body {
    font-family: var(--font-body);
    color: var(--bx-ink);
    background: var(--bx-white);
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, .display-1, .display-2, .display-3, .display-4 {
    font-family: var(--font-head);
    font-weight: 800;
    letter-spacing: -.02em;
}

a { text-decoration: none; transition: color .25s ease; }

img { max-width: 100%; }

.section { padding: 100px 0; position: relative; }
.section-sm { padding: 70px 0; }
.bg-soft { background: var(--bx-gray); }
.bg-ink { background: var(--bx-grad-dark); color: #fff; }
.bg-ink h1, .bg-ink h2, .bg-ink h3 { color: #fff; }

.text-red { color: var(--bx-red) !important; }
.text-blue { color: var(--bx-blue) !important; }

::selection { background: var(--bx-red); color: #fff; }

/* Custom scrollbar */
::-webkit-scrollbar { width: 10px; }
::-webkit-scrollbar-track { background: #0a0a0a; }
::-webkit-scrollbar-thumb { background: var(--bx-red); border-radius: 10px; }

/* --------------------------- Typography --------------------------- */
.eyebrow {
    font-family: var(--font-label);
    text-transform: uppercase;
    letter-spacing: .28em;
    font-weight: 700;
    font-size: .78rem;
    color: var(--bx-red);
    display: inline-flex;
    align-items: center;
    gap: .6rem;
    margin-bottom: 1rem;
}
.eyebrow::before {
    content: '';
    width: 32px; height: 2px;
    background: var(--bx-red);
    display: inline-block;
}
.eyebrow.center { justify-content: center; }
.eyebrow.light { color: #fff; }
.eyebrow.light::before { background: #fff; }

.section-title {
    font-size: clamp(2rem, 4vw, 3.1rem);
    line-height: 1.08;
    margin-bottom: 1rem;
}
.section-title .hl { color: var(--bx-red); position: relative; }

.lead-muted { color: var(--bx-muted); font-size: 1.08rem; max-width: 640px; }
.center .lead-muted, .text-center .lead-muted { margin-left: auto; margin-right: auto; }

/* ---------------------------- Buttons ----------------------------- */
.btn { font-family: var(--font-label); font-weight: 700; letter-spacing: .02em; border-radius: 50px; padding: .85rem 1.8rem; transition: all .3s cubic-bezier(.2,.8,.2,1); border: 2px solid transparent; }
.btn:focus { box-shadow: none; }

.btn-bx {
    background: var(--bx-grad);
    color: #fff;
    box-shadow: var(--bx-shadow-red);
}
.btn-bx:hover { color: #fff; transform: translateY(-3px); box-shadow: 0 20px 38px rgba(225, 6, 0, .5); }

.btn-outline-bx { border-color: rgba(255,255,255,.55); color: #fff; background: transparent; }
.btn-outline-bx:hover { background: #fff; color: var(--bx-black); transform: translateY(-3px); }

.btn-dark-bx { background: var(--bx-ink); color: #fff; }
.btn-dark-bx:hover { background: #000; color: #fff; transform: translateY(-3px); }

.btn-ghost-dark { border-color: rgba(0,0,0,.18); color: var(--bx-ink); }
.btn-ghost-dark:hover { background: var(--bx-ink); color: #fff; }

.btn-lg { padding: 1.05rem 2.3rem; font-size: 1rem; }

/* --------------------------- Navbar ------------------------------ */
.navbar {
    padding: .9rem 0;
    transition: all .35s ease;
    background: transparent;
}
.navbar.scrolled {
    background: rgba(10, 10, 10, .92);
    backdrop-filter: blur(14px);
    padding: .55rem 0;
    box-shadow: 0 10px 30px rgba(0,0,0,.35);
}
.navbar-brand { display: flex; align-items: center; gap: .65rem; }
.navbar-brand .logo-img { height: 54px; width: auto; transition: height .3s ease; }
.navbar.scrolled .navbar-brand .logo-img { height: 46px; }

.navbar .nav-link {
    font-family: var(--font-label);
    font-weight: 600;
    color: rgba(255,255,255,.82) !important;
    margin: 0 .35rem;
    position: relative;
    padding: .5rem .2rem !important;
}
.navbar .nav-link::after {
    content: '';
    position: absolute; left: 0; bottom: -2px;
    width: 0; height: 2px; background: var(--bx-red);
    transition: width .3s ease;
}
.navbar .nav-link:hover, .navbar .nav-link.active { color: #fff !important; }
.navbar .nav-link:hover::after, .navbar .nav-link.active::after { width: 100%; }
.navbar-toggler { border: none; color: #fff; font-size: 1.5rem; padding: 0; }
.navbar-toggler:focus { box-shadow: none; }

/* solid navbar variant for inner pages before scroll handled by scrolled class on load */
.navbar.solid { background: rgba(10,10,10,.92); backdrop-filter: blur(14px); }

@media (max-width: 991.98px) {
    .navbar-collapse {
        background: rgba(10,10,10,.97);
        margin-top: .8rem;
        padding: 1rem 1.2rem;
        border-radius: 16px;
    }
    .navbar .nav-link { margin: .25rem 0; }
}

/* ---------------------------- Hero ------------------------------- */
.hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    color: #fff;
    overflow: hidden;
    background: #000;
}
.hero-bg {
    position: absolute; inset: 0;
    background-size: cover; background-position: center;
    transform: scale(1.08);
    animation: heroZoom 18s ease-in-out infinite alternate;
}
@keyframes heroZoom { to { transform: scale(1); } }
.hero-overlay {
    position: absolute; inset: 0;
    background:
        linear-gradient(115deg, rgba(10,10,10,.94) 0%, rgba(10,10,10,.72) 42%, rgba(225,6,0,.35) 100%),
        linear-gradient(0deg, rgba(0,0,0,.85) 0%, transparent 55%);
}
.hero-content { position: relative; z-index: 3; padding-top: var(--nav-h); }
.hero h1 {
    font-size: clamp(2.6rem, 6.4vw, 5.4rem);
    line-height: .98;
    text-transform: uppercase;
    margin-bottom: 1.2rem;
}
.hero h1 .stroke {
    -webkit-text-stroke: 2px #fff;
    -webkit-text-fill-color: transparent;
    color: transparent;
}
.hero .tagline {
    font-family: var(--font-label);
    font-weight: 700; letter-spacing: .04em;
    color: var(--bx-red);
    text-transform: uppercase;
    font-size: clamp(1rem, 2vw, 1.35rem);
}
.hero p.intro { color: rgba(255,255,255,.82); font-size: 1.12rem; max-width: 540px; margin: 1.2rem 0 2rem; }

/* hero floating stats */
.hero-stats { display: flex; flex-wrap: wrap; gap: 2.4rem; margin-top: 3rem; }
.hero-stats .stat .num { font-family: var(--font-head); font-weight: 800; font-size: 2.6rem; line-height: 1; }
.hero-stats .stat .num .text-red { color: var(--bx-red); }
.hero-stats .stat .lbl { font-family: var(--font-label); text-transform: uppercase; letter-spacing: .14em; font-size: .72rem; color: rgba(255,255,255,.7); margin-top: .35rem; }

.scroll-cue {
    position: absolute; bottom: 26px; left: 50%; transform: translateX(-50%);
    z-index: 4; color: rgba(255,255,255,.7); font-size: 1.4rem;
    animation: bob 1.8s ease-in-out infinite;
}
@keyframes bob { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(10px)} }

/* page hero (inner pages) */
.page-hero {
    position: relative; padding: calc(var(--nav-h) + 70px) 0 70px;
    color: #fff; text-align: center; overflow: hidden; background: #000;
}
.page-hero .hero-bg { animation: none; transform: none; opacity: .5; }
.page-hero h1 { font-size: clamp(2.2rem, 5vw, 3.6rem); text-transform: uppercase; position: relative; z-index: 2; }
.page-hero .breadcrumb-bx { position: relative; z-index: 2; font-family: var(--font-label); font-size: .85rem; color: rgba(255,255,255,.7); margin-top: .6rem; }
.page-hero .breadcrumb-bx a { color: #fff; }
.page-hero .breadcrumb-bx .sep { color: var(--bx-red); margin: 0 .5rem; }

/* --------------------------- Cards ------------------------------- */
.bx-card {
    background: #fff;
    border-radius: var(--bx-radius);
    box-shadow: var(--bx-shadow-sm);
    overflow: hidden;
    transition: transform .4s cubic-bezier(.2,.8,.2,1), box-shadow .4s ease;
    height: 100%;
    border: 1px solid var(--bx-line);
}
.bx-card:hover { transform: translateY(-10px); box-shadow: var(--bx-shadow); }

/* Program card */
.program-card {
    position: relative; border-radius: var(--bx-radius); overflow: hidden;
    height: 100%; min-height: 260px; display: flex; flex-direction: column;
    justify-content: flex-end; padding: 1.6rem; color: #fff; isolation: isolate;
    box-shadow: var(--bx-shadow-sm);
    transition: transform .4s cubic-bezier(.2,.8,.2,1), box-shadow .4s ease;
}
.program-card::before {
    content: ''; position: absolute; inset: 0; z-index: -2;
    background-size: cover; background-position: center;
    background-image: var(--img);
    transition: transform .6s ease;
}
.program-card::after {
    content: ''; position: absolute; inset: 0; z-index: -1;
    background: linear-gradient(180deg, rgba(10,10,10,.05) 0%, rgba(10,10,10,.55) 55%, rgba(10,10,10,.92) 100%);
    transition: background .4s ease;
}
.program-card:hover { transform: translateY(-8px); box-shadow: var(--bx-shadow); }
.program-card:hover::before { transform: scale(1.1); }
.program-card:hover::after { background: linear-gradient(180deg, rgba(225,6,0,.25) 0%, rgba(10,10,10,.6) 55%, rgba(10,10,10,.95) 100%); }
.program-card .pc-icon {
    width: 50px; height: 50px; border-radius: 14px; background: var(--bx-grad);
    display: grid; place-items: center; font-size: 1.4rem; margin-bottom: auto;
    box-shadow: var(--bx-shadow-red);
}
.program-card h5 { color: #fff; margin: .9rem 0 .25rem; font-size: 1.18rem; }
.program-card p { color: rgba(255,255,255,.78); font-size: .9rem; margin: 0; }
.program-card .pc-link { font-family: var(--font-label); font-weight: 700; font-size: .8rem; text-transform: uppercase; letter-spacing: .1em; color: #fff; margin-top: .8rem; opacity: 0; transform: translateY(8px); transition: all .35s ease; }
.program-card:hover .pc-link { opacity: 1; transform: translateY(0); }

/* simple icon feature card */
.feature-card {
    background: #fff; border-radius: var(--bx-radius); padding: 2.2rem 1.8rem; height: 100%;
    border: 1px solid var(--bx-line); transition: all .35s ease; position: relative; overflow: hidden;
}
.feature-card::after { content:''; position:absolute; left:0; top:0; height:4px; width:0; background: var(--bx-grad); transition: width .4s ease; }
.feature-card:hover { transform: translateY(-8px); box-shadow: var(--bx-shadow); }
.feature-card:hover::after { width: 100%; }
.feature-icon {
    width: 64px; height: 64px; border-radius: 18px; display: grid; place-items: center;
    font-size: 1.7rem; color: #fff; background: var(--bx-grad-dark); margin-bottom: 1.2rem; transition: all .35s ease;
}
.feature-card:hover .feature-icon { background: var(--bx-grad); box-shadow: var(--bx-shadow-red); transform: rotate(-6deg); }
.feature-card h5 { font-size: 1.15rem; margin-bottom: .5rem; }
.feature-card p { color: var(--bx-muted); font-size: .94rem; margin: 0; }

/* pill chips for mode/activities */
.chip-grid { display: flex; flex-wrap: wrap; gap: .7rem; }
.chip {
    background: #fff; border: 1px solid var(--bx-line); border-radius: 50px;
    padding: .55rem 1.15rem; font-family: var(--font-label); font-weight: 600; font-size: .85rem;
    display: inline-flex; align-items: center; gap: .5rem; transition: all .3s ease; box-shadow: var(--bx-shadow-sm);
}
.chip i { color: var(--bx-red); }
.chip:hover { background: var(--bx-ink); color: #fff; transform: translateY(-3px); }
.chip:hover i { color: #fff; }

/* --------------------------- Events ------------------------------ */
.event-card { background:#fff; border-radius: var(--bx-radius); overflow:hidden; box-shadow: var(--bx-shadow-sm); height:100%; transition: all .4s ease; border:1px solid var(--bx-line); }
.event-card:hover { transform: translateY(-8px); box-shadow: var(--bx-shadow); }
.event-media { position: relative; aspect-ratio: 16/10; overflow: hidden; }
.event-media img { width:100%; height:100%; object-fit: cover; transition: transform .6s ease; }
.event-card:hover .event-media img { transform: scale(1.08); }
.event-date {
    position:absolute; top:14px; left:14px; background: var(--bx-grad); color:#fff;
    border-radius: 14px; text-align:center; padding:.5rem .8rem; line-height:1; box-shadow: var(--bx-shadow-red);
}
.event-date .d { font-family: var(--font-head); font-weight:800; font-size:1.4rem; }
.event-date .m { font-family: var(--font-label); font-size:.7rem; text-transform:uppercase; letter-spacing:.1em; }
.event-tag { position:absolute; bottom:14px; left:14px; background: rgba(0,0,0,.7); color:#fff; backdrop-filter: blur(6px); font-family: var(--font-label); font-weight:600; font-size:.72rem; text-transform:uppercase; letter-spacing:.08em; padding:.35rem .8rem; border-radius:50px; }
.event-body { padding: 1.4rem 1.5rem 1.6rem; }
.event-body h5 { font-size:1.18rem; margin-bottom:.6rem; }
.event-meta { display:flex; flex-wrap:wrap; gap:1rem; color: var(--bx-muted); font-size:.86rem; margin-bottom:1rem; }
.event-meta i { color: var(--bx-red); margin-right:.35rem; }

/* --------------------------- Counters ---------------------------- */
.stat-strip { background: var(--bx-grad-dark); color:#fff; position: relative; overflow:hidden; }
.stat-strip::before { content:''; position:absolute; inset:0; background-image: url('/images/pattern.svg'); opacity:.06; }
.counter-box { text-align:center; padding: 1rem; position: relative; z-index:2; }
.counter-box .ic { font-size: 2rem; color: var(--bx-red); margin-bottom:.6rem; }
.counter-box .num { font-family: var(--font-head); font-weight:800; font-size: clamp(2.4rem,4vw,3.4rem); line-height:1; }
.counter-box .lbl { font-family: var(--font-label); text-transform:uppercase; letter-spacing:.14em; font-size:.78rem; color: rgba(255,255,255,.72); margin-top:.5rem; }

/* achievement / trophy cards */
.achieve-card { background:#fff; border-radius: var(--bx-radius); padding: 1.8rem; height:100%; border:1px solid var(--bx-line); box-shadow: var(--bx-shadow-sm); transition: all .35s ease; display:flex; gap:1.1rem; align-items:flex-start; }
.achieve-card:hover { transform: translateY(-6px); box-shadow: var(--bx-shadow); }
.achieve-card .tro { width:56px; height:56px; border-radius:16px; background: linear-gradient(135deg,#ffd34d,#f5a623); color:#7a4b00; display:grid; place-items:center; font-size:1.5rem; flex-shrink:0; }
.achieve-card h6 { font-family: var(--font-head); font-weight:700; margin-bottom:.25rem; }
.achieve-card p { color: var(--bx-muted); font-size:.88rem; margin:0; }
.achieve-card .yr { font-family: var(--font-label); font-weight:700; font-size:.75rem; color: var(--bx-red); }

/* --------------------------- News ------------------------------- */
.news-ticker { background: var(--bx-red); color:#fff; overflow:hidden; display:flex; align-items:center; }
.news-ticker .nt-label { background:#000; color:#fff; font-family: var(--font-label); font-weight:700; text-transform:uppercase; letter-spacing:.1em; font-size:.78rem; padding:.7rem 1.1rem; white-space:nowrap; display:flex; align-items:center; gap:.5rem; flex-shrink:0; }
.news-ticker .nt-label .dot { width:8px; height:8px; background: var(--bx-red); border-radius:50%; animation: blink 1s infinite; }
@keyframes blink { 50%{ opacity:.2; } }
.nt-track-wrap { overflow:hidden; flex:1; }
.nt-track { display:flex; gap:3rem; white-space:nowrap; animation: ticker 30s linear infinite; font-family: var(--font-label); font-weight:600; font-size:.9rem; padding-left:1.5rem; }
.nt-track span i { margin-right:.4rem; }
.news-ticker:hover .nt-track { animation-play-state: paused; }
@keyframes ticker { to { transform: translateX(-50%); } }

.news-card { background:#fff; border-radius: var(--bx-radius); overflow:hidden; box-shadow: var(--bx-shadow-sm); height:100%; transition: all .4s ease; border:1px solid var(--bx-line); }
.news-card:hover { transform: translateY(-8px); box-shadow: var(--bx-shadow); }
.news-media { aspect-ratio: 16/10; overflow:hidden; position:relative; }
.news-media img { width:100%; height:100%; object-fit:cover; transition: transform .6s ease; }
.news-card:hover .news-media img { transform: scale(1.08); }
.news-cat { position:absolute; top:12px; left:12px; background: var(--bx-grad); color:#fff; font-family: var(--font-label); font-weight:700; font-size:.68rem; text-transform:uppercase; letter-spacing:.08em; padding:.3rem .7rem; border-radius:50px; }
.news-body { padding: 1.3rem 1.4rem 1.5rem; }
.news-body .date { font-family: var(--font-label); font-size:.76rem; color: var(--bx-muted); text-transform:uppercase; letter-spacing:.08em; }
.news-body h6 { font-family: var(--font-head); font-weight:700; font-size:1.05rem; margin:.5rem 0; line-height:1.35; }
.news-body p { color: var(--bx-muted); font-size:.88rem; margin:0 0 .6rem; }
.news-feature { position: relative; border-radius: var(--bx-radius-lg); overflow:hidden; min-height:420px; display:flex; flex-direction:column; justify-content:flex-end; padding:2rem; color:#fff; height:100%; }
.news-feature img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2; transition: transform .6s ease; }
.news-feature::after { content:''; position:absolute; inset:0; z-index:-1; background: linear-gradient(180deg, transparent 25%, rgba(10,10,10,.96) 95%); }
.news-feature:hover img { transform: scale(1.06); }
.news-feature h3 { color:#fff; font-size: clamp(1.4rem,2.4vw,2rem); }

/* --------------------------- About ------------------------------ */
.about-img-wrap { position: relative; }
.about-img-wrap .img-main { border-radius: var(--bx-radius-lg); box-shadow: var(--bx-shadow); width:100%; }
.about-img-wrap .img-badge {
    position:absolute; bottom:-26px; right:-12px; background: var(--bx-grad); color:#fff;
    border-radius: var(--bx-radius); padding:1.3rem 1.6rem; box-shadow: var(--bx-shadow-red); text-align:center;
}
.about-img-wrap .img-badge .n { font-family: var(--font-head); font-weight:800; font-size:2.2rem; line-height:1; }
.about-img-wrap .img-badge .t { font-family: var(--font-label); font-size:.72rem; text-transform:uppercase; letter-spacing:.1em; }
.about-img-wrap .img-dots { position:absolute; top:-22px; left:-22px; width:110px; height:110px; background-image: radial-gradient(var(--bx-red) 2px, transparent 2px); background-size: 16px 16px; opacity:.5; z-index:-1; }

.tick-list { list-style:none; padding:0; margin: 1.5rem 0 0; }
.tick-list li { display:flex; gap:.8rem; align-items:flex-start; margin-bottom:.9rem; font-weight:500; }
.tick-list li i { color: var(--bx-red); margin-top:.2rem; font-size:1.1rem; }

/* vision / mission */
.vm-card { border-radius: var(--bx-radius-lg); padding: 2.4rem 2rem; height:100%; color:#fff; position:relative; overflow:hidden; isolation:isolate; transition: transform .4s ease; }
.vm-card:hover { transform: translateY(-8px); }
.vm-card::before { content:''; position:absolute; inset:0; z-index:-1; opacity:.9; }
.vm-card.v1::before { background: var(--bx-grad); }
.vm-card.v2::before { background: var(--bx-grad-dark); }
.vm-card.v3::before { background: var(--bx-grad-blue); }
.vm-card .vm-ic { width:64px; height:64px; border-radius:18px; background: rgba(255,255,255,.16); display:grid; place-items:center; font-size:1.7rem; margin-bottom:1.2rem; }
.vm-card h4 { color:#fff; margin-bottom:.7rem; }
.vm-card p { color: rgba(255,255,255,.88); margin:0; }
.vm-card .vm-watermark { position:absolute; right:-10px; bottom:-30px; font-size:8rem; opacity:.12; z-index:-1; }

/* --------------------------- Gallery ----------------------------- */
.gallery-filter { display:flex; flex-wrap:wrap; gap:.6rem; justify-content:center; margin-bottom:2.5rem; }
.gallery-filter button {
    font-family: var(--font-label); font-weight:600; font-size:.85rem; border:1px solid var(--bx-line);
    background:#fff; color: var(--bx-ink); padding:.55rem 1.3rem; border-radius:50px; transition: all .3s ease;
}
.gallery-filter button.active, .gallery-filter button:hover { background: var(--bx-grad); color:#fff; border-color: transparent; box-shadow: var(--bx-shadow-red); }

.gallery-grid { columns: 3; column-gap: 1rem; }
.gallery-grid .g-item { break-inside: avoid; margin-bottom: 1rem; border-radius: var(--bx-radius); overflow:hidden; position:relative; display:block; }
.gallery-grid .g-item img { width:100%; display:block; transition: transform .6s ease; }
.gallery-grid .g-item::after { content:''; position:absolute; inset:0; background: linear-gradient(180deg, transparent 40%, rgba(225,6,0,.75)); opacity:0; transition: opacity .35s ease; }
.gallery-grid .g-item .g-zoom { position:absolute; inset:0; display:grid; place-items:center; color:#fff; font-size:1.6rem; opacity:0; transform: scale(.7); transition: all .35s ease; z-index:2; }
.gallery-grid .g-item:hover img { transform: scale(1.08); }
.gallery-grid .g-item:hover::after { opacity:1; }
.gallery-grid .g-item:hover .g-zoom { opacity:1; transform: scale(1); }
.gallery-grid .g-item .g-cap { position:absolute; bottom:12px; left:14px; z-index:3; color:#fff; font-family: var(--font-label); font-weight:600; opacity:0; transform: translateY(8px); transition: all .35s ease; }
.gallery-grid .g-item:hover .g-cap { opacity:1; transform: translateY(0); }
@media (max-width: 991.98px){ .gallery-grid { columns:2; } }
@media (max-width: 575.98px){ .gallery-grid { columns:1; } }

.video-card { position:relative; border-radius: var(--bx-radius); overflow:hidden; display:block; aspect-ratio:16/9; }
.video-card img { width:100%; height:100%; object-fit:cover; transition: transform .6s ease; }
.video-card::after { content:''; position:absolute; inset:0; background: rgba(10,10,10,.35); transition: background .35s ease; }
.video-card:hover img { transform: scale(1.07); }
.video-card:hover::after { background: rgba(225,6,0,.35); }
.video-card .play { position:absolute; inset:0; display:grid; place-items:center; z-index:2; }
.video-card .play span { width:74px; height:74px; border-radius:50%; background: var(--bx-grad); color:#fff; display:grid; place-items:center; font-size:1.5rem; box-shadow: var(--bx-shadow-red); transition: transform .35s ease; }
.video-card:hover .play span { transform: scale(1.12); }
.video-card .v-cap { position:absolute; bottom:0; left:0; right:0; z-index:3; padding:1.2rem; color:#fff; background: linear-gradient(transparent, rgba(0,0,0,.8)); font-family: var(--font-head); font-weight:700; }

/* ------------------------ Testimonials --------------------------- */
.testi-card {
    background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.16);
    backdrop-filter: blur(16px); border-radius: var(--bx-radius-lg); padding: 2.2rem; height:100%; color:#fff;
    transition: all .4s ease;
}
.testi-card:hover { transform: translateY(-8px); border-color: rgba(225,6,0,.6); }
.testi-card .quote-ic { font-size:2.4rem; color: var(--bx-red); line-height:1; margin-bottom:.6rem; }
.testi-card p { color: rgba(255,255,255,.9); font-size:1rem; line-height:1.7; }
.testi-card .stars { color: #ffc107; margin: 1rem 0; letter-spacing:2px; }
.testi-head { display:flex; align-items:center; gap:.9rem; margin-top:1.2rem; }
.testi-head img { width:54px; height:54px; border-radius:50%; object-fit:cover; border:2px solid var(--bx-red); }
.testi-head .nm { font-family: var(--font-head); font-weight:700; }
.testi-head .rl { font-family: var(--font-label); font-size:.78rem; color: rgba(255,255,255,.65); text-transform:uppercase; letter-spacing:.08em; }

/* testimonial light variant for inner page */
.testi-card.light { background:#fff; border:1px solid var(--bx-line); color: var(--bx-ink); box-shadow: var(--bx-shadow-sm); }
.testi-card.light p { color: var(--bx-ink); }
.testi-card.light .nm { color: var(--bx-ink); }
.testi-card.light .rl { color: var(--bx-muted); }

/* --------------------------- CTA band ---------------------------- */
.cta-band { position: relative; overflow:hidden; background: var(--bx-grad); color:#fff; border-radius: var(--bx-radius-lg); padding: 3.5rem; }
.cta-band::after { content:'\f091'; font-family:'bootstrap-icons'; position:absolute; right:-20px; bottom:-40px; font-size:12rem; opacity:.12; }
.cta-band h2 { color:#fff; }

/* --------------------------- Team -------------------------------- */
.team-card { border-radius: var(--bx-radius); overflow:hidden; position:relative; box-shadow: var(--bx-shadow-sm); }
.team-card img { width:100%; aspect-ratio: 3/4; object-fit:cover; transition: transform .6s ease; }
.team-card:hover img { transform: scale(1.07); }
.team-info { position:absolute; left:0; right:0; bottom:0; padding:1.4rem; color:#fff; background: linear-gradient(transparent, rgba(10,10,10,.92)); }
.team-info h6 { font-family: var(--font-head); font-weight:700; color:#fff; margin-bottom:.1rem; }
.team-info span { font-family: var(--font-label); font-size:.78rem; color: var(--bx-red); text-transform:uppercase; letter-spacing:.08em; }
.team-social { position:absolute; top:14px; right:14px; display:flex; flex-direction:column; gap:.5rem; opacity:0; transform: translateX(12px); transition: all .35s ease; }
.team-card:hover .team-social { opacity:1; transform: translateX(0); }
.team-social a { width:36px; height:36px; border-radius:50%; background:#fff; color: var(--bx-ink); display:grid; place-items:center; transition: all .3s ease; }
.team-social a:hover { background: var(--bx-red); color:#fff; }

/* --------------------------- Contact ----------------------------- */
.contact-card { background:#fff; border-radius: var(--bx-radius); padding:1.7rem; border:1px solid var(--bx-line); box-shadow: var(--bx-shadow-sm); height:100%; transition: all .35s ease; }
.contact-card:hover { transform: translateY(-6px); box-shadow: var(--bx-shadow); }
.contact-card .ci { width:56px; height:56px; border-radius:16px; background: var(--bx-grad); color:#fff; display:grid; place-items:center; font-size:1.4rem; margin-bottom:1rem; }
.contact-card h6 { font-family: var(--font-head); font-weight:700; margin-bottom:.3rem; }
.contact-card p, .contact-card a { color: var(--bx-muted); margin:0; }
.contact-card a:hover { color: var(--bx-red); }

.form-control, .form-select { border-radius: 12px; padding: .85rem 1rem; border: 1px solid var(--bx-line); background: var(--bx-gray); font-family: var(--font-body); }
.form-control:focus, .form-select:focus { border-color: var(--bx-red); box-shadow: 0 0 0 .2rem rgba(225,6,0,.12); background:#fff; }
.form-label { font-family: var(--font-label); font-weight:600; font-size:.85rem; }

.map-wrap { border-radius: var(--bx-radius); overflow:hidden; box-shadow: var(--bx-shadow-sm); line-height:0; }
.map-wrap iframe { width:100%; height:100%; min-height:380px; border:0; filter: grayscale(.3) contrast(1.05); }

/* --------------------------- Footer ------------------------------ */
.footer { background: #060606; color: rgba(255,255,255,.7); padding-top: 80px; position:relative; overflow:hidden; }
.footer::before { content:''; position:absolute; top:0; left:0; right:0; height:4px; background: var(--bx-grad); }
.footer .logo-img { height:60px; margin-bottom:1.2rem; }
.footer h6 { color:#fff; font-family: var(--font-head); font-weight:700; margin-bottom:1.3rem; font-size:1.05rem; position:relative; padding-bottom:.6rem; }
.footer h6::after { content:''; position:absolute; left:0; bottom:0; width:34px; height:2px; background: var(--bx-red); }
.footer a { color: rgba(255,255,255,.65); }
.footer a:hover { color: var(--bx-red); }
.footer .f-links { list-style:none; padding:0; margin:0; }
.footer .f-links li { margin-bottom:.7rem; }
.footer .f-links li a { display:inline-flex; align-items:center; gap:.5rem; transition: all .3s ease; }
.footer .f-links li a:hover { padding-left:.35rem; }
.footer .f-contact li { display:flex; gap:.7rem; margin-bottom:1rem; align-items:flex-start; }
.footer .f-contact li i { color: var(--bx-red); margin-top:.2rem; }
.footer .f-social { display:flex; gap:.6rem; margin-top:1.2rem; }
.footer .f-social a { width:42px; height:42px; border-radius:12px; background: rgba(255,255,255,.08); display:grid; place-items:center; color:#fff; transition: all .3s ease; }
.footer .f-social a:hover { background: var(--bx-red); transform: translateY(-4px); }
.footer .newsletter .form-control { background: rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12); color:#fff; }
.footer .newsletter .form-control::placeholder { color: rgba(255,255,255,.5); }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.08); margin-top: 60px; padding: 24px 0; font-size:.86rem; }

/* --------------------- Floating contact -------------------------- */
.floating-contact { position: fixed; right: 20px; bottom: 24px; z-index: 1040; display:flex; flex-direction:column; gap:.8rem; }
.floating-contact a { width:56px; height:56px; border-radius:50%; display:grid; place-items:center; color:#fff; font-size:1.5rem; box-shadow: 0 10px 24px rgba(0,0,0,.25); transition: transform .3s ease; position:relative; }
.floating-contact a:hover { transform: scale(1.12); color:#fff; }
.floating-contact .fc-wa { background:#25d366; }
.floating-contact .fc-call { background: var(--bx-grad); }
.floating-contact .fc-enq { background: var(--bx-ink); }
.floating-contact a::after { content:''; position:absolute; inset:0; border-radius:50%; border:2px solid currentColor; animation: pulse-ring 2s ease-out infinite; opacity:.6; }
@keyframes pulse-ring { 0%{ transform: scale(1); opacity:.6; } 100%{ transform: scale(1.6); opacity:0; } }
.floating-contact .fc-tip { position:absolute; right:70px; top:50%; transform: translateY(-50%) translateX(10px); background:#000; color:#fff; font-family: var(--font-label); font-size:.78rem; font-weight:600; padding:.4rem .8rem; border-radius:8px; white-space:nowrap; opacity:0; pointer-events:none; transition: all .3s ease; }
.floating-contact a:hover .fc-tip { opacity:1; transform: translateY(-50%) translateX(0); }

/* back to top */
.to-top { position: fixed; left: 20px; bottom: 24px; z-index:1039; width:48px; height:48px; border-radius:14px; background: var(--bx-ink); color:#fff; display:grid; place-items:center; opacity:0; pointer-events:none; transition: all .35s ease; border:none; }
.to-top.show { opacity:1; pointer-events:auto; }
.to-top:hover { background: var(--bx-red); transform: translateY(-4px); }

/* --------------------------- Utilities --------------------------- */
.divider-x { width:60px; height:4px; background: var(--bx-grad); border-radius:4px; }
.shape-blur { position:absolute; border-radius:50%; filter: blur(80px); opacity:.5; z-index:0; pointer-events:none; }
.shape-red { background: rgba(225,6,0,.4); }
.shape-blue { background: rgba(0,168,232,.35); }

.partner-strip { filter: grayscale(1) brightness(2); opacity:.65; transition: all .3s ease; }
.partner-strip:hover { filter: none; opacity:1; }

.hover-rise { transition: transform .35s ease; }
.hover-rise:hover { transform: translateY(-6px); }

/* AOS fallback (in case CDN blocked, content still visible) */
.no-aos [data-aos] { opacity:1 !important; transform:none !important; }
