*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--c1:#ff6b6b;--c2:#4ecdc4;--c3:#ffe66d;--c4:#a8e6cf;--c5:#ff8b94;--c6:#6c63ff;--c7:#ffa552;--c8:#c9f0ff;--bg:#f7f5ff;--surface:#fff;--border:#e8e4ff;--text:#2d2b55;--muted:#8b89a8;--sidebar:#2d2b55;--font-main:"Nunito", sans-serif;--font-display:"Fredoka One", cursive}body{font-family:var(--font-main);background:var(--bg);color:var(--text);min-height:100vh}.app-shell{min-height:100vh;display:flex}.main-content{flex:1;padding:28px 32px;overflow-y:auto}.sidebar{background:var(--sidebar);flex-direction:column;flex-shrink:0;width:220px;min-height:100vh;display:flex}.sidebar-logo{padding:24px 20px 16px}.sidebar-brand{font-family:var(--font-display);color:#fff;font-size:20px;line-height:1.1}.sidebar-sub{color:#fff9;margin-top:2px;font-size:10px}.sidebar-role{background:#ffffff1a;border-radius:8px;margin:0 14px 16px;padding:8px 10px}.sidebar-role-label{color:#fff9;font-size:10px}.sidebar-role-name{color:#fff;font-size:13px;font-weight:700}.sidebar-section{color:#ffffff80;letter-spacing:.08em;text-transform:uppercase;padding:12px 20px 4px;font-size:10px;font-weight:700}.sidebar nav a{color:#ffffffb3;border-left:3px solid #0000;align-items:center;gap:10px;padding:10px 20px;font-size:13px;font-weight:600;text-decoration:none;transition:all .15s;display:flex}.sidebar nav a:hover,.sidebar nav a.active{color:#fff;border-left-color:var(--c2);background:#ffffff1a}.sidebar-bottom{border-top:1px solid #ffffff1a;margin-top:auto;padding:16px 20px}.page-header{margin-bottom:28px}.page-header h1{font-family:var(--font-display);font-size:28px}.page-header p{color:var(--muted);margin-top:3px;font-size:14px}.page-header-row{justify-content:space-between;align-items:flex-start;margin-bottom:28px;display:flex}.card{background:var(--surface);border:1.5px solid var(--border);border-radius:16px;padding:20px 22px}.card+.card{margin-top:16px}.stats-row{gap:14px;margin-bottom:24px;display:grid}.stats-row-4{grid-template-columns:repeat(4,1fr)}.stats-row-3{grid-template-columns:repeat(3,1fr)}.stat-card{background:var(--surface);border:1.5px solid var(--border);border-radius:14px;padding:16px 18px}.stat-val{font-family:var(--font-display);font-size:30px}.stat-lbl{color:var(--muted);margin-top:3px;font-size:12px;font-weight:600}.btn{font-family:var(--font-main);cursor:pointer;border:none;border-radius:10px;align-items:center;gap:6px;padding:9px 18px;font-size:13px;font-weight:700;text-decoration:none;transition:all .15s;display:inline-flex}.btn-primary{background:var(--c6);color:#fff}.btn-primary:hover{background:#5a51e8}.btn-outline{border:1.5px solid var(--border);color:var(--text);background:0 0}.btn-outline:hover{background:var(--bg)}.btn-success{background:var(--c2);color:#fff}.btn-danger{background:var(--c1);color:#fff}.btn-warn{background:var(--c7);color:#fff}.btn-sm{border-radius:8px;padding:6px 13px;font-size:12px}.btn-full{justify-content:center;width:100%}.form-group{margin-bottom:16px}.form-label{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;font-size:12px;font-weight:700;display:block}.form-input,.form-select,.form-textarea{border:1.5px solid var(--border);width:100%;font-family:var(--font-main);color:var(--text);background:var(--surface);border-radius:10px;outline:none;padding:10px 14px;font-size:14px;transition:border-color .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--c6)}.form-textarea{resize:vertical;min-height:80px}.form-error{color:var(--c1);margin-top:4px;font-size:12px}.data-table{border-collapse:collapse;width:100%;font-size:13px}.data-table th{text-align:left;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1.5px solid var(--border);padding:10px 14px;font-size:11px;font-weight:700}.data-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:12px 14px}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--bg)}.progress-bar{background:#eee;border-radius:99px;height:6px;overflow:hidden}.progress-fill{border-radius:99px;height:100%;transition:width .3s}.tag{border-radius:99px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-block}.tag-blue{color:var(--c6);background:#e8e4ff}.tag-green{color:#0a6b5a;background:#d4f7f0}.tag-orange{color:#8a5500;background:#fff0d4}.tag-red{color:#8a0000;background:#ffe0e0}.tag-gray{color:#555;background:#f0eeee}.avatar-card{background:var(--surface);border:1.5px solid var(--border);text-align:center;cursor:pointer;border-radius:16px;padding:16px 12px;transition:all .2s;position:relative}.avatar-card:hover{border-color:var(--c6);transform:translateY(-2px);box-shadow:0 8px 24px #6c63ff1f}.avatar-emoji{margin-bottom:8px;font-size:44px;display:block}.avatar-name{font-size:12px;font-weight:700}.chat-wrap{flex-direction:column;height:380px;display:flex}.chat-messages{flex-direction:column;flex:1;gap:10px;padding:14px;display:flex;overflow-y:auto}.msg{max-width:75%}.msg-mine{align-self:flex-end}.msg-theirs{align-self:flex-start}.msg-bubble{border-radius:14px;padding:10px 14px;font-size:13px;line-height:1.5}.msg-mine .msg-bubble{background:var(--c6);color:#fff;border-bottom-right-radius:4px}.msg-theirs .msg-bubble{background:var(--surface);border:1.5px solid var(--border);border-bottom-left-radius:4px}.msg-meta{color:var(--muted);margin-top:3px;font-size:11px}.msg-mine .msg-meta{text-align:right}.chat-input{border-top:1.5px solid var(--border);gap:8px;padding:12px;display:flex}.chat-input input{flex:1}.code-box{text-align:center;background:linear-gradient(135deg,#e8e4ff,#d4f7f0);border-radius:16px;padding:20px}.code-label{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:11px;font-weight:700}.code-val{font-family:var(--font-display);color:var(--c6);letter-spacing:.12em;margin:6px 0;font-size:38px}.code-hint{color:var(--muted);font-size:12px}.approval-item{background:var(--surface);border:1.5px solid var(--border);border-radius:12px;align-items:center;gap:14px;margin-bottom:10px;padding:14px;display:flex}.flex-row{align-items:center;gap:12px;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.grid-2{grid-template-columns:1fr 1fr;gap:18px;display:grid}.grid-3{grid-template-columns:1fr 1fr 1fr;gap:14px;display:grid}.avatar-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:14px;display:grid}.divider{background:var(--border);height:1px;margin:16px 0}.text-muted{color:var(--muted)}.text-sm{font-size:13px}.fw7{font-weight:700}.mb2{margin-bottom:8px}.mb4{margin-bottom:16px}.notif-dot{background:var(--c1);vertical-align:middle;border-radius:50%;width:7px;height:7px;margin-left:6px;display:inline-block}.xp-bar-wrap{background:#eee;border-radius:99px;height:12px;overflow:hidden}.xp-bar-fill{background:linear-gradient(90deg, var(--c6), var(--c2));border-radius:99px;height:100%;transition:width .4s}.week-grid{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.week-day{text-align:center}.wd-label{color:var(--muted);margin-bottom:4px;font-size:10px;font-weight:700}.wd-dot{border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;margin:0 auto;font-size:12px;font-weight:700;display:flex}.wd-done{color:#0a6b5a;background:#d4f7f0}.wd-partial{color:#8a6d00;background:#fff5c0}.wd-miss{color:#8a0000;background:#ffe0e0}.wd-none{color:#aaa;background:#eee}.auth-wrap{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{background:var(--surface);border:1.5px solid var(--border);border-radius:24px;width:100%;max-width:420px;padding:36px 32px}.auth-logo{font-family:var(--font-display);color:var(--c6);text-align:center;margin-bottom:4px;font-size:32px}.auth-sub{text-align:center;color:var(--muted);margin-bottom:28px;font-size:14px}.report-bar-row{align-items:center;gap:12px;margin-bottom:10px;display:flex}.rb-label{flex-shrink:0;width:130px;font-size:12px;font-weight:700}.rb-bar{background:#eee;border-radius:99px;flex:1;height:10px;overflow:hidden}.rb-fill{border-radius:99px;height:100%}.rb-pct{color:var(--muted);text-align:right;width:36px;font-size:12px;font-weight:700}@media (max-width:768px){.sidebar{width:60px}.sidebar-brand,.sidebar-sub,.sidebar-role,.sidebar-section,.sidebar-bottom,.sidebar nav a span{display:none}.sidebar nav a{justify-content:center;padding:14px}.main-content{padding:16px}.stats-row-4{grid-template-columns:repeat(2,1fr)}.grid-2{grid-template-columns:1fr}}
