:root{--primary: #10b981;--primary-dark: #059669;--primary-gradient: linear-gradient(135deg, #10b981 0%, #059669 100%);--bg: #f8fafc;--card: #ffffff;--text: #1e293b;--text-secondary: #64748b;--text-light: #94a3b8;--border: #e2e8f0;--danger: #ef4444;--danger-light: #fef2f2;--warning: #f59e0b;--warning-light: #fffbeb;--success: #10b981;--success-light: #ecfdf5;--radius-card: 16px;--radius-btn: 24px;--radius-input: 12px;--shadow: 0 4px 20px rgba(0, 0, 0, .05);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .08);--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;overflow-x:hidden}.page{max-width:480px;margin:0 auto;min-height:100vh;padding:0 20px 100px;position:relative}.page-header{padding:20px 0 16px;display:flex;align-items:center;justify-content:space-between}.page-title{font-size:22px;font-weight:700;color:var(--text)}.page-subtitle{font-size:14px;color:var(--text-secondary);margin-top:2px}.back-btn{width:36px;height:36px;border-radius:12px;background:var(--card);border:none;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);cursor:pointer;transition:transform .15s;font-size:18px;color:var(--text)}.back-btn:active{transform:scale(.92)}.logout-btn{font-size:13px;color:var(--text-secondary);background:transparent;border:1px solid var(--border);border-radius:20px;padding:4px 14px;height:32px;font-family:var(--font);cursor:pointer}.logout-btn:active{background:var(--bg)}.card{background:var(--card);border-radius:var(--radius-card);padding:20px;box-shadow:var(--shadow);margin-bottom:16px;transition:transform .2s}.card-title{font-size:15px;font-weight:600;color:var(--text);margin-bottom:12px}.card-label{font-size:13px;color:var(--text-secondary);margin-bottom:4px}.card-value{font-size:28px;font-weight:700;background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.btn{height:48px;border:none;border-radius:var(--radius-btn);font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s;width:100%;font-family:var(--font)}.btn:active{transform:scale(.96)}.btn-primary{background:var(--primary-gradient);color:#fff;box-shadow:0 4px 14px #10b9814d}.btn-primary:hover{box-shadow:0 6px 20px #10b98166}.btn-secondary{background:var(--bg);color:var(--text)}.btn-danger{background:transparent;color:#e57373;border:1.5px solid #e57373}.btn-danger:active{background:#fef2f2}.btn-outline{background:transparent;color:var(--primary);border:1.5px solid var(--primary)}.btn-sm{height:36px;font-size:13px;border-radius:18px;padding:0 16px;width:auto}.bottom-bar{position:fixed;bottom:0;left:0;right:0;padding:12px 20px;padding-bottom:calc(12px + env(safe-area-inset-bottom));background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(0,0,0,.04);z-index:100;display:flex;justify-content:center}.bottom-bar .btn{max-width:440px}.input-group{margin-bottom:16px}.input-label{font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:6px;display:block}.input-field{width:100%;height:48px;border:1.5px solid var(--border);border-radius:var(--radius-input);padding:0 16px;font-size:15px;font-family:var(--font);color:var(--text);background:var(--card);transition:border-color .2s;outline:none}.input-field:focus{border-color:var(--primary)}.input-field::placeholder{color:var(--text-light)}.kpi-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;background:var(--card);border-radius:var(--radius-card);box-shadow:var(--shadow);margin-bottom:16px}.kpi-table{width:100%;min-width:520px;border-collapse:collapse;font-size:13px}.kpi-table th{background:#f1f5f9;padding:10px;text-align:left;font-weight:600;color:var(--text-secondary);font-size:12px;white-space:nowrap;border-bottom:2px solid var(--border)}.kpi-table td{padding:10px;border-bottom:1px solid var(--border);vertical-align:middle}.kpi-table tbody tr:last-child td{border-bottom:none}.kpi-table .col-name{font-weight:600;white-space:nowrap}.kpi-table .col-weight{color:var(--primary);font-weight:600;white-space:nowrap}.kpi-table .col-readonly{color:var(--text-secondary)}.kpi-table input{width:100%;min-width:60px;padding:6px 8px;border:1.5px solid var(--border);border-radius:8px;font-size:13px;font-family:var(--font);outline:none;background:var(--bg);color:var(--text)}.kpi-table input:focus{border-color:var(--primary);background:#fff}.kpi-table input[type=number]{width:70px;text-align:center;font-weight:600}.kpi-table tfoot td{border-top:2px solid var(--border);border-bottom:none;font-weight:700;font-size:15px;padding:12px 10px}.week-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;padding:0 4px}.week-title{font-size:15px;font-weight:700}.kpi-section{padding:12px 14px;background:var(--card);border-radius:var(--radius-card);box-shadow:var(--shadow);margin-bottom:6px}.kpi-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:1.5px solid var(--border)}.kpi-section-name{font-weight:700;font-size:15px}.kpi-section-weight{color:var(--primary);font-weight:700;font-size:14px;white-space:nowrap}.kpi-row{display:flex;justify-content:space-between;align-items:flex-start;padding:5px 0;font-size:14px;gap:12px}.kpi-row-label{color:var(--text-secondary);font-size:13px;white-space:nowrap;min-width:60px}.kpi-row-value{font-weight:500;text-align:right;flex:1;word-break:break-all}.kpi-input-group{margin-top:8px}.kpi-input-group label{display:block;font-size:13px;color:var(--text-secondary);margin-bottom:4px}.kpi-score-row{display:flex;align-items:center;gap:6px;margin-top:8px}.kpi-score-row label{font-size:13px;color:var(--text-secondary);white-space:nowrap}.kpi-score-input{width:70px;padding:6px 8px;border:1.5px solid var(--border);border-radius:8px;font-size:16px;font-weight:700;font-family:var(--font);text-align:center;outline:none;background:var(--bg);color:var(--text)}.kpi-score-input:focus{border-color:var(--primary);background:#fff}.kpi-score-unit{font-size:13px;color:var(--text-secondary)}.total-bar{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--card);border-radius:var(--radius-card);box-shadow:var(--shadow);margin-bottom:16px}.total-label{font-size:14px;color:var(--text-secondary)}.total-score{font-size:24px;font-weight:700;color:var(--primary)}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600}.badge-success{background:var(--success-light);color:var(--success)}.badge-warning{background:var(--warning-light);color:var(--warning)}.badge-danger{background:var(--danger-light);color:var(--danger)}.badge-info{background:#eff6ff;color:#3b82f6}.badge-next{background:#f5f3ff;color:#7c3aed}.rule-key{font-weight:800;color:var(--danger);font-style:normal}.countdown{display:flex;gap:8px;justify-content:center;margin:12px 0}.countdown-item{text-align:center;background:var(--bg);border-radius:12px;padding:8px 12px;min-width:56px}.countdown-num{font-size:24px;font-weight:700;color:var(--text)}.countdown-label{font-size:11px;color:var(--text-secondary)}.list-item{display:flex;align-items:center;padding:14px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s}.list-item:last-child{border-bottom:none}.list-item-avatar{width:40px;height:40px;border-radius:12px;background:var(--primary-gradient);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;margin-right:12px;flex-shrink:0}.list-item-content{flex:1}.list-item-title{font-size:15px;font-weight:600}.list-item-desc{font-size:13px;color:var(--text-secondary);margin-top:2px}.list-item-action{color:var(--text-light);font-size:18px}.late-warning{background:var(--danger-light);border:1px solid rgba(239,68,68,.15);border-radius:12px;padding:12px 16px;display:flex;align-items:center;gap:10px;margin-bottom:16px;font-size:13px;color:var(--danger);font-weight:500}.loading{display:flex;justify-content:center;padding:40px}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty{text-align:center;padding:40px 20px;color:var(--text-secondary)}.empty-icon{font-size:48px;margin-bottom:12px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:flex-end;justify-content:center}.modal-content{background:var(--card);border-radius:20px 20px 0 0;padding:24px 20px;padding-bottom:calc(24px + env(safe-area-inset-bottom));width:100%;max-width:480px;max-height:80vh;overflow-y:auto;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-title{font-size:18px;font-weight:700}.modal-close{width:32px;height:32px;border-radius:50%;border:none;background:var(--bg);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}.tabs{display:flex;gap:4px;background:var(--bg);border-radius:14px;padding:4px;margin-bottom:20px}.tab{flex:1;height:36px;border:none;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;background:transparent;color:var(--text-secondary);transition:all .2s;font-family:var(--font)}.tab.active{background:var(--card);color:var(--text);box-shadow:0 2px 8px #0000000f}.form-row{display:flex;gap:12px;margin-bottom:16px}.form-row>*{flex:1}.kpi-item{background:var(--card);border-radius:var(--radius-card);padding:20px;box-shadow:var(--shadow);margin-bottom:16px}.kpi-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.kpi-item-name{font-size:16px;font-weight:600}.kpi-item-weight{font-size:13px;font-weight:600;color:var(--primary);background:var(--success-light);padding:3px 10px;border-radius:20px}.toast{position:fixed;top:20px;left:50%;transform:translate(-50%);background:var(--text);color:#fff;padding:12px 24px;border-radius:12px;font-size:14px;font-weight:500;z-index:300;animation:fadeInDown .3s ease;max-width:340px;text-align:center}.toast-success{background:var(--success)}.toast-error{background:var(--danger)}@keyframes fadeInDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.week-selector{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:20px}.week-nav-btn{width:36px;height:36px;border-radius:50%;border:1.5px solid var(--border);background:var(--card);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .15s}.week-nav-btn:active{transform:scale(.9)}.week-label{font-size:15px;font-weight:600;min-width:100px;text-align:center}.compare-row{display:flex;align-items:center;padding:12px 0;border-bottom:1px solid var(--border)}.compare-row:last-child{border-bottom:none}.compare-label{flex:1;font-size:13px;color:var(--text-secondary)}.compare-value{font-size:15px;font-weight:600;min-width:50px;text-align:center}.compare-arrow{margin:0 8px;color:var(--text-light)}.fade-in{animation:fadeIn .4s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}select.input-field{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}.divider{height:1px;background:var(--border);margin:16px 0}
