:root{--bg: #121212;--bg-panel: #181a1b;--bg-card: #202325;--bg-input: #282c2f;--bg-hover: #32373b;--bg-active: #193330;--bdr: rgba(255, 255, 255, .08);--bdr-hi: rgba(255, 255, 255, .16);--bdr-bright: rgba(0, 255, 204, .4);--teal: #00ffcc;--teal-light: #5effda;--teal-dim: rgba(0, 255, 204, .15);--teal-bdr: rgba(0, 255, 204, .4);--green: #10b981;--pink: #f43f5e;--pink-dim: rgba(244, 63, 94, .15);--amber: #f59e0b;--blue: #3b82f6;--purple: #8b5cf6;--t1: #ffffff;--t2: #a1a1aa;--t3: #52525b;--r: 10px;--r-sm: 6px;--r-xs: 4px;--font: "Inter", system-ui, -apple-system, sans-serif;--mono: "DM Mono", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}body.admin-body{overflow:auto}body{background-color:var(--bg);background-image:linear-gradient(rgba(0,255,204,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(0,255,204,.04) 1px,transparent 1px);background-size:30px 30px;color:var(--t1);font-family:var(--font);font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button,input,select{font-family:inherit}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}#root{height:100vh}.app{display:grid;grid-template-columns:270px 390px 1fr;height:100vh;overflow:hidden}.left-col{display:flex;flex-direction:column;overflow:hidden;background:transparent;border-right:1px solid var(--bdr)}.search-wrap{padding:14px 14px 10px;position:relative;flex-shrink:0}.search-box{width:100%;background:var(--bg-input);border:1px solid var(--bdr-hi);color:var(--t1);padding:9px 12px 9px 36px;border-radius:var(--r);font-size:12px;outline:none;transition:border-color .15s,box-shadow .15s}.search-box:focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-dim)}.search-box::placeholder{color:var(--t3)}.search-icon{position:absolute;left:26px;top:50%;transform:translateY(-50%);color:var(--t3);pointer-events:none;display:flex}.sec-head{font-size:10px;font-weight:700;color:var(--teal);letter-spacing:.1em;text-transform:uppercase;padding:10px 14px 6px;display:flex;align-items:center;gap:7px;border-top:1px solid var(--bdr)}.cat-section{flex-shrink:0}.cat-list{padding:0 10px 4px}.cat-item{padding:8px 10px;border-radius:var(--r-sm);cursor:pointer;font-size:12px;font-weight:500;color:var(--t2);transition:all .12s;border:1px solid transparent;display:flex;align-items:center;justify-content:space-between;gap:6px;margin-bottom:1px}.cat-item:hover{background:var(--bg-hover);color:var(--t1);border-color:var(--bdr)}.cat-item.active{background:var(--teal-dim);border-color:var(--teal-bdr);color:var(--teal-light);font-weight:600}.cat-item.vert-cat:hover{background:var(--pink-dim)}.cat-item.vert-cat.active{background:var(--pink-dim);border-color:#f43f5e66;color:#fda4af}.cat-badge{font-family:var(--mono);font-size:10px;background:#ffffff14;color:var(--t3);padding:1px 6px;border-radius:10px;flex-shrink:0}.cat-item.active .cat-badge{background:var(--teal-dim);color:var(--teal)}.cat-item.vert-cat.active .cat-badge{background:var(--pink-dim);color:#fda4af}.vert-tag{font-size:8px;font-weight:800;background:var(--pink);color:#fff;padding:1px 4px;border-radius:3px;flex-shrink:0}.layouts-section{flex:1;overflow:hidden;display:flex;flex-direction:column}.layouts-scroll{flex:1;overflow-y:auto;padding:4px 10px 12px;display:flex;flex-direction:column;gap:4px}.layout-card{display:flex;align-items:center;gap:10px;padding:10px 11px;border-radius:var(--r);border:1px solid var(--bdr);background:var(--bg-card);cursor:pointer;transition:all .12s}.layout-card:hover{border-color:var(--bdr-hi);background:var(--bg-hover)}.layout-card.active{border-color:var(--teal-bdr);background:var(--bg-active);box-shadow:0 0 0 1px var(--teal-dim)}.layout-card.vert-card.active{border-color:#f43f5e80;background:var(--pink-dim)}.lthumb-land{width:52px;height:29px;border-radius:3px;background:var(--bg-input);border:1px solid var(--bdr);overflow:hidden;flex-shrink:0}.lthumb-vert{width:17px;height:29px;border-radius:3px;background:var(--bg-input);border:1px solid var(--bdr);overflow:hidden;flex-shrink:0}.layout-card.active .lthumb-land,.layout-card.active .lthumb-vert{border-color:var(--teal-bdr)}.layout-card.vert-card.active .lthumb-land,.layout-card.vert-card.active .lthumb-vert{border-color:#f43f5e80}.lname{font-size:12px;font-weight:600;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.layout-card.active .lname{color:var(--teal-light)}.layout-card.vert-card.active .lname{color:#fda4af}.lsub{font-size:10px;color:var(--t3);margin-top:1px}.no-results{font-size:11px;color:var(--t3);padding:8px 4px;font-style:italic}.mid-col{display:flex;flex-direction:column;overflow:hidden;background:transparent;border-right:1px solid var(--bdr)}.mid-header{padding:16px 18px 13px;border-bottom:1px solid var(--bdr);flex-shrink:0;display:flex;align-items:center;gap:8px}.mid-title{font-size:16px;font-weight:700;color:var(--t1)}.mid-body{flex:1;overflow-y:auto;padding:16px 18px}.field-group{margin-bottom:14px}.field-label{font-size:10px;font-weight:700;color:var(--t2);letter-spacing:.07em;text-transform:uppercase;margin-bottom:5px;display:block}.field-input{width:100%;background:var(--bg-input);border:1px solid var(--bdr-hi);color:var(--t1);padding:8px 11px;border-radius:var(--r-sm);font-size:13px;outline:none;transition:border-color .15s,box-shadow .15s}.field-input:focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-dim)}.field-select{width:100%;background:var(--bg-input);border:1px solid var(--bdr-hi);color:var(--t1);padding:8px 11px;border-radius:var(--r-sm);font-size:13px;outline:none;cursor:pointer}.field-select:focus{border-color:var(--teal)}.src-list-lbl{font-size:10px;font-weight:700;color:var(--t2);letter-spacing:.07em;text-transform:uppercase;margin-bottom:8px;display:block}.no-scene{text-align:center;padding:32px 0;font-size:12px;color:var(--t3);font-style:italic}.src-cards{display:flex;flex-direction:column;gap:6px}.src-card{border-radius:var(--r-sm);border:1px solid var(--bdr-hi);overflow:hidden;background:var(--bg-card);transition:border-color .12s}.src-card.open{border-color:var(--teal);box-shadow:0 0 0 1px var(--teal-dim)}.src-card-head{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background .12s}.src-card-head:hover{background:var(--bg-hover)}.src-card.open .src-card-head{background:var(--bg-active)}.src-icon{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.si-cam{background:#22c55e33;color:#22c55e}.si-screen{background:#3b82f633;color:#60a5fa}.si-browser{background:#8b5cf633;color:#a78bfa}.si-image{background:#ec489933;color:#f472b6}.si-media{background:#f59e0b33;color:#fbbf24}.si-text{background:#fbbf2433;color:#fde68a}.si-color{background:#64748b33;color:#94a3b8}.src-card-name{flex:1;font-size:13px;font-weight:500;color:var(--t1)}.src-vis-btn{width:26px;height:26px;border-radius:50%;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--green);opacity:.7;transition:opacity .12s;flex-shrink:0}.src-vis-btn:hover{opacity:1}.src-card-body{padding:12px;border-top:1px solid var(--bdr);background:var(--bg-input)}.edit-row{margin-bottom:9px}.edit-label{font-size:9px;font-weight:700;color:var(--t3);letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px;display:block}.edit-input{width:100%;background:var(--bg-card);border:1px solid var(--bdr-hi);color:var(--t1);padding:6px 8px;border-radius:var(--r-xs);font-size:12px;outline:none;transition:border-color .15s}.edit-input:focus{border-color:var(--teal)}.coord-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.action-row{display:flex;gap:8px;margin-top:14px}.coll-group{margin-top:12px}.queue-bar{border-top:1px solid var(--bdr);padding:9px 18px;flex-shrink:0;background:var(--bg-card);min-height:45px}.queue-row{display:flex;align-items:center;gap:5px;flex-wrap:wrap}.queue-lbl{font-size:10px;font-weight:700;color:var(--teal);letter-spacing:.07em;text-transform:uppercase;flex-shrink:0;display:flex;align-items:center;gap:4px}.q-chip{display:flex;align-items:center;gap:4px;padding:2px 7px 2px 9px;background:var(--bg-input);border:1px solid var(--bdr-hi);border-radius:20px;font-size:11px;color:var(--t2)}.q-chip.v-chip{border-color:#f43f5e66;background:var(--pink-dim)}.q-x{background:none;border:none;cursor:pointer;color:var(--t3);font-size:14px;line-height:1;padding:0;transition:color .12s}.q-x:hover{color:var(--pink)}.queue-empty-txt{font-size:11px;color:var(--t3);font-style:italic}.right-col{display:flex;flex-direction:column;overflow:hidden;background:transparent}.right-scroll{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:14px}.panel-card{background:var(--bg-panel);border:1px solid var(--bdr-hi);border-radius:var(--r);overflow:hidden;box-shadow:0 2px 8px #0000004d}.panel-head{padding:12px 14px;border-bottom:1px solid var(--bdr);display:flex;align-items:center;justify-content:space-between;background:var(--bg-card)}.panel-head-title{font-size:14px;font-weight:700;color:var(--t1);display:flex;align-items:center;gap:8px}.panel-head-title .ph-icon{color:var(--teal);display:flex}.panel-head-right{display:flex;align-items:center;gap:6px}.res-badge{font-family:var(--mono);font-size:10px;background:var(--bg-input);border:1px solid var(--bdr-hi);color:var(--t2);padding:3px 8px;border-radius:4px}.vert-res-badge{background:var(--pink-dim);border-color:#f43f5e59;color:#fda4af}.canvas-stage{background:var(--bg-input);display:flex;align-items:center;justify-content:center;padding:18px;position:relative;min-height:210px}.canvas-stage:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 0%,rgba(20,184,166,.07),transparent 65%);pointer-events:none}.canvas-frame{position:relative;z-index:1;flex-shrink:0;border-radius:6px;padding:2px;background:linear-gradient(135deg,#14b8a680,#2dd4bf33,#14b8a614);box-shadow:0 4px 24px #00000080,0 0 0 1px #14b8a626,0 0 30px #14b8a614}.canvas-frame.v-frame{background:linear-gradient(180deg,#f43f5e80,#fb718533,#f43f5e14);box-shadow:0 4px 24px #00000080,0 0 0 1px #f43f5e26,0 0 30px #f43f5e14}.obs-canvas{background:#06080f;border-radius:4px;position:relative;overflow:hidden;display:block}.res-overlay{position:absolute;top:6px;right:6px;font-family:var(--mono);font-size:9px;background:#14b8a640;color:var(--teal-light);padding:2px 6px;border-radius:3px;z-index:5;border:1px solid rgba(20,184,166,.3)}.src-blk{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden}.sb-cam{background:#22c55e14;border:1px solid rgba(34,197,94,.4)}.sb-screen{background:#3b82f612;border:1px solid rgba(59,130,246,.38)}.sb-browser{background:#8b5cf614;border:1px solid rgba(139,92,246,.4)}.sb-image{background:#ec48990f;border:1px solid rgba(236,72,153,.32)}.sb-color{background:#64748b14;border:1px dashed rgba(100,116,139,.4)}.sb-media{background:#f59e0b12;border:1px solid rgba(245,158,11,.38)}.sb-text{background:#fbbf2412;border:1px solid rgba(251,191,36,.45)}.sb-other{background:#4755690f;border:1px dashed rgba(71,85,105,.35)}.sb-lbl{font-family:var(--mono);font-size:7px;font-weight:500;color:#ffffffa6;text-align:center;padding:1px 3px;pointer-events:none;line-height:1.3}.sb-pct{font-family:var(--mono);font-size:6px;color:#ffffff52;margin-top:1px;pointer-events:none}.canvas-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:32px;color:var(--t3)}.preview-info{font-size:11px;color:var(--t2);padding:8px 14px 12px}.preview-info strong{color:var(--t1);font-weight:600}.json-pre{padding:12px 14px;font-family:var(--mono);font-size:10px;line-height:1.7;color:#7dd3fc;overflow-y:auto;max-height:200px;white-space:pre;background:var(--bg-input)}.json-empty{padding:14px;font-family:var(--mono);font-size:11px;color:var(--t3);font-style:italic;background:var(--bg-input)}.json-actions{display:flex;gap:6px}.panel-body{padding:12px 14px}.import-steps{display:flex;flex-direction:column;gap:6px}.import-step,.imp-step{display:flex;gap:8px;align-items:flex-start}.imp-n{width:17px;height:17px;border-radius:50%;background:var(--teal-dim);border:1px solid var(--teal-bdr);color:var(--teal);font-size:8px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.imp-t{font-size:11px;color:var(--t2);line-height:1.5}.btn{display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:8px 14px;border-radius:var(--r-sm);border:1px solid transparent;font-size:12px;font-weight:600;cursor:pointer;transition:all .14s;white-space:nowrap}.btn:disabled{opacity:.35;cursor:not-allowed}.btn-teal{background:var(--teal);color:#031a18;border-color:var(--teal)}.btn-teal:hover:not(:disabled){background:#2dd4bf;box-shadow:0 0 0 3px var(--teal-dim)}.btn-ghost{background:var(--bg-input);color:var(--t2);border-color:var(--bdr-hi)}.btn-ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--t1);border-color:var(--bdr-bright)}.btn-sm{padding:5px 10px;font-size:11px}.btn-full{width:100%}.toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%) translateY(60px);background:var(--bg-card);border:1px solid var(--teal-bdr);color:var(--t1);font-size:12px;font-weight:500;padding:9px 18px;border-radius:50px;box-shadow:0 8px 30px #00000080;transition:transform .28s cubic-bezier(.34,1.56,.64,1),opacity .2s;z-index:9999;pointer-events:none;white-space:nowrap;opacity:0}.toast.show{transform:translate(-50%) translateY(0);opacity:1}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 50% 0%,rgba(20,184,166,.08),transparent 60%)}.login-card{background:var(--bg-card);border:1px solid var(--bdr-hi);border-radius:16px;padding:40px 36px;width:360px;box-shadow:0 24px 64px #00000080}.login-logo{display:flex;align-items:center;gap:10px;margin-bottom:28px}.login-logo-icon{width:36px;height:36px;border-radius:8px;background:linear-gradient(135deg,var(--teal),var(--blue));display:flex;align-items:center;justify-content:center;box-shadow:0 0 20px #14b8a64d}.login-title{font-size:20px;font-weight:800;color:var(--t1)}.login-sub{font-size:12px;color:var(--t2);margin-bottom:24px}.login-label{font-size:10px;font-weight:700;color:var(--t3);letter-spacing:.08em;text-transform:uppercase;margin-bottom:5px;display:block}.login-input{width:100%;background:var(--bg-input);border:1px solid var(--bdr-hi);color:var(--t1);padding:10px 12px;border-radius:var(--r-sm);font-size:14px;outline:none;margin-bottom:16px;transition:border-color .15s,box-shadow .15s}.login-input:focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-dim)}.login-btn{width:100%;background:var(--teal);color:#031a18;border:none;padding:11px;border-radius:var(--r-sm);font-size:13px;font-weight:700;cursor:pointer;transition:all .15s}.login-btn:hover{background:#2dd4bf;box-shadow:0 0 0 3px var(--teal-dim)}.admin-app{min-height:100vh}.admin-header{height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:var(--bg-card);border-bottom:1px solid var(--bdr);position:sticky;top:0;z-index:100}.admin-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--teal) 40%,transparent 80%);opacity:.4}.header-logo{display:flex;align-items:center;gap:10px}.header-logo-icon{width:30px;height:30px;border-radius:6px;background:linear-gradient(135deg,var(--teal),var(--blue));display:flex;align-items:center;justify-content:center}.header-title{font-size:16px;font-weight:800;color:var(--t1)}.header-badge{font-size:10px;font-weight:600;background:var(--amber-dim, rgba(245, 158, 11, .13));color:var(--amber, #f59e0b);border:1px solid rgba(245,158,11,.3);padding:2px 8px;border-radius:20px}.header-actions{display:flex;align-items:center;gap:8px}.stats-bar{padding:12px 24px;background:var(--bg-card);border-bottom:1px solid var(--bdr);display:flex;align-items:center;gap:20px}.stat{display:flex;align-items:center;gap:8px}.stat-val{font-family:var(--mono);font-size:20px;font-weight:700;color:var(--t1)}.stat-lbl{font-size:11px;color:var(--t3)}.stat-div{width:1px;height:32px;background:var(--bdr)}.admin-main{padding:24px;max-width:1400px;margin:0 auto}.pack-section{margin-bottom:28px}.pack-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--bdr)}.pack-title-row{display:flex;align-items:center;gap:10px}.pack-name{font-size:15px;font-weight:700;color:var(--t1)}.pack-count{font-family:var(--mono);font-size:11px;color:var(--t3);background:var(--bg-input);padding:2px 7px;border-radius:10px}.pack-tag{font-size:9px;font-weight:700;padding:2px 7px;border-radius:4px;letter-spacing:.06em;text-transform:uppercase}.tag-live{background:var(--green-dim, rgba(34, 197, 94, .13));color:var(--green, #22c55e);border:1px solid rgba(34,197,94,.3)}.tag-month1{background:var(--pink-dim);color:var(--pink);border:1px solid rgba(244,63,94,.3)}.tag-month2{background:#8b5cf621;color:var(--purple);border:1px solid rgba(139,92,246,.3)}.tag-month3{background:#3b82f621;color:var(--blue);border:1px solid rgba(59,130,246,.3)}.tag-month4{background:#f59e0b21;color:var(--amber);border:1px solid rgba(245,158,11,.3)}.tag-month5{background:var(--teal-dim);color:var(--teal);border:1px solid var(--teal-bdr)}.tag-month6{background:#ec489921;color:#f472b6;border:1px solid rgba(236,72,153,.3)}.tpl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:8px}.tpl-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r-sm);background:var(--bg-card);border:1px solid var(--bdr);transition:border-color .12s,background .12s}.tpl-row.enabled{border-color:var(--bdr-hi)}.tpl-row.disabled{opacity:.45}.tpl-row:hover{background:var(--bg-hover)}.mini-thumb{width:40px;height:23px;border-radius:3px;background:var(--bg-input);border:1px solid var(--bdr);overflow:hidden;flex-shrink:0}.tpl-info{flex:1;min-width:0}.tpl-name{font-size:11px;font-weight:600;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tpl-meta{font-size:9px;color:var(--t3);margin-top:1px;display:flex;align-items:center;gap:5px}.vert-pill{font-size:8px;font-weight:700;background:var(--pink-dim);color:var(--pink);padding:1px 4px;border-radius:3px}.toggle-wrap{flex-shrink:0}.toggle{width:36px;height:20px;background:var(--bg-input);border-radius:10px;border:1px solid var(--bdr-hi);position:relative;cursor:pointer;transition:background .2s,border-color .2s;flex-shrink:0}.toggle.on{background:var(--teal);border-color:var(--teal)}.toggle:after{content:"";position:absolute;left:2px;top:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:transform .2s cubic-bezier(.34,1.56,.64,1);box-shadow:0 1px 3px #0000004d}.toggle.on:after{transform:translate(16px)}.btn-red{background:#ef444421;color:var(--red, #ef4444);border-color:#ef44444d}.btn-red:hover{background:#ef444438}.btn-green{background:var(--green-dim, rgba(34, 197, 94, .13));color:var(--green, #22c55e);border-color:#22c55e4d}.btn-green:hover{background:#22c55e38}.logout-btn{font-size:11px;color:var(--t3);background:none;border:1px solid var(--bdr);padding:5px 10px;border-radius:var(--r-sm);cursor:pointer;transition:all .15s}.logout-btn:hover{color:var(--red, #ef4444);border-color:#ef44444d}
