@import url("https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Noto+Sans+KR:wght@300;400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600&display=swap");:root{--bg-base:#000;--bg-surface:#0d0d0d;--bg-elevated:#141414;--bg-hover:#1a1a1a;--bg-active:#222;--bg-gradient:radial-gradient(ellipse at 20% 50%,rgba(40,40,40,.4) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(35,35,35,.35) 0%,transparent 55%),linear-gradient(160deg,#0e0e0e,#111 40%,#0e0e0e);--panel-bg:#000;--panel-border:hsla(0,0%,100%,.08);--panel-shadow:0 0 0 1px hsla(0,0%,100%,.05),0 10px 50px rgba(0,0,0,.85),0 2px 10px rgba(0,0,0,.6);--color-accent:#e3a812;--color-accent-hover:#c28f0e;--color-accent-dim:rgba(227,168,18,.12);--color-accent-border:rgba(227,168,18,.35);--color-accent-text:#0a0a0a;--color-accent-gradient:linear-gradient(180deg,#cfc09f 0%,#ffecb3 45%,#b8892e 82%,#6e521d);--color-accent-gradient-hover:linear-gradient(180deg,#e0d3b0 0%,#fff4c9 45%,#d1a13e 82%,#866325);--color-accent-glow:rgba(255,236,179,.75);--color-red:#c43c3c;--color-red-hover:#b03232;--color-red-dim:rgba(196,60,60,.1);--color-red-border:rgba(196,60,60,.3);--color-beige:#c4a87a;--color-beige-hover:#b89a6a;--color-beige-dim:hsla(37,39%,62%,.1);--color-beige-border:hsla(37,39%,62%,.3);--color-bull:#00c076;--color-bear:#f23645;--color-bull-dim:rgba(0,192,118,.12);--color-bear-dim:rgba(242,54,69,.12);--text-primary:#f5f5f5;--text-second:#d0d0d0;--text-muted:#909090;--text-inverse:#0a0a0a;--border:hsla(0,0%,100%,.06);--border-strong:hsla(0,0%,100%,.1);--border-focus:rgba(227,168,18,.55);--gray-1:#191919;--gray-2:#242424;--gray-3:#333;--gray-4:#555;--gray-5:#888;--color-info:#5a9fd4;--color-success:#00c076;--color-warning:#fbbf24;--color-error:#c43c3c;--overlay:rgba(0,0,0,.75)}html.light{--bg-base:#f0f0f0;--bg-surface:#fff;--bg-elevated:#fff;--bg-hover:#e5e5e5;--bg-active:#dadada;--bg-gradient:linear-gradient(160deg,#ededed,#f0f0f0 40%,#ededed);--panel-bg:hsla(0,0%,100%,.97);--panel-border:rgba(0,0,0,.1);--panel-shadow:0 0 0 1px rgba(0,0,0,.06),0 8px 40px rgba(0,0,0,.08),0 2px 8px rgba(0,0,0,.04);--color-accent:#b8860b;--color-accent-hover:#9a7009;--color-accent-dim:rgba(184,134,11,.12);--color-accent-border:rgba(184,134,11,.35);--color-accent-text:#0a0a0a;--color-accent-gradient:linear-gradient(180deg,#cfc09f 0%,#ffecb3 45%,#b8892e 82%,#6e521d);--color-accent-gradient-hover:linear-gradient(180deg,#e0d3b0 0%,#fff4c9 45%,#d1a13e 82%,#866325);--color-accent-glow:rgba(255,236,179,.85);--color-red:#c43c3c;--color-red-hover:#b03232;--color-red-dim:rgba(196,60,60,.08);--color-red-border:rgba(196,60,60,.25);--color-beige:#8c7a5a;--color-beige-hover:#7a6a4a;--color-beige-dim:rgba(140,122,90,.08);--color-beige-border:rgba(140,122,90,.25);--color-bull:#0a8a50;--color-bear:#d42030;--color-bull-dim:rgba(10,138,80,.08);--color-bear-dim:rgba(212,32,48,.08);--text-primary:#000;--text-second:#2a2a2a;--text-muted:#666;--text-inverse:#fff;--border:rgba(0,0,0,.1);--border-strong:rgba(0,0,0,.18);--border-focus:rgba(184,134,11,.55);--gray-1:#f0f0f0;--gray-2:#e5e5e5;--gray-3:#ccc;--gray-4:#999;--gray-5:#666;--color-info:#2e7ab8;--color-success:#0a8a50;--color-warning:#d97706;--color-error:#c43c3c;--overlay:rgba(0,0,0,.4)}:root{--font-logo:"Bebas Neue",sans-serif;--font-sans:"Noto Sans KR",sans-serif;--font-mono:"IBM Plex Mono",monospace;--fs-xs:13px;--fs-sm:15px;--fs-base:17px;--fs-md:20px;--fs-lg:26px;--fs-xl:36px;--fs-2xl:52px;--fw-light:300;--fw-regular:400;--fw-medium:500;--fw-semi:600;--fw-bold:700;--lh-tight:1.2;--lh-normal:1.5;--lh-loose:1.75}:root.large-text{--fs-xs:15px;--fs-sm:17px;--fs-base:20px;--fs-md:24px;--fs-lg:32px;--fs-xl:44px;--fs-2xl:64px}:root{--radius-sm:2px;--radius-md:4px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--sidebar-width:240px;--topbar-height:52px;--content-max-width:1400px;--modal-max-width:900px;--transition-fast:0.12s ease;--transition-normal:0.22s ease;--transition-slow:0.38s ease;--shadow-sm:0 1px 3px rgba(0,0,0,.4),0 1px 2px rgba(0,0,0,.3);--shadow-md:0 4px 12px rgba(0,0,0,.5),0 2px 6px rgba(0,0,0,.4);--shadow-lg:0 8px 24px rgba(0,0,0,.6),0 4px 12px rgba(0,0,0,.5)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:var(--fs-base);font-weight:var(--fw-regular);line-height:var(--lh-normal);color:var(--text-primary);background-color:var(--bg-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color var(--transition-normal),color var(--transition-normal)}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--text-primary)}button{font-family:var(--font-sans);cursor:pointer;border:none;background:none}input,select,textarea{font-family:var(--font-sans);font-size:var(--fs-base);color:var(--text-primary);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);outline:none;transition:border-color var(--transition-fast),background var(--transition-fast);color-scheme:dark}input[type=date]::-webkit-calendar-picker-indicator,input[type=datetime-local]::-webkit-calendar-picker-indicator,input[type=time]::-webkit-calendar-picker-indicator{filter:invert(1) brightness(2);cursor:pointer}input:focus,select:focus,textarea:focus{border-color:var(--border-focus);background:var(--bg-active)}ol,ul{list-style:none}img,svg{display:block;max-width:100%}table{border-collapse:collapse;width:100%}.num{font-family:var(--font-mono)}.text-bull{color:var(--color-bull)!important}.text-bear{color:var(--color-bear)!important}.text-accent{color:var(--color-accent)!important}.gold-text{background:var(--color-accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;color:transparent;filter:drop-shadow(0 1px 0 rgba(255,236,179,.35)) drop-shadow(0 2px 4px rgba(0,0,0,.5))}.text-muted{color:var(--text-muted)!important}.text-second{color:var(--text-second)!important}.font-mono{font-family:var(--font-mono)!important}.fw-bold{font-weight:var(--fw-bold)!important}.fw-semi{font-weight:var(--fw-semi)!important}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-3);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--gray-4)}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}body,html{height:100%}body{background:var(--bg-base)}.notice-bar{background:#1a1a1a}.notice-bar__inner{padding:8px 48px;display:flex;align-items:center;gap:var(--space-2);font-size:13px;font-weight:var(--fw-medium);color:var(--text-second)}.notice-bar__inner svg{flex-shrink:0;width:14px;height:14px;color:var(--color-accent);opacity:.7}.notice-bar__text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.site-header{position:-webkit-sticky;position:sticky;top:0;z-index:100;background:var(--bg-base);border-bottom:1px solid hsla(0,0%,100%,.04)}.site-header__inner{height:48px;display:flex;align-items:center;justify-content:space-between;padding:0 24px}.site-header__logo{font-family:var(--font-logo);font-size:28px;font-weight:400;letter-spacing:5px;background:var(--color-accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;color:transparent;filter:drop-shadow(0 1px 0 rgba(255,236,179,.35)) drop-shadow(0 2px 4px rgba(0,0,0,.5));white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;user-select:none;text-decoration:none;flex-shrink:0}.site-nav{display:flex;align-items:stretch;background:#111;border-bottom:1px solid hsla(0,0%,100%,.04);padding:0 max(24px,calc((100% - 1400px) / 2))}.site-nav__item{position:relative;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:5px;width:130px;flex-shrink:0;padding:12px 0;font-size:var(--fs-sm);font-weight:var(--fw-medium);color:#fff;text-decoration:none;white-space:nowrap;border-bottom:2px solid transparent;transition:all var(--transition-fast)}.site-nav__item svg{width:16px;height:16px;flex-shrink:0;stroke-width:1.5;opacity:.6}.site-nav__item:hover{color:#fff;background:hsla(0,0%,100%,.03)}.site-nav__item:hover svg{opacity:.9}.site-nav__item.active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.site-nav__item.active svg{color:var(--color-accent);opacity:1}.site-nav__item.active:after{display:none}.site-nav__dropdown-wrap{position:relative;display:flex;width:130px;flex-shrink:0;align-items:stretch}.site-nav__item--has-children{background:none;border:none;border-bottom:2px solid transparent;font-family:inherit;cursor:pointer}.site-nav__chevron{width:12px!important;height:12px!important;color:#beffac!important;opacity:1!important;stroke-width:3!important;margin-top:-1px;transition:transform var(--transition-fast)}.site-nav__chevron.rotated{transform:rotate(180deg)}.site-nav__item--has-children.mega-open{color:#fff!important;-webkit-text-fill-color:#fff!important;background:hsla(0,0%,100%,.03)}.site-nav__item--has-children.mega-open:after{display:none}.site-nav__item--has-children.mega-open svg{opacity:1}.site-nav__item--has-children.active .site-nav__chevron{color:var(--color-accent)!important;opacity:.7!important}.site-nav__dropdown{position:absolute;top:100%;left:0;min-width:160px;background:#1a1a1a;border:1px solid hsla(0,0%,100%,.08);border-top:2px solid var(--color-accent);padding:6px 0;z-index:200;box-shadow:0 8px 24px rgba(0,0,0,.6)}.site-nav__dropdown-item{display:block;padding:11px 20px;font-size:var(--fs-sm);font-weight:var(--fw-medium);color:#fff;text-decoration:none;text-align:center;transition:background var(--transition-fast),color var(--transition-fast)}.site-nav__dropdown-item:hover{background:rgba(227,168,18,.08);color:var(--color-accent)}.site-nav__dropdown-item.active{color:var(--color-accent)}.site-header__pc-right{display:flex;align-items:center;gap:14px;flex-shrink:0;font-size:13px}.site-header__mobile-right{display:none;align-items:center;gap:4px;flex-shrink:0;margin-left:auto}.site-header__user-btn{display:flex;align-items:center;gap:5px;padding:5px 12px;background:none;border:none;color:#fff;font-size:13px;font-weight:var(--fw-medium);font-family:var(--font-sans);cursor:pointer;white-space:nowrap;transition:color var(--transition-fast)}.site-header__user-btn:hover{color:var(--color-accent)}.user-dropdown-wrap{position:relative}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:4px;z-index:200;box-shadow:0 4px 16px rgba(0,0,0,.4)}.user-dropdown__info{padding:14px 16px 10px}.user-dropdown__name{font-size:var(--fs-sm);font-weight:var(--fw-bold);color:var(--text-primary);margin-bottom:2px}.user-dropdown__email{font-size:var(--fs-xs);color:var(--text-muted);margin-bottom:8px}.user-dropdown__level{display:flex;align-items:center;gap:6px}.user-dropdown__level-label{font-size:12px;color:var(--text-muted)}.user-dropdown__level-value{font-family:var(--font-mono);font-size:13px;font-weight:var(--fw-bold);color:var(--color-accent)}.user-dropdown__level-badge.admin{font-size:12px;font-weight:var(--fw-bold);color:var(--color-accent-text);background:var(--color-accent);padding:1px 8px;border-radius:2px}.user-dropdown__divider{height:1px;background:var(--border);margin:0}.user-dropdown__item{display:flex;align-items:center;gap:8px;width:100%;padding:10px 16px;background:none;border:none;color:var(--text-second);font-size:var(--fs-xs);font-family:var(--font-sans);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.user-dropdown__item:hover{background:var(--bg-hover);color:var(--text-primary)}.user-dropdown__item--danger:hover{color:var(--color-red)}.subbar{height:1px;position:relative;overflow:hidden}.subbar__inner{position:absolute;inset:0;background:linear-gradient(90deg,transparent,#6e521d 15%,#b8892e 30%,#ffecb3 50%,#b8892e 70%,#6e521d 85%,transparent);background-size:200% 100%;animation:goldShimmer 10s ease-in-out infinite}@keyframes goldShimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.site-footer{margin-top:60px;background:#0d0d0d;border-top:1px solid var(--border)}.site-footer__inner{max-width:1400px;margin:0 auto;padding:40px 48px 24px}.site-footer__brand{margin-bottom:28px}.site-footer__logo{font-family:var(--font-logo);font-size:28px;letter-spacing:4px;background:var(--color-accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-decoration:none}.site-footer__desc{font-size:13px;color:var(--text-muted);margin-top:6px}.site-footer__links{display:flex;gap:60px;margin-bottom:32px}.site-footer__col{display:flex;flex-direction:column;gap:8px}.site-footer__col-title{font-size:13px;font-weight:var(--fw-semi);color:var(--text-second);margin:0 0 4px;text-transform:uppercase;letter-spacing:.5px}.site-footer__col a{font-size:13px;color:var(--text-muted);text-decoration:none;transition:color var(--transition-fast)}.site-footer__col a:hover{color:var(--color-accent)}.site-footer__bottom{padding-top:20px;border-top:1px solid var(--border);font-size:12px;color:var(--text-muted);font-family:var(--font-mono)}@media (max-width:600px){.site-footer__inner{padding:32px var(--space-4) 20px}.site-footer__links{gap:40px}}.hamburger{display:none;flex-direction:column;justify-content:center;gap:4px;width:32px;height:32px;padding:var(--space-2);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.hamburger:hover{background:var(--bg-hover)}.hamburger span{display:block;width:100%;height:1.5px;background:var(--text-second);border-radius:2px}.site-main{min-height:calc(100vh - 52px);display:flex;flex-direction:column;align-items:center;padding:var(--space-10) var(--space-5) var(--space-6)}.site-main__inner{width:100%;max-width:var(--content-max-width)}.page-header{margin-bottom:var(--space-6)}.page-title{font-size:var(--fs-lg);font-weight:var(--fw-semi);color:var(--text-primary);letter-spacing:-.3px;line-height:var(--lh-tight)}.page-subtitle{font-size:var(--fs-sm);color:var(--text-muted);margin-top:4px}.sidebar{width:260px;display:none;flex-direction:column;transition:transform var(--transition-normal)}.sidebar__nav{padding:var(--space-3) 0;flex:1 1;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:10px var(--space-5);font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--text-second);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);text-decoration:none;position:relative}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{color:var(--color-accent);font-weight:var(--fw-semi);background:var(--color-accent-dim)}.nav-item.active:before{content:"";position:absolute;left:0;top:20%;bottom:20%;width:2px;background:var(--color-accent);border-radius:0 2px 2px 0}.sidebar__group{display:flex;flex-direction:column}.nav-item--group{display:flex;justify-content:space-between;align-items:center;width:100%;background:none;border:none;font-family:inherit;text-align:left}.nav-item--group svg{opacity:.4;flex-shrink:0}.sidebar__group-children{display:flex;flex-direction:column}.nav-item--child{padding-left:calc(var(--space-5) + 14px)!important;font-size:var(--fs-xs)!important}.sidebar__header{display:flex;align-items:center;justify-content:space-between;height:52px;padding:0 var(--space-5);border-bottom:1px solid var(--border);flex-shrink:0}.sidebar__close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.sidebar__close:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar__footer{padding:var(--space-4) var(--space-5);padding-bottom:calc(var(--space-4) + env(safe-area-inset-bottom, 8px));border-top:1px solid var(--border);flex-shrink:0}.sidebar-overlay{display:none;position:fixed;inset:0;background:var(--overlay);z-index:9999;opacity:0;transition:opacity var(--transition-normal);pointer-events:none}.sidebar-overlay.active{opacity:1;pointer-events:auto}@media (max-width:1023px){.site-header__pc-right,.site-nav{display:none}.hamburger,.site-header__mobile-right{display:flex}.subbar{display:none}.site-header__inner{height:52px}.sidebar{display:flex;position:fixed;top:0;left:0;right:0;bottom:0;width:100%;z-index:10000;background:var(--bg-base);transform:translateX(100%);overflow-y:auto}.sidebar.open{transform:translateX(0)}.sidebar-overlay{display:block;z-index:9999}.site-main{padding:var(--space-5) var(--space-4)}}@media (max-width:600px){.site-header__inner{padding:0 var(--space-4)}.notice-bar__inner{padding:7px var(--space-4);font-size:13px}.site-main{padding:var(--space-4) var(--space-3)}}.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:7px var(--space-4);font-family:var(--font-sans);font-size:var(--fs-sm);font-weight:var(--fw-medium);border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;line-height:var(--lh-tight)}.btn-primary{background:var(--color-accent-gradient);font-weight:var(--fw-semi);box-shadow:0 2px 8px rgba(0,0,0,.4),inset 0 0 0 1px rgba(255,236,179,.45);text-shadow:0 1px 0 hsla(0,0%,100%,.25)}.btn-primary,.btn-primary:hover{color:var(--color-accent-text,#0a0a0a);border-color:transparent}.btn-primary:hover{background:var(--color-accent-gradient-hover);box-shadow:0 3px 12px rgba(255,236,179,.35),inset 0 0 0 1px rgba(255,236,179,.55)}.btn-apply{background:var(--color-accent-gradient);color:var(--color-accent-text,#0a0a0a);border-color:transparent;font-weight:var(--fw-semi);box-shadow:0 2px 8px rgba(0,0,0,.4),inset 0 0 0 1px rgba(255,236,179,.45);text-shadow:0 1px 0 hsla(0,0%,100%,.25)}.btn-apply:hover{background:linear-gradient(180deg,#e05555 0,#ff6b6b 45%,#c43c3c 82%,#8b1a1a);color:#fff;border-color:transparent;text-shadow:0 1px 2px rgba(0,0,0,.3);box-shadow:0 3px 12px rgba(196,60,60,.35),inset 0 0 0 1px hsla(0,100%,74%,.4)}.btn-sm{padding:4px 10px;font-size:var(--fs-xs)}.btn-ghost{background:transparent;color:var(--text-second)}.btn-ghost,.btn-ghost:hover{border-color:var(--border-strong)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-danger{background:var(--color-bear);color:#fff;border-color:var(--color-bear)}.btn-danger:hover{opacity:.85}.btn-action{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-strong);font-size:var(--fs-base);font-weight:var(--fw-semi);padding:var(--space-4);transition:background var(--transition-fast),border-color var(--transition-fast)}.btn-action:hover{background:var(--bg-active);border-color:var(--color-accent-border);color:var(--text-primary)}.btn-full{width:100%;justify-content:center}.modal-backdrop{position:fixed;inset:0;background:var(--overlay);z-index:500;display:flex;align-items:center;justify-content:center;padding:var(--space-4);opacity:0;pointer-events:none;transition:opacity var(--transition-normal);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.modal-backdrop.open{opacity:1;pointer-events:auto}.modal{background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-md);width:100%;max-width:var(--modal-max-width);max-height:88vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);transform:translateY(16px);transition:transform var(--transition-normal)}.modal-backdrop.open .modal{transform:translateY(0)}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border);flex-shrink:0}.modal__title{font-size:var(--fs-md);font-weight:var(--fw-semi);color:var(--text-primary)}.modal__close{color:var(--text-muted);padding:4px;border-radius:var(--radius-sm);transition:color var(--transition-fast),background var(--transition-fast);cursor:pointer}.modal__close:hover{color:var(--text-primary);background:var(--bg-hover)}.modal__body{padding:var(--space-5);overflow-y:auto;flex:1 1;color:var(--text-second);font-size:var(--fs-base);line-height:var(--lh-loose)}.modal__footer{display:flex;justify-content:flex-end;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-top:1px solid var(--border);flex-shrink:0}.modal--confirm .modal{max-width:440px}.modal--confirm .modal__body{text-align:center;padding:var(--space-8) var(--space-6)}.modal--confirm .confirm-icon{width:40px;height:40px;margin:0 auto var(--space-4);color:var(--color-warning)}.modal--confirm .confirm-desc{font-size:var(--fs-sm);color:var(--text-second);line-height:var(--lh-loose)}.form-group{margin-bottom:var(--space-4)}.form-label{display:block;font-size:var(--fs-xs);font-weight:var(--fw-semi);color:var(--text-second);margin-bottom:var(--space-2);letter-spacing:.3px;text-transform:uppercase}.form-input{width:100%;padding:var(--space-3) var(--space-3);background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--fs-base);transition:border-color var(--transition-fast),background var(--transition-fast)}.form-input:focus{border-color:var(--border-focus);background:var(--bg-active)}.form-input::placeholder{color:var(--text-muted)}.form-hint{color:var(--text-muted)}.form-error,.form-hint{font-size:var(--fs-xs);margin-top:4px}.form-error{color:var(--color-error)}.form-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--space-4);gap:var(--space-4)}@media (max-width:600px){.modal-backdrop{padding:0;align-items:flex-end}.modal{border-radius:var(--radius-md) var(--radius-md) 0 0;max-height:92vh}.form-grid{grid-template-columns:1fr}}#toast-container{position:fixed;bottom:var(--space-5);right:var(--space-5);display:flex;flex-direction:column;gap:var(--space-2);z-index:9999;pointer-events:none}.toast{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-md);min-width:260px;max-width:340px;box-shadow:var(--shadow-lg);pointer-events:auto;animation:toastIn .2s ease forwards}.toast.hide{animation:toastOut .2s ease forwards}.toast--success{border-top:2px solid var(--color-success)}.toast--error{border-top:2px solid var(--color-error)}.toast--warning{border-top:2px solid var(--color-warning)}.toast--info{border-top:2px solid var(--color-accent)}.toast__icon{flex-shrink:0;margin-top:1px}.toast--success .toast__icon{color:var(--color-success)}.toast--error .toast__icon{color:var(--color-error)}.toast--warning .toast__icon{color:var(--color-warning)}.toast--info .toast__icon{color:var(--color-accent)}.toast__body{flex:1 1}.toast__title{font-size:var(--fs-sm);font-weight:var(--fw-semi);color:var(--text-primary);line-height:var(--lh-tight)}.toast__message{font-size:var(--fs-xs);color:var(--text-muted);margin-top:3px;line-height:var(--lh-normal)}.toast__close{flex-shrink:0;color:var(--text-muted);padding:2px;border-radius:var(--radius-sm);transition:color var(--transition-fast),background var(--transition-fast);cursor:pointer}.toast__close:hover{color:var(--text-primary);background:var(--bg-hover)}@keyframes toastIn{0%{transform:translateX(110%);opacity:0}to{transform:translateX(0);opacity:1}}@keyframes toastOut{0%{transform:translateX(0);opacity:1}to{transform:translateX(110%);opacity:0}}@media (max-width:600px){#toast-container{bottom:var(--space-3);right:var(--space-3);left:var(--space-3)}.toast{min-width:unset;max-width:100%}}.gallery-grid{display:grid;grid-template-columns:repeat(6,1fr);grid-gap:var(--space-2);gap:var(--space-2)}.gallery-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:border-color var(--transition-fast),transform var(--transition-fast)}.gallery-card:hover{border-color:var(--border-strong);transform:translateY(-2px)}.gallery-card__thumb{width:100%;aspect-ratio:4/3;object-fit:cover;background:var(--bg-surface);display:block}.gallery-card__thumb--blur{filter:blur(12px);-webkit-filter:blur(12px)}.gallery-card__thumb--empty{width:100%;aspect-ratio:4/3;background:var(--bg-surface);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.gallery-card__body{padding:var(--space-3)}.gallery-card__title{font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--text-primary);line-height:var(--lh-tight);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gallery-card__meta{display:flex;align-items:center;gap:var(--space-3);margin-top:6px;font-size:var(--fs-xs);color:var(--text-muted)}.gallery-card__meta span{display:inline-flex;align-items:center;gap:3px}.gallery-grid .gallery-card__body{padding:6px 8px}.gallery-grid .gallery-card__title{font-size:var(--fs-xs);font-weight:var(--fw-medium)}.gallery-grid .gallery-card__meta{gap:8px;margin-top:3px;font-size:11px}.gallery-grid .gallery-card__meta span:first-child{max-width:60px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.villain-list{width:100%;border-top:1px solid var(--border-strong);border-bottom:1px solid var(--border-strong);background:var(--bg-elevated)}.villain-list__row{display:grid;grid-template-columns:56px 72px 1fr 110px 80px 60px 60px;align-items:center;grid-gap:var(--space-3);gap:var(--space-3);padding:8px 12px;border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--transition-fast)}.villain-list__row:last-child{border-bottom:none}.villain-list__row:hover{background:var(--bg-hover)}.villain-list__head{cursor:default;font-size:var(--fs-xs);color:var(--text-muted);font-weight:var(--fw-semi);padding:10px 12px;border-bottom:1px solid var(--border-strong)}.villain-list__head,.villain-list__head:hover{background:var(--bg-surface)}.villain-list__id{color:var(--text-muted);font-family:var(--font-mono);font-size:12px;text-align:center}.villain-list__thumb{width:64px;height:48px;object-fit:cover;background:var(--bg-surface);border-radius:2px;display:block}.villain-list__thumb--blur{filter:blur(8px);-webkit-filter:blur(8px)}.villain-list__thumb--empty{width:64px;height:48px;background:var(--bg-surface);border-radius:2px;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.villain-list__title{font-size:var(--fs-sm);color:var(--text-primary);font-weight:var(--fw-medium);min-width:0}.villain-list__author,.villain-list__title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.villain-list__author{font-size:var(--fs-xs);color:var(--text-second)}.villain-list__date,.villain-list__num{font-size:var(--fs-xs);color:var(--text-muted);font-family:var(--font-mono);text-align:center}.villain-toolbar{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);flex-wrap:wrap}.villain-toolbar--row1{justify-content:space-between}.villain-toolbar--row2{padding:var(--space-3);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:var(--space-4)}.villain-toolbar__left{display:flex;align-items:center;gap:var(--space-4)}.villain-toolbar__total{margin-left:auto;font-size:var(--fs-xs);color:var(--text-muted)}.villain-toolbar__total strong{color:var(--text-primary);font-family:var(--font-mono)}.villain-search{position:relative;display:flex;align-items:center;flex:1 1;min-width:220px;max-width:360px;background:var(--bg-base);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:0 var(--space-3);height:34px}.villain-search:focus-within{border-color:var(--color-accent)}.villain-search svg{color:var(--text-muted);flex-shrink:0}.villain-search input{flex:1 1;border:none;background:transparent;color:var(--text-primary);font-size:var(--fs-xs);padding:0 var(--space-2);outline:none;font-family:inherit}.villain-search input::placeholder{color:var(--text-muted)}.villain-search__clear{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:18px;padding:0 4px;line-height:1}.villain-search__clear:hover{color:var(--text-primary)}.region-filter{position:relative}.region-filter__btn{display:inline-flex;align-items:center;gap:6px;height:34px;padding:0 var(--space-3);background:var(--bg-base);border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text-second);font-size:var(--fs-xs);font-family:inherit;cursor:pointer;white-space:nowrap}.region-filter__btn:hover{border-color:var(--text-muted)}.region-filter__btn--active{border-color:var(--color-accent);color:var(--text-primary)}.region-filter__btn svg{color:var(--text-muted)}.region-filter__btn--active>svg:first-child{color:var(--color-accent)}.region-filter__clear{margin-left:4px;padding:0 6px;color:var(--text-muted);font-size:14px;line-height:1;border-radius:2px}.region-filter__clear:hover{background:var(--bg-hover);color:var(--text-primary)}.region-filter__panel{position:absolute;top:calc(100% + 4px);left:0;z-index:100;width:280px;max-width:calc(100vw - 32px);max-height:400px;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-md);box-shadow:0 8px 24px rgba(0,0,0,.4);display:flex;flex-direction:column;overflow:hidden}.region-filter__search{padding:var(--space-2);border-bottom:1px solid var(--border)}.region-filter__search input{width:100%;height:32px;padding:0 var(--space-3);background:var(--bg-base);border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--fs-xs);font-family:inherit;outline:none}.region-filter__search input:focus{border-color:var(--color-accent)}.region-filter__list{list-style:none;margin:0;padding:4px 0;overflow-y:auto;flex:1 1}.region-filter__item{display:flex;justify-content:space-between;align-items:center;padding:8px 14px;font-size:var(--fs-xs);color:var(--text-second);cursor:pointer}.region-filter__item:hover{background:var(--bg-hover);color:var(--text-primary)}.region-filter__item--active{background:var(--bg-active);color:var(--color-accent);font-weight:var(--fw-semi)}.region-filter__count{color:var(--text-muted);font-family:var(--font-mono);font-size:11px}.region-filter__empty{padding:16px;text-align:center;color:var(--text-muted);font-size:var(--fs-xs)}.density-toggle{display:inline-flex;border:1px solid var(--border-strong);border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-base);height:34px}.density-toggle__btn{display:inline-flex;align-items:center;gap:6px;padding:0 var(--space-3);background:transparent;border:none;color:var(--text-muted);font-size:var(--fs-xs);font-family:inherit;cursor:pointer;white-space:nowrap}.density-toggle__btn+.density-toggle__btn{border-left:1px solid var(--border-strong)}.density-toggle__btn:hover{color:var(--text-primary)}.density-toggle__btn.active{background:var(--color-accent);color:var(--color-accent-text);font-weight:var(--fw-semi)}@media (max-width:1400px){.gallery-grid{grid-template-columns:repeat(5,1fr)}}@media (max-width:1100px){.gallery-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width:768px){.gallery-grid{grid-template-columns:repeat(3,1fr)}.villain-toolbar--row2{padding:var(--space-2)}.villain-search{min-width:140px;max-width:none}.villain-toolbar__total{width:100%;text-align:right}.region-filter__panel{left:auto;right:0;width:calc(100vw - 32px);max-width:320px}.villain-list__row{grid-template-columns:48px 1fr 80px 54px;gap:var(--space-2);padding:6px 10px}.villain-list__row>.villain-list__id,.villain-list__row>.villain-list__num:nth-last-child(-n+2){display:none}}@media (max-width:480px){.gallery-grid{grid-template-columns:repeat(2,1fr)}.villain-list__row{grid-template-columns:44px 1fr 60px}.villain-list__row>.villain-list__author{display:none}}.post-list-table{width:100%;border-collapse:collapse}.post-list-table th{font-size:var(--fs-xs);font-weight:var(--fw-semi);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border-strong);text-align:left}.post-list-table td{padding:var(--space-3);border-bottom:1px solid var(--border);font-size:var(--fs-sm);color:var(--text-second)}.post-list-table tr:hover td{background:var(--bg-hover)}.post-list-table .col-id{width:60px;text-align:center;color:var(--text-muted);font-family:var(--font-mono);font-size:var(--fs-xs)}.post-list-table .col-title{cursor:pointer}.post-list-table .col-title:hover{color:var(--text-primary)}.post-list-table .col-author{width:100px}.post-list-table .col-date{width:90px}.post-list-table .col-date,.post-list-table .col-views{font-size:var(--fs-xs);color:var(--text-muted);font-family:var(--font-mono)}.post-list-table .col-views{width:60px;text-align:center}.pagination{display:flex;gap:var(--space-1);margin-top:var(--space-5)}.pagination,.pagination__btn{align-items:center;justify-content:center}.pagination__btn{display:inline-flex;min-width:32px;height:32px;padding:0 var(--space-2);font-size:var(--fs-xs);font-family:var(--font-mono);color:var(--text-muted);background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.pagination__btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-strong)}.pagination__btn.active{background:var(--color-accent);color:var(--color-accent-text,#0a0a0a);border-color:var(--color-accent);font-weight:var(--fw-semi)}.pagination__btn:disabled{opacity:.3;cursor:default}.post-detail{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md)}.post-detail__header{padding:var(--space-5);border-bottom:1px solid var(--border)}.post-detail__title{font-size:var(--fs-lg);font-weight:var(--fw-semi);color:var(--text-primary);line-height:var(--lh-tight);margin-bottom:var(--space-3)}.post-detail__meta{display:flex;align-items:center;gap:var(--space-4);font-size:var(--fs-xs);color:var(--text-muted)}.post-detail__meta span{display:inline-flex;align-items:center;gap:4px}.post-detail__content{padding:var(--space-5);font-size:var(--fs-base);color:#fff;line-height:var(--lh-loose);white-space:pre-wrap;word-break:break-word}html.light .post-detail__content{color:#000}.post-detail__content img{max-width:50%;border-radius:var(--radius-sm);margin:var(--space-3) 0}.post-detail__files{padding:0 var(--space-5) var(--space-4);overflow-anchor:none}.post-detail__files img{display:block;max-width:50%;height:auto}@media (max-width:768px){.replay-iframe-wrap{max-width:100%!important}}.file-item{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--fs-xs);color:var(--text-second);text-decoration:none;margin-right:var(--space-2);margin-bottom:var(--space-2);transition:border-color var(--transition-fast)}.file-item:hover{border-color:var(--border-strong);color:var(--text-primary)}.post-detail__actions{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-top:1px solid var(--border)}.like-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:transparent;border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text-muted);font-size:var(--fs-sm);cursor:pointer;transition:all var(--transition-fast)}.like-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.like-btn.liked{color:var(--color-accent);border-color:var(--color-accent-border);background:var(--color-accent-dim)}.comments-section{margin-top:var(--space-4)}.comments-section__title{font-size:var(--fs-sm);font-weight:var(--fw-semi);color:var(--text-primary);margin-bottom:var(--space-4)}.comment-write{display:flex;gap:var(--space-3);margin-bottom:var(--space-4)}.comment-write textarea{flex:1 1;padding:var(--space-3);background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--fs-sm);font-family:var(--font-sans);resize:vertical;min-height:60px;transition:border-color var(--transition-fast)}.comment-write textarea:focus{border-color:var(--border-focus);outline:none}.comment-item{padding:var(--space-3) 0;border-bottom:1px solid var(--border)}.comment-item:last-child{border-bottom:none}.comment-item__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.comment-item__author{font-size:var(--fs-sm);font-weight:var(--fw-semi);color:var(--text-primary)}.comment-item__date{font-size:var(--fs-xs);color:var(--text-muted);font-family:var(--font-mono)}.comment-item__content{font-size:var(--fs-sm);color:var(--text-second);line-height:var(--lh-normal);white-space:pre-wrap}.comment-item__delete{font-size:var(--fs-xs);color:var(--text-muted);cursor:pointer;padding:2px 6px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.comment-item__delete:hover{color:var(--color-error);background:var(--bg-hover)}.write-form{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-5)}.write-form__title-input{width:100%;padding:var(--space-3);background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--fs-md);font-weight:var(--fw-semi);margin-bottom:var(--space-4);transition:border-color var(--transition-fast)}.write-form__title-input:focus{border-color:var(--border-focus);outline:none}.write-form__content-input{width:100%;min-height:300px;padding:var(--space-3);background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--fs-base);font-family:var(--font-sans);line-height:var(--lh-loose);resize:vertical;margin-bottom:var(--space-4);transition:border-color var(--transition-fast)}.write-form__content-input:focus{border-color:var(--border-focus);outline:none}.upload-area{border:1px dashed var(--border-strong);border-radius:var(--radius-sm);padding:var(--space-5);text-align:center;cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast);margin-bottom:var(--space-4)}.upload-area:hover{border-color:var(--color-accent-border);background:var(--bg-hover)}.upload-area__text{font-size:var(--fs-sm);color:var(--text-muted)}.upload-area__hint{font-size:var(--fs-xs);color:var(--text-muted);margin-top:var(--space-2);opacity:.7}.uploaded-files{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-4)}.uploaded-file{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--fs-xs);color:var(--text-second)}.uploaded-file__remove{color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast)}.uploaded-file__remove:hover{color:var(--color-error)}.auth-form{max-width:400px;margin:0 auto;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-8)}.auth-form__title{font-size:var(--fs-lg);font-weight:var(--fw-semi);color:var(--text-primary);text-align:center;margin-bottom:var(--space-6)}.auth-form__link{text-align:center;margin-top:var(--space-4);font-size:var(--fs-sm);color:var(--text-muted)}.search-bar{display:flex;gap:var(--space-2);margin-bottom:var(--space-4)}.search-bar input{flex:1 1;padding:var(--space-2) var(--space-3);background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--fs-sm)}.search-bar input:focus{border-color:var(--border-focus);outline:none}.empty-state{text-align:center;padding:var(--space-12) var(--space-5);color:var(--text-muted)}.empty-state__icon{margin-bottom:var(--space-4);opacity:.4}.empty-state__text{font-size:var(--fs-sm)}.list-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}@media (max-width:1023px){.gallery-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:767px){.gallery-grid{grid-template-columns:repeat(2,1fr)}.post-list-table .col-id,.post-list-table .col-views{display:none}.auth-form{padding:var(--space-5)}}@media (max-width:480px){.gallery-grid{gap:var(--space-2)}.gallery-card__body{padding:var(--space-2)}}.login-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:500;display:flex;align-items:center;justify-content:center}.login-modal{position:relative;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:4px;padding:32px 28px;width:360px;max-width:90vw}.login-modal__close{position:absolute;top:12px;right:12px;background:none;border:none;color:var(--text-muted);cursor:pointer}.login-modal__close:hover{color:var(--text-primary)}.login-modal__logo{font-family:var(--font-logo);font-size:28px;letter-spacing:5px;text-align:center;margin-bottom:4px;background:var(--color-accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 6px var(--color-accent-glow))}.login-modal__title{text-align:center;font-size:var(--fs-sm);color:var(--text-muted);margin-bottom:20px}.auth-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .25s ease}.auth-card{display:flex;width:820px;max-width:95vw;max-height:90vh;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);overflow:hidden;animation:slideUp .3s ease}.auth-card__form{flex:1 1;padding:var(--space-10) var(--space-8);display:flex;flex-direction:column;justify-content:center;min-width:0}.auth-card__logo{font-family:var(--font-logo);font-size:28px;letter-spacing:5px;color:var(--color-accent);margin-bottom:var(--space-2)}.auth-card__title{font-size:var(--fs-lg);font-weight:var(--fw-semi);color:var(--text-primary);margin-bottom:var(--space-6)}.auth-card__subtitle{font-size:var(--fs-sm);color:var(--text-muted);margin-top:calc(-1 * var(--space-4));margin-bottom:var(--space-6)}.auth-card__visual{width:380px;background:#0e0e0e;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;border-left:1px solid var(--border)}.matrix-rain{position:absolute;inset:0;overflow:hidden;opacity:.15}.matrix-col{position:absolute;top:-100%;font-family:var(--font-mono);font-size:12px;line-height:1.4;color:var(--color-accent);writing-mode:vertical-rl;animation:rain linear infinite;white-space:nowrap}@keyframes rain{0%{transform:translateY(-100%)}to{transform:translateY(calc(100vh + 100%))}}.terminal-box{position:relative;z-index:2;text-align:center;padding:var(--space-8)}.terminal-box__prompt{font-family:var(--font-mono);font-size:var(--fs-sm);color:var(--color-accent);opacity:.7;margin-bottom:var(--space-4)}.terminal-box__ascii{font-size:11px;line-height:1.3;white-space:pre;opacity:.5}.terminal-box__ascii,.terminal-box__tagline{font-family:var(--font-mono);color:var(--text-muted)}.terminal-box__tagline{font-size:var(--fs-xs);margin-top:var(--space-5);letter-spacing:2px;text-transform:uppercase}.cursor-blink{display:inline-block;width:8px;height:15px;background:var(--color-accent);margin-left:4px;vertical-align:middle;animation:cursorBlink 1s step-end infinite}@keyframes cursorBlink{0%,to{opacity:1}50%{opacity:0}}.auth-card__close{position:absolute;top:var(--space-3);right:var(--space-3);width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);z-index:10}.auth-card__close:hover{background:var(--bg-hover);color:var(--text-primary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width:767px){.auth-card{flex-direction:column;width:100%;max-width:440px}.auth-card__visual{display:none}.auth-card__form{padding:var(--space-6)}}.slot-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:var(--space-3);gap:var(--space-3)}.slot-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:border-color var(--transition-fast),transform var(--transition-fast)}.slot-card:hover{border-color:var(--color-accent-border);transform:translateY(-2px)}.slot-card__img{width:100%;aspect-ratio:339/180;object-fit:cover;display:block;background:var(--bg-surface)}.slot-card__name{padding:var(--space-2) var(--space-3);font-size:var(--fs-xs);color:var(--text-second);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.game-launcher{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:600;display:flex;align-items:center;justify-content:center;padding:var(--space-4);animation:fadeIn .2s ease}.game-launcher__card{position:relative;width:100%;max-width:1200px;height:600px;background:#141414;border:1px solid var(--border-strong);border-radius:var(--radius-md);overflow:hidden;display:grid;grid-template-columns:1fr 1fr}.game-launcher__close{position:absolute;top:12px;right:12px;z-index:2;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.6);border:1px solid hsla(0,0%,100%,.15);border-radius:2px;color:#ccc;cursor:pointer;transition:all .15s ease}.game-launcher__close:hover{background:rgba(0,0,0,.8);color:#fff}.game-launcher__thumb{width:100%;height:100%;background:#0a0a0a;display:flex;align-items:center;justify-content:center;overflow:hidden}.game-launcher__thumb img{width:100%;height:100%;object-fit:contain}.game-launcher__right{display:flex;flex-direction:column;justify-content:center}.game-launcher__info{padding:24px 24px 12px;text-align:center}.game-launcher__name{font-size:var(--fs-md);font-weight:var(--fw-bold);color:#f5f5f5;margin-bottom:4px}.game-launcher__provider{font-size:var(--fs-xs);color:var(--text-muted)}.game-launcher__buttons{padding:12px 24px 24px;display:flex;flex-direction:column;gap:10px}@media (max-width:768px){.game-launcher__card{max-width:360px;grid-template-columns:1fr}.game-launcher__thumb{aspect-ratio:1/1}.game-launcher__info{padding:16px 20px 8px}.game-launcher__buttons{padding:12px 20px 20px}}.game-launcher__play{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 0!important;font-size:var(--fs-sm)!important;font-weight:var(--fw-medium);color:#f5f5f5!important;border-color:hsla(0,0%,100%,.2)!important;background:hsla(0,0%,100%,.04)!important}.game-launcher__play:hover{color:#fff!important;border-color:hsla(0,0%,100%,.4)!important;background:hsla(0,0%,100%,.1)!important}.game-launcher__ad{width:100%;display:flex;align-items:center;justify-content:center;padding:14px 0!important;font-size:var(--fs-base)!important;font-weight:var(--fw-bold);text-decoration:none}.game-fullscreen{position:fixed;inset:0;z-index:700;background:#000;animation:fadeIn .15s ease}.game-fullscreen iframe{width:100%;height:100%;border:none}.game-fullscreen__close{position:fixed;top:12px;left:12px;z-index:710;display:flex;align-items:center;gap:6px;padding:8px 14px;font-size:13px;color:hsla(0,0%,100%,.7);background:rgba(0,0,0,.5);border:1px solid hsla(0,0%,100%,.15);border-radius:2px;cursor:pointer;transition:all .15s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.game-fullscreen__close:hover{color:#fff;background:rgba(0,0,0,.8);border-color:hsla(0,0%,100%,.35)}@media (max-width:1023px){.slot-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:767px){.slot-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.slot-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-2)}}.file-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));grid-gap:var(--space-3);gap:var(--space-3);margin-bottom:var(--space-3)}.file-card{position:relative;aspect-ratio:4/3;border-radius:var(--radius-md);overflow:hidden;border:2px solid transparent;cursor:-webkit-grab;cursor:grab;transition:border-color var(--transition-fast),opacity var(--transition-fast);background:var(--bg-surface)}.file-card:active{cursor:-webkit-grabbing;cursor:grabbing}.file-card.drag-over,.file-card.is-first{border-color:var(--color-accent)}.file-card.drag-over{opacity:.6}.file-card.dragging{opacity:.4}.file-card__img{width:100%;height:100%;object-fit:cover;display:block}.file-card__noimg{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);font-size:var(--fs-xs);gap:var(--space-2);padding:var(--space-2);text-align:center;word-break:break-all}.file-card__badge{position:absolute;top:6px;left:6px;font-size:10px;font-weight:var(--fw-semi);color:var(--color-accent-text);background:var(--color-accent);padding:1px 6px;border-radius:var(--radius-sm);letter-spacing:.5px}.file-card__name{position:absolute;bottom:0;left:0;right:0;padding:4px 6px;font-size:10px;color:#fff;background:linear-gradient(transparent,rgba(0,0,0,.7));overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-card__remove{position:absolute;top:6px;right:6px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.6);border-radius:50%;color:#fff;cursor:pointer;transition:background var(--transition-fast);border:none}.file-card__remove:hover{background:var(--color-error)}@media (max-width:480px){.file-grid{grid-template-columns:repeat(2,1fr)}}.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:700;display:flex;align-items:center;justify-content:center;cursor:zoom-out;animation:fadeIn .2s ease;padding:var(--space-4)}.lightbox img{max-width:95vw;max-height:90vh;object-fit:contain;border-radius:var(--radius-md);box-shadow:var(--shadow-lg)}.lightbox__close{position:absolute;top:var(--space-4);right:var(--space-4);width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:hsla(0,0%,100%,.1);border-radius:50%;color:#fff;cursor:pointer;border:none;transition:background var(--transition-fast)}.lightbox__close:hover{background:hsla(0,0%,100%,.2)}.splash-screen{position:fixed;top:0;left:0;right:0;bottom:0;z-index:99999;display:flex;align-items:center;justify-content:center;background:#0a0a0a;transition:opacity .4s ease}.splash-screen.splash-fade{opacity:0;pointer-events:none}.splash-logo{font-family:var(--font-logo);font-size:64px;letter-spacing:8px;background:var(--color-accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;color:transparent;filter:drop-shadow(0 2px 0 rgba(255,236,179,.45)) drop-shadow(0 4px 10px rgba(0,0,0,.6));animation:splashGrow 2s ease-out forwards}@keyframes splashGrow{0%{transform:scale(.9);opacity:0}30%{transform:scale(1);opacity:1}70%{transform:scale(1);opacity:1}to{transform:scale(1.08);opacity:1}}.dashboard{display:flex;flex-direction:column;gap:40px;padding-bottom:48px}.banner-grid--hero{display:grid;grid-template-columns:1fr;grid-gap:8px;gap:8px}.banner-grid--solo{display:grid;grid-template-columns:1fr}.banner-grid__main{display:grid}.banner-grid__main .banner-grid__item{aspect-ratio:16/9}.banner-grid__side{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:8px;gap:8px}.banner-grid__side .banner-grid__item{aspect-ratio:16/9}.banner-grid__item{display:block;position:relative;overflow:hidden;border-radius:4px;border:1px solid var(--border);background:var(--bg-surface);transition:border-color var(--transition-fast)}.banner-grid__item--empty{background:var(--bg-surface);border-style:dashed}.banner-grid__item:hover{border-color:var(--color-accent-border)}.banner-grid__item--empty:hover{border-color:var(--border)}.banner-grid__item img,.banner-grid__item picture{width:100%;height:100%;display:block;object-fit:cover}@media (max-width:768px){.banner-grid--hero{grid-template-columns:1fr;gap:6px}.banner-grid__main .banner-grid__item{aspect-ratio:16/9}.banner-grid__side{grid-template-columns:repeat(3,1fr);gap:6px}.banner-grid__side .banner-grid__item{aspect-ratio:16/9}.banner-grid__item{border-radius:2px}}.dash-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.dash-section-title{font-size:20px;font-weight:var(--fw-bold);color:var(--text-primary);margin:0;display:flex;align-items:center;gap:10px}.dash-section-icon{color:var(--color-accent);flex-shrink:0}.dash-section-more{font-size:13px;color:var(--text-muted);text-decoration:none;transition:color var(--transition-fast);display:inline-flex;align-items:center;gap:2px}.dash-section-more:hover{color:var(--color-accent)}.dash-section-tabs{display:flex;gap:0;margin-bottom:16px;border-bottom:1px solid var(--border)}.dash-section-tab{padding:8px 16px;font-size:14px;font-weight:var(--fw-medium);color:var(--text-muted);background:none;border:none;cursor:pointer;position:relative;transition:color var(--transition-fast);font-family:var(--font-sans)}.dash-section-tab:hover{color:var(--text-primary)}.dash-section-tab.active{color:var(--color-accent);font-weight:var(--fw-semi)}.dash-section-tab.active:after{content:"";position:absolute;bottom:-1px;left:8px;right:8px;height:2px;background:var(--color-accent)}.dash-empty{text-align:center;padding:48px 0;color:var(--text-muted);font-size:var(--fs-sm)}.dash-gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:16px;gap:16px}.dash-gallery-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:4px;overflow:hidden;cursor:pointer;transition:border-color var(--transition-fast),transform .2s ease}.dash-gallery-card:hover{border-color:var(--color-accent-border);transform:translateY(-2px)}.dash-gallery-card:hover .dash-gallery-thumb{transform:scale(1.03)}.dash-gallery-thumb-wrap{overflow:hidden;aspect-ratio:4/3}.dash-gallery-thumb{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}.dash-gallery-thumb--empty{width:100%;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);color:var(--text-muted)}.dash-gallery-info{padding:12px 14px}.dash-gallery-title{font-size:14px;font-weight:var(--fw-semi);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4}.dash-gallery-meta{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:center;gap:10px;margin-top:6px;font-size:12px;color:var(--text-muted)}.dash-gallery-meta span{display:inline-flex;align-items:center;gap:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.dash-two-col{display:grid;grid-template-columns:1fr 1fr;grid-gap:32px;gap:32px}.dash-two-col--aligned>.dash-section{display:flex;flex-direction:column}.dash-two-col--aligned .dash-gallery-grid,.dash-two-col--aligned .dash-slots-grid{flex:1 1}.dash-post-list{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.dash-post-item{padding:10px 14px;cursor:pointer;border-bottom:1px solid var(--border);transition:background var(--transition-fast)}.dash-post-item:last-child{border-bottom:none}.dash-post-item:hover{background:var(--bg-hover)}.dash-post-title{font-size:var(--fs-sm);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-post-meta{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:center;gap:10px;margin-top:3px;font-size:12px;color:var(--text-muted)}.dash-post-meta span{display:inline-flex;align-items:center;gap:2px;white-space:nowrap}.dash-slots-grid{display:grid;grid-template-columns:repeat(5,1fr);grid-gap:12px;gap:12px}.dash-slot-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:4px;overflow:hidden;cursor:pointer;text-align:center;transition:border-color var(--transition-fast),transform .2s ease}.dash-slot-card:hover{border-color:var(--color-accent-border);transform:translateY(-2px)}.dash-slot-img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.dash-slot-img--empty{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);color:var(--text-muted)}.dash-slot-name{font-size:13px;font-weight:var(--fw-medium);color:var(--text-primary);padding:8px 8px 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-slot-provider{font-size:11px;color:var(--text-muted);padding:0 8px 8px}.dash-channel-list{background:var(--bg-elevated);border:1px solid var(--border);border-radius:4px;overflow:hidden}.dash-channel-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid var(--border);text-decoration:none;color:inherit;cursor:pointer;transition:background .15s}.dash-channel-item:last-child{border-bottom:none}.dash-channel-item:hover{background:var(--bg-hover)}.dash-channel-img{object-fit:cover}.dash-channel-img,.dash-channel-img--empty{width:36px;height:36px;border-radius:4px;flex-shrink:0}.dash-channel-img--empty{background:var(--color-accent-dim);color:var(--color-accent);display:flex;align-items:center;justify-content:center}.dash-channel-info{flex:1 1;min-width:0}.dash-channel-name{font-size:14px;font-weight:var(--fw-semi);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-channel-meta{display:flex;align-items:center;gap:8px;margin-top:2px}.dash-channel-badge{font-size:11px;padding:1px 6px;border-radius:2px;background:var(--color-accent-dim);color:var(--color-accent);border:1px solid var(--color-accent-border);font-weight:600}.dash-channel-period{display:inline-flex;align-items:center;gap:3px;font-size:11px;color:var(--text-muted);font-family:var(--font-mono)}.dash-hero-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:24px;gap:24px;align-items:start}.dash-hero-row__banners{min-width:0}.dash-hero-row__vendor{min-width:0;display:flex;flex-direction:column;overflow:hidden}.dash-vendor-banners{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:8px;gap:8px;padding:0;margin-top:auto;flex-shrink:0}.dash-vendor-banner{display:block;border-radius:2px;overflow:hidden;border:1px solid var(--border);transition:border-color var(--transition-fast)}.dash-vendor-banner:hover{border-color:var(--border-strong)}.dash-vendor-banner img{width:100%;height:auto;display:block}.dash-vendor-list{flex:1 1;overflow:hidden;border:1px solid var(--border);border-radius:4px}.dash-vendor-item{padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--transition-fast)}.dash-vendor-item:last-child{border-bottom:none}.dash-vendor-item:hover{background:var(--bg-hover)}.dash-vendor-item__title{font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-vendor-item__meta{display:flex;align-items:center;gap:10px;margin-top:4px;font-size:12px;color:var(--text-muted)}.dash-region-tabs{display:flex;gap:4px;margin-bottom:16px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.dash-region-tabs::-webkit-scrollbar{display:none}.dash-region-tab{display:flex;align-items:center;gap:5px;padding:6px 14px;font-size:13px;font-weight:var(--fw-medium);color:var(--text-muted);background:var(--bg-surface);border:1px solid var(--border);border-radius:4px;cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);font-family:var(--font-sans)}.dash-region-tab:hover{border-color:var(--border-strong);color:var(--text-primary)}.dash-region-tab.active{background:var(--color-accent-dim);border-color:var(--color-accent-border);color:var(--color-accent);font-weight:var(--fw-semi)}.dash-region-tab__icon{font-size:14px;line-height:1}.dash-slide-wrap{position:relative;background:#151515;border:1px solid var(--border);border-radius:4px;padding:16px}.dash-slide-track{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;padding:2px 0}.dash-slide-track::-webkit-scrollbar{display:none}.dash-slide-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:rgba(30,30,30,.85);border:1px solid var(--border-strong);border-radius:4px;color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);opacity:0}.dash-slide-wrap:hover .dash-slide-arrow{opacity:1}.dash-slide-arrow:hover{background:#f5f5f5;border-color:#f5f5f5;color:var(--color-red)}.dash-slide-arrow--left{left:-16px}.dash-slide-arrow--right{right:-16px}.dash-slide-card{flex:0 0 200px;scroll-snap-align:start;background:var(--bg-surface);border:1px solid var(--border);border-radius:4px;overflow:hidden;cursor:pointer;transition:border-color var(--transition-fast),transform .2s ease}.dash-slide-card:hover{border-color:var(--color-accent-border);transform:translateY(-2px)}.dash-slide-card__thumb{aspect-ratio:4/3;overflow:hidden}.dash-slide-card__thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}.dash-slide-card__thumb--blur img{filter:blur(12px);-webkit-filter:blur(12px)}.dash-slide-card:hover .dash-slide-card__thumb img{transform:scale(1.03)}.dash-slide-card__thumb--empty{aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);color:var(--text-muted)}.dash-slide-card__info{padding:10px 12px}.dash-slide-card__title{font-size:13px;font-weight:var(--fw-semi);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-slide-card__meta{display:flex;align-items:center;gap:8px;margin-top:4px;font-size:11px;color:var(--text-muted)}.dash-slide-card__meta span{display:inline-flex;align-items:center;gap:2px;font-family:var(--font-mono)}.dash-slide-card__meta span:first-child{font-family:var(--font-sans)}.dash-slide-slot{flex:0 0 140px;scroll-snap-align:start;background:var(--bg-surface);border:1px solid var(--border);border-radius:4px;overflow:hidden;cursor:pointer;text-align:center;transition:border-color var(--transition-fast),transform .2s ease}.dash-slide-slot:hover{border-color:var(--color-accent-border);transform:translateY(-2px)}.dash-slide-slot__img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.dash-slide-slot__img--empty{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);color:var(--text-muted)}.dash-slide-slot__name{font-size:12px;font-weight:var(--fw-medium);color:var(--text-primary);padding:6px 8px 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-slide-slot__provider{font-size:11px;color:var(--text-muted);padding:0 8px 8px}.dash-replay-hero{display:grid;grid-template-columns:3fr 2fr;grid-gap:20px;gap:20px;background:var(--bg-surface);border:1px solid var(--border);border-radius:4px;overflow:hidden;min-height:374px}.dash-replay-hero__player{position:relative;background:#000;min-height:374px}.dash-replay-hero__iframe{width:100%;height:100%;min-height:374px;border:none;display:block}.dash-replay-hero__info{display:flex;flex-direction:column;padding:24px 24px 24px 0;gap:8px}.dash-replay-hero__game{font-size:22px;font-weight:var(--fw-bold);color:var(--text-primary);line-height:1.3}.dash-replay-hero__provider{font-size:14px;color:var(--color-accent);font-weight:var(--fw-semi)}.dash-replay-hero__stats{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px;margin:12px 0}.dash-replay-hero__stat{background:var(--bg-elevated);border:1px solid var(--border);border-radius:4px;padding:10px 12px}.dash-replay-hero__stat-label{display:block;font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.dash-replay-hero__stat-value{display:block;font-size:18px;font-weight:var(--fw-bold);font-family:var(--font-mono);color:var(--text-primary)}.dash-replay-hero__stat-value--accent{color:var(--color-accent)}.dash-replay-hero__badge{padding:8px 12px;border-radius:4px;font-size:13px;font-weight:var(--fw-medium)}.dash-replay-hero__badge--verified{background:var(--color-accent-dim);border:1px solid var(--color-accent-border);color:var(--color-accent)}.dash-replay-hero__badge--suspicious{background:rgba(196,60,60,.12);border:1px solid rgba(196,60,60,.35);color:var(--color-red)}@media (max-width:768px){.dashboard{gap:32px}.dash-hero-row{grid-template-columns:1fr;gap:28px}.dash-slide-card{flex:0 0 160px}.dash-slide-slot{flex:0 0 120px}.dash-slide-arrow{display:none}.dash-replay-hero{grid-template-columns:1fr;min-height:auto}.dash-replay-hero__iframe{min-height:264px}.dash-replay-hero__info{padding:16px}.dash-replay-hero__game{font-size:18px}.dash-replay-hero__stat-value{font-size:15px}.dash-gallery-grid{grid-template-columns:repeat(2,1fr);gap:12px}.dash-two-col{grid-template-columns:1fr;gap:28px}.dash-slots-grid{grid-template-columns:repeat(3,1fr);gap:10px}.splash-logo{font-size:48px;letter-spacing:6px}}.channels-page{padding-bottom:var(--space-6)}.channels-header{margin-bottom:var(--space-5)}.channels-header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.channels-title{font-size:var(--fs-lg);font-weight:var(--fw-bold);color:var(--text-primary);margin:0 0 4px;display:flex;align-items:center;gap:10px}.channels-title-icon{color:var(--color-accent)}.channels-desc{color:var(--text-muted);font-size:var(--fs-xs);margin:0;display:flex;align-items:center}.channels-apply-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--color-accent);color:var(--color-accent-text);border:none;border-radius:2px;font-size:14px;font-weight:600;font-family:var(--font-sans);cursor:pointer;white-space:nowrap;transition:background .15s}.channels-apply-btn:hover{background:var(--color-accent-hover)}.channels-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:var(--space-5);flex-wrap:wrap}.channels-categories{display:flex;gap:6px;flex-wrap:wrap}.channels-cat-btn{padding:6px 14px;border-radius:2px;border:1px solid var(--border-strong);background:transparent;color:var(--text-second);font-size:var(--fs-xs);font-family:var(--font-sans);cursor:pointer;transition:all .15s}.channels-cat-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.channels-cat-btn.active{background:var(--color-accent);color:var(--color-accent-text);border-color:var(--color-accent)}.channels-search-wrap{position:relative}.channels-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.channels-search{padding:8px 12px 8px 32px;border-radius:2px;border:1px solid var(--border-strong);background:var(--bg-surface);color:var(--text-primary);font-size:14px;font-family:var(--font-sans);outline:none;width:220px;max-width:100%;transition:border-color .15s}.channels-search:focus{border-color:var(--color-accent)}.channels-search::placeholder{color:var(--text-muted)}.channels-empty{text-align:center;padding:48px 20px;color:var(--text-muted);font-size:var(--fs-sm)}.channels-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:16px;gap:16px}.channel-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:4px;overflow:hidden;text-decoration:none;color:inherit;position:relative;transition:border-color .15s,transform .15s;cursor:pointer;display:flex;flex-direction:column}.channel-card:hover{border-color:var(--color-accent-border);transform:translateY(-2px)}.channel-card-top{position:relative;padding:16px 16px 0;display:flex;align-items:center;gap:12px}.channel-card-img{object-fit:cover}.channel-card-img,.channel-card-img--empty{width:48px;height:48px;border-radius:4px;flex-shrink:0}.channel-card-img--empty{display:flex;align-items:center;justify-content:center}.channel-card-badge,.channel-card-img--empty{background:var(--color-accent-dim);color:var(--color-accent)}.channel-card-badge{display:inline-block;padding:2px 8px;border-radius:2px;font-size:11px;font-weight:600;border:1px solid var(--color-accent-border)}.channel-card-body{padding:12px 16px 16px;flex:1 1;display:flex;flex-direction:column}.channel-card-name{font-size:var(--fs-sm);font-weight:var(--fw-semi);color:var(--text-primary);margin-bottom:8px}.channel-card-costs{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.channel-card-cost{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--text-second)}.channel-card-cost-label{color:var(--text-muted);font-size:11px}.channel-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto}.channel-card-period{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--text-muted);font-family:var(--font-mono)}.channel-card-link-icon{color:var(--color-accent)}.channel-detail{max-width:700px}.channel-detail-back{display:inline-flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-muted);font-size:var(--fs-xs);font-family:var(--font-sans);cursor:pointer;padding:0;margin-bottom:var(--space-4);transition:color .15s}.channel-detail-back:hover{color:var(--color-accent)}.channel-detail-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:4px;padding:24px}.channel-detail-header{display:flex;align-items:flex-start;gap:20px;margin-bottom:20px}.channel-detail-img{object-fit:cover}.channel-detail-img,.channel-detail-img--empty{width:80px;height:80px;border-radius:4px;flex-shrink:0}.channel-detail-img--empty{background:var(--color-accent-dim);color:var(--color-accent);display:flex;align-items:center;justify-content:center}.channel-detail-info{display:flex;flex-direction:column;gap:6px}.channel-detail-name{font-size:var(--fs-md);font-weight:var(--fw-bold);color:var(--text-primary);margin:0}.channel-detail-period{display:inline-flex;align-items:center;gap:4px;font-size:var(--fs-xs);color:var(--text-muted);font-family:var(--font-mono)}.channel-detail-costs{display:flex;gap:24px;padding:16px;background:var(--bg-surface);border:1px solid var(--border);border-radius:4px;margin-bottom:20px}.channel-detail-cost-item{display:flex;align-items:center;gap:8px;color:var(--text-second);font-size:14px}.channel-detail-cost-label{color:var(--text-muted);font-size:13px}.channel-detail-cost-value{font-weight:var(--fw-semi);color:var(--text-primary)}.channel-detail-desc{color:var(--text-second);font-size:var(--fs-sm);line-height:1.7;margin-bottom:24px}.channel-detail-desc p{margin:0 0 8px}.channel-detail-tg-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:var(--color-accent);color:var(--color-accent-text);font-size:var(--fs-sm);font-weight:var(--fw-semi);font-family:var(--font-sans);border:none;border-radius:2px;cursor:pointer;text-decoration:none;transition:background .15s}.channel-detail-tg-btn:hover{background:var(--color-accent-hover)}.channel-detail-content{margin-top:24px}.channel-detail-content-title{font-size:var(--fs-md);font-weight:var(--fw-bold);color:var(--text-primary);margin:0 0 16px;padding-bottom:8px;border-bottom:1px solid var(--border-strong)}.channel-detail-blocks{display:flex;flex-direction:column;gap:0;max-width:500px;margin:0 auto}.channel-detail-block-img{width:100%}.channel-detail-block-img img{width:100%;display:block;border-radius:2px}.channel-detail-block-text{padding:16px 0;color:var(--text-second);font-size:var(--fs-sm);line-height:1.8}.channel-detail-block-text p{margin:0 0 4px}@media (max-width:768px){.channel-detail-blocks{max-width:100%}}.channel-card-vip{position:absolute;top:8px;right:8px;padding:2px 8px;background:linear-gradient(180deg,#cfc09f 0,#ffecb3 45%,#b8892e 82%,#6e521d);color:#0a0a0a;font-size:10px;font-weight:800;font-family:var(--font-mono);letter-spacing:1px;border-radius:2px;z-index:2}.channel-apply-overlay{position:fixed;inset:0;background:var(--overlay);display:flex;align-items:center;justify-content:center;z-index:500}.channel-apply-modal{background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:4px;padding:24px;width:90%;max-width:480px}.channel-apply-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.channel-apply-title{font-size:var(--fs-md);font-weight:var(--fw-bold);color:var(--text-primary);margin:0}.channel-apply-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;transition:color .15s}.channel-apply-close:hover{color:var(--text-primary)}.channel-apply-warning{background:var(--color-red-dim);border:1px solid var(--color-red-border);border-radius:2px;color:var(--color-red)}.channel-apply-notice,.channel-apply-warning{display:flex;align-items:center;gap:6px;padding:8px 12px;font-size:13px;font-weight:600;margin-bottom:16px}.channel-apply-notice{background:var(--color-accent-dim);border:1px solid var(--color-accent-border);border-radius:2px;color:var(--color-accent)}.channel-apply-form{display:flex;flex-direction:column;gap:12px}.channel-apply-field label{display:block;font-size:13px;font-weight:600;color:var(--text-muted);margin-bottom:4px}.channel-apply-field input,.channel-apply-field textarea{width:100%;padding:8px 12px;font-size:14px;background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:2px;color:var(--text-primary);font-family:var(--font-sans);outline:none;box-sizing:border-box;transition:border-color .15s}.channel-apply-field input:focus,.channel-apply-field textarea:focus{border-color:var(--color-accent)}.channel-apply-field textarea{min-height:70px;resize:vertical}.channel-apply-field input::placeholder,.channel-apply-field textarea::placeholder{color:var(--text-muted)}.channel-apply-submit{width:100%;padding:10px;background:var(--color-accent);color:var(--color-accent-text);border:none;border-radius:2px;font-size:15px;font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:background .15s;margin-top:4px}.channel-apply-submit:hover:not(:disabled){background:var(--color-accent-hover)}.channel-apply-submit:disabled{opacity:.6;cursor:not-allowed}@media (max-width:1023px){.channels-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){.channels-grid{grid-template-columns:repeat(2,1fr)}.channels-toolbar{flex-direction:column;align-items:stretch}.channels-search{width:100%}.channel-detail-header{flex-direction:column;align-items:center;text-align:center}.channel-detail-costs{flex-direction:column;gap:12px}}@media (max-width:480px){.channels-grid{grid-template-columns:1fr}}.vendor-cards{gap:2px}.vendor-card,.vendor-cards{display:flex;flex-direction:column}.vendor-card{gap:8px;padding:16px 20px;background:var(--bg-surface);border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--transition-fast)}.vendor-card:first-child{border-radius:var(--radius-md) var(--radius-md) 0 0}.vendor-card:last-child{border-radius:0 0 var(--radius-md) var(--radius-md);border-bottom:none}.vendor-card:hover{background:var(--bg-hover)}.vendor-card--notice{background:hsla(0,0%,100%,.03);border-left:2px solid var(--color-accent)}.vendor-card--notice:hover{background:var(--bg-hover)}.vendor-card__top{display:flex;align-items:center;justify-content:space-between;gap:8px}.vendor-card__channel{font-size:13px;font-weight:var(--fw-medium);color:var(--text-muted);background:var(--bg-hover);padding:2px 10px;border-radius:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}.vendor-card__channel--notice{color:var(--color-accent);background:var(--color-accent-dim)}.vendor-card__schedule{display:inline-flex;align-items:center;gap:4px;color:var(--text-second);white-space:nowrap}.vendor-card__schedule,.vendor-card__time{font-size:13px;font-family:var(--font-mono)}.vendor-card__time{color:var(--text-muted);flex-shrink:0}.vendor-card__title{font-size:var(--fs-base);font-weight:var(--fw-medium);color:var(--text-primary);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.vendor-card__bottom{display:flex;align-items:center;justify-content:space-between;gap:8px}.vendor-card__author,.vendor-card__stats{font-size:13px;color:var(--text-muted)}.vendor-card__stats{display:flex;align-items:center;gap:12px;font-family:var(--font-mono)}.vendor-card__stats span{display:flex;align-items:center;gap:4px}@media (max-width:600px){.vendor-card{padding:14px}.vendor-card__title{font-size:var(--fs-sm)}.vendor-card__channel{max-width:160px}}.replay-list{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:10px;gap:10px}.replay-card{display:flex;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:border-color var(--transition-fast)}.replay-card:hover{border-color:var(--border-strong)}.replay-card__thumb{width:130px;aspect-ratio:5/3;flex-shrink:0;background:var(--bg-elevated);overflow:hidden}.replay-card__thumb img{width:100%;height:100%;object-fit:cover}.replay-card__thumb-empty{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);opacity:.3}.replay-card__body{flex:1 1;padding:10px 14px;display:flex;flex-direction:column;justify-content:center;gap:4px;min-width:0}.replay-card__row1{display:flex;align-items:center;gap:6px}.replay-card--pinned{border:1.5px solid var(--color-accent)!important;box-shadow:0 0 8px rgba(227,168,18,.15)}.replay-card__provider{font-size:11px;font-weight:var(--fw-semi);color:var(--text-muted);background:var(--bg-hover);padding:1px 6px;border-radius:2px;white-space:nowrap}.replay-card__badge-wrap{margin-left:auto}.replay-card__badge{padding:1px 6px;border-radius:2px;display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:700;white-space:nowrap}.replay-card__badge--ok{background:#00c076;color:#fff}.replay-card__badge--warn{background:#f23645;color:#fff}.replay-card__title{font-size:var(--fs-sm);font-weight:var(--fw-semi);color:var(--text-primary);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.replay-card__wininfo{min-height:18px}.replay-card__multi{font-size:14px;font-weight:700}.replay-card__amount,.replay-card__multi{font-family:var(--font-mono);color:var(--color-accent)}.replay-card__amount{font-size:13px;font-weight:600}.replay-card__bottom{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--text-muted)}.replay-card__stats{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11px}.replay-card__stats span{display:flex;align-items:center;gap:3px}@media (max-width:900px){.replay-list{grid-template-columns:1fr}}@media (max-width:600px){.replay-card__thumb{width:90px}.replay-card__amount{font-size:11px}.replay-card__multi{font-size:12px}.replay-card__body{padding:8px 10px}.replay-card__title{font-size:13px}}.chat-fab{position:fixed;bottom:24px;right:24px;z-index:9000;width:52px;height:52px;border-radius:4px;background:var(--color-accent-gradient);color:var(--bg-base);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,.5);transition:transform .2s}.chat-fab:hover{transform:scale(1.05)}.chat-panel{position:fixed;bottom:24px;right:24px;z-index:9000;width:400px;height:560px;background:var(--bg-base);border:1px solid var(--border-strong);border-radius:4px;display:flex;flex-direction:column;box-shadow:0 8px 32px rgba(0,0,0,.6)}.chat-panel__header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.chat-panel__title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:var(--fw-semi);color:var(--text-primary)}.chat-panel__online{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:var(--fw-regular);color:var(--color-green);font-family:var(--font-mono)}.chat-panel__actions{display:flex;gap:6px}.chat-panel__action-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:2px;color:var(--text-second);cursor:pointer;font-size:12px;font-family:var(--font-sans);font-weight:var(--fw-medium);transition:all var(--transition-fast);white-space:nowrap}.chat-panel__action-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--color-accent-border)}.chat-panel__action-btn--close:hover{color:var(--color-red);border-color:var(--color-red)}.chat-panel__body{flex:1 1;overflow-y:auto;padding:10px 14px;display:flex;flex-direction:column;gap:6px;scrollbar-width:thin;scrollbar-color:var(--bg-hover) transparent}.chat-msg{padding:6px 8px;border-radius:4px;transition:background var(--transition-fast)}.chat-msg:hover{background:hsla(0,0%,100%,.03)}.chat-msg__header{display:flex;align-items:center;gap:6px;margin-bottom:2px}.chat-msg__user{font-size:12px;font-weight:var(--fw-semi);color:var(--color-accent)}.chat-msg--mine .chat-msg__user{color:var(--color-green)}.chat-msg__time{font-size:10px;color:var(--text-muted);font-family:var(--font-mono)}.chat-msg__text{font-size:13px;color:var(--text-primary);line-height:1.5;word-break:break-word}.chat-panel__footer{border-top:1px solid var(--border);padding:10px 14px;flex-shrink:0}.chat-panel__input-wrap{display:flex;gap:8px}.chat-panel__input{flex:1 1;padding:8px 12px;background:var(--bg-surface);border:1px solid var(--border);border-radius:2px;color:var(--text-primary);font-size:13px;font-family:var(--font-sans);outline:none}.chat-panel__input:focus{border-color:var(--color-accent-border)}.chat-panel__send{padding:8px 12px;background:var(--color-accent-gradient);border:none;border-radius:2px;color:var(--bg-base);cursor:pointer;display:flex;align-items:center;font-weight:var(--fw-semi)}.chat-panel__send:disabled{opacity:.4;cursor:default}.chat-panel__login-msg{text-align:center;font-size:13px;color:var(--text-muted);padding:8px;cursor:pointer;border-radius:2px;transition:background var(--transition-fast)}.chat-panel__login-msg:hover{background:var(--bg-hover);color:var(--color-accent)}@media (max-width:600px){.chat-panel{bottom:0;right:0;left:0;width:100%;height:70vh;border-radius:4px 4px 0 0;border-bottom:none}.chat-fab{bottom:16px;right:16px;width:46px;height:46px}.chat-panel__body{padding:10px 12px}.chat-panel__footer{padding:8px 12px}.chat-panel__action-btn{padding:8px 12px;font-size:13px;gap:5px}}.juso-banners{display:grid;grid-template-columns:repeat(6,1fr);grid-gap:var(--space-2);gap:var(--space-2);margin-bottom:var(--space-5)}.juso-banner{display:block;border-radius:4px;overflow:hidden;border:1px solid var(--border);transition:border-color var(--transition-fast),transform var(--transition-fast)}.juso-banner:hover{border-color:var(--color-accent-border);transform:translateY(-1px)}.juso-banner img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}@media (max-width:768px){.juso-banners{grid-template-columns:repeat(3,1fr)}}.replay-banners{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:var(--space-3);gap:var(--space-3)}.replay-banner{display:block;border-radius:4px;overflow:hidden;border:1px solid var(--border);transition:border-color var(--transition-fast)}.replay-banner:hover{border-color:var(--color-accent-border)}.replay-banner img{width:100%;height:auto;display:block}.juso-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:var(--space-4);gap:var(--space-4)}.juso-card{display:block;background:var(--bg-surface);border:1px solid var(--border);border-radius:4px;overflow:hidden;text-decoration:none;transition:border-color var(--transition-fast),transform var(--transition-fast)}.juso-card:hover{border-color:var(--color-accent-border);transform:translateY(-2px)}.juso-card__img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;background:var(--bg-elevated)}.juso-card__img--empty{color:var(--text-muted)}.juso-card__img--empty,.juso-card__noimg{display:flex;align-items:center;justify-content:center}.juso-card__noimg{aspect-ratio:16/9;flex-direction:column;padding:var(--space-4);background:var(--bg-elevated);text-align:center;gap:8px}.juso-card__noimg-title{font-size:var(--fs-md);font-weight:var(--fw-bold);color:var(--text-primary);line-height:1.3;word-break:keep-all}.juso-card__body{padding:var(--space-3)}.juso-card__title{font-size:var(--fs-sm);font-weight:var(--fw-semi);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.juso-card:hover .juso-card__title,.juso-card__title{color:var(--text-primary)}.juso-card__url{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-muted);margin-top:4px;font-family:var(--font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media (max-width:768px){.juso-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-3)}}.chat-full{display:flex;flex-direction:column;height:calc(100vh - 130px);min-height:400px}.chat-full__header{display:flex;align-items:center;justify-content:space-between;padding-bottom:16px;border-bottom:1px solid var(--border);margin-bottom:0}.chat-full__title{display:flex;align-items:center;gap:10px;font-size:20px;font-weight:var(--fw-bold);color:var(--text-primary)}.chat-full__meta{display:flex;align-items:center;gap:16px}.chat-full__online{display:inline-flex;align-items:center;gap:4px;font-size:13px;color:var(--color-green);font-family:var(--font-mono)}.chat-full__body{flex:1 1;overflow-y:auto;padding:16px 0;display:flex;flex-direction:column;gap:4px;scrollbar-width:thin;scrollbar-color:var(--bg-hover) transparent}.chat-full-msg{padding:8px 12px;border-radius:4px;transition:background var(--transition-fast)}.chat-full-msg:hover{background:var(--bg-surface)}.chat-full-msg__header{display:flex;align-items:center;gap:8px;margin-bottom:2px}.chat-full-msg__user{font-size:13px;font-weight:var(--fw-semi);color:var(--color-accent)}.chat-full-msg--mine .chat-full-msg__user{color:var(--color-green)}.chat-full-msg__time{font-size:11px;color:var(--text-muted);font-family:var(--font-mono)}.chat-full-msg__del{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:14px;padding:0 4px;opacity:0}.chat-full-msg:hover .chat-full-msg__del{opacity:1}.chat-full-msg__del:hover{color:var(--color-red)}.chat-full-msg__text{font-size:14px;color:var(--text-primary);line-height:1.6;word-break:break-word}.chat-full__footer{border-top:1px solid var(--border);padding-top:16px}.chat-full__input-wrap{display:flex;gap:10px}.chat-full__input{flex:1 1;padding:12px 16px;background:var(--bg-surface);border:1px solid var(--border);border-radius:4px;color:var(--text-primary);font-size:15px;font-family:var(--font-sans);outline:none}.chat-full__input:focus{border-color:var(--color-accent-border)}.chat-full__send{padding:12px 24px;background:var(--color-accent-gradient);border:none;border-radius:4px;color:var(--bg-base);cursor:pointer;display:flex;align-items:center;gap:6px;font-size:14px;font-weight:var(--fw-semi);font-family:var(--font-sans)}.chat-full__send:disabled{opacity:.4;cursor:default}.chat-full__login-msg{text-align:center;font-size:15px;color:var(--text-muted);padding:12px;cursor:pointer;border-radius:4px;transition:background var(--transition-fast)}.chat-full__login-msg:hover{background:var(--bg-hover);color:var(--color-accent)}