/* ═══════════════════════════════════════════
   MOZ Academy — Premium Cinematic Theme
   Inspired by keanuvisuals.com
   ═══════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700;800&family=Inter:wght@300;400;500;600;700&display=swap');

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;overflow-x:hidden}

:root{
    --bg:#080b12;--bg2:#0d1117;--bg-card:#12161f;--bg-card-hover:#181e2a;
    --border:#1c2333;--border-glow:#2563eb40;
    --accent:#3b82f6;--accent2:#2563eb;--accent-glow:#60a5fa;
    --text:#f0f4f8;--text2:#94a3b8;--text3:#64748b;
    --success:#10b981;--danger:#ef4444;--warning:#f59e0b;
    --orange:#ea580c;--orange-glow:#f97316;
    --gradient:linear-gradient(135deg,#3b82f6,#8b5cf6);
    --gradient-warm:linear-gradient(135deg,#ea580c,#f59e0b);
    --shadow:0 25px 80px rgba(0,0,0,.5);
    --glow:0 0 60px rgba(59,130,246,.12);
    --font-h:'Space Grotesk',sans-serif;
    --font-b:'Inter',sans-serif;
    --max-w:1240px;--header-h:70px;
}

body{font-family:var(--font-b);background:var(--bg);color:var(--text);line-height:1.7;overflow-x:hidden}
a{color:inherit;text-decoration:none;transition:.3s}
img{max-width:100%;display:block}
.container{max-width:var(--max-w);margin:0 auto;padding:0 20px}

/* ══ HEADER ══ */
.header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(8,11,18,.7);backdrop-filter:blur(24px);border-bottom:1px solid transparent;transition:.4s}
.header.scrolled{background:rgba(8,11,18,.95);border-color:var(--border)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);max-width:var(--max-w);margin:0 auto;padding:0 20px}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--font-h);font-size:1.3rem;font-weight:800;letter-spacing:-.02em}
.logo-icon{width:36px;height:36px;border-radius:50%;border:2px solid var(--orange);display:flex;align-items:center;justify-content:center;font-size:.9rem}
.logo span{color:var(--orange)}
.nav{display:flex;align-items:center;gap:28px}
.nav a{color:var(--text2);font-size:.88rem;font-weight:500;transition:.3s;position:relative}
.nav a:hover{color:var(--text)}
.nav-close, .nav-brand{display:none}
.nav-cta{padding:10px 22px;background:var(--orange);color:#fff;border-radius:8px;font-weight:700;font-size:.85rem;letter-spacing:.02em;text-transform:uppercase;transition:.3s !important;border:none}
.nav-cta:hover{background:var(--orange-glow);color:#fff !important;transform:translateY(-2px);box-shadow:0 6px 24px rgba(234,88,12,.35)}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.hamburger span{width:24px;height:2px;background:var(--text);transition:.3s}

/* ══ HERO ══ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
.hero-video-bg{position:absolute;inset:0;z-index:0}
.hero-video-bg video{width:100%;height:100%;object-fit:cover;filter:brightness(.25) saturate(1.3)}
.hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(8,11,18,.3) 0%,rgba(8,11,18,.5) 40%,var(--bg) 100%)}
.hero-content{position:relative;z-index:2;text-align:center;max-width:860px;margin:0 auto;padding:0 20px}
.hero h1{font-family:var(--font-h);font-size:clamp(2.8rem,7vw,5.5rem);font-weight:800;line-height:1.05;letter-spacing:-.04em;margin-bottom:24px;text-transform:uppercase}
.hero h1 .orange{color:var(--orange);font-style:italic}
.hero h1 .white{color:var(--text)}
.hero-sub{font-size:clamp(1rem,2vw,1.2rem);color:var(--text2);max-width:550px;margin:0 auto 40px;line-height:1.7}
.hero-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.btn-hero{padding:16px 40px;border-radius:10px;font-size:1rem;font-weight:700;cursor:pointer;transition:.3s;border:none;font-family:var(--font-b);text-transform:uppercase;letter-spacing:.03em}
.btn-hero-primary{background:var(--orange);color:#fff}
.btn-hero-primary:hover{background:var(--orange-glow);transform:translateY(-3px);box-shadow:0 10px 40px rgba(234,88,12,.3)}
.btn-hero-outline{background:transparent;color:var(--text);border:1.5px solid rgba(255,255,255,.2)}
.btn-hero-outline:hover{border-color:var(--text);background:rgba(255,255,255,.05)}

/* Scroll indicator */
.scroll-indicator{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text3);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase}
.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--text3),transparent);animation:scrollPulse 2s infinite}
@keyframes scrollPulse{0%,100%{opacity:.3}50%{opacity:1}}

/* ══ TRUSTED BY ══ */
.trusted{padding:40px 0;border-bottom:1px solid var(--border)}
.trusted-label{text-align:center;font-size:.7rem;color:var(--text3);text-transform:uppercase;letter-spacing:.15em;margin-bottom:20px}
.trusted-logos{display:flex;justify-content:center;gap:40px;align-items:center;opacity:.4;flex-wrap:wrap}
.trusted-logos span{font-family:var(--font-h);font-size:1.1rem;font-weight:700;color:var(--text2)}

/* ══ PORTFOLIO GRID (keanuvisuals bento style) ══ */
.portfolio{padding:80px 0}
.portfolio-grid{
    display:grid;
    grid-template-columns:1fr 1fr 1fr;
    grid-template-rows:400px 340px 380px;
    gap:14px;
}
/* Row 1: tall-video(r1+r2) | video | video */
/* Row 2: (continued)       | quote | video */
/* Row 3: quote | video | video */
.portfolio-item{position:relative;border-radius:14px;overflow:hidden;cursor:pointer;transition:.4s}
.portfolio-item:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(0,0,0,.4)}
.portfolio-item video,.portfolio-item img{width:100%;height:100%;object-fit:cover;transition:.6s}
.portfolio-item:hover video,.portfolio-item:hover img{transform:scale(1.06)}
.portfolio-item .overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.85) 0%,rgba(0,0,0,.1) 40%,transparent 70%);display:flex;flex-direction:column;justify-content:flex-end;padding:20px;opacity:.9;transition:.3s}
.portfolio-item:hover .overlay{opacity:1}
.portfolio-item .p-title{font-family:var(--font-h);font-size:1.05rem;font-weight:800;text-transform:uppercase;margin-bottom:6px;letter-spacing:-.01em}
.portfolio-item .p-stats{display:flex;gap:16px;font-size:.72rem;color:var(--text2);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.portfolio-item .p-stats span{display:flex;align-items:center;gap:5px}

/* Bento layout positions */
.p-item-1{grid-column:1;grid-row:1/3} /* Tall left (2 rows) */
.p-item-2{grid-column:2;grid-row:1}
.p-item-3{grid-column:3;grid-row:1}
.p-item-quote1{grid-column:2;grid-row:2} /* Quote card row 2 */
.p-item-4{grid-column:3;grid-row:2}
.p-item-quote2{grid-column:1;grid-row:3} /* Quote card row 3 */
.p-item-5{grid-column:2;grid-row:3}
.p-item-6{grid-column:3;grid-row:3}

/* Quote card in portfolio */
.quote-card{background:linear-gradient(160deg,#1a1207 0%,#1c1510 40%,#161210 100%);border:1px solid rgba(234,88,12,.15);border-radius:14px;padding:24px;display:flex;flex-direction:column;justify-content:space-between;transition:.3s}
.quote-card:hover{border-color:rgba(234,88,12,.3)}
.quote-avatar{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.quote-avatar img{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid rgba(234,88,12,.4)}
.quote-avatar .q-badge{width:18px;height:18px;border-radius:50%;background:var(--orange);display:flex;align-items:center;justify-content:center;font-size:.55rem;color:#fff;margin-left:-16px;margin-top:18px;position:relative;z-index:1}
.quote-text{font-family:var(--font-h);font-size:1.05rem;font-weight:800;line-height:1.35;text-transform:uppercase;letter-spacing:-.01em;color:var(--text);flex:1}
.quote-author{font-size:.8rem;color:var(--text2);margin-top:12px;font-weight:500}

/* ══ STATS ══ */
.stats{padding:60px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.stat{text-align:center;padding:30px 16px;position:relative}
.stat:not(:last-child)::after{content:'';position:absolute;right:0;top:20%;bottom:20%;width:1px;background:var(--border)}
.stat-num{font-family:var(--font-h);font-size:clamp(2rem,4vw,3rem);font-weight:800;background:var(--gradient-warm);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:4px}
.stat-label{font-size:.8rem;color:var(--text3);font-weight:500}

/* ══ COURSES SECTION ══ */
.courses{padding:100px 0}
.section-header{margin-bottom:48px}
.section-dot{display:inline-flex;align-items:center;gap:8px;margin-bottom:12px}
.section-dot::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--orange);animation:pulse2 2s infinite}
@keyframes pulse2{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}
.section-dot span{font-size:.75rem;text-transform:uppercase;letter-spacing:.15em;color:var(--text2);font-weight:600}
.section-h2{font-family:var(--font-h);font-size:clamp(2rem,5vw,3.5rem);font-weight:800;line-height:1.1;letter-spacing:-.03em}
.section-h2 .orange{color:var(--orange);font-style:italic}
.section-sub{font-size:1.05rem;color:var(--text2);max-width:520px;margin-top:14px;line-height:1.7}

/* Course display like Creators Club */
.courses-showcase{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.courses-visual{position:relative}
.courses-visual-inner{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;overflow:hidden;padding:20px;box-shadow:var(--shadow)}
.courses-laptop{position:relative;border-radius:12px;overflow:hidden;aspect-ratio:16/10}
.courses-laptop video,.courses-laptop img{width:100%;height:100%;object-fit:cover}
.courses-info h3{font-family:var(--font-h);font-size:2rem;font-weight:800;margin-bottom:12px}
.courses-info h3 .orange{color:var(--orange);font-style:italic}
.courses-info p{color:var(--text2);margin-bottom:28px;line-height:1.8}
.btn-learn{display:inline-flex;align-items:center;gap:8px;padding:16px 36px;background:var(--orange);color:#fff;border-radius:10px;font-weight:700;font-size:1rem;transition:.3s;border:none;cursor:pointer;text-transform:uppercase;letter-spacing:.03em;font-family:var(--font-b)}
.btn-learn:hover{background:var(--orange-glow);transform:translateY(-3px);box-shadow:0 10px 40px rgba(234,88,12,.3);color:#fff}

/* ══ PRICING CARDS ══ */
.pricing{padding:100px 0;background:var(--bg2)}
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px;margin-top:48px}
.price-card{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:32px;transition:.4s;position:relative;overflow:hidden}
.price-card.featured{border-color:var(--accent);box-shadow:var(--glow)}
.price-card.featured::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient)}
.price-card:hover{transform:translateY(-6px);border-color:rgba(59,130,246,.3)}
.price-badge{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin-bottom:14px}
.price-name{font-family:var(--font-h);font-size:1.5rem;font-weight:800;margin-bottom:4px}
.price-desc{font-size:.85rem;color:var(--text2);margin-bottom:24px;line-height:1.6}
.price-amount{margin-bottom:24px;display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.price-current{font-family:var(--font-h);font-size:2.4rem;font-weight:800}
.price-original{font-size:.95rem;color:var(--text3);text-decoration:line-through}
.price-save{font-size:.7rem;color:var(--success);font-weight:700;padding:3px 10px;background:rgba(16,185,129,.1);border-radius:4px}
.price-features{list-style:none;margin-bottom:28px}
.price-features li{display:flex;align-items:flex-start;gap:10px;padding:7px 0;font-size:.88rem;color:var(--text2)}
.price-features li::before{content:'✓';color:var(--accent);font-weight:700;flex-shrink:0;margin-top:1px}
.price-btn{display:block;width:100%;padding:14px;text-align:center;border-radius:10px;font-size:.95rem;font-weight:700;cursor:pointer;transition:.3s;border:none;font-family:var(--font-b);letter-spacing:.02em}
.price-card.featured .price-btn{background:var(--gradient);color:#fff}
.price-card:not(.featured) .price-btn{background:var(--bg2);color:var(--text);border:1px solid var(--border)}
.price-btn:hover{transform:translateY(-2px);box-shadow:var(--glow)}

/* Upgrade banner */
.upgrade-note{background:rgba(59,130,246,.06);border:1px solid rgba(59,130,246,.15);border-radius:12px;padding:16px 20px;margin-top:20px;display:flex;align-items:center;gap:12px;font-size:.85rem;color:var(--text2)}
.upgrade-note i{color:var(--accent);font-size:1.2rem}

/* ══ TESTIMONIALS ══ */
.testimonials{padding:100px 0}
.testi-grid{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;padding:8px 0;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.testi-grid::-webkit-scrollbar{display:none}
.testi-card{flex:0 0 380px;scroll-snap-align:start;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:28px;transition:.3s}
.testi-card:hover{border-color:rgba(59,130,246,.2)}
.testi-stars{color:var(--warning);font-size:.85rem;margin-bottom:14px;letter-spacing:2px}
.testi-text{font-size:.95rem;color:var(--text2);line-height:1.8;margin-bottom:20px;font-style:italic}
.testi-author{display:flex;align-items:center;gap:12px}
.testi-avatar{width:44px;height:44px;border-radius:50%;background:var(--gradient-warm);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.1rem;flex-shrink:0}
.testi-name{font-weight:600;font-size:.9rem}
.testi-result{font-size:.8rem;color:var(--success);font-weight:600}

/* ══ FAQ ══ */
.faq-section{padding:100px 0;background:var(--bg2)}
.faq-list{max-width:760px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:20px 0;cursor:pointer;font-weight:600;font-size:1rem;transition:.3s}
.faq-q:hover{color:var(--orange)}
.faq-icon{font-size:1.3rem;transition:.3s;color:var(--text3)}
.faq-item.open .faq-icon{transform:rotate(45deg);color:var(--orange)}
.faq-a{max-height:0;overflow:hidden;transition:.4s ease;color:var(--text2);font-size:.95rem;line-height:1.8}
.faq-item.open .faq-a{max-height:300px}
.faq-a-inner{padding:0 0 20px}

/* ══ CTA ══ */
.cta{padding:80px 0}
.cta-box{background:linear-gradient(135deg,rgba(234,88,12,.08),rgba(59,130,246,.08));border:1px solid rgba(234,88,12,.12);border-radius:24px;padding:60px 40px;text-align:center}
.cta-box h2{font-family:var(--font-h);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;margin-bottom:16px}
.cta-box p{color:var(--text2);max-width:500px;margin:0 auto 32px;font-size:1.05rem}

/* ══ FOOTER ══ */
.footer{padding:40px 0;border-top:1px solid var(--border)}
.footer-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.footer-brand{font-family:var(--font-h);font-weight:800;font-size:1rem}
.footer-brand span{color:var(--orange)}
.footer-links{display:flex;gap:20px}
.footer-links a{color:var(--text3);font-size:.8rem;transition:.3s}
.footer-links a:hover{color:var(--text)}
.footer-social{display:flex;gap:10px}
.footer-social a{width:36px;height:36px;border-radius:8px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text3);transition:.3s;font-size:.85rem}
.footer-social a:hover{border-color:var(--orange);color:var(--orange);background:rgba(234,88,12,.06)}
.footer-copy{text-align:center;margin-top:24px;padding-top:24px;border-top:1px solid var(--border);font-size:.75rem;color:var(--text3)}

/* ══ MODAL ══ */
.modal{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.85);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:.3s}
.modal.open{opacity:1;pointer-events:all}
.modal-box{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:36px;max-width:460px;width:92%;transform:scale(.92) translateY(20px);transition:.35s}
.modal.open .modal-box{transform:scale(1) translateY(0)}
.modal-title{font-family:var(--font-h);font-size:1.4rem;font-weight:800;margin-bottom:6px}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:.8rem;color:var(--text2);margin-bottom:5px;font-weight:500}
.form-input{width:100%;padding:13px 16px;background:var(--bg);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:.95rem;font-family:var(--font-b);transition:.3s;outline:none}
.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(59,130,246,.08)}
.form-input::placeholder{color:var(--text3)}

/* ══ SCROLL REVEAL ══ */
.reveal{opacity:0;transform:translateY(50px);transition:opacity .8s ease,transform .8s cubic-bezier(.25,.8,.25,1)}
.reveal.vis{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-50px);transition:opacity .8s ease,transform .8s ease}
.reveal-left.vis{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(50px);transition:opacity .8s ease,transform .8s ease}
.reveal-right.vis{opacity:1;transform:translateX(0)}
.stagger>*:nth-child(1){transition-delay:.05s}.stagger>*:nth-child(2){transition-delay:.15s}.stagger>*:nth-child(3){transition-delay:.25s}.stagger>*:nth-child(4){transition-delay:.35s}

/* ══ RESPONSIVE ══ */
@media(max-width:1024px){
    .portfolio-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto;gap:12px}
    .p-item-1,.p-item-2,.p-item-3,.p-item-4,.p-item-5,.p-item-6,
    .p-item-quote1,.p-item-quote2{grid-column:auto;grid-row:auto}
    .portfolio-item{min-height:220px}
    .quote-card{min-height:180px}
    .courses-showcase{grid-template-columns:1fr;gap:32px}
}

@media(max-width:768px){
    .header{backdrop-filter:none !important;background:rgba(8,11,18,.98) !important}
    .nav{position:fixed !important;top:0 !important;right:0 !important;bottom:0 !important;left:auto !important;
        width:300px;max-width:82vw;
        background:linear-gradient(160deg,#0d1220 0%,#111827 40%,#0f172a 70%,#131b2e 100%) !important;
        border-left:1px solid rgba(59,130,246,.12);
        flex-direction:column !important;align-items:stretch !important;justify-content:flex-start !important;
        padding:0 28px 30px !important;gap:0 !important;z-index:999;
        transform:translateX(110%);transition:transform .4s cubic-bezier(.4,0,.2,1);
        display:flex !important;box-shadow:-20px 0 60px rgba(0,0,0,.7);overflow-y:auto;overflow-x:hidden}
    .nav.open{transform:translateX(0)}
    .nav::before{content:'';position:absolute;top:-80px;right:-80px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(234,88,12,.15),transparent 70%);pointer-events:none}
    .nav::after{content:'';position:absolute;bottom:-60px;left:-40px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(59,130,246,.1),transparent 70%);pointer-events:none}
    .nav .nav-brand{display:block !important;padding:24px 40px 20px 0;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:8px;font-family:var(--font-h);font-size:1.1rem;font-weight:800;color:var(--text)}
    .nav .nav-brand span{color:var(--orange)}
    .nav a{font-size:1rem !important;padding:14px 0 !important;border-bottom:1px solid rgba(255,255,255,.06) !important;position:relative;z-index:1;display:block !important;width:100%}
    .nav a:last-of-type{border-bottom:none !important}
    .nav-cta{text-align:center !important;width:100% !important;padding:14px !important;margin-top:20px !important;border-bottom:none !important;border-radius:10px !important;position:relative;z-index:1;display:block !important}
    .hamburger{display:flex;z-index:1001}
    .nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(6px);z-index:998;transition:opacity .3s}
    .nav-overlay.show{display:block;opacity:1}
    
    .hero h1{font-size:clamp(2.2rem,8vw,3.2rem)}
    .hero-sub{font-size:.95rem}
    .btn-hero{padding:14px 28px;font-size:.9rem;width:100%;justify-content:center;text-align:center}
    .hero-btns{flex-direction:column;padding:0 10px}
    .scroll-indicator{display:none}
    
    .stats-grid{grid-template-columns:1fr 1fr}
    .stat:nth-child(2)::after{display:none}
    .stat{padding:20px 12px}
    .stat-num{font-size:1.8rem}
    
    .portfolio-grid{grid-template-columns:1fr;gap:10px}
    .portfolio-item{min-height:200px}
    .quote-card{min-height:auto;padding:20px}
    .quote-text{font-size:1rem}
    
    .pricing-grid{grid-template-columns:1fr}
    
    .testi-card{flex:0 0 310px}
    
    .cta-box{padding:40px 20px}
    
    .footer-inner{flex-direction:column;text-align:center;gap:12px}
    
    section,.courses,.pricing,.testimonials,.faq-section,.cta{padding:60px 0}
    
    .courses-visual-inner{padding:12px}
}

@media(max-width:400px){
    .hero h1{font-size:2rem}
    .price-card{padding:24px}
    .price-current{font-size:2rem}
}
