@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{font-synthesis:none;text-rendering:optimizelegibility}.login-container{background:#f8f9ff;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;display:flex}.login-panel-form{background:#fff;border-left:1px solid #e2e8f0;flex:0 0 480px;justify-content:center;align-items:center;padding:3rem;display:flex}.login-form{width:100%;max-width:380px}.login-brand{align-items:center;gap:12px;margin-bottom:6px;display:flex}.login-logo{align-items:center;display:flex}.login-title{color:#0058be;letter-spacing:-.02em;margin:0;font-size:28px;font-weight:700}.login-subtitle{color:#64748b;margin:0 0 32px;font-size:15px}.login-field{margin-bottom:20px}.login-field label{color:#1e293b;letter-spacing:.01em;margin-bottom:6px;font-size:13px;font-weight:600;display:block}.field-icon{margin-right:4px}.field-header{justify-content:space-between;align-items:center;display:flex}.forgot-link{color:#3b82f6;cursor:pointer;background:0 0;border:none;padding:0;font-size:12px;font-weight:500}.forgot-link:hover{text-decoration:underline}.login-field input{color:#1e293b;box-sizing:border-box;background:#fff;border:1px solid #cbd5e1;border-radius:8px;width:100%;padding:12px 14px;font-family:Inter,sans-serif;font-size:14px;transition:border-color .2s,box-shadow .2s}.login-field input::placeholder{color:#94a3b8}.login-field input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f626}.password-wrapper{position:relative}.password-wrapper input{padding-right:44px}.toggle-password{cursor:pointer;background:0 0;border:none;padding:0;font-size:16px;line-height:1;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.login-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;align-items:center;gap:8px;margin-bottom:16px;padding:10px 14px;font-size:13px;font-weight:500;display:flex}.login-btn{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:10px;width:100%;margin-top:8px;padding:14px;font-family:Inter,sans-serif;font-size:15px;font-weight:600;transition:background .2s,transform .1s}.login-btn:hover:not(:disabled){background:#2563eb;transform:translateY(-1px)}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.btn-arrow{margin-left:6px;transition:transform .2s;display:inline-block}.login-btn:hover .btn-arrow{transform:translate(4px)}.btn-loading{justify-content:center;align-items:center;gap:8px;display:flex}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-panel-hero{background:linear-gradient(135deg,#f0f5ff 0%,#e8f0fe 50%,#f8f9ff 100%);flex-direction:column;flex:1;justify-content:center;align-items:center;padding:4rem;display:flex;position:relative;overflow:hidden}.login-panel-hero:before{content:"";background:radial-gradient(circle,#3b82f614 0%,#0000 70%);border-radius:50%;width:400px;height:400px;position:absolute;top:-120px;right:-120px}.hero-content{text-align:center;z-index:1;max-width:520px;position:relative}.hero-badge{letter-spacing:.08em;color:#1e293b;background:#fff;border:1px solid #e2e8f0;border-radius:20px;margin-bottom:28px;padding:6px 16px;font-size:11px;font-weight:700;display:inline-block}.hero-quote{color:#0f172a;letter-spacing:-.02em;border:none;margin:0 0 24px;padding:0;font-size:28px;font-weight:700;line-height:1.35}.hero-divider{background:#3b82f6;border-radius:2px;width:60px;height:3px;margin:0 auto 24px}.hero-description{color:#64748b;margin:0;font-size:15px;font-style:italic;line-height:1.6}.hero-footer{z-index:1;gap:32px;margin-top:48px;display:flex;position:relative}.hero-stat{color:#475569;align-items:center;gap:6px;font-size:13px;font-weight:500;display:flex}.stat-icon{font-size:14px}@media (width<=900px){.login-container{flex-direction:column}.login-panel-form{border-bottom:1px solid #e2e8f0;border-right:none;flex:none;padding:2rem}.login-panel-hero{min-height:250px;padding:2rem}.hero-quote{font-size:22px}.hero-footer{flex-wrap:wrap;justify-content:center;gap:16px}}.layout{background:#f8fafc;height:100vh;display:flex;overflow:hidden}.sidebar{background:#fff;border-right:1px solid #e2e8f0;flex-direction:column;flex-shrink:0;width:220px;padding:20px 0;display:flex}.sidebar-brand{border-bottom:1px solid #f1f5f9;align-items:center;gap:10px;margin-bottom:8px;padding:0 20px 20px;display:flex}.brand-text{flex-direction:column;display:flex}.brand-name{color:#1e40af;letter-spacing:-.02em;font-size:17px;font-weight:700}.brand-sub{color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-weight:600}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:8px 12px;display:flex}.nav-item{color:#64748b;cursor:pointer;font-size:14px;font-weight:500;font-family:var(--font-sans);text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;width:100%;padding:10px 12px;transition:all .15s;display:flex}.nav-item:hover{color:#1e293b;background:#f1f5f9}.nav-item.active{color:#2563eb;background:#eff6ff;font-weight:600}.nav-icon{text-align:center;width:20px;font-size:16px}.sidebar-actions{flex-direction:column;gap:8px;padding:12px 14px;display:flex}.btn-nueva-tarea{color:#fff;cursor:pointer;width:100%;font-size:14px;font-weight:600;font-family:var(--font-sans);background:#3b82f6;border:none;border-radius:10px;padding:12px;transition:background .15s}.btn-nueva-tarea:hover{background:#2563eb}.btn-ai-summary{color:#fff;cursor:pointer;width:100%;font-size:13px;font-weight:600;font-family:var(--font-sans);background:linear-gradient(135deg,#1e40af,#3b82f6);border:none;border-radius:10px;padding:10px}.btn-ai-summary:hover{opacity:.9}.sidebar-bottom-links{flex-direction:column;gap:2px;padding:4px 14px;display:flex}.nav-item-small{color:#94a3b8;cursor:pointer;font-size:12px;font-family:var(--font-sans);text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;width:100%;padding:6px 10px;display:flex}.nav-item-small:hover{color:#64748b;background:#f8fafc}.sidebar-footer{border-top:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:12px 14px 0;display:flex}.user-info{align-items:center;gap:10px;display:flex}.user-avatar{color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:700;display:flex}.user-details{flex-direction:column;display:flex}.user-name{color:#1e293b;font-size:12px;font-weight:600}.user-role{color:#94a3b8;font-size:10px}.btn-logout{cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px;font-size:14px;transition:background .15s}.btn-logout:hover{background:#fef2f2}.main-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.topbar{background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;padding:10px 24px;display:flex}.topbar-left{flex:1;align-items:center;gap:16px;display:flex}.topbar-tabs{gap:4px;display:flex}.topbar-tab{color:#94a3b8;cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-sans);background:0 0;border:none;border-bottom:2px solid #0000;padding:6px 14px;transition:all .15s}.topbar-tab:hover{color:#475569}.topbar-tab.active{color:#2563eb;border-bottom-color:#2563eb}.topbar-search{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;flex:1;align-items:center;gap:8px;max-width:360px;padding:6px 12px;display:flex}.search-icon{color:#94a3b8;font-size:14px}.search-input{color:#1e293b;font-size:13px;font-family:var(--font-sans);background:0 0;border:none;outline:none;flex:1}.topbar-right{align-items:center;gap:12px;display:flex}.btn-timer-topbar{color:#fff;cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-sans);white-space:nowrap;background:#3b82f6;border:none;border-radius:8px;padding:8px 16px}.btn-timer-topbar:hover{background:#2563eb}.topbar-empresa{color:#3b82f6;background:#eff6ff;border-radius:14px;padding:4px 10px;font-size:12px;font-weight:600}.topbar-date{color:#64748b;text-transform:capitalize;white-space:nowrap;font-size:12px}.page-content{flex:1;padding:20px 24px;overflow-y:auto}.dashboard-stitch{flex-direction:column;gap:24px;padding-bottom:20px;display:flex}.dash-header-stitch{justify-content:space-between;align-items:flex-end;display:flex}.dash-title-wrap h1{color:#0f172a;margin:0 0 4px;font-size:24px;font-weight:700}.dash-title-wrap p{color:#475569;margin:0;font-size:14px}.dash-actions{gap:10px;display:flex}.dash-kpi-row{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.dash-kpi-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;padding:20px;display:flex;position:relative;overflow:hidden}.kpi-top{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.kpi-title{color:#64748b;letter-spacing:.05em;text-transform:uppercase;font-size:11px;font-weight:700}.kpi-badge{color:#0284c7;background:#e0f2fe;border-radius:12px;padding:2px 8px;font-size:11px;font-weight:700}.kpi-values-row{align-items:center;gap:24px;margin-bottom:16px;display:flex}.kpi-val-group{flex-direction:column;display:flex}.kpi-big{color:#0f172a;font-size:32px;font-weight:700;line-height:1}.kpi-sub{color:#64748b;margin-top:4px;font-size:12px}.kpi-val-divider{background:#e2e8f0;width:1px;height:30px}.kpi-bar{background:#f1f5f9;border-radius:3px;width:100%;height:6px;margin-top:auto;overflow:hidden}.kpi-bar-fill{background:#2563eb;border-radius:3px;height:100%}.center-content{text-align:center;justify-content:center;align-items:center}.circular-score{width:100px;height:100px;margin:16px 0;position:relative}.circular-chart{max-width:100%;max-height:250px;margin:0 auto;display:block}.circle-bg{fill:none;stroke:#f1f5f9;stroke-width:3.8px}.circle{fill:none;stroke-width:3.8px;stroke-linecap:round;stroke:#2563eb}.circle-text{flex-direction:column;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.c-num{color:#0f172a;font-size:28px;font-weight:700;line-height:1}.c-label{color:#64748b;text-transform:uppercase;font-size:10px;font-weight:700}.kpi-footer-text{color:#475569;margin-top:auto;font-size:13px}.sprint-title-big{color:#0f172a;margin:16px 0 auto;font-size:24px;font-weight:700}.sprint-progress-wrap{width:100%}.sprint-prog-header{color:#475569;justify-content:space-between;margin-bottom:8px;font-size:12px;font-weight:600;display:flex}.dash-main-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.dash-box{background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;padding:20px;display:flex}.icon-btn{cursor:pointer;color:#94a3b8;font-size:18px}.link-action{color:#2563eb;font-size:13px;font-weight:600;text-decoration:none}.donut-wrap{justify-content:center;margin:20px 0;display:flex}.donut-chart{background:conic-gradient(#1a73e8 0% 45%,#5f6368 45% 75%,#aecbfa 75% 100%);border-radius:50%;justify-content:center;align-items:center;width:160px;height:160px;display:flex}.donut-hole{background:#fff;border-radius:50%;justify-content:center;align-items:center;width:110px;height:110px;display:flex}.donut-hole span{color:#0f172a;font-size:14px;font-weight:700}.donut-legend{flex-direction:column;gap:12px;margin-top:auto;display:flex}.legend-item{align-items:center;gap:10px;display:flex}.l-dot{border-radius:50%;width:10px;height:10px}.l-label{color:#475569;flex:1;font-size:13px}.l-val{color:#0f172a;font-size:13px;font-weight:700}.priority-list{flex-direction:column;gap:12px;display:flex}.p-item{border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:12px;padding:12px;display:flex}.p-badge{border-radius:4px;padding:2px 6px;font-size:10px;font-weight:700}.p-badge.ALTA{color:#b91c1c;background:#fee2e2}.p-badge.MEDIA{color:#0369a1;background:#e0f2fe}.p-badge.BAJA{color:#475569;background:#f1f5f9}.p-info{flex-direction:column;flex:1;display:flex}.p-title{color:#0f172a;font-size:13px;font-weight:600}.p-meta{color:#64748b;margin-top:2px;font-size:11px}.p-actions{gap:8px;display:flex}.btn-play{cursor:pointer;color:#475569;background:0 0;border:1px solid #cbd5e1;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:10px;display:flex}.btn-dots{cursor:pointer;color:#94a3b8;background:0 0;border:none;font-size:16px}.dash-trend{min-height:200px}.trend-legend{color:#475569;align-items:center;gap:6px;font-size:12px;font-weight:600;display:flex}.trend-chart-placeholder{border-bottom:1px solid #e2e8f0;flex:1;justify-content:center;align-items:flex-end;margin-top:20px;padding-bottom:8px;display:flex}.trend-days{color:#94a3b8;justify-content:space-between;width:100%;font-size:11px;font-weight:600;display:flex}.projects-page{flex-direction:column;gap:24px;height:100%;padding-bottom:20px;display:flex;overflow-y:auto}.proj-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:flex-end;padding-bottom:12px;display:flex}.proj-header h1{color:#0f172a;margin:0 0 4px;font-size:24px;font-weight:700}.proj-header p{color:#475569;margin:0;font-size:14px}.btn-new-project{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:600}.proj-form-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px;box-shadow:0 4px 6px -1px #0000000d}.proj-form-card h3{color:#0f172a;margin:0 0 20px;font-size:18px;font-weight:700}.proj-form-layout{grid-template-columns:1fr 1fr;gap:32px;display:grid}.proj-form-col{flex-direction:column;gap:16px;display:flex}.proj-form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.proj-field{flex-direction:column;gap:6px;display:flex}.proj-field label{color:#475569;font-size:12px;font-weight:700}.proj-field input,.proj-field textarea{font-size:14px;font-family:var(--font-sans);color:#0f172a;background:#f8fafc;border:1px solid #cbd5e1;border-radius:6px;padding:10px 12px}.proj-field input:focus,.proj-field textarea:focus{background:#fff;border-color:#2563eb;outline:none}.proj-field textarea{resize:vertical;min-height:110px}.creatable-select{position:relative}.creatable-select input{box-sizing:border-box;width:100%}.creatable-dropdown{z-index:10;background:#fff;border:1px solid #cbd5e1;border-radius:6px;max-height:200px;margin-top:4px;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 10px 15px -3px #0000001a}.c-item{color:#334155;cursor:pointer;border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:10px 12px;font-size:13px;display:flex}.c-item-text{flex:1}.c-item-del{color:#cbd5e1;cursor:pointer;padding:0 4px;font-size:14px;font-weight:700}.c-item-del:hover{color:#ef4444}.c-item:hover{color:#2563eb;background:#f8fafc}.c-create{color:#10b981;font-weight:600;display:block}.c-create:hover{color:#059669;background:#f0fdf4}.c-item-empty{color:#94a3b8;padding:10px 12px;font-size:13px;font-style:italic}.color-picker{gap:8px;margin-top:4px;display:flex}.color-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;width:24px;height:24px;padding:0;transition:transform .1s}.color-swatch:hover{transform:scale(1.1)}.color-swatch.active{border-color:#0f172a;box-shadow:inset 0 0 0 2px #fff}.proj-form-footer{border-top:1px solid #e2e8f0;justify-content:flex-end;margin-top:24px;padding-top:20px;display:flex}.btn-create-project-lg{color:#fff;cursor:pointer;background:#0f172a;border:none;border-radius:8px;padding:12px 24px;font-size:14px;font-weight:600}.btn-create-project-lg:hover{background:#1e293b}.proj-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;display:grid}.proj-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;display:flex;overflow:hidden}.proj-card-bar{width:100%;height:6px}.proj-card-body{flex-direction:column;gap:16px;padding:20px;display:flex}.proj-card-top{justify-content:space-between;align-items:flex-start;display:flex}.pct-left h4{color:#0f172a;margin:0 0 4px;font-size:16px;font-weight:700}.proj-code{color:#64748b;background:#f1f5f9;border-radius:4px;padding:2px 6px;font-size:11px;font-weight:700}.proj-meta-tags{flex-wrap:wrap;gap:8px;display:flex}.meta-tag{color:#475569;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:4px 8px;font-size:11px;font-weight:600}.proj-desc-preview{color:#475569;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:13px;display:-webkit-box;overflow:hidden}.proj-stats{border-top:1px solid #f1f5f9;justify-content:space-between;padding-top:12px;display:flex}.proj-stat{flex-direction:column;gap:2px;display:flex}.stat-num{color:#0f172a;font-size:18px;font-weight:700;font-family:var(--font-mono)}.stat-label{color:#64748b;text-transform:uppercase;letter-spacing:.05em;font-size:11px}.proj-progress{align-items:center;gap:12px;margin-top:4px;display:flex}.proj-progress-bar{background:#f1f5f9;border-radius:3px;flex:1;height:6px}.proj-progress-fill{border-radius:3px;height:100%;transition:width .5s}.proj-progress-text{color:#475569;text-align:right;width:36px;font-size:12px;font-weight:700}.proj-loading{text-align:center;color:#64748b;padding:40px}.proj-empty{text-align:center;background:#fff;border:1px dashed #cbd5e1;border-radius:12px;padding:60px 20px}.proj-empty span{margin-bottom:16px;font-size:48px;display:block}.proj-empty h3{color:#0f172a;margin:0 0 8px;font-size:18px}.proj-empty p{color:#64748b;margin:0;font-size:14px}.kanban-page-stitch{flex-direction:column;gap:16px;height:100%;display:flex;overflow:hidden}.kb-stitch-header{border-bottom:1px solid #e2e8f0;flex-shrink:0;justify-content:space-between;align-items:flex-end;padding-bottom:12px;display:flex}.kb-stitch-title h1{color:#0f172a;margin:0 0 4px;font-size:24px;font-weight:700}.kb-stitch-title p{color:#475569;margin:0;font-size:14px}.kb-stitch-actions{align-items:center;gap:12px;display:flex}.view-toggle-kb{background:#f1f5f9;border-radius:8px;padding:4px;display:flex}.view-toggle-kb button{color:#64748b;cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-sans);background:0 0;border:none;border-radius:6px;padding:8px 16px;transition:all .15s}.view-toggle-kb button.active{color:#0f172a;background:#fff;box-shadow:0 1px 3px #0000001a}.kb-search-stitch{background:#fff;border:1px solid #cbd5e1;border-radius:8px;align-items:center;gap:8px;padding:6px 12px;display:flex}.kb-search-stitch input{color:#1e293b;width:160px;font-size:13px;font-family:var(--font-sans);border:none;outline:none}.kb-btn-outline{color:#334155;cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-sans);background:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:8px 16px}.kb-btn-outline:hover{background:#f8fafc}.kb-stitch-board{flex:1;gap:20px;padding-bottom:10px;display:flex;overflow:auto hidden}.kb-stitch-col{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;width:300px;min-width:300px;display:flex}.kb-col-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.col-h-left{align-items:center;gap:8px;display:flex}.col-dot{border-radius:50%;width:8px;height:8px}.col-name{color:#475569;letter-spacing:.05em;font-size:12px;font-weight:700}.col-badge{color:#475569;background:#e2e8f0;border-radius:12px;padding:2px 8px;font-size:11px;font-weight:700}.col-add-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;padding:0;font-size:20px;line-height:1}.col-add-btn:hover{color:#0f172a}.kb-col-body{flex-direction:column;flex:1;gap:12px;padding:12px;display:flex;overflow-y:auto}.kb-stitch-card{cursor:grab;background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:16px;transition:border-color .2s;box-shadow:0 1px 2px #0000000d}.kb-stitch-card:hover{border-color:#cbd5e1}.kb-stitch-card:active{cursor:grabbing}.card-top{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.card-priority{border-radius:4px;padding:2px 6px;font-size:10px;font-weight:700}.card-priority.p-alta{color:#b91c1c;background:#fee2e2}.card-priority.p-media{color:#0369a1;background:#e0f2fe}.card-priority.p-baja{color:#475569;background:#f1f5f9}.card-menu-btn{color:#cbd5e1;cursor:pointer;background:0 0;border:none;font-size:12px}.card-menu-btn:hover{color:#ef4444}.card-title{color:#0f172a;margin:0 0 4px;font-size:14px;font-weight:600;line-height:1.4}.card-project{color:#64748b;margin:0 0 12px;font-size:12px}.card-timer-active{background:#eff6ff;border-radius:6px;justify-content:space-between;align-items:center;margin-bottom:12px;padding:8px 12px;display:flex}.t-badge{color:#fff;background:#2563eb;border-radius:4px;padding:2px 6px;font-size:9px;font-weight:700}.t-time{color:#1e40af;font-size:12px;font-weight:700;font-family:var(--font-mono)}.card-footer{border-top:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding-top:12px;display:flex}.card-avatars{align-items:center;gap:8px;display:flex}.c-avatar{color:#fff;background:#334155;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:10px;font-weight:700;display:flex}.c-timer-btn{color:#0284c7;cursor:pointer;background:#e0f2fe;border-radius:4px;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;display:flex}.card-meta{color:#94a3b8;gap:10px;font-size:12px;font-weight:500;display:flex}.kb-stitch-add-card{background:#fff;border:1px dashed #cbd5e1;border-radius:10px;flex-direction:column;gap:8px;padding:12px;display:flex}.kb-stitch-add-card input{width:100%;font-size:13px;font-family:var(--font-sans);border:1px solid #e2e8f0;border-radius:6px;padding:8px}.kb-stitch-add-card input:focus{border-color:#3b82f6;outline:none}.add-actions{justify-content:space-between;align-items:center;display:flex}.add-actions select{font-size:12px;font-family:var(--font-sans);border:1px solid #e2e8f0;border-radius:4px;padding:4px}.add-btn-ok{color:#fff;cursor:pointer;font-size:12px;font-weight:600;font-family:var(--font-sans);background:#3b82f6;border:none;border-radius:4px;margin-right:4px;padding:4px 12px}.add-btn-cancel{color:#64748b;cursor:pointer;font-size:12px;font-weight:600;font-family:var(--font-sans);background:0 0;border:none}.roadmap-view{background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;flex:1;display:flex;overflow:hidden}.rm-header{background:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex}.rm-project-col{color:#64748b;text-transform:uppercase;letter-spacing:.05em;border-right:1px solid #e2e8f0;align-items:center;width:250px;min-width:250px;padding:16px;font-size:12px;font-weight:700;display:flex}.rm-days-grid{flex:1;grid-template-columns:repeat(14,1fr);display:grid}.rm-day-col{border-right:1px solid #f1f5f9;flex-direction:column;justify-content:center;align-items:center;padding:8px 0;display:flex}.rm-day-col:last-child{border-right:none}.rm-day-col.rm-today{background:#eff6ff}.rm-day-name{color:#94a3b8;text-transform:uppercase;font-size:10px;font-weight:700}.rm-day-num{color:#1e293b;margin-top:2px;font-size:16px;font-weight:600}.rm-day-col.rm-today .rm-day-num{color:#2563eb;font-weight:700}.rm-body{flex:1;overflow:hidden auto}.rm-row{border-bottom:1px solid #f1f5f9;min-height:80px;display:flex}.rm-row:hover{background:#f8fafc}.rm-project-info{background:#fff;border-right:1px solid #e2e8f0;flex-direction:column;justify-content:center;width:250px;min-width:250px;padding:16px;display:flex}.rm-p-code{color:#3b82f6;background:#eff6ff;border-radius:4px;align-self:flex-start;margin-bottom:6px;padding:2px 6px;font-size:10px;font-weight:700}.rm-p-name{color:#0f172a;margin-bottom:4px;font-size:14px;font-weight:600}.rm-p-count{color:#64748b;font-size:12px}.rm-timeline{flex:1;position:relative}.rm-grid-lines{pointer-events:none;grid-template-columns:repeat(14,1fr);display:grid;position:absolute;inset:0}.rm-grid-line{border-right:1px dashed #e2e8f0;height:100%}.rm-task-bars{padding:10px 0;position:absolute;inset:0}.rm-task-bar{cursor:pointer;white-space:nowrap;border-radius:6px;align-items:center;height:26px;padding:0 10px;transition:opacity .2s;display:flex;position:absolute;overflow:hidden;box-shadow:0 2px 4px #0000001a}.rm-task-bar:hover{opacity:.85;z-index:10}.rm-tb-title{color:#fff;text-overflow:ellipsis;font-size:11px;font-weight:600;overflow:hidden}.timetracking-stitch{flex-direction:column;gap:20px;height:100%;display:flex}.tt-header-stitch{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:flex-end;padding-bottom:12px;display:flex}.tt-title h1{color:#0f172a;margin:0;font-size:24px;font-weight:700}.tt-top-actions{align-items:center;gap:10px;display:flex}.tt-icon-btn{cursor:pointer;background:#fff;border:1px solid #cbd5e1;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;display:flex}.tt-icon-btn:hover{background:#f8fafc}.btn-outline:hover{background:#f8fafc}.btn-primary:hover{background:#1d4ed8}.tt-grid-stitch{flex:1;grid-template-columns:2fr 1fr;gap:20px;min-height:0;display:grid}.tt-card-stitch{background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;padding:20px;display:flex}.tt-left-panel{flex-direction:column;display:flex;overflow-y:auto}.active-session-card{border:2px solid #2563eb}.active-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.session-status{color:#2563eb;letter-spacing:.05em;font-size:11px;font-weight:700}.session-controls{gap:8px;display:flex}.btn-pause-stitch,.btn-stop-stitch{cursor:pointer;color:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;display:flex}.btn-pause-stitch{background:#f59e0b}.btn-stop-stitch{background:#ef4444}.btn-pause-stitch:disabled,.btn-stop-stitch:disabled{cursor:not-allowed;background:#cbd5e1}.timer-big{color:#0f172a;font-size:72px;font-weight:700;line-height:1;font-family:var(--font-mono);text-align:center;margin-bottom:24px}.timer-desc-input{width:100%;font-size:20px;font-family:var(--font-sans);color:#0f172a;border:none;border-bottom:2px solid #e2e8f0;margin-bottom:32px;padding:8px 0;font-weight:500}.timer-desc-input:focus{border-color:#2563eb;outline:none}.timer-progress-wrap{background:#f1f5f9;border-radius:3px;height:6px;margin-bottom:8px;overflow:hidden}.timer-prog-fill{background:#2563eb;height:100%;transition:width 1s linear}.timer-times{color:#64748b;justify-content:space-between;margin-bottom:32px;font-size:12px;font-weight:500;display:flex}.timer-fields-row{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px;display:grid}.field-group{flex-direction:column;gap:8px;display:flex}.field-group label{color:#64748b;letter-spacing:.05em;font-size:11px;font-weight:700}.field-group input,.field-group textarea{font-size:13px;font-family:var(--font-sans);color:#0f172a;background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;padding:10px 12px}.field-group input:focus,.field-group textarea:focus{background:#fff;border-color:#2563eb;outline:none}.field-group textarea{resize:vertical}.label-row{justify-content:space-between;align-items:center;display:flex}.auto-saving{color:#10b981;font-size:10px;font-weight:700}.technical-notes{margin-bottom:24px}.text-danger{color:#ef4444!important}.incident-row{gap:10px;display:flex}.incident-row input{flex:1}.btn-log{color:#b91c1c;cursor:pointer;background:#fee2e2;border:none;border-radius:8px;padding:0 16px;font-weight:600}.tt-right-panel{flex-direction:column;gap:20px;display:flex}.daily-log-card{flex-direction:column;flex:1;display:flex}.daily-log-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.daily-log-header h3{color:#0f172a;margin:0;font-size:16px;font-weight:700}.total-time{color:#2563eb;background:#eff6ff;border-radius:12px;padding:4px 10px;font-size:14px;font-weight:600}.daily-log-list{flex-direction:column;flex:1;gap:16px;margin-bottom:20px;display:flex;overflow-y:auto}.dl-item{border-bottom:1px solid #f1f5f9;flex-direction:column;padding-bottom:16px;display:flex}.dl-item:last-child{border-bottom:none}.dl-item-top{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.dl-time{color:#0f172a;font-size:18px;font-weight:700;font-family:var(--font-mono)}.dl-edit{cursor:pointer;opacity:.5;background:0 0;border:none;font-size:14px}.dl-edit:hover{opacity:1}.dl-title{color:#334155;margin-bottom:4px;font-size:14px;font-weight:600}.dl-desc{color:#64748b;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:12px;display:-webkit-box;overflow:hidden}.ai-summary-wrap{text-align:center;background:#f8fafc;border-radius:8px;padding:16px}.btn-ai-summary-big{color:#fff;cursor:pointer;width:100%;font-size:14px;font-weight:600;font-family:var(--font-sans);background:#8b5cf6;border:none;border-radius:8px;margin-bottom:8px;padding:12px}.btn-ai-summary-big:hover{background:#7c3aed}.ai-summary-wrap p{color:#64748b;margin:0;font-size:11px}.prod-score-card{color:#fff;background:#1e293b;border:none}.ps-header{align-items:center;gap:8px;margin-bottom:16px;display:flex}.ps-icon{color:#fff;background:#22c55e;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;display:flex}.ps-title{letter-spacing:.05em;color:#94a3b8;font-size:11px;font-weight:700}.ps-big{margin-bottom:12px;font-size:32px;font-weight:700;line-height:1;display:block}.ps-bar{background:#334155;border-radius:3px;height:6px}.ps-bar-fill{background:#22c55e;border-radius:3px;height:100%}.gcal{flex-direction:column;height:calc(100vh - 90px);display:flex}.gcal-header{justify-content:space-between;align-items:center;padding:0 0 12px;display:flex}.gcal-header-left{align-items:center;gap:10px;display:flex}.gcal-header-right{align-items:center;display:flex}.gcal-icon{font-size:20px}.gcal-title{color:#1e293b;margin-right:12px;font-size:18px;font-weight:700}.gcal-btn-today{color:#3c4043;cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-sans);background:#fff;border:1px solid #dadce0;border-radius:4px;padding:6px 16px}.gcal-btn-today:hover{background:#f8f9fa}.gcal-nav-btn{color:#5f6368;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:22px;display:flex}.gcal-nav-btn:hover{background:#f1f3f4}.gcal-month-title{color:#3c4043;margin:0;font-size:20px;font-weight:400}.gcal-view-toggle{border:1px solid #dadce0;border-radius:4px;display:flex;overflow:hidden}.gcal-view-btn{color:#5f6368;cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font-sans);background:#fff;border:none;border-right:1px solid #dadce0;padding:6px 14px}.gcal-view-btn:last-child{border-right:none}.gcal-view-btn.active{color:#1a73e8;background:#e8f0fe;font-weight:600}.gcal-view-btn:hover{background:#f8f9fa}.gcal-body{flex:1;gap:0;display:flex;overflow:hidden}.gcal-sidebar{flex-shrink:0;width:200px;padding:0 16px 0 0;overflow-y:auto}.gcal-btn-create{color:#3c4043;cursor:pointer;font-size:14px;font-weight:500;font-family:var(--font-sans);background:#fff;border:1px solid #dadce0;border-radius:24px;align-items:center;gap:8px;margin-bottom:16px;padding:12px 22px;transition:box-shadow .2s;display:flex;box-shadow:0 1px 3px #00000014}.gcal-btn-create:hover{box-shadow:0 4px 8px #0000001f}.gcal-mini{margin-bottom:16px}.mini-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.mini-header span{color:#3c4043;font-size:13px;font-weight:500}.mini-header button{color:#5f6368;cursor:pointer;background:0 0;border:none;border-radius:50%;padding:2px 6px;font-size:16px}.mini-header button:hover{background:#f1f3f4}.mini-weekdays{grid-template-columns:repeat(7,1fr);display:grid}.mini-weekdays span{text-align:center;color:#70757a;padding:4px 0;font-size:10px;font-weight:500}.mini-days{grid-template-columns:repeat(7,1fr);display:grid}.mini-empty{height:26px}.mini-day{color:#3c4043;cursor:pointer;width:26px;height:26px;font-size:11px;font-family:var(--font-sans);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;margin:0 auto;display:flex}.mini-day:hover{background:#f1f3f4}.mini-day.today{color:#fff;background:#1a73e8;font-weight:700}.mini-day.in-week{color:#1a73e8;background:#e8f0fe}.mini-day.today.in-week{color:#fff;background:#1a73e8}.gcal-main{border-left:1px solid #dadce0;flex:1;overflow:auto}.gcal-week{flex-direction:column;height:100%;display:flex}.gcal-week-header{z-index:2;background:#fff;border-bottom:1px solid #dadce0;grid-template-columns:56px repeat(7,1fr);display:grid;position:sticky;top:0}.gcal-gmt{color:#70757a;text-align:center;align-self:end;padding:8px 4px;font-size:9px}.gcal-week-day-header{text-align:center;padding:8px 0 4px}.gcal-day-name{color:#70757a;text-transform:uppercase;font-size:11px;font-weight:500;display:block}.gcal-day-number{color:#3c4043;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:22px;font-weight:400;display:inline-flex}.gcal-day-number.today-circle{color:#fff;background:#1a73e8;font-weight:500}.gcal-week-day-header.today .gcal-day-name{color:#1a73e8}.gcal-week-grid{flex:1;grid-template-columns:56px repeat(7,1fr);display:grid;overflow-y:auto}.gcal-time-col{position:relative}.gcal-time-label{color:#70757a;text-align:right;height:56px;font-size:10px;font-family:var(--font-sans);box-sizing:border-box;padding-right:8px;position:relative;top:-6px}.gcal-day-col{border-left:1px solid #dadce0;position:relative}.gcal-day-col.today-col{background:#e8f0fe12}.gcal-hour-cell{cursor:pointer;border-bottom:1px solid #f1f3f4;height:56px}.gcal-hour-cell:hover{background:#f8f9fa}.gcal-event-block{cursor:pointer;z-index:1;border:1px solid #ffffff26;border-radius:8px;flex-direction:column;gap:4px;padding:6px 8px;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;position:absolute;left:2px;right:2px;overflow:hidden;box-shadow:0 2px 4px #0000001a}.gcal-event-block:hover{opacity:.95;z-index:10;transform:translateY(-1px);box-shadow:0 6px 12px #00000026}.gcal-event-title{color:#fff;white-space:nowrap;text-overflow:ellipsis;letter-spacing:.2px;font-size:11px;font-weight:700;overflow:hidden}.gcal-event-time{color:#ffffffd9;white-space:nowrap;font-size:10px;font-weight:500}.gcal-event-desc{color:#fffc;-webkit-line-clamp:5;text-overflow:ellipsis;white-space:pre-wrap;-webkit-box-orient:vertical;margin-top:2px;font-size:10px;line-height:1.4;display:-webkit-box;overflow:hidden}.gcal-month{flex-direction:column;height:100%;display:flex}.gcal-month-header{border-bottom:1px solid #dadce0;grid-template-columns:repeat(7,1fr);display:grid}.gcal-month-header span{text-align:center;color:#70757a;text-transform:uppercase;padding:8px 0;font-size:11px;font-weight:500}.gcal-month-grid{flex:1;grid-template-columns:repeat(7,1fr);display:grid}.gcal-month-empty{border-bottom:1px solid #f1f3f4;border-right:1px solid #f1f3f4}.gcal-month-cell{cursor:pointer;border-bottom:1px solid #f1f3f4;border-right:1px solid #f1f3f4;min-height:80px;padding:4px}.gcal-month-cell:hover{background:#f8f9fa}.gcal-month-cell.today{background:#e8f0fe20}.gcal-month-num{color:#3c4043;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;display:inline-flex}.gcal-month-num.today-circle{color:#fff;background:#1a73e8;font-weight:700}.gcal-month-events{flex-direction:column;gap:1px;margin-top:2px;display:flex}.gcal-month-event{color:#fff;white-space:nowrap;text-overflow:ellipsis;border-radius:3px;padding:1px 4px;font-size:10px;font-weight:500;overflow:hidden}.gcal-month-more{color:#1a73e8;padding:1px 4px;font-size:10px;font-weight:600}.gcal-day-view{flex-direction:column;height:100%;display:flex}.gcal-day-view-header{text-align:center;border-bottom:1px solid #dadce0;padding:8px}.gcal-day-grid{flex:1;grid-template-columns:56px 1fr;display:grid;overflow-y:auto}.gcal-modal-overlay{z-index:100;background:#0000004d;justify-content:center;align-items:flex-start;padding-top:120px;display:flex;position:fixed;inset:0}.gcal-modal{background:#fff;border-radius:8px;flex-direction:column;gap:20px;width:700px;padding:32px 36px;display:flex;box-shadow:0 8px 32px #0003}.gcal-modal-title{font-size:20px;font-family:var(--font-sans);color:#3c4043;border:none;border-bottom:2px solid #1a73e8;outline:none;padding:8px 0;font-weight:400}.gcal-modal-row{color:#5f6368;align-items:center;gap:10px;font-size:13px;display:flex}.gcal-modal-row.align-top{align-items:flex-start}.gcal-modal-row select{font-size:13px;font-family:var(--font-sans);color:#3c4043;background:#fff;border:1px solid #dadce0;border-radius:4px;padding:6px 8px}.gcal-modal-select-wide{flex:1}.gcal-modal-textarea{font-size:15px;font-family:var(--font-sans);color:#3c4043;resize:vertical;border:1px solid #dadce0;border-radius:6px;flex:1;min-height:250px;padding:12px}.gcal-modal-textarea:focus{border-color:#1a73e8;outline:none}.gcal-color-picker{gap:6px;display:flex}.gcal-color-dot{cursor:pointer;border:2px solid #0000;border-radius:50%;width:22px;height:22px;transition:transform .1s}.gcal-color-dot:hover{transform:scale(1.1)}.gcal-color-dot.active{border-color:#3c4043;box-shadow:inset 0 0 0 2px #fff}.gcal-modal-actions{justify-content:flex-end;gap:8px;margin-top:10px;display:flex}.gcal-btn-save{color:#fff;cursor:pointer;background:#1a73e8;border:none;border-radius:4px;padding:8px 16px;font-size:14px;font-weight:500}.gcal-btn-save:hover{background:#1557b0}.gcal-btn-cancel{color:#5f6368;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:8px 16px;font-size:14px;font-weight:500}.gcal-btn-cancel:hover{background:#f1f3f4}.gcal-btn-clear{color:#ef4444;cursor:pointer;background:#ef444414;border:1px solid #ef444433;border-radius:8px;align-items:center;gap:6px;margin-right:12px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex}.gcal-btn-clear:hover{color:#fff;background:#ef4444;transform:translateY(-1px);box-shadow:0 4px 12px #ef444440}.gcal-btn-auto{color:#fff;cursor:pointer;font-size:13px;font-weight:700;font-family:var(--font-sans);background:linear-gradient(135deg,#4f46e5,#8b5cf6);border:none;border-radius:8px;align-items:center;gap:6px;margin-right:12px;padding:8px 18px;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex;box-shadow:0 4px 12px #6366f14d}.gcal-btn-auto:hover{transform:translateY(-1px);box-shadow:0 6px 16px #6366f166}.gcal-btn-auto:active{transform:translateY(1px);box-shadow:0 2px 8px #6366f14d}.gcal-modal-auto{max-width:450px;padding:32px}.modal-auto-title{color:#0f172a;margin:0 0 12px;font-size:20px;font-weight:700}.modal-auto-desc{color:#475569;margin-bottom:16px;font-size:14px;line-height:1.5}.modal-auto-list{flex-direction:column;gap:10px;margin:0 0 20px;padding:0;list-style:none;display:flex}.modal-auto-list li{color:#334155;background:#f8fafc;border-radius:6px;align-items:center;gap:8px;padding:8px 12px;font-size:14px;display:flex}.modal-auto-warning{color:#b91c1c;background:#fee2e2;border-radius:6px;margin-bottom:24px;padding:12px;font-size:13px}.modal-auto-actions{justify-content:flex-end;gap:12px;display:flex}.btn-auto-cancel{color:#64748b;cursor:pointer;background:0 0;border:none;font-size:14px;font-weight:600}.btn-auto-confirm{color:#fff;cursor:pointer;background:#0f172a;border:none;border-radius:6px;padding:10px 20px;font-size:14px;font-weight:600}.btn-auto-confirm:hover{background:#1e293b}.btn-auto-confirm:disabled{opacity:.5;cursor:not-allowed}.dash-loading{text-align:center;color:#94a3b8;padding:60px 0;font-size:14px}@media (width<=800px){.gcal-sidebar{display:none}.gcal-week-header,.gcal-week-grid{grid-template-columns:48px repeat(7,1fr)}}.gcal-context-menu{z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border:1px solid #e2e8f0cc;border-radius:12px;width:240px;animation:.15s cubic-bezier(.4,0,.2,1) fadeIn;position:fixed;overflow:hidden;box-shadow:0 10px 25px -5px #00000026,0 8px 10px -6px #0000001a}.gcal-context-menu-btn{text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:14px 16px;font-size:13.5px;font-weight:600;transition:all .2s;display:flex}.gcal-context-menu-btn:hover{background:#f8fafc;padding-left:20px}.gcal-btn-edit{color:#3b82f6;border-bottom:1px solid #f1f5f9}.gcal-btn-complete{color:#10b981;border-bottom:1px solid #f1f5f9}.gcal-btn-uncomplete{color:#64748b;border-bottom:1px solid #f1f5f9}.gcal-btn-delete{color:#ef4444}.gcal-btn-delete:hover{color:#dc2626;background:#fef2f2}.gcal-context-menu-section{background:#f8fafc;border-bottom:1px solid #f1f5f9;padding:12px 16px}.gcal-context-menu-section label{color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:11px;font-weight:600;display:block}.gcal-context-menu-section select{cursor:pointer;background:#fff;border:1px solid #cbd5e1;border-radius:6px;width:100%;padding:8px;font-size:12px;transition:border-color .2s}.gcal-context-menu-section select:hover,.gcal-context-menu-section select:focus{border-color:#94a3b8;outline:none}.gcal-event-block.drag-over{filter:brightness(1.2);opacity:.9!important;z-index:99!important;border:2px dashed #fff!important;transform:scale(1.05)!important;box-shadow:0 0 20px #0006!important}.reports-stitch{flex-direction:column;gap:20px;height:100%;padding-bottom:20px;display:flex;overflow-y:auto}.rep-header-stitch{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:flex-end;padding-bottom:12px;display:flex}.rep-title h1{color:#0f172a;margin:0 0 4px;font-size:24px;font-weight:700}.rep-title p{color:#475569;margin:0;font-size:14px}.rep-actions{gap:10px;display:flex}.btn-outline{color:#334155;cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-sans);background:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:8px 16px}.btn-primary{color:#fff;cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-sans);background:#2563eb;border:none;border-radius:8px;padding:8px 16px}.rep-kpi-row{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.rep-kpi-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;padding:20px;display:flex}.rep-kpi-card.kpi-highlight{color:#fff;background:#2563eb;border-color:#2563eb}.rep-kpi-card.kpi-highlight .rk-label,.rep-kpi-card.kpi-highlight .rk-sub{color:#bfdbfe}.rep-kpi-card.kpi-highlight .rk-value{color:#fff}.rk-label{color:#64748b;letter-spacing:.05em;text-transform:uppercase;margin-bottom:8px;font-size:11px;font-weight:700}.rk-value{color:#0f172a;margin-bottom:4px;font-size:32px;font-weight:700;line-height:1}.rk-sub{color:#94a3b8;font-size:12px;font-weight:500}.rk-bar{background:#f1f5f9;border-radius:2px;height:4px;margin-top:16px}.rk-fill{border-radius:2px;height:100%}.rep-main-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}.rep-col-left,.rep-col-right{flex-direction:column;gap:20px;display:flex}.rep-box{background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;padding:24px;display:flex}.box-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.box-header h3{color:#0f172a;margin:0;font-size:16px;font-weight:700}.info-icon{color:#94a3b8;cursor:pointer}.battery-container{justify-content:center;align-items:center;margin:20px 0 30px;display:flex}.battery-body{border:4px solid #cbd5e1;border-radius:12px;align-items:stretch;width:180px;height:80px;padding:4px;display:flex;position:relative}.battery-level{background:#10b981;border-radius:6px;transition:width 1s}.battery-text{text-align:center;color:#0f172a;text-shadow:0 0 10px #fffc;width:100%;font-size:24px;font-weight:800;position:absolute;top:50%;transform:translateY(-50%)}.battery-tip{background:#cbd5e1;border-radius:0 4px 4px 0;width:8px;height:30px;margin-left:-2px}.battery-desc{color:#475569;text-align:center;margin:0;font-size:13px}.rules-list{flex-direction:column;gap:16px;display:flex}.rule-item{border:1px solid #0000;border-radius:8px;align-items:flex-start;gap:12px;padding:12px;display:flex}.rule-item.success{background:#f0fdf4;border-color:#bbf7d0}.rule-item.warning{background:#fffbeb;border-color:#fef08a}.r-icon{margin-top:2px;font-size:16px}.r-text{flex-direction:column;display:flex}.r-title{color:#0f172a;font-size:14px;font-weight:600}.r-desc{color:#475569;margin-top:2px;font-size:13px}.chart-legend{color:#64748b;gap:12px;font-size:12px;font-weight:500;display:flex}.l-dot{border-radius:50%;width:8px;height:8px;margin-right:4px;display:inline-block}.chart-bars{border-bottom:1px solid #e2e8f0;justify-content:space-around;align-items:flex-end;height:180px;margin-top:10px;padding-bottom:10px;display:flex}.bar-group{flex-direction:column;align-items:center;width:40px;display:flex}.bar-stack{flex-direction:column;justify-content:flex-end;gap:2px;width:24px;height:140px;display:flex}.bar{border-radius:4px;width:100%;transition:height .5s}.bg-deep{background:#3b82f6}.bg-admin{background:#94a3b8}.bar-label{color:#64748b;margin-top:8px;font-size:12px;font-weight:500}.alert-count{color:#b91c1c;background:#fee2e2;border-radius:12px;padding:2px 8px;font-size:11px;font-weight:700}.crit-alerts-list{flex-direction:column;gap:12px;display:flex}.c-alert{border:1px solid;border-radius:8px;align-items:flex-start;gap:12px;padding:16px;display:flex}.c-alert.warning{background:#fef2f2;border-color:#fecaca}.c-alert.info{background:#eff6ff;border-color:#bfdbfe}.ca-icon{font-size:20px}.ca-content{flex-direction:column;flex:1;display:flex}.ca-title{color:#0f172a;margin-bottom:4px;font-size:14px;font-weight:700}.ca-desc{color:#475569;font-size:13px;line-height:1.4}.ca-action{color:#2563eb;cursor:pointer;background:0 0;border:none;align-self:flex-start;margin-top:8px;padding:0;font-size:13px;font-weight:700}.c-alert.warning .ca-action{color:#b91c1c}:root{--bg-primary:#f8f9ff;--bg-surface:#fff;--color-primary:#3b82f6;--color-primary-hover:#2563eb;--text-primary:#0f172a;--text-secondary:#64748b;--border:#e2e8f0;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"JetBrains Mono", monospace}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%}.dashboard-placeholder{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex}.placeholder-card{background:var(--bg-surface);border:1px solid var(--border);text-align:center;border-radius:16px;max-width:420px;padding:48px;box-shadow:0 4px 24px #0000000f}.placeholder-card h1{margin-bottom:16px;font-size:24px}.placeholder-card p{color:var(--text-secondary);margin-bottom:8px;font-size:14px}.placeholder-card strong{color:var(--text-primary)}.logout-btn{color:#fff;font-size:14px;font-weight:600;font-family:var(--font-sans);cursor:pointer;background:#ef4444;border:none;border-radius:8px;margin-top:24px;padding:10px 24px;transition:background .2s}.logout-btn:hover{background:#dc2626}.inactivity-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;background:#00000080;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.inactivity-modal{text-align:center;background:#fff;border-radius:16px;max-width:380px;padding:40px;animation:.3s slideUp;box-shadow:0 20px 60px #00000026}.inactivity-icon{margin-bottom:16px;font-size:48px;display:block}.inactivity-modal h2{color:#0f172a;margin:0 0 8px;font-size:20px;font-weight:700}.inactivity-modal p{color:#64748b;margin:0 0 24px;font-size:14px}.inactivity-btn{color:#fff;font-size:15px;font-weight:600;font-family:var(--font-sans);cursor:pointer;background:#3b82f6;border:none;border-radius:10px;padding:12px 32px;transition:background .2s}.inactivity-btn:hover{background:#2563eb}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.module-placeholder{color:#94a3b8;flex-direction:column;justify-content:center;align-items:center;min-height:400px;display:flex}.placeholder-icon{margin-bottom:16px;font-size:48px}.module-placeholder h2{color:#64748b;margin:0 0 8px;font-size:20px;font-weight:700}.module-placeholder p{margin:0;font-size:14px}
