
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --y:#FFE600;--y-d:rgba(255,230,0,.6);
  --bk:#080808;--bg:#0B0B0B;--bg2:#0F0F0F;
  --card:#141414;--card2:#1A1A1A;--card3:#222;
  --border:rgba(255,230,0,.06);--border-hi:rgba(255,230,0,.15);
  --text:#F8F7F2;--dim:rgba(248,247,242,.55);--dim2:rgba(248,247,242,.3);
  --green:#00E676;--red:#FF5252;--blue:#448AFF;--purple:#B388FF;--pink:#FF6B9D;--orange:#FF9800;
  --ff-d:'Fredoka',sans-serif;--ff-b:'Nunito',sans-serif;--paper:#FFFDF0;
}
html{scroll-behavior:smooth}
body{font-family:var(--ff-b);background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font-family:inherit}
.area{display:none}
.area.active{display:block;animation:fadeIn .4s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* SITE PUBLICO */
.site{background:var(--y);color:var(--bk);font-family:var(--ff-b);min-height:100vh}
.site-nav{position:fixed;top:0;left:0;right:0;z-index:80;padding:22px 40px;display:flex;align-items:center;justify-content:space-between;gap:22px;transition:all .3s}
.site-nav.scrolled{background:rgba(255,230,0,.92);backdrop-filter:blur(10px);padding:14px 40px;box-shadow:0 2px 20px rgba(0,0,0,.05)}
.site-logo{display:flex;align-items:center;gap:12px;cursor:pointer}
.site-logo-mark{width:44px;height:44px;background:var(--bk);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--y);font-family:var(--ff-d);font-weight:700;font-size:1.25rem;flex-shrink:0}
.site-logo-text{font-family:var(--ff-d);font-weight:600;font-size:1.3rem;letter-spacing:-.02em;line-height:1}
.site-logo-text small{display:block;font-family:var(--ff-b);font-weight:700;font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--bk);opacity:.7;margin-top:3px}
.site-nav-links{display:flex;gap:30px;align-items:center}
.site-nav-links a{font-weight:700;font-size:.95rem;color:var(--bk);transition:opacity .2s}
.site-nav-links a:hover{opacity:.65}
.site-nav-ctas{display:flex;gap:10px;align-items:center}
.site-btn{padding:11px 22px;border-radius:99px;font-weight:700;font-size:.88rem;transition:all .2s;display:inline-flex;align-items:center;gap:6px;border:2px solid var(--bk);cursor:pointer}
.site-btn-outline{color:var(--bk);background:transparent}
.site-btn-outline:hover{background:var(--bk);color:var(--y)}
.site-btn-solid{background:var(--bk);color:var(--y)}
.site-btn-solid:hover{background:transparent;color:var(--bk)}

.site-hero{min-height:100vh;padding:140px 40px 80px;position:relative;overflow:hidden}
.site-badge{display:inline-flex;align-items:center;gap:10px;padding:10px 22px;background:var(--bk);color:var(--y);border-radius:99px;font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;margin-bottom:30px}
.site-badge::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--y);animation:pulseDot 2s ease infinite}
@keyframes pulseDot{0%,100%{opacity:1}50%{opacity:.4}}
.site-h1{font-family:var(--ff-d);font-weight:600;font-size:clamp(3rem,8vw,7rem);letter-spacing:-.04em;line-height:.92;color:var(--bk)}
.site-h1 em{font-style:normal;background:var(--bk);color:var(--y);padding:0 .12em .04em;border-radius:12px;display:inline-block;line-height:1}
.site-sub{max-width:640px;margin-top:30px;font-size:1.1rem;line-height:1.6;color:var(--bk);font-weight:500}
.site-sub strong{font-weight:800}
.site-hero-ctas{display:flex;gap:12px;margin-top:40px;flex-wrap:wrap}
.site-hero-ctas .site-btn{font-size:1rem;padding:14px 28px}
.site-floating{position:fixed;bottom:24px;right:24px;z-index:70;display:flex;flex-direction:column;gap:8px;align-items:flex-end}
.site-float-btn{padding:12px 20px;border-radius:99px;background:var(--bk);color:var(--y);font-weight:800;font-size:.85rem;display:inline-flex;align-items:center;gap:8px;box-shadow:0 10px 30px rgba(0,0,0,.2);transition:transform .2s;cursor:pointer;border:none}
.site-float-btn:hover{transform:translateY(-2px)}
.site-float-btn svg{width:16px;height:16px}
.site-float-btn.outline{background:var(--y);color:var(--bk);border:2px solid var(--bk)}
.site-float-btn.outline:hover{background:var(--bk);color:var(--y)}

.site-section{padding:100px 40px;background:var(--bk);color:var(--paper);position:relative}
.site-section.light{background:var(--paper);color:var(--bk)}
.site-sec-head{max-width:900px;margin:0 auto 60px;text-align:center}
.site-sec-label{font-size:.78rem;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--y);margin-bottom:14px}
.site-section.light .site-sec-label{color:var(--bk)}
.site-sec-title{font-family:var(--ff-d);font-weight:600;font-size:clamp(2rem,5vw,3.5rem);letter-spacing:-.03em;line-height:1.05}
.site-sec-desc{margin-top:16px;font-size:1.05rem;line-height:1.6;color:var(--dim);max-width:640px;margin-left:auto;margin-right:auto;font-weight:500}
.site-section.light .site-sec-desc{color:rgba(0,0,0,.55)}

.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;max-width:1200px;margin:0 auto}
.service-card{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:34px 32px;transition:all .3s;position:relative;overflow:hidden}
.service-card:hover{border-color:var(--border-hi);transform:translateY(-5px);background:var(--card2)}
.service-num{font-family:var(--ff-d);font-size:.75rem;font-weight:700;letter-spacing:.14em;color:var(--y);margin-bottom:20px}
.service-icon{width:64px;height:64px;border-radius:18px;background:rgba(255,230,0,.06);border:1px solid rgba(255,230,0,.15);display:flex;align-items:center;justify-content:center;color:var(--y);margin-bottom:22px;transition:all .3s}
.service-card:hover .service-icon{transform:rotate(-5deg) scale(1.05)}
.service-icon svg{width:28px;height:28px}
.service-name{font-family:var(--ff-d);font-weight:600;font-size:1.4rem;letter-spacing:-.02em;margin-bottom:10px}
.service-desc{color:var(--dim);line-height:1.6;font-size:.94rem;margin-bottom:18px}
.service-tags{display:flex;gap:6px;flex-wrap:wrap}
.service-tag{padding:5px 12px;background:rgba(255,230,0,.06);border:1px solid rgba(255,230,0,.14);color:var(--y);border-radius:99px;font-size:.72rem;font-weight:700}
.service-arrow{position:absolute;top:28px;right:28px;width:36px;height:36px;border-radius:50%;background:rgba(255,230,0,.08);display:flex;align-items:center;justify-content:center;color:var(--y);transition:all .3s}
.service-card:hover .service-arrow{background:var(--y);color:var(--bk);transform:translate(3px,-3px)}
.service-arrow svg{width:15px;height:15px}

.cases-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;max-width:1200px;margin:0 auto}
.case-card{border-radius:22px;overflow:hidden;background:var(--bk);transition:transform .3s;border:1px solid var(--border)}
.case-card:hover{transform:translateY(-5px)}
.case-highlight{height:220px;background:var(--y);color:var(--bk);display:flex;align-items:center;justify-content:center;font-family:var(--ff-d);font-size:5rem;font-weight:700;position:relative}
.case-highlight::after{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(0,0,0,.1) 1px,transparent 1px);background-size:14px 14px;opacity:.4}
.case-label{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);font-family:var(--ff-b);font-size:.72rem;font-weight:800;letter-spacing:.15em;text-transform:uppercase}
.case-body{padding:24px 26px}
.case-tag{font-size:.72rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--y);margin-bottom:10px}
.case-title{font-family:var(--ff-d);font-weight:600;font-size:1.2rem;margin-bottom:6px;color:var(--paper)}
.case-desc{color:var(--dim);font-size:.88rem;line-height:1.55}

.site-footer{background:var(--bk);padding:60px 40px 40px;color:var(--paper);border-top:1px solid var(--border)}
.footer-huge{font-family:var(--ff-d);font-weight:700;font-size:clamp(4rem,15vw,12rem);color:var(--y);letter-spacing:-.05em;line-height:.85;text-align:center;margin-bottom:40px}
.footer-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:30px;padding-top:40px;border-top:1px solid var(--border)}
.footer-col h4{font-family:var(--ff-d);font-weight:600;font-size:.95rem;margin-bottom:14px;color:var(--y)}
.footer-col a{display:block;padding:5px 0;color:var(--dim);font-size:.88rem;font-weight:600;transition:color .2s;cursor:pointer}
.footer-col a:hover{color:var(--y)}
.footer-bottom{max-width:1200px;margin:30px auto 0;padding-top:24px;border-top:1px solid var(--border);display:flex;justify-content:space-between;font-size:.78rem;color:var(--dim);flex-wrap:wrap;gap:10px}

/* LOGIN */
.login-area{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:20px}
.login-bg{position:absolute;inset:0;z-index:0}
.login-orb{position:absolute;border-radius:50%;filter:blur(120px);opacity:.1}
.login-orb:nth-child(1){width:500px;height:500px;background:var(--y);top:-100px;left:-100px;animation:orbFloat 20s infinite alternate}
.login-orb:nth-child(2){width:400px;height:400px;background:var(--y);bottom:-100px;right:-100px;animation:orbFloat 16s infinite alternate reverse}
@keyframes orbFloat{from{transform:translate(0,0)}to{transform:translate(40px,-30px)}}
.login-card{position:relative;z-index:2;width:100%;max-width:420px;padding:44px 36px;background:rgba(255,255,255,.02);border:1px solid var(--border-hi);border-radius:24px;backdrop-filter:blur(40px)}
.login-logo{text-align:center;margin-bottom:32px}
.login-mark{width:54px;height:54px;background:var(--y);border-radius:14px;display:inline-flex;align-items:center;justify-content:center;font-family:var(--ff-d);font-weight:700;font-size:1.5rem;color:var(--bk);margin-bottom:12px}
.login-brand{font-family:var(--ff-d);font-weight:600;font-size:1.4rem}
.login-brand small{display:block;font-family:var(--ff-b);font-weight:700;font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--y);margin-top:3px}
.login-title{text-align:center;font-weight:700;font-size:1rem;margin-bottom:4px}
.login-sub{text-align:center;color:var(--dim);font-size:.85rem;margin-bottom:26px;font-weight:500}
.login-demo{background:rgba(255,230,0,.05);border:1px solid rgba(255,230,0,.15);border-radius:10px;padding:10px 14px;margin-bottom:18px;font-size:.76rem;color:var(--dim);line-height:1.6}
.login-demo strong{color:var(--y);font-weight:800}
.login-demo code{font-family:monospace;background:rgba(255,230,0,.08);padding:1px 6px;border-radius:4px;color:var(--y);font-size:.78rem}

/* APP LAYOUT */
.app{display:flex;min-height:100vh}
.sb{position:fixed;top:0;left:0;bottom:0;width:256px;background:var(--bk);border-right:1px solid var(--border);z-index:100;display:flex;flex-direction:column;padding:22px 0;transition:transform .3s}
.sb-logo{padding:0 20px 24px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border);margin-bottom:16px}
.sb-mark{width:38px;height:38px;background:var(--y);border-radius:11px;display:flex;align-items:center;justify-content:center;font-family:var(--ff-d);font-weight:700;font-size:1.15rem;color:var(--bk);flex-shrink:0}
.sb-brand{font-family:var(--ff-d);font-weight:600;font-size:1.1rem;letter-spacing:-.02em;line-height:1}
.sb-brand small{display:block;font-family:var(--ff-b);font-weight:700;font-size:.58rem;letter-spacing:.13em;text-transform:uppercase;color:var(--y);margin-top:3px}
.sb-nav{flex:1;display:flex;flex-direction:column;gap:2px;padding:0 12px;overflow-y:auto}
.sb-nav::-webkit-scrollbar{width:3px}
.sb-nav::-webkit-scrollbar-thumb{background:var(--border-hi);border-radius:99px}
.sb-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:10px;font-weight:700;font-size:.85rem;color:var(--dim);cursor:pointer;transition:all .15s;position:relative;user-select:none}
.sb-item:hover{color:var(--text);background:rgba(255,230,0,.04)}
.sb-item.active{color:var(--y);background:rgba(255,230,0,.08)}
.sb-item.active::before{content:'';position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:3px;height:18px;background:var(--y);border-radius:0 3px 3px 0}
.sb-item svg{width:17px;height:17px;flex-shrink:0}
.sb-item.super::after{content:'⚡';margin-left:auto;font-size:.72rem;opacity:.5}
.sb-badge{margin-left:auto;font-size:.62rem;font-weight:800;padding:2px 7px;border-radius:99px}
.bg-y{background:var(--y);color:var(--bk)}
.bg-g{background:var(--green);color:#000}
.bg-r{background:var(--red);color:#fff}
.sb-sec{font-size:.6rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:rgba(248,247,242,.18);padding:18px 14px 6px}
.sb-bottom{padding:12px;border-top:1px solid var(--border);margin-top:auto}
.sb-user{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:10px;cursor:pointer;transition:background .2s}
.sb-user:hover{background:rgba(255,230,0,.04)}
.sb-av{width:34px;height:34px;border-radius:50%;background:var(--y);color:var(--bk);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.75rem;flex-shrink:0}
.sb-uname{font-weight:700;font-size:.82rem;line-height:1.15}
.sb-urole{font-size:.68rem;color:var(--y);font-weight:700;margin-top:1px}

.main{margin-left:256px;flex:1;min-height:100vh;min-width:0}
.topbar{position:sticky;top:0;z-index:50;background:rgba(11,11,11,.9);backdrop-filter:blur(24px);border-bottom:1px solid var(--border);padding:14px 32px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.tb-left{display:flex;align-items:center;gap:14px;flex:1;min-width:0}
.menu-btn{display:none;width:36px;height:36px;border-radius:10px;background:var(--card);align-items:center;justify-content:center;color:var(--text);border:none}
.tb-title{font-family:var(--ff-d);font-weight:600;font-size:1.15rem;letter-spacing:-.02em}
.tb-actions{display:flex;align-items:center;gap:8px}
.tb-btn{height:38px;padding:0 14px;border-radius:10px;background:var(--card);border:1px solid var(--border);display:inline-flex;align-items:center;gap:7px;color:var(--text);font-weight:700;font-size:.83rem;transition:all .2s;cursor:pointer}
.tb-btn:hover{color:var(--y);border-color:var(--border-hi);background:var(--card2)}
.tb-btn svg{width:15px;height:15px}
.tb-btn.pri{background:var(--y);color:var(--bk);border-color:var(--y)}
.tb-btn.pri:hover{transform:translateY(-1px);box-shadow:0 8px 20px rgba(255,230,0,.3);color:var(--bk)}
.tb-icon-btn{position:relative;width:38px;height:38px;border-radius:10px;background:var(--card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--dim);transition:all .2s;cursor:pointer}
.tb-icon-btn:hover{color:var(--y);border-color:var(--border-hi)}
.tb-icon-btn svg{width:17px;height:17px}
.tb-dot{position:absolute;top:7px;right:7px;width:8px;height:8px;background:var(--red);border-radius:50%;border:2px solid var(--bg)}
.content{padding:28px 32px 80px;max-width:1500px}

.page{display:none}
.page.active{display:block;animation:fadeIn .4s ease}

/* HELP TOOLTIP */
.help{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:rgba(255,230,0,.08);color:var(--y);font-size:.68rem;font-weight:800;cursor:help;margin-left:6px;position:relative;border:1px solid rgba(255,230,0,.15);transition:all .2s;flex-shrink:0}
.help:hover{background:var(--y);color:var(--bk);transform:scale(1.1)}
.help[data-tip]:hover::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--bk);color:var(--text);padding:10px 14px;border-radius:10px;font-size:.78rem;font-weight:600;white-space:normal;width:280px;max-width:calc(100vw - 40px);z-index:1000;box-shadow:0 10px 30px rgba(0,0,0,.5);border:1px solid var(--border-hi);line-height:1.45;text-align:left;pointer-events:none}

/* Sections */
.sec{margin-bottom:32px}
.sec-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;flex-wrap:wrap;gap:10px}
.sec-title{font-family:var(--ff-d);font-weight:600;font-size:1.2rem;letter-spacing:-.02em;display:flex;align-items:center;gap:10px}
.sec-title svg{width:20px;height:20px;color:var(--y)}
.sec-sub{font-size:.85rem;color:var(--dim);font-weight:500;margin-top:4px}

/* KPI */
.kpi-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:26px}
.kpi{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px;position:relative;overflow:hidden;transition:all .2s}
.kpi:hover{border-color:var(--border-hi);transform:translateY(-2px)}
.kpi::after{content:'';position:absolute;top:-30px;right:-30px;width:80px;height:80px;border-radius:50%;opacity:.06;transition:opacity .3s}
.kpi:hover::after{opacity:.12}
.k1::after{background:var(--y)}.k2::after{background:var(--green)}.k3::after{background:var(--blue)}.k4::after{background:var(--purple)}.k5::after{background:var(--pink)}
.kpi-label{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--dim);margin-bottom:8px;display:flex;align-items:center}
.kpi-val{font-family:var(--ff-d);font-size:1.6rem;font-weight:600;letter-spacing:-.03em;line-height:1}
.kpi-change{display:inline-flex;align-items:center;gap:3px;font-size:.72rem;font-weight:800;margin-top:6px;padding:2px 7px;border-radius:99px}
.up{background:rgba(0,230,118,.1);color:var(--green)}
.down{background:rgba(255,82,82,.1);color:var(--red)}

/* Tables */
.tbl-wrap{background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden;margin-bottom:20px}
.tbl-head{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:12px}
.tbl-title{font-family:var(--ff-d);font-weight:600;font-size:1.05rem}
.tbl-filters{display:flex;gap:8px;align-items:center;position:relative}
.tbl-search-wrap{position:relative}
.tbl-search{background:var(--card2);border:1px solid var(--border);border-radius:10px;padding:9px 14px 9px 34px;color:var(--text);font-weight:600;font-size:.85rem;outline:none;width:240px}
.tbl-search-wrap svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--dim2);pointer-events:none}
.tbl-search:focus{border-color:var(--border-hi)}
.tbl-filter-btn{padding:9px 14px;background:var(--card2);border:1px solid var(--border);border-radius:10px;font-weight:700;font-size:.82rem;color:var(--text);display:inline-flex;align-items:center;gap:6px;transition:all .2s;position:relative;cursor:pointer}
.tbl-filter-btn:hover{border-color:var(--border-hi)}
.tbl-filter-btn svg{width:14px;height:14px;color:var(--y)}
.filter-dropdown{position:absolute;top:calc(100% + 4px);right:0;background:var(--card);border:1px solid var(--border-hi);border-radius:10px;padding:8px;min-width:200px;z-index:20;display:none;box-shadow:0 10px 30px rgba(0,0,0,.4)}
.filter-dropdown.open{display:block}
.filter-dropdown .fg{padding:6px 10px 4px;font-size:.66rem;font-weight:800;color:var(--dim2);letter-spacing:.1em;text-transform:uppercase}
.filter-dropdown label{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:6px;font-size:.82rem;font-weight:600;cursor:pointer;color:var(--text)}
.filter-dropdown label:hover{background:rgba(255,230,0,.06)}
.filter-dropdown input{accent-color:var(--y)}
table{width:100%;border-collapse:collapse}
thead th{text-align:left;padding:12px 22px;font-size:.66rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--dim2);border-bottom:1px solid var(--border);white-space:nowrap;background:var(--card2)}
tbody tr{border-bottom:1px solid var(--border);transition:background .15s}
tbody tr:last-child{border:none}
tbody tr:hover{background:rgba(255,230,0,.02)}
tbody td{padding:14px 22px;font-size:.87rem;font-weight:600}
.avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--ff-d);font-weight:600;font-size:.72rem;flex-shrink:0}
.user-cell{display:flex;align-items:center;gap:10px}
.status{padding:4px 10px;border-radius:99px;font-size:.7rem;font-weight:800;display:inline-block}
.st-active{background:rgba(0,230,118,.08);color:var(--green)}
.st-onboard{background:rgba(255,230,0,.08);color:var(--y)}
.st-paused{background:rgba(255,152,0,.08);color:var(--orange)}
.st-late{background:rgba(255,82,82,.08);color:var(--red)}
.st-paid{background:rgba(0,230,118,.08);color:var(--green)}
.action-btn{width:28px;height:28px;border-radius:7px;background:transparent;color:var(--dim);display:inline-flex;align-items:center;justify-content:center;font-size:1.05rem;transition:all .2s;cursor:pointer;border:none}
.action-btn:hover{background:rgba(255,230,0,.08);color:var(--y)}

/* Date sel */
.date-sel{display:flex;gap:4px;background:var(--card);padding:4px;border-radius:11px;border:1px solid var(--border)}
.date-sel button{padding:6px 14px;border-radius:8px;font-weight:700;font-size:.78rem;color:var(--dim);transition:all .2s;cursor:pointer;border:none;background:transparent}
.date-sel button:hover{color:var(--text)}
.date-sel button.active{background:var(--y);color:var(--bk)}

/* Chart */
.chart-box{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px;margin-bottom:20px}
.chart-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:22px;flex-wrap:wrap;gap:12px}
.chart-title{font-family:var(--ff-d);font-weight:600;font-size:1.05rem;margin-bottom:3px;display:flex;align-items:center}
.chart-sub{font-size:.78rem;color:var(--dim);font-weight:500}
.chart-area{height:240px;position:relative;display:flex;align-items:flex-end;gap:6px;padding-top:20px}
.bar-group{flex:1;display:flex;flex-direction:column;gap:2px;height:100%;justify-content:flex-end;align-items:stretch;position:relative}
.bar-group:hover .bar-tt{opacity:1;transform:translate(-50%,-4px)}
.bar{border-radius:4px 4px 0 0;transition:height .7s cubic-bezier(.25,.46,.45,.94),opacity .2s;min-height:2px;cursor:pointer}
.bar:hover{opacity:.8}
.bar-y{background:var(--y)}.bar-b{background:var(--blue)}
.bar-tt{position:absolute;top:-34px;left:50%;transform:translate(-50%,0);font-size:.7rem;font-weight:800;color:var(--y);white-space:nowrap;opacity:0;transition:all .2s;pointer-events:none;background:var(--bk);padding:4px 8px;border-radius:6px;border:1px solid var(--border-hi)}
.chart-labels{display:flex;gap:6px;margin-top:10px}
.chart-labels span{flex:1;text-align:center;font-size:.65rem;font-weight:700;color:var(--dim2)}
.chart-legend{display:flex;gap:18px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}
.lg{display:flex;align-items:center;gap:6px;font-size:.78rem;font-weight:700;color:var(--dim)}
.lg-dot{width:10px;height:10px;border-radius:50%}

/* Modal */
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(8px);z-index:500;display:none;align-items:center;justify-content:center;padding:20px;overflow-y:auto}
.modal-ov.open{display:flex}
.modal{background:var(--card);border:1px solid var(--border);border-radius:20px;width:100%;max-width:720px;max-height:92vh;overflow-y:auto;animation:modalIn .3s ease;margin:auto}
.modal.wide{max-width:920px}
@keyframes modalIn{from{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1)}}
.modal::-webkit-scrollbar{width:4px}
.modal::-webkit-scrollbar-thumb{background:var(--border-hi);border-radius:99px}
.modal-head{padding:24px 28px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start;position:sticky;top:0;background:var(--card);z-index:2;border-radius:20px 20px 0 0}
.modal-title{font-family:var(--ff-d);font-weight:600;font-size:1.2rem;margin-bottom:3px;display:flex;align-items:center}
.modal-sub{font-size:.82rem;color:var(--dim)}
.modal-close{width:32px;height:32px;border-radius:8px;background:var(--card2);color:var(--dim);display:flex;align-items:center;justify-content:center;transition:all .2s;cursor:pointer;border:none}
.modal-close:hover{color:var(--red);background:rgba(255,82,82,.08)}
.modal-close svg{width:16px;height:16px}
.modal-body{padding:24px 28px}
.modal-actions{display:flex;gap:10px;padding:20px 28px;border-top:1px solid var(--border);justify-content:flex-end;background:var(--card);position:sticky;bottom:0;border-radius:0 0 20px 20px;flex-wrap:wrap}
.mbtn{padding:10px 20px;border-radius:10px;font-weight:800;font-size:.86rem;transition:all .2s;display:inline-flex;align-items:center;gap:6px;cursor:pointer;border:none}
.mbtn-cancel{background:var(--card2);color:var(--dim)}
.mbtn-cancel:hover{color:var(--text)}
.mbtn-save{background:var(--y);color:var(--bk)}
.mbtn-save:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(255,230,0,.3)}
.mbtn-save svg{width:14px;height:14px}
.mbtn-del{background:rgba(255,82,82,.1);color:var(--red);border:1px solid rgba(255,82,82,.2)}
.mbtn-del:hover{background:rgba(255,82,82,.15)}

.mtabs{display:flex;gap:4px;padding:0 28px;background:var(--card);border-bottom:1px solid var(--border);overflow-x:auto;scrollbar-width:none;position:sticky;top:72px;z-index:2}
.mtabs::-webkit-scrollbar{display:none}
.mtab{padding:14px 14px;font-weight:700;font-size:.84rem;color:var(--dim);cursor:pointer;transition:color .2s;position:relative;white-space:nowrap;display:flex;align-items:center;gap:7px;background:transparent;border:none}
.mtab:hover{color:var(--text)}
.mtab.active{color:var(--y)}
.mtab.active::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--y);border-radius:2px}
.mtab svg{width:14px;height:14px}
.mtab-panel{display:none;padding:24px 28px}
.mtab-panel.active{display:block}

/* Forms */
.field{margin-bottom:14px}
.field label{display:flex;font-size:.7rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--dim);margin-bottom:6px;align-items:center}
.field input,.field textarea,.field select{width:100%;padding:11px 14px;background:var(--card2);border:1.5px solid var(--border);border-radius:10px;color:var(--text);font-weight:600;font-size:.88rem;outline:none;transition:border-color .2s}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--border-hi)}
.field input::placeholder,.field textarea::placeholder{color:var(--dim2)}
.field textarea{resize:vertical;min-height:80px;line-height:1.5}
.field-row{display:grid;gap:12px}
.fr-2{grid-template-columns:1fr 1fr}
.fr-3{grid-template-columns:1fr 1fr 1fr}
.field-help{font-size:.72rem;color:var(--dim2);margin-top:4px}

/* Check/Toggle */
.check-list{display:flex;flex-direction:column;gap:8px}
.check-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--card2);border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:all .2s}
.check-item:hover{border-color:var(--border-hi);background:var(--card3)}
.check-item.checked{border-color:rgba(255,230,0,.3);background:rgba(255,230,0,.04)}
.check-box{width:20px;height:20px;border-radius:6px;border:1.5px solid var(--border-hi);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .2s}
.check-item.checked .check-box{background:var(--y);border-color:var(--y)}
.check-box svg{width:12px;height:12px;color:var(--bk);opacity:0}
.check-item.checked .check-box svg{opacity:1}
.check-body{flex:1}
.check-title{font-weight:800;font-size:.88rem}
.check-desc{font-size:.76rem;color:var(--dim);margin-top:1px}

.toggle-row{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;background:var(--card2);border:1px solid var(--border);border-radius:10px;margin-bottom:8px;gap:12px}
.toggle-body{flex:1;min-width:0}
.toggle-title{font-weight:800;font-size:.88rem;display:flex;align-items:center}
.toggle-desc{font-size:.76rem;color:var(--dim);margin-top:1px}
.toggle{position:relative;width:42px;height:24px;background:var(--card3);border-radius:99px;cursor:pointer;transition:background .2s;flex-shrink:0}
.toggle::after{content:'';position:absolute;top:3px;left:3px;width:18px;height:18px;background:var(--dim2);border-radius:50%;transition:all .2s}
.toggle.on{background:rgba(255,230,0,.2)}
.toggle.on::after{left:21px;background:var(--y)}

/* Toast */
#toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(100px);background:var(--y);color:var(--bk);padding:12px 22px;border-radius:99px;font-weight:800;font-size:.88rem;box-shadow:0 10px 30px rgba(255,230,0,.3);opacity:0;transition:all .3s;z-index:1000;pointer-events:none;display:inline-flex;align-items:center;gap:8px}
#toast svg{width:16px;height:16px}

/* COURSE CARDS */
.course-row{display:flex;gap:16px;overflow-x:auto;padding:4px 0 16px;scrollbar-width:none}
.course-row::-webkit-scrollbar{display:none}
.course-card{min-width:280px;max-width:280px;background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden;cursor:pointer;transition:all .3s;display:flex;flex-direction:column}
.course-card:hover{transform:translateY(-6px);border-color:var(--border-hi)}
.ct{height:160px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.ct-1{background:linear-gradient(135deg,#1a0e00,#3d1f00,#1a0e00)}
.ct-2{background:linear-gradient(135deg,#001a0e,#003d1f,#001a0e)}
.ct-3{background:linear-gradient(135deg,#0e001a,#1f003d,#0e001a)}
.ct-4{background:linear-gradient(135deg,#1a1a00,#3d3d00,#1a1a00)}
.ct-5{background:linear-gradient(135deg,#1a000e,#3d001f,#1a000e)}
.ct-6{background:linear-gradient(135deg,#001a1a,#003d3d,#001a1a)}
.ct-icon{position:relative;z-index:2;width:58px;height:58px;border-radius:16px;background:rgba(0,0,0,.5);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:var(--y);transition:transform .3s}
.course-card:hover .ct-icon{transform:scale(1.1) rotate(-5deg)}
.ct-icon svg{width:26px;height:26px}
.ct-tag{position:absolute;top:12px;left:12px;z-index:3;font-size:.62rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:5px 10px;border-radius:6px;background:rgba(0,0,0,.55);backdrop-filter:blur(10px);color:var(--y);border:1px solid rgba(255,230,0,.2)}
.course-prog{position:absolute;bottom:0;left:0;right:0;height:3px;background:rgba(255,255,255,.06);z-index:3}
.course-prog-bar{height:100%;background:var(--y);border-radius:0 3px 3px 0}
.course-info{padding:16px 18px;flex:1}
.course-name{font-family:var(--ff-d);font-weight:600;font-size:1rem;margin-bottom:4px;line-height:1.2}
.course-meta{font-size:.76rem;color:var(--dim);font-weight:600}

/* Tracking */
.lt-banner{background:linear-gradient(135deg,rgba(255,230,0,.06),rgba(255,230,0,.02));border:1px solid rgba(255,230,0,.15);border-radius:18px;padding:22px 26px;margin-bottom:22px;display:flex;align-items:center;gap:20px;position:relative;overflow:hidden;flex-wrap:wrap}
.lt-icon{width:54px;height:54px;border-radius:14px;background:var(--y);color:var(--bk);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.lt-icon svg{width:24px;height:24px}
.lt-body{flex:1;min-width:200px}
.lt-title{font-family:var(--ff-d);font-weight:600;font-size:1.1rem;margin-bottom:3px}
.lt-sub{font-size:.83rem;color:var(--dim)}
.lt-status-chip{padding:7px 14px;background:rgba(0,230,118,.1);color:var(--green);border:1px solid rgba(0,230,118,.2);border-radius:99px;font-size:.78rem;font-weight:800;display:inline-flex;align-items:center;gap:6px}
.lt-status-chip::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 10px var(--green);animation:pulseDot 2s infinite}
.lt-status-chip.off{background:rgba(255,82,82,.1);color:var(--red);border-color:rgba(255,82,82,.2)}
.lt-status-chip.off::before{background:var(--red);box-shadow:0 0 10px var(--red);animation:none}

.funnel{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:22px;margin-bottom:20px}
.funnel-stages{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
.stage{background:var(--card2);border:1px solid var(--border);border-radius:12px;padding:16px;text-align:center;position:relative}
.stage::after{content:'→';position:absolute;right:-10px;top:50%;transform:translateY(-50%);color:var(--border-hi);font-weight:800;z-index:2}
.stage:last-child::after{display:none}
.stage-count{font-family:var(--ff-d);font-size:1.8rem;font-weight:600;color:var(--y);line-height:1}
.stage-label{font-size:.74rem;font-weight:700;color:var(--dim);margin-top:4px;text-transform:uppercase;letter-spacing:.04em}
.stage-pct{font-size:.7rem;color:var(--dim2);font-weight:700;margin-top:2px}

/* QR Box */
.qr-section{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:26px;text-align:center}
.qr-box{width:200px;height:200px;background:white;border-radius:14px;margin:0 auto 16px;padding:14px;position:relative;display:flex;align-items:center;justify-content:center}
.qr-box::before{content:'';position:absolute;inset:14px;background:repeating-conic-gradient(#000 0% 25%,#fff 0% 50%) 50%/16px 16px;border-radius:4px;opacity:.85}
.qr-box::after{content:'G';width:38px;height:38px;background:var(--y);border-radius:9px;position:relative;z-index:2;display:flex;align-items:center;justify-content:center;border:3px solid white;color:var(--bk);font-family:var(--ff-d);font-weight:700;font-size:1.05rem}

/* Financial */
.fin-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:22px;margin-bottom:14px}
.goal-bar-wrap{margin-top:14px}
.goal-bar{height:10px;background:var(--card2);border-radius:99px;overflow:hidden;position:relative}
.goal-bar-fill{height:100%;background:linear-gradient(90deg,var(--y),#ffcc00);border-radius:99px;position:relative;transition:width 1s cubic-bezier(.25,.46,.45,.94)}
.goal-bar-label{display:flex;justify-content:space-between;margin-top:8px;font-size:.78rem;color:var(--dim);font-weight:700}
.goal-bar-label strong{color:var(--text);font-weight:800}

/* Responsive */
@media(max-width:1100px){
  .kpi-grid{grid-template-columns:repeat(3,1fr)}
  .site-nav-links{display:none}
  .funnel-stages{grid-template-columns:repeat(3,1fr)}
  .stage:nth-child(3n)::after{display:none}
}
@media(max-width:900px){
  .sb{transform:translateX(-100%)}
  .sb.open{transform:translateX(0);box-shadow:0 0 40px rgba(0,0,0,.5)}
  .main{margin-left:0}
  .menu-btn{display:flex}
  .content{padding:20px 16px 60px}
  .topbar{padding:12px 18px}
  .kpi-grid{grid-template-columns:1fr 1fr}
  .fr-2,.fr-3{grid-template-columns:1fr}
  .tbl-search{width:100%;max-width:240px}
  .site-nav{padding:16px 20px}
  .site-hero{padding:100px 20px 60px}
  .site-section{padding:60px 20px}
  .funnel-stages{grid-template-columns:1fr 1fr}
  .stage::after{display:none}
}
@media(max-width:600px){
  .kpi-grid{grid-template-columns:1fr}
  .modal{max-width:100%}
  .funnel-stages{grid-template-columns:1fr}
}
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:99;display:none;backdrop-filter:blur(4px)}
.overlay.open{display:block}
