/* ============================================================
 * ANSOFTIO Design Layer 2026
 * ============================================================
 * Modern senior-dev design pass that enhances all existing pages.
 * Loaded LAST so it takes precedence over older asf-*.css rules.
 *
 * Approach: progressive enhancement — never break older rules,
 * just refine typography, depth, motion, micro-interactions.
 *
 * Patches applied:
 *   1. Refined design tokens (spring-easing, motion-blur, etc.)
 *   2. Typography rhythm (line-heights, letter-spacing, font-features)
 *   3. Hero — glass-morphism + animated gradient mesh + floating cards
 *   4. Cards — soft 3D tilt-on-hover, subtle shine sweep
 *   5. Buttons — gradient sheen, press-feedback, focus ring
 *   6. Section headers — accent dot + uppercase label rhythm
 *   7. Service / Course / Internship card polish
 *   8. Reviews placeholder polish
 *   9. SaaS product cards — depth + glass overlay
 *  10. Footer — refined dark layout + social icon hover lift
 *  11. Dashboard sidebars — refined active state + micro-spacing
 *  12. AI Chatbot — modern bubbles, gradient glow on focus
 *  13. Forms — refined inputs, validation states, button-loading
 *  14. Scrollbar refinement (webkit)
 *  15. Reduce-motion respect
 * ============================================================ */

/* ----- 1. Tokens ---------------------------------------------- */
:root{
    /* Colors — refined for 2026 */
    --asf-2026-navy: #0B1426;
    --asf-2026-navy-2: #0F1B33;
    --asf-2026-blue: #2563EB;
    --asf-2026-blue-vivid: #3B82F6;
    --asf-2026-cyan: #06B6D4;
    --asf-2026-violet: #8B5CF6;
    --asf-2026-amber: #F59E0B;
    --asf-2026-rose: #F43F5E;
    --asf-2026-emerald: #10B981;
    --asf-2026-bg: #F8FAFC;
    --asf-2026-bg-2: #F1F5F9;
    --asf-2026-surface: #FFFFFF;
    --asf-2026-text: #0F172A;
    --asf-2026-text-muted: #475569;
    --asf-2026-text-light: #94A3B8;
    --asf-2026-border: #E2E8F0;
    --asf-2026-border-light: #F1F5F9;

    /* Depth */
    --asf-2026-shadow-xs: 0 1px 2px rgba(15,23,42,.04);
    --asf-2026-shadow-sm: 0 2px 4px rgba(15,23,42,.06), 0 1px 2px rgba(15,23,42,.04);
    --asf-2026-shadow: 0 4px 6px -1px rgba(15,23,42,.07), 0 2px 4px -2px rgba(15,23,42,.05);
    --asf-2026-shadow-md: 0 10px 15px -3px rgba(15,23,42,.08), 0 4px 6px -4px rgba(15,23,42,.05);
    --asf-2026-shadow-lg: 0 20px 25px -5px rgba(15,23,42,.10), 0 10px 10px -5px rgba(15,23,42,.04);
    --asf-2026-shadow-xl: 0 25px 50px -12px rgba(15,23,42,.18);
    --asf-2026-shadow-glow-blue: 0 0 0 1px rgba(37,99,235,.10), 0 8px 28px -6px rgba(37,99,235,.30);
    --asf-2026-shadow-glow-violet: 0 0 0 1px rgba(139,92,246,.10), 0 8px 28px -6px rgba(139,92,246,.30);

    /* Motion */
    --asf-2026-spring: cubic-bezier(.34,1.56,.64,1);
    --asf-2026-ease: cubic-bezier(.4,0,.2,1);
    --asf-2026-fast: 180ms;
    --asf-2026-mid: 280ms;
    --asf-2026-slow: 480ms;

    /* Radii */
    --asf-2026-r-sm: 8px;
    --asf-2026-r:    12px;
    --asf-2026-r-lg: 16px;
    --asf-2026-r-xl: 24px;
}

/* ----- 2. Typography rhythm ----------------------------------- */
body{
    font-feature-settings: "ss01","cv11","cv02","ss02";
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
.asf-heading-lg, .asf-home-hero-heading,
section h2, section h1{
    letter-spacing: -0.02em;
    line-height: 1.15;
}
.asf-section-header .asf-label, .asf-label{
    font-size: 0.75rem;
    letter-spacing: 0.16em;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--asf-2026-cyan);
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.asf-section-header .asf-label::before{
    content: "";
    width: 28px;
    height: 2px;
    background: linear-gradient(90deg, var(--asf-2026-cyan), transparent);
    border-radius: 2px;
}
.asf-subheading{
    font-size: 1.0625rem;
    line-height: 1.7;
    color: var(--asf-2026-text-muted);
    max-width: 720px;
    margin: 12px auto 0;
}

/* ----- 3. Hero — gradient mesh + glass dashboard -------------- */
.asf-home-hero{
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(1200px 600px at 10% -10%, rgba(59,130,246,.35), transparent 55%),
        radial-gradient(900px 500px at 100% 20%, rgba(139,92,246,.32), transparent 50%),
        radial-gradient(700px 500px at 30% 110%, rgba(6,182,212,.28), transparent 55%),
        linear-gradient(135deg, #0B1426 0%, #0F1B33 60%, #1E1B4B 100%);
    color: #fff;
}
.asf-home-hero::before{
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(to right, rgba(255,255,255,.04) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(255,255,255,.04) 1px, transparent 1px);
    background-size: 56px 56px;
    mask-image: radial-gradient(ellipse 60% 50% at 50% 35%, #000 30%, transparent 75%);
    pointer-events: none;
}
.asf-home-hero::after{
    content: "";
    position: absolute;
    width: 540px;
    height: 540px;
    top: -120px;
    right: -200px;
    background: conic-gradient(from 90deg, var(--asf-2026-blue-vivid), var(--asf-2026-violet), var(--asf-2026-cyan), var(--asf-2026-blue-vivid));
    filter: blur(120px);
    opacity: .35;
    border-radius: 50%;
    pointer-events: none;
    animation: asf-mesh-rotate 22s linear infinite;
}
@keyframes asf-mesh-rotate{
    to{ transform: rotate(360deg); }
}
.asf-home-hero-badge{
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 14px;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 999px;
    color: #cbd5e1;
    font-size: .8125rem;
    font-weight: 500;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}
.asf-home-hero-badge::before{
    content: "";
    width: 6px;
    height: 6px;
    background: var(--asf-2026-emerald);
    border-radius: 50%;
    box-shadow: 0 0 8px var(--asf-2026-emerald);
    animation: asf-pulse 1.6s ease-in-out infinite;
}
@keyframes asf-pulse{
    0%, 100%{ opacity: 1; transform: scale(1); }
    50%{ opacity: .55; transform: scale(.85); }
}
.asf-home-hero-heading{
    background: linear-gradient(135deg, #ffffff 30%, #cbd5e1 60%, #ffffff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}
.asf-home-hero-actions .asf-btn-primary,
.asf-home-hero-actions .asf-btn-cta,
.asf-home-final-cta .asf-btn-cta{
    background: linear-gradient(135deg, var(--asf-2026-blue-vivid) 0%, var(--asf-2026-violet) 50%, var(--asf-2026-cyan) 100%);
    background-size: 200% 200%;
    border: 0;
    box-shadow: 0 10px 25px -10px rgba(59,130,246,.5), 0 0 0 1px rgba(255,255,255,.08) inset;
    transition: transform var(--asf-2026-fast) var(--asf-2026-spring), box-shadow var(--asf-2026-mid) var(--asf-2026-ease), background-position var(--asf-2026-slow) var(--asf-2026-ease);
}
.asf-home-hero-actions .asf-btn-primary:hover,
.asf-home-hero-actions .asf-btn-cta:hover,
.asf-home-final-cta .asf-btn-cta:hover{
    transform: translateY(-2px);
    box-shadow: 0 18px 35px -10px rgba(59,130,246,.65), 0 0 0 1px rgba(255,255,255,.12) inset;
    background-position: 100% 50%;
}

/* Hero glass dashboard card */
.asf-home-hero-dashboard{
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.10);
    backdrop-filter: blur(22px) saturate(140%);
    -webkit-backdrop-filter: blur(22px) saturate(140%);
    border-radius: 20px;
    box-shadow: 0 30px 60px -20px rgba(0,0,0,.5);
    transform-style: preserve-3d;
    transition: transform var(--asf-2026-mid) var(--asf-2026-ease);
}
.asf-home-hero-3d-wrap:hover .asf-home-hero-dashboard{
    transform: rotateY(-3deg) rotateX(2deg) translateY(-4px);
}
.asf-home-hero-dash-stat{
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 12px;
    transition: transform var(--asf-2026-fast) var(--asf-2026-spring), background var(--asf-2026-fast) var(--asf-2026-ease);
}
.asf-home-hero-dash-stat:hover{
    transform: translateY(-2px);
    background: rgba(255,255,255,.08);
}
.asf-home-hero-chip{
    background: linear-gradient(135deg, rgba(59,130,246,.14), rgba(139,92,246,.14));
    border: 1px solid rgba(255,255,255,.12);
    color: #e2e8f0;
}

/* Floating cards above the hero dashboard — micro float animation */
.asf-home-hero-float{
    background: rgba(255,255,255,.96) !important;
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(255,255,255,.6);
    box-shadow: var(--asf-2026-shadow-xl);
    animation: asf-float 5.5s ease-in-out infinite;
}
.asf-home-hero-float-2{ animation-delay: -2.5s; }
@keyframes asf-float{
    0%, 100%{ transform: translateY(0); }
    50%{ transform: translateY(-12px); }
}

/* ----- 4. Section headers -------------------------------------- */
.asf-section{
    position: relative;
}
.asf-section-header{
    text-align: center;
    margin-bottom: 48px;
}

/* ----- 5. Cards — soft 3D ------------------------------------- */
.asf-home-service-card,
.asf-home-course-card,
.asf-home-internship-card,
.asf-home-category-card,
.asf-career-addon-card,
.asf-testimonial-card{
    background: var(--asf-2026-surface);
    border: 1px solid var(--asf-2026-border);
    border-radius: var(--asf-2026-r-lg);
    box-shadow: var(--asf-2026-shadow-sm);
    transition: transform var(--asf-2026-mid) var(--asf-2026-spring), box-shadow var(--asf-2026-mid) var(--asf-2026-ease), border-color var(--asf-2026-mid) var(--asf-2026-ease);
    position: relative;
    overflow: hidden;
}
.asf-home-service-card::before,
.asf-home-course-card::before,
.asf-home-internship-card::before,
.asf-home-category-card::before,
.asf-career-addon-card::before{
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(59,130,246,.05) 0%, rgba(139,92,246,.04) 100%);
    opacity: 0;
    transition: opacity var(--asf-2026-mid) var(--asf-2026-ease);
    pointer-events: none;
    border-radius: inherit;
}
.asf-home-service-card:hover,
.asf-home-course-card:hover,
.asf-home-internship-card:hover,
.asf-home-category-card:hover,
.asf-career-addon-card:hover,
.asf-testimonial-card:hover{
    transform: translateY(-6px);
    box-shadow: var(--asf-2026-shadow-lg);
    border-color: rgba(59,130,246,.2);
}
.asf-home-service-card:hover::before,
.asf-home-course-card:hover::before,
.asf-home-internship-card:hover::before,
.asf-home-category-card:hover::before,
.asf-career-addon-card:hover::before{
    opacity: 1;
}

/* Course card — top accent bar reveals on hover */
.asf-home-course-card::after,
.asf-career-addon-card::after{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--asf-2026-blue-vivid), var(--asf-2026-violet), var(--asf-2026-cyan));
    transform: scaleX(0);
    transform-origin: left;
    transition: transform var(--asf-2026-slow) var(--asf-2026-ease);
}
.asf-home-course-card:hover::after,
.asf-career-addon-card:hover::after{
    transform: scaleX(1);
}

/* Service-card icon — gradient halo on hover */
.asf-home-service-icon,
.asf-home-category-icon{
    transition: transform var(--asf-2026-mid) var(--asf-2026-spring);
}
.asf-home-service-card:hover .asf-home-service-icon,
.asf-home-category-card:hover .asf-home-category-icon{
    transform: scale(1.1) rotate(-4deg);
}

/* ----- 6. Buttons --------------------------------------------- */
.asf-btn{
    transition: transform var(--asf-2026-fast) var(--asf-2026-spring), box-shadow var(--asf-2026-fast) var(--asf-2026-ease), background var(--asf-2026-fast) var(--asf-2026-ease);
    will-change: transform;
}
.asf-btn:active{
    transform: translateY(1px) scale(.98);
}
.asf-btn:focus-visible{
    outline: 2px solid var(--asf-2026-blue-vivid);
    outline-offset: 3px;
}
.asf-btn-primary{
    background: linear-gradient(135deg, var(--asf-2026-blue-vivid), var(--asf-2026-cyan));
    border: 0;
    color: #fff;
    box-shadow: 0 4px 14px -4px rgba(59,130,246,.5);
}
.asf-btn-primary:hover{
    box-shadow: 0 10px 24px -6px rgba(59,130,246,.65);
    transform: translateY(-2px);
}
.asf-btn-cta{
    background: linear-gradient(135deg, #F97316, #F43F5E, #8B5CF6);
    background-size: 200% 200%;
    border: 0;
    color: #fff;
    box-shadow: 0 6px 20px -6px rgba(244,63,94,.5);
}
.asf-btn-cta:hover{
    background-position: 100% 50%;
    transform: translateY(-2px);
    box-shadow: 0 12px 30px -6px rgba(244,63,94,.6);
}
.asf-btn-outline{
    background: transparent;
    border: 1.5px solid currentColor;
}
.asf-btn-outline:hover{
    background: rgba(255,255,255,.06);
}

/* ----- 7. Hero hero-trust line refresh ------------------------ */
.asf-home-hero-trust{
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    background: rgba(16,185,129,.08);
    border: 1px solid rgba(16,185,129,.2);
    border-radius: 999px;
    color: #6ee7b7;
    font-size: .875rem;
    margin-top: 18px;
}

/* ----- 8. Reviews — sample badge polish ----------------------- */
.asf-testimonial-card[data-placeholder="1"]::after{
    background: linear-gradient(135deg, #e0e7ff, #cbd5e1);
    color: #3730a3;
    box-shadow: var(--asf-2026-shadow-xs);
}

/* ----- 9. SaaS product cards — depth + glass overlay ---------- */
.asf-home-product-card,
.asf-home-saas-card,
section[aria-labelledby="asf-products-heading"] .asf-home-service-card{
    position: relative;
    overflow: hidden;
    transition: transform var(--asf-2026-mid) var(--asf-2026-spring), box-shadow var(--asf-2026-mid) var(--asf-2026-ease);
}
.asf-home-product-card:hover,
.asf-home-saas-card:hover,
section[aria-labelledby="asf-products-heading"] .asf-home-service-card:hover{
    transform: translateY(-6px) scale(1.01);
    box-shadow: var(--asf-2026-shadow-xl);
}

/* ----- 10. Footer refinement ---------------------------------- */
.asf-footer{
    position: relative;
    background:
        radial-gradient(800px 400px at 5% 0%, rgba(59,130,246,.10), transparent 60%),
        linear-gradient(180deg, #0B1426 0%, #060912 100%);
}
.asf-footer a{
    transition: color var(--asf-2026-fast) var(--asf-2026-ease), transform var(--asf-2026-fast) var(--asf-2026-spring);
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.asf-footer a:hover{
    color: var(--asf-2026-cyan);
    transform: translateX(2px);
}
.asf-footer-social a{
    width: 36px;
    height: 36px;
    border-radius: 10px;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.10);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: transform var(--asf-2026-fast) var(--asf-2026-spring), background var(--asf-2026-fast) var(--asf-2026-ease);
}
.asf-footer-social a:hover{
    transform: translateY(-3px) scale(1.05);
    background: linear-gradient(135deg, var(--asf-2026-blue-vivid), var(--asf-2026-violet));
    border-color: transparent;
}

/* ----- 11. Header refinement ---------------------------------- */
.asf-site-header{
    backdrop-filter: blur(14px) saturate(140%);
    -webkit-backdrop-filter: blur(14px) saturate(140%);
    background: rgba(255,255,255,.85);
    border-bottom: 1px solid rgba(15,23,42,.06);
    transition: box-shadow var(--asf-2026-mid) var(--asf-2026-ease), background var(--asf-2026-mid) var(--asf-2026-ease);
}
.asf-site-header.is-scrolled{
    box-shadow: var(--asf-2026-shadow-sm);
    background: rgba(255,255,255,.95);
}
.asf-nav-link{
    position: relative;
    transition: color var(--asf-2026-fast) var(--asf-2026-ease);
}
.asf-nav-link::after{
    content: "";
    position: absolute;
    left: 12px;
    right: 12px;
    bottom: 4px;
    height: 2px;
    background: linear-gradient(90deg, var(--asf-2026-blue-vivid), var(--asf-2026-cyan));
    border-radius: 2px;
    transform: scaleX(0);
    transform-origin: center;
    transition: transform var(--asf-2026-mid) var(--asf-2026-spring);
}
.asf-nav-link:hover::after,
.asf-nav-link.is-active::after{
    transform: scaleX(1);
}

/* ----- 12. Dashboard sidebars (student/intern/client) --------- */
.asf-student-sidebar,
.asf-intern-sidebar,
.asf-client-sidebar{
    border-right: 1px solid rgba(255,255,255,.06);
}
.asf-student-nav-link,
.asf-intern-nav-link,
.asf-client-nav-link{
    border-radius: 10px;
    transition: background var(--asf-2026-fast) var(--asf-2026-ease), transform var(--asf-2026-fast) var(--asf-2026-spring), color var(--asf-2026-fast) var(--asf-2026-ease);
    position: relative;
}
.asf-student-nav-link:hover,
.asf-intern-nav-link:hover,
.asf-client-nav-link:hover{
    background: rgba(255,255,255,.06);
    transform: translateX(2px);
}
.asf-student-nav-link.asf-active,
.asf-intern-nav-link.asf-active,
.asf-client-nav-link.asf-active{
    background: linear-gradient(90deg, rgba(59,130,246,.18), rgba(139,92,246,.10) 60%, transparent);
    color: #fff;
    box-shadow: inset 3px 0 0 var(--asf-2026-blue-vivid);
}

/* Topbar avatar refinement */
.asf-student-topbar-avatar,
.asf-intern-topbar-avatar,
.asf-client-topbar-avatar{
    box-shadow: 0 0 0 2px var(--asf-2026-surface), 0 0 0 4px rgba(59,130,246,.18);
}

/* ----- 13. AI Chatbot polish ---------------------------------- */
.asf-ai-chatbot,
.asf-ai-chatbot-window,
[id*="chatbot"] [class*="chat-window"]{
    background: linear-gradient(180deg, #0F1B33 0%, #1E1B4B 100%);
    border: 1px solid rgba(255,255,255,.10);
    box-shadow: 0 30px 60px -20px rgba(0,0,0,.5);
    border-radius: 18px;
    overflow: hidden;
}
.asf-chat-bubble-bot, .asf-chat-bubble--bot{
    background: linear-gradient(135deg, #1E293B, #0F172A);
    border: 1px solid rgba(255,255,255,.06);
    color: #e2e8f0;
}
.asf-chat-bubble-user, .asf-chat-bubble--user{
    background: linear-gradient(135deg, var(--asf-2026-blue-vivid), var(--asf-2026-violet));
    color: #fff;
    box-shadow: 0 4px 14px -4px rgba(59,130,246,.5);
}
.asf-chat-input,
[id*="chatbot"] input[type="text"]{
    background: rgba(15,23,42,.6) !important;
    border: 1px solid rgba(255,255,255,.10) !important;
    color: #e2e8f0 !important;
    transition: border-color var(--asf-2026-fast) var(--asf-2026-ease), box-shadow var(--asf-2026-fast) var(--asf-2026-ease);
}
.asf-chat-input:focus,
[id*="chatbot"] input[type="text"]:focus{
    border-color: var(--asf-2026-blue-vivid) !important;
    box-shadow: 0 0 0 3px rgba(59,130,246,.18) !important;
    outline: 0 !important;
}

/* ----- 14. Forms ---------------------------------------------- */
.asf-form-input,
.asf-form-select,
.asf-form-textarea,
input[type="text"]:not([class*="wp-"]),
input[type="email"]:not([class*="wp-"]),
input[type="tel"]:not([class*="wp-"]),
input[type="number"]:not([class*="wp-"]),
input[type="search"]:not([class*="wp-"]),
input[type="password"]:not([class*="wp-"]),
textarea:not([class*="wp-"]),
select:not([class*="wp-"]){
    border-radius: 10px !important;
    transition: border-color var(--asf-2026-fast) var(--asf-2026-ease), box-shadow var(--asf-2026-fast) var(--asf-2026-ease);
}
input:focus:not([class*="wp-"]),
textarea:focus:not([class*="wp-"]),
select:focus:not([class*="wp-"]){
    border-color: var(--asf-2026-blue-vivid) !important;
    box-shadow: 0 0 0 3px rgba(59,130,246,.16) !important;
    outline: 0 !important;
}

/* ----- 15. Inquiry form polish (universal) -------------------- */
.asf-inquiry-form-wrap{
    border-radius: 18px;
    box-shadow: var(--asf-2026-shadow-md);
    border: 1px solid var(--asf-2026-border);
    background: linear-gradient(180deg, #fff, #fafbfd);
    position: relative;
    overflow: hidden;
}
.asf-inquiry-form-wrap::before{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--asf-2026-blue-vivid), var(--asf-2026-violet), var(--asf-2026-cyan));
}

/* ----- 16. Scroll-reveal animation ---------------------------- */
.asf-section{
    opacity: 1;
}
[data-asf-reveal]{
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 700ms var(--asf-2026-ease), transform 700ms var(--asf-2026-spring);
}
[data-asf-reveal].is-visible{
    opacity: 1;
    transform: translateY(0);
}

/* ----- 17. Scrollbar refinement (webkit) ---------------------- */
::-webkit-scrollbar{ width: 10px; height: 10px; }
::-webkit-scrollbar-track{ background: var(--asf-2026-bg-2); }
::-webkit-scrollbar-thumb{
    background: linear-gradient(180deg, #94a3b8, #64748b);
    border-radius: 6px;
    border: 2px solid var(--asf-2026-bg-2);
}
::-webkit-scrollbar-thumb:hover{
    background: linear-gradient(180deg, #64748b, #475569);
}

/* ----- 18. Reduce-motion respect ------------------------------ */
@media (prefers-reduced-motion: reduce){
    *,
    *::before,
    *::after{
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .01ms !important;
        scroll-behavior: auto !important;
    }
}

/* ----- 19. Mobile polish -------------------------------------- */
@media (max-width: 768px){
    .asf-home-hero-heading{
        font-size: 2.25rem !important;
        line-height: 1.15;
    }
    .asf-home-hero::after{
        width: 380px;
        height: 380px;
    }
    .asf-section-header{
        margin-bottom: 32px;
    }
    .asf-section{
        padding-top: 60px;
        padding-bottom: 60px;
    }
}

/* ----- 20. Pricing tier badges (course tiers) ---------------- */
.asf-tier-paid{
    background: linear-gradient(135deg, #FEF3C7, #FDE68A);
    color: #92400E;
}
.asf-tier-semi{
    background: linear-gradient(135deg, #DBEAFE, #BFDBFE);
    color: #1E40AF;
}
.asf-tier-free{
    background: linear-gradient(135deg, #DCFCE7, #BBF7D0);
    color: #166534;
}


/* ============================================================
 * v1.49 — WebGL Hero canvas + Premium dashboard polish + Premium AI chat
 * ============================================================ */

/* WebGL hero canvas — positioned absolutely under the hero content */
#asf-hero-3d{
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    pointer-events: none;
    opacity: 0.85;
}
.asf-home-hero{ position: relative; }
.asf-home-hero .asf-container{ position: relative; z-index: 1; }
.asf-home-hero-content,
.asf-home-hero-visual{ position: relative; z-index: 2; }

/* Dashboard mockup gets a soft halo so it floats over the WebGL scene */
.asf-home-hero-dashboard{
    box-shadow:
        0 30px 60px -20px rgba(0,0,0,.6),
        0 0 80px rgba(59,130,246,.18),
        inset 0 1px 0 rgba(255,255,255,.08);
}

/* ============================================================
 * Premium dashboard refinements (student / intern / client)
 * ============================================================ */
.asf-student-content,
.asf-intern-content,
.asf-client-content{
    background:
        radial-gradient(900px 400px at 0% 0%, rgba(59,130,246,.04), transparent 60%),
        radial-gradient(700px 400px at 100% 0%, rgba(139,92,246,.04), transparent 60%),
        var(--asf-2026-bg);
    min-height: 100vh;
}

.asf-student-topbar,
.asf-intern-topbar,
.asf-client-topbar{
    background: rgba(255,255,255,.85);
    backdrop-filter: blur(18px) saturate(140%);
    -webkit-backdrop-filter: blur(18px) saturate(140%);
    border-bottom: 1px solid rgba(15,23,42,.06);
    box-shadow: 0 1px 0 rgba(255,255,255,.5) inset;
}

/* Generic stat-card upgrade */
.asf-stat,
.asf-stat-card,
.asf-dashboard-stat{
    background: linear-gradient(180deg, #ffffff 0%, #fafbfd 100%);
    border: 1px solid var(--asf-2026-border);
    border-radius: 14px;
    padding: 18px 20px;
    box-shadow: var(--asf-2026-shadow-sm);
    transition: transform var(--asf-2026-fast) var(--asf-2026-spring), box-shadow var(--asf-2026-fast) var(--asf-2026-ease), border-color var(--asf-2026-fast) var(--asf-2026-ease);
    position: relative;
    overflow: hidden;
}
.asf-stat::before,
.asf-stat-card::before,
.asf-dashboard-stat::before{
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--asf-2026-blue-vivid), var(--asf-2026-violet), var(--asf-2026-cyan));
    opacity: 0;
    transition: opacity var(--asf-2026-mid) var(--asf-2026-ease);
}
.asf-stat:hover,
.asf-stat-card:hover,
.asf-dashboard-stat:hover{
    transform: translateY(-3px);
    box-shadow: var(--asf-2026-shadow-md);
    border-color: rgba(59,130,246,.18);
}
.asf-stat:hover::before,
.asf-stat-card:hover::before,
.asf-dashboard-stat:hover::before{ opacity: 1; }

.asf-stat-value,
.asf-stat-num{
    background: linear-gradient(135deg, var(--asf-2026-blue-vivid), var(--asf-2026-violet));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    font-weight: 800;
}

/* Generic dashboard card upgrade */
.asf-card,
.asf-dashboard-card{
    background: #fff;
    border: 1px solid var(--asf-2026-border);
    border-radius: 14px;
    box-shadow: var(--asf-2026-shadow-sm);
    transition: box-shadow var(--asf-2026-mid) var(--asf-2026-ease);
}
.asf-card:hover,
.asf-dashboard-card:hover{
    box-shadow: var(--asf-2026-shadow-md);
}

/* Tables — modern look */
.asf-table,
.asf-data-table{
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid var(--asf-2026-border);
}
.asf-table thead,
.asf-data-table thead{
    background: linear-gradient(180deg, #f8fafc, #f1f5f9);
}
.asf-table th,
.asf-data-table th{
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--asf-2026-text-muted);
    font-weight: 700;
    padding: 12px 16px;
    border-bottom: 1px solid var(--asf-2026-border);
}
.asf-table td,
.asf-data-table td{
    padding: 14px 16px;
    border-bottom: 1px solid var(--asf-2026-border-light);
    transition: background var(--asf-2026-fast) var(--asf-2026-ease);
}
.asf-table tbody tr:hover td,
.asf-data-table tbody tr:hover td{
    background: rgba(59,130,246,.03);
}
.asf-table tbody tr:last-child td,
.asf-data-table tbody tr:last-child td{ border-bottom: 0; }

/* ============================================================
 * Premium AI Chatbot redesign (matches ChatGPT/Claude polish)
 * ============================================================ */
.asf-ai-chatbot,
.asf-ai-chatbot-window{
    background: linear-gradient(180deg, #0F172A 0%, #1E1B4B 100%);
    border: 1px solid rgba(255,255,255,.10);
    border-radius: 20px;
    overflow: hidden;
    box-shadow:
        0 50px 80px -20px rgba(0,0,0,.6),
        0 0 0 1px rgba(255,255,255,.04),
        inset 0 1px 0 rgba(255,255,255,.06);
}
.asf-ai-chatbot-header{
    background: linear-gradient(180deg, rgba(255,255,255,.04), transparent);
    border-bottom: 1px solid rgba(255,255,255,.08);
    padding: 14px 18px;
}
.asf-ai-chatbot-header h3,
.asf-ai-chatbot-header .asf-ai-title{
    color: #fff;
    font-weight: 700;
}
.asf-ai-chatbot-status{
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #6ee7b7;
    font-size: 0.75rem;
}
.asf-ai-chatbot-status::before{
    content: "";
    width: 8px;
    height: 8px;
    background: #10b981;
    border-radius: 50%;
    box-shadow: 0 0 8px #10b981;
    animation: asf-pulse 1.6s ease-in-out infinite;
}

/* Bubbles */
.asf-chat-bubble,
.asf-msg{
    max-width: 85%;
    padding: 12px 16px;
    border-radius: 14px;
    font-size: 0.875rem;
    line-height: 1.55;
    margin-bottom: 12px;
    transition: opacity var(--asf-2026-fast) var(--asf-2026-ease);
}
.asf-chat-bubble--bot,
.asf-msg--bot,
.asf-chat-bubble-bot{
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.08);
    color: #e2e8f0;
    align-self: flex-start;
    border-bottom-left-radius: 4px;
}
.asf-chat-bubble--user,
.asf-msg--user,
.asf-chat-bubble-user{
    background: linear-gradient(135deg, var(--asf-2026-blue-vivid), var(--asf-2026-violet));
    color: #fff;
    align-self: flex-end;
    border-bottom-right-radius: 4px;
    box-shadow: 0 6px 18px -6px rgba(59,130,246,.5);
}

/* Typing indicator dots */
.asf-typing-indicator{
    display: inline-flex;
    gap: 4px;
    padding: 12px 16px;
    background: rgba(255,255,255,.06);
    border-radius: 14px;
    border: 1px solid rgba(255,255,255,.08);
}
.asf-typing-indicator span{
    width: 6px;
    height: 6px;
    background: #94a3b8;
    border-radius: 50%;
    animation: asf-typing 1.2s ease-in-out infinite;
}
.asf-typing-indicator span:nth-child(2){ animation-delay: .15s; }
.asf-typing-indicator span:nth-child(3){ animation-delay: .3s; }
@keyframes asf-typing{
    0%, 60%, 100%{ transform: translateY(0); opacity: .4; }
    30%{ transform: translateY(-6px); opacity: 1; }
}

/* Quick reply chips — gradient look */
.asf-quick-reply,
.asf-chat-chip{
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.10);
    color: #cbd5e1;
    padding: 6px 12px;
    border-radius: 999px;
    font-size: 0.8125rem;
    cursor: pointer;
    transition: all var(--asf-2026-fast) var(--asf-2026-ease);
}
.asf-quick-reply:hover,
.asf-chat-chip:hover{
    background: linear-gradient(135deg, rgba(59,130,246,.18), rgba(139,92,246,.18));
    border-color: rgba(59,130,246,.35);
    color: #fff;
    transform: translateY(-1px);
}

/* Input area */
.asf-chat-input-wrap,
.asf-ai-chatbot-input{
    background: rgba(255,255,255,.04);
    border-top: 1px solid rgba(255,255,255,.08);
    padding: 14px 16px;
}

/* ============================================================
 * Floating chat button (FAB) — premium look
 * ============================================================ */
.asf-ai-chatbot-fab,
.asf-chat-fab{
    background: linear-gradient(135deg, var(--asf-2026-blue-vivid), var(--asf-2026-violet));
    border: 1px solid rgba(255,255,255,.16);
    color: #fff;
    box-shadow:
        0 12px 30px -8px rgba(59,130,246,.5),
        0 0 0 4px rgba(59,130,246,.12);
    transition: transform var(--asf-2026-fast) var(--asf-2026-spring), box-shadow var(--asf-2026-fast) var(--asf-2026-ease);
}
.asf-ai-chatbot-fab:hover,
.asf-chat-fab:hover{
    transform: translateY(-3px) scale(1.05);
    box-shadow:
        0 18px 40px -8px rgba(59,130,246,.65),
        0 0 0 6px rgba(59,130,246,.18);
}

/* ============================================================
 * Page-hero refinements (used on Contact, About, Services etc.)
 * ============================================================ */
.asf-page-hero{
    position: relative;
    overflow: hidden;
}
.asf-page-hero::after{
    content: "";
    position: absolute;
    width: 460px;
    height: 460px;
    bottom: -180px;
    right: -160px;
    background: radial-gradient(circle, rgba(255,255,255,.15), transparent 70%);
    border-radius: 50%;
    pointer-events: none;
}
.asf-page-hero-title{
    background: linear-gradient(135deg, #ffffff 30%, #cbd5e1 60%, #ffffff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    letter-spacing: -0.02em;
}

/* ============================================================
 * Loading skeleton for cards (used by JS)
 * ============================================================ */
.asf-skeleton{
    background: linear-gradient(90deg, #f1f5f9 0%, #e2e8f0 50%, #f1f5f9 100%);
    background-size: 200% 100%;
    animation: asf-skeleton 1.4s ease-in-out infinite;
    border-radius: 8px;
}
@keyframes asf-skeleton{
    0%{ background-position: 200% 0; }
    100%{ background-position: -200% 0; }
}

/* ============================================================
 * Mega menu (header navigation)
 * ============================================================ */
.asf-mega-menu{
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: rgba(255,255,255,.98);
    backdrop-filter: blur(22px) saturate(140%);
    -webkit-backdrop-filter: blur(22px) saturate(140%);
    border-top: 1px solid rgba(15,23,42,.08);
    box-shadow: 0 30px 50px -10px rgba(15,23,42,.15);
    padding: 28px 0;
    opacity: 0;
    transform: translateY(8px);
    visibility: hidden;
    transition: opacity var(--asf-2026-mid) var(--asf-2026-ease), transform var(--asf-2026-mid) var(--asf-2026-ease), visibility 0s linear var(--asf-2026-mid);
}
.asf-nav-item:hover .asf-mega-menu,
.asf-nav-item:focus-within .asf-mega-menu{
    opacity: 1;
    transform: translateY(0);
    visibility: visible;
    transition: opacity var(--asf-2026-mid) var(--asf-2026-ease), transform var(--asf-2026-mid) var(--asf-2026-ease), visibility 0s;
}

/* ============================================================
 * Reduce motion guard for the WebGL canvas
 * ============================================================ */
@media (prefers-reduced-motion: reduce){
    #asf-hero-3d{ display: none; }
}

/* Mobile — hide WebGL on small screens to save bandwidth + battery */
@media (max-width: 640px){
    #asf-hero-3d{ opacity: 0.6; }
}
