.login-page{min-height:100vh;background:#0b1120;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.login-bg-circle{position:absolute;border-radius:50%;pointer-events:none}.c1{width:600px;height:600px;background:radial-gradient(circle,rgba(26,115,232,.18) 0%,transparent 70%);top:-200px;left:-150px}.c2{width:400px;height:400px;background:radial-gradient(circle,rgba(99,102,241,.12) 0%,transparent 70%);bottom:-100px;right:200px}.c3{width:250px;height:250px;background:radial-gradient(circle,rgba(26,115,232,.1) 0%,transparent 70%);bottom:100px;left:300px}.login-container{display:flex;width:860px;min-height:520px;border-radius:20px;overflow:hidden;box-shadow:0 30px 80px #00000080;position:relative;z-index:1}.login-panel{width:340px;flex-shrink:0;background:linear-gradient(160deg,#1a73e8,#0d47a1 60%,#0a1628);display:flex;align-items:center;justify-content:center;padding:48px 36px;position:relative;overflow:hidden}.login-panel:before{content:"";position:absolute;width:300px;height:300px;border-radius:50%;border:1px solid rgba(255,255,255,.08);top:-80px;right:-80px}.login-panel:after{content:"";position:absolute;width:200px;height:200px;border-radius:50%;border:1px solid rgba(255,255,255,.06);bottom:-60px;left:-60px}.panel-inner{position:relative;z-index:1;width:100%}.panel-logo{margin-bottom:20px}.panel-logo-img{width:140px;height:auto}.panel-company{font-size:26px;font-weight:700;color:#fff;margin:0 0 10px;letter-spacing:-.5px;word-break:keep-all;line-height:1.3}.panel-product{font-size:26px;color:#ffffffe6;margin:0;letter-spacing:-.5px;font-weight:700}.panel-divider{width:40px;height:2px;background:#ffffff4d;margin:24px 0;border-radius:2px}.panel-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.panel-features li{display:flex;align-items:center;gap:10px;font-size:13px;color:#ffffffbf}.feat-dot{width:6px;height:6px;border-radius:50%;background:#ffffff80;flex-shrink:0}.login-form-panel{flex:1;background:#fff;display:flex;flex-direction:column;justify-content:space-between}.login-form-inner{flex:1;display:flex;flex-direction:column;justify-content:center;padding:52px 48px 36px}.login-form-header{margin-bottom:36px}.login-form-header h2{font-size:24px;font-weight:700;color:#0f172a;margin:0 0 8px}.login-form-header p{font-size:13px;color:#94a3b8;margin:0}.login-form{display:flex;flex-direction:column;gap:20px}.login-field{display:flex;flex-direction:column;gap:7px}.login-field label{font-size:12px;font-weight:600;color:#475569;letter-spacing:.3px}.login-input-wrap{position:relative}.login-input-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:#94a3b8;display:flex;align-items:center}.login-input-wrap input{width:100%;padding:11px 14px 11px 40px;font-size:14px;border:1.5px solid #e2e8f0;border-radius:8px;outline:none;transition:border-color .15s,box-shadow .15s;color:#0f172a;background:#f8fafc;box-sizing:border-box}.login-input-wrap input:focus{border-color:#1a73e8;background:#fff;box-shadow:0 0 0 3px #1a73e81f}.login-input-wrap input::placeholder{color:#cbd5e1}.login-error{display:flex;align-items:center;gap:7px;color:#dc2626;font-size:13px;background:#fef2f2;border:1px solid #fecaca;border-radius:7px;padding:9px 12px}.login-btn{width:100%;padding:13px;background:#1a73e8;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:background .15s,transform .1s;display:flex;align-items:center;justify-content:center;margin-top:4px;letter-spacing:.3px}.login-btn:hover:not(:disabled){background:#1557b0}.login-btn:active:not(:disabled){transform:scale(.99)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.login-form-footer{padding:16px 48px;font-size:11px;color:#cbd5e1;text-align:right;border-top:1px solid #f1f5f9}@media (max-width: 700px){.login-container{width:100%;min-height:100vh;flex-direction:column;border-radius:0}.login-panel{width:100%;padding:32px 28px}.panel-features{display:none}.login-form-inner{padding:36px 28px 24px}}.layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:210px;background:#1a73e8;display:flex;flex-direction:column;flex-shrink:0;box-shadow:2px 0 8px #0000001a}.sidebar-logo{padding:22px 18px 18px;border-bottom:1px solid rgba(255,255,255,.2)}.logo-text{display:block;font-size:11px;font-weight:400;color:#ffffffb3;letter-spacing:.3px;word-break:keep-all}.logo-sub{font-size:20px;font-weight:700;color:#fff;margin-top:3px;display:block;letter-spacing:-.5px;word-break:keep-all}.sidebar-nav{flex:1;padding:10px 0}.nav-item{display:flex;align-items:center;gap:10px;padding:11px 18px;color:#fffc;font-size:14px;transition:all .15s;border-left:3px solid transparent}.nav-item:hover{background:#ffffff26;color:#fff}.nav-item.active{background:#fff3;color:#fff;border-left-color:#fff;font-weight:600}.nav-icon{font-size:16px}.sidebar-user{padding:12px 18px;border-top:1px solid rgba(255,255,255,.2);font-size:12px;color:#ffffffb3;cursor:pointer;transition:background .15s;border-radius:6px;margin:0 6px}.sidebar-user:hover{background:#ffffff1a}.sidebar-user:hover .sidebar-pw-hint{opacity:1}.sidebar-username{display:block;font-weight:600;color:#fff;margin-bottom:2px}.sidebar-role{display:block;font-size:11px}.sidebar-pw-hint{display:block;font-size:11px;color:#ffffff73;margin-top:2px;opacity:0;transition:opacity .15s}.logout-btn{width:calc(100% - 24px);margin:10px 12px;padding:8px;background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:6px;font-size:13px;transition:all .15s}.logout-btn:hover{background:#ffffff40}.main-content{flex:1;overflow-y:auto;background:var(--bg-primary);position:relative}.main-footer{position:fixed;bottom:12px;right:16px;font-size:11px;color:var(--text-secondary);opacity:.6;pointer-events:none}.hamburger-btn{display:none}@media (max-width: 768px){.hamburger-btn{display:flex;align-items:center;justify-content:center;position:fixed;top:12px;left:12px;z-index:200;width:40px;height:40px;background:#1a73e8;color:#fff;border:none;border-radius:8px;font-size:20px;cursor:pointer;box-shadow:0 2px 8px #0003}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:300}.sidebar{position:fixed;top:0;left:0;height:100vh;z-index:400;transform:translate(-100%);transition:transform .25s ease}.sidebar.sidebar-open{transform:translate(0)}.main-content{padding-top:60px}}.screen-editor{padding:16px;-webkit-user-select:none;user-select:none}.se-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.se-hint{font-size:12px;color:var(--text-secondary)}.se-size{font-size:12px;color:var(--accent);font-weight:600;background:var(--accent-light);padding:3px 10px;border-radius:12px}.se-canvas-wrap{overflow:auto;background:#e2e8f0;border-radius:8px;padding:12px;display:flex;justify-content:center}.se-canvas{position:relative;background:#1e293b;border-radius:4px;overflow:hidden;box-shadow:0 4px 20px #00000059;flex-shrink:0;cursor:default}.se-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:36px 36px;pointer-events:none;z-index:0}.snap-line{position:absolute;pointer-events:none;z-index:50}.snap-x{top:0;bottom:0;width:1px;background:#ff3c3cd9;box-shadow:0 0 4px #ff3c3c99}.snap-y{left:0;right:0;height:1px;background:#ff3c3cd9;box-shadow:0 0 4px #ff3c3c99}.se-window{position:absolute;border:2px solid;border-radius:3px;z-index:10;display:flex;flex-direction:column;justify-content:space-between;padding:4px 5px;cursor:move;transition:box-shadow .1s;box-sizing:border-box}.se-window.selected{z-index:20;box-shadow:0 0 0 2px #fff,0 0 0 4px #fff6}.se-label{display:flex;align-items:center;gap:5px;pointer-events:none;overflow:hidden}.se-kind{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;background:#ffffff40;padding:1px 5px;border-radius:3px;white-space:nowrap;flex-shrink:0}.se-name{font-size:10px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;opacity:.9}.se-info{font-size:9px;opacity:.75;text-align:right;pointer-events:none;font-family:monospace;letter-spacing:.2px}.se-del{position:absolute;top:2px;right:2px;width:15px;height:15px;background:#dc2626d9;color:#fff;border-radius:50%;font-size:8px;display:none;align-items:center;justify-content:center;padding:0;z-index:30;line-height:1;cursor:pointer}.se-window:hover .se-del{display:flex}.se-h{position:absolute;z-index:25}.se-h-ne,.se-h-nw,.se-h-se,.se-h-sw{width:9px;height:9px;background:#fff;border:2px solid var(--accent);border-radius:50%}.se-h-ne{top:-5px;right:-5px;cursor:ne-resize}.se-h-nw{top:-5px;left:-5px;cursor:nw-resize}.se-h-se{bottom:-5px;right:-5px;cursor:se-resize}.se-h-sw{bottom:-5px;left:-5px;cursor:sw-resize}.se-h-n,.se-h-s{left:8px;right:8px;height:7px;cursor:n-resize;background:transparent}.se-h-n{top:-3px;cursor:n-resize}.se-h-s{bottom:-3px;cursor:s-resize}.se-h-e,.se-h-w{top:8px;bottom:8px;width:7px;background:transparent}.se-h-e{right:-3px;cursor:e-resize}.se-h-w{left:-3px;cursor:w-resize}.se-h-n:hover,.se-h-s:hover,.se-h-e:hover,.se-h-w:hover{background:#ffffff26}.wle-root{display:flex;flex-direction:column;height:100%;background:var(--bg-primary);overflow:hidden}.wle-topbar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--border);background:#fff;flex-shrink:0;gap:12px;flex-wrap:wrap}.wle-region-select{padding:6px 10px;border:1px solid var(--border);border-radius:7px;font-size:13px}.wle-live-badge{font-size:12px;background:#f0fdf4;border:1px solid #bbf7d0;color:#166534;padding:3px 10px;border-radius:10px}.wle-save-status{font-size:12px;color:var(--text-secondary);min-width:60px;text-align:right}.wle-save-status.saved{color:#16a34a;font-weight:600}.wle-save-status.saving{color:#2563eb}.wle-body{display:flex;flex:1;overflow:hidden}.wle-sidebar{width:220px;flex-shrink:0;border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;background:#fff}.wle-sidebar-title{padding:10px 14px 6px;font-size:12px;font-weight:700;color:var(--text-secondary);letter-spacing:.5px}.wle-palette{display:flex;flex-direction:column;gap:4px;padding:0 10px 10px}.wle-palette-btn{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:7px;border:1px solid var(--border);background:#f8fafc;cursor:pointer;font-size:12px;transition:all .12s;text-align:left;position:relative}.wle-palette-btn:hover{background:var(--accent-light);border-color:var(--accent)}.wle-palette-btn.exists{background:#eff6ff;border-color:#93c5fd}.wle-palette-preview{font-size:11px;color:var(--text-secondary);background:#e2e8f0;padding:1px 5px;border-radius:4px;flex-shrink:0;max-width:70px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wle-palette-label{font-weight:600;color:var(--text-primary);flex:1}.wle-exists-dot{font-size:8px;color:#3b82f6;position:absolute;right:8px}.wle-props{border-top:1px solid var(--border);padding:10px;flex:1}.wle-props-title{font-size:12px;font-weight:700;color:var(--text-secondary);display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.wle-del-btn{padding:2px 8px;border-radius:4px;border:1px solid #fca5a5;background:#fef2f2;color:#dc2626;font-size:11px;cursor:pointer}.wle-del-btn:hover{background:#fee2e2}.wle-prop-row{display:flex;align-items:center;gap:5px;margin-bottom:7px;flex-wrap:wrap}.wle-prop-row label{font-size:11px;font-weight:600;color:var(--text-secondary);flex-shrink:0}.wle-prop-row input[type=number]{width:48px;padding:3px 5px;border:1px solid var(--border);border-radius:5px;font-size:12px}.wle-prop-row input[type=color]{width:30px;height:24px;border:1px solid var(--border);border-radius:4px;padding:1px;cursor:pointer;background:none}.wle-prop-row input[type=checkbox]{cursor:pointer}.wle-prop-row select{padding:2px 5px;border:1px solid var(--border);border-radius:5px;font-size:11px}.wle-prop-row span{font-size:11px;color:var(--text-secondary)}.wle-canvas-wrap{flex:1;display:flex;flex-direction:column;align-items:center;padding:16px;overflow:auto;background:#1e293b}.wle-canvas-label{font-size:11px;color:#94a3b8;margin-bottom:10px;align-self:flex-start}.wle-canvas{position:relative;flex-shrink:0;border:2px solid #334155;border-radius:4px;overflow:hidden;cursor:default;-webkit-user-select:none;user-select:none}.wle-canvas-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#0f172a,#1e3a5f)}.wle-canvas-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#475569;font-size:13px;pointer-events:none}.wle-elem{position:absolute;display:flex;align-items:center;cursor:move;border:1px dashed transparent;border-radius:3px;padding:0 4px;box-sizing:border-box;overflow:hidden;white-space:nowrap;font-family:맑은 고딕,sans-serif;transition:border-color .1s}.wle-elem:hover{border-color:#ffffff4d}.wle-elem.selected{border-color:#60a5fa;box-shadow:0 0 0 1px #60a5fa}.win-panel{height:100%;display:flex;flex-direction:column;background:var(--bg-primary)}.win-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border);background:#fff;box-shadow:var(--shadow-sm)}.device-info{display:flex;flex-direction:column;gap:2px}.device-title{font-size:16px;font-weight:700}.device-meta{font-size:12px;color:var(--text-secondary)}.win-body{flex:1;display:flex;flex-direction:column;overflow:hidden}.win-tabs{display:flex;gap:6px;padding:10px 16px;border-bottom:1px solid var(--border);background:#fff;overflow-x:auto;flex-shrink:0}.win-tab{display:flex;align-items:center;gap:6px;padding:6px 14px;background:#f1f5f9;border:1px solid var(--border);border-radius:20px;cursor:pointer;font-size:13px;white-space:nowrap;transition:all .12s;color:var(--text-secondary)}.win-tab:hover{background:var(--bg-hover);border-color:var(--accent);color:var(--accent)}.win-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.win-kind-badge{font-size:11px;background:#0000001a;padding:1px 6px;border-radius:10px}.tab-del{background:none;color:inherit;opacity:.6;font-size:13px;padding:0 2px;line-height:1}.tab-del:hover{opacity:1}.sched-area{flex:1;display:flex;flex-direction:row;overflow:hidden}.sched-list-panel{width:260px;border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;flex-shrink:0;background:#fff}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border);font-size:13px;font-weight:600;position:sticky;top:0;background:#f8fafc;z-index:1}.sched-item{padding:10px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}.sched-item:hover{background:var(--bg-hover)}.sched-item.selected{background:var(--accent-light);border-left:3px solid var(--accent)}.sched-name{font-size:13px;font-weight:500;margin-bottom:3px}.sched-date{font-size:11px;color:var(--text-secondary);margin-bottom:5px}.week-badges{display:flex;gap:3px;margin-bottom:7px}.week-badge{font-size:10px;padding:1px 5px;border-radius:3px;background:#f1f5f9;color:var(--text-secondary);border:1px solid var(--border)}.week-badge.on{background:var(--accent);color:#fff;border-color:var(--accent)}.cont-panel{flex:1;overflow-y:auto;background:var(--bg-primary)}.cont-section{background:#fff;margin:12px;border-radius:8px;border:1px solid var(--border);overflow:hidden}.cont-item{display:flex;align-items:center;gap:8px;padding:9px 14px;border-bottom:1px solid var(--border);font-size:13px;transition:background .12s}.cont-item:last-child{border-bottom:none}.cont-item:hover{background:#f8fafc}.cont-kind{font-size:16px}.cont-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cont-dur{font-size:11px;color:var(--text-secondary);white-space:nowrap}.cont-time{font-size:10px;color:#0891b2;background:#e0f2fe;padding:1px 6px;border-radius:8px;white-space:nowrap}.sched-active-badge{display:inline-block;margin-left:6px;font-size:10px;font-weight:700;color:#16a34a;background:#dcfce7;padding:1px 6px;border-radius:8px;vertical-align:middle}.empty-msg{padding:20px;text-align:center;color:var(--text-secondary);font-size:12px}.win-sidebar{width:160px;flex-shrink:0;background:#fff;border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto}.win-sidebar-header{padding:10px 12px;font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);background:#f8fafc;flex-shrink:0}.win-sidebar-item{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .12s;border-left:3px solid transparent}.win-sidebar-item:hover{background:#f8fafc}.win-sidebar-item.active{background:var(--accent-light);border-left-color:var(--accent)}.wsb-minimap{width:36px;height:28px;flex-shrink:0;background:#e2e8f0;border-radius:3px;position:relative;overflow:hidden}.wsb-minimap-rect{position:absolute;left:var(--dx);top:var(--dy);width:var(--dw);height:var(--dh);border-radius:1px;opacity:.85}.wkd-bg-contents{background:#1a73e8}.wkd-bg-weather{background:#16a34a}.wkd-bg-caption{background:#d97706}.wsb-info{display:flex;flex-direction:column;gap:2px;min-width:0}.wsb-name{font-size:12px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wsb-kind{font-size:11px;font-weight:600}.wkd-text-contents{color:#1a73e8}.wkd-text-weather{color:#16a34a}.wkd-text-caption{color:#d97706}.wsb-size{font-size:10px;color:var(--text-secondary)}.sched-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--text-secondary)}.sched-empty span{font-size:28px}.sched-empty p{font-size:13px;text-align:center}.win-list-section{margin:12px;background:#fff;border-radius:8px;border:1px solid var(--border);overflow:hidden}.win-list-item{display:flex;align-items:center;gap:10px;padding:9px 14px;border-bottom:1px solid var(--border);cursor:pointer;font-size:13px;transition:background .12s}.win-list-item:last-child{border-bottom:none}.win-list-item:hover{background:var(--bg-hover)}.win-list-item.selected{background:var(--accent-light)}.win-kind-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.wkd-contents{background:#1a73e8}.wkd-weather{background:#16a34a}.wkd-caption{background:#d97706}.win-list-name{font-weight:500;flex:0 0 auto}.win-list-meta{font-size:11px;color:var(--text-secondary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:200}.modal{background:#fff;border-radius:10px;padding:28px;width:440px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000026}.modal h3{margin-bottom:20px;font-size:15px;font-weight:700;padding-bottom:12px;border-bottom:1px solid var(--border)}.form-group input[type=text],.form-group input[type=number],.form-group input[type=time],.form-group input[type=date],.form-group select,.form-group textarea{width:100%}.week-selector{display:flex;gap:5px}.week-btn{width:34px;height:34px;border-radius:50%;background:#f1f5f9;color:var(--text-secondary);border:1px solid var(--border);font-size:12px;font-weight:600;transition:all .12s}.week-btn.on{background:var(--accent);color:#fff;border-color:var(--accent)}.news-toggle-row{display:flex;align-items:center;gap:10px;padding:8px 14px;background:#f8fafc;border-bottom:1px solid var(--border);flex-wrap:wrap}.news-toggle-label{font-size:13px;font-weight:600;color:var(--text-primary)}.news-toggle-btn{padding:4px 14px;border-radius:14px;border:none;font-size:12px;font-weight:700;cursor:pointer;transition:all .12s}.news-toggle-btn.news-on{background:#0891b2;color:#fff}.news-toggle-btn.news-off{background:#e2e8f0;color:var(--text-secondary)}.news-toggle-btn.news-on:hover{background:#0e7490}.news-toggle-btn.news-off:hover{background:#cbd5e1;color:var(--text-primary)}.news-toggle-hint{font-size:11px;color:#0891b2;font-style:italic}.news-style-panel{background:#f8fafc;border-bottom:1px solid var(--border);padding:10px 14px}.news-style-row2{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-end;margin-bottom:10px}.news-style-item2{display:flex;flex-direction:column;gap:4px}.news-style-item2 label{font-size:11px;font-weight:600;color:var(--text-secondary)}.news-style-item2 input[type=number]{padding:4px 6px;border:1px solid var(--border);border-radius:5px;font-size:12px}.news-style-item2 input[type=color]{width:32px;height:28px;border:1px solid var(--border);border-radius:5px;padding:2px;cursor:pointer;background:none}.news-style-preview{padding:6px 12px;border-radius:6px;font-family:맑은 고딕,sans-serif;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:14px}.weather-region-panel{width:280px;flex-shrink:0;border-right:1px solid var(--border);overflow-y:auto;background:#fff}.weather-preview-card{background:linear-gradient(135deg,#0f172a,#1e3a5f);border-radius:10px;padding:16px;color:#fff;display:flex;flex-direction:column;gap:6px}.wp-city{font-size:13px;font-weight:700;opacity:.8;letter-spacing:1px}.wp-temp{font-size:22px;font-weight:800}.wp-dust{display:flex;flex-direction:column;gap:3px;font-size:12px;opacity:.85}.wp-time{font-size:11px;opacity:.5;margin-top:4px}.device-page{display:flex;height:100vh;overflow:hidden;background:var(--bg-primary)}.group-sidebar{width:220px;flex-shrink:0;background:#fff;border-right:1px solid var(--border);display:flex;flex-direction:column}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:14px 14px 10px;border-bottom:1px solid var(--border);font-size:13px;font-weight:700;color:var(--text-primary)}.inline-form{display:flex;gap:5px;padding:8px 10px;border-bottom:1px solid var(--border);background:#f8fafc}.inline-form input{flex:1;min-width:0}.group-list{flex:1;overflow-y:auto;padding:6px 0}.sidebar-empty{padding:24px 16px;text-align:center;font-size:12px;color:var(--text-secondary)}.group-item{display:flex;align-items:center;gap:8px;padding:10px 12px;cursor:pointer;border-radius:8px;margin:2px 6px;transition:background .12s;position:relative}.group-item:hover{background:#f1f5f9}.group-item.active{background:var(--accent-light)}.group-item.active .group-name{color:var(--accent);font-weight:700}.group-icon{font-size:15px;flex-shrink:0}.group-name{flex:1;font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.group-badge{background:var(--accent-light);color:var(--accent);font-size:11px;font-weight:700;padding:2px 7px;border-radius:10px;flex-shrink:0}.group-del-btn{display:none;background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:11px;padding:2px 4px;border-radius:4px;line-height:1}.group-del-btn:hover{background:#fee2e2;color:#dc2626}.group-item:hover .group-del-btn{display:block}.device-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.main-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-secondary);gap:12px}.main-empty span{font-size:52px}.main-empty p{font-size:14px}.view-topbar{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:#fff;border-bottom:1px solid var(--border);flex-shrink:0;gap:12px;min-height:56px}.topbar-left{display:flex;align-items:center;gap:10px;min-width:0}.back-btn{white-space:nowrap;flex-shrink:0}.topbar-title{font-size:15px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-count{font-size:12px;color:var(--text-secondary);white-space:nowrap}.topbar-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.power-btn-group{display:flex;gap:6px;padding:4px 10px;background:#f8fafc;border:1px solid var(--border);border-radius:8px}.status-pill{font-size:11px;font-weight:600;padding:3px 10px;border-radius:12px;background:#f1f5f9;color:var(--text-secondary);white-space:nowrap}.status-pill.online{background:#dcfce7;color:#16a34a}.status-pill.offline{background:#f1f5f9;color:#94a3b8}.group-view{flex:1;display:flex;flex-direction:column;overflow:hidden}.device-grid{flex:1;overflow-y:auto;padding:24px;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,220px));gap:20px;align-content:start;align-items:start}.device-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px 12px 12px;cursor:pointer;transition:box-shadow .15s,transform .15s;display:flex;flex-direction:column;align-items:center;position:relative}.device-card:hover{box-shadow:0 6px 20px #00000021;transform:translateY(-3px)}@keyframes dv-pulse{0%,to{background:#16a34a;box-shadow:inset 0 0 12px #4ade804d}50%{background:#22c55e;box-shadow:inset 0 0 24px #4ade8099}}@keyframes dv-win-pulse{0%,to{opacity:.88;filter:brightness(1.05)}50%{opacity:1;filter:brightness(1.35)}}.dv-screen{width:100%;height:100%;border-radius:2px}.dv-offline{background:#0a0f1a}.dv-online{background:#16a34a;animation:dv-pulse 2s ease-in-out infinite;box-shadow:0 0 10px #3b82f659,inset 0 0 8px #3b82f626}.dv-did-frame{width:100%;background:#1e293b;border-radius:5px;padding:6px;box-shadow:0 2px 8px #0006;position:relative}.dv-did-frame .dv-screen{aspect-ratio:16 / 9}.dv-did-frame.dv-did-vertical{width:52%}.dv-did-frame.dv-did-vertical .dv-screen{aspect-ratio:9 / 16}.dv-kiosk-outer{display:flex;flex-direction:column;align-items:center;width:100%}.dv-kiosk-frame{width:48%;background:#1e293b;border-radius:6px 6px 0 0;padding:5px;box-shadow:0 2px 8px #0006}.dv-kiosk-frame .dv-screen{aspect-ratio:9 / 16}.dv-kiosk-pole{width:48%;height:22px;background:linear-gradient(to bottom,#253347,#334155);border-radius:0 0 3px 3px}.dv-kiosk-base{width:56%;height:7px;background:#475569;border-radius:2px;box-shadow:0 2px 4px #0000004d}.dv-ev-frame{width:82%;background:#1e293b;border-radius:4px;padding:10px;box-shadow:0 2px 8px #0006;border:2px solid #0f172a}.dv-ev-frame .dv-screen{aspect-ratio:4 / 3}.dv-mv-frame{width:100%;background:#0f172a;border-radius:5px;padding:7px;box-shadow:0 2px 8px #0006}.dv-mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px;aspect-ratio:16 / 9}.dv-mv-cell{border-radius:1px}.dv-mv-cell.dv-offline{background:#0a0f1a}.dv-mv-cell.dv-online{background:#16a34a;animation:dv-pulse 2s ease-in-out infinite}.card-info{width:100%;text-align:center;margin-top:10px}.card-name{font-size:13px;font-weight:700;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:4px}.card-type-badge{display:inline-block;font-size:10px;font-weight:700;color:var(--accent);background:var(--accent-light);padding:1px 8px;border-radius:10px;margin-bottom:3px}.card-meta{font-size:11px;color:var(--text-secondary);line-height:1.5}.card-group{font-size:10px;color:#60a5fa;margin-bottom:2px}.card-id{font-size:10px;color:#94a3b8;margin-top:2px}.card-actions{display:none;gap:4px;margin-top:10px;flex-wrap:wrap;justify-content:center}.device-card:hover .card-actions{display:flex}.device-view{flex:1;display:flex;flex-direction:column;overflow:hidden}.device-view-body{flex:1;overflow:hidden}.btn-power-on{background:#16a34a;color:#fff;border:none}.btn-power-on:hover:not(:disabled){background:#15803d}.btn-power-off{background:#dc2626;color:#fff;border:none}.btn-power-off:hover:not(:disabled){background:#b91c1c}.btn-reboot{background:#d97706;color:#fff;border:none}.btn-reboot:hover:not(:disabled){background:#b45309}.btn-copy{background:#0891b2;color:#fff;border:none}.btn-copy:hover{background:#0e7490}.btn-display-start{background:#16a34a;color:#fff;border:none}.btn-display-start:hover:not(:disabled){background:#15803d}.btn-player-restart{background:#2563eb;color:#fff;border:none}.btn-player-restart:hover:not(:disabled){background:#1d4ed8}.btn-display-start:disabled,.btn-player-restart:disabled{opacity:.5;cursor:not-allowed}.btn-apply{background:#7c3aed;color:#fff;border:none}.btn-apply:hover{background:#6d28d9}.btn-power-on:disabled,.btn-power-off:disabled,.btn-reboot:disabled{opacity:.5;cursor:not-allowed}.btn-xs{padding:3px 8px;font-size:11px;border-radius:5px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:#fff;border:1px solid var(--border);border-radius:10px;padding:28px;width:480px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-md)}.modal h3{margin-bottom:20px;font-size:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}.form-group input[type=text],.form-group input[type=number],.form-group input[type=time],.form-group select{width:100%}.row-inputs{display:flex;align-items:center;gap:8px}.device-card.unapproved{opacity:.6;cursor:default}.device-card.unapproved:hover{transform:none;box-shadow:none}.unapproved-badge{position:absolute;top:6px;left:6px;background:#dc2626;color:#fff;font-size:11px;font-weight:700;padding:2px 7px;border-radius:4px;pointer-events:none;z-index:10}.btn-preview{background:#0ea5e9;color:#fff;border:none}.btn-preview:hover:not(:disabled){background:#0284c7}.btn-preview:disabled{opacity:.6;cursor:default}.snapshot-modal{width:800px!important;max-width:92vw}.snapshot-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}.snapshot-modal-header h3{margin-bottom:0;border:none;padding:0;font-size:15px}.snapshot-img{width:100%;border-radius:6px;border:1px solid var(--border);display:block}.snapshot-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px;color:var(--text-secondary);font-size:14px;text-align:center}.snapshot-error span{font-size:40px}.btn-update{background:#7c3aed;color:#fff;border:none;font-weight:600}.btn-update:hover:not(:disabled){background:#6d28d9}.btn-update:disabled{opacity:.6;cursor:default}.update-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.update-popup{background:#fff;border-radius:16px;padding:40px 48px;text-align:center;box-shadow:0 20px 60px #00000040;display:flex;flex-direction:column;align-items:center;gap:14px;min-width:320px;animation:popIn .25s ease}@keyframes popIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.update-spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#7c3aed;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.update-check{width:52px;height:52px;background:#10b981;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:26px;font-weight:700;animation:popIn .3s ease}.update-popup-title{font-size:17px;font-weight:700;color:var(--text-primary)}.update-popup-msg{font-size:13px;color:var(--text-secondary);line-height:1.6}.update-error-icon{width:52px;height:52px;background:#dc2626;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;font-weight:700;animation:popIn .3s ease}.update-spinner-retry{border-top-color:#f59e0b}.media-page{padding:24px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.page-header h2{font-size:18px;font-weight:700}.upload-area{display:flex;align-items:center;gap:12px}.progress-bar{width:200px;height:20px;background:#f1f5f9;border-radius:10px;overflow:hidden;position:relative;border:1px solid var(--border)}.progress-fill{height:100%;background:var(--accent);transition:width .2s}.progress-bar span{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--text-primary);font-weight:600}.media-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:20px}.media-tab{padding:10px 20px;font-size:14px;font-weight:600;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;gap:8px;transition:color .15s}.media-tab:hover{color:var(--text-primary)}.media-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-count{background:var(--accent-light);color:var(--accent);font-size:11px;font-weight:700;padding:1px 7px;border-radius:10px}.media-grid{display:flex;flex-wrap:wrap;gap:12px}.media-card{width:180px;background:#fff;border:1px solid var(--border);border-radius:8px;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:box-shadow .15s}.media-card:hover{box-shadow:var(--shadow-md)}.media-thumb{height:100px;display:flex;align-items:center;justify-content:center;background:#f1f5f9;font-size:36px}.image-thumb img{width:100%;height:100%;object-fit:cover}.media-info{padding:8px 10px;flex:1;display:flex;flex-direction:column;gap:3px}.media-name{font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.media-size{font-size:11px;color:var(--text-secondary)}.media-card .btn{margin:0 8px 8px}.empty-msg{color:var(--text-secondary);font-size:13px;padding:20px}.log-page{padding:24px;height:100vh;display:flex;flex-direction:column}.page-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.page-header h2{font-size:18px;font-weight:700;margin:0 0 4px}.log-type-badge{padding:2px 8px;border-radius:10px;font-size:11px;color:#fff;white-space:nowrap;font-weight:600}.log-sender{font-weight:600}.log-empty{text-align:center;padding:40px;color:var(--text-secondary)}.log-row-warning td{background:#fffbeb}.log-row-error td{background:#fef2f2}.log-row-ok td{background:#f0fdf4}.account-page{padding:24px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px}.acc-tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:2px solid var(--border)}.acc-tab{padding:8px 18px;font-size:13px;font-weight:600;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;gap:6px;transition:color .12s}.acc-tab:hover{color:var(--text-primary)}.acc-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.trash-badge{background:#dc2626;color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px}.account-table-wrap{background:#fff;border:1px solid var(--border);border-radius:10px;overflow:hidden;box-shadow:var(--shadow-sm)}.trash-notice{padding:8px 16px;font-size:12px;color:#92400e;background:#fef9c3;border-bottom:1px solid #fde68a}.account-table{width:100%;border-collapse:collapse;font-size:14px}.account-table th{background:#f8fafc;padding:11px 16px;text-align:left;border-bottom:2px solid var(--border);font-size:12px;font-weight:600;color:var(--text-secondary)}.account-table td{padding:10px 16px;border-bottom:1px solid var(--border);vertical-align:middle}.account-table tr:last-child td{border-bottom:none}.account-table tr:hover td{background:#f8fafc}.row-suspended td{opacity:.6}.row-suspended .td-username{text-decoration:line-through;color:var(--text-secondary)}.row-trash td{color:var(--text-secondary)}.td-empty{text-align:center;padding:32px 24px!important;color:var(--text-secondary);font-size:13px}.role-badge{padding:3px 10px;border-radius:12px;font-size:12px;font-weight:600}.status-badge{padding:3px 10px;border-radius:12px;font-size:12px;font-weight:600}.status-badge.active{background:#dcfce7;color:#16a34a}.status-badge.suspended{background:#fee2e2;color:#dc2626}.days-badge{font-size:12px;font-weight:700;color:#64748b}.days-badge.urgent{color:#dc2626}.row-actions{display:flex;gap:6px}.btn-edit{background:#f1f5f9;color:var(--text-primary);border:1px solid var(--border)}.btn-edit:hover{background:#e2e8f0}.btn-suspend{background:#fef3c7;color:#92400e;border:1px solid #fde68a}.btn-suspend:hover{background:#fde68a}.btn-unsuspend{background:#dcfce7;color:#166534;border:1px solid #86efac}.btn-unsuspend:hover{background:#bbf7d0}.btn-restore{background:var(--accent-light);color:var(--accent);border:1px solid #c7d2fe}.btn-restore:hover{background:#c7d2fe}.modal{background:#fff;border-radius:10px;padding:28px;width:400px;box-shadow:0 20px 60px #00000026}.modal h3{margin-bottom:20px;font-size:16px;font-weight:700;padding-bottom:12px;border-bottom:1px solid var(--border)}.form-group input,.form-group select{width:100%}.expires-date{font-size:13px;color:var(--text-primary)}.expires-none{font-size:13px;color:var(--text-secondary)}.expires-over{font-size:13px;color:#dc2626;font-weight:600}.org-page{padding:24px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px}.org-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.org-card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:18px;box-shadow:var(--shadow-sm)}.org-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}.org-name{display:block;font-size:16px;font-weight:700;margin-bottom:3px}.org-folder{display:block;font-size:12px;color:var(--text-secondary)}.org-accounts{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px;align-items:center}.org-label{font-size:11px;font-weight:600;color:var(--text-secondary)}.org-account-badge{font-size:11px;padding:2px 8px;border-radius:10px;border:1px solid var(--border)}.org-account-badge.admin{background:var(--accent-light);color:var(--accent);border-color:#bfdbfe}.org-account-badge.user{background:#f1f5f9;color:var(--text-secondary)}.org-meta{font-size:11px;color:var(--text-secondary)}.org-empty{grid-column:1/-1;text-align:center;padding:48px;color:var(--text-secondary);background:#fff;border-radius:10px;border:1px dashed var(--border)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:#fff;border-radius:10px;padding:28px;width:460px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000026}.modal h3{margin-bottom:8px;font-size:16px;font-weight:700;padding-bottom:12px;border-bottom:1px solid var(--border)}.form-grid{display:flex;flex-direction:column;gap:14px}.form-group{display:flex;flex-direction:column;gap:5px}.form-group label{font-size:12px;font-weight:600;color:var(--text-secondary)}.form-group input{width:100%}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:24px;padding-top:16px;border-top:1px solid var(--border)}.org-account-badge.suspended{opacity:.5;text-decoration:line-through}.org-dday{display:inline-block;margin-left:5px;padding:1px 5px;background:#fef9c3;color:#b45309;font-size:10px;font-weight:700;border-radius:4px;border:1px solid #fde68a}.org-dday.urgent{background:#fef2f2;color:#dc2626;border-color:#fecaca}.access-log-page{padding:24px;height:100vh;display:flex;flex-direction:column}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}.log-table-wrap{flex:1;overflow-y:auto;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow-sm)}.log-table{width:100%;border-collapse:collapse;font-size:13px}.log-table th{background:#f8fafc;padding:10px 14px;text-align:left;border-bottom:2px solid var(--border);position:sticky;top:0;font-size:12px;font-weight:600;color:var(--text-secondary)}.log-table td{padding:9px 14px;border-bottom:1px solid var(--border);vertical-align:middle}.log-table tr:hover td{background:#f8fafc}.log-time{color:var(--text-secondary);font-size:12px;white-space:nowrap}.role-badge{padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}.role-badge.master{background:#fef3c7;color:#92400e}.role-badge.admin{background:var(--accent-light);color:var(--accent)}.role-badge.user{background:#f1f5f9;color:var(--text-secondary)}.result-badge{padding:2px 10px;border-radius:10px;font-size:11px;font-weight:600}.result-badge.success{background:#dcfce7;color:#16a34a}.result-badge.fail{background:#fee2e2;color:#dc2626}.stats-page{padding:24px;overflow-y:auto}.stat-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}.stat-card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:20px;text-align:center;box-shadow:var(--shadow-sm)}.stat-icon{font-size:28px;margin-bottom:8px}.stat-value{font-size:32px;font-weight:800;color:var(--accent);line-height:1;margin-bottom:4px}.stat-label{font-size:12px;color:var(--text-secondary)}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.stats-panel{background:#fff;border:1px solid var(--border);border-radius:10px;padding:20px;box-shadow:var(--shadow-sm)}.stats-panel h3{font-size:14px;font-weight:700;margin-bottom:16px;color:var(--text-primary)}.empty-msg{color:var(--text-secondary);font-size:13px}.org-device-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}.org-device-name{font-size:13px;font-weight:500;width:100px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.org-device-bar-wrap{flex:1;height:10px;background:#f1f5f9;border-radius:5px;overflow:hidden}.org-device-bar{height:100%;background:var(--accent);border-radius:5px;transition:width .3s;min-width:4px}.org-device-count{font-size:12px;color:var(--text-secondary);display:flex;align-items:center;gap:4px;white-space:nowrap}.online-dot{width:6px;height:6px;border-radius:50%;background:var(--online)}.trend-chart{display:flex;align-items:flex-end;gap:8px;height:140px;padding-top:20px}.trend-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end;gap:4px}.trend-count{font-size:11px;font-weight:600;color:var(--accent);min-height:16px}.trend-bar{width:100%;background:var(--accent);border-radius:4px 4px 0 0;min-height:4px;transition:height .3s;opacity:.8}.trend-date{font-size:10px;color:var(--text-secondary);white-space:nowrap}.storage-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:8px;flex-wrap:wrap}.storage-panel-header h3{margin-bottom:0}.storage-period-tabs{display:flex;gap:4px}.storage-period-tab{padding:4px 10px;font-size:12px;border:1px solid var(--border);border-radius:6px;background:#fff;color:var(--text-secondary);cursor:pointer;transition:all .15s}.storage-period-tab:hover{border-color:var(--accent);color:var(--accent)}.storage-period-tab.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}.storage-total{font-size:12px;font-weight:400;color:var(--text-secondary);margin-left:8px}.storage-bar{background:#10b981}.storage-size{font-size:12px;color:var(--text-secondary);white-space:nowrap;min-width:60px;text-align:right}.settings-page{padding:24px;max-width:720px}.page-header{margin-bottom:24px}.page-header h2{font-size:18px;font-weight:700;margin-bottom:4px}.page-desc{font-size:13px;color:var(--text-secondary)}.settings-card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:24px;box-shadow:var(--shadow-sm)}.settings-section-title{font-size:15px;font-weight:700;margin-bottom:8px;color:var(--text-primary)}.settings-desc{font-size:13px;color:var(--text-secondary);line-height:1.7;margin-bottom:16px}.rss-presets{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.preset-btn{padding:5px 14px;border-radius:16px;border:1px solid var(--border);background:#f8fafc;font-size:12px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .12s}.preset-btn:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent)}.rss-input-row{display:flex;gap:8px;align-items:center;margin-bottom:20px}.rss-input{flex:1;padding:9px 12px;border:1px solid var(--border);border-radius:7px;font-size:13px;outline:none}.rss-input:focus{border-color:var(--accent)}.headlines-preview{background:#f8fafc;border:1px solid var(--border);border-radius:8px;overflow:hidden}.headlines-title{padding:10px 14px;font-size:12px;font-weight:700;color:var(--text-secondary);border-bottom:1px solid var(--border);background:#f1f5f9}.headlines-list{list-style:none;max-height:320px;overflow-y:auto}.headline-item{display:flex;align-items:flex-start;gap:10px;padding:9px 14px;border-bottom:1px solid var(--border);font-size:13px;line-height:1.5}.headline-item:last-child{border-bottom:none}.headline-num{font-size:11px;font-weight:700;color:var(--accent);background:var(--accent-light);padding:1px 6px;border-radius:8px;flex-shrink:0;margin-top:1px}.no-rss-msg{font-size:12px;color:var(--text-secondary);font-style:italic}.news-style-row{display:flex;flex-wrap:wrap;gap:20px;align-items:flex-end;padding:16px 0 12px;border-top:1px solid var(--border);margin-top:4px}.news-style-item{display:flex;flex-direction:column;gap:6px}.news-style-item label{font-size:12px;font-weight:600;color:var(--text-secondary)}.news-style-item input[type=number]{padding:6px 8px;border:1px solid var(--border);border-radius:6px;font-size:13px}.news-style-item input[type=color]{width:36px;height:32px;border:1px solid var(--border);border-radius:6px;padding:2px;cursor:pointer;background:none}.style-unit{font-size:11px;color:var(--text-secondary);margin-top:-4px}.style-swatch{font-size:11px;padding:2px 6px;border-radius:4px;border:1px solid var(--border)}.news-preview-bar{width:100%;padding:10px 14px;border-radius:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:4px;margin-bottom:16px;box-sizing:border-box;font-family:맑은 고딕,sans-serif}.ip-list{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px;min-height:36px}.ip-empty{font-size:13px;color:var(--text-secondary);padding:6px 0}.ip-item{display:flex;align-items:center;gap:6px;background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:4px 10px 4px 12px}.ip-value{font-family:monospace;font-size:14px;font-weight:600}.ip-del-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:13px;line-height:1;padding:0 2px}.ip-del-btn:hover{color:#dc2626}.ip-add-row{display:flex;gap:8px;margin-bottom:8px}.ip-input{flex:1;max-width:260px}.ip-error{color:#dc2626;font-size:13px;margin-bottom:8px}.ip-notice{font-size:12px;color:var(--text-secondary);margin-top:10px}.ip-notice a{color:var(--accent)}.approval-page{padding:24px;max-width:1100px}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.page-header h2{font-size:20px;font-weight:700;color:var(--text-primary);margin:0 0 4px}.page-desc{font-size:13px;color:var(--text-secondary);margin:0}.approval-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:80px 0;color:var(--text-secondary);font-size:15px}.approval-table-wrap{overflow-x:auto;border-radius:8px;border:1px solid var(--border)}.approval-table{width:100%;border-collapse:collapse;font-size:14px}.approval-table th{background:var(--surface-2);padding:10px 14px;text-align:left;font-weight:600;color:var(--text-secondary);font-size:12px;border-bottom:1px solid var(--border)}.approval-table td{padding:12px 14px;border-bottom:1px solid var(--border);color:var(--text-primary)}.approval-table tr:last-child td{border-bottom:none}.approval-table tr:hover td{background:var(--surface-2)}.td-org{font-weight:600}.td-name{font-weight:600;color:var(--accent)}.td-ip{font-family:monospace;font-size:13px}.type-badge{padding:2px 8px;background:#1e3a5f;color:#60a5fa;border-radius:4px;font-size:12px;font-weight:600}.btn-approve{background:#16a34a;color:#fff;border:none;padding:5px 14px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer}.btn-approve:hover:not(:disabled){background:#15803d}.btn-approve:disabled{opacity:.5;cursor:not-allowed}.appr-tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid var(--border);padding-bottom:0}.appr-tab{padding:8px 18px;border:none;background:none;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.appr-tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.appr-badge{display:inline-block;background:#dc2626;color:#fff;font-size:11px;font-weight:700;border-radius:8px;padding:1px 6px;margin-left:4px}.url-notice{padding:10px 14px;background:var(--surface-2);border-bottom:1px solid var(--border);font-size:13px;color:var(--text-secondary)}.url-notice code{background:var(--surface-3, #1e293b);padding:1px 6px;border-radius:4px;font-size:13px;color:var(--text-primary)}.url-id-badge{display:inline-block;background:#1a73e8;color:#fff;font-size:12px;font-weight:700;font-family:monospace;padding:3px 10px;border-radius:5px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Malgun Gothic,맑은 고딕,-apple-system,sans-serif;background:#f0f4f8;color:#1e293b;font-size:14px}:root{--bg-primary: #f0f4f8;--bg-secondary: #ffffff;--bg-card: #e8f0fe;--bg-hover: #dbeafe;--accent: #1a73e8;--accent-hover: #1557b0;--accent-light: #e8f0fe;--text-primary: #1e293b;--text-secondary: #64748b;--border: #dde3ea;--border-focus: #1a73e8;--success: #16a34a;--warning: #d97706;--error: #dc2626;--online: #16a34a;--offline: #94a3b8;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 12px rgba(0,0,0,.1)}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;outline:none;font-family:inherit}input,select,textarea{font-family:inherit;background:#fff;border:1px solid var(--border);color:var(--text-primary);padding:7px 10px;border-radius:6px;outline:none;transition:border-color .15s;font-size:14px}input:focus,select:focus,textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #1a73e81f}.btn{padding:7px 16px;border-radius:6px;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex;align-items:center;gap:5px}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:#fff;color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-hover)}.btn-danger{background:transparent;color:var(--error);border:1px solid #fca5a5}.btn-danger:hover{background:var(--error);color:#fff;border-color:var(--error)}.btn-sm{padding:4px 10px;font-size:12px;border-radius:5px}.btn:disabled{opacity:.5;cursor:not-allowed}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}
