:root{--bg: #f5f7fa;--bg-elevated: #ffffff;--bg-card: #ffffff;--border: #e2e8f0;--border-subtle: #f1f5f9;--text: #1e293b;--text-muted: #64748b;--text-faint: #94a3b8;--accent: #0284c7;--accent-soft: #e0f2fe;--accent-hover: #0ea5e9;--accent-dark: #0c63a4;--info: #0284c7;--info-soft: #e0f2fe;--success: #059669;--success-soft: #d1fae5;--warning: #d97706;--warning-soft: #fef3c7;--danger: #dc2626;--danger-soft: #fee2e2;--brand-active: #7c3aed;--brand-skill: #f59e0b;--brand-team: #10b981;--brand-psych: #ec4899;--radius: 12px;--radius-sm: 8px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow: 0 2px 8px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .1);--font: "Noto Sans TC", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--transition: .2s ease;--sidebar-w: 240px;--topbar-h: 56px}*{box-sizing:border-box}body{margin:0;font-family:var(--font);background:var(--bg);color:var(--text);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased}.app{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--bg-elevated);border-right:1px solid var(--border);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform var(--transition)}.sidebar.collapsed{transform:translate(calc(-1 * var(--sidebar-w)));position:fixed;left:0;top:0;bottom:0;z-index:90;box-shadow:var(--shadow-md)}.sidebar-brand{padding:1.35rem 1.25rem 1rem;display:flex;align-items:center;gap:.65rem;border-bottom:1px solid var(--border-subtle)}.brand-icon{color:var(--accent);font-size:1.35rem;font-weight:700}.brand-text{font-weight:600;font-size:1rem;color:var(--text)}.sidebar-user{padding:1rem 1.25rem;display:flex;align-items:center;gap:.85rem;border-bottom:1px solid var(--border-subtle);background:var(--accent-soft)}.user-avatar{width:40px;height:40px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{font-weight:500;font-size:.95rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.8rem;color:var(--text-muted);margin-top:.2rem}.btn-collapse-sidebar{width:32px;height:32px;border-radius:6px;background:transparent;border:1px solid var(--border);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.85rem;transition:all .2s ease;flex-shrink:0}.btn-collapse-sidebar:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:scale(1.05)}.btn-collapse-sidebar:active{transform:scale(.95)}.collapse-icon{display:inline-block;transition:transform .2s ease}.sidebar-stats{padding:1rem 1.25rem;display:grid;grid-template-columns:1fr 1fr;gap:.75rem;border-bottom:1px solid var(--border-subtle)}.stat-item{padding:.6rem .8rem;background:var(--bg);border-radius:var(--radius-sm);text-align:center}.stat-label{font-size:.75rem;color:var(--text-muted);margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:1.3rem;font-weight:600;color:var(--accent)}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto}.nav-section-title{padding:.7rem 1.25rem;font-size:.8rem;text-transform:uppercase;color:var(--text-faint);letter-spacing:.5px;font-weight:600;margin-top:.5rem}.nav-section-title:first-child{margin-top:0}.nav-item{display:flex;align-items:center;gap:.7rem;padding:.7rem 1.25rem;color:var(--text-muted);text-decoration:none;transition:color var(--transition),background var(--transition);border-left:3px solid transparent;margin:0 .5rem;border-radius:0 var(--radius-sm) var(--radius-sm) 0}.nav-item:hover{color:var(--accent);background:var(--accent-soft)}.nav-item.active{color:var(--accent);background:var(--accent-soft);border-left-color:var(--accent);font-weight:500}.nav-icon{font-size:1.05rem;opacity:.85}.nav-label{font-size:.95rem}.sidebar-footer{padding:1rem 1.25rem;border-top:1px solid var(--border-subtle)}.footer-info{margin-bottom:.75rem}.footer-tag{font-size:.75rem;color:var(--text-faint);display:block;margin-bottom:.3rem}.footer-version{font-size:.8rem;color:var(--text-muted);font-weight:500}.btn-logout{width:100%;padding:.65rem .85rem;background:var(--danger-soft);color:var(--danger);border:1px solid var(--danger-soft);border-radius:var(--radius-sm);cursor:pointer;font-size:.9rem;font-weight:500;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all var(--transition);font-family:var(--font)}.btn-logout:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.main-wrap{flex:1;display:flex;flex-direction:column;min-width:0}.topbar{height:var(--topbar-h);min-height:var(--topbar-h);background:var(--bg-elevated);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:1rem;padding:0 1.5rem}.topbar-menu{background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;padding:.4rem;border-radius:var(--radius-sm);transition:color var(--transition),background var(--transition)}.topbar-menu:hover{color:var(--accent);background:var(--accent-soft)}.topbar-title{margin:0;font-size:1.1rem;font-weight:600;color:var(--text)}.topbar-meta{margin-left:auto;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.topbar-date{font-size:.9rem;color:var(--text-muted)}.topbar-filter{display:flex;align-items:center;gap:.5rem}.topbar-filter label{margin:0;font-size:.85rem;color:var(--text-muted);white-space:nowrap}.topbar-filter select{padding:.35rem .6rem;font-size:.9rem;min-width:120px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--text)}.content{flex:1;padding:1rem 1.25rem;overflow-y:auto}.page{display:none;animation:pageIn .25s ease}.page.active{display:block}@keyframes pageIn{0%{opacity:0}to{opacity:1}}.page-inner{max-width:1200px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1rem;overflow:hidden;box-shadow:var(--shadow);transition:all var(--transition);border-left:4px solid var(--accent)}.card:hover{box-shadow:var(--shadow-md);border-color:#cbd5e1;transform:translateY(-1px)}.card.card-engagement{border-left-color:var(--brand-active)}.card.card-skills{border-left-color:var(--brand-skill)}.card.card-team{border-left-color:var(--brand-team)}.card.card-psych{border-left-color:var(--brand-psych)}.card-title{margin:0;padding:.85rem 1rem;font-size:.95rem;font-weight:600;border-bottom:1px solid var(--border-subtle);color:var(--text);background:linear-gradient(180deg,#fafbfc 0%,var(--bg-card) 100%);display:flex;align-items:center;gap:.5rem}.card-title:before{content:"";width:3px;height:18px;background:linear-gradient(180deg,var(--accent),var(--accent-hover));border-radius:2px}.card-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.6rem}.card-head .card-title{border-bottom:none;background:none}.card-body{padding:1rem}.card-body-table{padding:0}.card-actions .card-body{border-top:1px solid var(--border-subtle)}.filter-row{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1rem;padding:.75rem 1.25rem;border-bottom:1px solid var(--border-subtle);background:#fafbfc}.filter-row .field-inline{display:flex;align-items:center;gap:.4rem}.filter-row .field-inline label{margin:0;font-size:.85rem;color:var(--text-muted)}.filter-row select,.filter-row input[type=date]{padding:.4rem .65rem;font-size:.9rem;min-width:110px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card)}.form-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem}.field{margin-bottom:.8rem}.field:last-child{margin-bottom:0}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin-bottom:.8rem}.field-inline{display:flex;align-items:center;gap:.5rem}.field-inline label{margin:0;white-space:nowrap}label{display:block;font-size:.88rem;font-weight:500;color:var(--text-muted);margin-bottom:.4rem}.required{color:var(--danger)}.range-val{color:var(--accent);font-weight:600}input[type=text],input[type=number],input[type=date],textarea,select{width:100%;padding:.5rem .7rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font:inherit;font-size:.9rem;transition:border-color var(--transition),box-shadow var(--transition)}select{cursor:pointer;min-width:120px}input:hover,textarea:hover,select:hover{border-color:#cbd5e1}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}textarea{resize:vertical;min-height:3.5rem}.slider-row{display:flex;flex-direction:column;gap:.35rem}input[type=range]{width:100%;height:6px;-webkit-appearance:none;appearance:none;background:var(--border);border-radius:3px}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;box-shadow:var(--shadow-sm);transition:transform var(--transition),box-shadow var(--transition)}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 2px 6px #0284c759}input[type=range]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;border:none;box-shadow:var(--shadow-sm)}.quick-btns{display:flex;flex-wrap:wrap;gap:.35rem}.quick-btns button{padding:.3rem .55rem;font-size:.82rem;border:1px solid var(--border);background:var(--bg-card);color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);box-shadow:var(--shadow-sm)}.quick-btns button:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.quick-btns button.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 6px #0284c74d}.option-btns{display:flex;flex-wrap:wrap;gap:.4rem}.option-btns button{padding:.45rem .85rem;font-size:.88rem;border:1px solid var(--border);background:var(--bg-card);color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);box-shadow:var(--shadow-sm)}.option-btns button:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.option-btns button.selected{background:var(--accent-soft);border-color:var(--accent);color:var(--accent);font-weight:500;box-shadow:0 1px 3px #0284c726}.tricks-list{margin-bottom:.5rem}.trick-tag{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .6rem;background:var(--accent-soft);border:1px solid rgba(2,132,199,.2);border-radius:var(--radius-sm);font-size:.88rem;margin:.25rem .25rem 0 0;box-shadow:var(--shadow-sm)}.trick-tag .name{color:var(--accent);font-weight:500}.trick-tag .detail{color:var(--text-muted);font-size:.82rem}.trick-level-select{display:flex;align-items:center}.trick-level-select select{padding:.2rem .4rem;font-size:.75rem;border:1px solid rgba(2,132,199,.3);border-radius:4px;background:#fff;cursor:pointer;color:var(--text)}.trick-level-select select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #0284c71a}.trick-tag button{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:0 .2rem;font-size:1rem;line-height:1;transition:color var(--transition)}.trick-tag button:hover{color:var(--danger)}.trick-item.add-trick{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.5rem}.trick-item.add-trick input:first-of-type{flex:1;min-width:120px}.trick-item.add-trick input:last-of-type{flex:1;min-width:130px}.btn-add{padding:.45rem .8rem;font-size:.88rem;border:1px dashed var(--accent);background:transparent;color:var(--accent);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition)}.btn-add:hover{background:var(--accent-soft)}.delete-session-btn{background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;padding:.2rem .4rem;transition:color var(--transition);margin-left:auto}.delete-session-btn:hover{color:var(--danger)}.btn{padding:.55rem 1.1rem;font-size:.92rem;font-family:inherit;font-weight:500;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);box-shadow:var(--shadow-sm);display:inline-flex;align-items:center;gap:.4rem}.btn:active{transform:scale(.98)}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;font-weight:600}.btn-primary:hover{background:linear-gradient(135deg,var(--accent-hover),var(--accent-dark));transform:translateY(-2px);box-shadow:0 4px 12px #0284c759}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary{background:linear-gradient(135deg,var(--brand-skill),#f87171);color:#fff}.btn-secondary:hover{box-shadow:0 4px 12px #f59e0b4d;transform:translateY(-2px)}.btn-ghost{background:var(--bg-card);color:var(--text-muted);border:1px solid var(--border)}.btn-ghost:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}.btn-danger-ghost{background:var(--bg-card);color:var(--danger);border:1px solid var(--danger)}.btn-danger-ghost:hover{background:var(--danger-soft);transform:translateY(-2px)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#047857;box-shadow:0 4px 12px #0596694d;transform:translateY(-2px)}.btn-sm{padding:.4rem .7rem;font-size:.82rem}.btn-group{display:inline-flex;gap:.5rem;align-items:center}.flex-row{display:flex;flex-wrap:wrap;align-items:center}.gap-m{gap:.75rem}.gap-l{gap:1rem}.search-box{position:relative;max-width:360px}.search-box input{padding-left:2.5rem;border:1px solid var(--border);width:100%}.search-box:before{content:"🔍";position:absolute;left:.8rem;top:50%;transform:translateY(-50%);font-size:.95rem;opacity:.6}.overview-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.quick-class-wrap{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.quick-class-wrap label{margin:0}.quick-class-wrap input{flex:1;min-width:100px}.quick-class-wrap select{width:auto;max-width:160px}@media (max-width: 900px){.overview-grid,.form-grid-3,.field-row{grid-template-columns:1fr}}.students-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}@media (max-width: 700px){.students-grid{grid-template-columns:1fr}}.by-class-list,.recent-list{list-style:none;margin:0;padding:0}.by-class-list li,.recent-list li{padding:.65rem .85rem;border-radius:var(--radius-sm);margin-bottom:.4rem;font-size:.92rem;cursor:pointer;border:1px solid var(--border-subtle);transition:all var(--transition);background:var(--bg-card);box-shadow:var(--shadow-sm)}.by-class-list li:hover,.recent-list li:hover{background:var(--accent-soft);border-color:#0284c740;box-shadow:0 2px 6px #0284c71f}.by-class-list .count,.recent-list .meta{color:var(--text-muted);font-size:.86em}.recent-list .meta{display:block;margin-top:.15rem}.by-class-list .empty,.recent-list .empty{color:var(--text-faint);font-style:italic;padding:.85rem;cursor:default}.table-wrap{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:.9rem}.data-table th,.data-table td{padding:.7rem 1rem;text-align:left;border-bottom:1px solid var(--border-subtle)}.data-table th{font-weight:600;color:var(--text-muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;background:#fafbfc}.data-table tbody tr{transition:background var(--transition)}.data-table tbody tr:hover{background:var(--accent-soft)}.empty-hint{color:var(--text-faint);font-style:italic;padding:1.5rem;text-align:center}.stats-strip{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem 1.5rem;padding:.9rem 1rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1.25rem;font-size:.92rem;color:var(--text-muted)}.stats-strip span{display:inline-flex;align-items:center;gap:.35rem}.stats-strip strong{color:var(--accent);font-weight:600;font-size:1rem}.stats-strip .sep{color:var(--border);font-weight:300}.chart-bars{padding:.6rem 0}.chart-row{display:flex;align-items:center;gap:.85rem;margin-bottom:.85rem}.chart-label{min-width:110px;font-size:.9rem;color:var(--text-muted)}.chart-bar-wrap{flex:1;height:10px;background:var(--border-subtle);border-radius:5px;overflow:hidden}.chart-bar{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-hover));border-radius:5px;transition:width .5s ease;box-shadow:0 1px 3px #0284c740}.chart-val{font-size:.9rem;font-weight:600;color:var(--text-muted);min-width:2rem}.modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:1.5rem}.modal[hidden]{display:none}.modal-backdrop{position:absolute;inset:0;background:#0006;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-dialog{position:relative;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);max-width:480px;width:100%;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-md);animation:modalIn .25s ease}@keyframes modalIn{0%{opacity:0;transform:scale(.98) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border-subtle);background:#fafbfc}.modal-header h3{margin:0;font-size:1rem;font-weight:600}.modal-close{background:none;border:none;color:var(--text-muted);font-size:1.35rem;cursor:pointer;padding:.25rem;line-height:1;border-radius:var(--radius-sm);transition:color var(--transition),background var(--transition)}.modal-close:hover{color:var(--text);background:var(--border-subtle)}.modal-body{padding:1.25rem;overflow-y:auto;font-size:.9rem}.modal-body dl{margin:0}.modal-body dt{font-weight:600;color:var(--text-muted);margin-top:.75rem;font-size:.8rem}.modal-body dt:first-child{margin-top:0}.modal-body dd{margin:.2rem 0 0}.modal-body .class-session-list{list-style:none;margin:0;padding:0}.modal-body .class-session-item{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;padding:.65rem .85rem;border-radius:var(--radius-sm);margin-bottom:.4rem;font-size:.9rem;cursor:pointer;border:1px solid var(--border-subtle);transition:all var(--transition);background:var(--bg-card);box-shadow:var(--shadow-sm)}.modal-body .class-session-item:hover{background:var(--accent-soft);border-color:#0284c740}.modal-body .class-session-item .date{font-weight:500}.modal-body .class-session-item .meta{color:var(--text-muted);font-size:.9em}.modal-body .class-session-item .hint{color:var(--accent);font-size:.8em;margin-right:.5rem}.modal-body .empty{color:var(--text-faint);font-style:italic}.toast{position:fixed;bottom:1.5rem;right:1.5rem;padding:.75rem 1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);font-size:.9rem;box-shadow:var(--shadow-md);z-index:200;animation:toastIn .3s ease}.toast[hidden]{display:none}@keyframes toastIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.sidebar:not(.collapsed){position:fixed;left:0;top:0;bottom:0;z-index:90}.sidebar.collapsed{transform:translate(calc(-1 * var(--sidebar-w)))}}.validation-badge{display:inline-flex;align-items:center;gap:.3rem;font-size:.8rem;padding:.25rem .6rem;border-radius:4px;font-weight:500}.validation-badge.warning{background:var(--warning-soft);color:var(--warning)}.validation-badge.danger{background:var(--danger-soft);color:var(--danger)}.validation-badge.success{background:var(--success-soft);color:var(--success)}.alert{padding:.85rem 1rem;border-radius:var(--radius-sm);margin-bottom:1rem;display:flex;align-items:flex-start;gap:.75rem;border-left:4px solid;box-shadow:var(--shadow-sm)}.alert-warning{background:var(--warning-soft);border-left-color:var(--warning);color:#92400e}.alert-danger{background:var(--danger-soft);border-left-color:var(--danger);color:#7f1d1d}.alert-success{background:var(--success-soft);border-left-color:var(--success);color:#065f46}.alert-info{background:var(--info-soft);border-left-color:var(--info);color:#0c2340}.alert-icon{font-size:1.1rem;flex-shrink:0}.alert-content{flex:1}.alert-close{background:none;border:none;cursor:pointer;color:inherit;opacity:.6;transition:opacity var(--transition);padding:0;font-size:1.3rem;line-height:1}.alert-close:hover{opacity:1}.sort-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;padding:1rem;background:#fafbfc;border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:1rem}.sort-toolbar label{margin:0;font-size:.9rem;color:var(--text-muted);font-weight:500}.sort-toolbar select{padding:.4rem .65rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);min-width:140px}.sort-icon{font-size:1.1rem;opacity:.6}.class-presets{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem;padding:.5rem;background:#fafbfc;border-radius:var(--radius-sm);border:1px dashed var(--border)}.class-preset-btn{padding:.35rem .7rem;font-size:.85rem;border:1px solid var(--accent);background:var(--accent-soft);color:var(--accent);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);font-weight:500}.class-preset-btn:hover{background:var(--accent);color:#fff;box-shadow:0 2px 6px #0284c74d}.class-preset-btn.add{border-style:dashed;background:transparent;color:var(--text-muted);border-color:var(--border)}.class-preset-btn.add:hover{background:transparent;color:var(--accent);border-color:var(--accent)}.duplicate-indicator{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .6rem;background:var(--info-soft);border:1px solid rgba(2,132,199,.2);border-radius:var(--radius-sm);font-size:.82rem;color:var(--info);font-weight:500}.duplicate-indicator:before{content:"⚡"}.time-inputs{display:flex;align-items:flex-end;gap:.5rem;margin-top:.5rem}.time-inputs .field{flex:1;margin-bottom:0}.time-inputs .time-sep{padding:0 .5rem;color:var(--text-muted);font-weight:500}.time-inputs .time-result{padding:.55rem .8rem;background:var(--info-soft);border:1px solid rgba(2,132,199,.2);border-radius:var(--radius-sm);color:var(--info);font-weight:600;font-size:.92rem;white-space:nowrap}.stats-card{background:linear-gradient(135deg,#f8fafc,#f1f5f9);padding:1rem;border-radius:var(--radius);border:1px solid var(--border);text-align:center;box-shadow:var(--shadow);transition:all var(--transition)}.stats-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stats-card .stat-label{font-size:.85rem;color:var(--text-muted);margin-bottom:.5rem;font-weight:500}.stats-card .stat-value{font-size:2rem;font-weight:700;color:var(--accent);margin-bottom:.25rem}.stats-card .stat-unit{font-size:.8rem;color:var(--text-faint)}.progress-bar{height:8px;background:var(--border);border-radius:4px;overflow:hidden;margin:.5rem 0}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--success),var(--info));border-radius:4px;transition:width .5s ease}.progress-label{display:flex;justify-content:space-between;font-size:.85rem;color:var(--text-muted);margin-bottom:.4rem}.progress-label .progress-val{font-weight:600;color:var(--accent)}.time-duration-display{margin-top:.5rem;padding:.5rem .8rem;background:#e0f2fe;border-radius:6px;color:#0284c7;font-weight:500;font-size:.9rem;border-left:3px solid #0284c7}@media (max-width: 768px){.topbar-menu{width:44px;height:44px;display:flex;align-items:center;justify-content:center}.quick-btns button{min-width:44px;min-height:44px;padding:.5rem .75rem}.modal-close{width:44px;height:44px;display:flex;align-items:center;justify-content:center}.btn{min-height:44px;padding:.65rem 1rem}}.simple-table{width:100%;border-collapse:collapse;font-size:.95rem}.simple-table thead{background:var(--bg);border-bottom:2px solid var(--border)}.simple-table th{padding:.75rem;text-align:left;font-weight:600;color:var(--text)}.simple-table td{padding:.65rem .75rem;border-bottom:1px solid var(--border-subtle);color:var(--text)}.simple-table tbody tr:hover{background:var(--accent-soft)}.simple-table .text-right{text-align:right}.users-list{display:flex;flex-direction:column;gap:.75rem}.user-item{padding:.85rem 1rem;background:var(--bg);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.6rem}.user-item-info{display:flex;flex-direction:column;gap:.2rem}.user-name{font-weight:600;color:var(--text);font-size:.95rem}.user-email{font-size:.85rem;color:var(--text-muted)}.user-role{font-size:.8rem;padding:.25rem .6rem;border-radius:4px;font-weight:500}.user-role.creator{background:#fef3c7;color:#92400e}.user-role.user{background:#e0f2fe;color:#0c63a4}.user-created{font-size:.8rem;color:var(--text-faint)}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.stat-card{padding:1rem;background:linear-gradient(135deg,var(--accent-soft) 0%,#f0f9ff 100%);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);text-align:center}.stat-label{font-size:.85rem;color:var(--text-muted);margin-bottom:.5rem;display:block}.stat-number{font-size:2rem;font-weight:700;color:var(--accent)}@media (max-width: 768px){.stats-grid{grid-template-columns:1fr}.user-item{flex-direction:column;align-items:flex-start}}.sync-indicator{position:fixed;top:10px;right:10px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:8px 16px;border-radius:8px;font-size:.85rem;font-weight:500;z-index:9999;display:none;align-items:center;gap:8px;box-shadow:0 4px 12px #10b9814d;animation:slideIn .3s ease-out;transition:all .3s ease}.sync-indicator.active{display:flex}.sync-indicator:hover{transform:translateY(-2px);box-shadow:0 6px 16px #10b98166}.sync-indicator .sync-icon{font-size:1.1rem;animation:pulse 2s ease-in-out infinite}.sync-indicator .sync-text{line-height:1}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes slideIn{0%{transform:translate(120%);opacity:0}to{transform:translate(0);opacity:1}}.toast{position:fixed;bottom:24px;right:24px;padding:12px 20px;border-radius:8px;font-size:.9rem;font-weight:500;z-index:10000;box-shadow:0 8px 16px #00000026;animation:toastSlideIn .3s ease-out;max-width:400px;backdrop-filter:blur(10px);transition:all .3s ease}.toast:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0003}.toast-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-left:4px solid #047857}.toast-info{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border-left:4px solid #1d4ed8}.toast-error{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border-left:4px solid #b91c1c}.toast-warning{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border-left:4px solid #b45309}@keyframes toastSlideIn{0%{transform:translateY(100px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 768px){.sync-indicator{top:8px;right:8px;padding:6px 12px;font-size:.8rem}.toast{bottom:16px;right:16px;left:16px;max-width:calc(100% - 32px);font-size:.85rem}}@media (max-width: 480px){.sync-indicator{padding:6px 10px;font-size:.75rem}.sync-indicator .sync-icon{font-size:1rem}.toast{bottom:12px;right:12px;left:12px;max-width:calc(100% - 24px);padding:10px 16px;font-size:.8rem}}@media (prefers-color-scheme: dark){.sync-indicator{box-shadow:0 4px 12px #10b98180}.toast{box-shadow:0 8px 16px #0000004d}}@media (prefers-reduced-motion: reduce){.sync-indicator,.toast,.sync-indicator .sync-icon{animation:none}.sync-indicator:hover,.toast:hover{transform:none}}
