@import"https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700;800&family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap";:root{--bg:#f4f5fc;--card:#ffffff;--panel:#ffffff;--panel2:#f7f7fd;--ink:#191a2e;--txt:#191a2e;--muted:#7e7f9a;--faint:#a9aac4;--line:#eef0f7;--line2:#e6e8f3;--violet:#6c5ce7;--violet2:#8b7cf0;--violetSoft:#efecfe;--lav:#f1eefe;--pur:#efe9ff;--mint:#e4f7ec;--peach:#fdeee7;--sky:#e9f1fe;--gold:#6c5ce7;--teal:#1bbfae;--green:#16c784;--red:#f5577a;--blue:#5b8def;--purple:#8b7cf0;--amber:#f7b500;--radius:20px;--shadow:0 10px 30px rgba(89,86,151,.08);--shadow-sm:0 4px 16px rgba(89,86,151,.06);--shadow-lg:0 18px 44px rgba(89,86,151,.16);--sans:"Plus Jakarta Sans",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;--display:"Sora",var(--sans)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--sans);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}a{color:inherit;text-decoration:none}h1,h2,h3,h4{font-family:var(--display);margin:0;letter-spacing:-.02em;font-weight:700}button{font-family:var(--sans);cursor:pointer}input,select,textarea{font-family:var(--sans)}::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-thumb{background:#dcdef0;border-radius:8px}::-webkit-scrollbar-track{background:transparent}.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(900px 500px at 80% -5%,rgba(108,92,231,.14),transparent 55%),radial-gradient(800px 460px at -5% 10%,rgba(139,124,240,.12),transparent 50%),var(--bg)}.auth-card{width:100%;max-width:400px;background:var(--card);border:1px solid var(--line);border-radius:24px;padding:40px 34px;box-shadow:var(--shadow-lg)}.auth-logo{display:flex;align-items:center;gap:12px;margin-bottom:28px}.auth-logo .mark{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,#7b6cf0,#6c5ce7);color:#fff;font-weight:800;font-family:var(--display);font-size:22px;box-shadow:0 8px 20px #6c5ce766}.auth-card h1{font-size:24px}.auth-card .sub{color:var(--muted);margin-top:4px;font-size:13px}.app{display:flex;min-height:100vh}.sidebar{width:248px;flex:0 0 248px;background:var(--card);border-right:1px solid var(--line);padding:18px 14px;position:sticky;top:0;height:100vh;overflow-y:auto;z-index:40}.brand{display:flex;align-items:center;gap:11px;padding:6px 10px 18px}.brand .mark{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(135deg,#7b6cf0,#6c5ce7);color:#fff;font-weight:800;font-family:var(--display);font-size:18px;box-shadow:0 6px 16px #6c5ce766}.brand b{font-family:var(--display);font-size:17px;letter-spacing:-.02em;color:var(--ink)}.brand span{display:block;font-size:10px;color:var(--faint);letter-spacing:.16em;text-transform:uppercase;margin-top:1px}.nav-group{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);padding:14px 12px 6px;font-weight:700}.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:13px;color:var(--muted);font-weight:600;font-size:13.5px;margin-bottom:2px;transition:all .18s cubic-bezier(.4,0,.2,1);white-space:nowrap}.nav-item:hover{background:#f6f5fe;color:var(--ink);transform:translate(2px)}.nav-item.active{background:var(--violetSoft);color:var(--violet)}.nav-item svg{flex:0 0 18px}.main{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;gap:14px;padding:16px 26px;position:sticky;top:0;background:#f4f5fcdb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:30}.topbar h2{font-size:19px}.topbar .sub{color:var(--faint);font-size:12.5px;margin-top:1px}.topbar .spacer{flex:1}.content{padding:18px 26px 60px;max-width:1320px;width:100%;animation:fade .3s cubic-bezier(.2,.7,.3,1)}@keyframes fade{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.menu-btn{display:none;background:var(--card);border:1px solid var(--line);color:var(--ink);width:38px;height:38px;border-radius:10px;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.btn{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);background:var(--card);color:var(--ink);padding:9px 15px;border-radius:12px;font-weight:600;font-size:13px;transition:.16s;box-shadow:var(--shadow-sm)}.btn:hover{border-color:var(--violet);color:var(--violet);transform:translateY(-1px)}.btn.primary{background:linear-gradient(135deg,#7b6cf0,#6c5ce7);border-color:transparent;color:#fff;box-shadow:0 8px 20px #6c5ce752}.btn.primary:hover{filter:brightness(1.05);color:#fff}.btn.ghost{background:var(--card)}.btn.danger:hover{border-color:var(--red);color:var(--red)}.btn.sm{padding:7px 12px;font-size:12px}.icon-btn{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;background:transparent;border:1px solid transparent;color:var(--muted);transition:.14s}.icon-btn:hover{background:#f1f0fb;color:var(--violet)}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);transition:transform .2s cubic-bezier(.2,.7,.3,1),box-shadow .2s}.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.card h3{font-size:15px;margin-bottom:14px;display:flex;align-items:center;gap:8px}.grid{display:grid;gap:16px}.g2{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}@media (max-width:1100px){.g4,.g3{grid-template-columns:repeat(2,1fr)}}@media (max-width:680px){.g2,.g3,.g4{grid-template-columns:1fr}}.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;position:relative;overflow:hidden;box-shadow:var(--shadow);transition:.2s}.stat:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.stat .ic{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;margin-bottom:13px}.stat .lbl{color:var(--muted);font-size:12.5px;font-weight:600}.stat .val{font-family:var(--display);font-size:25px;font-weight:700;margin-top:3px;letter-spacing:-.02em}.stat .sub{font-size:11.5px;color:var(--faint);margin-top:4px;font-weight:500}.kpi{border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);transition:transform .2s cubic-bezier(.2,.7,.3,1),box-shadow .2s}.kpi:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.kpi .top{display:flex;align-items:center;gap:10px;margin-bottom:14px}.kpi .ic{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;background:#fff;box-shadow:var(--shadow-sm)}.kpi .lbl{font-size:12.5px;font-weight:600;color:var(--muted)}.kpi .val{font-family:var(--display);font-size:25px;font-weight:700;letter-spacing:-.02em}.kpi .chip{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:700;padding:3px 9px;border-radius:99px;margin-top:10px}.kpi .sub{font-size:11.5px;color:var(--faint);margin-top:8px;font-weight:500}.tbl-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:var(--card);box-shadow:var(--shadow)}table.tbl{width:100%;border-collapse:collapse;font-size:13px;min-width:520px}.tbl th{text-align:left;padding:13px 14px;color:var(--faint);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--line);background:transparent}.tbl td{padding:13px 14px;border-bottom:1px solid var(--line)}.tbl tr:last-child td{border-bottom:none}.tbl tr:hover td{background:#faf9fe}.tbl .actions{display:flex;gap:4px;justify-content:flex-end}.pill{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700;background:#f0f1f8;color:var(--muted)}.pill.green{background:#e3f8ef;color:#0f9d6b}.pill.red{background:#fde7ee;color:#e0436a}.pill.gold{background:var(--violetSoft);color:var(--violet)}.pill.blue{background:#e8f0fe;color:#3f74e0}.pill.purple{background:#efeaff;color:#7b5cf0}.empty{text-align:center;padding:60px 20px;color:var(--faint)}.empty .ic{width:60px;height:60px;border-radius:18px;background:var(--violetSoft);display:grid;place-items:center;margin:0 auto 16px;color:var(--violet)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#191a2e52;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;overflow-y:auto}.modal{width:100%;max-width:560px;background:var(--card);border-radius:22px;box-shadow:var(--shadow-lg);overflow:hidden;animation:pop .2s cubic-bezier(.2,.7,.3,1)}@keyframes pop{0%{transform:translateY(14px) scale(.98);opacity:0}to{transform:none;opacity:1}}.modal-head{display:flex;align-items:center;padding:18px 22px;border-bottom:1px solid var(--line)}.modal-head h3{font-size:17px}.modal-body{padding:20px 22px;max-height:66vh;overflow-y:auto}.modal-foot{padding:16px 22px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end}.field{margin-bottom:14px}.field label{display:block;font-size:12px;color:var(--muted);font-weight:600;margin-bottom:6px}.input,select.input,textarea.input{width:100%;background:#f7f7fd;border:1px solid var(--line2);color:var(--ink);padding:10px 12px;border-radius:11px;font-size:13.5px;outline:none;transition:.14s}.input:focus{border-color:var(--violet);background:#fff;box-shadow:0 0 0 3px #6c5ce71a}textarea.input{resize:vertical;min-height:80px}.fld-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width:540px){.fld-row{grid-template-columns:1fr}}.search{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:9px 13px;min-width:200px;box-shadow:var(--shadow-sm)}.search input{background:transparent;border:none;outline:none;color:var(--ink);width:100%;font-size:13px}.bar{height:9px;background:#f0f1f8;border-radius:99px;overflow:hidden}.bar>i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,#8b7cf0,#6c5ce7);transition:width .5s cubic-bezier(.2,.7,.3,1)}.sticky-board{display:flex;flex-wrap:wrap;gap:16px}.sticky{width:210px;min-height:200px;border-radius:14px;padding:16px;color:#3a3a52;position:relative;box-shadow:var(--shadow);transition:.2s;font-weight:500}.sticky:hover{transform:translateY(-4px) rotate(-1deg);box-shadow:var(--shadow-lg)}.sticky.yellow{background:#fdf3cf}.sticky.green{background:#d6f5e3}.sticky.blue{background:#dcebff}.sticky.pink{background:#ffe0ec}.sticky.purple{background:#e8e3ff}.sticky.orange{background:#ffe6d6}.sticky .x{position:absolute;top:8px;right:8px;opacity:.4;cursor:pointer}.sticky .x:hover{opacity:1}.sticky textarea{width:100%;background:transparent;border:none;outline:none;resize:none;font-family:var(--sans);font-size:14px;color:#3a3a52;min-height:120px;font-weight:500}.gal{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px}.gal .ph{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--card);position:relative;box-shadow:var(--shadow);transition:.2s}.gal .ph:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.gal .ph img{width:100%;height:150px;object-fit:cover;display:block}.gal .ph .cap{padding:9px 11px}.gal .ph .cap b{font-size:13px}.gal .ph .cap .tg{font-size:11px;color:var(--faint);margin-top:2px}.journey{position:relative;padding-left:8px}.journey:before{content:"";position:absolute;left:21px;top:8px;bottom:8px;width:2px;background:linear-gradient(var(--violet),var(--teal))}.mile{display:flex;gap:18px;margin-bottom:8px;position:relative}.mile .dot{flex:0 0 28px;height:28px;border-radius:50%;background:#fff;border:2px solid var(--violet);display:grid;place-items:center;z-index:2;margin-top:14px;box-shadow:var(--shadow-sm)}.mile .body{flex:1;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:14px 16px;margin-bottom:10px;box-shadow:var(--shadow);transition:.2s}.mile .body:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.chk-item{display:flex;align-items:center;gap:10px;padding:8px 4px;border-bottom:1px solid var(--line)}.chk-item:last-child{border:none}.chk-box{width:20px;height:20px;border-radius:6px;border:2px solid var(--line2);display:grid;place-items:center;flex:0 0 20px;cursor:pointer;transition:.14s}.chk-box.on{background:var(--green);border-color:var(--green);color:#fff}.chk-item.done span{text-decoration:line-through;color:var(--faint)}.tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px}.tab{padding:8px 15px;border-radius:11px;background:var(--card);border:1px solid var(--line);color:var(--muted);font-weight:600;font-size:13px;box-shadow:var(--shadow-sm);transition:.14s}.tab:hover{color:var(--violet)}.tab.active{background:linear-gradient(135deg,#7b6cf0,#6c5ce7);color:#fff;border-color:transparent;box-shadow:0 6px 16px #6c5ce74d}.muted{color:var(--muted)}.faint{color:var(--faint)}.row{display:flex;align-items:center;gap:10px}.wrap{flex-wrap:wrap}.right{margin-left:auto}.mb{margin-bottom:16px}.scrim{display:none}@media (max-width:900px){.sidebar{position:fixed;left:0;top:0;transform:translate(-100%);transition:.22s;box-shadow:var(--shadow-lg)}.sidebar.open{transform:none}.scrim.show{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#191a2e66;z-index:35}.menu-btn{display:grid}.content{padding:18px 14px 50px}}
