/*
Theme Name:  Fourcup Schools
Theme URI:   https://fourcup.in
Author:      Fourcup Technologies Pvt. Ltd.
Author URI:  https://fourcup.com
Description: Official WordPress theme for Fourcup Schools — Premier IT Training Institute in Chennai. SDET, SAP ERP, AWS/Azure Cloud, Java, Python, Full Stack courses with 95% placement support and FC Page Editor.
Version:     4.8.0
Requires at least: 6.2
Tested up to:      6.7
Requires PHP:      7.4
License:           Proprietary
Text Domain:       fourcup-schools
Tags:              education, dark-theme, animated, responsive, courses, training
Build: #6.8.0
*/

/* ─────────────────────────────────────────────────
   @FONT-FACE — LOCAL FONTS
   Orbitron  : H1, H2 (headings)
   Zoho Puvi : H3–H6 (bold), body text (regular)
───────────────────────────────────────────────── */
@font-face{font-family:'Orbitron';src:url('assets/fonts/orbitron/Orbitron-Regular.ttf') format('truetype');font-weight:400;font-display:swap}
@font-face{font-family:'Orbitron';src:url('assets/fonts/orbitron/Orbitron-Medium.ttf') format('truetype');font-weight:500;font-display:swap}
@font-face{font-family:'Orbitron';src:url('assets/fonts/orbitron/Orbitron-SemiBold.ttf') format('truetype');font-weight:600;font-display:swap}
@font-face{font-family:'Orbitron';src:url('assets/fonts/orbitron/Orbitron-Bold.ttf') format('truetype');font-weight:700;font-display:swap}
@font-face{font-family:'Orbitron';src:url('assets/fonts/orbitron/Orbitron-ExtraBold.ttf') format('truetype');font-weight:800;font-display:swap}
@font-face{font-family:'Orbitron';src:url('assets/fonts/orbitron/Orbitron-Black.ttf') format('truetype');font-weight:900;font-display:swap}
@font-face{font-family:'Zoho Puvi';src:url('assets/fonts/zohopuvi/Zoho Puvi Thin.ttf') format('truetype');font-weight:100;font-display:swap}
@font-face{font-family:'Zoho Puvi';src:url('assets/fonts/zohopuvi/Zoho Puvi Extralight.ttf') format('truetype');font-weight:200;font-display:swap}
@font-face{font-family:'Zoho Puvi';src:url('assets/fonts/zohopuvi/Zoho Puvi Light.ttf') format('truetype');font-weight:300;font-display:swap}
@font-face{font-family:'Zoho Puvi';src:url('assets/fonts/zohopuvi/Zoho Puvi Regular.ttf') format('truetype');font-weight:400;font-display:swap}
@font-face{font-family:'Zoho Puvi';src:url('assets/fonts/zohopuvi/Zoho Puvi Regular Italic.ttf') format('truetype');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'Zoho Puvi';src:url('assets/fonts/zohopuvi/Zoho Puvi Medium.ttf') format('truetype');font-weight:500;font-display:swap}
@font-face{font-family:'Zoho Puvi';src:url('assets/fonts/zohopuvi/Zoho Puvi Semibold.ttf') format('truetype');font-weight:600;font-display:swap}
@font-face{font-family:'Zoho Puvi';src:url('assets/fonts/zohopuvi/Zoho Puvi Semibold Italic.ttf') format('truetype');font-weight:600;font-style:italic;font-display:swap}
@font-face{font-family:'Zoho Puvi';src:url('assets/fonts/zohopuvi/Zoho Puvi Bold.ttf') format('truetype');font-weight:700;font-display:swap}
@font-face{font-family:'Zoho Puvi';src:url('assets/fonts/zohopuvi/Zoho Puvi Bold Italic.ttf') format('truetype');font-weight:700;font-style:italic;font-display:swap}
@font-face{font-family:'Zoho Puvi';src:url('assets/fonts/zohopuvi/Zoho Puvi Extrabold.ttf') format('truetype');font-weight:800;font-display:swap}
@font-face{font-family:'Zoho Puvi';src:url('assets/fonts/zohopuvi/Zoho Puvi Black.ttf') format('truetype');font-weight:900;font-display:swap}

/* ─────────────────────────────────────────────────
   CSS VARIABLES
───────────────────────────────────────────────── */
:root{
  --bg:#05090F; --bg2:#080D18; --bg-card:#0C1220; --bg-glass:rgba(12,18,32,.78);
  --teal:#00D4AA; --teal-dim:#00A882; --teal-glow:rgba(0,212,170,.18);
  --gold:#F0A500; --gold-dim:#C07800;
  --white:#FFFFFF; --off-white:#F0F6FF; --muted:#DEEBFF;
  --border:rgba(0,212,170,.13); --border-light:rgba(255,255,255,.06);
  --red:#FF6B6B; --purple:#A78BFA; --pink:#F472B6; --green:#34D399;
  --fh:'Orbitron','Courier New',monospace;
  --fb:'Zoho Puvi','Segoe UI',sans-serif;
  --nav-h:72px; --r:14px; --rl:20px; --rxl:28px;
  --sh-teal:0 0 50px rgba(0,212,170,.12);
  --sh-card:0 24px 64px rgba(0,0,0,.4);
  --t:all .3s cubic-bezier(.4,0,.2,1);
}

/* ─────────────────────────────────────────────────
   RESET & BASE
───────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{background:var(--bg);color:var(--white);font-family:var(--fb);font-weight:400;line-height:1.7;overflow-x:hidden}
a{color:inherit;text-decoration:none;transition:var(--t)}
ul,ol{list-style:none}
img{max-width:100%;display:block;height:auto}
button{cursor:pointer;font-family:var(--fb);border:none;outline:none;background:none}
input,select,textarea{font-family:var(--fb)}
strong,b{font-weight:700}

/* ─────────── TYPOGRAPHY ─────────── */
h1,h2{font-family:var(--fh);font-weight:900;line-height:1.1;letter-spacing:-.5px;color:var(--white)}
h3,h4,h5,h6{font-family:var(--fb);font-weight:700;line-height:1.25;color:var(--white)}
p,li,span,td,th{font-family:var(--fb);font-weight:400;color:inherit}

/* ─────────────────────────────────────────────────
   CANVAS BG
───────────────────────────────────────────────── */
#fc-canvas{position:fixed;inset:0;z-index:0;pointer-events:none}

/* ─────────────────────────────────────────────────
   LAYOUT
───────────────────────────────────────────────── */
.fc-wrap{max-width:1300px;margin:0 auto;padding:0 clamp(16px,5%,80px);width:100%}
.fc-sec{position:relative;z-index:1}
.fc-pad{padding:90px 0}
.fc-pad-sm{padding:56px 0}

/* ─────────────────────────────────────────────────
   NAVBAR
───────────────────────────────────────────────── */
#fc-nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 clamp(16px,4%,60px);
  background:rgba(5,9,15,.85);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border);
  transition:var(--t);
}
#fc-nav.stuck{background:rgba(5,9,15,.98);box-shadow:0 4px 30px rgba(0,0,0,.5)}

/* Logo */
.fc-logo{display:flex;align-items:center;gap:11px;flex-shrink:0}
.fc-logo-img{width:42px;height:42px;object-fit:contain;display:block}
.fc-logo-icon{
  width:42px;height:42px;border-radius:11px;
  background:linear-gradient(135deg,var(--teal),var(--teal-dim));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--fh);font-size:18px;font-weight:900;color:#fff;
  box-shadow:0 0 22px rgba(0,212,170,.4);flex-shrink:0;
}
.fc-logo-text{font-family:var(--fh);font-size:14px;font-weight:800;letter-spacing:1.5px;color:var(--white);line-height:1.2}
.fc-logo-text span{color:var(--teal)}
.fc-logo-sub{font-size:10px;color:rgba(255,255,255,.5);letter-spacing:2px;text-transform:uppercase;margin-top:2px;font-family:var(--fb)}

/* Nav links */
.fc-nav-menu{display:flex;align-items:center;gap:28px}
.fc-nav-menu a{font-family:var(--fb);font-size:13.5px;font-weight:600;color:var(--off-white);opacity:.95;letter-spacing:.3px;position:relative;padding-bottom:4px;transition:var(--t)}
.fc-nav-menu a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--teal);border-radius:2px;transition:var(--t)}
.fc-nav-menu a:hover,.fc-nav-menu a.active{opacity:1;color:var(--white)}
.fc-nav-menu a:hover::after,.fc-nav-menu a.active::after{width:100%}
.fc-nav-menu a.active{color:var(--teal)}

/* Nav actions */
.fc-nav-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}
.fc-btn-ghost{padding:8px 18px;border-radius:8px;font-size:13px;font-weight:700;border:1.5px solid rgba(255,255,255,.2);color:var(--white);font-family:var(--fb);transition:var(--t)}
.fc-btn-ghost:hover{border-color:var(--teal);color:var(--teal)}
.fc-btn-nav{padding:9px 20px;border-radius:8px;font-size:13px;font-weight:700;background:linear-gradient(135deg,var(--teal),var(--teal-dim));color:#fff;font-family:var(--fb);box-shadow:0 4px 14px rgba(0,212,170,.28);transition:var(--t)}
.fc-btn-nav:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(0,212,170,.45)}

/* Hamburger */
.fc-burger{display:none;flex-direction:column;gap:5px;padding:5px;cursor:pointer;flex-shrink:0}
.fc-burger span{display:block;width:22px;height:2px;background:var(--white);border-radius:2px;transition:var(--t)}
.fc-burger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.fc-burger.open span:nth-child(2){opacity:0;transform:translateX(-6px)}
.fc-burger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile drawer */
#fc-drawer{
  display:none;position:fixed;top:var(--nav-h);left:0;right:0;
  background:rgba(5,9,15,.98);backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border);z-index:999;
  padding:16px 5% 24px;flex-direction:column;gap:2px;
  max-height:calc(100vh - var(--nav-h));overflow-y:auto;
}
#fc-drawer.open{display:flex}
#fc-drawer a{padding:13px 4px;font-size:15px;font-weight:600;color:var(--white);font-family:var(--fb);border-bottom:1px solid rgba(255,255,255,.05);display:flex;align-items:center;gap:10px;transition:var(--t)}
#fc-drawer a:last-child{border:0}
#fc-drawer a:hover,#fc-drawer a.active{color:var(--teal);padding-left:10px}
#fc-drawer .mob-demo{margin-top:14px;background:linear-gradient(135deg,var(--teal),var(--teal-dim));color:#fff;border-radius:10px;padding:14px;justify-content:center;font-weight:700}
#fc-drawer .mob-demo:hover{padding-left:14px}

/* ─────────────────────────────────────────────────
   BUTTONS
───────────────────────────────────────────────── */
.fc-btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:10px;font-size:14px;font-weight:700;font-family:var(--fb);transition:var(--t);cursor:pointer;letter-spacing:.2px;white-space:nowrap}
.fc-btn-primary{background:linear-gradient(135deg,var(--teal),var(--teal-dim));color:#fff;box-shadow:0 6px 20px rgba(0,212,170,.3)}
.fc-btn-primary:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(0,212,170,.5)}
.fc-btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-dim));color:#fff;box-shadow:0 6px 20px rgba(240,165,0,.25)}
.fc-btn-gold:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(240,165,0,.45)}
.fc-btn-outline{border:1.5px solid rgba(255,255,255,.2);color:var(--white);background:transparent}
.fc-btn-outline:hover{border-color:var(--teal);color:var(--teal);background:rgba(0,212,170,.04)}
.fc-btn-outline-gold{border:1.5px solid rgba(240,165,0,.35);color:var(--gold);background:transparent}
.fc-btn-outline-gold:hover{border-color:var(--gold);background:rgba(240,165,0,.07)}
.fc-btn-sm{padding:9px 18px;font-size:13px;border-radius:8px}
.fc-btn-lg{padding:16px 34px;font-size:15px;border-radius:12px}
.fc-btn-full{width:100%;justify-content:center}

/* ─────────────────────────────────────────────────
   CARDS
───────────────────────────────────────────────── */
.fc-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--rl);transition:var(--t)}
.fc-card-hover:hover{border-color:rgba(0,212,170,.3);box-shadow:var(--sh-teal);transform:translateY(-5px)}

/* ─────────────────────────────────────────────────
   BADGES & TAGS
───────────────────────────────────────────────── */
.fc-badge{display:inline-flex;align-items:center;font-size:10px;font-weight:800;font-family:var(--fb);letter-spacing:1.5px;text-transform:uppercase;padding:4px 11px;border-radius:100px}
.badge-teal{background:rgba(0,212,170,.12);color:var(--teal);border:1px solid rgba(0,212,170,.22)}
.badge-gold{background:rgba(240,165,0,.12);color:var(--gold);border:1px solid rgba(240,165,0,.22)}
.badge-red{background:rgba(255,107,107,.12);color:var(--red);border:1px solid rgba(255,107,107,.22)}
.badge-purple{background:rgba(167,139,250,.12);color:var(--purple);border:1px solid rgba(167,139,250,.22)}
.badge-pink{background:rgba(244,114,182,.12);color:var(--pink);border:1px solid rgba(244,114,182,.22)}
.fc-tag{display:inline-flex;font-size:11px;font-weight:600;font-family:var(--fb);padding:3px 9px;border-radius:100px;background:rgba(0,212,170,.07);color:var(--teal);border:1px solid rgba(0,212,170,.14)}
.fc-tag.gold{background:rgba(240,165,0,.07);color:var(--gold);border-color:rgba(240,165,0,.14)}
.fc-tag.purple{background:rgba(167,139,250,.07);color:var(--purple);border-color:rgba(167,139,250,.14)}
.fc-tag.pink{background:rgba(244,114,182,.07);color:var(--pink);border-color:rgba(244,114,182,.14)}

/* ─────────────────────────────────────────────────
   SECTION HEADERS
───────────────────────────────────────────────── */
.fc-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--fb);font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--teal);margin-bottom:16px}
.fc-eyebrow::before,.fc-eyebrow::after{content:'';display:inline-block;width:26px;height:1px;background:var(--teal)}
.fc-sec-title{font-size:clamp(1.7rem,3.5vw,2.7rem);font-weight:900;margin-bottom:14px;color:var(--white)}
.fc-sec-title .hl{color:var(--teal)}
.fc-sec-title .hg{background:linear-gradient(135deg,var(--gold),#FF8500);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.fc-sec-desc{font-size:15px;color:var(--muted);line-height:1.85}
.fc-sec-hdr{text-align:center;max-width:700px;margin:0 auto 56px}

/* ─────────────────────────────────────────────────
   MARQUEE STRIP
───────────────────────────────────────────────── */
.fc-marquee-outer{overflow:hidden;position:relative}
.fc-marquee-inner{display:flex;gap:60px;align-items:center;animation:fcMarquee 26s linear infinite;width:max-content}
.fc-marquee-inner:hover{animation-play-state:paused}
@keyframes fcMarquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.fc-co-pill{display:flex;align-items:center;gap:8px;font-family:var(--fb);font-size:14px;font-weight:700;color:rgba(255,255,255,.5);white-space:nowrap;transition:var(--t)}
.fc-co-pill:hover{color:var(--white)}
.fc-co-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

/* ─────────────────────────────────────────────────
   STATS
───────────────────────────────────────────────── */
.fc-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;background:transparent;border-radius:0;overflow:visible;padding:0}
.fc-stat{background:transparent;padding:38px 24px;text-align:center;position:relative;overflow:visible;transition:var(--t);box-shadow:none!important;border:none}
/* fc-stat::after decorative line removed */
.fc-stat:hover::after{transform:scaleX(1)}
.fc-stat-num{font-family:var(--fh);font-size:2.6rem;font-weight:900;line-height:1;background:linear-gradient(135deg,var(--white),var(--teal));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px}
.fc-stat-label{font-size:13px;color:var(--muted);font-weight:500}

/* ─────────────────────────────────────────────────
   COURSE CARDS
───────────────────────────────────────────────── */
.fc-courses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:22px}
.fc-course-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--rl);overflow:hidden;transition:var(--t);position:relative;display:flex;flex-direction:column}
.fc-course-card:hover{transform:translateY(-7px);border-color:rgba(0,212,170,.32);box-shadow:var(--sh-card),var(--sh-teal)}
.cc-img{position:relative;overflow:hidden;flex-shrink:0}
.cc-img img{width:100%;height:185px;object-fit:cover;transition:transform .45s ease;display:block}
/* fc-cc-img-wrap (courses page v2 cards) needs its own rules */
.fc-cc-img-wrap{position:relative;overflow:hidden;height:200px;flex-shrink:0;background:linear-gradient(135deg,rgba(0,212,170,.08),rgba(5,9,15,.8));display:grid;place-items:center}
.fc-cc-img-wrap img{position:absolute;top:50%;left:50%;width:84%;height:84%;transform:translate(-50%,-50%);object-fit:contain;display:block;transition:transform .5s}
.fc-course-card:hover .cc-img img{transform:translate(-50%,-50%) scale(1.05)}
.cc-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(12,18,32,.9) 100%)}
.cc-cat{position:absolute;top:13px;left:13px;backdrop-filter:blur(8px)}
.cc-flag{position:absolute;top:13px;right:13px}
.cc-dur{position:absolute;bottom:13px;right:13px;font-size:11px;font-weight:700;font-family:var(--fb);color:rgba(240,246,255,.9);background:rgba(5,9,15,.7);padding:3px 9px;border-radius:100px}
.cc-body{padding:20px;flex:1;display:flex;flex-direction:column}
.cc-title{font-family:var(--fh);font-size:13.5px;font-weight:800;color:var(--white);line-height:1.3;margin-bottom:8px}
.cc-desc{font-size:13px;color:var(--muted);line-height:1.7;margin-bottom:12px;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cc-tags{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:14px}
.cc-foot{padding:13px 20px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:8px;flex-shrink:0}
.cc-meta{display:flex;gap:12px}
.cc-meta-item{font-size:11.5px;color:var(--muted);display:flex;align-items:center;gap:4px;font-family:var(--fb)}
.cc-know-btn{padding:7px 16px;border-radius:7px;font-size:12px;font-weight:700;font-family:var(--fb);background:linear-gradient(135deg,var(--teal),var(--teal-dim));color:#fff;box-shadow:0 3px 10px rgba(0,212,170,.2);transition:var(--t);flex-shrink:0}
.cc-know-btn:hover{transform:translateY(-2px);box-shadow:0 7px 18px rgba(0,212,170,.4)}
/* ════════════════════════════════════════════════════════════════
   FC COURSE CARD v2 — Complete global definition
   Used on: All Courses page, Category pages, Home page
════════════════════════════════════════════════════════════════ */
.fc-courses-grid-v2{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));column-gap:22px;row-gap:40px;padding-top:30px}
.fc-course-card-v2{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--rl);overflow:visible;transition:var(--t);display:flex;flex-direction:column;position:relative}
.fc-course-card-v2:hover{transform:translateY(-5px);border-color:rgba(0,212,170,.25);box-shadow:0 16px 40px rgba(0,0,0,.35),var(--sh-teal,0 0 24px rgba(0,212,170,.15))}
.fc-cc-img-wrap{position:relative;overflow:hidden;height:200px;flex-shrink:0;background:linear-gradient(135deg,rgba(0,212,170,.08),rgba(5,9,15,.8));display:grid;place-items:center}
.fc-cc-img-wrap img{position:absolute;top:50%;left:50%;width:84%;height:84%;transform:translate(-50%,-50%);object-fit:contain;display:block;transition:transform .5s}
.fc-course-card-v2:hover .fc-cc-img-wrap img{transform:translate(-50%,-50%) scale(1.04)}
.fc-cc-img-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,9,15,0) 40%,rgba(5,9,15,.85) 100%)}
.fc-cc-img-badges{position:absolute;top:12px;left:12px;display:flex;gap:6px;flex-wrap:wrap}
.fc-cc-hot-badge{position:absolute;top:0;right:0;transform:translateY(-100%);z-index:10}
.fc-cc-img-footer{position:absolute;bottom:0;left:0;right:0;padding:10px 14px;display:flex;align-items:center;justify-content:space-between}
.fc-cc-dur-pill{background:rgba(5,9,15,.7);border:1px solid rgba(255,255,255,.15);border-radius:100px;padding:3px 10px;font-size:11px;font-weight:700;color:rgba(255,255,255,.9);font-family:var(--fb);backdrop-filter:blur(8px)}
.fc-cc-rating-v2{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:700;color:#fff;font-family:var(--fb)}
.fc-cc-body-v2{padding:16px;flex:1;display:flex;flex-direction:column}
.fc-cc-students{font-size:11px;color:rgba(0,212,170,.8);font-weight:700;font-family:var(--fb);margin-bottom:8px}
.fc-cc-title-v2{font-size:18px;font-weight:800;color:#fff;margin-bottom:7px;line-height:1.28}
.fc-cc-desc-v2{font-size:12.5px;color:var(--muted);line-height:1.65;margin-bottom:11px;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.fc-cc-tools-v2{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:12px}
.fc-cc-tool{padding:3px 9px;border-radius:5px;font-size:11px;font-weight:600;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:var(--muted);font-family:var(--fb)}
.fc-cc-modes{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px}
.fc-cc-mode-pill{padding:2px 8px;border-radius:100px;font-size:10.5px;font-weight:700;background:rgba(0,212,170,.08);border:1px solid rgba(0,212,170,.15);color:var(--teal);font-family:var(--fb)}
.fc-cc-footer-v2{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;border-top:1px solid var(--border);background:rgba(0,0,0,.12);flex-shrink:0}
.fc-cc-meta-v2{display:flex;gap:12px}
.fc-cc-meta-item-v2{font-size:11.5px;color:var(--muted);font-family:var(--fb)}
.fc-cc-btn-v2{padding:7px 15px;border-radius:8px;background:var(--teal);color:#fff;font-size:12px;font-weight:700;text-decoration:none;transition:var(--t);font-family:var(--fb);white-space:nowrap}
.fc-cc-btn-v2:hover{background:#00b89a;color:#fff}


/* ─────────────────────────────────────────────────
   STAR RATING DISPLAY
───────────────────────────────────────────────── */
.fc-stars{display:inline-flex;gap:2px}
.fc-star{font-size:13px;color:#3a3a3a}
.fc-star.on{color:var(--gold)}

/* ─────────────────────────────────────────────────
   TESTIMONIALS SLIDER
───────────────────────────────────────────────── */
.fc-tsl-outer{overflow:hidden;position:relative}
.fc-tsl-track{display:flex;gap:20px;transition:transform .55s cubic-bezier(.4,0,.2,1)}
.fc-tsl-card{flex-shrink:0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--rl);padding:28px;position:relative;transition:var(--t)}
.fc-tsl-card::before{content:'"';position:absolute;top:-6px;left:22px;font-size:72px;font-family:var(--fh);color:var(--teal);opacity:.1;line-height:1}
.fc-tsl-card:hover{border-color:rgba(0,212,170,.3);transform:translateY(-4px)}
.fc-tsl-stars{display:flex;gap:3px;margin-bottom:13px}
.fc-tsl-star{color:var(--gold);font-size:13px}
.fc-tsl-text{font-size:13.5px;line-height:1.8;color:var(--muted);font-style:italic;margin-bottom:20px}
.fc-tsl-author{display:flex;align-items:center;gap:13px}
.fc-tsl-avatar{width:46px;height:46px;border-radius:50%;overflow:hidden;flex-shrink:0;border:2px solid var(--border);background:linear-gradient(135deg,var(--teal-dim),var(--bg-card));display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:15px;font-weight:800;color:var(--white)}
.fc-tsl-avatar img{width:100%;height:100%;object-fit:cover}
.fc-tsl-name{font-size:14px;font-weight:700;color:var(--white);font-family:var(--fb)}
.fc-tsl-role{font-size:12px;color:var(--muted);font-family:var(--fb)}
.fc-tsl-co{color:var(--teal);font-weight:600}
.fc-slider-nav{display:flex;justify-content:center;align-items:center;gap:14px;margin-top:36px}
.fc-sl-btn{width:42px;height:42px;border-radius:50%;border:1px solid var(--border);background:var(--bg-card);color:var(--white);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--t)}
.fc-sl-btn:hover{background:var(--teal);border-color:var(--teal)}
.fc-sl-dots{display:flex;gap:7px}
.fc-sl-dot{width:7px;height:7px;border-radius:50%;background:var(--border);cursor:pointer;transition:var(--t);border:none}
.fc-sl-dot.on{background:var(--teal);width:22px;border-radius:100px}

/* ─────────────────────────────────────────────────
   FORMS
───────────────────────────────────────────────── */
.fc-fg{margin-bottom:16px}
.fc-fg label{display:block;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:7px;font-family:var(--fb)}
.fc-fg input,.fc-fg select,.fc-fg textarea{width:100%;padding:12px 15px;background:rgba(255,255,255,.03);border:1.5px solid var(--border);border-radius:9px;color:var(--white);font-size:14px;font-family:var(--fb);transition:var(--t);-webkit-appearance:none;appearance:none}
.fc-fg select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2300D4AA' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 13px center;padding-right:36px;background-color:rgba(12,18,32,.9)}
.fc-fg select option{background:#0C1220;color:var(--white)}
.fc-fg input:focus,.fc-fg select:focus,.fc-fg textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(0,212,170,.1);background:rgba(0,212,170,.02)}
.fc-fg input::placeholder,.fc-fg textarea::placeholder{color:rgba(122,144,176,.45)}
.fc-fg textarea{resize:vertical;min-height:88px;line-height:1.65}
.fc-form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fc-form-check{display:flex;align-items:flex-start;gap:9px;margin-bottom:18px}
.fc-form-check input[type=checkbox]{width:16px;height:16px;margin-top:3px;accent-color:var(--teal);cursor:pointer;flex-shrink:0}
.fc-form-check label{font-size:13px;color:var(--muted);cursor:pointer;font-weight:400;text-transform:none;letter-spacing:0;font-family:var(--fb)}
.fc-form-check label a{color:var(--teal);text-decoration:underline}
.fc-submit{width:100%;padding:14px;border-radius:9px;font-size:14px;font-weight:700;background:linear-gradient(135deg,var(--teal),var(--teal-dim));color:#fff;box-shadow:0 5px 18px rgba(0,212,170,.28);transition:var(--t);display:flex;align-items:center;justify-content:center;gap:8px;font-family:var(--fb);cursor:pointer;border:none;letter-spacing:.2px}
.fc-submit:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(0,212,170,.5)}
.fc-submit:disabled{opacity:.6;cursor:default;transform:none}

/* ─────────────────────────────────────────────────
   ACCORDION (Curriculum)
───────────────────────────────────────────────── */
.fc-acc-item{border:1px solid var(--border);border-radius:10px;overflow:hidden;margin-bottom:9px}
.fc-acc-header{display:flex;align-items:center;justify-content:space-between;padding:15px 18px;cursor:pointer;background:rgba(255,255,255,.02);transition:var(--t)}
.fc-acc-header:hover{background:rgba(0,212,170,.04)}
.fc-acc-header h3{font-size:14px;font-weight:600;color:var(--white);margin:0;flex:1}
.fc-acc-meta{font-size:11.5px;color:var(--muted);margin-right:12px;white-space:nowrap;font-family:var(--fb)}
.fc-acc-arr{color:var(--teal);font-size:18px;transition:var(--t);flex-shrink:0}
.fc-acc-header.open .fc-acc-arr{transform:rotate(180deg)}
.fc-acc-body{display:none;padding:0 18px 15px;border-top:1px solid var(--border)}
.fc-acc-body.open{display:block}
.fc-acc-sub{font-size:13px;font-weight:700;color:var(--teal);margin:13px 0 8px;font-family:var(--fb)}
.fc-acc-body ul{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}
.fc-acc-body ul li{display:flex;align-items:flex-start;gap:8px;font-size:13.5px;color:var(--muted)}
.fc-acc-body ul li::before{content:'▷';color:var(--teal);font-size:10px;flex-shrink:0;margin-top:3px}

/* ─────────────────────────────────────────────────
   FAQ
───────────────────────────────────────────────── */
.fc-faq-item{border:1px solid var(--border);border-radius:10px;overflow:hidden;margin-bottom:9px}
.fc-faq-q{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;cursor:pointer;font-family:var(--fb);font-size:14px;font-weight:600;color:var(--white);background:rgba(255,255,255,.02);transition:var(--t)}
.fc-faq-q:hover{background:rgba(0,212,170,.04);color:var(--teal)}
.fc-faq-arr{color:var(--teal);font-size:18px;transition:var(--t);flex-shrink:0}
.fc-faq-item.open .fc-faq-arr{transform:rotate(180deg)}
.fc-faq-a{display:none;padding:13px 18px;font-size:13.5px;color:var(--muted);line-height:1.8;border-top:1px solid var(--border)}
.fc-faq-item.open .fc-faq-a{display:block}

/* ─────────────────────────────────────────────────
   PAGE HERO (inner pages)
───────────────────────────────────────────────── */
.fc-page-hero{padding:calc(var(--nav-h) + 64px) 0 64px;text-align:center;position:relative;z-index:1;overflow:hidden}
.fc-page-hero::before{content:'';position:absolute;top:-80px;left:50%;transform:translateX(-50%);width:900px;height:500px;background:radial-gradient(ellipse,rgba(0,212,170,.06) 0%,transparent 70%);pointer-events:none}
.fc-hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(0,212,170,.08);border:1px solid rgba(0,212,170,.22);border-radius:100px;padding:6px 15px;font-size:11px;font-weight:700;color:var(--teal);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:18px;font-family:var(--fb)}
.fc-hero-badge .live-dot{width:7px;height:7px;background:var(--teal);border-radius:50%;animation:fcPulse 1.5s ease infinite}
.fc-page-hero h1{font-size:clamp(1.9rem,5vw,3.5rem);margin-bottom:16px}
.fc-page-hero .sub{font-size:16px;color:var(--muted);max-width:620px;margin:0 auto 26px;line-height:1.82}

/* Breadcrumb */
.fc-crumb{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);margin-bottom:18px;justify-content:center;flex-wrap:wrap;font-family:var(--fb)}
.fc-crumb a{color:var(--muted);transition:var(--t)}
.fc-crumb a:hover{color:var(--teal)}
.fc-crumb .sep{color:rgba(122,144,176,.35)}
.fc-crumb .cur{color:var(--teal);font-weight:600}

/* ─────────────────────────────────────────────────
   REVEAL ANIMATIONS
───────────────────────────────────────────────── */
.fc-rev{opacity:0;transform:translateY(26px);transition:opacity .65s ease,transform .65s ease}
.fc-rev.in{opacity:1;transform:translateY(0)}
.fc-rev.fl{transform:translateX(-26px)}.fc-rev.fl.in{transform:translateX(0)}
.fc-rev.fr{transform:translateX(26px)}.fc-rev.fr.in{transform:translateX(0)}
.fc-rev.sc{transform:scale(.9)}.fc-rev.sc.in{transform:scale(1)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}
.d4{transition-delay:.4s}.d5{transition-delay:.5s}

/* Keyframes */
@keyframes fcPulse{0%,100%{box-shadow:0 0 0 0 rgba(0,212,170,.5)}50%{box-shadow:0 0 0 10px rgba(0,212,170,0)}}
@keyframes fcBlink{0%,100%{opacity:1}50%{opacity:0}}
@keyframes fcFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@keyframes fcSpin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes fcScaleIn{from{transform:scale(.88);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes fcGlow{0%,100%{box-shadow:0 0 20px rgba(0,212,170,.2)}50%{box-shadow:0 0 50px rgba(0,212,170,.5)}}

/* ─────────────────────────────────────────────────
   TOOLTIPS
───────────────────────────────────────────────── */
[data-tip]{position:relative}
[data-tip]::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:#111827;border:1px solid var(--border);color:var(--white);font-size:11px;font-weight:500;padding:6px 12px;border-radius:7px;white-space:nowrap;pointer-events:none;opacity:0;transition:var(--t);z-index:100;font-family:var(--fb)}
[data-tip]:hover::after{opacity:1}

/* ─────────────────────────────────────────────────
   FOOTER
───────────────────────────────────────────────── */
#fc-footer{background:var(--bg-card);border-top:1px solid var(--border);padding:60px 0 0;position:relative;z-index:1}
.fc-footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px;padding:0 clamp(16px,5%,80px)}
.fc-footer-about p{font-size:13.5px;color:var(--off-white);opacity:.9;line-height:1.82;margin:14px 0 20px}
.fc-footer-socials{display:flex;gap:8px}
.fc-soc{width:36px;height:36px;border-radius:9px;border:1px solid var(--border);background:rgba(255,255,255,.03);display:flex;align-items:center;justify-content:center;font-size:15px;transition:var(--t)}
.fc-soc:hover{background:rgba(0,212,170,.1);border-color:rgba(0,212,170,.3)}
.fc-footer-col h4{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--white);margin-bottom:16px;font-family:var(--fb)}
.fc-footer-col ul{display:flex;flex-direction:column;gap:9px}
.fc-footer-col ul li a{font-size:13px;color:var(--off-white);opacity:.85;transition:var(--t)}
.fc-footer-col ul li a:hover{color:var(--teal);opacity:1;padding-left:4px}
.fc-footer-bottom{border-top:1px solid var(--border);padding:20px clamp(16px,5%,80px);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.fc-footer-bottom p,.fc-footer-bottom a{font-size:12px;color:rgba(220,235,255,.5);font-family:var(--fb)}
.fc-footer-bottom a:hover{color:var(--teal);opacity:1}
.fc-fv{font-size:10px;color:var(--white);opacity:.3;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.05);padding:3px 11px;border-radius:100px;letter-spacing:1px;font-family:var(--fb)}

/* ─────────────────────────────────────────────────
   WHATSAPP — LEFT SIDE
───────────────────────────────────────────────── */
#fc-wa{
  position:fixed;bottom:28px;left:28px;z-index:990;
  width:54px;height:54px;border-radius:50%;
  background:linear-gradient(135deg,#25D366,#128C7E);
  display:flex;align-items:center;justify-content:center;font-size:27px;
  box-shadow:0 6px 24px rgba(37,211,102,.4);
  animation:fcFloat 3.2s ease-in-out infinite;
  cursor:pointer;transition:transform .2s ease;
}
#fc-wa:hover{transform:scale(1.12);animation:none;box-shadow:0 12px 34px rgba(37,211,102,.6)}
#fc-wa .wa-tip{
  position:absolute;LEFT:62px;top:50%;transform:translateY(-50%);
  background:#111827;border:1px solid var(--border);border-radius:8px;
  padding:7px 13px;font-size:12px;font-weight:600;white-space:nowrap;
  opacity:0;pointer-events:none;transition:var(--t);font-family:var(--fb);color:var(--white);
}
#fc-wa:hover .wa-tip{opacity:1}

/* ─────────────────────────────────────────────────
   PRICE REVEAL BOX
───────────────────────────────────────────────── */
.fc-price-box{
  background:linear-gradient(135deg,rgba(0,212,170,.06),rgba(240,165,0,.03));
  border:1px solid rgba(0,212,170,.2);border-radius:var(--rl);
  padding:32px;text-align:center;position:relative;overflow:hidden;
}
.fc-price-hidden{display:flex;flex-direction:column;align-items:center;gap:16px}
.fc-price-reveal-btn{
  padding:12px 28px;border-radius:10px;font-size:14px;font-weight:700;
  background:linear-gradient(135deg,var(--teal),var(--teal-dim));
  color:#fff;cursor:pointer;border:none;font-family:var(--fb);
  box-shadow:0 5px 18px rgba(0,212,170,.28);transition:var(--t);
  display:inline-flex;align-items:center;gap:8px;
}
.fc-price-reveal-btn:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(0,212,170,.48)}
.fc-price-revealed{display:none}
.fc-price-amount{font-family:var(--fh);font-size:2.4rem;font-weight:900;color:var(--white);margin-bottom:4px}
.fc-price-note{font-size:12px;color:var(--muted);margin-bottom:20px}

/* ─────────────────────────────────────────────────
   COURSE DETAIL — FULL SCREEN LAYOUT
───────────────────────────────────────────────── */
.fc-course-detail{padding-top:var(--nav-h)}
.fc-course-hero{
  position:relative;width:100%;height:clamp(280px,45vw,560px);
  overflow:hidden;
}
.fc-course-hero img{width:100%;height:100%;object-fit:cover;display:block}
.fc-course-hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(5,9,15,.3) 0%,rgba(5,9,15,.85) 100%);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:clamp(20px,5%,60px);
}
.fc-course-tabs-bar{
  position:sticky;top:var(--nav-h);z-index:100;
  background:rgba(5,9,15,.95);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  display:flex;overflow-x:auto;
  scrollbar-width:none;
}
.fc-course-tabs-bar::-webkit-scrollbar{display:none}
.fc-ctab{
  padding:14px 22px;font-size:13.5px;font-weight:700;color:var(--white);
  border-bottom:2.5px solid transparent;cursor:pointer;background:none;
  transition:var(--t);white-space:nowrap;font-family:var(--fb);opacity:.65;
  border-top:0;border-left:0;border-right:0;
}
.fc-ctab:hover{opacity:1;color:var(--teal)}
.fc-ctab.on{color:var(--teal);border-bottom-color:var(--teal);opacity:1}
.fc-ctab-pane{display:none}
.fc-ctab-pane.on{display:block;animation:fcScaleIn .3s ease}
.fc-course-main{max-width:1100px;margin:0 auto;padding:0 clamp(16px,5%,60px) 80px}

/* ─────────────────────────────────────────────────
   BATCH CARDS
───────────────────────────────────────────────── */
.fc-batch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px}
.fc-batch-card{background:var(--bg-card);border:1px solid var(--border);border-radius:13px;padding:22px;text-align:center;transition:var(--t)}
.fc-batch-card:hover{border-color:rgba(0,212,170,.3);transform:translateY(-3px)}
.fc-batch-card.feat{border-color:var(--teal);background:linear-gradient(135deg,rgba(0,212,170,.07),var(--bg-card))}
.fc-batch-type{font-size:10px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--teal);margin-bottom:9px;font-family:var(--fb)}
.fc-batch-sched{font-family:var(--fb);font-size:13px;font-weight:700;color:var(--white);margin-bottom:4px}
.fc-batch-time{font-size:12px;color:var(--muted);font-family:var(--fb)}
.fc-batch-seats{display:inline-block;margin:10px 0;font-size:11px;font-weight:700;font-family:var(--fb);padding:3px 12px;border-radius:100px;background:rgba(255,107,107,.1);color:var(--red);border:1px solid rgba(255,107,107,.2)}

/* ─────────────────────────────────────────────────
   SUCCESS STATE
───────────────────────────────────────────────── */
.fc-success{display:none;text-align:center;padding:32px 16px;animation:fcScaleIn .4s ease}
.fc-success-icon{font-size:54px;margin-bottom:13px}
.fc-success h3{font-family:var(--fh);font-size:19px;font-weight:800;color:var(--white);margin-bottom:9px}
.fc-success p{font-size:14px;color:var(--muted);line-height:1.72}

/* ─────────────────────────────────────────────────
   BECOME A TRAINER STEPS
───────────────────────────────────────────────── */
.fc-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:0;position:relative}
.fc-steps::before{content:'';position:absolute;top:44px;left:calc(100%/6);right:calc(100%/6);height:2px;background:linear-gradient(90deg,var(--teal),var(--gold));z-index:0}
.fc-step{text-align:center;padding:0 24px;position:relative;z-index:1}
.fc-step-num{width:88px;height:88px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--teal-dim));display:flex;align-items:center;justify-content:center;margin:0 auto 20px;box-shadow:0 0 28px rgba(0,212,170,.35)}
.fc-step-num span{font-family:var(--fh);font-size:1.6rem;font-weight:900;color:#fff}
.fc-step h3{font-size:16px;margin-bottom:9px}
.fc-step p{font-size:13.5px;color:var(--muted);line-height:1.75}

/* =============================================================
   COMPREHENSIVE RESPONSIVE — Mobile-First
   Supports: 320px → 4K | Mobile, Tablet, Desktop, TV
   ============================================================= */

/* ── 1280px: Large desktop adjustments ── */
@media(max-width:1280px){
  .fc-wrap{padding:0 clamp(20px,4%,60px)}
}

/* ── 1100px: Medium desktop ── */
@media(max-width:1100px){
  .fc-footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .fc-stats-grid{grid-template-columns:repeat(2,1fr)}
  /* Course grid to 2 cols */
  .fc-courses-grid{grid-template-columns:repeat(2,1fr)!important}
  .fc-courses-grid-v2{grid-template-columns:repeat(2,1fr)!important}
  /* Pricing to 2 cols */
  .fc-pricing-grid{grid-template-columns:repeat(2,1fr)!important}
  /* Course detail sidebar stacks */
  .fc-course-grid{grid-template-columns:1fr!important}
  .fc-course-sidebar{position:static!important}
  /* Courses layout sidebar stacks */
  .fc-courses-layout{grid-template-columns:1fr!important}
}

/* ── 960px: Small desktop / large tablet ── */
@media(max-width:960px){
  .fc-hero-2col{grid-template-columns:1fr!important}
  .fc-hero-2col > div:last-child{display:none}
  .fc-why-2col{grid-template-columns:1fr!important}
  .fc-enroll-2col{grid-template-columns:1fr!important}
  .fc-schools-grid{grid-template-columns:repeat(2,1fr)!important}
  .fc-happy-grid{grid-template-columns:1fr!important}
  .fc-cph-grid{grid-template-columns:1fr!important}
  .fc-related-grid{grid-template-columns:repeat(2,1fr)!important}
  /* Trainer section image full width */
  .fc-why-2col > div:first-child img{height:280px!important}
}

/* ── 900px: Tablet/mobile ── */
@media(max-width:900px){
  /* Nav */
  .fc-nav-menu,.fc-nav-actions{display:none}
  .fc-burger{display:flex}
  :root{--nav-h:60px}
  /* Spacing */
  .fc-pad{padding:52px 0}
  .fc-pad-sm{padding:36px 0}
  /* Forms */
  .fc-form-row{grid-template-columns:1fr!important}
  /* Steps */
  .fc-steps{grid-template-columns:1fr!important}
  .fc-steps::before{display:none}
  /* Course cards to 1 col */
  .fc-courses-grid{grid-template-columns:1fr!important}
  .fc-courses-grid-v2{grid-template-columns:1fr!important}
  /* Stats 2 col on tablet */
  .fc-stats-grid{grid-template-columns:repeat(2,1fr)!important}
  /* Trainer card stack */
  .fc-trainer-card{flex-direction:column!important}
  .fc-trainer-stats{grid-template-columns:repeat(2,1fr)!important}
  /* Find more grid */
  .fc-find-grid{grid-template-columns:repeat(2,1fr)!important}
  /* Batch grid */
  .fc-batches-grid{grid-template-columns:1fr!important}
  /* Placement stats */
  .fc-placement-strip{flex-direction:column!important}
  .fc-ps-item{border-right:none!important;border-bottom:1px solid var(--border)!important;min-width:100%!important}
  .fc-ps-item:last-child{border:none!important}
  /* Why 2col stack */
  .fc-why-2col{gap:32px!important}
  /* Trainer mini card stack */
  .fc-trainer-mini-card{flex-direction:column!important;text-align:center!important}
  /* Hss grid */
  .fc-hss-grid{grid-template-columns:repeat(2,1fr)!important}
  /* Schools grid */
  .fc-schools-grid{grid-template-columns:1fr!important}
}

/* ── 768px: Mobile landscape / tablet portrait ── */
@media(max-width:768px){
  /* Pricing */
  .fc-pricing-grid{grid-template-columns:1fr!important}
  /* Trainer CTA — critical mobile fix */
  .fc-trainercta-wrap{
    flex-direction:column!important;
    text-align:center!important;
    padding:28px 20px!important;
    gap:20px!important;
  }
  .fc-trainercta-wrap > div:last-child{align-self:center!important}
  /* Contact 3 cards */
  [style*="grid-template-columns:1fr 1fr 1fr"]{grid-template-columns:1fr!important}
  /* Free strip */
  .fc-free-strip{flex-wrap:wrap!important;gap:8px!important}
  .fc-free-pill{min-width:calc(50% - 4px)!important;flex:0 0 auto!important}
  /* Hero padding */
  section#home{padding-top:calc(var(--nav-h) + 24px)!important;padding-bottom:40px!important;min-height:auto!important}
  /* Footer */
  .fc-footer-grid{grid-template-columns:1fr!important}
  .fc-footer-bottom{flex-direction:column!important;text-align:center!important;gap:8px!important}
  /* Batch options on courses page */
  [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}
  /* Course detail tabs */
  .fc-stab{padding:11px 14px!important;font-size:12px!important}
  /* Syllabus stats */
  .fc-syl-stats{flex-wrap:wrap!important;gap:14px!important}
  /* Acc body indent */
  .fc-acc-body{padding-left:16px!important}
  /* Why trainer strip */
  .fc-trainer-strip{flex-direction:column!important;text-align:center!important}
}

/* ── 600px: Mobile standard ── */
@media(max-width:600px){
  /* Typography scale */
  h1{font-size:clamp(1.65rem,7vw,2.2rem)!important}
  h2{font-size:clamp(1.35rem,5.5vw,1.8rem)!important}
  h3{font-size:clamp(1.1rem,4vw,1.4rem)!important}
  /* Buttons */
  .fc-btn-lg{padding:13px 22px!important;font-size:13.5px!important}
  .fc-hero-ctas{gap:10px!important}
  .fc-hero-ctas .fc-btn{width:100%;justify-content:center!important}
  /* Stats — 2×2 grid on mobile */
  .fc-stats-grid{
    grid-template-columns:repeat(2,1fr)!important;
    gap:12px!important;
  }
  .fc-stat-num{font-size:1.6rem!important}
  /* Cat tabs scroll */
  .fc-cat-tabs{overflow-x:auto!important;flex-wrap:nowrap!important;padding-bottom:6px!important;gap:6px!important;-webkit-overflow-scrolling:touch!important}
  .fc-cat-tab{flex-shrink:0!important}
  /* Course cards */
  .fc-courses-grid{grid-template-columns:1fr!important}
  .fc-courses-grid-v2{grid-template-columns:1fr!important}
  /* Pricing */
  .fc-pricing-grid{grid-template-columns:1fr!important}
  /* Batch */
  .fc-batch-grid{grid-template-columns:1fr!important}
  .fc-batches-grid{grid-template-columns:1fr!important}
  /* Related */
  .fc-related-grid{grid-template-columns:1fr!important}
  /* Pkg grid */
  .fc-pkg-grid{grid-template-columns:1fr!important}
  /* Find more */
  .fc-find-grid{grid-template-columns:1fr!important}
  /* Hss stats on course listing hero */
  .fc-hss-grid{grid-template-columns:repeat(2,1fr)!important;gap:10px!important}
  /* Enroll form */
  .fc-course-body{padding:28px 16px 60px!important}
  /* Hero on mobile */
  .fc-course-hero-full{min-height:40svh!important}
  .fc-course-hero-content{padding:28px 16px 28px!important}
  /* Section padding */
  .fc-sec-hdr{margin-bottom:24px!important}
  .fc-section-head{margin:36px 0 18px!important}
  /* Trainer section image */
  .fc-why-2col img{height:220px!important}
  /* Why item gap */
  .fc-why-item-v2{padding:12px 0!important}
  /* Batch info bar */
  [style*="padding:18px 22px"]{padding:14px 16px!important}
  /* Placement stats */
  .fc-placement-strip{flex-direction:column!important}
  /* Price main */
  .fc-price-main{font-size:1.6rem!important}
  /* Sidebar */
  .fc-sidebar-body{padding:16px!important}
  /* Trainer stats */
  .fc-trainer-stats{grid-template-columns:repeat(2,1fr)!important}
  /* WA button — move slightly on mobile */
  #fc-wa{bottom:80px!important;left:16px!important;width:48px!important;height:48px!important;font-size:22px!important}
  /* Hero stats on home page */
  [data-counter-group]{gap:16px!important}
  /* Marquee label */
  .fc-marquee-section p{font-size:10px!important}
  /* Mobile tabs */
  .fc-stab-inner{padding:0 2px!important}
  .fc-stab{padding:10px 12px!important;font-size:11.5px!important}
  /* Form grid */
  .fc-mb-grid{grid-template-columns:1fr!important}
  /* Courses CTA */
  .fc-courses-cta{padding:28px 20px!important}
}

/* ── 480px: Small mobiles (SE, older Android) ── */
@media(max-width:480px){
  :root{--nav-h:56px}
  h1{font-size:clamp(1.5rem,7vw,2rem)!important}
  /* Wrap padding */
  .fc-wrap{padding:0 14px!important}
  /* Course hero */
  .fc-course-hero-full{min-height:36svh!important}
  /* Stat numbers */
  .fc-hss-num{font-size:1.4rem!important}
  .fc-stat-num{font-size:1.5rem!important}
  /* Pricing cards */
  .fc-price-main{font-size:1.5rem!important}
  /* Form inputs */
  .fc-fg input,.fc-fg select,.fc-fg textarea{font-size:16px!important} /* prevent zoom on iOS */
  /* Prevent iOS input zoom */
  input,select,textarea{font-size:16px!important}
  /* CTA banner trainer */
  .fc-trainercta-wrap h2{font-size:1.35rem!important}
  /* Batch label */
  .fc-batch-lbl,.fc-batch-type{font-size:10px!important;letter-spacing:.5px!important}
  /* Acc accordion */
  .fc-acc-head{padding:12px 14px!important}
  .fc-acc-title{font-size:13px!important}
  /* Category tabs */
  .fc-cat-tab{padding:7px 14px!important;font-size:12px!important}
}

/* ── 360px: Very small phones ── */
@media(max-width:360px){
  .fc-wrap{padding:0 12px!important}
  .fc-btn{padding:10px 18px!important;font-size:13px!important}
  .fc-free-pill{min-width:100%!important}
}

/* ── Touch devices: 44px minimum tap targets ── */
@media(hover:none) and (pointer:coarse){
  .fc-btn,.fc-ctab,.fc-stab,.fc-cat-tab,.fc-cc-btn-v2,.cc-know-btn{
    min-height:44px!important;
    display:inline-flex!important;
    align-items:center!important;
    justify-content:center!important;
  }
  .fc-sl-btn{width:44px!important;height:44px!important}
  /* Disable hover effects on touch */
  .fc-course-card-v2:hover,.fc-course-card:hover{transform:none!important}
  /* Keep floating cards hidden on touch (they overlap) */
  [style*="fcFloat"]{display:none!important}
}

/* ── High-DPI / Retina screens ── */
@media(-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){
  .fc-logo-img{image-rendering:crisp-edges}
}

/* ── Large screens (1440px+) ── */
@media(min-width:1440px){
  .fc-wrap{max-width:1400px}
  .fc-sec-title{font-size:clamp(1.8rem,2.2vw,2.6rem)}
}

/* ── 4K / ultra-wide ── */
@media(min-width:1920px){
  .fc-wrap{max-width:1600px}
  :root{--nav-h:80px}
}

/* ─────────────────────────────────────────────────
   WP CONTENT STYLES
───────────────────────────────────────────────── */
.wp-content p{color:var(--muted);margin-bottom:14px}
.wp-content h2{font-size:1.8rem;margin:28px 0 12px}
.wp-content h3{font-size:1.3rem;margin:22px 0 9px}
.wp-content ul{list-style:disc;padding-left:20px;color:var(--muted);margin-bottom:14px}
.wp-content img{border-radius:var(--r);margin:16px 0}
.screen-reader-text{clip:rect(1px,1px,1px,1px);position:absolute!important;height:1px;width:1px;overflow:hidden}
.alignleft{float:left;margin:0 22px 14px 0}
.alignright{float:right;margin:0 0 14px 22px}
.aligncenter{margin:0 auto 14px}

/* ─────────────────────────────────────────────────
   PLACEMENTS PAGE (v3.2.7)
───────────────────────────────────────────────── */
.fc-pl-page{padding-top:var(--nav-h);position:relative;z-index:1}
.fc-pl-hero{padding:76px 0 52px;position:relative;overflow:hidden}
.fc-pl-hero::before{
  content:'';position:absolute;right:-110px;top:-150px;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(0,212,170,.22) 0%,rgba(0,212,170,0) 70%);pointer-events:none
}
.fc-pl-hero::after{
  content:'';position:absolute;left:-90px;bottom:-200px;width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(240,165,0,.15) 0%,rgba(240,165,0,0) 70%);pointer-events:none
}
.fc-pl-hero-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:34px;align-items:center}
.fc-pl-kicker{display:inline-flex;align-items:center;padding:7px 14px;border:1px solid rgba(0,212,170,.35);border-radius:100px;background:rgba(0,212,170,.1);font-size:11px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;color:var(--teal)}
.fc-pl-h1{font-size:clamp(2rem,4.2vw,3.35rem);margin:16px 0 12px;line-height:1.12}
.fc-pl-sub{font-size:15px;color:var(--muted);line-height:1.9;max-width:650px}
.fc-pl-keywords{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}
.fc-pl-keywords span{padding:6px 10px;border-radius:100px;font-size:11px;font-weight:600;color:#d9ecff;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.11)}
.fc-pl-hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}

.fc-pl-command{
  border:1px solid var(--border);border-radius:18px;padding:22px;
  background:linear-gradient(160deg,rgba(12,18,32,.95),rgba(7,13,24,.9));
  box-shadow:0 24px 70px rgba(0,0,0,.45),0 0 0 1px rgba(0,212,170,.06) inset
}
.fc-pl-command h3{font-family:var(--fh);font-size:1.05rem;letter-spacing:.4px;margin-bottom:8px}
.fc-pl-command p{font-size:13px;color:var(--muted);line-height:1.75;margin-bottom:14px}
.fc-pl-score{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.fc-pl-score-item{border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:14px;background:rgba(255,255,255,.02)}
.fc-pl-score-item strong{display:block;font-family:var(--fh);font-size:1.55rem;line-height:1;color:var(--white)}
.fc-pl-score-item small{display:block;margin-top:6px;font-size:11.6px;color:var(--muted);line-height:1.55}
.fc-pl-logo-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:13px}
.fc-pl-logo-row span{padding:5px 10px;border-radius:100px;font-size:10.8px;font-weight:700;border:1px solid rgba(0,212,170,.24);color:var(--teal);background:rgba(0,212,170,.08)}

.fc-pl-achievements{padding:18px 0 8px}
.fc-pl-ach-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.fc-pl-ach-card{
  background:linear-gradient(165deg,rgba(12,18,32,.95),rgba(10,16,28,.9));
  border:1px solid var(--border);border-radius:14px;padding:18px;transition:var(--t)
}
.fc-pl-ach-card:hover{transform:translateY(-4px);border-color:rgba(0,212,170,.28);box-shadow:var(--sh-teal)}
.fc-pl-ach-card strong{font-family:var(--fh);font-size:1.42rem;color:var(--teal);display:block;margin-bottom:5px}
.fc-pl-ach-card h3{font-size:14.5px;margin-bottom:6px}
.fc-pl-ach-card p{font-size:12.8px;color:var(--muted);line-height:1.72}

.fc-pl-story-layout{display:grid;grid-template-columns:1.12fr .88fr;gap:16px;align-items:start}
.fc-pl-carousel-wrap{padding:4px 0}
.fc-pl-carousel{position:relative;overflow:hidden;border-radius:16px;border:1px solid var(--border);background:rgba(8,13,24,.85)}
.fc-pl-track{display:flex;transition:transform .45s ease}
.fc-pl-slide{min-width:100%;display:grid;grid-template-columns:1fr 1fr}
.fc-pl-slide img{width:100%;height:350px;object-fit:cover}
.fc-pl-slide-copy{padding:22px;display:flex;flex-direction:column;justify-content:center;background:linear-gradient(135deg,rgba(0,212,170,.06),rgba(240,165,0,.04))}
.fc-pl-slide-copy h3{font-size:1.14rem;margin-bottom:8px}
.fc-pl-slide-copy p{font-size:13.4px;color:var(--muted);line-height:1.82}
.fc-pl-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.fc-pl-meta span{font-size:10.8px;padding:4px 9px;border-radius:100px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.03);color:#d8e8fb}
.fc-pl-car-nav{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:12px}
.fc-pl-car-btn{width:42px;height:42px;border-radius:50%;border:1px solid var(--border);background:rgba(255,255,255,.04);color:var(--white);font-size:19px;display:flex;align-items:center;justify-content:center}
.fc-pl-car-btn:hover{border-color:var(--teal);color:var(--teal)}
.fc-pl-dots{display:flex;align-items:center;justify-content:center;gap:8px;flex:1}
.fc-pl-dots button{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.2);border:0}
.fc-pl-dots button.on{background:var(--teal);box-shadow:0 0 0 4px rgba(0,212,170,.18)}

.fc-pl-story-stack{display:grid;gap:12px}
.fc-pl-story{
  border:1px solid rgba(255,255,255,.09);border-radius:14px;padding:16px;
  background:linear-gradient(165deg,rgba(255,255,255,.02),rgba(255,255,255,.04))
}
.fc-pl-story h3{font-size:14.4px;margin-bottom:6px}
.fc-pl-story p{font-size:12.9px;color:var(--muted);line-height:1.75}
.fc-pl-story .meta{display:flex;flex-wrap:wrap;gap:7px;margin-top:10px}
.fc-pl-story .meta span{font-size:10.6px;padding:4px 8px;border-radius:100px;border:1px solid rgba(0,212,170,.22);color:var(--teal);background:rgba(0,212,170,.08)}

.fc-pl-track-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.fc-pl-track-card{
  border:1px solid var(--border);border-radius:14px;padding:18px;
  background:linear-gradient(165deg,rgba(10,16,28,.95),rgba(12,19,34,.88));transition:var(--t)
}
.fc-pl-track-card:hover{transform:translateY(-4px);box-shadow:var(--sh-teal);border-color:rgba(0,212,170,.28)}
.fc-pl-track-card .ico{display:inline-flex;padding:5px 11px;border-radius:100px;background:rgba(240,165,0,.12);border:1px solid rgba(240,165,0,.26);color:var(--gold);font-size:11px;font-weight:700;margin-bottom:10px}
.fc-pl-track-card h3{font-size:14.5px;margin-bottom:6px}
.fc-pl-track-card p{font-size:12.8px;color:var(--muted);line-height:1.75}

.fc-pl-process{position:relative;padding-top:6px}
.fc-pl-flow{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;position:relative}
.fc-pl-flow::before{
  content:'';position:absolute;left:4%;right:4%;top:52px;height:2px;z-index:0;
  background:linear-gradient(90deg,rgba(0,212,170,.35),rgba(240,165,0,.4))
}
.fc-pl-step{position:relative;z-index:1;background:rgba(12,18,32,.95);border:1px solid var(--border);border-radius:14px;padding:16px;min-height:176px}
.fc-pl-step .num{
  width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:var(--fh);font-size:12px;font-weight:800;color:#fff;margin-bottom:11px;
  background:linear-gradient(135deg,var(--teal),#009778)
}
.fc-pl-step:nth-child(3n) .num{background:linear-gradient(135deg,var(--gold),#ff8500)}
.fc-pl-step h3{font-size:13.9px;margin-bottom:7px}
.fc-pl-step p{font-size:12.7px;color:var(--muted);line-height:1.72}

.fc-pl-bottom-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:16px}
.fc-pl-faq-card{border:1px solid var(--border);border-radius:16px;padding:20px;background:linear-gradient(160deg,rgba(10,16,28,.95),rgba(11,18,31,.9))}
.fc-pl-faq-card .fc-faq-item{border:1px solid rgba(255,255,255,.08)}

.fc-pl-seo{
  padding:22px;border-radius:16px;border:1px solid rgba(240,165,0,.24);
  background:linear-gradient(145deg,rgba(240,165,0,.08),rgba(0,212,170,.05))
}
.fc-pl-seo h2{font-size:1.35rem;margin-bottom:10px}
.fc-pl-seo p{font-size:13.6px;color:#e4f0ff;line-height:1.85;margin-bottom:11px}
.fc-pl-seo-tags{display:flex;gap:8px;flex-wrap:wrap}
.fc-pl-seo-tags span{padding:5px 10px;border-radius:100px;font-size:10.8px;border:1px solid rgba(255,255,255,.18);background:rgba(0,0,0,.18);color:#f6fbff}

.fc-pl-cta{margin-top:26px;padding:28px;border-radius:18px;border:1px solid var(--border);background:linear-gradient(140deg,rgba(0,212,170,.1),rgba(0,212,170,.03))}
.fc-pl-cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}
.fc-pl-cta p{color:var(--muted);font-size:14px;line-height:1.85}

@media(max-width:1120px){
  .fc-pl-hero-grid{grid-template-columns:1fr}
  .fc-pl-ach-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .fc-pl-story-layout{grid-template-columns:1fr}
  .fc-pl-track-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .fc-pl-flow{grid-template-columns:repeat(2,minmax(0,1fr))}
  .fc-pl-flow::before{display:none}
  .fc-pl-bottom-grid{grid-template-columns:1fr}
  .fc-pl-cta-grid{grid-template-columns:1fr}
}

@media(max-width:700px){
  .fc-pl-hero{padding:52px 0 40px}
  .fc-pl-slide{grid-template-columns:1fr}
  .fc-pl-slide img{height:230px}
  .fc-pl-ach-grid{grid-template-columns:1fr}
  .fc-pl-track-grid{grid-template-columns:1fr}
  .fc-pl-flow{grid-template-columns:1fr}
}

/* ══════════════════════════════════════════════════════════════
   GLOBAL DESIGN SYSTEM v3.2.8
   Unified visual language from Placements page — applied globally
══════════════════════════════════════════════════════════════ */

/* ── Eyebrow label (all pages) ── */
.fc-eyebrow-v2{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:800;letter-spacing:2.5px;text-transform:uppercase;color:var(--teal);font-family:var(--fb);margin-bottom:14px}
.fc-eyebrow-v2::before{content:'';width:28px;height:2px;background:linear-gradient(90deg,var(--teal),transparent);flex-shrink:0}
.fc-eyebrow-v2::after{content:'';width:28px;height:2px;background:linear-gradient(270deg,var(--teal),transparent);flex-shrink:0}

/* Override existing eyebrow with new style */
.fc-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:800;letter-spacing:2.5px;text-transform:uppercase;color:var(--teal);font-family:var(--fb);margin-bottom:14px;justify-content:center;width:100%}
.fc-eyebrow::before{content:'';width:28px;height:2px;background:linear-gradient(90deg,var(--teal),transparent);flex-shrink:0}
.fc-eyebrow::after{content:'';width:28px;height:2px;background:linear-gradient(270deg,var(--teal),transparent);flex-shrink:0}

/* ── Section header (all pages) ── */
.fc-sec-hdr{text-align:center;margin-bottom:48px}
.fc-sec-title{font-family:var(--fh);font-size:clamp(1.5rem,3vw,2.2rem);font-weight:900;color:#fff;margin-bottom:12px;line-height:1.15}
.fc-sec-desc{font-size:15px;color:var(--muted);max-width:600px;margin:0 auto;line-height:1.85;font-family:var(--fb)}
.fc-section-head{text-align:center;margin-bottom:44px}
.fc-section-head h2{font-family:var(--fh);font-size:clamp(1.5rem,3vw,2.2rem);font-weight:900;color:#fff;margin-bottom:12px}
.fc-section-head p{font-size:15px;color:var(--muted);max-width:600px;margin:0 auto;line-height:1.85;font-family:var(--fb)}

/* ── Gradient headline highlight (all pages) ── */
.fc-hl-teal{background:linear-gradient(135deg,var(--teal),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hl,.hg{background:linear-gradient(135deg,var(--teal),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ── Glassmorphism cards (global) ── */
.fc-glass-card{background:linear-gradient(135deg,rgba(0,212,170,.06),rgba(240,165,0,.03));border:1px solid rgba(0,212,170,.15);border-radius:18px;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}

/* ── Stat cards (global, matches Placements design) ── */
.fc-stat,.fc-hss-item{background:transparent;border:none;padding:24px 18px;text-align:center;transition:.3s}
.fc-stat:hover,.fc-hss-item:hover{transform:translateY(-3px)}
.fc-stat-num,.fc-hss-num{font-family:var(--fh);font-size:2.2rem;font-weight:900;background:linear-gradient(135deg,var(--teal),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:6px}
.fc-stat-label,.fc-hss-lbl{font-size:12.5px;color:var(--muted);font-family:var(--fb);line-height:1.5}

/* ── Course cards — unified with new design ── */
/* fc-course-card-v2 moved to global card section */

/* ── Section glow backgrounds ── */
.fc-sec-teal-bg{background:linear-gradient(180deg,transparent,rgba(0,212,170,.03) 50%,transparent)}
.fc-sec-gold-bg{background:linear-gradient(180deg,transparent,rgba(240,165,0,.02) 50%,transparent)}
.fc-sec-grid-bg{background-image:radial-gradient(rgba(0,212,170,.06) 1px,transparent 1px);background-size:32px 32px}

/* ── Decorative glow orbs (utility classes) ── */
.fc-orb-teal{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(0,212,170,.12) 0%,transparent 70%);pointer-events:none;z-index:0}
.fc-orb-gold{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(240,165,0,.08) 0%,transparent 70%);pointer-events:none;z-index:0}

/* ── Process steps (timeline-style, global) ── */
.fc-step-node-v2{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--teal-dim));display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:1rem;font-weight:900;color:#fff;box-shadow:0 0 0 4px rgba(0,212,170,.2),0 0 25px rgba(0,212,170,.25);flex-shrink:0}

/* ── Feature/value cards ── */
.fc-feat-v2{background:rgba(12,18,32,.8);border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:24px;transition:.3s;position:relative;overflow:hidden}
.fc-feat-v2::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--teal),var(--gold));opacity:0;transition:.3s}
.fc-feat-v2:hover{transform:translateY(-4px);border-color:rgba(0,212,170,.2)}
.fc-feat-v2:hover::after{opacity:1}

/* ── Testimonial cards (global) ── */
.fc-tsl-card{background:rgba(12,18,32,.8);border:1px solid rgba(0,212,170,.12);border-left:3px solid var(--teal);border-radius:0 14px 14px 0;padding:24px;position:relative;transition:.3s}
.fc-tsl-card:hover{transform:translateX(3px);box-shadow:0 10px 36px rgba(0,0,0,.35)}

/* ── Badge/tag chips (global) ── */
.fc-chip-teal{padding:3px 12px;border-radius:100px;background:rgba(0,212,170,.08);border:1px solid rgba(0,212,170,.2);font-size:10.5px;font-weight:700;color:var(--teal);font-family:var(--fb)}
.fc-chip-gold{padding:3px 12px;border-radius:100px;background:rgba(240,165,0,.08);border:1px solid rgba(240,165,0,.2);font-size:10.5px;font-weight:700;color:var(--gold);font-family:var(--fb)}

/* ── FAQ (global style from Placements) ── */
.fc-faq-item-v2{border:1px solid rgba(0,212,170,.12);border-radius:12px;margin-bottom:8px;overflow:hidden}
.fc-faq-q-v2{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 20px;cursor:pointer;background:rgba(12,18,32,.8);transition:.2s;font-size:13.5px;font-weight:700;color:#F0F6FF;font-family:var(--fb);border:none;width:100%;text-align:left}
.fc-faq-q-v2:hover{background:rgba(0,212,170,.05);color:var(--teal)}
.fc-faq-a-v2{display:none;padding:0 20px 16px;font-size:13.5px;color:var(--muted);line-height:1.8;font-family:var(--fb)}
.fc-faq-item-v2.open .fc-faq-a-v2{display:block}
.fc-faq-icon-v2{width:26px;height:26px;border-radius:50%;background:rgba(0,212,170,.1);border:1px solid rgba(0,212,170,.2);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--teal);flex-shrink:0;transition:.2s}
.fc-faq-item-v2.open .fc-faq-icon-v2{transform:rotate(45deg);background:rgba(0,212,170,.18)}

/* ── CTA bands (global gradient style) ── */
.fc-cta-band-v2{background:linear-gradient(135deg,rgba(0,212,170,.1),rgba(240,165,0,.06));border:1px solid rgba(0,212,170,.18);border-radius:22px;padding:56px;text-align:center;position:relative;overflow:hidden}
.fc-cta-band-v2::before{content:'';position:absolute;top:-80px;left:50%;transform:translateX(-50%);width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(0,212,170,.1),transparent 70%);pointer-events:none}

/* ── Marquee company strip (global) ── */
.fc-mq-strip{background:rgba(0,212,170,.03);border-top:1px solid rgba(0,212,170,.12);border-bottom:1px solid rgba(0,212,170,.12);padding:26px 0;overflow:hidden}
.fc-mq-inner{display:flex;animation:fcMqScroll 28s linear infinite}
.fc-mq-inner:hover{animation-play-state:paused}
.fc-co-pill{display:flex;align-items:center;gap:8px;padding:7px 26px;border-right:1px solid rgba(255,255,255,.05);flex-shrink:0}
.fc-co-dot{width:7px;height:7px;border-radius:50%;background:var(--teal);opacity:.7;flex-shrink:0}
.fc-co-name{font-size:13.5px;font-weight:700;color:#C8D8EE;font-family:var(--fb);white-space:nowrap}
@keyframes fcMqScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── Success story card (global, for home + about us) ── */
.fc-story-card-v2{background:rgba(12,18,32,.8);border:1px solid rgba(0,212,170,.12);border-left:3px solid var(--teal);border-radius:0 14px 14px 0;padding:22px;position:relative;transition:.3s}
.fc-story-card-v2:hover{transform:translateX(3px);box-shadow:0 10px 36px rgba(0,0,0,.35)}
.fc-story-card-v2::before{content:'"';position:absolute;top:10px;right:14px;font-size:3.5rem;color:rgba(0,212,170,.08);font-family:Georgia,serif;line-height:1}
.fc-story-avatar-v2{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--gold));display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:.9rem;font-weight:900;color:#fff;flex-shrink:0;border:2px solid rgba(0,212,170,.3)}

/* ── Home page updates to match new design ── */
.fc-hero-badge-v2{display:inline-flex;align-items:center;gap:8px;padding:5px 14px;border-radius:100px;border:1px solid rgba(0,212,170,.3);background:rgba(0,212,170,.07);font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--teal);font-family:var(--fb)}
.fc-hero-badge-v2::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--teal);animation:fcPulse 1.5s infinite;flex-shrink:0}

/* ── Improve form design globally ── */
.fc-fg label{display:block;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:7px;font-family:var(--fb)}
.fc-fg input,.fc-fg select,.fc-fg textarea{width:100%;padding:11px 14px;border:1.5px solid rgba(0,212,170,.15);border-radius:10px;font-size:13.5px;background:rgba(5,9,15,.6);color:#F0F6FF;font-family:var(--fb);transition:.2s;box-sizing:border-box}
.fc-fg input:focus,.fc-fg select:focus,.fc-fg textarea:focus{border-color:var(--teal);outline:none;box-shadow:0 0 0 3px rgba(0,212,170,.08)}
.fc-fg select option{background:#0C1220;color:#F0F6FF}
.fc-submit,.fc-btn-submit{background:linear-gradient(135deg,var(--teal),var(--teal-dim));color:#fff;padding:13px 28px;border-radius:10px;font-size:14px;font-weight:700;border:none;cursor:pointer;font-family:var(--fb);width:100%;transition:.2s;display:block}
.fc-submit:hover,.fc-btn-submit:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,212,170,.4)}

/* ── Improve button styles globally ── */
.fc-btn-primary{background:linear-gradient(135deg,var(--teal),var(--teal-dim));color:#fff;padding:11px 24px;border-radius:10px;font-size:13.5px;font-weight:700;display:inline-flex;align-items:center;gap:7px;transition:.2s;border:none;cursor:pointer;font-family:var(--fb);text-decoration:none;box-shadow:0 4px 16px rgba(0,212,170,.25)}
.fc-btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,212,170,.45);color:#fff}
.fc-btn-outline{background:transparent;color:var(--teal);padding:11px 24px;border-radius:10px;font-size:13.5px;font-weight:700;display:inline-flex;align-items:center;gap:7px;transition:.2s;border:1.5px solid rgba(0,212,170,.35);cursor:pointer;font-family:var(--fb);text-decoration:none}
.fc-btn-outline:hover{background:rgba(0,212,170,.08);border-color:var(--teal);color:#fff}
.fc-btn-outline-gold{background:transparent;color:var(--gold);padding:11px 24px;border-radius:10px;font-size:13.5px;font-weight:700;display:inline-flex;align-items:center;gap:7px;transition:.2s;border:1.5px solid rgba(240,165,0,.35);cursor:pointer;font-family:var(--fb);text-decoration:none}
.fc-btn-outline-gold:hover{background:rgba(240,165,0,.08);border-color:var(--gold);color:#fff}
.fc-btn-lg{padding:14px 30px;font-size:14.5px}
.fc-btn-full{width:100%;justify-content:center}

/* ── Responsive additions ── */
@media(max-width:768px){
  .fc-cta-band-v2{padding:32px 20px}
  .fc-btn-lg{padding:13px 22px;font-size:13.5px}
}

/* ══════════════════════════════════════════════════════════════
   GLOBAL CARD SYSTEM UPGRADE v3.2.9
   Upgrade all fc-card instances to match Placements design
══════════════════════════════════════════════════════════════ */

/* Override the base card to match new design */
.fc-card {
  background: linear-gradient(135deg, rgba(13,22,37,.95), rgba(12,18,32,.9)) !important;
  border: 1px solid rgba(0,212,170,.12) !important;
  border-radius: var(--rl, 20px) !important;
}
.fc-card-hover:hover, .fc-card:hover {
  border-color: rgba(0,212,170,.28) !important;
  transform: translateY(-5px);
  box-shadow: 0 20px 50px rgba(0,0,0,.4), 0 0 30px rgba(0,212,170,.1) !important;
}

/* Section backgrounds upgrade */
.fc-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  background: transparent !important;
}
.fc-stat-card-item {
  background: transparent;
  border: none;
  border-radius: 16px;
  padding: 28px 18px;
  text-align: center;
  transition: .3s;
  position: relative;
  overflow: hidden;
}
.fc-stat-card-item:hover {
  transform: translateY(-5px);
  box-shadow: 0 0 40px rgba(0,212,170,.12);
}
.fc-stat-card-item::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--teal), var(--gold));
  opacity: 0;
  transition: .3s;
}
.fc-stat-card-item:hover::before { opacity: 1; }

/* Hero stats upgrade */
.fc-hs-item .fc-hs-num,
[data-counter-group] [data-target] {
  font-family: var(--fh);
  font-weight: 900;
}

/* Upgrade all eyebrow labels site-wide */
p.fc-eyebrow, .fc-eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: 2.5px !important;
  text-transform: uppercase !important;
  color: var(--teal) !important;
  font-family: var(--fb) !important;
  margin-bottom: 14px !important;
}
p.fc-eyebrow::before, .fc-eyebrow::before {
  content: '' !important;
  width: 28px !important;
  height: 2px !important;
  background: linear-gradient(90deg, var(--teal), transparent) !important;
  flex-shrink: 0 !important;
}
p.fc-eyebrow::after, .fc-eyebrow::after {
  content: '' !important;
  width: 28px !important;
  height: 2px !important;
  background: linear-gradient(270deg, var(--teal), transparent) !important;
  flex-shrink: 0 !important;
}

/* Upgrade section titles globally */
.fc-sec-title {
  font-family: var(--fh) !important;
  font-size: clamp(1.5rem, 3vw, 2.2rem) !important;
  font-weight: 900 !important;
  color: #fff !important;
  line-height: 1.15 !important;
}

/* Upgrade section descriptions globally */
.fc-sec-desc {
  font-size: 15px !important;
  color: var(--muted) !important;
  line-height: 1.85 !important;
  font-family: var(--fb) !important;
}

/* Upgrade existing testimonial slider cards */
.fc-tsl-outer { position: relative; overflow: hidden; }
.fc-tsl-card {
  background: rgba(12,18,32,.85) !important;
  border: 1px solid rgba(0,212,170,.12) !important;
  border-left: 3px solid var(--teal) !important;
  border-radius: 0 14px 14px 0 !important;
  padding: 26px !important;
  position: relative;
}
.fc-tsl-text {
  font-size: 13.5px !important;
  line-height: 1.82 !important;
  color: var(--muted) !important;
  font-style: italic !important;
}
.fc-tsl-stars { color: var(--gold) !important; font-size: 14px !important; margin-bottom: 10px !important; letter-spacing: 2px !important; }
.fc-tsl-name { font-size: 14px !important; font-weight: 700 !important; color: #fff !important; }
.fc-tsl-role { font-size: 12px !important; color: var(--teal) !important; font-weight: 600 !important; }
.fc-tsl-co   { font-size: 11.5px !important; color: var(--muted) !important; }
.fc-tsl-avatar {
  width: 44px !important;
  height: 44px !important;
  border-radius: 50% !important;
  border: 2px solid rgba(0,212,170,.3) !important;
  background: linear-gradient(135deg, var(--teal), var(--gold)) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-family: var(--fh) !important;
  font-size: .9rem !important;
  font-weight: 900 !important;
  color: #fff !important;
  overflow: hidden !important;
  flex-shrink: 0 !important;
}

/* Upgrade form design globally */
.fc-fg input, .fc-fg select, .fc-fg textarea {
  border-color: rgba(0,212,170,.15) !important;
  background: rgba(5,9,15,.6) !important;
  border-radius: 10px !important;
}
.fc-fg input:focus, .fc-fg select:focus, .fc-fg textarea:focus {
  border-color: var(--teal) !important;
  box-shadow: 0 0 0 3px rgba(0,212,170,.08) !important;
}

/* Upgrade course card v2 image overlays */
/* fc-cc-img-wrap background override removed — handled in card v2 section */

/* Upgrade pricing plans */
.fc-pricing-grid > div {
  transition: transform .3s, box-shadow .3s, border-color .3s !important;
}
.fc-pricing-grid > div:hover {
  transform: translateY(-6px) !important;
}

/* Upgrade FAQ items (existing) */
.fc-faq-item {
  border: 1px solid rgba(0,212,170,.1) !important;
  border-radius: 12px !important;
  margin-bottom: 8px !important;
  overflow: hidden !important;
}
.fc-faq-q {
  background: rgba(12,18,32,.8) !important;
  transition: background .2s !important;
}
.fc-faq-q:hover { background: rgba(0,212,170,.05) !important; color: var(--teal) !important; }
.fc-faq-item.open .fc-faq-q { color: var(--teal) !important; }

/* Accordion upgrade */
.fc-acc-item { border-bottom: 1px solid rgba(0,212,170,.1) !important; }
.fc-acc-head { transition: background .2s !important; }
.fc-acc-head:hover { background: rgba(0,212,170,.04) !important; }

/* Batch cards upgrade */
.fc-batch-card {
  background: linear-gradient(135deg, rgba(13,22,37,.9), rgba(12,18,32,.95)) !important;
  border: 1px solid rgba(0,212,170,.12) !important;
  border-radius: 14px !important;
}
.fc-batch-card:hover {
  border-color: rgba(0,212,170,.3) !important;
  transform: translateY(-3px) !important;
}
.fc-batch-card.feat {
  border-color: var(--teal) !important;
  background: linear-gradient(135deg, rgba(0,212,170,.08), rgba(12,18,32,.95)) !important;
}

/* Tag upgrade */
.fc-tag {
  padding: 3px 11px !important;
  border-radius: 100px !important;
  background: rgba(0,212,170,.07) !important;
  border: 1px solid rgba(0,212,170,.18) !important;
  font-size: 10.5px !important;
  font-weight: 700 !important;
  color: var(--teal) !important;
}

/* CTA button nav upgrade */
.fc-btn-nav {
  background: linear-gradient(135deg, var(--teal), var(--teal-dim)) !important;
  box-shadow: 0 4px 16px rgba(0,212,170,.25) !important;
}
.fc-btn-nav:hover {
  box-shadow: 0 8px 28px rgba(0,212,170,.45) !important;
  transform: translateY(-1px) !important;
}

/* ════════════════════════════════════════════════════════════════
   GLOBAL MOBILE ALIGNMENT & READABILITY FIXES — Build #5.5.0
   Applies across all pages for proper responsive design
════════════════════════════════════════════════════════════════ */

/* ── Brighter muted text for readability ── */
:root { --muted: #DEEBFF }

/* ── Global text alignment rules ── */
.fc-wrap p:not([class]),
.fc-sec-desc,
.cc-desc,
.fc-pl-stars + p,
.hv4-hero-desc,
.hv4-sub,
.hv4-reason p,
.hv4-school-desc,
.hv4-diff-desc,
.hv4-review-txt,
.hv4-perk-txt,
.ab4-hero-sub,
.ab4-sub,
.ab4-vm p,
.ab4-domain-desc,
.ab4-why p,
.ab4-value p,
.ab4-mile-desc,
.la-sub,
.la-desc,
.la-card-p,
.la-rm-desc,
.ct-sub,
.ct-form-sub,
.ct-info-sub,
.ct-consent,
.fc-section-desc,
.fc-sec-desc { text-align: justify; hyphens: auto }

/* ── Section headings always centered ── */
.fc-sec-hdr h2,
.fc-sec-hdr h3,
.fc-section-head h2,
.fch-h2,
.hv4-h2,
.ab4-h2,
.la-h2,
.ct-h1,
.fc-sec-title { text-align: center }

/* ── Eyebrow labels centered ── */
.fc-eyebrow,
.hv4-eyebrow,
.ab4-eyebrow,
.la-eyebrow,
.ct-eyebrow { justify-content: center; text-align: center }

/* ── Contact card content centered ── */
.hv4-contact-card *,
.ct-card *,
.ab4-domain *,
.la-track * { text-align: center }

/* ════════════════════════════════════════════════════════════════
   GLOBAL MOBILE RESPONSIVE — max-width: 768px
════════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {

  /* ── Core container ── */
  .fc-wrap { padding: 0 16px }
  .fc-pad  { padding: 56px 0 }
  .fc-pad-sm { padding: 36px 0 }

  /* ── Nav mobile ── */
  .fc-nav-menu { display: none }
  #fc-burger { display: flex }

  /* ── Typography scale ── */
  .fc-sec-title,
  .fch-h2, .hv4-h2, .ab4-h2, .la-h2 {
    font-size: clamp(1.5rem, 6vw, 2rem)
  }
  .fc-sec-desc, .hv4-sub, .ab4-sub, .la-desc {
    font-size: 14px; max-width: 100%
  }

  /* ── Hero ── */
  .hv4-hero-grid,
  .ab4-hero-grid,
  .la-hero-inner,
  .ct-main-grid,
  .fch-enroll-grid,
  .fch-app-grid,
  .hv4-app-grid { grid-template-columns: 1fr !important; gap: 28px !important }

  /* ── Hero stats ── */
  .hv4-stats { grid-template-columns: repeat(2, 1fr) !important }
  .hv4-si    { border-right: none !important; border-bottom: 1px solid var(--border); padding: 14px !important }
  .hv4-si:nth-child(even) { border-right: none !important }
  .hv4-sn { font-size: 1.5rem }

  /* ── Hide visuals on small screens ── */
  .hv4-visual, .la-terminal { display: none }

  /* ── Cards grids ── */
  .hv4-school-grid,
  .hv4-diff-grid,
  .hv4-contact-grid,
  .hv4-pricing-grid,
  .hv4-review-grid,
  .la-tracks,
  .la-cards-grid,
  .ct-cards-grid,
  .ab4-vm-grid,
  .ab4-domain-grid,
  .ab4-values-grid,
  .ab4-why-grid,
  .fc-courses-grid { grid-template-columns: 1fr !important }

  /* ── Course cards ── */
  .cc-img img { height: 200px }
  .cc-title { font-size: 14px }

  /* ── CTA buttons ── */
  .hv4-ctas,
  .la-hero-ctas,
  .ab4-hero-ctas { flex-direction: column; gap: 10px }
  .hv4-ctas .fc-btn,
  .la-hero-ctas .fc-btn,
  .ab4-hero-ctas .fc-btn { width: 100%; justify-content: center }

  /* ── Trainer band ── */
  .hv4-trainer-band,
  .fc-trainercta-wrap { flex-direction: column !important; text-align: center !important; padding: 32px 20px !important }

  /* ── Form rows ── */
  .ct-row { grid-template-columns: 1fr !important }
  .fch-form-card { padding: 24px }

  /* ── Pricing ── */
  .hv4-pricing-grid { grid-template-columns: 1fr 1fr !important }

  /* ── Timeline ── */
  .ab4-timeline::before { left: 22px }
  .ab4-mile-node { width: 44px; height: 44px; font-size: 16px }
  .la-roadmap::before { left: 22px }
  .la-rm-node { width: 44px; height: 44px; font-size: 18px }

  /* ── Course page trainer layout ── */
  .fc-trainer-grid-2col { grid-template-columns: 1fr !important }

  /* ── Stats strip ── */
  .ab4-stats-strip { flex-direction: column }
  .ab4-si { border-right: none !important; border-bottom: 1px solid rgba(0,212,170,.1) !important; min-width: auto }
  .la-stats-ticker { flex-wrap: wrap }
  .la-st { min-width: 120px }

  /* ── Contact map ── */
  .ct-map-frame iframe { height: 260px }

  /* ── Section header spacing ── */
  .hv4-hdr, .ab4-hdr, .la-hdr { margin-bottom: 30px }

  /* ── Batch cards / pricing on course page ── */
  .fc-batches-grid { grid-template-columns: 1fr !important }
  .fc-batch-payment-grid { grid-template-columns: 1fr !important }

  /* ── single course page ── */
  .fc-course-grid { grid-template-columns: 1fr !important }
  .fc-course-sidebar { display: none }
  .fc-course-hero-full { min-height: 48svh }

  /* ── Prevent text overflow ── */
  * { word-break: break-word }
  pre, code { overflow-x: auto }
}

/* ════ 480px — smallest phones ════ */
@media (max-width: 480px) {

  .hv4-pricing-grid { grid-template-columns: 1fr !important }
  .ct-cards-grid    { grid-template-columns: 1fr !important }
  .la-tracks        { grid-template-columns: 1fr !important }
  .ab4-mini-stats   { grid-template-columns: 1fr 1fr !important }
  .hv4-stats        { grid-template-columns: 1fr 1fr !important }

  /* CTA band padding */
  .ab4-cta-band,
  .hv4-trainer-band { padding: 32px 16px !important }

  /* Eyebrow lines hidden on small screens */
  .hv4-eyebrow::before, .hv4-eyebrow::after,
  .ab4-eyebrow::before, .ab4-eyebrow::after,
  .la-eyebrow::before,  .la-eyebrow::after,
  .ct-eyebrow::before,  .ct-eyebrow::after  { display: none }

  /* Font sizes */
  .hv4-h1, .ab4-hero-h1, .la-h1 { font-size: clamp(1.6rem, 7vw, 2rem) }
  .hv4-sn, .ab4-sn, .la-st-num { font-size: 1.4rem }
  .fc-btn { padding: 11px 18px; font-size: 13px }
  .fc-btn-lg { padding: 13px 22px; font-size: 14px }
}

/* ════ Tablet — 900–1100px ════ */
@media (min-width: 769px) and (max-width: 1100px) {
  .hv4-school-grid { grid-template-columns: 1fr 1fr !important }
  .hv4-diff-grid   { grid-template-columns: repeat(2, 1fr) !important }
  .hv4-pricing-grid { grid-template-columns: repeat(2, 1fr) !important }
  .ct-cards-grid   { grid-template-columns: repeat(2, 1fr) !important }
  .la-tracks       { grid-template-columns: repeat(2, 1fr) !important }
  .la-cards-grid   { grid-template-columns: 1fr 1fr !important }
  .ab4-domain-grid { grid-template-columns: repeat(2, 1fr) !important }
  .ab4-values-grid { grid-template-columns: repeat(2, 1fr) !important }
}

/* ════════════════════════════════════════════════════════════════
   GLOBAL IMAGE FIT + ICON DISPLAY FIXES — Build #5.6.0
════════════════════════════════════════════════════════════════ */

/* targeted image rules moved to card v2 section */

/* cc-img placeholder fix REMOVED — handled by original definition */
.cc-img img[src=""],
.cc-img img:not([src]),
.cc-img img[src*="placeholder"] {
  display: none;
}
.cc-img:not(:has(img[src]:not([src=""])))::after,
.cc-img:has(img[src=""]):not(:has(img:not([src=""])))::before {
  content: "📚";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 52px;
  opacity: .4;
}

/* Fix 3: Icon boxes - ensure emoji render and have proper sizing */
.hv4-reason-ico,
.hv4-diff-ico,
.hv4-perk-ico,
.hv4-contact-ring,
.ct-card-ico,
.ab4-why-ico,
.ab4-value-ico,
.la-track-ico,
.la-rm-node,
.fc-reason-ico,
.bt4-benefit-ico {
  display: flex;
  align-items: center;
  justify-content: center;
  font-style: normal;
  line-height: 1;
  font-family: "Apple Color Emoji","Segoe UI Emoji","Noto Color Emoji",sans-serif;
}

/* Fix 3: Why reasons icon boxes fill */
.hv4-reason-ico { font-size: 22px; }
.hv4-diff-ico   { font-size: 20px; }
.hv4-contact-ring { font-size: 28px; }
.ct-card-ico    { font-size: 26px; }
.ab4-why-ico    { font-size: 22px; }
.ab4-value-ico  { font-size: 26px; }
.la-track-ico   { font-size: 36px; }

/* Fix 8: Home contact cards - full center alignment */
.hv4-contact-card,
.hv4-contact-card *,
.hv4-contact-ring,
.hv4-contact-title,
.hv4-contact-val { 
  text-align: center;
}
.hv4-contact-card {
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* Fix 6: Course packages grid - better design */
.fc-pkg-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 18px;
  margin: 16px 0 28px;
}
.fc-pkg-card {
  background: linear-gradient(135deg, rgba(13,22,37,.95), rgba(12,18,32,.9));
  border: 1px solid rgba(0,212,170,.15);
  border-radius: 16px;
  overflow: hidden;
  transition: .3s;
  position: relative;
}
.fc-pkg-card:hover {
  border-color: rgba(0,212,170,.35);
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0,0,0,.4);
}
.fc-pkg-img {
  height: 120px;
  background: linear-gradient(135deg, rgba(0,212,170,.12), rgba(255,170,0,.06));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 48px;
  border-bottom: 1px solid rgba(0,212,170,.1);
  position: relative;
  overflow: hidden;
}
.fc-pkg-img::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(0,212,170,.05), transparent);
}
.fc-pkg-body { padding: 18px 16px; }
.fc-pkg-title {
  font-size: 15px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 8px;
  line-height: 1.35;
}
.fc-pkg-desc {
  font-size: 12.5px;
  color: var(--muted);
  line-height: 1.72;
  text-align: justify;
  hyphens: auto;
  margin-bottom: 12px;
}
.fc-pkg-link {
  font-size: 12px;
  color: var(--teal);
  font-weight: 700;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  transition: .15s;
}
.fc-pkg-link:hover { color: var(--gold); }

/* Fix 7: Course overview sections - better spacing and design */
.fc-cs { max-width: 100%; }
.fc-cs h2 {
  font-size: 20px;
  margin-bottom: 16px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(0,212,170,.12);
  color: #fff;
}
.fc-learn-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 28px;
}
.fc-learn-item {
  background: rgba(0,212,170,.04);
  border: 1px solid rgba(0,212,170,.1);
  border-left: 3px solid var(--teal);
  border-radius: 0 10px 10px 0;
  padding: 12px 14px;
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 13.5px;
  color: var(--muted);
  transition: .2s;
}
.fc-learn-item:hover {
  background: rgba(0,212,170,.07);
  color: var(--white);
}
.fc-learn-item::before {
  content: "✓";
  color: var(--teal);
  font-weight: 800;
  flex-shrink: 0;
}
.fc-who-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 0;
  border-bottom: 1px solid rgba(255,255,255,.04);
  font-size: 13.5px;
  color: var(--muted);
}
.fc-who-item:last-child { border: none; }
.fc-why-list-v2 { display: flex; flex-direction: column; gap: 12px; }
.fc-why-item-v2 {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  background: rgba(0,212,170,.03);
  border: 1px solid rgba(0,212,170,.1);
  border-radius: 12px;
  padding: 16px;
  transition: .2s;
}
.fc-why-item-v2:hover {
  background: rgba(0,212,170,.06);
  border-color: rgba(0,212,170,.22);
}
.fc-jtk-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(255,255,255,.04);
}
.fc-jtk-item:last-child { border: none; }

/* Fix: Overview section separators */
.fc-cs > h2 + * { margin-top: 0; }
.fc-cs > * + h2 { margin-top: 32px; }

/* Global gold color update for urgency/accent bands */
.hv4-urg { background: rgba(240,165,0,.07); border-color: rgba(240,165,0,.22); }

/* cc-img flex/absolute override REMOVED — conflicts with card height */


/* ═══ SOCIAL MEDIA ICONS — 4-col layout ═══════════════════════ */
.fc-footer-socials {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 14px;
  max-width: 200px; /* 4 per row at ~44px each */
}
.fc-soc {
  width: 40px; height: 40px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.1);
  background: rgba(12,18,32,.8);
  display: flex; align-items: center; justify-content: center;
  font-size: 17px; text-decoration: none;
  transition: .2s; flex-shrink: 0;
  font-family: "Apple Color Emoji","Segoe UI Emoji","Noto Color Emoji",sans-serif;
}
.fc-soc:hover {
  border-color: var(--soc-color, var(--teal));
  background: color-mix(in srgb, var(--soc-color, var(--teal)) 12%, transparent);
  transform: translateY(-2px);
}

/* ═══ FOOTER GRID — with optional 5th column ═════════════════ */
.fc-footer-grid {
  display: grid;
  grid-template-columns: 1.6fr repeat(3, 1fr);
  gap: 40px;
  padding: 60px 5% 40px;
  max-width: 1300px;
  margin: 0 auto;
}
/* 5 columns if extra col present */
.fc-footer-grid:has(.fc-footer-col:nth-child(5)) {
  grid-template-columns: 1.4fr repeat(4, 1fr);
}
@media (max-width: 1000px) {
  .fc-footer-grid { grid-template-columns: 1fr 1fr !important; gap: 28px; }
}
@media (max-width: 600px) {
  .fc-footer-grid { grid-template-columns: 1fr !important; gap: 24px; }
  .fc-footer-socials { max-width: 100%; }
}

/* ═══ MENU SYNC — Nav menus in footer use theme styles ═════════ */
.fc-footer-col ul, .fc-footer-col .menu { list-style: none; padding: 0; margin: 0; }
.fc-footer-col ul li { margin-bottom: 0; }
.fc-footer-col ul li a { 
  font-size: 13.5px; color: rgba(255,255,255,.65); font-family: var(--fb);
  text-decoration: none; transition: .2s; display: block; padding: 4px 0;
}
.fc-footer-col ul li a:hover { color: var(--teal); padding-left: 6px; }

/* ═══ NAV CUSTOMIZER SYNC — wp_nav_menu primary location ══════ */
/* When a WP nav menu is assigned to fc_primary location, it renders here */
.fc-nav-wp-menu {
  display: flex; gap: 28px; align-items: center; list-style: none;
  padding: 0; margin: 0;
}
.fc-nav-wp-menu > li > a {
  font-family: var(--fb); font-size: 13.5px; font-weight: 600;
  color: var(--off-white); text-decoration: none; transition: .2s;
  padding-bottom: 4px; position: relative;
}
.fc-nav-wp-menu > li > a::after {
  content: ''; position: absolute; bottom: 0; left: 0; width: 0;
  height: 2px; background: var(--teal); border-radius: 2px; transition: .2s;
}
.fc-nav-wp-menu > li > a:hover,
.fc-nav-wp-menu > li.current-menu-item > a { color: var(--teal); }
.fc-nav-wp-menu > li > a:hover::after,
.fc-nav-wp-menu > li.current-menu-item > a::after { width: 100%; }

/* Sub-menus from WP nav menus with description support */
.fc-nav-wp-menu .sub-menu {
  position: absolute; top: calc(100% + 8px); left: 0;
  background: rgba(8,14,26,.97); border: 1px solid rgba(0,212,170,.18);
  border-radius: 14px; padding: 12px; min-width: 200px;
  box-shadow: 0 20px 60px rgba(0,0,0,.6); list-style: none;
  opacity: 0; pointer-events: none; transform: translateY(8px); transition: .2s;
}
.fc-nav-wp-menu li:hover > .sub-menu {
  opacity: 1; pointer-events: auto; transform: translateY(0);
}
.fc-nav-wp-menu .sub-menu li a {
  font-size: 13px; color: rgba(255,255,255,.7); padding: 8px 12px;
  border-radius: 8px; display: block; transition: .15s;
}
.fc-nav-wp-menu .sub-menu li a:hover { background: rgba(0,212,170,.08); color: var(--teal); }
.fc-nav-wp-menu li { position: relative; }

/* ════════════════════════════════════════════════════════════════
   v4.2.0 — Category Page + Courses Page Polish
════════════════════════════════════════════════════════════════ */

/* Category page sidebar sticky fix on mobile */
@media(max-width:1100px) {
  .ccat-body { grid-template-columns: 1fr !important; }
  .ccat-sidebar { position: static !important; }
  .ccat-enroll-box { margin-bottom: 0; }
}

/* Category testimonial empty avatar fallback */
.ccat-tc-ava {
  background: linear-gradient(135deg, rgba(0,212,170,.2), rgba(240,165,0,.1));
  object-fit: cover;
  flex-shrink: 0;
}

/* Category contact cards full-width on mobile */
@media(max-width:480px) {
  .ccat-contact-grid { grid-template-columns: 1fr !important; }
  .ccat-stats-bar { max-width: 100% !important; flex-wrap: wrap; }
  .ccat-si { min-width: 80px; }
  .ccat-hl-grid { grid-template-columns: repeat(2,1fr) !important; }
  .ccat-cta { padding: 32px 18px !important; }
}

/* Learn & Act terminal on large screens only */
@media(max-width:900px) {
  .la-hero-inner { grid-template-columns: 1fr !important; }
  .la-terminal { display: none; }
}

/* Courses page CTA banner */
.fc-courses-cta-banner {
  background: linear-gradient(135deg,rgba(0,212,170,.08),rgba(240,165,0,.04));
  border: 1px solid rgba(0,212,170,.2);
  border-radius: 20px;
  padding: 52px 40px;
  text-align: center;
}
@media(max-width:600px) {
  .fc-courses-cta-banner { padding: 32px 20px; }
}

/* Release notes version badges */
.fc-rn-v4 { 
  background: linear-gradient(135deg, rgba(0,212,170,.15), rgba(240,165,0,.08));
  border-color: rgba(0,212,170,.3) !important;
}

/* Fix: category page body grid on tablet */
@media(min-width:769px) and (max-width:1100px) {
  .ccat-testi-grid { grid-template-columns: repeat(2,1fr) !important; }
  .ccat-contact-grid { grid-template-columns: repeat(2,1fr) !important; }
  .ccat-related-grid { grid-template-columns: repeat(2,1fr) !important; }
}

/* Ensure all fc-btn in category page are properly sized */
.ccat-submit:disabled { opacity: .7; cursor: not-allowed; }

/* Learn page domain filter tab active state */
.la-dt.active {
  background: var(--teal) !important;
  color: #fff !important;
  border-color: var(--teal) !important;
  box-shadow: 0 4px 14px rgba(0,212,170,.3);
}

/* Smooth show/hide for filtered cards */
.la-arch[style*="display: none"] { display: none !important; }
.la-arch { transition: opacity .25s ease; }


/* ════════════════════════════════════════════════════════════════
   v4.3.0 — FINAL POLISH PASS (Fixes 2, 3, 10, 12)
════════════════════════════════════════════════════════════════ */

/* ── FIX 3: Universal image auto-fit for all image cards ─────── */
/* All card images, course images, hero images, testimonial avatars, */
/* trainer photos — auto-fit to their containers */
/* Broad image override removed — was overriding fixed px heights */


/* cc-img aspect-ratio override REMOVED — conflicts with card height */

/* Placeholder when no image */
.cc-img img[src=""],
.cc-img img:not([src]) {
  background: linear-gradient(135deg, rgba(0,212,170,.15), rgba(240,165,0,.08));
}

/* ── FIX 12: Center-aligned course cards (What You Get free cards) ─ */
.fc-free-grid,
.fc-freebie-grid,
.fch-free-grid,
[class*="free-grid"] {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 240px));
  gap: 18px;
  justify-content: center;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 20px;
}
.fc-free-card,
.fc-freebie-card,
.fch-free-card {
  text-align: center;
  padding: 24px 18px;
  background: rgba(10,16,28,.8);
  border: 1px solid rgba(0,212,170,.15);
  border-radius: 14px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  transition: transform .25s, border-color .25s, box-shadow .25s;
}
.fc-free-card:hover,
.fc-freebie-card:hover,
.fch-free-card:hover {
  transform: translateY(-4px);
  border-color: rgba(0,212,170,.4);
  box-shadow: 0 12px 30px rgba(0,212,170,.12);
}

/* ── All course cards centered inside their grids on narrow screens ── */
@media (max-width: 600px) {
  .fc-courses-grid,
  .ccat-grid,
  .ccat-related-grid {
    justify-content: center;
  }
  .fc-course-card {
    max-width: 380px;
    margin: 0 auto;
    width: 100%;
  }
}

/* ── FIX 10: Smooth entrance animations ────────────────────────── */
.fc-rev {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .7s cubic-bezier(.22,1,.36,1), transform .7s cubic-bezier(.22,1,.36,1);
}
.fc-rev.in-view,
.fc-rev.visible {
  opacity: 1;
  transform: translateY(0);
}
.fc-rev.d1 { transition-delay: .1s; }
.fc-rev.d2 { transition-delay: .2s; }
.fc-rev.d3 { transition-delay: .3s; }
.fc-rev.d4 { transition-delay: .4s; }
.fc-rev.from-left  { transform: translateX(-40px); }
.fc-rev.from-right { transform: translateX(40px); }
.fc-rev.in-view.from-left,
.fc-rev.in-view.from-right { transform: translateX(0); }

/* Card hover lift (consistent across all card types) */
.fc-course-card,
.ccat-hl,
.ccat-wc,
.ccat-tc,
.ccat-cc,
.la-arch,
.la-card,
.ct-card {
  transition: transform .28s cubic-bezier(.22,1,.36,1), 
              border-color .28s, 
              box-shadow .28s;
}
.fc-course-card:hover,
.ccat-tc:hover,
.ccat-cc:hover,
.la-arch:hover,
.la-card:hover,
.ct-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 20px 50px rgba(0,0,0,.4);
}

/* Skeleton/loading animation */
@keyframes fc-shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

/* Counter animation */
@keyframes fcFadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

/* ── FIX 2: Polish & spacing fixes ─────────────────────────────── */
/* Consistent section padding */
.fc-section,
section[class*="fc-"] {
  position: relative;
}

/* Fix: ensure sticky sidebar doesn't overflow on small heights */
.ccat-sidebar,
.fc-course-sidebar {
  max-height: calc(100vh - var(--nav-h) - 40px);
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--teal) transparent;
}
.ccat-sidebar::-webkit-scrollbar,
.fc-course-sidebar::-webkit-scrollbar {
  width: 4px;
}
.ccat-sidebar::-webkit-scrollbar-thumb,
.fc-course-sidebar::-webkit-scrollbar-thumb {
  background: var(--teal);
  border-radius: 2px;
}

/* Fix: Ensure buttons have consistent height & centering */
.fc-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  white-space: nowrap;
}

/* Fix: All testimonial cards text-align left, names centered inline */
.ccat-tc,
.fc-testi-card {
  text-align: left;
}

/* Fix: Polish batch cards consistency */
.ccat-batch,
.fc-batch-card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 180px;
}

/* Fix: Menu dropdown alignment on mobile */
@media (max-width: 900px) {
  .fc-nav-menu { display: none !important; }
}
@media (min-width: 901px) {
  #fc-drawer { display: none !important; }
}

/* Fix: Contact cards fully centered */
.ccat-cc,
.ct-card {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.ccat-cc *,
.ct-card * { text-align: center; }

/* Fix: Release notes styling */
details.fc-rn-item summary::-webkit-details-marker { display: none; }
details.fc-rn-item summary::marker { content: ''; }
details.fc-rn-item[open] summary { background: rgba(0,212,170,.04) !important; }

/* Fix: Prevent horizontal scroll */
html, body { overflow-x: hidden; max-width: 100vw; }

/* Fix: Section title consistent gap */
.fc-sec-title,
.fc-section-title {
  margin-bottom: .5em;
}

/* ── Dynamically injected course submenu (WP menu mode) ─────── */
#fc-nav-courses-wp {
  min-width: 600px;
  max-width: 780px;
  padding: 12px 0 0 0;
  display: flex;
  flex-wrap: wrap;
}
#fc-nav-courses-wp .fc-sub-group {
  display: inline-block;
  vertical-align: top;
  min-width: 180px;
  padding: 14px 16px;
  border-right: 1px solid rgba(255,255,255,.06);
}
#fc-nav-courses-wp .fc-sub-footer {
  width: 100%;
  border-top: 1px solid rgba(255,255,255,.06);
  padding: 10px 16px;
}
/* When using WP nav menu, the li that has fc-nav-has-dynamic-courses 
   should use the wide panel layout */
.fc-nav-has-dynamic-courses .fc-sub-panel,
.fc-nav-has-dynamic-courses > .fc-sub-panel {
  min-width: 600px;
  max-width: 780px;
  left: 0;
  transform: none;
  z-index: 1001;}

/* ── WP menu: course submenu item needs relative positioning ── */
.fc-nav-wp-menu > li { position: relative; }
.fc-nav-wp-menu > li:hover > .fc-sub-panel,
.fc-nav-wp-menu > li:hover > #fc-nav-courses-wp,
.fc-nav-wp-menu > li > .fc-sub-panel:hover,
.fc-nav-wp-menu > li > #fc-nav-courses-wp:hover {
  opacity: 1;
  visibility: visible;
  pointer-events: all;
}
.fc-nav-wp-menu > li > .sub-menu {
  /* Hide default WP sub-menu UL — our custom panel replaces it */
  display: none !important;
}

/* ── Nav course link: short title + scroll on hover ──────────── */
.fc-sub-course-link { overflow: hidden; max-width: 180px; }
.fc-sub-course-text {
  display: inline-block;
  white-space: nowrap;
  transition: none;
}
.fc-sub-course-scroll .fc-sub-course-text {
  animation: none;
}
.fc-sub-course-scroll:hover .fc-sub-course-text {
  animation: fcSubScroll 3s linear forwards;
}
@keyframes fcSubScroll {
  0%   { transform: translateX(0); }
  15%  { transform: translateX(0); }
  85%  { transform: translateX(-60%); }
  100% { transform: translateX(-60%); }
}
.fc-sub-courses li a { max-width: 200px; }

/* ── Also fix the group width to handle more content ── */
.fc-sub-panel .fc-sub-group { min-width: 200px; max-width: 240px;   position: relative;
  z-index: 1;
}


/* ── Global image fit — hero and section images ──────────── */
.hv4-vis-frame{overflow:hidden;border-radius:var(--rl)}
/* Height set per-page in inline <style>; only enforce object-fit here */
.hv4-vis-frame img{width:100%;object-fit:cover;display:block;object-position:center top}
.hv4-app-img{overflow:hidden;border-radius:var(--rl)}
.hv4-app-img img{width:100%;object-fit:cover;display:block;object-position:center}
.hv4-trainer-ava img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.fc-tsl-avatar img,.ccat-tc-ava{object-fit:cover;border-radius:50%}
.fc-course-hero-full img.fc-hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top}

/* ════════════════════════════════════════════════════════════════
   GLOBAL IMAGE FIT — All image containers, all pages
   Containers define the height; img fills with object-fit:cover
════════════════════════════════════════════════════════════════ */

/* Single course hero */
.fc-course-hero-full { position:relative; overflow:hidden; }
.fc-course-hero-full img.fc-hero-bg {
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover; object-position:center top;
}

/* Sidebar image on single course */
.fc-sidebar-img { width:100%; height:160px; object-fit:cover; display:block; border-radius:var(--rl) var(--rl) 0 0; }

/* Become-a-trainer hero image */
.bt4-hero-img { overflow:hidden; border-radius:20px; }
.bt4-hero-img img { width:100%; height:460px; object-fit:cover; display:block; }

/* Contact page map/image */
.ct-map-frame { overflow:hidden; border-radius:16px; height:300px; }
.ct-map-frame img { width:100%; height:100%; object-fit:cover; display:block; }

/* Testimonial avatars — circular */
.fc-tsl-avatar, .ccat-tc-ava { 
  border-radius:50%; overflow:hidden;
  object-fit:cover; object-position:center;
}
img.ccat-tc-ava { width:100%; height:100%; }

/* Placements page section images */
.fc-pl-img-frame { overflow:hidden; border-radius:16px; }
.fc-pl-img-frame img { width:100%; height:360px; object-fit:cover; display:block; }

/* Learn page images */
.la-arch-img { overflow:hidden; border-radius:12px; }
.la-arch-img img { width:100%; height:200px; object-fit:cover; display:block; }

/* About page team photos */
.ab4-team-img { overflow:hidden; border-radius:50%; width:80px; height:80px; flex-shrink:0; }
.ab4-team-img img { width:100%; height:100%; object-fit:cover; }

/* Responsive: reduce hero image heights on mobile */
@media(max-width:768px) {
  .bt4-hero-img img { height:280px; }
  .fc-pl-img-frame img { height:240px; }
  .fc-sidebar-img { height:140px; }
}
@media(max-width:480px) {
  .bt4-hero-img img { height:200px; }
}

/* ════════════════════════════════════════════════════════════════
   ELEMENTOR COMPATIBILITY — Page builder integration styles
   Ensures Elementor sections display correctly within our theme.
════════════════════════════════════════════════════════════════ */

/* Full canvas — no padding/margin conflicts with Elementor sections */
.fc-elementor-canvas {
  width: 100%;
  overflow-x: hidden;
}

/* Elementor sections get correct width */
.fc-elementor-canvas .elementor-section-boxed > .elementor-container {
  max-width: 1280px;
}

/* Fix Elementor typography to blend with our theme vars */
.fc-elementor-canvas .elementor-widget-text-editor,
.fc-elementor-canvas .elementor-widget-heading {
  color: var(--white);
}

/* Ensure Elementor buttons use our teal by default */
.fc-elementor-canvas .elementor-button {
  background-color: var(--teal);
  border-radius: var(--rl);
  font-family: var(--fb);
}

/* Elementor sections can be full-width */
.fc-elementor-canvas .elementor-section.elementor-section-stretched {
  width: 100vw;
  left: 0;
  position: relative;
}

/* Sync Elementor headings with Orbitron font */
.fc-elementor-canvas h1,
.fc-elementor-canvas h2,
.fc-elementor-canvas h3 {
  font-family: var(--fh, 'Orbitron', sans-serif);
}

/* Fix Elementor image widgets */
.fc-elementor-canvas .elementor-widget-image img {
  border-radius: var(--rl);
  display: block;
}

/* Elementor divider color */
.fc-elementor-canvas .elementor-divider-separator {
  border-color: var(--border);
}

/* ════════════════════════════════════════════════════════════════
   IMAGE FIT — Clean object-fit rules for all image containers.
   Images fill their containers with object-fit:cover.
   Visual inset is achieved with border/outline on container,
   NOT padding (padding breaks absolute-positioned overlays).
════════════════════════════════════════════════════════════════ */

/* ─ Hero visual card ─────────────────────────────────────────── */
.hv4-vis-frame { overflow:hidden; border-radius:var(--rl); position:relative; min-height:380px; }
.hv4-vis-frame img {
  position:absolute; top:50%; left:50%;
  width:84%; height:84%;
  object-fit:contain; object-position:center;
  display:block; transform:translate(-50%,-50%);
}

/* ─ Our Approach image ───────────────────────────────────────── */
.hv4-app-img { overflow:hidden; border-radius:var(--rl); position:relative; min-height:420px; }
.hv4-app-img img {
  position:absolute; top:50%; left:50%;
  width:84%; height:84%;
  object-fit:contain; object-position:center;
  display:block; transform:translate(-50%,-50%);
}

/* fc-cc-img-wrap v2 — defined globally in card v2 section above */

/* ─ Home page old-style course card image (185px) ────────────── */
.cc-img { position:relative; overflow:hidden; flex-shrink:0; height:185px; }
.cc-img img {
  position:absolute; top:50%; left:50%;
  width:84%; height:84%;
  object-fit:contain; object-position:center; display:block;
  transform:translate(-50%,-50%); transition:transform .45s ease;
}

/* ─ Sidebar image on single course page ──────────────────────── */
.fc-sidebar-img {
  width:100%; height:160px;
  object-fit:cover; display:block;
  border-radius:0;
}

/* ─ Become a Trainer apply section ───────────────────────────── */
.bt4-apply-img { overflow:hidden; border-radius:16px; position:relative; min-height:220px; }
.bt4-apply-img img { position:absolute; top:50%; left:50%; width:84%; height:84%; object-fit:contain; object-position:center; display:block; transform:translate(-50%,-50%); }

/* ─ Placements image frame ───────────────────────────────────── */
.fc-pl-img-frame { overflow:hidden; border-radius:16px; position:relative; min-height:360px; }
.fc-pl-img-frame img { position:absolute; top:50%; left:50%; width:84%; height:84%; object-fit:contain; object-position:center; display:block; transform:translate(-50%,-50%); }

/* ─ Become a Trainer hero photo (circular, 80px) ─────────────── */
.bt4-hero-img {
  width:80px; height:80px; border-radius:50%;
  overflow:hidden; border:3px solid var(--gold);
  margin:0 auto 14px; box-shadow:0 0 24px rgba(255,170,0,.25);
}
.bt4-hero-img img { width:100%; height:100%; object-fit:cover; }

/* ─ About Us team photo circles ──────────────────────────────── */
.ab4-team-img { overflow:hidden; border-radius:50%; width:80px; height:80px; flex-shrink:0; }
.ab4-team-img img { width:100%; height:100%; object-fit:cover; }

/* ─ Testimonial avatars ──────────────────────────────────────── */
.fc-tsl-avatar img, .ccat-tc-ava, .hv4-review-ava img,
.hv4-trainer-ava img, .hv4-trainer-photo img {
  object-fit:cover; object-position:center top;
}

/* ─ Single course hero full-screen ───────────────────────────── */
.fc-course-hero-full img.fc-hero-bg {
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover; object-position:center top; z-index:0;
}

/* ─ Responsive ───────────────────────────────────────────────── */
@media(max-width:768px) {
  .hv4-vis-frame { min-height:280px; }
  .hv4-app-img { min-height:320px; }
  .fc-pl-img-frame { min-height:240px; }
  .bt4-apply-img { min-height:180px; }
}
@media(max-width:480px) {
  .hv4-vis-frame { min-height:220px; }
  .hv4-app-img { min-height:240px; }
}

/* ══ STATS SECTION — GUARANTEED TRANSPARENT ══════════════════
   Overrides any stale rule that adds card bg/border to stat cells.
════════════════════════════════════════════════════════════════ */
.fc-stats-grid,
.fc-stats-grid-wrap {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  gap: 0 !important;
}
.fc-stat,
.fc-stat-card-item,
.fc-hss-item {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  outline: none !important;
}
.fc-stat:hover,
.fc-stat-card-item:hover,
.fc-hss-item:hover {
  background: transparent !important;
  box-shadow: none !important;
}

/* ══ COURSE CARD — BADGE OVERLAP FIX ════════════════════════
   Category badge: 1-line, max-width, ellipsis
   Hot/flag badge: always top-right, never overlaps category
════════════════════════════════════════════════════════════════ */
.fc-cc-img-badges {
  position: absolute;
  top: 12px;
  left: 12px;
  right: 52px;       /* leave room for hot badge on right */
  display: flex;
  gap: 6px;
  flex-wrap: nowrap; /* no wrapping — stays 1 line */
  z-index: 2;
}
.fc-cc-img-badges .fc-badge {
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: inline-block;
}
.fc-cc-hot-badge {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 3;
  left: auto;        /* ensure never pushed left */
  transform: translateY(-100%);
}
/* Hot badge pill text — 1 line, never 2 lines */
.fc-cc-hot-badge .fc-badge,
.fc-cc-hot-badge .cc-flag {
  white-space: nowrap;
  padding: 4px 10px;
  font-size: 10px;
  line-height: 1.4;
  transform: translateY(-100%);
}

/* ══ TOOL CHIPS — TRUNCATE LONG NAMES ═══════════════════════ */
.fc-cc-tool,
.fc-tag {
  max-width: 140px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: inline-block;
}
/* Mode pill also truncate */
.fc-cc-mode-pill {
  max-width: 120px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ══ COURSE CARD — LEFT-ALIGN BODY TEXT ════════════════════
   Justify causes word-gap ugliness in narrow card widths.
════════════════════════════════════════════════════════════ */
.fc-cc-title-v2,
.fc-cc-desc-v2,
.fc-cc-tools-v2,
.fc-cc-meta-v2,
.fc-cc-body-v2 {
  text-align: left !important;
  hyphens: none !important;
}
.fc-cc-desc-v2 {
  text-align: left !important;
}

/* ══ DIFFERENTIATOR SECTION — ALIGNMENT ════════════════════ */
.hv4-diff-grid h2,
section .hv4-diff-grid ~ h2,
.hv4-diff-card .hv4-diff-title {
  text-align: left !important;
  hyphens: none;
}
.hv4-diff-card .hv4-diff-desc {
  text-align: left !important;
  hyphens: none;
}
/* Section heading above diff grid */
.hv4-diff-grid { margin-top: 12px; }

/* ══ SCHOOL CARDS — BUTTON CENTER ══════════════════════════ */
.hv4-school-card .fc-btn,
.hv4-school-card a.fc-btn {
  display: inline-flex !important;
  margin: auto auto 0 auto;  /* push to bottom, center horizontally */
  align-self: center;
}
.hv4-school-card {
  align-items: center; /* center icon + title + desc + btn horizontally */
}

/* ══ COURSE FILTER TABS — TRUNCATE LONG NAMES ══════════════ */
.fc-tab-btn,
button[data-fc-filter],
button[data-tab-filter] {
  max-width: 220px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ══ WHY SECTION — LEFT COLUMN VERTICAL CENTER ═════════════ */
.hv4-app-grid > div:first-child,
.hv4-app-grid .fl {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-self: center;
}

/* ══ ENROLL FORM — LEFT COLUMN VERTICAL CENTER ═════════════ */
.hv4-enroll-grid > div:first-child {
  align-self: center;
}

/* ══ TESTIMONIAL CAROUSEL — ENSURE FULL VISIBILITY ══════════
   fc-tsl-outer clips overflow. fc-tsl-card must not be cut.
════════════════════════════════════════════════════════════ */
.fc-tsl-outer {
  overflow: hidden;
  position: relative;
}
.fc-tsl-track {
  display: flex;
  gap: 20px;
  align-items: stretch;  /* equal height cards */
  will-change: transform;
}
.fc-tsl-card {
  display: flex !important;
  flex-direction: column !important;
  min-height: 220px;
  overflow: visible;
}
.fc-tsl-text {
  flex: 1;
  text-align: left !important;
  hyphens: none !important;
  display: -webkit-box;
  -webkit-line-clamp: 6;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ══════════════════════════════════════════════════════════════════
   FC TESTIMONIAL CAROUSEL v2 — Placement Stories & Happy Customers
   NEW design: card carousel with dots, arrows, touch swipe, autoplay
   Used on: Home page, Placements page
══════════════════════════════════════════════════════════════════ */

/* ── Shared carousel wrapper ── */
.fc-car-wrap {
  position: relative;
  overflow: hidden;
  border-radius: 20px;
}
.fc-car-track {
  display: flex;
  gap: 24px;
  align-items: stretch;
  transition: transform .5s cubic-bezier(.4,0,.2,1);
  will-change: transform;
}

/* ── PLACEMENT STORIES card ── */
.fc-ps-card {
  flex-shrink: 0;
  background: linear-gradient(145deg, rgba(13,22,38,.97) 0%, rgba(8,14,26,.97) 100%);
  border: 1px solid rgba(0,212,170,.15);
  border-top: 3px solid var(--teal, #00D4AA);
  border-radius: 18px;
  padding: 32px 28px 28px;
  display: flex;
  flex-direction: column;
  gap: 0;
  position: relative;
  transition: transform .25s, box-shadow .25s;
  min-height: 300px;
}
.fc-ps-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 48px rgba(0,0,0,.5), 0 0 0 1px rgba(0,212,170,.2);
}
.fc-ps-card-quote {
  font-size: 56px;
  color: var(--teal, #00D4AA);
  opacity: .12;
  line-height: 1;
  font-family: Georgia, serif;
  position: absolute;
  top: 16px;
  left: 24px;
  user-select: none;
  pointer-events: none;
}
.fc-ps-header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 18px;
}
.fc-ps-avatar {
  width: 54px;
  height: 54px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  border: 2.5px solid var(--teal, #00D4AA);
  background: linear-gradient(135deg, #00D4AA 0%, #F0A500 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--fh, sans-serif);
  font-size: 1.2rem;
  font-weight: 900;
  color: #fff;
  flex-shrink: 0;
}
.fc-ps-avatar img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
}
.fc-ps-info { flex: 1; min-width: 0; }
.fc-ps-name {
  font-family: var(--fh, sans-serif);
  font-size: 15px;
  font-weight: 800;
  color: #fff;
  margin-bottom: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.fc-ps-role {
  font-size: 12px;
  color: var(--teal, #00D4AA);
  font-weight: 600;
  font-family: var(--fb, sans-serif);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.fc-ps-company {
  font-size: 11.5px;
  color: var(--muted, #B0C4D8);
  font-family: var(--fb, sans-serif);
  margin-top: 1px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.fc-ps-stars {
  display: flex;
  gap: 3px;
  margin-bottom: 14px;
}
.fc-ps-star { font-size: 16px; color: #F0A500; line-height: 1; }
.fc-ps-star-empty { font-size: 16px; color: rgba(176,196,216,.25); line-height: 1; }
.fc-ps-text {
  font-size: 14px;
  line-height: 1.8;
  color: var(--muted, #B0C4D8);
  font-style: italic;
  flex: 1;
  margin: 0 0 18px;
  display: -webkit-box;
  -webkit-line-clamp: 5;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.fc-ps-course {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 10.5px;
  font-weight: 700;
  color: var(--teal, #00D4AA);
  background: rgba(0,212,170,.07);
  border: 1px solid rgba(0,212,170,.2);
  border-radius: 100px;
  padding: 4px 12px;
  font-family: var(--fb, sans-serif);
  margin-top: auto;
  align-self: flex-start;
}

/* ── HAPPY CUSTOMERS card (same structure, gold accent) ── */
.fc-hc2-card {
  flex-shrink: 0;
  background: linear-gradient(145deg, rgba(13,22,38,.97) 0%, rgba(8,14,26,.97) 100%);
  border: 1px solid rgba(240,165,0,.15);
  border-top: 3px solid var(--gold, #F0A500);
  border-radius: 18px;
  padding: 32px 28px 28px;
  display: flex;
  flex-direction: column;
  gap: 0;
  position: relative;
  transition: transform .25s, box-shadow .25s;
  min-height: 300px;
}
.fc-hc2-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 48px rgba(0,0,0,.5), 0 0 0 1px rgba(240,165,0,.2);
}
.fc-hc2-card .fc-ps-card-quote { color: var(--gold, #F0A500); }
.fc-hc2-card .fc-ps-avatar { border-color: var(--gold, #F0A500); background: linear-gradient(135deg,#F0A500,#ff6b35); }
.fc-hc2-card .fc-ps-role { color: var(--gold, #F0A500); }
.fc-hc2-card .fc-ps-star { color: #F0A500; }
.fc-hc2-card .fc-ps-course { color: var(--gold,#F0A500);background:rgba(240,165,0,.07);border-color:rgba(240,165,0,.2); }

/* ── Navigation: arrows + dots ── */
.fc-car-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-top: 36px;
}
.fc-car-btn {
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 2px solid rgba(0,212,170,.3);
  background: rgba(0,212,170,.06);
  color: var(--teal, #00D4AA);
  font-size: 24px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: .2s;
  line-height: 1;
  flex-shrink: 0;
}
.fc-car-btn:hover {
  background: var(--teal, #00D4AA);
  color: #fff;
  border-color: var(--teal, #00D4AA);
  box-shadow: 0 4px 16px rgba(0,212,170,.35);
}
.fc-hc2-wrap .fc-car-btn {
  border-color: rgba(240,165,0,.3);
  background: rgba(240,165,0,.06);
  color: var(--gold, #F0A500);
}
.fc-hc2-wrap .fc-car-btn:hover {
  background: var(--gold, #F0A500);
  color: #fff;
  border-color: var(--gold, #F0A500);
  box-shadow: 0 4px 16px rgba(240,165,0,.35);
}
.fc-car-dots {
  display: flex; gap: 8px; align-items: center;
}
.fc-car-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: rgba(0,212,170,.2);
  border: none; cursor: pointer;
  transition: .25s; padding: 0; flex-shrink: 0;
}
.fc-car-dot.on {
  background: var(--teal, #00D4AA);
  width: 28px; border-radius: 4px;
}
.fc-hc2-wrap .fc-car-dot { background: rgba(240,165,0,.2); }
.fc-hc2-wrap .fc-car-dot.on { background: var(--gold,#F0A500); }

/* ── See More button ── */
.fc-see-more {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 28px;
  border-radius: 100px;
  border: 2px solid var(--teal, #00D4AA);
  background: transparent;
  color: var(--teal, #00D4AA);
  font-family: var(--fb, sans-serif);
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
  transition: .2s;
  margin-top: 32px;
}
.fc-see-more:hover {
  background: var(--teal, #00D4AA);
  color: #fff;
  box-shadow: 0 6px 20px rgba(0,212,170,.35);
}
.fc-see-more.gold {
  border-color: var(--gold, #F0A500);
  color: var(--gold, #F0A500);
}
.fc-see-more.gold:hover {
  background: var(--gold, #F0A500);
  color: #fff;
  box-shadow: 0 6px 20px rgba(240,165,0,.35);
}

/* ── Responsive ── */
@media (max-width: 768px) {
  .fc-ps-card, .fc-hc2-card { padding: 22px 18px 20px; min-height: 240px; }
  .fc-ps-text { -webkit-line-clamp: 4; }
  .fc-car-wrap { border-radius: 14px; }
}
@media (max-width: 480px) {
  .fc-ps-card, .fc-hc2-card { padding: 18px 14px 16px; }
  .fc-car-btn { width: 38px; height: 38px; font-size: 20px; }
}
/* ══════════════════════════════════════════════════════════════════ */

