:root{--bg:#f0f2f5;--surface:#fff;--border:#e5e7eb;--primary:#3b82f6;--primary-dark:#2563eb;--primary-light:#eff6ff;--text-1:#111827;--text-2:#6b7280;--text-3:#9ca3af;--green:#10b981;--green-bg:#ecfdf5;--red:#ef4444;--red-bg:#fef2f2;--warning:#f59e0b;--warning-bg:#fffbeb;--warning-border:#fde68a;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 16px #0000001a;--radius-sm:8px;--radius-md:12px;--sidebar-width:224px;--header-height:60px;--font:-apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans KR", sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--text-1);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}#root{height:100vh}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none}input{font-family:inherit;font-size:inherit}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--surface);border-right:1px solid var(--border);flex-direction:column;height:100vh;transition:transform .25s;display:flex;overflow:hidden}.sidebar__logo{height:var(--header-height);border-bottom:1px solid var(--border);color:var(--text-1);flex-shrink:0;align-items:center;gap:8px;padding:0 20px;font-size:15px;font-weight:700;display:flex}.sidebar__logo-icon{color:var(--primary)}.sidebar__close{color:var(--text-3);border-radius:6px;margin-left:auto;padding:4px;transition:background .15s;display:none}.sidebar__close:hover{background:var(--bg);color:var(--text-2)}.sidebar__user{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:10px;padding:16px 20px;display:flex}.sidebar__avatar{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:600;display:flex}.sidebar__username{color:var(--text-1);align-items:center;gap:6px;font-size:13px;font-weight:600;display:flex}.sidebar__admin-badge{background:var(--primary);color:#fff;letter-spacing:.02em;border-radius:10px;padding:1px 6px;font-size:10px;font-weight:700}.sidebar__date{color:var(--text-3);margin-top:1px;font-size:11px}.sidebar__nav{flex-direction:column;flex:1;gap:2px;padding:12px 10px;display:flex;overflow-y:auto}.sidebar__nav-item{border-radius:var(--radius-sm);color:var(--text-2);align-items:center;gap:10px;padding:9px 12px;font-size:13.5px;transition:background .15s,color .15s;display:flex}.sidebar__nav-item:hover{background:var(--bg);color:var(--text-1)}.sidebar__nav-item--active{background:var(--primary-light);color:var(--primary);font-weight:600}.sidebar__nav-icon{width:18px;height:18px;color:var(--text-3);flex-shrink:0}.sidebar__nav-item--active .sidebar__nav-icon{color:var(--primary)}.sidebar__footer{border-top:1px solid var(--border);flex-shrink:0;padding:12px 10px}.sidebar__settings{border-radius:var(--radius-sm);color:var(--text-2);align-items:center;gap:10px;width:100%;padding:9px 12px;font-size:13.5px;transition:background .15s;display:flex}.sidebar__settings:hover{background:var(--bg);color:var(--text-1)}.sidebar__logout:hover{background:var(--red-bg);color:var(--red)}.sidebar__logout:hover .sidebar__nav-icon{color:var(--red)}@media (width<=768px){.sidebar{z-index:110;width:240px;min-width:240px;box-shadow:none;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar--open{transform:translate(0)}.sidebar__close{display:flex}.sidebar__logo{font-size:14px}.sidebar__nav-item{padding:11px 12px;font-size:14px}}.header{height:var(--header-height);background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:12px;padding:0 24px;display:flex}.header__menu-btn{width:36px;height:36px;color:var(--text-2);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s;display:none}.header__menu-btn:hover{background:var(--bg)}.header__search-wrap{flex:1;max-width:400px;position:relative}.header__search{position:relative}.header__search-icon{color:var(--text-3);width:16px;height:16px;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.header__search input{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text-1);border-radius:8px;outline:none;padding:8px 12px 8px 36px;transition:border-color .15s}.header__search input:focus{border-color:var(--primary);background:var(--surface)}.header__search input::placeholder{color:var(--text-3)}.header__search-dropdown{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-md);z-index:999;border-radius:10px;padding:4px 0;list-style:none;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow:hidden}.header__search-item{cursor:pointer;align-items:center;gap:8px;padding:8px 14px;transition:background .1s;display:flex}.header__search-item:hover,.header__search-item--focused{background:var(--bg)}.header__search-ticker{color:var(--text-1);min-width:60px;font-size:13px;font-weight:600}.header__search-name{color:var(--text-2);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:12px;overflow:hidden}.header__search-exch{color:var(--text-3);flex-shrink:0;font-size:11px}.header__right{align-items:center;gap:8px;margin-left:auto;display:flex}.header__realtime{color:var(--green);background:#f0fdf4;border:1px solid #d1fae5;border-radius:20px;align-items:center;gap:6px;padding:5px 10px;font-size:12px;font-weight:600;display:flex}.header__realtime-dot{background:var(--green);border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:2s infinite pulse}.header__realtime-text{white-space:nowrap}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.header__icon-btn{width:36px;height:36px;color:var(--text-2);border-radius:8px;justify-content:center;align-items:center;transition:background .15s;display:flex;position:relative}.header__icon-btn:hover{background:var(--bg);color:var(--text-1)}.header__badge{background:var(--red);border:2px solid var(--surface);border-radius:50%;width:7px;height:7px;position:absolute;top:6px;right:6px}.header__user-wrap{position:relative}.header__avatar{background:var(--primary);color:#fff;cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:700;transition:opacity .15s,box-shadow .15s;display:flex;position:relative}.header__avatar:hover{opacity:.9;box-shadow:0 0 0 3px var(--primary-light)}.header__avatar-dot{background:var(--warning);border:2px solid var(--surface);border-radius:50%;width:9px;height:9px;position:absolute;bottom:0;right:0}.header__dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);width:210px;box-shadow:var(--shadow-md);z-index:200;animation:.15s dropdown-in;position:absolute;top:calc(100% + 10px);right:0;overflow:hidden}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.header__dropdown-info{background:var(--bg);align-items:center;gap:10px;padding:14px 16px;display:flex}.header__dropdown-avatar{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.header__dropdown-name{color:var(--text-1);font-size:13px;font-weight:700}.header__dropdown-role{margin-top:3px}.header__dropdown-admin,.header__dropdown-user{border-radius:10px;align-items:center;gap:4px;padding:2px 7px;font-size:11px;font-weight:600;display:inline-flex}.header__dropdown-admin{background:var(--warning-bg);color:var(--warning);border:1px solid var(--warning-border)}.header__dropdown-user{background:var(--primary-light);color:var(--primary)}.header__dropdown-divider{background:var(--border);height:1px}.header__dropdown-item{width:100%;color:var(--text-2);text-align:left;align-items:center;gap:10px;padding:11px 16px;font-size:13px;transition:background .15s,color .15s;display:flex}.header__dropdown-item:hover{background:var(--bg);color:var(--text-1)}.header__dropdown-item--danger:hover{background:var(--red-bg);color:var(--red)}@media (width<=768px){.header{gap:8px;padding:0 16px}.header__menu-btn{display:flex}.header__search{max-width:none}.header__realtime-text{display:none}.header__realtime{padding:6px 8px}.header__dropdown{left:auto;right:0}}.layout{height:100vh;display:flex;overflow:hidden}.layout__main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.layout__content{flex:1;padding:24px;overflow-y:auto}.layout__backdrop{display:none}@media (width<=768px){.layout__content{padding:16px}.layout__backdrop{z-index:100;background:#0006;display:block;position:fixed;inset:0}}.dashboard{max-width:1400px}@media (width<=768px){.dashboard__title h1{font-size:18px}.dashboard__report-btn span{display:none}.dashboard__report-btn{padding:7px 10px}[data-widget-id=charts],.widget__drag-handle,.widget__drag-placeholder{display:none}.widget__bar{padding:10px 14px}}.dashboard__title{margin-bottom:20px}.dashboard__title h1{color:var(--text-1);font-size:22px;font-weight:700}.dashboard__title p{color:var(--text-2);margin-top:2px;font-size:13px}.dashboard__actions{justify-content:flex-end;margin-bottom:4px;display:flex}.dashboard__report-btn{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-2);background:var(--surface);align-items:center;gap:6px;padding:7px 14px;font-size:13px;transition:background .15s;display:flex}.dashboard__report-btn:hover{background:var(--bg)}.widget{background:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:box-shadow .2s;overflow:hidden}.widget--dragging{box-shadow:var(--shadow-md);opacity:.95;border-color:var(--primary)}.widget__bar{border-bottom:1px solid var(--border);background:#fafafa;align-items:center;gap:8px;min-height:40px;padding:10px 16px;display:flex}.widget__drag-handle{color:var(--text-3);cursor:grab;touch-action:none;border-radius:4px;justify-content:center;align-items:center;padding:2px 4px;transition:color .15s,background .15s;display:flex}.widget__drag-handle:hover{color:var(--text-2);background:var(--border)}.widget__drag-handle:active{cursor:grabbing}.widget__label{color:var(--text-2);flex:1;font-size:12px;font-weight:500}.widget__lock-btn{width:26px;height:26px;color:var(--text-3);border-radius:6px;justify-content:center;align-items:center;transition:color .15s,background .15s;display:flex}.widget__lock-btn:hover{color:var(--text-1);background:var(--border)}.widget__lock-btn--locked{color:var(--primary)}.widget__body{padding:0}.widget--locked{opacity:.92}.widget--locked .widget__bar{background:var(--bg)}.widget__drag-placeholder{flex-shrink:0;width:23px;display:inline-block}.ws-backdrop{z-index:199;position:fixed;inset:0}.ws-popover{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);width:200px;box-shadow:var(--shadow-md);z-index:200;position:absolute;top:calc(100% + 12px);right:0}.ws-popover__tail{background:var(--surface);border-left:1px solid var(--border);border-top:1px solid var(--border);width:10px;height:10px;position:absolute;top:-6px;right:20px;transform:rotate(45deg)}.ws-popover__title{color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;padding:10px 14px 6px;font-size:11px;font-weight:600}.ws-popover__list{padding:4px 0 6px;list-style:none}.ws-popover__item{padding:0}.ws-popover__label{color:var(--text-1);cursor:pointer;align-items:center;gap:10px;padding:8px 14px;font-size:13px;transition:background .12s;display:flex}.ws-popover__label:hover{background:var(--bg)}.ws-popover__checkbox{width:14px;height:14px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.dashboard__report-btn--active{background:var(--bg);border-color:var(--primary);color:var(--primary)}.scr-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.scr-header__title h1{color:var(--text-1);font-size:22px;font-weight:700}.scr-header__title p{color:var(--text-2);margin-top:2px;font-size:13px}.scr-header__actions{align-items:center;gap:8px;display:flex}.scr-btn{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-2);background:var(--surface);cursor:pointer;align-items:center;gap:6px;padding:7px 14px;font-size:13px;transition:background .15s;display:flex}.scr-btn:hover{background:var(--bg)}.scr-btn--primary{background:var(--primary);color:#fff;border-color:var(--primary)}.scr-btn--primary:hover{opacity:.88;background:var(--primary)}.scr-presets{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:12px;padding:14px 16px}.scr-presets__row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.scr-presets__chips{flex-wrap:wrap;gap:8px;display:flex}.scr-market-filter{border:1px solid var(--border);border-radius:var(--radius-sm);flex-shrink:0;display:flex;overflow:hidden}.scr-market-btn{color:var(--text-2);background:var(--surface);border-right:1px solid var(--border);cursor:pointer;white-space:nowrap;padding:5px 14px;font-size:12px;font-weight:500;transition:background .12s,color .12s}.scr-market-btn:last-child{border-right:none}.scr-market-btn:hover{background:var(--bg)}.scr-market-btn--active{background:var(--primary);color:#fff}.scr-chip{border:1.5px solid var(--border);background:var(--surface);color:var(--text-2);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:20px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.scr-chip:hover{border-color:var(--primary);color:var(--primary)}.scr-chip--active{background:var(--primary);border-color:var(--primary);color:#fff}.scr-chip--active:hover{opacity:.85}.scr-chip--disabled{opacity:.38;cursor:not-allowed}.scr-chip__dot{opacity:.8;background:currentColor;border-radius:50%;flex-shrink:0;width:6px;height:6px}.scr-results{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.scr-results__bar{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.scr-results__count{color:var(--text-2);font-size:13px}.scr-results__count strong{color:var(--text-1);font-weight:600}.scr-select{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-2);cursor:pointer;outline:none;padding:5px 10px;font-size:12px}.scr-table-scroll{-webkit-overflow-scrolling:touch;overflow-x:auto}.scr-table{border-collapse:collapse;width:100%;min-width:560px}.scr-table thead tr{border-bottom:1px solid var(--border);background:#f9fafb}.scr-table th{text-align:left;color:var(--text-2);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none;padding:10px 16px;font-size:12px;font-weight:600}.scr-table th:hover{color:var(--text-1)}.scr-table th.sorted{color:var(--primary)}.scr-table td{border-bottom:1px solid var(--border);color:var(--text-1);padding:12px 16px;font-size:13px}.scr-table tbody tr:last-child td{border-bottom:none}.scr-table tbody tr:hover td{background:var(--bg);cursor:pointer}.scr-ticker{font-weight:700}.scr-name{color:var(--text-3);margin-top:2px;font-size:11px}.up{color:var(--green);font-weight:600}.down{color:var(--red);font-weight:600}.scr-badge{border-radius:20px;align-items:center;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.scr-badge--price{background:var(--green-bg);color:var(--green)}.scr-badge--volume{color:#4f46e5;background:#eef2ff}.scr-empty{text-align:center;color:var(--text-3);padding:56px 20px;font-size:14px}.scr-adv-backdrop{z-index:300;background:#0003;position:fixed;inset:0}.scr-adv-panel{background:var(--surface);border-left:1px solid var(--border);z-index:301;flex-direction:column;width:300px;height:100%;display:flex;position:fixed;top:0;right:0;box-shadow:-4px 0 20px #00000014}.scr-adv-panel__header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.scr-adv-panel__title{color:var(--text-1);font-size:15px;font-weight:600}.scr-adv-panel__close{width:28px;height:28px;color:var(--text-3);border-radius:6px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.scr-adv-panel__close:hover{background:var(--bg);color:var(--text-1)}.scr-adv-panel__body{flex-direction:column;flex:1;gap:24px;padding:20px;display:flex;overflow-y:auto}.scr-adv-group{flex-direction:column;gap:12px;display:flex}.scr-adv-group__name{color:var(--text-1);border-bottom:1px solid var(--border);padding-bottom:8px;font-size:13px;font-weight:600}.scr-adv-row{color:var(--text-2);align-items:center;gap:8px;font-size:13px;display:flex}.scr-adv-row label{color:var(--text-2);flex:1;font-size:13px}.scr-input{border:1px solid var(--border);border-radius:var(--radius-sm);width:64px;color:var(--text-1);background:var(--bg);text-align:center;outline:none;padding:5px 8px;font-size:13px;transition:border-color .15s}.scr-input:focus{border-color:var(--primary)}@media (width<=768px){.scr-header{flex-direction:column;gap:12px}.scr-adv-panel{width:100%}}.stock-page{max-width:960px}.stock-nav{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.stock-nav__left{align-items:center;gap:10px;display:flex}.stock-back-btn{border:1px solid var(--border);background:var(--surface);width:32px;height:32px;color:var(--text-2);border-radius:8px;justify-content:center;align-items:center;transition:background .15s;display:flex}.stock-back-btn:hover{background:var(--bg)}.stock-nav__name{color:var(--text-1);font-size:16px;font-weight:700}.stock-nav__ticker{color:var(--text-3);margin-top:2px;font-size:12px}.stock-nav__exch{background:var(--bg);border:1px solid var(--border);color:var(--text-3);border-radius:4px;margin-left:6px;padding:1px 6px;font-size:10px;display:inline-block}.stock-alert-wrap{position:relative}.stock-alert-btn{border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--surface);color:var(--text-2);cursor:pointer;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;transition:all .15s;display:flex}.stock-alert-btn:hover{border-color:var(--primary);color:var(--primary)}.stock-alert-btn--on{border-color:var(--primary);color:var(--primary);background:#eff6ff}.alert-backdrop{z-index:199;position:fixed;inset:0}.alert-popover{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);width:230px;box-shadow:var(--shadow-md);z-index:200;position:absolute;top:calc(100% + 10px);right:0}.alert-popover__tail{background:var(--surface);border-left:1px solid var(--border);border-top:1px solid var(--border);width:10px;height:10px;position:absolute;top:-6px;right:20px;transform:rotate(45deg)}.alert-popover__section-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;padding:12px 14px 6px;font-size:10px;font-weight:700}.alert-popover__list{padding:2px 0 6px}.alert-popover__item label{color:var(--text-1);cursor:pointer;align-items:center;gap:10px;padding:7px 14px;font-size:13px;transition:background .12s;display:flex}.alert-popover__item label:hover{background:var(--bg)}.alert-popover__item input[type=checkbox]{width:14px;height:14px;accent-color:var(--primary);flex-shrink:0}.alert-popover__item-sub{color:var(--text-3);margin-left:auto;font-size:11px}.alert-popover__footer{border-top:1px solid var(--border);padding:8px 10px}.alert-popover__off-btn{border-radius:var(--radius-sm);width:100%;color:var(--red);background:var(--red-bg);padding:7px;font-size:12px;font-weight:500;transition:opacity .15s}.alert-popover__off-btn:hover{opacity:.8}.stock-chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:12px;overflow:hidden}.stock-interval-tabs{border-bottom:1px solid var(--border);flex-wrap:wrap;gap:2px;padding:10px 14px;display:flex}.stock-interval-tab{color:var(--text-3);cursor:pointer;border-radius:20px;padding:4px 11px;font-size:12px;font-weight:500;transition:all .15s}.stock-interval-tab:hover{color:var(--text-1);background:var(--bg)}.stock-interval-tab--active{background:var(--primary);color:#fff}.stock-candle-container{width:100%;padding:4px 0}.tg-register-popup{z-index:200;background:var(--surface);border:1px solid var(--border);width:280px;box-shadow:var(--shadow-md);border-radius:12px;padding:18px 16px 14px;position:absolute;top:calc(100% + 10px);right:0}.tg-register-popup__title{color:var(--text-1);margin-bottom:8px;font-size:14px;font-weight:600}.tg-register-popup__desc{color:var(--text-2);margin-bottom:14px;font-size:12px;line-height:1.6}.tg-register-popup__btn{text-align:center;color:#fff;background:#229ed9;border-radius:8px;margin-bottom:10px;padding:9px 0;font-size:13px;font-weight:500;text-decoration:none;display:block}.tg-register-popup__btn:hover{opacity:.88}.tg-register-popup__loading{color:var(--text-3);text-align:center;padding:8px 0;font-size:12px}.tg-register-popup__hint{color:var(--text-3);text-align:center;font-size:11px}@media (width<=768px){.stock-price-value{font-size:28px}.alert-popover{right:-8px}.stock-interval-tabs{gap:1px;padding:8px 10px}.stock-interval-tab{padding:4px 8px;font-size:11px}}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);width:100%;max-width:420px;padding:36px 36px 32px}.login-logo{align-items:center;gap:8px;margin-bottom:24px;display:flex}.login-logo__icon{color:var(--primary)}.login-logo__text{color:var(--text-1);font-size:16px;font-weight:700}.login-tabs{border-bottom:1px solid var(--border);margin-bottom:24px;display:flex}.login-tab{color:var(--text-3);border-bottom:2px solid #0000;flex:1;margin-bottom:-1px;padding:10px 0;font-size:13px;font-weight:500;transition:color .15s,border-color .15s}.login-tab:hover{color:var(--text-2)}.login-tab--active{color:var(--primary);border-bottom-color:var(--primary);font-weight:700}.login-success{color:var(--green);background:var(--green-bg);border-radius:var(--radius-sm);border:1px solid #a7f3d0;align-items:center;gap:8px;margin-bottom:16px;padding:10px 14px;font-size:12.5px;line-height:1.5;display:flex}.login-form{flex-direction:column;gap:16px;display:flex}.login-field{flex-direction:column;gap:5px;display:flex}.login-field label{color:var(--text-1);font-size:12.5px;font-weight:600}.login-hint{color:var(--text-3);font-size:11.5px;font-weight:400}.login-field input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);width:100%;color:var(--text-1);outline:none;padding:10px 14px;font-size:13.5px;transition:border-color .15s,background .15s}.login-field input:focus{border-color:var(--primary);background:var(--surface)}.login-field input::placeholder{color:var(--text-3)}.login-pw-wrap{position:relative}.login-pw-wrap input{padding-right:40px}.login-pw-toggle{color:var(--text-3);align-items:center;padding:2px;transition:color .15s;display:flex;position:absolute;top:50%;right:11px;transform:translateY(-50%)}.login-pw-toggle:hover{color:var(--text-2)}.login-field-error{color:var(--red);margin-top:1px;font-size:11.5px}.login-textarea{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);width:100%;color:var(--text-1);font-size:13.5px;font-family:var(--font);resize:vertical;outline:none;padding:10px 14px;line-height:1.6;transition:border-color .15s,background .15s}.login-textarea:focus{border-color:var(--primary);background:var(--surface)}.login-textarea::placeholder{color:var(--text-3)}.login-remember{color:var(--text-2);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:7px;margin:-4px 0;font-size:13px;display:flex}.login-remember input[type=checkbox]{width:15px;height:15px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.login-error{color:var(--red);background:var(--red-bg);border-radius:var(--radius-sm);border:1px solid #fecaca;margin:-2px 0;padding:10px 14px;font-size:12.5px;line-height:1.5}.login-btn{background:var(--primary);color:#fff;border-radius:var(--radius-sm);justify-content:center;align-items:center;gap:7px;margin-top:4px;padding:11px;font-size:14px;font-weight:600;transition:background .15s;display:flex}.login-btn:hover:not(:disabled){background:var(--primary-dark)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.admin-page{max-width:960px;padding:28px}@media (width<=768px){.admin-page{padding:0}.admin-header{padding:16px 16px 0}.admin-filters{padding:0 16px}.admin-table-wrap{-webkit-overflow-scrolling:touch;border-left:none;border-right:none;border-radius:0;overflow-x:auto}.admin-table{min-width:560px}.admin-loading,.admin-empty{border-left:none;border-right:none;border-radius:0}}.admin-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.admin-title-row{align-items:center;gap:8px;display:flex}.admin-title-icon{color:var(--primary)}.admin-title{color:var(--text-1);font-size:18px;font-weight:700}.admin-refresh{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-2);background:var(--surface);align-items:center;gap:6px;padding:7px 14px;font-size:13px;transition:background .15s;display:flex}.admin-refresh:hover:not(:disabled){background:var(--bg)}.admin-refresh:disabled{opacity:.5;cursor:not-allowed}.spin{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.admin-filters{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.admin-filter{border:1px solid var(--border);color:var(--text-2);background:var(--surface);border-radius:20px;align-items:center;gap:6px;padding:6px 14px;font-size:12.5px;transition:all .15s;display:flex}.admin-filter:hover{border-color:var(--primary);color:var(--primary)}.admin-filter--active{background:var(--primary-light);border-color:var(--primary);color:var(--primary);font-weight:600}.admin-filter-count{background:var(--bg);color:var(--text-2);border-radius:10px;padding:1px 7px;font-size:11px}.admin-filter--active .admin-filter-count{background:var(--primary);color:#fff}.admin-loading,.admin-empty{text-align:center;color:var(--text-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:48px;font-size:14px}.admin-table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}.admin-table{border-collapse:collapse;width:100%;font-size:13.5px}.admin-table thead{background:var(--bg);border-bottom:1px solid var(--border)}.admin-table th{text-align:left;color:var(--text-2);white-space:nowrap;padding:11px 16px;font-size:12px;font-weight:600}.admin-table td{border-bottom:1px solid var(--border);vertical-align:top;padding:13px 16px}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr:hover{background:var(--bg)}.admin-td-username{color:var(--text-1);white-space:nowrap;font-weight:600}.admin-td-date{color:var(--text-3);white-space:nowrap;font-size:12.5px}.admin-td-msg{color:var(--text-2);max-width:300px;line-height:1.5}.admin-no-msg{color:var(--text-3)}.admin-status{white-space:nowrap;border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.status--pending{background:var(--warning-bg);color:var(--warning);border:1px solid var(--warning-border)}.status--approved{background:var(--green-bg);color:var(--green);border:1px solid #a7f3d0}.status--rejected{background:var(--red-bg);color:var(--red);border:1px solid #fecaca}.admin-actions{gap:6px;display:flex}.admin-btn{border-radius:var(--radius-sm);padding:5px 12px;font-size:12.5px;font-weight:600;transition:opacity .15s}.admin-btn:disabled{opacity:.5;cursor:not-allowed}.admin-btn--approve{background:var(--green);color:#fff}.admin-btn--approve:hover:not(:disabled){opacity:.85}.admin-btn--reject{background:var(--red);color:#fff}.admin-btn--reject:hover:not(:disabled){opacity:.85}.admin-processed{color:var(--text-3);font-size:12px}.notfound-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.notfound-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);text-align:center;width:100%;max-width:400px;padding:56px 48px}.notfound-icon{color:var(--text-3);margin-bottom:16px}.notfound-code{color:var(--primary);letter-spacing:-2px;margin-bottom:12px;font-size:64px;font-weight:800;line-height:1}.notfound-title{color:var(--text-1);margin-bottom:8px;font-size:17px;font-weight:700}.notfound-desc{color:var(--text-2);margin-bottom:28px;font-size:13.5px;line-height:1.6}.notfound-btn{background:var(--primary);color:#fff;border-radius:var(--radius-sm);align-items:center;gap:7px;padding:10px 22px;font-size:14px;font-weight:600;transition:background .15s;display:inline-flex}.notfound-btn:hover{background:var(--primary-dark)}
