@import url("https://fonts.googleapis.com/css2?family=Be+Vietnam+Pro:wght@400;500;600;700&family=Noto+Serif:ital,wght@0,400;0,600;0,700;1,400&display=swap");:root{--bg:#ffffff;--surface:#ffffff;--surface-2:#f9f9f9;--ink:#1d1b17;--muted:#70695c;--border:#d8cfb8;--accent:#c8102e;--accent-dark:#8b0a1f;--green:#2f7655;--blue:#245c99;--red:#b42336;--gold:#b8893a;--shadow:none}*{box-sizing:border-box}html{scroll-behavior:smooth;text-size-adjust:100%}body,html{margin:0;min-height:100%;width:100%;overflow-x:hidden;background:var(--bg);color:var(--ink);font-family:"Noto Serif",Times New Roman,serif}.admin-steps,.alert-item,.eyebrow,.filter-row,.kpi-card p,.kpi-card span,.official-meta,.official-nav,.report-list,.status,button,input,select,td,textarea,th{font-family:Be Vietnam Pro,Segoe UI,Arial,sans-serif}button,input,select,textarea{font:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}.login-screen,.screen-center{min-height:100vh;display:grid;place-items:center;padding:24px}.login-screen{background:linear-gradient(120deg,rgba(185,25,47,.12),transparent 42%),linear-gradient(220deg,rgba(36,92,153,.12),transparent 38%),var(--bg)}.login-panel{width:min(480px,100%);background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow);padding:30px}.brand{display:flex;align-items:center;gap:18px}.brand img{object-fit:contain;mix-blend-mode:multiply;border-radius:4px}.brand strong{display:block;font-size:16px;line-height:1.2;color:var(--ink)}.brand span{display:block;color:var(--muted);font-size:12px;margin-top:3px}.official-header .brand strong{font-size:26px;line-height:1.08;color:var(--accent-dark)}.official-header .brand span{margin-top:5px;font-style:italic}.brand.large{margin-bottom:28px}.brand.large strong{font-size:20px}.login-panel h1{margin:0 0 8px;font-size:34px;letter-spacing:0}.login-panel p{margin:0 0 24px;color:var(--muted);line-height:1.6}.entry-form,.form-stack{display:grid;grid-gap:16px;gap:16px}label{display:grid;grid-gap:7px;gap:7px;font-size:13px;font-weight:700;color:#39342c}input,select,textarea{width:100%;border:1px solid var(--border);border-radius:6px;background:#fffdf8;color:var(--ink);padding:11px 12px;outline:none}input:focus,select:focus,textarea:focus{box-shadow:0 0 0 3px rgba(185,25,47,.12)}.demo-actions button,.filter-row button,.ghost-button,.primary-button,.secondary-button{border:1px solid transparent;border-radius:6px;min-height:38px;padding:0 14px;font-weight:700;transition:transform .16s ease,box-shadow .16s ease,background .16s ease,border-color .16s ease}.primary-button{background:var(--accent);color:white}.demo-actions button,.secondary-button{background:var(--surface-2);border-color:var(--border);color:var(--ink)}.ghost-button{width:100%;background:transparent;border-color:var(--border);color:var(--muted)}.demo-actions button:hover,.filter-row button:hover,.ghost-button:hover,.primary-button:hover,.secondary-button:hover{transform:translateY(-1px);box-shadow:0 10px 18px rgba(48,38,24,.08)}.demo-actions button:active,.filter-row button:active,.ghost-button:active,.primary-button:active,.secondary-button:active{transform:translateY(0) scale(.98)}.compact{min-height:30px;padding:0 10px;border-radius:4px;font-size:12px}.form-error{background:#ffe7ea;border:1px solid #f1b8c0;color:#8f1022;padding:10px 12px;border-radius:6px}.form-note{background:#eaf6ee;border:1px solid #b8dec5;color:#245d3f;padding:10px 12px;border-radius:6px}.attachment-tools{display:flex;align-items:center;justify-content:flex-end;gap:14px;flex-wrap:wrap}.template-link{color:var(--red);font-weight:700;text-decoration:underline;text-underline-offset:3px}.attachment-name{color:var(--muted);font-size:13px;font-weight:700}.demo-actions{margin-top:18px;border-top:1px solid var(--border);padding-top:16px;display:flex;flex-wrap:wrap;gap:8px}.demo-actions span{width:100%;color:var(--muted);font-size:12px}.app-frame{min-height:100vh;width:100%;min-width:0;overflow-x:hidden}.official-header{position:relative;width:100%;min-height:116px;background:var(--surface);border-bottom:1px solid var(--border);padding:18px 44px 14px;display:flex;align-items:center;justify-content:space-between;gap:24px;animation:slideDown .45s ease both}.official-meta{display:flex;align-items:center;gap:12px}.header-login-btn{width:auto;min-height:28px;display:inline-flex;align-items:center;padding:0 14px;border-radius:4px;font-size:13px;font-weight:500;text-decoration:none;border:1px solid var(--border);background:var(--surface);color:var(--muted);cursor:pointer;transition:all .2s}.header-login-btn:hover{background:var(--bg-hover);color:var(--text);border-color:var(--text-muted)}.header-user-area{display:flex;align-items:center;gap:8px}.push-control{position:relative;display:flex;align-items:center}.push-button{min-height:28px;padding:0 10px;border:1px solid var(--border);border-radius:4px;background:var(--surface);color:var(--muted);font-size:12px;font-weight:700}.push-button.enabled{background:#eaf6ee;border-color:#b8dec5;color:#245d3f}.push-button:disabled{cursor:wait;opacity:.7}.push-message{position:absolute;z-index:20;right:0;top:calc(100% + 8px);width:260px;padding:9px 10px;border:1px solid var(--border);border-radius:6px;background:#fffdf8;box-shadow:0 10px 24px rgba(48,38,24,.14);color:var(--ink);font-size:12px}.user-name-badge{font-size:13px;font-weight:500;color:var(--text);border:1px solid var(--border);padding:4px 10px;border-radius:4px;background:var(--surface-2);display:inline-flex;align-items:center;gap:6px}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--success)}.user-name-text{max-width:180px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:inline-block}.header-logout-btn{width:auto;min-height:26px;display:inline-flex;align-items:center;padding:0 8px;border-radius:4px;font-size:12px;font-weight:500;text-decoration:none;background:transparent;border:1px solid var(--border);color:var(--muted);cursor:pointer;transition:all .2s}.header-logout-btn:hover{background:var(--bg-hover);color:var(--text);border-color:var(--text-muted)}@media (min-width:981px){.header-logout-btn{display:none}}.official-nav{width:100%;background:var(--surface-2);border-bottom:1px solid var(--border);padding:0 44px;align-items:center;justify-content:space-between;gap:16px;animation:slideDown .52s ease both}.nav-scroll,.official-nav{min-height:38px;display:flex}.nav-scroll{align-items:stretch;gap:4px;overflow-x:auto;min-width:0}.official-nav a{display:flex;align-items:center;padding:0 14px;color:#4a463c;font-size:11px;font-weight:700;text-transform:uppercase;white-space:nowrap;transition:color .16s ease,background .16s ease}.official-nav a.active,.official-nav a:hover{color:var(--accent-dark);background:rgba(250,246,236,.75)}.nav-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.nav-actions .ghost-button{width:auto;min-height:28px;border-radius:4px;padding:0 10px;background:var(--surface)}.user-card{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:12px}.user-card span,.user-card strong{display:block}.demo-badge,.user-card span{color:var(--muted);font-size:12px;margin-top:4px}.demo-badge{background:#eef3ff;border:1px solid #cbd8fb;border-radius:4px;padding:6px 8px;font-family:Arial,Helvetica,sans-serif}.main{width:100%;min-width:0;padding:24px 44px 34px;max-width:1440px;margin:0 auto}.topbar{display:flex;justify-content:space-between;gap:18px;align-items:center;margin-bottom:22px}.eyebrow,.topbar p{margin:0;color:var(--muted);text-transform:uppercase;font-size:11px;letter-spacing:.08em;font-weight:700}.topbar h1{margin:6px 0 0;font-size:clamp(26px,3vw,40px);letter-spacing:0}.topbar-meta{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:12px 16px;min-width:160px}.topbar-meta span,.topbar-meta strong{display:block}.topbar-meta span{color:var(--muted);font-size:12px}.page-stack{display:grid;grid-gap:24px;gap:24px;animation:fadeUp .5s ease both}.dashboard-toolbar{display:flex;justify-content:space-between;align-items:flex-end;gap:18px}.dashboard-toolbar h1{margin:5px 0 0;color:var(--accent-dark);font-size:clamp(24px,3vw,34px);line-height:1.12}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));grid-gap:0;gap:0;border:1px solid var(--border);border-radius:6px;overflow:hidden}.kpi-card,.kpi-grid{background:var(--surface)}.kpi-card{border:0;border-right:1px solid var(--border);border-radius:0;padding:18px 22px;min-height:126px;box-shadow:var(--shadow);transition:background .18s ease,transform .18s ease}.kpi-card:hover{background:#fffaf2;transform:translateY(-2px)}.kpi-card:last-child{border-right:0}.kpi-card span{display:flex;align-items:center;gap:8px;color:var(--muted);text-transform:uppercase;font-size:10px;font-weight:700;letter-spacing:.12em;white-space:nowrap}.kpi-card span:before{content:"";width:14px;height:1px;background:var(--accent)}.kpi-card strong{display:block;margin-top:14px;font-size:40px;line-height:1;color:var(--ink)}.kpi-card p{margin:10px 0 0;color:var(--muted);font-size:12px}.kpi-card.green strong{color:var(--green)}.kpi-card.red strong{color:var(--red)}.kpi-card.blue strong{color:var(--blue)}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1.46fr) minmax(270px,.5fr);grid-gap:24px;gap:24px;align-items:start}.panel{background:var(--surface);border:1px solid var(--border);border-radius:6px;box-shadow:var(--shadow);overflow:hidden;transition:box-shadow .18s ease,transform .18s ease}.panel:hover{box-shadow:0 16px 34px rgba(40,31,20,.08)}.panel-head{min-height:74px;padding:16px 18px;display:flex;gap:16px;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border)}.panel-head.compact{min-height:auto;padding:18px 20px 8px;border-bottom:0}.panel-head h2{margin:0;font-size:18px;letter-spacing:0}.panel-head strong{white-space:nowrap;color:var(--accent-dark)}.panel-head input{max-width:280px}.subline{display:block;margin-top:6px;color:var(--muted);font-size:12px;font-style:italic}.chart-summary{display:grid;grid-template-columns:1.25fr .95fr}.chart-block{border-right:1px solid var(--border);min-width:0}.cchc-block{min-width:0}.line-chart{display:block;width:100%;height:210px;padding:8px 20px 0}.line-chart line{stroke:#dfd4bf;stroke-width:.5;stroke-dasharray:2 2}.line-chart polyline{fill:rgba(200,16,46,.11);stroke:var(--accent);stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke}.chart-legend{display:flex;align-items:center;gap:18px;padding:4px 20px 18px;color:var(--muted);font-family:Arial,Helvetica,sans-serif;font-size:12px}.chart-legend span{display:inline-flex;align-items:center;gap:6px}.chart-legend i{width:14px;height:2px;background:var(--accent)}.chart-legend i.dash{height:1px;background:transparent;border-top:1px dashed var(--muted)}.chart-legend strong{margin-left:auto;color:var(--ink);font-weight:500}.ratio-card{display:flex;flex-direction:column;align-items:center;padding:20px 24px 16px;gap:18px}.ratio-donut{position:relative;width:180px;height:180px;display:grid;place-items:center}.ratio-donut svg{position:absolute;inset:0;width:100%;height:100%;transform:rotate(-90deg)}.ratio-bg,.ratio-fg{fill:none;stroke-width:20}.ratio-bg{stroke:#eadfcb}.ratio-fg{stroke:var(--accent);stroke-linecap:round;animation:ratioDraw .8s ease both}.ratio-label{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:2px;text-align:center}.ratio-label strong{font-size:38px;line-height:1;color:var(--accent-dark);letter-spacing:-.02em}.ratio-label strong small{font-size:22px;font-weight:600}.ratio-label span{font:700 10px Be Vietnam Pro,Segoe UI,sans-serif;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}.ratio-stats{justify-content:center;gap:0;width:100%;max-width:360px}.ratio-stat,.ratio-stats{display:flex;align-items:center}.ratio-stat{flex:1 1;flex-direction:column;gap:4px;padding:0 12px}.ratio-stat-value{font:700 20px Georgia,Times New Roman,serif;color:var(--ink);line-height:1}.ratio-stat-value.accent{color:var(--accent)}.ratio-stat-name,.ratio-stat-value.muted{color:var(--muted)}.ratio-stat-name{font:600 10px Be Vietnam Pro,Segoe UI,sans-serif;text-transform:uppercase;letter-spacing:.08em}.ratio-stat-divider{width:1px;height:32px;background:var(--border);flex-shrink:0}.ratio-updated{font:500 11px Be Vietnam Pro,Segoe UI,sans-serif;color:var(--muted);opacity:.7}.mini-kpi-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:14px;gap:14px;padding:14px 20px 18px}.mini-kpi{min-height:104px;background:#eef2e9;border:1px solid #b8cdbf;border-radius:5px;padding:12px 14px;font-family:Arial,Helvetica,sans-serif;transition:transform .18s ease,border-color .18s ease,background .18s ease}.mini-kpi:hover{transform:translateY(-2px);border-color:#6fa37f;background:#f3f8ef}.mini-kpi span{display:block;color:var(--muted);text-transform:uppercase;font-size:10px;letter-spacing:.08em;font-weight:700}.mini-kpi strong{display:block;margin-top:8px;color:var(--green);font-family:Georgia,Times New Roman,serif;font-size:34px;line-height:1}.mini-kpi small{display:flex;justify-content:space-between;gap:8px;margin-top:10px;color:var(--muted);font-size:10px}.mini-kpi b{color:var(--green)}.alert-panel{display:flex;flex-direction:column}.admin-steps div,.alert-item,.report-list div{display:grid;grid-gap:5px;gap:5px;padding:12px 18px;border-bottom:1px solid var(--border)}.alert-panel .panel-head{min-height:48px;padding:14px 18px}.alert-panel .panel-head strong{color:var(--accent);font-size:12px}.alert-item{position:relative;padding-left:48px;transition:background .16s ease,transform .16s ease}.alert-item:hover{background:#fff8ec;transform:translateX(2px)}.alert-item:before{content:"!";position:absolute;left:18px;top:14px;width:22px;height:22px;display:grid;place-items:center;border-radius:3px;background:#f6d4dc;color:var(--accent);font-weight:700}.alert-item strong{color:var(--red);font-size:0}.admin-steps span,.alert-item span,.report-list span{color:#342f28}.alert-item small,.report-list small{color:var(--muted);line-height:1.5;font-size:11px}.empty{padding:18px;color:var(--muted)}.filter-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:10px 18px;background:var(--surface-2);border-bottom:1px solid var(--border)}.filter-label{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:10px;margin-right:4px}.filter-row button{background:var(--surface);border-color:#c2b895;color:#4a463c;min-height:26px;border-radius:4px;font-size:11px;padding:0 10px;display:inline-flex;align-items:center;gap:6px}.filter-row button i,.group-tag i{width:6px;height:6px;border-radius:50%;display:inline-block}.filter-row button.active{background:var(--ink);color:white}.filter-row button.danger{background:var(--red)}.table-scroll{width:100%;max-width:100%;overflow:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse;min-width:1080px;font-family:Arial,Helvetica,sans-serif;font-size:13px}th{text-align:left;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em;background:var(--surface-2);padding:12px 16px;border-bottom:2px solid #c2b895}td{padding:14px 16px;border-bottom:1px solid var(--border);vertical-align:middle}tbody tr{cursor:pointer;transition:background .16s ease,transform .16s ease}tbody tr:hover{background:#fff6e8}tbody tr:nth-child(2n){background:rgba(216,207,184,.18)}td small,td span{display:block;color:var(--muted);margin-top:4px;font-size:12px}.table-panel .panel-head{min-height:50px;padding:14px 18px}.table-panel .panel-head>div{display:flex;align-items:center;gap:10px}.table-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.table-actions input{min-width:220px;min-height:30px;padding:6px 10px;border-radius:4px}.table-count{display:inline-flex;align-items:center;min-height:22px;padding:0 8px;border:1px solid var(--border);border-radius:4px;background:var(--surface-2);color:var(--muted);font-family:Arial,Helvetica,sans-serif;font-size:11px}.stt{color:var(--accent);font-family:Georgia,Times New Roman,serif;font-size:16px;font-weight:700}.group-tag{align-items:center;gap:6px;padding:3px 8px;border:1px solid var(--border);border-radius:4px;color:#4a463c}.code-chip,.group-tag{display:inline-flex;background:var(--surface-2)}.code-chip{width:auto;margin:0 8px 0 0;padding:2px 6px;border:1px solid var(--border);border-radius:3px;font-size:10px;color:var(--muted)}.code-chip,.num{font-family:monospace}.num{text-align:right;white-space:nowrap}.num.strong{color:var(--ink);font-weight:700}.progress-wrap{min-width:150px}.progress-track{position:relative;height:10px;background:var(--surface-2);border:1px solid var(--border);border-radius:2px;overflow:hidden}.progress-fill{height:100%;width:var(--fill-width,100%);border-radius:1px;transition:width .6s cubic-bezier(.22,1,.36,1)}.progress-marker{position:absolute;top:-3px;width:2px;height:16px;background:#1d1b17;opacity:.55}.progress-caption{display:flex;justify-content:space-between;gap:8px;margin-top:5px;font-size:11px;color:var(--muted)}.status{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:0 9px;border-radius:4px;font-size:12px;font-weight:700;white-space:nowrap;border:1px solid transparent}.status.green{background:#e4f4eb;color:#246444}.status.blue{background:#e4effb;color:#245c99}.status.violet{background:#f0e8fb;color:#6c35a0}.status.red{background:#ffe7ea;color:#9c1b2e}.selected-row td{background:#fffcf8!important;border-bottom:none}.detail-row td{padding:0!important;border-top:none}.inline-detail{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:24px;margin:0 16px 16px;box-shadow:0 4px 12px rgba(30,27,22,.04);animation:fadeIn .2s ease}.inline-detail-header{display:flex;justify-content:space-between;align-items:flex-start}.inline-detail h3{margin:12px 0 16px;font-size:24px;line-height:1.3;color:var(--accent-dark)}.drawer-close{border:1px solid var(--border);background:var(--surface-2);border-radius:4px;min-height:30px;padding:0 10px}.drawer-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));border:1px solid var(--border);border-radius:6px;overflow:hidden;margin:18px 0}.drawer-grid div{padding:14px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);background:#fffaf2}.drawer-grid span{display:block;color:var(--muted);font:700 10px Be Vietnam Pro,Segoe UI,sans-serif;text-transform:uppercase;letter-spacing:.08em}.drawer-grid strong{display:block;margin-top:8px;font-size:24px;color:var(--ink)}.inline-detail p{color:#4a463c;line-height:1.7}.entry-form{padding:18px;grid-template-columns:repeat(2,minmax(0,1fr))}.admin-indicator-form .form-error,.admin-indicator-form label:first-child,.admin-indicator-form label:nth-child(13),.admin-indicator-form label:nth-child(3),.admin-plan-form .form-error,.admin-plan-form label:first-child,.admin-plan-form label:nth-child(4),.button-row,.entry-form label:first-child,.entry-form label:nth-child(4),.form-note{grid-column:1/-1}.check-row{display:flex;align-items:center;gap:8px;min-height:42px}.check-row input{width:auto}.danger-outline{color:var(--red);border-color:var(--red)}.button-row{display:flex;justify-content:flex-end;gap:10px}.report-list{max-height:420px;overflow:auto}.admin-steps{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.admin-steps div{border-right:1px solid var(--border)}.approve-table{min-width:700px}.approve-table th{background:var(--surface-2);border-bottom:2px solid var(--accent)}.approve-actions{display:flex;gap:6px}.approve-btn{border:1px solid transparent;border-radius:4px;min-height:30px;padding:0 10px;font-weight:700;font-size:11px;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,background .16s ease}.approve-btn:hover{transform:translateY(-1px);box-shadow:0 6px 14px rgba(48,38,24,.1)}.approve-btn:active{transform:translateY(0) scale(.97)}.approve-btn.green{background:#e4f4eb;color:#246444;border-color:#b8dec5}.approve-btn.green:hover{background:#2f7655;color:white}.approve-btn.red{background:#ffe7ea;color:#9c1b2e;border-color:#f1b8c0}.approve-btn.red:hover{background:var(--red);color:white}.schedule-add-btn{margin-left:auto}.schedule-add-btn+.secondary-button{margin-left:8px}.schedule-entry-form{border-top:1px solid var(--border);padding:0 0 18px}.schedule-entry-form h3{margin:0;font-size:16px;color:var(--accent-dark)}.sched-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:12px;gap:12px;padding:0 20px}.sched-grid label{font-size:12px}.sched-full{grid-column:1/-1}.recipient-picker{margin:0;padding:12px;border:1px solid var(--border);border-radius:6px}.recipient-picker legend{padding:0 6px;font-size:12px;font-weight:700}.recipient-options{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:8px;gap:8px}.recipient-option{display:flex;grid-template-columns:none;align-items:flex-start;gap:8px;padding:9px;border:1px solid var(--border);border-radius:5px;background:#fffdf8}.recipient-option input{width:auto;margin-top:2px}.recipient-option span{display:grid;grid-gap:2px;gap:2px}.recipient-option small{color:var(--muted);font-weight:500}.dashboard-schedule-form{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:#fffdf8;padding:14px 0}.schedule-attendee-picker{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:8px;gap:8px}.schedule-table .schedule-attendee-picker{grid-template-columns:minmax(0,1fr);min-width:220px}.schedule-editing-row td{background:#fff8ec;padding:14px}.schedule-inline-editor{display:grid;grid-template-columns:minmax(150px,.8fr) minmax(110px,.55fr) minmax(90px,.45fr) minmax(150px,.75fr) minmax(240px,1.25fr) minmax(240px,1.1fr) minmax(240px,1fr) auto;grid-gap:12px;gap:12px;align-items:start}.schedule-inline-editor label{min-width:0}.schedule-inline-editor input,.schedule-inline-editor select,.schedule-inline-editor textarea{width:100%}.schedule-inline-editor textarea{min-height:70px;resize:vertical}.schedule-day-textarea{margin-top:8px;min-height:54px!important}.schedule-inline-attendees{max-height:260px;overflow-y:auto}.schedule-inline-actions{align-self:start;padding-top:22px}.sched-msg{margin:10px 20px 0}.sched-actions{padding:14px 20px 0}.sched-pending{border-top:1px solid var(--border)}.sched-pending h3{margin:0;font-size:16px;color:var(--ink)}.schedule-table{min-width:820px}.schedule-table th{background:var(--accent-dark);color:#fff;font-size:11px;text-transform:uppercase;letter-spacing:.1em;padding:12px 14px;border-bottom:0}.schedule-table td{padding:12px 14px;vertical-align:top;line-height:1.5}.schedule-table input,.schedule-table select{min-width:0;padding:8px 9px;font-size:13px}.schedule-table td strong{color:var(--accent)}.schedule-table tbody tr{transition:background .2s ease,transform .2s ease}.schedule-table tbody tr:hover{background:#fff6e8;transform:translateX(3px)}.schedule-edit-message{margin:0 18px 12px}.calendar-link{display:inline-flex;align-items:center;min-height:30px;padding:0 9px;border:1px solid var(--border);border-radius:4px;color:var(--accent-dark);background:#fffdf8;font-size:11px;font-weight:700;text-decoration:none;white-space:nowrap}@keyframes fadeUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes drawerIn{0%{opacity:0;transform:translateX(28px)}to{opacity:1;transform:translateX(0)}}@keyframes ratioDraw{0%{stroke-dasharray:0 100}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulseGlow{0%,to{text-shadow:0 0 0 transparent}50%{text-shadow:0 0 12px rgba(200,16,46,.18)}}@keyframes scanLine{0%{top:-2px;opacity:.5}to{top:100%;opacity:0}}@keyframes countUp{0%{opacity:0;transform:translateY(8px) scale(.92)}to{opacity:1;transform:translateY(0) scale(1)}}.anim-stagger{animation:fadeUp .55s cubic-bezier(.22,.61,.36,1) both}.anim-stagger:first-child{animation-delay:0s}.anim-stagger:nth-child(2){animation-delay:.08s}.anim-stagger:nth-child(3){animation-delay:.16s}.anim-stagger:nth-child(4){animation-delay:.24s}.anim-stagger:nth-child(5){animation-delay:.32s}.kpi-card{animation:countUp .5s cubic-bezier(.22,.61,.36,1) both}.kpi-card:first-child{animation-delay:.05s}.kpi-card:nth-child(2){animation-delay:.12s}.kpi-card:nth-child(3){animation-delay:.19s}.kpi-card:nth-child(4){animation-delay:.26s}.kpi-card strong{animation:pulseGlow 3s ease-in-out infinite}.official-header:before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:linear-gradient(90deg,var(--accent) 0 51%,var(--gold) 51% 100%),linear-gradient(90deg,transparent,rgba(255,255,255,.5) 50%,transparent);background-size:100% 100%,200% 100%;animation:shimmer 4s linear infinite}.panel{position:relative}.mini-kpi{animation:fadeUp .45s cubic-bezier(.22,.61,.36,1) both}.mini-kpi:first-child{animation-delay:.1s}.mini-kpi:nth-child(2){animation-delay:.18s}.mini-kpi:nth-child(3){animation-delay:.26s}.mini-kpi:nth-child(4){animation-delay:.34s}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(200,16,46,.12);animation:fadeIn .2s ease}.primary-button{position:relative;overflow:hidden}.primary-button:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at var(--x,50%) var(--y,50%),rgba(255,255,255,.25),transparent 60%);opacity:0;transition:opacity .3s ease}.primary-button:active:after{opacity:1}.alert-item{animation:fadeUp .4s cubic-bezier(.22,.61,.36,1) both}.alert-item:first-child{animation-delay:.05s}.alert-item:nth-child(2){animation-delay:.12s}.alert-item:nth-child(3){animation-delay:.19s}.alert-item:nth-child(4){animation-delay:.26s}.alert-item:nth-child(5){animation-delay:.33s}.schedule-table tbody tr,table tbody tr{animation:fadeUp .35s cubic-bezier(.22,.61,.36,1) both}table tbody tr:first-child{animation-delay:.03s}table tbody tr:nth-child(2){animation-delay:.06s}table tbody tr:nth-child(3){animation-delay:.09s}table tbody tr:nth-child(4){animation-delay:.12s}table tbody tr:nth-child(5){animation-delay:.15s}table tbody tr:nth-child(6){animation-delay:.18s}table tbody tr:nth-child(n+7){animation-delay:.21s}.official-nav a{position:relative}.official-nav a:after{content:"";position:absolute;bottom:0;left:50%;right:50%;height:2px;background:var(--accent);transition:left .25s cubic-bezier(.22,.61,.36,1),right .25s cubic-bezier(.22,.61,.36,1)}.official-nav a.active:after,.official-nav a:hover:after{left:0;right:0}.ratio-donut:hover .ratio-fg{filter:drop-shadow(0 0 8px rgba(200,16,46,.3));transition:filter .3s ease}.report-list div{transition:background .2s ease,transform .2s ease,box-shadow .2s ease}.report-list div:hover{background:#fff6e8;transform:translateX(3px);box-shadow:-3px 0 0 var(--accent)}.mobile-nav{display:none}.desktop-only{display:block}.mobile-only{display:none}.mobile-cards{display:grid;grid-gap:14px;gap:14px;padding:14px}.assignment-card{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:14px;box-shadow:0 2px 8px rgba(0,0,0,.02)}.assignment-card .card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.assignment-card .card-title{display:block;font-size:14px;color:var(--ink);margin-bottom:12px;line-height:1.4}.assignment-card .card-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:8px;gap:8px;background:#fffaf2;border:1px solid var(--border);border-radius:4px;padding:10px;margin-bottom:12px}.assignment-card .card-grid div{display:flex;flex-direction:column;gap:4px}.assignment-card .card-grid span{font-size:10px;color:var(--muted);text-transform:uppercase}.assignment-card .card-grid strong{font-size:12px;color:var(--ink)}.assignment-card .card-footer{font-size:12px;color:var(--muted);padding-top:8px;border-top:1px dashed var(--border);flex-wrap:wrap;gap:8px}@media (max-width:980px){.app-frame{padding-bottom:66px}.official-header{padding:14px 18px;min-height:92px;align-items:flex-start}.official-header .brand{gap:12px}.official-header .brand img{width:44px;height:44px}.official-header .brand strong{font-size:18px}.official-meta{display:flex!important;margin-top:4px}.user-name-text{max-width:110px}.official-nav{padding:0 10px;min-height:42px}.nav-actions{display:none}.main{padding:18px}.admin-steps,.chart-summary,.dashboard-grid,.kpi-grid,.mini-kpi-grid,.schedule-list{grid-template-columns:1fr}.ratio-donut{width:150px;height:150px}.ratio-stats{max-width:100%}.dashboard-toolbar{align-items:flex-start;flex-direction:column}.kpi-card{border-right:0;border-bottom:1px solid var(--border)}.kpi-card:last-child{border-bottom:0}.chart-block{border-right:0;border-bottom:1px solid var(--border)}.chart-legend{flex-wrap:wrap}.chart-legend strong{width:100%;margin-left:0}.panel-head{align-items:flex-start;flex-direction:column}.table-panel .panel-head>div{flex-wrap:wrap}.panel-head input{max-width:none}.entry-form,.sched-grid{grid-template-columns:1fr}.mobile-nav{position:fixed;left:0;right:0;bottom:0;z-index:20;display:flex;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap;background:#fff8ec;border-top:1px solid var(--border)}.desktop-only{display:none}.mobile-only{display:block}.mobile-nav a{min-height:58px;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:0 16px;flex:0 0 auto;font-size:12px;font-weight:700;color:var(--muted)}.mobile-nav a.active{color:var(--accent);background:#fff1df}}@media (max-width:620px){.cchc-block,.chart-block,.chart-summary,.panel,.schedule-panel,.table-panel{max-width:100%;overflow:hidden}.recipient-options{grid-template-columns:1fr}.push-button{max-width:92px;min-height:34px;padding:0 8px;line-height:1.12;font-size:11px}.push-message{position:fixed;top:72px;right:12px;width:min(300px,calc(100vw - 24px))}.official-header{min-height:auto;padding:10px 12px;align-items:center;gap:10px;flex-wrap:wrap}.official-header .brand{flex:1 1 190px;min-width:0;gap:10px}.official-header .brand img{width:38px;height:38px}.official-header .brand strong{font-size:15px;line-height:1.12}.official-header .brand span{font-size:11px;margin-top:3px}.official-meta{margin-left:auto;gap:6px;flex:0 1 auto}.header-user-area{gap:6px;max-width:100%}.user-name-badge{max-width:132px;padding:4px 8px;font-size:12px}.user-name-text{max-width:104px}.header-login-btn,.header-logout-btn{min-height:32px;padding:0 10px;font-size:12px}.official-nav{display:none}.mobile-nav{min-height:52px;padding-bottom:env(safe-area-inset-bottom)}.mobile-nav a{min-height:52px;padding:0 14px;font-size:11px}.main{padding:12px 10px 82px}.page-stack{gap:14px}.dashboard-toolbar{gap:10px}.dashboard-toolbar .ghost-button{min-height:36px;padding:0 12px}.kpi-grid{border-radius:6px}.kpi-card{min-height:82px;padding:12px 14px}.kpi-card span{font-size:9px;letter-spacing:.08em;white-space:normal}.kpi-card strong{margin-top:10px;font-size:28px}.kpi-card p{margin-top:7px;font-size:11px;line-height:1.35}.dashboard-grid{gap:12px}.chart-summary{min-width:0;width:100%}.cchc-block,.chart-block{padding-bottom:10px}.chart-block{overflow-x:hidden;overflow-y:hidden}.panel-head.compact{padding:12px 12px 4px}.cchc-block .panel-head h2,.chart-block .panel-head h2{font-size:14px;line-height:1.25}.cchc-block .subline{font-size:11px;line-height:1.35}.ratio-card{display:grid;grid-template-columns:94px minmax(0,1fr);align-items:center;padding:8px 8px 10px;grid-gap:8px 10px;gap:8px 10px;width:100%;min-width:0;max-width:100%;overflow:hidden}.ratio-donut{width:92px;height:92px;margin:0 auto;flex:0 0 auto}.ratio-bg,.ratio-fg{stroke-width:16}.ratio-label strong{font-size:20px}.ratio-label strong small{font-size:10px}.ratio-label span{font-size:7px;letter-spacing:.04em}.ratio-stats{display:flex;flex-direction:column;align-items:stretch;justify-content:center;gap:5px;min-width:0}.ratio-stat{display:grid;grid-template-columns:auto auto;align-items:baseline;justify-content:start;grid-column-gap:8px;column-gap:8px;padding:0;min-width:0}.ratio-stat-divider{display:none}.ratio-stat-value{order:2;font-size:11.5px;white-space:nowrap;text-align:left}.ratio-stat-name{order:1;font-size:7.6px;letter-spacing:0;text-align:left;white-space:nowrap;overflow-wrap:anywhere}.ratio-updated{grid-column:1/-1;font-size:9px;text-align:center}.mini-kpi-grid{display:grid;grid-template-columns:1fr;grid-gap:8px;gap:8px;padding:8px 12px 12px;overflow:visible}.mini-kpi{width:100%;min-width:0;min-height:auto;padding:8px 9px;overflow:visible}.mini-kpi span{display:block;font-size:8px;line-height:1.2;letter-spacing:.035em;white-space:normal;overflow-wrap:anywhere}.mini-kpi strong{margin-top:5px;font-size:20px}.panel-head{min-height:auto;padding:14px}.panel-head h2{font-size:16px}.alert-panel .panel-head{min-height:46px;padding:12px 14px;flex-direction:row;align-items:center}.alert-panel .panel-head h2{font-size:16px;line-height:1.25}.alert-panel .panel-head strong{margin-left:auto;font-size:12px}.alert-panel{width:100%;max-width:100%;overflow:hidden}.alert-panel .alert-list{display:flex;gap:10px;width:100%;max-width:100%;min-width:0;box-sizing:border-box;max-height:none!important;overflow-x:auto!important;overflow-y:visible!important;padding:8px 8px calc(76px + env(safe-area-inset-bottom));scrollbar-width:thin;scrollbar-color:#c2b895 #fff8ec;-webkit-overflow-scrolling:touch}.alert-panel .alert-list::-webkit-scrollbar{height:6px}.alert-panel .alert-list::-webkit-scrollbar-track{background:#fff8ec}.alert-panel .alert-list::-webkit-scrollbar-thumb{background:#c2b895;border-radius:999px}.alert-panel .alert-item{display:grid;grid-template-columns:18px minmax(0,1fr);grid-column-gap:8px;column-gap:8px;grid-row-gap:4px;row-gap:4px;align-items:start;width:auto;flex:0 0 min(360px,calc(100vw - 42px));max-width:calc(100vw - 42px);min-width:0;box-sizing:border-box;padding:9px;min-height:auto;border:1px solid var(--border);border-radius:6px;overflow:visible}.alert-panel .alert-item strong{display:none}.alert-panel .empty{width:100%;padding:14px}.alert-item:before{position:static;grid-column:1;grid-row:1/span 2;width:18px;height:18px;font-size:12px}.alert-panel .alert-item span{font-size:11.5px;line-height:1.34;margin:0}.alert-panel .alert-item small,.alert-panel .alert-item span{display:block;grid-column:2;width:100%;max-width:100%;min-width:0;white-space:normal;word-break:break-word;overflow:visible;overflow-wrap:anywhere}.alert-panel .alert-item small{margin-top:0;font-size:10px;line-height:1.42}.filter-row{flex-wrap:nowrap;align-items:center;gap:8px;overflow-x:auto;padding:10px 12px;-webkit-overflow-scrolling:touch}.filter-row .filter-label,.filter-row button{flex:0 0 auto}.table-count{white-space:nowrap}.table-scroll{width:100%;max-width:calc(100vw - 20px);overflow-x:auto;-webkit-overflow-scrolling:touch}.table-scroll table{min-width:680px;font-size:12px}.table-scroll td,.table-scroll th{padding:10px 9px}.progress-wrap{min-width:110px}.schedule-table{min-width:680px}.schedule-table td,.schedule-table th{padding:10px 9px;font-size:12px}.schedule-table th{letter-spacing:.06em}.schedule-inline-editor{grid-template-columns:1fr}.schedule-inline-attendees{max-height:none}.schedule-inline-actions{padding-top:0}.entry-form{padding:14px}.button-row{justify-content:stretch;flex-direction:column}.button-row button{width:100%}.line-chart{height:220px}.login-panel{padding:22px}}.login-layout-new{min-height:100vh;display:grid;place-items:center;padding:24px;background-color:#ffffff;font-family:Arial,Helvetica,sans-serif}.login-wrapper-new{width:min(440px,100%);display:flex;flex-direction:column;align-items:center}.login-brand-box{width:100%;display:flex;align-items:center;gap:16px;background:#ffffff;border:1px solid #f0f0f0;border-radius:12px;padding:18px 24px;box-shadow:0 4px 12px rgba(0,0,0,.02);margin-bottom:32px}.login-logo-img{object-fit:contain;mix-blend-mode:multiply;border-radius:4px}.login-brand-text strong{display:block;font-size:14px;line-height:1.3;color:#b9192f;text-transform:uppercase}.login-brand-text span{display:block;color:#245c99;font-size:13px;font-style:italic;margin-top:4px}.login-title-new{margin:0 0 28px;font-size:24px;color:#1a2530;font-weight:700;text-align:center}.login-card-new{width:100%;background:#ffffff;border:1px solid #e1e4e8;border-radius:8px;overflow:hidden;box-shadow:0 8px 24px rgba(28,41,61,.04);margin-bottom:40px}.login-tabs-new{display:flex;border-bottom:1px solid #e1e4e8;background:#ffffff}.login-tab-new{flex:1 1;display:flex;align-items:center;justify-content:center;gap:8px;min-height:48px;border:0;background:transparent;color:#5c6c7f;font-size:14px;font-weight:600;border-bottom:2px solid transparent;cursor:pointer}.login-tab-new.active{color:#032b5f;background:#eef3fc;border-bottom:2px solid #032b5f}.login-form-new{padding:30px;gap:22px}.input-group-new,.login-form-new{display:flex;flex-direction:column}.input-group-new{gap:8px}.input-group-new label{font-size:13px;font-weight:600;color:#445468}.input-group-new small{font-size:12px;color:#8c98a4;margin-left:2px}.input-with-icon-new{position:relative;display:flex;align-items:center}.input-with-icon-new svg{position:absolute;left:14px;pointer-events:none}.input-with-icon-new input{width:100%;padding:12px 14px 12px 42px;border:1px solid #d0d7df;border-radius:6px;font-size:14px;background:#ffffff;color:#1a2530;transition:border-color .2s,box-shadow .2s}.input-with-icon-new input:focus{border-color:#89a3c9;box-shadow:0 0 0 3px rgba(137,163,201,.2);outline:none}.login-submit-new{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;min-height:46px;background:#7a8898;color:#ffffff;border:0;border-radius:6px;font-size:15px;font-weight:700;cursor:pointer;margin-top:6px;transition:background .2s}.login-submit-new:hover{background:#647384}.login-secondary-new{width:100%;min-height:40px;background:#ffffff;color:#032b5f;border:1px solid #d0d7df;border-radius:6px;font-size:14px;font-weight:700;cursor:pointer;transition:background .2s,border-color .2s}.login-secondary-new:hover{background:#f3f6fa;border-color:#89a3c9}.login-secondary-new:disabled{cursor:not-allowed;opacity:.65}.login-footer-new{color:#8c98a4;font-size:12px;text-align:center}