/* =========================================================
   UTKAL VIDYAPEETH — "INK STUDIO" DESIGN SYSTEM  v2
   World-class hero + foundation
   Prefix: .uv-  (scoped so it never fights Bootstrap)
   ========================================================= */

:root {
    /* ---- Canvas ---- */
    --uv-bg:        #06070B;
    --uv-bg-2:      #0A0C13;
    --uv-panel:     rgba(255,255,255,.045);
    --uv-panel-2:   rgba(255,255,255,.02);
    --uv-brd:       rgba(255,255,255,.09);
    --uv-brd-2:     rgba(255,255,255,.14);

    /* ---- Ink text ---- */
    --uv-text:      #EEF2F8;
    --uv-muted:     #93A0B4;
    --uv-faint:     #5E6B7E;

    /* ---- Accents ---- */
    --uv-amber:     #FFB020;
    --uv-amber-2:   #FF8A00;
    --uv-cyan:      #38E0CE;
    --uv-teal:      #0FA3A3;
    --uv-violet:    #8B7BFF;

    /* ---- Gradients ---- */
    --uv-g-amber:   linear-gradient(135deg,#FFC24D 0%,#FF8A00 100%);
    --uv-g-cyan:    linear-gradient(135deg,#6AF0DF 0%,#0FA3A3 100%);
    --uv-g-serif:   linear-gradient(120deg,#FFD37A 0%,#FF9A2E 45%,#38E0CE 120%);

    /* ---- Type ---- */
    --uv-head:  'Space Grotesk','Jost',sans-serif;
    --uv-serif: 'Instrument Serif',Georgia,serif;
    --uv-body:  'Inter','Open Sans',sans-serif;

    /* ---- Radii / shadow ---- */
    --uv-r:     18px;
    --uv-r-lg:  26px;
    --uv-pill:  999px;
    --uv-sh:    0 30px 80px -30px rgba(0,0,0,.8);
    --uv-sh-amber: 0 18px 50px -14px rgba(255,138,0,.5);
}

.uv-font-head { font-family: var(--uv-head); }
.uv-font-serif { font-family: var(--uv-serif); }

/* ============ Buttons (magnetic-ready) ============ */
.uv-btn {
    position: relative; display: inline-flex; align-items: center; justify-content: center; gap: 10px;
    font-family: var(--uv-head); font-weight: 600; font-size: 1rem; letter-spacing: .01em;
    padding: 16px 30px; border-radius: var(--uv-pill);
    border: 0; cursor: pointer; text-decoration: none; overflow: hidden;
    transition: transform .3s cubic-bezier(.2,.9,.25,1), box-shadow .3s, background .3s, color .3s;
    will-change: transform;
}
.uv-btn > * { position: relative; z-index: 1; }
.uv-btn-primary { background: var(--uv-g-amber); color: #2a1600; box-shadow: var(--uv-sh-amber); }
.uv-btn-primary:hover { color: #2a1600; box-shadow: 0 24px 60px -12px rgba(255,138,0,.7); }
.uv-btn-ghost {
    background: var(--uv-panel); color: #fff; border: 1px solid var(--uv-brd-2);
    backdrop-filter: blur(10px);
}
.uv-btn-ghost:hover { color: #fff; background: rgba(255,255,255,.09); }
/* sheen sweep */
.uv-btn-primary::after {
    content:""; position:absolute; inset:0; z-index:0;
    background: linear-gradient(115deg,transparent 20%,rgba(255,255,255,.55) 50%,transparent 80%);
    transform: translateX(-130%); transition: transform .7s ease;
}
.uv-btn-primary:hover::after { transform: translateX(130%); }

/* ============ eyebrow / chip ============ */
.uv-eyebrow {
    display:inline-flex; align-items:center; gap:10px;
    font-family:var(--uv-head); font-weight:600; letter-spacing:.22em; text-transform:uppercase;
    font-size:.72rem; color:var(--uv-cyan);
}
.uv-eyebrow::before { content:""; width:30px; height:1px; background:linear-gradient(90deg,var(--uv-cyan),transparent); }

.uv-chip {
    display:inline-flex; align-items:center; gap:9px;
    padding:9px 16px; border-radius:var(--uv-pill);
    font-family:var(--uv-head); font-weight:500; font-size:.82rem;
    background:var(--uv-panel); border:1px solid var(--uv-brd); color:#d6e0ee; backdrop-filter:blur(8px);
}
.uv-chip .dot { width:7px; height:7px; border-radius:50%; background:var(--uv-cyan);
    box-shadow:0 0 0 0 rgba(56,224,206,.6); animation:uv-pulse 1.8s infinite; }
@keyframes uv-pulse { 0%{box-shadow:0 0 0 0 rgba(56,224,206,.55);} 70%{box-shadow:0 0 0 9px rgba(56,224,206,0);} 100%{box-shadow:0 0 0 0 rgba(56,224,206,0);} }

/* =========================================================
   NAV (premium dark glass) — overrides template nav
   ========================================================= */
/* announcement bar */
.uv-announce { background:#050609; border-bottom:1px solid var(--uv-brd); }
.uv-announce-inner { display:flex; align-items:center; justify-content:center; gap:12px;
    padding:10px 20px; font-family:var(--uv-body); font-size:.86rem; color:var(--uv-muted); }
.uv-announce-inner strong { color:#fff; font-weight:600; }
.uv-announce-inner .ann-dot { width:7px; height:7px; border-radius:50%; background:var(--uv-amber);
    box-shadow:0 0 0 0 rgba(255,176,32,.6); animation:uv-pulse 1.8s infinite; }
.uv-announce-inner .ann-link { color:var(--uv-cyan); font-family:var(--uv-head); font-weight:600;
    text-decoration:none; display:inline-flex; align-items:center; gap:7px; transition:gap .25s, color .25s; }
.uv-announce-inner .ann-link:hover { color:#6af0df; gap:11px; }

/* nav — SOLID near-black (fixes the transparent-over-white gray) */
.navbar.uv-nav {
    background:#08090E !important;
    -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px);
    border-bottom:1px solid var(--uv-brd);
    box-shadow:0 8px 30px -20px rgba(0,0,0,.8) !important;
    position:sticky; top:0; z-index:1000;
}
.navbar.uv-nav .navbar-brand { padding:0 !important; background:transparent; }

/* ---- UV logo lockup (native, works on dark) ---- */
.uv-logo { display:inline-flex; align-items:center; gap:12px; text-decoration:none; }
.uv-logo-mark {
    position:relative; width:46px; height:46px; border-radius:13px; flex-shrink:0;
    display:grid; place-items:center; font-family:var(--uv-head); font-weight:700;
    font-size:1.15rem; letter-spacing:-.03em; color:#04211f;
    background:linear-gradient(140deg,#5ef0e0 0%,#17c3c3 45%,#0b8a8a 100%);
    box-shadow:0 8px 22px -8px rgba(23,195,195,.7), inset 0 1px 0 rgba(255,255,255,.35);
}
/* glossy sheen + amber spark accent */
.uv-logo-mark::before { content:""; position:absolute; inset:0; border-radius:13px;
    background:linear-gradient(160deg,rgba(255,255,255,.5),transparent 45%); mix-blend-mode:overlay; }
.uv-logo-mark::after { content:""; position:absolute; top:7px; right:7px; width:6px; height:6px; border-radius:50%;
    background:var(--uv-amber); box-shadow:0 0 8px rgba(255,176,32,.9); }
.uv-logo-word { display:flex; flex-direction:column; line-height:1; }
.uv-logo-word b { font-family:var(--uv-head); font-weight:700; font-size:1.18rem; letter-spacing:-.01em; color:#fff; }
.uv-logo-word small { font-family:var(--uv-body); font-size:.58rem; letter-spacing:.2em; text-transform:uppercase;
    color:var(--uv-cyan); margin-top:5px; font-weight:600; }
/* on light surfaces (print page) */
.uv-logo.on-light .uv-logo-word b { color:var(--uv-navy); }
@media (max-width:420px){ .uv-logo-word small { display:none; } }
.navbar.uv-nav .nav-link {
    color: #c7d2e2 !important; font-family: var(--uv-head); font-weight: 500;
    font-size: .95rem; padding: 10px 16px !important; transition: color .2s;
}
.navbar.uv-nav .nav-link:hover, .navbar.uv-nav .nav-link.active { color: #fff !important; }
.navbar.uv-nav .nav-link.active { position: relative; }
.navbar.uv-nav .nav-link.active::after {
    content:""; position:absolute; left:16px; right:16px; bottom:4px; height:2px; border-radius:2px;
    background: var(--uv-g-cyan);
}
.navbar.uv-nav .dropdown-menu {
    background: #0b0d14; border: 1px solid var(--uv-brd); border-radius: 14px; padding: 8px;
    box-shadow: var(--uv-sh);
}
.navbar.uv-nav .dropdown-item { color: #c7d2e2; border-radius: 9px; padding: 10px 14px; font-family: var(--uv-body); }
.navbar.uv-nav .dropdown-item:hover { background: rgba(56,224,206,.12); color: #fff; }
.navbar.uv-nav .navbar-toggler { border-color: var(--uv-brd); }
.navbar.uv-nav .navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3E%3Cpath stroke='%23ffffff' stroke-width='2' stroke-linecap='round' d='M4 8h22M4 15h22M4 22h22'/%3E%3C/svg%3E");
}
@media (max-width:991px){
    .navbar.uv-nav .navbar-collapse { background:#0b0d14; border:1px solid var(--uv-brd); border-radius:16px; padding:14px; margin-top:10px; }
}

/* =========================================================
   HERO
   ========================================================= */
.uv-hero {
    position: relative; overflow: hidden; isolation: isolate;
    background: var(--uv-bg); color: var(--uv-text);
    padding: 150px 0 96px; min-height: 92vh; display: flex; align-items: center;
}
.uv-container { width: min(1240px, 92%); margin-inline: auto; }

/* aurora glows */
.uv-hero .glow { position:absolute; border-radius:50%; filter:blur(90px); z-index:-2; pointer-events:none; }
.uv-hero .glow.g1 { width:560px;height:560px; top:-160px; right:-60px;
    background:radial-gradient(circle,rgba(56,224,206,.30),transparent 62%); animation:uv-drift-a 20s ease-in-out infinite; }
.uv-hero .glow.g2 { width:520px;height:520px; bottom:-200px; left:-120px;
    background:radial-gradient(circle,rgba(139,123,255,.26),transparent 62%); animation:uv-drift-b 26s ease-in-out infinite; }
.uv-hero .glow.g3 { width:420px;height:420px; top:30%; left:40%;
    background:radial-gradient(circle,rgba(255,138,0,.14),transparent 60%); animation:uv-drift-a 30s ease-in-out infinite; }
@keyframes uv-drift-a { 50%{ transform:translate(-50px,44px) scale(1.12);} }
@keyframes uv-drift-b { 50%{ transform:translate(60px,-40px) scale(1.1);} }

/* grid + grain + pointer spotlight */
.uv-hero .grid-ov { position:absolute; inset:0; z-index:-2; opacity:.5;
    background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
    background-size:60px 60px;
    -webkit-mask-image:radial-gradient(70% 60% at 50% 35%,#000 35%,transparent 100%);
            mask-image:radial-gradient(70% 60% at 50% 35%,#000 35%,transparent 100%); }
.uv-hero .grain { position:absolute; inset:0; z-index:-1; opacity:.06; pointer-events:none; mix-blend-mode:overlay;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
.uv-hero .spotlight { position:absolute; inset:0; z-index:-1; pointer-events:none;
    background:radial-gradient(480px circle at var(--mx,50%) var(--my,30%),rgba(56,224,206,.10),transparent 70%);
    transition:background .2s ease; }

/* layout */
.uv-hero-grid { display:grid; grid-template-columns:1.08fr .92fr; gap:56px; align-items:center; width:100%; }

/* headline */
.uv-hero h1 {
    font-family:var(--uv-head); font-weight:700; color:var(--uv-text);
    font-size:clamp(2.7rem,6vw,5.2rem); line-height:1.0; letter-spacing:-.03em;
    margin:24px 0 26px;
}
.uv-hero h1 .ln > span { color:var(--uv-text); }
.uv-hero h1 .serif {
    font-family:var(--uv-serif); font-weight:400; font-style:italic; letter-spacing:-.01em;
    background:var(--uv-g-serif); -webkit-background-clip:text; background-clip:text; color:transparent;
    padding-right:.06em;
}
.uv-hero h1 .ln { display:block; overflow:hidden; }
.uv-hero h1 .ln > span { display:inline-block; }

.uv-lead { font-family:var(--uv-body); font-size:clamp(1.02rem,1.35vw,1.18rem);
    color:var(--uv-muted); max-width:520px; line-height:1.7; margin-bottom:34px; }
.uv-lead strong { color:#fff; font-weight:600; }

.uv-hero-cta { display:flex; flex-wrap:wrap; gap:14px; margin-bottom:30px; }

.uv-hero-note { display:flex; align-items:center; gap:12px; font-family:var(--uv-body); font-size:.9rem; color:var(--uv-muted); }
.uv-hero-note .avatars { display:inline-flex; }
.uv-hero-note .avatars span { width:30px;height:30px;border-radius:50%;margin-left:-9px;border:2px solid var(--uv-bg);
    background:var(--uv-g-cyan); display:grid;place-items:center;font-size:.68rem;font-weight:700;color:#04211f; font-family:var(--uv-head); }
.uv-hero-note strong { color:#fff; }

/* ---- BENTO ---- */
.uv-bento { display:grid; grid-template-columns:1fr 1fr; grid-auto-rows:auto; gap:16px; }
.uv-card {
    position:relative; border-radius:var(--uv-r-lg); padding:22px;
    background:linear-gradient(160deg,var(--uv-panel),var(--uv-panel-2));
    border:1px solid var(--uv-brd); box-shadow:var(--uv-sh);
    backdrop-filter:blur(12px); overflow:hidden;
    transform-style:preserve-3d; transition:transform .3s ease, border-color .3s;
}
.uv-card:hover { border-color:var(--uv-brd-2); }
.uv-card .c-label { font-family:var(--uv-head); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--uv-faint); display:flex; align-items:center; gap:8px; }
.uv-card .c-live { width:7px;height:7px;border-radius:50%;background:#ff5a5a; box-shadow:0 0 0 0 rgba(255,90,90,.6); animation:uv-pulse 1.6s infinite; }

.uv-card.span2 { grid-column:span 2; }

/* cohort card */
.cohort .big { font-family:var(--uv-head); font-weight:700; font-size:2rem; line-height:1; margin:14px 0 4px; }
.cohort .big #uv-seat-count { background:var(--uv-g-amber); -webkit-background-clip:text; background-clip:text; color:transparent; }
.cohort .sub { font-family:var(--uv-body); font-size:.85rem; color:var(--uv-muted); }
.cohort .meter { margin-top:16px; height:8px; border-radius:99px; background:rgba(255,255,255,.08); overflow:hidden; }
.cohort .meter i { display:block; height:100%; width:0; border-radius:99px; background:var(--uv-g-amber);
    box-shadow:0 0 16px rgba(255,138,0,.6); transition:width 1.4s cubic-bezier(.2,.8,.2,1); }
.cohort .countdown { display:flex; gap:8px; margin-top:16px; }
.cohort .countdown div { flex:1; text-align:center; background:rgba(255,255,255,.04); border:1px solid var(--uv-brd);
    border-radius:12px; padding:9px 4px; }
.cohort .countdown b { font-family:var(--uv-head); font-size:1.15rem; display:block; }
.cohort .countdown small { font-size:.6rem; letter-spacing:.1em; text-transform:uppercase; color:var(--uv-faint); }

/* build card */
.build .chips { display:flex; flex-wrap:wrap; gap:8px; margin-top:14px; }
.build .chips span { font-family:var(--uv-head); font-weight:500; font-size:.78rem; padding:7px 12px;
    border-radius:99px; background:rgba(56,224,206,.08); border:1px solid rgba(56,224,206,.22); color:#b7f3ea; }
.build .cap { font-family:var(--uv-body); font-size:.82rem; color:var(--uv-muted); margin-top:12px; }

/* ai card */
.ai { display:flex; flex-direction:column; justify-content:space-between; }
.ai .orb { width:56px;height:56px;border-radius:50%; margin:8px 0 14px; position:relative;
    background:radial-gradient(circle at 35% 30%,#fff,#38E0CE 40%,#0FA3A3 70%,#0a4b48);
    box-shadow:0 0 30px rgba(56,224,206,.55); animation:uv-bob 5s ease-in-out infinite; }
.ai .orb::after { content:""; position:absolute; inset:-10px; border-radius:50%; border:1px solid rgba(56,224,206,.25); }
.ai .t { font-family:var(--uv-head); font-weight:600; font-size:1.02rem; }
.ai .d { font-family:var(--uv-body); font-size:.82rem; color:var(--uv-muted); margin-top:4px; }
@keyframes uv-bob { 50%{ transform:translateY(-8px);} }

/* price tag floating */
.uv-price-tag { position:absolute; top:-16px; right:-10px; z-index:3;
    font-family:var(--uv-head); font-weight:700; font-size:.9rem;
    padding:12px 16px; border-radius:16px; background:var(--uv-g-amber); color:#2a1600;
    box-shadow:var(--uv-sh-amber); animation:uv-bob 6s ease-in-out infinite; transform:rotate(3deg); }
.uv-price-tag small { display:block; font-weight:600; font-size:.62rem; opacity:.7; text-transform:uppercase; letter-spacing:.1em; }

/* ---- trust strip ---- */
.uv-trust { margin-top:64px; display:grid; grid-template-columns:repeat(4,1fr); gap:20px;
    padding-top:32px; border-top:1px solid rgba(255,255,255,.08); }
.uv-trust .stat .num { font-family:var(--uv-head); font-weight:700; font-size:clamp(1.9rem,3vw,2.7rem); line-height:1;
    background:linear-gradient(180deg,#fff,#a9bdd8); -webkit-background-clip:text; background-clip:text; color:transparent; }
.uv-trust .stat .lbl { font-family:var(--uv-body); color:var(--uv-muted); font-size:.88rem; margin-top:9px; }

/* marquee */
.uv-marquee { overflow:hidden; margin-top:44px; -webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent); }
.uv-marquee .track { display:inline-flex; gap:20px; white-space:nowrap; animation:uv-scroll 30s linear infinite; }
.uv-marquee .track span { font-family:var(--uv-head); font-weight:600; color:var(--uv-faint); font-size:1rem; }
.uv-marquee .track span.dot { color:var(--uv-cyan); }
@keyframes uv-scroll { to { transform:translateX(-50%); } }

/* ---- reveal ---- */
.uv-reveal { opacity:0; transform:translateY(30px); transition:opacity .8s ease, transform .8s cubic-bezier(.2,.8,.2,1); }
.uv-reveal.in { opacity:1; transform:none; }
.uv-reveal.d1{transition-delay:.09s;} .uv-reveal.d2{transition-delay:.18s;}
.uv-reveal.d3{transition-delay:.27s;} .uv-reveal.d4{transition-delay:.36s;} .uv-reveal.d5{transition-delay:.45s;}

/* line-rise for headline */
.uv-rise .ln > span { transform:translateY(110%); opacity:0; transition:transform .9s cubic-bezier(.2,.85,.2,1), opacity .9s; }
.uv-rise.in .ln:nth-child(1) > span { transition-delay:.05s; }
.uv-rise.in .ln:nth-child(2) > span { transition-delay:.16s; }
.uv-rise.in .ln:nth-child(3) > span { transition-delay:.27s; }
.uv-rise.in .ln > span { transform:none; opacity:1; }

/* ============ Responsive ============ */
@media (max-width:960px){
    .uv-hero-grid{ grid-template-columns:1fr; gap:46px; }
    .uv-bento{ max-width:520px; }
    .uv-trust{ grid-template-columns:repeat(2,1fr); gap:28px; }
}
@media (max-width:560px){
    .uv-hero{ padding:120px 0 72px; min-height:auto; }
    .uv-hero-cta .uv-btn{ width:100%; }
    .uv-card.span2{ grid-column:span 2; }
    .uv-bento{ grid-template-columns:1fr 1fr; }
}

@media (prefers-reduced-motion: reduce){
    .uv-hero .glow,.uv-price-tag,.ai .orb,.uv-marquee .track,.uv-chip .dot,.uv-card .c-live{ animation:none !important; }
    .uv-reveal,.uv-rise .ln>span{ opacity:1 !important; transform:none !important; transition:none !important; }
    .uv-hero .spotlight{ display:none; }
}

/* =========================================================
   PHASE 2 — HOME SECTIONS  (Ink Studio)
   ========================================================= */
.uv-sec { position:relative; background:var(--uv-bg); color:var(--uv-text); padding:120px 0; overflow:hidden; }
/* neutralize template's dark global heading colors inside our sections */
.uv-sec h1, .uv-sec h2, .uv-sec h3, .uv-sec h4, .uv-sec h5, .uv-sec h6,
.uv-final h1, .uv-final h2, .uv-final h3 { color:var(--uv-text); }
.uv-sec.alt { background:var(--uv-bg-2); }
.uv-sec .sec-glow { position:absolute; width:560px; height:560px; border-radius:50%; filter:blur(120px); opacity:.5; z-index:0; pointer-events:none; }
.uv-sec .sec-glow.cyan { background:radial-gradient(circle,rgba(56,224,206,.16),transparent 65%); }
.uv-sec .sec-glow.amber { background:radial-gradient(circle,rgba(255,138,0,.14),transparent 65%); }
.uv-sec .sec-glow.violet { background:radial-gradient(circle,rgba(139,123,255,.16),transparent 65%); }
.uv-sec > .uv-container { position:relative; z-index:1; }

/* section head */
.uv-sec-head { max-width:760px; margin:0 auto 64px; text-align:center; }
.uv-sec-head.left { margin-left:0; text-align:left; }
.uv-h2 { font-family:var(--uv-head); font-weight:700; letter-spacing:-.025em; line-height:1.05;
    font-size:clamp(2rem,4.2vw,3.3rem); margin:18px 0 18px; color:var(--uv-text); }
.uv-h2 .serif { font-family:var(--uv-serif); font-weight:400; font-style:italic;
    background:var(--uv-g-serif); -webkit-background-clip:text; background-clip:text; color:transparent; }
.uv-h2 .cyan { background:var(--uv-g-cyan); -webkit-background-clip:text; background-clip:text; color:transparent; }
.uv-sub { font-family:var(--uv-body); font-size:1.08rem; color:var(--uv-muted); line-height:1.7; }

/* generic card */
.uv-panel { position:relative; border-radius:var(--uv-r-lg); padding:28px;
    background:linear-gradient(160deg,var(--uv-panel),var(--uv-panel-2));
    border:1px solid var(--uv-brd); overflow:hidden; transition:transform .35s cubic-bezier(.2,.8,.2,1), border-color .35s, box-shadow .35s; }
.uv-panel:hover { transform:translateY(-6px); border-color:var(--uv-brd-2); box-shadow:var(--uv-sh); }
.uv-ic { width:52px; height:52px; border-radius:14px; display:grid; place-items:center; font-size:1.25rem; }
.uv-ic.cyan { background:rgba(56,224,206,.12); color:var(--uv-cyan); border:1px solid rgba(56,224,206,.25); }
.uv-ic.amber { background:rgba(255,138,0,.12); color:var(--uv-amber); border:1px solid rgba(255,138,0,.28); }
.uv-ic.violet { background:rgba(139,123,255,.12); color:var(--uv-violet); border:1px solid rgba(139,123,255,.28); }
.uv-ic.red { background:rgba(255,90,90,.12); color:#ff7a7a; border:1px solid rgba(255,90,90,.28); }

.uv-grid { display:grid; gap:22px; }
.uv-g3 { grid-template-columns:repeat(3,1fr); }
.uv-g4 { grid-template-columns:repeat(4,1fr); }
.uv-g2 { grid-template-columns:repeat(2,1fr); }

/* ---- Reality Check ---- */
.uv-reality .stat-big { font-family:var(--uv-head); font-weight:700; font-size:clamp(2.6rem,5vw,3.6rem); line-height:1;
    background:linear-gradient(180deg,#ff8a8a,#ff5a5a); -webkit-background-clip:text; background-clip:text; color:transparent; }
.uv-reality .uv-panel p { color:var(--uv-muted); margin:12px 0 0; font-family:var(--uv-body); }
.uv-turn { margin-top:56px; text-align:center; }
.uv-turn h3 { font-family:var(--uv-head); font-weight:700; font-size:clamp(1.6rem,3.4vw,2.4rem); }
.uv-turn h3 .hl { background:var(--uv-g-amber); -webkit-background-clip:text; background-clip:text; color:transparent; }

/* ---- Capstone cards ---- */
.uv-cap-card { padding:0; }
.uv-cap-card .cap-top { height:150px; display:flex; align-items:flex-end; padding:20px; position:relative; overflow:hidden; }
.uv-cap-card .cap-top::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent,rgba(6,7,11,.6)); }
.uv-cap-card .cap-logo { position:relative; z-index:1; font-family:var(--uv-head); font-weight:700; font-size:1.5rem; color:#fff; }
.uv-cap-card .cap-body { padding:22px; }
.uv-cap-card .cap-body h4 { font-family:var(--uv-head); font-weight:600; font-size:1.12rem; margin-bottom:6px; }
.uv-cap-card .cap-body p { font-family:var(--uv-body); font-size:.9rem; color:var(--uv-muted); margin-bottom:14px; }
.uv-tags { display:flex; flex-wrap:wrap; gap:7px; }
.uv-tags span { font-family:var(--uv-head); font-weight:500; font-size:.74rem; padding:6px 11px; border-radius:99px;
    background:rgba(255,255,255,.05); border:1px solid var(--uv-brd); color:#c7d2e2; }
.cap-zomato { background:linear-gradient(135deg,#ff5a5f,#c1121f); }
.cap-uber { background:linear-gradient(135deg,#1f2937,#000); }
.cap-airbnb { background:linear-gradient(135deg,#ff385c,#bd1e59); }
.cap-zepto { background:linear-gradient(135deg,#7c3aed,#4c1d95); }

/* ---- AI Edge ---- */
.uv-split { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
.uv-feat-list { display:flex; flex-direction:column; gap:14px; }
.uv-feat { display:flex; gap:16px; align-items:flex-start; padding:18px; border-radius:16px;
    background:var(--uv-panel-2); border:1px solid var(--uv-brd); transition:border-color .3s, transform .3s; }
.uv-feat:hover { border-color:rgba(56,224,206,.4); transform:translateX(6px); }
.uv-feat .fi { flex-shrink:0; width:44px; height:44px; border-radius:12px; display:grid; place-items:center;
    background:rgba(56,224,206,.12); color:var(--uv-cyan); font-size:1.05rem; }
.uv-feat h4 { font-family:var(--uv-head); font-weight:600; font-size:1.02rem; margin-bottom:3px; }
.uv-feat p { font-family:var(--uv-body); font-size:.88rem; color:var(--uv-muted); margin:0; }
.uv-aiviz { position:relative; border-radius:var(--uv-r-lg); min-height:420px; display:grid; place-items:center;
    background:radial-gradient(circle at 50% 40%,rgba(56,224,206,.14),transparent 60%),linear-gradient(160deg,var(--uv-panel),var(--uv-panel-2));
    border:1px solid var(--uv-brd); overflow:hidden; }
.uv-aiviz .core { width:130px; height:130px; border-radius:50%; position:relative; z-index:2;
    background:radial-gradient(circle at 35% 30%,#fff,#38E0CE 42%,#0FA3A3 72%,#0a4b48);
    box-shadow:0 0 60px rgba(56,224,206,.55); animation:uv-bob 5s ease-in-out infinite; }
.uv-aiviz .ring { position:absolute; border:1px solid rgba(56,224,206,.22); border-radius:50%; animation:uv-spin 18s linear infinite; }
.uv-aiviz .ring.r1 { width:230px; height:230px; } .uv-aiviz .ring.r2 { width:330px; height:330px; animation-duration:26s; } .uv-aiviz .ring.r3 { width:430px; height:430px; animation-duration:34s; }
.uv-aiviz .ring span { position:absolute; top:-5px; left:50%; width:10px; height:10px; border-radius:50%; background:var(--uv-cyan); box-shadow:0 0 14px var(--uv-cyan); }
@keyframes uv-spin { to { transform:rotate(360deg); } }

/* ---- Timeline / roadmap ---- */
.uv-timeline { position:relative; display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.uv-timeline::before { content:""; position:absolute; top:26px; left:6%; right:6%; height:2px;
    background:linear-gradient(90deg,rgba(56,224,206,.15),var(--uv-cyan),var(--uv-amber)); z-index:0; }
.uv-step { position:relative; z-index:1; text-align:center; }
.uv-step .node { width:54px; height:54px; margin:0 auto 20px; border-radius:16px; display:grid; place-items:center;
    font-family:var(--uv-head); font-weight:700; background:#0b0d14; border:1px solid var(--uv-brd-2); color:var(--uv-cyan);
    box-shadow:0 0 0 6px var(--uv-bg); font-size:1.1rem; }
.uv-step.last .node { background:var(--uv-g-amber); color:#2a1600; border-color:transparent; box-shadow:0 0 0 6px var(--uv-bg),0 0 30px rgba(255,138,0,.5); }
.uv-step .mo { font-family:var(--uv-head); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--uv-faint); }
.uv-step h4 { font-family:var(--uv-head); font-weight:600; font-size:1.05rem; margin:8px 0 6px; }
.uv-step p { font-family:var(--uv-body); font-size:.88rem; color:var(--uv-muted); }

/* ---- Value stack ---- */
.uv-value-wrap { max-width:820px; margin:0 auto; }
.uv-value-row { display:flex; align-items:center; gap:16px; padding:16px 20px; border-bottom:1px solid var(--uv-brd); }
.uv-value-row .vi { width:40px; height:40px; border-radius:11px; display:grid; place-items:center; flex-shrink:0;
    background:rgba(56,224,206,.1); color:var(--uv-cyan); }
.uv-value-row .vt { flex:1; font-family:var(--uv-body); }
.uv-value-row .vt b { font-family:var(--uv-head); font-weight:600; display:block; color:var(--uv-text); }
.uv-value-row .vt small { color:var(--uv-muted); }
.uv-value-row .vp { font-family:var(--uv-head); font-weight:600; color:var(--uv-muted); text-decoration:line-through; }
.uv-value-row .vp.free { color:var(--uv-cyan); text-decoration:none; }
.uv-value-total { margin-top:30px; text-align:center; padding:32px; border-radius:var(--uv-r-lg);
    background:linear-gradient(160deg,rgba(255,138,0,.08),var(--uv-panel-2)); border:1px solid rgba(255,138,0,.25); }
.uv-value-total .worth { font-family:var(--uv-body); color:var(--uv-muted); }
.uv-value-total .worth s { color:#ff7a7a; }
.uv-value-total .now { font-family:var(--uv-head); font-weight:700; font-size:clamp(2rem,4vw,2.8rem); margin:8px 0 4px; }
.uv-value-total .now .hl { background:var(--uv-g-amber); -webkit-background-clip:text; background-clip:text; color:transparent; }

/* ---- Tools ---- */
.uv-tool { text-align:left; }
.uv-tool .badge-soon { position:absolute; top:18px; right:18px; font-family:var(--uv-head); font-weight:600; font-size:.66rem;
    letter-spacing:.1em; text-transform:uppercase; padding:5px 10px; border-radius:99px; background:rgba(56,224,206,.14); color:var(--uv-cyan); border:1px solid rgba(56,224,206,.3); }
.uv-tool h4 { font-family:var(--uv-head); font-weight:600; font-size:1.1rem; margin:18px 0 8px; }
.uv-tool p { font-family:var(--uv-body); font-size:.9rem; color:var(--uv-muted); }

/* ---- Testimonials ---- */
.uv-quote { display:flex; flex-direction:column; height:100%; }
.uv-quote .stars { color:var(--uv-amber); margin-bottom:14px; letter-spacing:2px; }
.uv-quote blockquote { font-family:var(--uv-body); font-size:1rem; line-height:1.7; color:#dde5ef; margin:0 0 20px; flex:1; }
.uv-quote .who { display:flex; align-items:center; gap:12px; }
.uv-quote .who .av { width:44px; height:44px; border-radius:50%; display:grid; place-items:center; font-family:var(--uv-head); font-weight:700; color:#04211f; background:var(--uv-g-cyan); }
.uv-quote .who b { font-family:var(--uv-head); font-weight:600; display:block; font-size:.95rem; }
.uv-quote .who small { color:var(--uv-cyan); font-size:.82rem; }

/* ---- Mentors ---- */
.uv-mentor { text-align:center; }
.uv-mentor .m-av { width:96px; height:96px; border-radius:50%; margin:0 auto 16px; display:grid; place-items:center;
    font-family:var(--uv-head); font-weight:700; font-size:1.6rem; color:#04211f; background:var(--uv-g-cyan);
    border:2px solid var(--uv-brd-2); }
.uv-mentor h4 { font-family:var(--uv-head); font-weight:600; font-size:1.05rem; }
.uv-mentor .role { color:var(--uv-cyan); font-size:.85rem; font-family:var(--uv-head); }
.uv-mentor p { font-family:var(--uv-body); font-size:.86rem; color:var(--uv-muted); margin-top:10px; }

/* ---- Pricing ---- */
.uv-price-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; align-items:stretch; }
.uv-plan { display:flex; flex-direction:column; }
.uv-plan.pop { border-color:rgba(255,138,0,.4); box-shadow:0 0 50px -18px rgba(255,138,0,.5); }
.uv-plan .p-tag { align-self:flex-start; font-family:var(--uv-head); font-weight:600; font-size:.68rem; letter-spacing:.12em; text-transform:uppercase;
    padding:6px 12px; border-radius:99px; background:var(--uv-g-amber); color:#2a1600; margin-bottom:18px; }
.uv-plan h4 { font-family:var(--uv-head); font-weight:600; font-size:1.15rem; }
.uv-plan .p-price { font-family:var(--uv-head); font-weight:700; font-size:2.6rem; margin:14px 0 2px; }
.uv-plan .p-price small { font-size:1rem; color:var(--uv-muted); font-weight:500; }
.uv-plan .p-desc { font-family:var(--uv-body); color:var(--uv-muted); font-size:.9rem; margin-bottom:20px; }
.uv-plan ul { list-style:none; padding:0; margin:0 0 26px; display:flex; flex-direction:column; gap:12px; flex:1; }
.uv-plan ul li { font-family:var(--uv-body); font-size:.92rem; color:#cdd7e4; display:flex; gap:10px; align-items:flex-start; }
.uv-plan ul li i { color:var(--uv-cyan); margin-top:3px; }
.uv-guarantee { margin-top:34px; text-align:center; display:inline-flex; align-items:center; gap:10px;
    padding:14px 24px; border-radius:99px; background:rgba(56,224,206,.08); border:1px solid rgba(56,224,206,.25);
    color:#bdeee7; font-family:var(--uv-body); font-size:.95rem; }

/* ---- FAQ ---- */
.uv-faq { max-width:820px; margin:0 auto; }
.uv-faq-item { border:1px solid var(--uv-brd); border-radius:16px; margin-bottom:14px; background:var(--uv-panel-2); overflow:hidden; }
.uv-faq-q { width:100%; text-align:left; background:none; border:0; cursor:pointer; padding:22px 24px;
    font-family:var(--uv-head); font-weight:600; font-size:1.05rem; color:var(--uv-text); display:flex; justify-content:space-between; align-items:center; gap:16px; }
.uv-faq-q .pm { flex-shrink:0; width:28px; height:28px; border-radius:8px; display:grid; place-items:center;
    background:rgba(56,224,206,.12); color:var(--uv-cyan); transition:transform .3s; }
.uv-faq-item.open .uv-faq-q .pm { transform:rotate(45deg); }
.uv-faq-a { max-height:0; overflow:hidden; transition:max-height .4s ease; }
.uv-faq-a p { padding:0 24px 22px; margin:0; font-family:var(--uv-body); color:var(--uv-muted); line-height:1.7; }

/* ---- Final CTA ---- */
.uv-final { background:var(--uv-bg); padding:120px 0; }
.uv-final-panel { position:relative; border-radius:32px; padding:72px 48px; text-align:center; overflow:hidden;
    background:radial-gradient(700px 400px at 50% -10%,rgba(255,176,32,.28),transparent 60%),linear-gradient(160deg,#12141c,#0a0c13);
    border:1px solid rgba(255,138,0,.3); }
.uv-final-panel .fp-glow { position:absolute; inset:0; z-index:0;
    background:radial-gradient(500px circle at 50% 120%,rgba(56,224,206,.18),transparent 60%); }
.uv-final-panel > * { position:relative; z-index:1; }
.uv-final h2 { font-family:var(--uv-head); font-weight:700; letter-spacing:-.02em; line-height:1.08;
    font-size:clamp(2rem,4.6vw,3.4rem); max-width:820px; margin:0 auto 20px; }
.uv-final h2 .serif { font-family:var(--uv-serif); font-style:italic; font-weight:400;
    background:var(--uv-g-amber); -webkit-background-clip:text; background-clip:text; color:transparent; }
.uv-final .fp-sub { font-family:var(--uv-body); color:#c7d2e2; font-size:1.1rem; max-width:560px; margin:0 auto 34px; }
.uv-final .fp-meta { margin-top:26px; font-family:var(--uv-body); color:var(--uv-muted); font-size:.9rem; }
.uv-final .fp-meta b { color:var(--uv-amber); }

/* ---- Footer v2 (premium dark) ---- */
.uv-footer2 { background:#05060A; border-top:1px solid var(--uv-brd); padding:72px 0 30px;
    color:var(--uv-muted); font-family:var(--uv-body); position:relative; }
.uv-foot-grid { display:grid; grid-template-columns:1.7fr 1fr 1fr 1.3fr; gap:40px;
    padding-bottom:44px; border-bottom:1px solid var(--uv-brd); }
.uv-foot-brand .uv-foot-logo { display:inline-flex; background:#fff; padding:6px 12px; border-radius:11px;
    margin-bottom:20px; box-shadow:0 6px 18px -8px rgba(0,0,0,.6); }
.uv-foot-brand .uv-foot-logo img { height:40px; width:auto; display:block; }
.uv-foot-brand p { max-width:330px; line-height:1.75; font-size:.92rem; color:var(--uv-muted); }
.uv-socials { display:flex; gap:10px; margin-top:22px; }
.uv-socials a { width:40px; height:40px; border-radius:11px; display:grid; place-items:center;
    color:var(--uv-muted); background:var(--uv-panel); border:1px solid var(--uv-brd); transition:all .25s; }
.uv-socials a:hover { color:#04211f; background:var(--uv-g-cyan); border-color:transparent; transform:translateY(-3px); }
.uv-foot-col h4 { font-family:var(--uv-head); font-weight:600; color:#fff; font-size:.95rem; margin:4px 0 16px; }
.uv-foot-col a { display:block; color:var(--uv-muted); text-decoration:none; font-size:.92rem; padding:7px 0;
    transition:color .2s, padding-left .2s; width:fit-content; }
.uv-foot-col a:hover { color:var(--uv-cyan); padding-left:5px; }
.uv-foot-contact a { display:flex; align-items:center; gap:10px; }
.uv-foot-contact a:hover { padding-left:0; }
.uv-foot-contact a i { color:var(--uv-cyan); width:16px; text-align:center; }
.uv-foot-bottom { display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap;
    padding-top:26px; font-size:.86rem; color:var(--uv-faint); }
.uv-foot-bottom .fb-mission { font-family:var(--uv-serif); font-style:italic; color:var(--uv-cyan); font-size:1.08rem; }
@media (max-width:900px){
    .uv-foot-grid { grid-template-columns:1fr 1fr; gap:32px 24px; }
    .uv-foot-brand { grid-column:1 / -1; }
}
@media (max-width:560px){
    .uv-footer2 { padding:56px 0 24px; }
    .uv-foot-grid { grid-template-columns:1fr; }
    .uv-foot-bottom { flex-direction:column; text-align:center; }
}

@media (max-width:960px){
    .uv-g3,.uv-g4 { grid-template-columns:repeat(2,1fr); }
    .uv-split { grid-template-columns:1fr; gap:36px; }
    .uv-timeline { grid-template-columns:repeat(2,1fr); }
    .uv-timeline::before { display:none; }
    .uv-price-grid { grid-template-columns:1fr; max-width:440px; margin-inline:auto; }
}
@media (max-width:560px){
    .uv-sec { padding:84px 0; }
    .uv-g3,.uv-g4,.uv-g2 { grid-template-columns:1fr; }
    .uv-final-panel { padding:48px 24px; }
}
@media (prefers-reduced-motion: reduce){
    .uv-aiviz .core,.uv-aiviz .ring { animation:none !important; }
}

/* =========================================================
   PHASE 3 — SUB-PAGE COMPONENTS
   ========================================================= */
/* ---- sub-page banner ---- */
.uv-banner { position:relative; overflow:hidden; isolation:isolate; border-bottom:1px solid var(--uv-brd);
    background:var(--uv-bg); color:var(--uv-text); padding:160px 0 84px; }
.uv-banner h1, .uv-banner h2, .uv-banner h3 { color:var(--uv-text); }
.uv-banner .b-glow { position:absolute; border-radius:50%; filter:blur(90px); z-index:-2; pointer-events:none; }
.uv-banner .b-glow.cyan { width:520px;height:520px; top:-160px; right:-80px; background:radial-gradient(circle,rgba(56,224,206,.24),transparent 62%); }
.uv-banner .b-glow.violet { width:460px;height:460px; bottom:-200px; left:-120px; background:radial-gradient(circle,rgba(139,123,255,.2),transparent 62%); }
.uv-banner .grid-ov { position:absolute; inset:0; z-index:-2; opacity:.4;
    background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
    background-size:60px 60px; -webkit-mask-image:radial-gradient(70% 70% at 50% 30%,#000 30%,transparent 100%); mask-image:radial-gradient(70% 70% at 50% 30%,#000 30%,transparent 100%); }
.uv-banner .spotlight { position:absolute; inset:0; z-index:-1; pointer-events:none;
    background:radial-gradient(460px circle at var(--mx,50%) var(--my,30%),rgba(56,224,206,.1),transparent 70%); }
.uv-breadcrumb { display:flex; gap:10px; align-items:center; font-family:var(--uv-head); font-size:.85rem; margin-bottom:22px; }
.uv-breadcrumb a { color:var(--uv-muted); text-decoration:none; transition:color .2s; }
.uv-breadcrumb a:hover { color:var(--uv-cyan); }
.uv-breadcrumb .sep { color:var(--uv-faint); }
.uv-breadcrumb .cur { color:var(--uv-cyan); }
.uv-banner h1 { font-family:var(--uv-head); font-weight:700; letter-spacing:-.025em; line-height:1.04;
    font-size:clamp(2.4rem,5vw,4rem); margin:14px 0 18px; }
.uv-banner h1 .serif { font-family:var(--uv-serif); font-weight:400; font-style:italic;
    background:var(--uv-g-serif); -webkit-background-clip:text; background-clip:text; color:transparent; }
.uv-banner .b-sub { font-family:var(--uv-body); color:var(--uv-muted); font-size:1.12rem; max-width:620px; line-height:1.7; }
.uv-banner .b-cta { margin-top:32px; display:flex; gap:14px; flex-wrap:wrap; }
.uv-banner .b-stats { margin-top:44px; display:flex; gap:40px; flex-wrap:wrap; }
.uv-banner .b-stats .s b { font-family:var(--uv-head); font-weight:700; font-size:1.7rem; display:block; }
.uv-banner .b-stats .s span { font-family:var(--uv-body); color:var(--uv-muted); font-size:.86rem; }

/* ---- dark forms ---- */
.uv-form { display:grid; gap:18px; }
.uv-form .row2 { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.uv-field label { display:block; font-family:var(--uv-head); font-weight:500; font-size:.82rem; color:var(--uv-muted); margin-bottom:8px; }
.uv-form input, .uv-form select, .uv-form textarea {
    width:100%; background:var(--uv-panel) !important; border:1px solid var(--uv-brd) !important; border-radius:12px !important;
    color:var(--uv-text) !important; font-family:var(--uv-body); font-size:.95rem; padding:14px 16px !important; height:auto !important; outline:none;
    transition:border-color .2s, box-shadow .2s; }
.uv-form input::placeholder, .uv-form textarea::placeholder { color:var(--uv-faint); }
.uv-form input:focus, .uv-form select:focus, .uv-form textarea:focus {
    border-color:var(--uv-cyan) !important; box-shadow:0 0 0 3px rgba(56,224,206,.15); }
.uv-form textarea { min-height:130px; resize:vertical; }
.uv-form select { -webkit-appearance:none; appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='%2393A0B4'%3E%3Cpath d='M7 10L2 4h10z'/%3E%3C/svg%3E") !important;
    background-repeat:no-repeat !important; background-position:right 16px center !important; padding-right:40px !important; }
.uv-form select option { background:#0b0d14; color:#fff; }

/* ---- check list ---- */
.uv-check { list-style:none; padding:0; margin:0; display:grid; gap:14px; }
.uv-check li { display:flex; gap:12px; align-items:flex-start; font-family:var(--uv-body); color:#cdd7e4; line-height:1.5; }
.uv-check li i { color:var(--uv-cyan); margin-top:4px; flex-shrink:0; }

/* ---- numbered module (curriculum) ---- */
.uv-module { display:flex; gap:18px; align-items:flex-start; }
.uv-module .m-num { flex-shrink:0; width:44px; height:44px; border-radius:12px; display:grid; place-items:center;
    font-family:var(--uv-head); font-weight:700; color:var(--uv-cyan); background:rgba(56,224,206,.1); border:1px solid rgba(56,224,206,.25); }
.uv-module h4 { font-family:var(--uv-head); font-weight:600; color:var(--uv-text); font-size:1.05rem; margin:6px 0 6px; }
.uv-module p { font-family:var(--uv-body); font-size:.9rem; color:var(--uv-muted); margin:0; }

/* ---- info row (contact) ---- */
.uv-info-row { display:flex; gap:16px; align-items:center; padding:16px 0; }
.uv-info-row .ir-ic { width:46px; height:46px; border-radius:13px; display:grid; place-items:center; flex-shrink:0;
    background:rgba(56,224,206,.1); color:var(--uv-cyan); border:1px solid rgba(56,224,206,.22); font-size:1.05rem; }
.uv-info-row .ir-t small { display:block; font-family:var(--uv-head); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--uv-faint); margin-bottom:3px; }
.uv-info-row .ir-t b { font-family:var(--uv-body); font-weight:500; color:var(--uv-text); }

@media (max-width:760px){
    .uv-banner { padding:130px 0 64px; }
    .uv-form .row2 { grid-template-columns:1fr; }
    .uv-banner .b-cta .uv-btn { width:100%; }
}

/* =========================================================
   PHASE 4 — FREE TOOLS
   ========================================================= */
.uv-tool-grid { display:grid; grid-template-columns:1fr 1fr; gap:26px; align-items:start; }
.uv-tool-panel { position:relative; border-radius:var(--uv-r-lg); padding:32px;
    background:linear-gradient(160deg,var(--uv-panel),var(--uv-panel-2)); border:1px solid var(--uv-brd); }
.uv-tool-panel h3 { font-family:var(--uv-head); font-weight:600; color:var(--uv-text); font-size:1.2rem; margin:0 0 6px; }
.uv-tool-panel .th-sub { font-family:var(--uv-body); color:var(--uv-muted); font-size:.92rem; margin-bottom:22px; }

/* score gauge */
.uv-gauge-wrap { display:flex; flex-direction:column; align-items:center; text-align:center; }
.uv-gauge { --v:0; width:190px; height:190px; border-radius:50%; display:grid; place-items:center; position:relative;
    background:conic-gradient(var(--gc,var(--uv-cyan)) calc(var(--v)*3.6deg), rgba(255,255,255,.07) 0);
    transition:--v .1s; }
.uv-gauge::before { content:""; position:absolute; inset:14px; border-radius:50%; background:#0a0c13; border:1px solid var(--uv-brd); }
.uv-gauge .g-inner { position:relative; z-index:1; }
.uv-gauge .g-num { font-family:var(--uv-head); font-weight:700; font-size:3rem; line-height:1; color:#fff; }
.uv-gauge .g-lbl { font-family:var(--uv-head); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--uv-faint); margin-top:4px; }
.uv-grade { margin-top:18px; font-family:var(--uv-head); font-weight:600; font-size:1.1rem; padding:8px 20px; border-radius:99px; display:inline-block; }
.uv-grade.good { background:rgba(56,224,206,.12); color:var(--uv-cyan); border:1px solid rgba(56,224,206,.3); }
.uv-grade.mid { background:rgba(255,176,32,.12); color:var(--uv-amber); border:1px solid rgba(255,176,32,.3); }
.uv-grade.low { background:rgba(255,90,90,.12); color:#ff7a7a; border:1px solid rgba(255,90,90,.3); }

/* score breakdown rows */
.uv-break { display:grid; gap:14px; margin-top:6px; }
.uv-break-row .br-top { display:flex; justify-content:space-between; font-family:var(--uv-body); font-size:.9rem; color:#cdd7e4; margin-bottom:7px; }
.uv-break-row .br-top b { font-family:var(--uv-head); color:#fff; }
.uv-break-row .br-bar { height:8px; border-radius:99px; background:rgba(255,255,255,.07); overflow:hidden; }
.uv-break-row .br-bar i { display:block; height:100%; width:0; border-radius:99px; background:var(--uv-g-cyan); transition:width 1s cubic-bezier(.2,.8,.2,1); }

/* suggestions */
.uv-sugg { list-style:none; padding:0; margin:18px 0 0; display:grid; gap:12px; }
.uv-sugg li { display:flex; gap:12px; align-items:flex-start; font-family:var(--uv-body); font-size:.92rem; color:#cdd7e4;
    padding:14px 16px; border-radius:12px; background:var(--uv-panel-2); border:1px solid var(--uv-brd); line-height:1.5; }
.uv-sugg li i { margin-top:3px; flex-shrink:0; }
.uv-sugg li.ok i { color:var(--uv-cyan); }
.uv-sugg li.warn i { color:var(--uv-amber); }
.uv-sugg li.bad i { color:#ff7a7a; }

/* checkbox / toggle checklist (linkedin) */
.uv-checklist { display:grid; gap:12px; }
.uv-checklist label { display:flex; align-items:center; gap:14px; padding:15px 18px; border-radius:13px; cursor:pointer;
    background:var(--uv-panel-2); border:1px solid var(--uv-brd); font-family:var(--uv-body); color:#cdd7e4; transition:border-color .2s, background .2s; }
.uv-checklist label:hover { border-color:var(--uv-brd-2); }
.uv-checklist input { display:none; }
.uv-checklist .box { width:22px; height:22px; border-radius:7px; border:1.5px solid var(--uv-brd-2); flex-shrink:0; display:grid; place-items:center; transition:all .2s; }
.uv-checklist .box i { font-size:.7rem; color:#04211f; opacity:0; }
.uv-checklist input:checked + .box { background:var(--uv-g-cyan); border-color:transparent; }
.uv-checklist input:checked + .box i { opacity:1; }
.uv-checklist input:checked ~ span { color:#fff; }

/* quiz */
.uv-quiz-progress { height:6px; border-radius:99px; background:rgba(255,255,255,.08); overflow:hidden; margin-bottom:28px; }
.uv-quiz-progress i { display:block; height:100%; width:0; border-radius:99px; background:var(--uv-g-cyan); transition:width .4s ease; }
.uv-quiz-step { display:none; }
.uv-quiz-step.active { display:block; animation:uv-fade .4s ease; }
@keyframes uv-fade { from{opacity:0;transform:translateY(10px);} to{opacity:1;transform:none;} }
.uv-quiz-q { font-family:var(--uv-head); font-weight:600; color:#fff; font-size:1.35rem; margin:0 0 6px; }
.uv-quiz-hint { font-family:var(--uv-body); color:var(--uv-muted); font-size:.9rem; margin-bottom:22px; }
.uv-opt { display:grid; gap:12px; }
.uv-opt button { text-align:left; width:100%; padding:17px 20px; border-radius:14px; cursor:pointer;
    background:var(--uv-panel-2); border:1px solid var(--uv-brd); color:#dbe4f0; font-family:var(--uv-body); font-size:.98rem;
    transition:border-color .2s, background .2s, transform .15s; display:flex; align-items:center; gap:14px; }
.uv-opt button:hover { border-color:rgba(56,224,206,.45); transform:translateX(4px); }
.uv-opt button .k { width:28px; height:28px; border-radius:8px; flex-shrink:0; display:grid; place-items:center;
    font-family:var(--uv-head); font-weight:600; font-size:.82rem; background:rgba(56,224,206,.12); color:var(--uv-cyan); }
.uv-quiz-nav { display:flex; justify-content:space-between; margin-top:26px; }
.uv-quiz-back { background:none; border:0; color:var(--uv-muted); font-family:var(--uv-head); cursor:pointer; font-size:.9rem; }
.uv-quiz-back:hover { color:#fff; }

/* roadmap result */
.uv-roadmap { display:grid; gap:12px; margin-top:18px; }
.uv-roadmap .rm { display:flex; gap:14px; align-items:flex-start; padding:16px; border-radius:13px; background:var(--uv-panel-2); border:1px solid var(--uv-brd); }
.uv-roadmap .rm .rn { width:32px; height:32px; border-radius:9px; flex-shrink:0; display:grid; place-items:center; font-family:var(--uv-head); font-weight:700; font-size:.85rem; background:var(--uv-g-cyan); color:#04211f; }
.uv-roadmap .rm b { font-family:var(--uv-head); color:#fff; display:block; font-size:.98rem; }
.uv-roadmap .rm span { font-family:var(--uv-body); color:var(--uv-muted); font-size:.88rem; }

/* calculator */
.uv-calc-result { text-align:center; }
.uv-calc-big { font-family:var(--uv-head); font-weight:700; font-size:clamp(2.4rem,5vw,3.4rem); line-height:1;
    background:var(--uv-g-cyan); -webkit-background-clip:text; background-clip:text; color:transparent; }
.uv-calc-cap { font-family:var(--uv-body); color:var(--uv-muted); font-size:.9rem; margin-top:8px; }
.uv-calc-bars { margin-top:28px; display:grid; gap:18px; }
.uv-calc-bar .cb-top { display:flex; justify-content:space-between; font-family:var(--uv-body); font-size:.88rem; color:#cdd7e4; margin-bottom:8px; }
.uv-calc-bar .cb-top b { font-family:var(--uv-head); }
.uv-calc-bar .cb-track { height:38px; border-radius:12px; background:rgba(255,255,255,.05); overflow:hidden; }
.uv-calc-bar .cb-track i { display:flex; align-items:center; padding-left:14px; height:100%; width:0; border-radius:12px;
    font-family:var(--uv-head); font-weight:600; font-size:.85rem; color:#04211f; transition:width 1.1s cubic-bezier(.2,.8,.2,1); white-space:nowrap; }
.uv-calc-bar.invest i { background:linear-gradient(90deg,#5b6b82,#8895a8); }
.uv-calc-bar.earn i { background:var(--uv-g-amber); }

.uv-range { width:100%; -webkit-appearance:none; appearance:none; height:6px; border-radius:99px; background:rgba(255,255,255,.1); outline:none; }
.uv-range::-webkit-slider-thumb { -webkit-appearance:none; width:22px; height:22px; border-radius:50%; background:var(--uv-cyan); cursor:pointer; box-shadow:0 0 12px rgba(56,224,206,.6); }
.uv-seg { display:flex; gap:10px; flex-wrap:wrap; }
.uv-seg button { flex:1; min-width:120px; padding:14px; border-radius:12px; cursor:pointer; font-family:var(--uv-head); font-weight:500;
    background:var(--uv-panel-2); border:1px solid var(--uv-brd); color:#cdd7e4; transition:all .2s; }
.uv-seg button.on { background:rgba(56,224,206,.12); border-color:rgba(56,224,206,.4); color:#fff; }

.uv-tool-empty { text-align:center; color:var(--uv-faint); font-family:var(--uv-body); padding:40px 10px; }
.uv-tool-empty i { font-size:2.4rem; color:var(--uv-brd-2); margin-bottom:14px; display:block; }

@media (max-width:860px){ .uv-tool-grid { grid-template-columns:1fr; } }

/* ---- form alerts / validation ---- */
.uv-alert { border-radius:14px; padding:18px 20px; margin-bottom:22px; font-family:var(--uv-body);
    display:flex; gap:14px; align-items:flex-start; animation:uv-fade .4s ease; }
.uv-alert.success { background:rgba(56,224,206,.1); border:1px solid rgba(56,224,206,.32); color:#bdeee7; }
.uv-alert.error { background:rgba(255,90,90,.1); border:1px solid rgba(255,90,90,.32); color:#ffc9c9; }
.uv-alert > i { margin-top:2px; font-size:1.1rem; color:var(--uv-cyan); }
.uv-alert.error > i { color:#ff7a7a; }
.uv-alert .a-body b { color:#fff; font-family:var(--uv-head); }
.uv-alert .a-wa { display:inline-flex; align-items:center; gap:8px; margin-top:14px; padding:11px 20px; border-radius:99px;
    background:#25D366; color:#04211f !important; font-family:var(--uv-head); font-weight:600; text-decoration:none; transition:transform .2s; }
.uv-alert .a-wa:hover { transform:translateY(-2px); color:#04211f; }
.uv-field-error { color:#ff7a7a; font-family:var(--uv-body); font-size:.82rem; margin-top:6px; }
.uv-form input.err, .uv-form textarea.err, .uv-form select.err { border-color:rgba(255,90,90,.55) !important; }

/* =========================================================
   PHASE 6 — comparison + curriculum
   ========================================================= */
.uv-compare-scroll { overflow-x:auto; -webkit-overflow-scrolling:touch; }
.uv-compare { min-width:640px; max-width:940px; margin:0 auto; border:1px solid var(--uv-brd); border-radius:var(--uv-r-lg);
    overflow:hidden; background:linear-gradient(160deg,var(--uv-panel),var(--uv-panel-2)); }
.uv-compare-row { display:grid; grid-template-columns:1.7fr 1fr 1fr 1fr; align-items:center; }
.uv-compare-row + .uv-compare-row { border-top:1px solid var(--uv-brd); }
.uv-compare-row > div { padding:16px 14px; text-align:center; font-family:var(--uv-body); font-size:.92rem; color:#cdd7e4; }
.uv-compare-row > div:first-child { text-align:left; color:#eaf1f8; font-weight:500; }
.uv-compare-head > div { font-family:var(--uv-head); font-weight:600; font-size:.92rem; color:var(--uv-muted); padding:20px 14px; }
.uv-compare-head .uv-col-us { color:#04211f; }
.uv-compare .uv-col-us { background:rgba(56,224,206,.09); }
.uv-compare-head .uv-col-us { background:var(--uv-g-cyan); position:relative; }
.uv-compare .uv-col-us b { display:block; font-size:1rem; }
.uv-compare-head .uv-col-us small { font-weight:600; font-size:.64rem; letter-spacing:.1em; text-transform:uppercase; opacity:.75; }
.uv-compare .ic-yes { color:var(--uv-cyan); font-size:1.05rem; }
.uv-compare .ic-no { color:#ff6b6b; opacity:.65; }
.uv-compare .ic-mid { color:var(--uv-amber); }
.uv-compare-head .uv-col-us .ic-yes { color:#04211f; }

/* curriculum highlight card */
.uv-curr-teaser { display:grid; gap:10px; margin-top:22px; }
.uv-curr-teaser .ct { display:flex; align-items:center; gap:12px; font-family:var(--uv-body); color:#cdd7e4; font-size:.94rem; }
.uv-curr-teaser .ct span { width:28px;height:28px;border-radius:8px;display:grid;place-items:center;flex-shrink:0;
    background:rgba(56,224,206,.1); color:var(--uv-cyan); font-family:var(--uv-head); font-weight:700; font-size:.78rem; }
