:root{--topbar-h: 56px;--z-topbar: 2000;--z-sidebar-overlay: 2100;--z-sidebar: 2200;--z-panel-overlay: 2300;--z-sidepanel: 2400;--z-topbar-underlay: 1500}@media(max-width:900px){.topbar{position:fixed;top:env(safe-area-inset-top,0px);left:0;right:0;height:var(--topbar-h);z-index:var(--z-topbar);background:var(--bg, #0b0f16);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;border-bottom:1px solid var(--border, rgba(255, 255, 255, .08))}.main{padding-top:calc(var(--topbar-h) + env(safe-area-inset-top,0px));width:100%;margin-left:0}.content{min-width:0}.sidebar-overlay,.panel-overlay{position:fixed;inset:0}.sidebar,.sidepanel{position:fixed;top:0;bottom:0}.sidebar-overlay{z-index:var(--z-sidebar-overlay)}.sidebar{z-index:var(--z-sidebar)}.panel-overlay{z-index:var(--z-panel-overlay)}.sidepanel{z-index:var(--z-sidepanel)}.app.sidebar-open .topbar,.app.panel-open .topbar{z-index:var(--z-topbar-underlay)}}.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast{display:flex;align-items:center;gap:12px;min-width:300px;max-width:500px;padding:14px 16px;background:#fff;border-radius:12px;box-shadow:0 10px 40px #10182826;border:1px solid var(--border);animation:slideIn .3s ease;pointer-events:auto}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.toast-icon{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:14px;font-weight:900;flex-shrink:0}.toast-success .toast-icon{background:#22c55e1f;color:#22c55e}.toast-error .toast-icon{background:#ef44441f;color:#ef4444}.toast-info .toast-icon{background:#3b82f61f;color:#3b82f6}.toast-warning .toast-icon{background:#f59e0b1f;color:#f59e0b}.toast-message{flex:1;font-size:13px;font-weight:600;color:#111827e6;line-height:1.4}.toast-close{width:20px;height:20px;border:none;background:none;cursor:pointer;opacity:.5;transition:opacity .2s;padding:0;display:grid;place-items:center}.toast-close:hover{opacity:1}@media(max-width:680px){.toast-container{left:10px;right:10px;top:10px}.toast{min-width:auto;width:100%}}.spinner{display:inline-block;position:relative}.spinner-sm{width:16px;height:16px}.spinner-md{width:24px;height:24px}.spinner-lg{width:40px;height:40px}.spinner-circle{width:100%;height:100%;border:2px solid rgba(46,120,212,.2);border-top-color:#2e78d4e6;border-radius:50%;animation:spin .6s linear infinite}.spinner-fullscreen{position:fixed;inset:0;display:grid;place-items:center;background:#fffc;z-index:9998}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.empty-icon{width:80px;height:80px;border-radius:50%;background:linear-gradient(180deg,#1118270a,#11182705);display:grid;place-items:center;margin-bottom:20px;color:#1118274d}.empty-icon svg{width:32px;height:32px}.empty-title{font-size:16px;font-weight:700;color:#111827b3;margin-bottom:8px}.empty-description{font-size:13px;color:#11182780;max-width:400px;line-height:1.5;margin-bottom:20px}.empty-action{margin-top:12px}.search-input-wrapper{position:relative;display:flex;align-items:center;width:100%;max-width:400px}.search-input-wrapper svg{position:absolute;left:14px;width:18px;height:18px;color:#11182766;pointer-events:none}.search-input{width:100%;height:44px;padding:0 40px 0 44px;border:1px solid var(--border);border-radius:12px;font-size:14px;outline:none;transition:all .2s;background:#fff}.search-input:focus{border-color:#2e78d466;box-shadow:0 0 0 3px #2e78d414}.search-input::placeholder{color:#11182766}.search-clear{position:absolute;right:10px;width:24px;height:24px;border:none;background:#11182714;border-radius:50%;cursor:pointer;font-size:18px;line-height:1;color:#11182799;transition:all .2s;display:grid;place-items:center}.search-clear:hover{background:#1118271f}@media(max-width:680px){.search-input-wrapper{max-width:100%}}:root{--border: rgba(17,24,39,.12)}.login{min-height:100vh;display:grid;place-items:center;padding:18px;background:radial-gradient(900px 600px at 20% 10%,rgba(46,120,212,.14),transparent 55%),radial-gradient(900px 600px at 80% 90%,rgba(16,185,129,.1),transparent 55%),#0b0f14;-webkit-text-size-adjust:100%}.login-card{width:min(460px,100%);border-radius:18px;border:1px solid var(--border);background:#ffffffeb;box-shadow:0 18px 60px #00000038;padding:18px;overflow:visible}.login .btn{appearance:none;border:1px solid var(--border);background:#fff;color:#111827e0;border-radius:12px;padding:10px 12px;font-size:12px;font-weight:1000;cursor:pointer;line-height:1;box-shadow:0 10px 24px #1018280f;transition:transform .14s ease,box-shadow .14s ease,background .14s ease,border-color .14s ease,color .14s ease}.login .btn:hover{transform:translateY(-1px);box-shadow:0 14px 30px #1018281a}.login .btn:active{transform:translateY(0);box-shadow:0 10px 22px #10182814}.login .btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.login .btn.primary{border-color:#2e78d442;background:#2e78d424;color:#1e40affa}.login .btn.ghost{border-color:#0f172a2e;background:#0f172a0f;color:#0f172adb}.login .btn.ghost:hover{border-color:#2e78d459;background:#2e78d41a;color:#1e40affa}.login-actions .btn.ghost:last-child{border-color:#ef444447;background:#ef444414;color:#b91c1cf2}.login-actions .btn.ghost:last-child:hover{border-color:#ef444466;background:#ef44441f;color:#991b1bfa}.login .login-actions{display:flex;gap:10px;margin-top:12px;justify-content:flex-end;flex-wrap:wrap}.login .login-actions .btn{min-width:140px}.login-card2{padding:0;overflow:hidden}.login-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;border-bottom:1px solid var(--border);background:#f4f7ffa6}.login-brand{display:flex;align-items:center;gap:10px}.login-mark2{width:44px;height:44px;border-radius:14px;background:#2e78d424;color:#2e78d4f2;display:grid;place-items:center;font-weight:1000;letter-spacing:.5px}.login-brand-title{font-weight:1000;font-size:14px;color:#111827eb;line-height:1.1}.login-brand-sub{margin-top:2px;font-size:12px;color:#1118278c}.login-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:#fff;font-size:12px;font-weight:1000;color:#1118279e}.login-badge.ok{border-color:#10b98133;background:#10b9811a;color:#10b981f2}.login-dot{width:8px;height:8px;border-radius:999px;background:#6b7280a6}.login-badge.ok .login-dot{background:#10b981f2}.login-body2{padding:18px}.login-title2{margin:6px 0;font-size:20px;font-weight:1000;color:#111827eb}.login-sub2{margin:0;color:#11182799;font-size:12px;line-height:1.45}.login-alert{margin-top:12px;border-radius:12px;padding:10px 12px;font-size:12px;font-weight:1000;border:1px solid rgba(46,120,212,.18);background:#2e78d414;color:#0b1f4be0}.login-alert.error{border:1px solid rgba(239,68,68,.25);background:#ef444414;color:#ef4444f2}.login-widgetbox{margin-top:14px;border:1px solid var(--border);background:#fff;border-radius:14px;box-shadow:0 6px 18px #1018280f;padding:12px}.login-widgetlabel{font-size:11px;font-weight:1000;color:#1118278c;margin-bottom:10px}.login-widgetbox #telegram-login-wrap{display:grid;place-items:center;min-height:44px}.login-loading{margin-top:10px;text-align:center;font-size:12px;font-weight:1000;color:#1118278c}.login-info{margin-top:14px;border:1px solid var(--border);background:#2e78d40d;border-radius:14px;padding:12px}.login-info-title{font-size:12px;font-weight:1000;color:#111827b8;margin-bottom:8px}.login-info-list{margin:0;padding-left:18px;color:#1118279e;font-size:12px;line-height:1.5}.login-footnote{margin-top:12px;text-align:center;font-size:12px;color:#11182780}@media(max-width:420px){.login{padding:12px}.login-head,.login-body2{padding:14px}.login-title2{font-size:18px}.login .login-actions{justify-content:stretch}.login .login-actions .btn{flex:1;min-width:0}}:root{--navy-1: #0b1f4b;--navy-2: #0a2a67;--blue: #2e78d4;--bg: #f4f7ff;--card: #ffffff;--muted: rgba(17, 24, 39, .55);--text: rgba(17, 24, 39, .92);--border: rgba(17, 24, 39, .08);--shadow: 0 10px 30px rgba(16, 24, 40, .08);--success: #10b981;--warning: #f59e0b;--error: #ef4444;--topbar-h: 56px;--z-topbar: 2000;--z-sidebar-overlay: 2100;--z-sidebar: 2200;--z-panel-overlay: 2300;--z-sidepanel: 2400;--z-modal-overlay: 2500;--z-modal: 2600;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Apple SD Gothic Neo,Noto Sans KR,Arial,Helvetica Neue,sans-serif}*{box-sizing:border-box}html,body{height:100%}body{margin:0;background:var(--bg);color:var(--text)}a{color:inherit;text-decoration:none}.app{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{background:linear-gradient(180deg,var(--navy-2),var(--navy-1));padding:18px 14px;display:flex;flex-direction:column;gap:14px;overflow-y:auto}.sb-top{display:grid;place-items:center;text-align:center;gap:10px;padding:8px 8px 12px;border-bottom:1px solid rgba(255,255,255,.12)}.logo{width:56px;height:56px;border-radius:999px;background:#ffffff24;display:grid;place-items:center}.logo-mark{width:28px;height:28px;border-radius:10px;background:#ffffffeb;color:var(--navy-2);display:grid;place-items:center;font-weight:900;text-transform:lowercase}.sb-title{color:#ffffffeb;font-weight:700;font-size:14px}.sb-sub{color:#ffffffa6;font-size:12px}.sb-links{display:flex;flex-direction:column;gap:6px;padding-top:4px}.sb-link{display:grid;grid-template-columns:22px 1fr 18px;align-items:center;gap:10px;padding:10px;border-radius:8px;color:#ffffffc7}.sb-link:hover{background:#ffffff14}.sb-link.active{background:#2e78d4e6;color:#fffffff2}.sb-ic{display:grid;place-items:center}.sb-arrow{opacity:.7;text-align:right}.sb-divider{height:1px;background:#ffffff1f;margin:12px 0}.sb-foot{margin-top:auto;padding-top:12px;border-top:1px solid rgba(255,255,255,.12);display:flex;flex-direction:column;gap:10px}.sb-user{color:#ffffffe6;font-size:12px}.sb-user-email{font-weight:600}.sb-user-meta{margin-top:6px;display:flex;gap:6px;flex-wrap:wrap}.pill{padding:4px 8px;border-radius:999px;background:#ffffff24;color:#ffffffe6;font-size:11px}.main{display:flex;flex-direction:column;min-width:0}.topbar{height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 22px;background:#ffffffb3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);z-index:var(--z-topbar)}.topbar-right{display:flex;align-items:center;gap:10px}.topbar-user{font-size:12px;color:#111827a6}.content{padding:22px;overflow-y:auto;min-width:0}.stack{display:flex;flex-direction:column;gap:14px}.pagehead{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}.h1{font-size:18px;font-weight:700}.h2{font-size:14px;font-weight:700}.actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.card{background:var(--card);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);overflow:hidden}.cardhead{padding:14px 16px;display:flex;align-items:baseline;justify-content:space-between;gap:10px;border-bottom:1px solid var(--border)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.kpi{background:var(--card);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:14px 16px}.kpi-title{color:#1118278c;font-size:12px}.kpi-value{margin-top:8px;font-size:28px;font-weight:800;color:#111827eb}.kpi-trend{margin-top:6px;font-size:11px;font-weight:800;color:var(--success)}.btn{border:1px solid rgba(46,120,212,.22);background:#2e78d4eb;color:#fff;padding:10px 12px;border-radius:8px;cursor:pointer;font-weight:600;font-size:12px;display:inline-flex;align-items:center;gap:6px}.btn:hover{filter:brightness(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.secondary{background:#2e78d41f;color:#2e78d4f2;border-color:#2e78d438}.btn.ghost{background:#ffffff1a;border-color:#ffffff2e;color:#ffffffeb}.btn.ghost:hover{background:#ffffff24}.iconbtn{width:36px;height:36px;display:grid;place-items:center;border-radius:10px;border:1px solid var(--border);background:#fff;cursor:pointer}.iconbtn:hover{background:#2e78d40f}.input{display:flex;align-items:center;gap:8px;border:1px solid var(--border);background:#fff;border-radius:10px;padding:10px 12px;min-width:240px;box-shadow:var(--shadow)}.input input{border:none;outline:none;width:100%;font-size:12px;color:#111827d9}.input-ic{color:#11182773;display:grid;place-items:center}.table-wrap{width:100%;overflow:auto;-webkit-overflow-scrolling:touch}.table{width:100%;border-collapse:collapse;font-size:12px}.table th,.table td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}.table th{color:#1118278c;font-weight:700;background:#f4f7ffb3;position:sticky;top:0;z-index:10}.table tbody tr:nth-child(2n) td{background:#f4f7ffb3}.muted{color:var(--muted)}.small{font-size:12px}.login{height:100vh;display:grid;place-items:center;background:radial-gradient(900px 500px at 20% 10%,rgba(46,120,212,.12),transparent 60%),radial-gradient(900px 500px at 80% 20%,rgba(11,31,75,.1),transparent 60%),var(--bg)}.login-card{width:min(520px,92vw);background:#fff;border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);padding:18px}.login-mark{width:48px;height:48px;border-radius:999px;background:#2e78d41f;color:#2e78d4f2;display:grid;place-items:center;font-weight:900;text-transform:lowercase}.login-card h1{margin:10px 0 6px;font-size:20px}.row{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}.row-click{cursor:pointer}.row-click:hover td{background:#2e78d40f!important}button.mini{padding:6px 10px;border-radius:8px;border:1px solid rgba(46,120,212,.22);background:#2e78d41a;color:#2e78d4f2;font-weight:800;font-size:12px;cursor:pointer}button.mini:hover{background:#2e78d424}.sidebar-overlay{position:fixed;inset:0;background:#0006;opacity:0;pointer-events:none;transition:opacity .16s ease;z-index:var(--z-sidebar-overlay)}.sidebar-overlay.open{opacity:1;pointer-events:auto}.panel-overlay{position:fixed;inset:0;background:#0006;opacity:0;pointer-events:none;transition:opacity .16s ease;z-index:var(--z-panel-overlay)}.panel-overlay.open{opacity:1;pointer-events:auto}.sidepanel{position:fixed;top:0;right:0;width:360px;max-width:92vw;height:100vh;background:#fff;border-left:1px solid var(--border);box-shadow:0 10px 40px #10182824;transform:translate(100%) translateZ(0);transition:transform .18s ease;z-index:var(--z-sidepanel);overflow:auto}.sidepanel.open{transform:translate(0) translateZ(0)}.panel-x{position:sticky;top:10px;margin-left:auto;margin-right:12px;margin-top:10px;width:34px;height:34px;border-radius:12px;border:1px solid var(--border);background:#fff;cursor:pointer;font-size:18px;line-height:1;z-index:2}.panel-x:hover{background:#2e78d40f}.profile{padding:8px 18px 14px;text-align:center}.profile-id{margin-top:8px;font-weight:800;color:#11182799;font-size:13px;word-break:break-all}.profile-id a{transition:color .15s ease}.profile-id a:hover{color:#2e78d4f2;text-decoration:underline}.profile-avatar{width:120px;height:120px;margin:12px auto 10px;border-radius:999px;background:linear-gradient(180deg,#1118270f,#11182705);display:grid;place-items:center;overflow:hidden}.profile-avatar img{width:100%;height:100%;object-fit:cover}.profile-avatar-fallback{width:112px;height:112px;border-radius:999px;background:#2e78d41a;color:#2e78d4f2;display:grid;place-items:center;font-weight:900;font-size:44px}.profile-name{font-weight:900;font-size:16px;color:#111827eb}.profile-sub{margin-top:6px;font-size:12px;color:#1118278c}.profile-actions{margin-top:12px;display:flex;justify-content:center;gap:10px}.profile-act{width:44px;height:44px;border-radius:12px;border:1px solid var(--border);background:#f4f7ffbf;cursor:pointer;display:grid;place-items:center;color:#111827bf}.profile-act:hover{background:#2e78d414;color:#2e78d4f2}.profile-act.disabled{opacity:.45;cursor:not-allowed}.profile-act.disabled:hover{background:#f4f7ffbf;color:#111827bf}.profile-act.telegram{color:#08c}.profile-act.telegram:hover{background:#0088cc14;color:#08c}.profile-act.telegram.disabled{color:#0088cc59}.profile-quick{margin-top:12px;display:flex;justify-content:center}.profile-status-toggle{margin-top:12px;display:flex;gap:8px;justify-content:center}.status-btn{padding:8px 16px;border-radius:8px;border:1px solid var(--border);background:#f4f7ffbf;color:#111827a6;font-size:12px;font-weight:700;cursor:pointer;transition:all .12s ease}.status-btn:hover{background:#2e78d414;border-color:#2e78d438}.status-btn.active{background:#2e78d41f;color:#2e78d4f2;border-color:#2e78d46b}.profile-section{padding:12px 18px 0}.profile-section-title{font-weight:900;font-size:12px;color:#111827b8;text-align:left;margin-bottom:8px}.profile-about{text-align:left;font-size:12px;color:#1118279e;line-height:1.45;background:#f4f7ffa6;border:1px solid var(--border);border-radius:14px;padding:12px}.profile-grid{padding:12px 18px 0;display:grid;grid-template-columns:1fr 1fr;gap:10px}.profile-field{border:1px solid var(--border);background:#fff;border-radius:14px;padding:12px;box-shadow:0 6px 18px #1018280f}.profile-k{font-size:11px;font-weight:900;color:#1118278c}.profile-v{margin-top:6px;font-size:12px;font-weight:900;color:#111827eb;word-break:break-word}.avatar-row{display:flex;align-items:center;gap:8px;padding-bottom:14px}.avatar{width:34px;height:34px;border-radius:999px;border:2px solid #fff;box-shadow:0 8px 18px #1018281a;overflow:hidden;background:#2e78d41f;display:grid;place-items:center;font-weight:900;color:#2e78d4f2}.avatar img{width:100%;height:100%;object-fit:cover}.avatar-more{font-size:12px;font-weight:900;color:#2e78d4f2}.modal-overlay{position:fixed;inset:0;background:#00000052;opacity:0;pointer-events:none;transition:opacity .16s ease;z-index:var(--z-modal-overlay)}.modal-overlay.open{opacity:1;pointer-events:auto}.modal{position:fixed;left:50%;top:50%;transform:translate(-50%,-46%) scale(.98);width:min(720px,92vw);background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 80px #10182838;opacity:0;pointer-events:none;transition:opacity .16s ease,transform .16s ease;z-index:var(--z-modal);overflow:hidden}.modal.open{opacity:1;pointer-events:auto;transform:translate(-50%,-50%) scale(1)}.modal.large{width:min(1000px,92vw)}.modal-head{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px}.modal-title{font-weight:900;font-size:14px}.modal-x{width:34px;height:34px;border-radius:12px;border:1px solid var(--border);background:#fff;cursor:pointer;font-size:18px;line-height:1}.modal-x:hover{background:#2e78d40f}.modal-body{padding:14px 16px 16px;max-height:calc(90vh - 80px);overflow-y:auto}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-size:11px;font-weight:900;color:#11182799}.text{width:100%;border:1px solid var(--border);border-radius:12px;padding:10px 12px;font-size:12px;outline:none;background:#fff}.text:focus{border-color:#2e78d46b;box-shadow:0 0 0 3px #2e78d41f}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:6px}.form-error{border:1px solid rgba(239,68,68,.25);background:#ef444414;color:#ef4444f2;padding:10px 12px;border-radius:12px;font-weight:800;font-size:12px}.pagination{display:flex;justify-content:center;align-items:center;gap:6px;padding:14px 16px;border-top:1px solid var(--border)}.page-btn{min-width:36px;height:36px;padding:0 10px;border-radius:8px;border:1px solid var(--border);background:#fff;color:#111827b8;font-size:12px;font-weight:700;cursor:pointer;display:grid;place-items:center;transition:all .12s ease}.page-btn:hover:not(:disabled){background:#2e78d40f;border-color:#2e78d438}.page-btn.active{background:#2e78d41f;color:#2e78d4f2;border-color:#2e78d46b}.page-btn:disabled{opacity:.4;cursor:not-allowed}.page-ellipsis{padding:0 6px;color:#11182773}.status-badge{padding:4px 10px;border-radius:6px;font-size:11px;font-weight:800;text-transform:lowercase}.status-badge.active{background:#10b9811f;color:#10b981f2}.status-badge.inactive{background:#6b72801f;color:#6b7280f2}.chart-container{padding:4px 0}.chart-title{font-size:13px;font-weight:800;color:#111827b8;margin-bottom:12px}.bar-chart{display:flex;flex-direction:column;gap:10px}.bar-item{display:flex;flex-direction:column;gap:6px}.bar-label{font-size:11px;font-weight:800;color:#111827a6}.bar-wrapper{position:relative;height:28px;background:#f4f7ffbf;border-radius:8px;overflow:hidden}.bar-fill{position:absolute;left:0;top:0;height:100%;background:linear-gradient(90deg,#2e78d4bf,#2e78d4eb);border-radius:8px;transition:width .32s ease}.bar-value{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:11px;font-weight:800;color:#111827b8;z-index:1}.setting-row{padding:12px 0;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:6px}.setting-row:last-child{border-bottom:none}.setting-label{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:700;color:#111827d9;cursor:pointer}.setting-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}@media(max-width:980px){.app{grid-template-columns:1fr}.sidebar{position:fixed;top:0;bottom:0;width:260px;height:100vh;z-index:var(--z-sidebar);transform:translate(-100%);transition:transform .18s ease}.sidebar.open{transform:translate(0)}.topbar{position:fixed;top:env(safe-area-inset-top,0px);left:0;right:0;height:var(--topbar-h);padding:12px 16px;z-index:var(--z-topbar);background:#ffffffd9;border-bottom:1px solid var(--border)}.main{padding-top:calc(var(--topbar-h) + env(safe-area-inset-top,0px));width:100%;margin-left:0}.topbar-left,.topbar-right{gap:8px}.topbar-user{display:none}.iconbtn{min-width:40px;min-height:40px}.hamburger{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:1px solid var(--border);border-radius:8px;background:#fff;cursor:pointer;transition:background .12s ease;margin-right:12px;flex-shrink:0}.hamburger:hover{background:var(--bg)}.hamburger:active{transform:scale(.95)}.content{padding:16px}.kpi-grid{grid-template-columns:1fr;gap:12px}.pagehead{flex-direction:column;align-items:flex-start;gap:12px}.actions{width:100%;flex-wrap:wrap;gap:8px}.btn,button{min-height:44px;font-size:14px}.input{min-width:200px;min-height:44px;font-size:16px}.grid2{grid-template-columns:1fr}.sidepanel{width:100%;max-width:100vw}}@media(max-width:680px){.content{padding:12px}.grid2{grid-template-columns:1fr}.pagehead{flex-direction:column;align-items:flex-start;gap:12px}.actions{width:100%;flex-direction:column}.actions>*{width:100%}.input{width:100%;min-width:auto}.kpi-value{font-size:22px}.table-wrap{overflow:visible}.table,.table thead,.table tbody,.table tr,.table th,.table td{display:block}.table thead{position:absolute;top:-9999px;left:-9999px}.table tr{margin-bottom:12px;border:1px solid var(--border);border-radius:12px;padding:14px;background:var(--card);box-shadow:0 4px 12px #1018280f}.table td{border:none;position:relative;padding:8px 0 8px 40%;text-align:right;white-space:normal}.table td:before{content:attr(data-label);position:absolute;left:0;width:38%;padding-right:10px;text-align:left;font-weight:700;color:var(--muted);font-size:11px}.table tbody tr:nth-child(2n) td{background:transparent}.profile-avatar{width:80px;height:80px}.profile-name{font-size:18px}.profile-grid{grid-template-columns:1fr}.hamburger{width:38px;height:38px}}@media(max-width:480px){.content{padding:10px}.kpi{padding:12px}.kpi-value{font-size:20px}.btn{font-size:13px;padding:0 14px}.sidebar{width:240px}}@media(min-width:981px){.hamburger,.sidebar-overlay{display:none}}@media(hover:none)and (pointer:coarse){.btn,button,.iconbtn{-webkit-tap-highlight-color:rgba(46,120,212,.1)}a,button,.btn,.iconbtn,.sb-link{min-width:44px;min-height:44px}.btn:hover,button:hover{transform:none}}@supports (padding: env(safe-area-inset-left)){.topbar{padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right))}.content{padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right));padding-bottom:max(16px,env(safe-area-inset-bottom))}.sidebar{padding-left:max(14px,env(safe-area-inset-left))}}@media(max-width:980px){body{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%}.table-wrap,.content{-webkit-overflow-scrolling:touch;scroll-behavior:smooth}}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media(-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.logo-mark,.profile-avatar,.avatar{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}.period-tabs{display:flex;gap:8px;flex-wrap:wrap}@media(max-width:680px){.period-tabs{display:grid;grid-template-columns:repeat(2,1fr)}.period-tabs button{padding:10px 12px!important;font-size:13px!important}}.filter-group{display:flex;gap:10px;align-items:center;flex-wrap:wrap}@media(max-width:680px){.filter-group{display:grid;grid-template-columns:1fr;gap:10px}.filter-group>*{width:100%;max-width:100%}}.chart-scroll-container{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}@media(max-width:680px){.chart-scroll-container::-webkit-scrollbar{height:4px}.chart-scroll-container::-webkit-scrollbar-thumb{background:#0003;border-radius:2px}}.hide-mobile{display:block}@media(max-width:680px){.hide-mobile{display:none!important}}.show-mobile{display:none}@media(max-width:680px){.show-mobile{display:block!important}}.mobile-stack{display:flex;gap:10px}@media(max-width:680px){.mobile-stack{flex-direction:column}}@media(max-width:680px){select.input,select.text,.actions select{width:100%;min-height:44px;font-size:16px;padding:12px}}.form-buttons{display:flex;gap:10px;margin-top:20px}@media(max-width:680px){.form-buttons{flex-direction:column-reverse}.form-buttons button{width:100%}}.responsive-flex{display:flex;gap:12px;flex-wrap:wrap}@media(max-width:680px){.responsive-flex{flex-direction:column}}.scroll-hint{position:relative}@media(max-width:680px){.scroll-hint:after{content:"";position:absolute;right:0;top:0;bottom:0;width:40px;background:linear-gradient(to left,rgba(244,247,255,1),transparent);pointer-events:none}}@media(max-width:680px){.card+.card{margin-top:12px}.stack>*+*{margin-top:14px}}.chart-legend{display:flex;gap:16px;margin-bottom:12px;font-size:12px;flex-wrap:wrap}@media(max-width:480px){.chart-legend{gap:10px;font-size:11px}.chart-legend-item{flex:0 0 auto}}.mobile-full{width:auto}@media(max-width:680px){.mobile-full{width:100%!important;max-width:100%!important}}.mobile-compact{padding:16px}@media(max-width:680px){.mobile-compact{padding:12px}}@media(max-width:480px){.mobile-compact{padding:10px}}
