/* ==========================================================================
   The Grafik Studio — Theme
   Navy #14213D · Orange #FB7A1C · White
   ========================================================================== */
:root{
  --navy:#14213D; --navy-2:#1b2c50; --navy-3:#24386a;
  --orange:#FB7A1C; --orange-2:#ff8f3c; --orange-dark:#e2640a;
  --white:#ffffff; --ink:#1a2238; --muted:#6b7488; --line:#e6e9f0;
  --bg:#f6f8fc; --card:#ffffff;
  --radius:16px; --radius-sm:10px;
  --shadow:0 10px 40px rgba(20,33,61,.10); --shadow-lg:0 24px 70px rgba(20,33,61,.18);
  --maxw:1180px;
  --grad:linear-gradient(135deg,var(--orange),var(--orange-2));
  --grad-navy:linear-gradient(160deg,var(--navy),#0d1830);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,.brand-text{font-family:'Poppins',sans-serif;line-height:1.15;color:var(--navy)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}
section{position:relative}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-family:'Poppins';
  padding:14px 28px;border-radius:50px;border:none;cursor:pointer;transition:.25s;font-size:15px;line-height:1}
.btn-primary,.btn-primary-sm{background:var(--grad);color:#fff;box-shadow:0 8px 24px rgba(251,122,28,.35)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(251,122,28,.5)}
.btn-primary-sm{padding:10px 20px;font-size:14px}
.btn-outline{background:transparent;border:2px solid var(--navy);color:var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff}
.btn-outline-sm{background:transparent;border:1.5px solid rgba(255,255,255,.4);color:#fff;padding:9px 18px;border-radius:50px;font-size:14px;font-weight:600}
.btn-outline-sm:hover{background:#fff;color:var(--navy)}
.btn-ghost-sm{background:rgba(251,122,28,.18);color:var(--orange-2);padding:9px 18px;border-radius:50px;font-size:14px;font-weight:600}
.btn-light{background:#fff;color:var(--navy)}
.btn-light:hover{transform:translateY(-2px)}
.btn-block{width:100%;justify-content:center}
.btn-lg{padding:17px 38px;font-size:17px}

/* ---- Header ---- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(20,33,61,.92);backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(255,255,255,.08);transition:.3s}
.site-header.scrolled{background:rgba(13,24,48,.98);box-shadow:0 6px 24px rgba(0,0,0,.25)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:82px}
.brand{display:flex;align-items:center}
.brand-img{height:60px;width:auto;max-width:280px;object-fit:contain}
.brand-text{display:flex;align-items:baseline;gap:7px;font-weight:800;letter-spacing:.5px}
.brand-text .bt-the{font-size:13px;color:#cdd6ea;font-weight:600}
.brand-text .bt-main{font-size:22px;color:#fff}
.brand-text .bt-studio{font-size:18px;color:#fff;font-weight:700}
.brand-text .bt-d{color:var(--orange)}
.footer-logo .bt-the{color:#9aa6c4}
.footer-logo .bt-main,.footer-logo .bt-studio{color:#fff}
.main-nav{display:flex;align-items:center;gap:26px}
.main-nav a{color:#dfe5f2;font-weight:500;font-size:15px;position:relative;transition:.2s}
.main-nav a:not(.btn):hover,.main-nav a.active:not(.btn){color:#fff}
.main-nav a:not(.btn).active::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--orange);border-radius:2px}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav-toggle span{width:26px;height:3px;background:#fff;border-radius:3px;transition:.3s}

/* ---- Flash / notifications ---- */
.flash{padding-top:16px;animation:slideDown .35s}
.flash-box{display:flex;align-items:center;gap:12px;padding:13px 16px;border-radius:12px;font-weight:500;
  font-size:14.5px;border:1px solid;box-shadow:0 6px 18px rgba(20,33,61,.07)}
.flash-msg{flex:1}
.flash-ic{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:13px;flex-shrink:0;color:#fff}
.flash-x{background:none;border:none;font-size:21px;line-height:1;color:inherit;opacity:.45;cursor:pointer;padding:0 2px}
.flash-x:hover{opacity:1}
.flash-success .flash-box{background:#ecfdf5;color:#065f46;border-color:#a7f3d0}
.flash-success .flash-ic{background:#16a34a}
.flash-error .flash-box{background:#fef2f2;color:#991b1b;border-color:#fecaca}
.flash-error .flash-ic{background:#dc2626}
.flash-info .flash-box{background:#eff6ff;color:#1e3a8a;border-color:#bfdbfe}
.flash-info .flash-ic{background:#2563eb}
@keyframes slideDown{from{transform:translateY(-12px);opacity:0}to{transform:translateY(0);opacity:1}}

/* ---- Hero ---- */
.hero{background:var(--grad-navy);color:#fff;overflow:hidden;padding:80px 0 90px;position:relative}
.hero::before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(251,122,28,.35),transparent 70%);top:-160px;right:-120px;filter:blur(20px)}
.hero::after{content:"";position:absolute;width:360px;height:360px;border-radius:50%;
  background:radial-gradient(circle,rgba(36,56,106,.7),transparent 70%);bottom:-140px;left:-100px}
.hero-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center;position:relative;z-index:2}
.hero .eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(251,122,28,.16);color:var(--orange-2);
  padding:8px 16px;border-radius:50px;font-weight:600;font-size:13px;margin-bottom:22px}
.hero h1{font-size:52px;color:#fff;font-weight:800;letter-spacing:-.5px}
.hero h1 .accent{color:var(--orange);position:relative}
.hero p.lead{font-size:19px;color:#c8d2e8;margin:22px 0 32px;max-width:540px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{display:flex;gap:34px;margin-top:40px}
.hero-stats .num{font-family:'Poppins';font-size:30px;font-weight:800;color:#fff}
.hero-stats .lbl{font-size:13px;color:#9fabc9}
.hero-visual{position:relative}
.hero-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:20px;
  padding:22px;backdrop-filter:blur(8px);box-shadow:var(--shadow-lg)}
.hero-play{aspect-ratio:16/9;border-radius:14px;background:linear-gradient(135deg,#24386a,#0d1830);
  display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.hero-play .ring{width:78px;height:78px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 0 0 rgba(251,122,28,.5);animation:pulse 2.2s infinite}
.hero-play .ring::after{content:"";border-left:22px solid #fff;border-top:13px solid transparent;border-bottom:13px solid transparent;margin-left:6px}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(251,122,28,.45)}70%{box-shadow:0 0 0 26px rgba(251,122,28,0)}100%{box-shadow:0 0 0 0 rgba(251,122,28,0)}}
.hero-badges{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap}
.hero-badges span{font-size:12px;background:rgba(255,255,255,.08);padding:7px 12px;border-radius:8px;color:#cdd6ea}

/* ---- Section heading ---- */
.sec{padding:80px 0}
.sec-head{text-align:center;max-width:680px;margin:0 auto 50px}
.sec-head .kicker{color:var(--orange);font-weight:700;font-size:13px;letter-spacing:2px;text-transform:uppercase}
.sec-head h2{font-size:38px;margin:10px 0 14px}
.sec-head p{color:var(--muted);font-size:17px}

/* ---- Trust bar ---- */
.trust{background:var(--navy);padding:22px 0;border-top:1px solid rgba(255,255,255,.06)}
.trust .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:18px}
.trust .item{color:#fff;display:flex;align-items:center;gap:13px;flex:1 1 200px;justify-content:center}
.trust .item .ti{width:42px;height:42px;border-radius:11px;background:rgba(251,122,28,.15);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.trust .item .tt{display:flex;flex-direction:column;line-height:1.25}
.trust .item .tt b{font-family:'Poppins';font-size:15px;color:#fff;font-weight:600}
.trust .item .tt span{font-size:12.5px;color:#9fabc9}

/* ---- Course cards ---- */
.course-grid{display:flex;flex-wrap:wrap;gap:26px;justify-content:center}
.course-card{background:var(--card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);
  transition:.3s;border:1px solid var(--line);display:flex;flex-direction:column;
  flex:1 1 320px;max-width:362px;width:100%}
.course-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.cc-media{aspect-ratio:16/9;background:var(--grad-navy);position:relative;display:flex;align-items:center;justify-content:center;color:#fff}
.cc-media .soft{font-family:'Poppins';font-weight:800;font-size:26px;opacity:.95;letter-spacing:.5px;text-align:center;padding:0 14px}
.cc-media .lens{position:absolute;top:14px;right:14px;width:30px;height:30px;border-radius:50%;
  border:3px solid var(--orange);box-shadow:inset 0 0 0 3px #ffd23f}
.cc-tag{position:absolute;bottom:12px;left:12px;background:var(--orange);color:#fff;font-size:11px;font-weight:700;padding:5px 11px;border-radius:50px}
.cc-soft-logo{position:absolute;top:50%;left:50%;transform:translate(-50%,-58%);width:74px;height:74px;object-fit:contain;filter:drop-shadow(0 8px 20px rgba(0,0,0,.35))}
.soft.soft-sm{position:absolute;bottom:14px;right:14px;left:auto;font-size:15px;font-weight:700;opacity:.92}

/* Software strip */
.soft-logos{display:flex;justify-content:center;flex-wrap:wrap;gap:40px}
.soft-logo{display:flex;flex-direction:column;align-items:center;gap:10px;transition:.3s}
.soft-logo:hover{transform:translateY(-6px)}
.soft-logo img{width:66px;height:66px;object-fit:contain;border-radius:16px;box-shadow:var(--shadow)}
.soft-logo span{font-size:13px;font-weight:600;color:var(--navy);font-family:'Poppins'}
.cc-body{padding:22px;display:flex;flex-direction:column;flex:1}
.cc-body h3{font-size:20px;margin-bottom:8px}
.cc-body .lvl{font-size:12px;color:var(--orange-dark);font-weight:600;margin-bottom:10px}
.cc-body p{color:var(--muted);font-size:14.5px;flex:1}
.cc-price{display:flex;align-items:baseline;gap:10px;margin:16px 0}
.cc-price .now{font-family:'Poppins';font-size:26px;font-weight:800;color:var(--navy)}
.cc-price .mrp{color:var(--muted);text-decoration:line-through;font-size:15px}
.cc-price .off{color:#16a34a;font-weight:700;font-size:13px}

/* ---- Combo banner ---- */
.combo{background:var(--grad-navy);border-radius:24px;color:#fff;padding:48px;display:grid;
  grid-template-columns:1.4fr 1fr;gap:34px;align-items:center;position:relative;overflow:hidden}
.combo::before{content:"";position:absolute;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(251,122,28,.4),transparent 70%);top:-100px;right:-60px}
.combo h2{color:#fff;font-size:34px}
.combo p{color:#c8d2e8;margin:14px 0 0}
.combo .clist{margin:18px 0;display:flex;flex-direction:column;gap:8px}
.combo .clist li{list-style:none;color:#dde4f2;display:flex;gap:10px;align-items:center}
.combo .clist li::before{content:"✓";color:var(--orange-2);font-weight:800}
.combo-price{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:18px;padding:28px;text-align:center;position:relative;z-index:2}
.combo-price .mrp{color:#9fabc9;text-decoration:line-through}
.combo-price .now{font-family:'Poppins';font-size:46px;font-weight:800;color:#fff;margin:6px 0}
.combo-price .save{display:inline-block;background:var(--orange);color:#fff;padding:5px 14px;border-radius:50px;font-weight:700;font-size:13px;margin-bottom:18px}

/* ---- Features ---- */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.feat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;transition:.3s}
.feat:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.feat .ic{width:54px;height:54px;border-radius:14px;background:rgba(251,122,28,.12);color:var(--orange-dark);
  display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:16px}
.feat h3{font-size:18px;margin-bottom:8px}
.feat p{color:var(--muted);font-size:14.5px}

/* ---- Steps ---- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:s}
.step{text-align:center;padding:18px}
.step .n{width:56px;height:56px;border-radius:50%;background:var(--grad);color:#fff;font-family:'Poppins';font-weight:800;
  font-size:22px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.step h4{font-size:17px;margin-bottom:6px}.step p{color:var(--muted);font-size:14px}

/* ---- Reviews ---- */
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.review{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.review .stars{color:#ffb400;margin-bottom:12px;letter-spacing:2px}
.review p{font-size:15px;color:#34405c;font-style:italic}
.review .who{display:flex;align-items:center;gap:12px;margin-top:18px}
.review .av{width:42px;height:42px;border-radius:50%;background:var(--grad-navy);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700}
.review .who b{display:block;font-size:14px;color:var(--navy)}
.review .who span{font-size:12px;color:var(--muted)}

/* ---- FAQ ---- */
.faq{max-width:760px;margin:0 auto}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:12px;overflow:hidden}
.faq-q{padding:18px 22px;font-weight:600;font-family:'Poppins';color:var(--navy);cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.faq-q::after{content:"+";color:var(--orange);font-size:22px;font-weight:700}
.faq-item.open .faq-q::after{content:"–"}
.faq-a{max-height:0;overflow:hidden;transition:.3s;padding:0 22px;color:var(--muted)}
.faq-item.open .faq-a{max-height:240px;padding:0 22px 18px}

/* ---- CTA band ---- */
.cta-band{background:var(--grad);color:#fff;border-radius:24px;text-align:center;padding:54px 30px}
.cta-band h2{color:#fff;font-size:34px}.cta-band p{color:rgba(255,255,255,.9);margin:12px 0 26px;font-size:17px}

/* ---- Footer ---- */
.site-footer{background:var(--navy);color:#c2cbe0;padding:56px 0 0;margin-top:80px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:30px;padding-bottom:40px}
.footer-logo-img{height:64px;width:auto;max-width:300px;object-fit:contain;margin-left:-10px}
.footer-brand p{margin-top:14px;font-size:14px;max-width:320px;color:#9aa6c4}
.footer-col h4{color:#fff;font-size:15px;margin-bottom:14px}
.footer-col a{display:block;color:#9aa6c4;font-size:14px;padding:5px 0;transition:.2s}
.footer-col a:hover{color:var(--orange-2)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:18px 0;font-size:13px;color:#8b97b6}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap}
.footer-legal{display:flex;gap:20px;flex-wrap:wrap}
.footer-legal a{color:#9aa6c4;transition:.2s}
.footer-legal a:hover{color:var(--orange-2)}

/* ---- WhatsApp float ---- */
.whatsapp-float{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:#25D366;color:#fff;
  display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(37,211,102,.5);z-index:90;transition:.25s;animation:pulse2 2.5s infinite}
.whatsapp-float:hover{transform:scale(1.1)}
@keyframes pulse2{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 18px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}

/* ---- Reveal animation ---- */
.reveal{opacity:0;transform:translateY(30px);transition:.7s cubic-bezier(.22,.61,.36,1)}
.reveal.in{opacity:1;transform:none}

/* ==========================================================================
   Inner pages
   ========================================================================== */
.page-hero{background:var(--grad-navy);color:#fff;padding:60px 0;text-align:center}
.page-hero h1{color:#fff;font-size:40px}
.page-hero p{color:#c8d2e8;margin-top:10px}
.breadcrumb{font-size:13px;color:#9fabc9;margin-bottom:14px}
.breadcrumb a{color:var(--orange-2)}

/* Checkout */
.checkout-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
.checkout-summary,.checkout-pay{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow)}
.checkout-summary h3,.checkout-pay h3{font-size:18px;margin-bottom:18px}
.co-item{display:flex;gap:14px;align-items:center;padding-bottom:16px;border-bottom:1px solid var(--line);margin-bottom:16px}
.co-thumb{width:56px;height:56px;border-radius:12px;background:var(--grad-navy);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}
.co-thumb img{width:40px;height:40px;object-fit:contain}
.co-thumb span{color:#fff;font-size:11px;font-weight:700;text-align:center}
.co-row{display:flex;justify-content:space-between;padding:8px 0;color:#4a5670;font-size:15px}
.co-total{border-top:2px solid var(--line);margin-top:10px;padding-top:14px;font-family:'Poppins';font-weight:800;font-size:20px;color:var(--navy)}
.co-perks{list-style:none;margin:0 0 20px}
.co-perks li{padding:6px 0;color:#4a5670;font-size:14.5px;display:flex;gap:9px}
.co-perks li::before{content:"✓";color:var(--orange);font-weight:800}
.co-secure{text-align:center;font-size:12.5px;color:var(--muted);margin-top:12px}
.co-back{display:block;text-align:center;margin-top:16px;color:var(--orange-dark);font-weight:600;font-size:14px}
@media(max-width:680px){.checkout-grid{grid-template-columns:1fr}}

/* Legal pages */
.legal-doc{max-width:820px;margin:0 auto}
.legal-intro{font-size:17px;color:#34405c;margin-bottom:10px}
.legal-block{margin-top:28px}
.legal-block h2{font-size:21px;margin-bottom:10px;color:var(--navy)}
.legal-block p{color:#4a5670;margin-bottom:10px;font-size:15.5px}
.legal-block ul{margin:6px 0 10px 22px;color:#4a5670}
.legal-block li{margin-bottom:6px}

/* Auth */
.auth-wrap{min-height:78vh;display:flex;align-items:center;justify-content:center;padding:50px 20px;background:var(--bg)}
.auth-card{background:#fff;border-radius:20px;box-shadow:var(--shadow-lg);padding:42px;width:100%;max-width:430px;border:1px solid var(--line)}
.auth-logo{display:block;text-align:center;margin-bottom:8px}
.auth-logo img{height:54px;width:auto;max-width:230px;object-fit:contain;display:inline-block}
.auth-card h1{font-size:26px;text-align:center}
.auth-card .sub{text-align:center;color:var(--muted);margin:8px 0 26px;font-size:14.5px}
.field{margin-bottom:16px}
.field label{display:block;font-size:13.5px;font-weight:600;color:var(--navy);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border:1.6px solid var(--line);border-radius:10px;font-size:15px;font-family:inherit;transition:.2s;background:#fbfcfe}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--orange);background:#fff;box-shadow:0 0 0 3px rgba(251,122,28,.12)}
.auth-alt{text-align:center;margin-top:18px;font-size:14px;color:var(--muted)}
.auth-alt a{color:var(--orange-dark);font-weight:600}

/* Course detail */
.cd-grid{display:grid;grid-template-columns:1fr 360px;gap:40px;align-items:start;margin-top:-60px;position:relative;z-index:3}
.cd-main{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:34px;border:1px solid var(--line)}
.cd-main h2{font-size:24px;margin:28px 0 14px}
.cd-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:26px;border:1px solid var(--line);position:sticky;top:90px}
.cd-card .price{font-family:'Poppins';font-size:36px;font-weight:800;color:var(--navy)}
.cd-card .mrp{color:var(--muted);text-decoration:line-through;margin-left:8px;font-size:17px}
.cd-card .off{color:#16a34a;font-weight:700;font-size:14px;margin-top:4px}
.cd-card ul{list-style:none;margin:20px 0}
.cd-card ul li{padding:7px 0;color:#34405c;font-size:14.5px;display:flex;gap:10px}
.cd-card ul li::before{content:"✓";color:var(--orange);font-weight:800}
.curriculum{border:1px solid var(--line);border-radius:12px;overflow:hidden}
.lesson-row{display:flex;align-items:center;gap:14px;padding:15px 18px;border-bottom:1px solid var(--line);background:#fff}
.lesson-row:last-child{border-bottom:none}
.lesson-row .ix{width:30px;height:30px;border-radius:50%;background:var(--bg);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:var(--navy)}
.lesson-row .ttl{flex:1;font-weight:500;font-size:15px}
.lesson-row .ic{color:var(--muted);font-size:14px}
.lesson-row .free{background:rgba(22,163,74,.12);color:#16a34a;font-size:11px;font-weight:700;padding:3px 9px;border-radius:50px}
.lesson-row .lock{color:var(--muted)}

/* Dashboard */
.dash{padding:50px 0}
.dash-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.dash-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}
.dash-card h3{font-size:18px;margin-bottom:6px}
.progress{height:9px;background:var(--line);border-radius:50px;overflow:hidden;margin:14px 0 8px}
.progress > span{display:block;height:100%;background:var(--grad);border-radius:50px;transition:width .6s}
.empty{text-align:center;padding:50px;background:#fff;border-radius:var(--radius);border:1px dashed var(--line)}

/* Avatar */
.avatar{border-radius:50%;object-fit:cover;display:inline-block;vertical-align:middle;border:2px solid rgba(255,255,255,.5)}
.avatar-initials{background:var(--grad);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-family:'Poppins'}

/* Profile */
.profile-hero{background:var(--grad-navy);color:#fff;padding:46px 0}
.profile-hero-inner{display:flex;align-items:center;gap:24px}
.ph-avatar .avatar{border:4px solid rgba(255,255,255,.18);box-shadow:var(--shadow-lg)}
.ph-info{flex:1}
.ph-info h1{color:#fff;font-size:30px;margin-bottom:2px}
.ph-info p{color:#c8d2e8;font-size:15px}
.ph-since{display:inline-block;margin-top:8px;font-size:13px;color:#9fabc9;background:rgba(255,255,255,.07);padding:5px 12px;border-radius:50px}
.pf-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.pf-stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px;text-align:center;box-shadow:var(--shadow)}
.pf-stat .ic{font-size:24px}
.pf-stat .n{font-family:'Poppins';font-size:30px;font-weight:800;color:var(--navy);margin-top:4px}
.pf-stat .l{color:var(--muted);font-size:13px}
.pf-grid{display:grid;grid-template-columns:1fr 330px;gap:24px;align-items:start}
.pf-last{display:flex;justify-content:space-between;align-items:center;gap:14px;background:#fff8f2;border:1px solid #ffd9b8;border-radius:12px;padding:16px}
.pf-course{padding:14px 0;border-bottom:1px solid var(--line)}
.pf-course:last-child{border-bottom:none}
.pf-edit{display:flex;gap:18px;align-items:center;margin-bottom:8px}
.pf-overall{text-align:center;margin-bottom:18px}
.ring{--p:0;width:120px;height:120px;border-radius:50%;margin:0 auto 8px;display:flex;align-items:center;justify-content:center;
  background:conic-gradient(var(--orange) calc(var(--p)*1%), var(--line) 0)}
.ring span{width:92px;height:92px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;
  font-family:'Poppins';font-weight:800;font-size:24px;color:var(--navy)}
.pf-miles{display:flex;flex-direction:column;gap:9px}
.pf-mile{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:10px;border:1px solid var(--line);font-size:14px}
.pf-mile.on{background:#f0fdf4;border-color:#bbf7d0}
.pf-mile.off{opacity:.6}
.pf-mile .mi{font-size:18px}
.pf-mile .mt{flex:1;font-weight:500}
.pf-mile .mb{color:#16a34a;font-weight:800}
@media(max-width:880px){.pf-stats{grid-template-columns:1fr 1fr}.pf-grid{grid-template-columns:1fr}.profile-hero-inner{flex-direction:column;text-align:center}}

/* Learn / player */
.learn{display:grid;grid-template-columns:1fr 340px;min-height:calc(100vh - 74px)}
.player-area{background:#0b1020;padding:0}
.player-wrap{position:relative;aspect-ratio:16/9;background:#000}
.player-wrap video{width:100%;height:100%;display:block;background:#000}
.player-wrap .bunny-frame{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
.player-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#9fabc9;text-align:center;padding:30px}
.player-placeholder .ic{font-size:46px;margin-bottom:12px}
.wm{position:absolute;pointer-events:none;color:rgba(255,255,255,.35);font-size:13px;font-weight:600;z-index:5;text-shadow:0 1px 3px rgba(0,0,0,.6)}
.lesson-meta{padding:26px 30px;color:#fff}
.lesson-meta h1{color:#fff;font-size:24px}
.lesson-meta p{color:#aeb8d2;margin-top:10px}
.playlist{background:var(--navy);color:#fff;overflow-y:auto;max-height:calc(100vh - 74px)}
.playlist .ph{padding:20px;border-bottom:1px solid rgba(255,255,255,.08)}
.playlist .ph .bar{height:7px;background:rgba(255,255,255,.12);border-radius:50px;margin-top:10px;overflow:hidden}
.playlist .ph .bar > span{display:block;height:100%;background:var(--grad)}
.pl-item{display:flex;gap:12px;align-items:center;padding:14px 20px;border-bottom:1px solid rgba(255,255,255,.06);color:#cdd6ea;font-size:14px;transition:.2s}
.pl-item:hover{background:rgba(255,255,255,.05)}
.pl-item.active{background:rgba(251,122,28,.16);color:#fff;border-left:3px solid var(--orange)}
.pl-item .st{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}
.pl-item .st.done{background:#16a34a;color:#fff}
.pl-item .st.locked{background:rgba(255,255,255,.1);color:#7e8aab}
.pl-item .st.open{background:var(--orange);color:#fff}
.pl-item.locked{opacity:.6;cursor:not-allowed}

/* Quiz */
.quiz-wrap{max-width:760px;margin:0 auto;padding:40px 0}
.q-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;margin-bottom:18px;box-shadow:var(--shadow)}
.q-card .qn{font-weight:700;font-family:'Poppins';color:var(--navy);margin-bottom:16px}
.opt{display:flex;align-items:center;gap:12px;padding:13px 16px;border:1.6px solid var(--line);border-radius:10px;margin-bottom:10px;cursor:pointer;transition:.2s}
.opt:hover{border-color:var(--orange);background:#fff8f2}
.opt input{accent-color:var(--orange);width:18px;height:18px}
.opt.correct{border-color:#16a34a;background:#f0fdf4}
.opt.wrong{border-color:#dc2626;background:#fef2f2}
.result-hero{text-align:center;padding:40px;border-radius:var(--radius);color:#fff;margin-bottom:24px}
.result-hero.pass{background:linear-gradient(135deg,#16a34a,#22c55e)}
.result-hero.fail{background:linear-gradient(135deg,#dc2626,#f87171)}
.result-hero .score{font-family:'Poppins';font-size:54px;font-weight:800}

/* Certificate */
.cert{max-width:900px;margin:40px auto;background:#fff;border:14px solid var(--navy);border-radius:8px;padding:54px;text-align:center;position:relative;box-shadow:var(--shadow-lg)}
.cert::after{content:"";position:absolute;inset:14px;border:2px solid var(--orange);border-radius:4px;pointer-events:none}
.cert-logo{height:64px;width:auto;max-width:280px;object-fit:contain;margin:0 auto 18px}
.cert .ct-k{color:var(--orange-dark);letter-spacing:3px;font-weight:700;text-transform:uppercase;font-size:13px}
.cert h1{font-size:38px;margin:10px 0}
.cert .name{font-family:'Poppins';font-size:34px;color:var(--navy);border-bottom:2px solid var(--orange);display:inline-block;padding:6px 30px;margin:18px 0}
.cert .course-name{font-size:20px;color:var(--navy);font-weight:600;margin:10px 0}
.cert .meta{display:flex;justify-content:space-between;margin-top:46px;font-size:13px;color:var(--muted)}

/* Analytics */
.an-range{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.an-range a{padding:8px 16px;border-radius:50px;background:#fff;border:1px solid var(--line);font-size:13.5px;font-weight:600;color:var(--navy);transition:.2s}
.an-range a:hover{border-color:var(--orange)}
.an-range a.active{background:var(--grad);color:#fff;border-color:transparent}
.an-live-bar{display:flex;align-items:center;gap:10px;background:var(--navy);color:#fff;border-radius:12px;padding:12px 18px;margin-bottom:18px;font-size:14px}
.an-live-dot{width:10px;height:10px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 0 rgba(34,197,94,.6);animation:pulse 1.8s infinite}
.an-live-bar #liveCount{font-weight:800;color:#4ade80}
.an-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px}
.an-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.an-card .ic{font-size:22px}
.an-card .n{font-family:'Poppins';font-size:26px;font-weight:800;color:var(--navy);margin-top:4px}
.an-card .l{color:var(--muted);font-size:13px}
.an-card .sub{color:var(--orange-dark);font-size:11.5px;margin-top:3px;font-weight:600}
.an-chart{display:flex;align-items:flex-end;gap:5px;height:200px;padding-top:14px;overflow-x:auto}
.an-bar-wrap{flex:1;min-width:18px;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end}
.an-bar{width:60%;min-height:3px;background:var(--grad);border-radius:6px 6px 0 0;display:flex;justify-content:center;position:relative;transition:.3s}
.an-bar span{position:absolute;top:-18px;font-size:11px;font-weight:700;color:var(--navy)}
.an-bar-lbl{font-size:10px;color:var(--muted);margin-top:6px;white-space:nowrap;transform:rotate(-35deg);transform-origin:top right;height:24px}
.an-pay{padding:10px 0;border-bottom:1px solid var(--line)}
.an-pay:last-child{border-bottom:none}
.an-top{margin-bottom:12px}
.an-top-bar{height:8px;background:var(--line);border-radius:50px;margin-top:5px;overflow:hidden}
.an-top-bar > span{display:block;height:100%;background:var(--grad);border-radius:50px}
.an-viewer{display:flex;align-items:center;gap:11px;padding:10px 0;border-bottom:1px solid var(--line)}
.an-viewer:last-child{border-bottom:none}
.an-since{background:#f0fdf4;color:#16a34a;font-size:12px;font-weight:700;padding:4px 10px;border-radius:50px;white-space:nowrap}
@media(max-width:980px){.an-cards{grid-template-columns:1fr 1fr}}

/* Tables (admin) */
.table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.table th,.table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--line);font-size:14px}
.table th{background:var(--navy);color:#fff;font-family:'Poppins';font-weight:600;font-size:13px}
.table tr:hover td{background:#fbfcff}
.badge{font-size:11px;font-weight:700;padding:4px 10px;border-radius:50px}
.badge.on{background:#dcfce7;color:#16a34a}.badge.off{background:#fee2e2;color:#dc2626}
.tag-soft{font-size:11px;background:rgba(251,122,28,.14);color:var(--orange-dark);padding:3px 9px;border-radius:50px;margin-right:4px}

/* Admin layout */
.admin{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.admin-side{background:var(--navy);color:#fff;padding:24px 16px}
.admin-side .logo{padding:6px 8px 18px;display:block}
.admin-logo-img{height:42px;width:auto;max-width:200px;object-fit:contain}
.admin-side a{display:flex;gap:10px;align-items:center;color:#b9c3dc;padding:12px 14px;border-radius:10px;font-size:14.5px;font-weight:500;margin-bottom:4px;transition:.2s}
.admin-side a:hover{background:rgba(255,255,255,.06);color:#fff}
.admin-side a.active{background:var(--grad);color:#fff}
.admin-main{padding:30px 34px;background:var(--bg)}
.admin-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:26px}
.admin-head h1{font-size:26px}
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:30px}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
.stat .n{font-family:'Poppins';font-size:32px;font-weight:800;color:var(--navy)}
.stat .l{color:var(--muted);font-size:13.5px;margin-top:4px}
.stat .ic{float:right;font-size:24px;opacity:.5}
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);margin-bottom:22px}
.panel h3{font-size:18px;margin-bottom:16px}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.muted{color:var(--muted)}
.mt{margin-top:20px}.mb{margin-bottom:20px}
.inline-form{display:inline}
.btn-danger{background:#fee2e2;color:#dc2626;padding:7px 14px;border-radius:8px;font-size:13px;font-weight:600;border:none;cursor:pointer}
.btn-sm{padding:8px 16px;font-size:13.5px}
.flex{display:flex;gap:10px;align-items:center}
.flex-between{display:flex;justify-content:space-between;align-items:center;gap:12px}
.note{background:#fff8f2;border:1px solid #ffd9b8;border-radius:10px;padding:14px 16px;font-size:13.5px;color:#8a5316;margin:14px 0}

/* ---- Responsive ---- */
@media(max-width:980px){
  .hero-inner{grid-template-columns:1fr;gap:36px}.hero h1{font-size:40px}
  .course-grid,.feat-grid,.review-grid,.steps{grid-template-columns:1fr 1fr}
  .combo{grid-template-columns:1fr}.cd-grid{grid-template-columns:1fr}
  .learn{grid-template-columns:1fr}.playlist{max-height:none}
  .admin{grid-template-columns:1fr}.admin-side{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .nav-toggle{display:flex}
  .main-nav{position:fixed;top:74px;right:0;width:260px;height:calc(100vh - 74px);background:var(--navy);flex-direction:column;
    align-items:flex-start;padding:24px;gap:16px;transform:translateX(100%);transition:.3s;box-shadow:-10px 0 40px rgba(0,0,0,.3)}
  .main-nav.open{transform:translateX(0)}
  .hero h1{font-size:32px}.sec-head h2{font-size:28px}.page-hero h1{font-size:30px}
  .course-grid,.feat-grid,.review-grid,.steps,.dash-grid,.row-2,.stat-grid,.footer-grid{grid-template-columns:1fr}
  .hero-stats{gap:22px}.sec{padding:54px 0}.combo,.cert{padding:28px}
  .cert .name{font-size:26px}
}
