.admin-layout{background:radial-gradient(circle at 0 0,#2563eb29,#0000 28%),radial-gradient(circle at 100% 0,#22d3ee1f,#0000 24%),#020817;grid-template-columns:260px 1fr;min-height:100vh;display:grid}.admin-sidebar{border-right:1px solid var(--line);background:radial-gradient(circle at top,#22d3ee14,#0000 35%),#0b1120;height:100vh;padding:20px;position:sticky;top:0}.admin-sidebar-top{flex-direction:column;height:100%;display:flex}.admin-logo{color:#fff;border:1px solid var(--line-soft);background:#ffffff0a;border-radius:18px;align-items:center;gap:12px;height:58px;margin-bottom:24px;padding:0 18px;font-weight:800;display:flex}.admin-logo svg{color:var(--accent)}.admin-nav{gap:10px;display:grid}.admin-nav a{height:50px;color:var(--text-muted);border-radius:16px;align-items:center;gap:12px;padding:0 16px;text-decoration:none;transition:all .2s;display:flex}.admin-nav a:hover{color:#fff;background:#ffffff0a}.admin-nav a.active{color:#fff;background:#22d3ee1a;border:1px solid #22d3ee2e}.admin-content{min-width:0;padding:28px;overflow-x:hidden}@media (width<=980px){.admin-layout{grid-template-columns:1fr}.admin-sidebar{height:auto;position:relative}}.devices-card-list{scrollbar-width:thin;scrollbar-color:#ffffff24 transparent}.devices-card-list::-webkit-scrollbar{width:8px}.devices-card-list::-webkit-scrollbar-track{background:0 0}.devices-card-list::-webkit-scrollbar-thumb{background:#ffffff24;border-radius:999px}.devices-card-list::-webkit-scrollbar-thumb:hover{background:#22d3ee47}.devices-card-list{flex:1;grid-template-columns:repeat(auto-fill,minmax(280px,280px));grid-auto-rows:230px;align-content:start;gap:16px;min-height:0;padding-top:6px;padding-right:8px;display:grid;overflow-y:auto}.device-card{cursor:pointer;border:1px solid var(--line-soft);background:radial-gradient(circle at 100% 0,#22d3ee14,#0000 35%),#ffffff06;border-radius:20px;flex-direction:column;justify-content:space-between;width:280px;height:230px;padding:18px;transition:all .2s;display:flex;overflow:hidden}.device-card:hover{background:radial-gradient(circle at 100% 0,#22d3ee1f,#0000 35%),#ffffff0a;border-color:#22d3ee38;transform:translateY(-2px)}.device-tile-header,.device-tile-left{gap:12px;display:flex}.device-tile-header{justify-content:space-between;align-items:flex-start}.device-tile-left{align-items:center;min-width:0}.device-tile-left h3{text-overflow:ellipsis;white-space:nowrap;max-width:120px;margin:0;font-size:1rem;overflow:hidden}.device-tile-left p{color:var(--text-muted);margin:4px 0 0;font-size:.85rem}.device-tile-data{grid-template-columns:1fr 1fr;gap:10px;display:grid}.device-tile-data div{border-top:1px solid var(--line-soft);padding-top:10px}.device-tile-data .full{grid-column:span 2}.device-tile-data span{color:var(--text-muted);margin-bottom:4px;font-size:.75rem;display:block}.device-tile-data strong{color:var(--text-soft);text-overflow:ellipsis;white-space:nowrap;font-size:.9rem;display:block;overflow:hidden}.device-mini-screen-wrap{place-items:center;height:42px;display:grid}.device-mini-screen{background:radial-gradient(circle at 100% 0,#22d3ee42,#0000 40%),#2563eb2e;border:1px solid #22d3ee66;border-radius:8px;width:56px;height:32px;transition:transform .25s}.devices-card-list{grid-template-columns:repeat(auto-fill,minmax(310px,1fr));grid-auto-rows:auto;gap:16px}.device-card{width:100%;min-height:190px}.content-card-list{scrollbar-width:thin;scrollbar-color:#ffffff24 transparent}.content-card-list::-webkit-scrollbar{width:8px}.content-card-list::-webkit-scrollbar-track{background:0 0}.content-card-list::-webkit-scrollbar-thumb{background:#ffffff24;border-radius:999px}.content-card-list::-webkit-scrollbar-thumb:hover{background:#22d3ee47}.content-card-list{flex:1;grid-template-columns:repeat(auto-fill,minmax(280px,280px));grid-auto-rows:260px;align-content:start;gap:16px;min-height:0;padding-top:6px;padding-right:8px;display:grid;overflow-y:auto}.content-card{border:1px solid var(--line);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0b112099;border-radius:20px;min-width:0;transition:all .25s;position:relative;overflow:hidden}.content-card:hover{transform:translateY(-4px);box-shadow:0 20px 60px #00000059}.content-preview{height:160px;color:var(--accent);background:#ffffff08;place-items:center;display:grid;position:relative;overflow:hidden}.content-preview img,.content-preview video{object-fit:cover;width:100%;height:100%}.content-preview svg{width:30px;height:30px}.content-preview-icon{color:var(--accent);font-size:22px}.content-preview.web{color:var(--accent)}.content-preview.video{color:#6366f1}.content-preview.image{color:var(--success)}.content-overlay{opacity:0;background:#0000008c;justify-content:center;align-items:center;gap:10px;transition:all .2s;display:flex;position:absolute;inset:0}.content-card:hover .content-overlay{opacity:1}.overlay-btn,.content-link{border-radius:12px;justify-content:center;align-items:center;font-weight:650;display:inline-flex}.overlay-btn{color:#fff;cursor:pointer;background:#22d3ee26;border:1px solid #22d3ee4d;padding:8px 14px}.overlay-btn:hover{background:#22d3ee40}.overlay-btn.danger,.content-delete{color:#f87171;background:#ef444426;border:1px solid #ef444433}.overlay-btn.danger:hover,.content-delete:hover{background:#ef444440}.content-card-body{gap:10px;min-width:0;padding:14px;display:grid}.content-title{justify-content:space-between;align-items:center;gap:10px;min-width:0;display:flex}.content-title h3,.content-card h3{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;max-width:100%;margin:0;font-size:.95rem;overflow:hidden}.content-title span,.content-card p{color:var(--text-muted);font-size:.75rem}.content-card p{margin:5px 0 0}.content-meta{justify-content:space-between;gap:12px;min-width:0;display:flex}.content-meta div{min-width:0}.content-meta span{color:var(--text-muted);margin-bottom:4px;font-size:.7rem;display:block}.content-meta strong{text-overflow:ellipsis;white-space:nowrap;max-width:120px;color:var(--text-soft);font-size:.8rem;display:block;overflow:hidden}.content-link{color:#fff;background:#2563eb29;border:1px solid #2563eb3d;height:38px;font-size:.85rem}.content-link:hover{background:#2563eb3d}.content-delete{cursor:pointer;border-radius:10px;padding:6px 10px;font-size:.75rem;position:absolute;top:10px;right:10px}.content-card-list{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-auto-rows:auto;gap:16px}.content-card{width:100%;min-height:260px}.upload-tabs{border:1px solid var(--line-soft);background:#ffffff09;border-radius:16px;grid-template-columns:1fr 1fr;gap:6px;margin:18px 20px 0;padding:5px;display:grid}.upload-tab{height:42px;color:var(--text-muted);cursor:pointer;background:0 0;border:0;border-radius:12px;font-weight:700}.upload-tab.active{color:#fff;background:#22d3ee1f;border:1px solid #22d3ee38}.link-upload-form{gap:14px;padding:20px;display:grid}.link-upload-form label{gap:8px;display:grid}.link-upload-form label span{color:var(--text-muted);font-size:.85rem}.link-upload-form input{border:1px solid var(--line);color:#fff;background:#ffffff09;border-radius:16px;outline:none;height:52px;padding:0 16px}.link-upload-form input:focus{border-color:#22d3ee5c;box-shadow:0 0 0 4px #22d3ee14}.link-upload-preview{background:#22d3ee0f;border:1px solid #22d3ee2e;border-radius:18px;align-items:center;gap:12px;padding:14px;display:flex}.link-upload-preview svg{color:var(--accent);flex-shrink:0}.link-upload-preview strong{display:block}.link-upload-preview p{color:var(--text-muted);margin:4px 0 0;font-size:.85rem}.group-content-preview img,.group-picker-preview img{object-fit:cover;width:100%;height:100%}.group-content-card .group-card-info,.group-picker-content-card .group-card-info{padding:0 14px}.group-content-card .icon-btn,.group-picker-content-card b{margin-right:12px}.mini-empty{color:var(--text-muted);border:1px dashed var(--line);background:#ffffff06;border-radius:16px;padding:18px}.group-actions-row{box-shadow:none;background:0 0;border:0;justify-content:flex-end;margin-top:18px;padding:0}.group-small-btn{height:48px;box-shadow:none;border-radius:16px;flex-shrink:0;align-items:center;gap:10px;padding:0 20px;font-weight:700;display:inline-flex}.group-create-form input:focus{border-color:#22d3ee5c;box-shadow:0 0 0 4px #22d3ee14}.groups-empty{text-align:center;color:var(--text-muted);flex:1;align-content:center;place-items:center;display:grid}.groups-empty svg{color:var(--accent)}.groups-empty h2{color:#fff;margin:14px 0 0}.groups-empty p{margin:8px 0 0}.groups-list::-webkit-scrollbar{width:8px}.group-board::-webkit-scrollbar{width:8px}.group-picker-grid::-webkit-scrollbar{width:8px}.group-grid::-webkit-scrollbar{width:8px}.group-content-grid::-webkit-scrollbar{width:8px}.groups-list::-webkit-scrollbar-track{background:0 0}.group-board::-webkit-scrollbar-track{background:0 0}.group-picker-grid::-webkit-scrollbar-track{background:0 0}.group-grid::-webkit-scrollbar-track{background:0 0}.group-content-grid::-webkit-scrollbar-track{background:0 0}.groups-list::-webkit-scrollbar-thumb{background:#94a3b847;border-radius:999px}.group-board::-webkit-scrollbar-thumb{background:#94a3b847;border-radius:999px}.group-picker-grid::-webkit-scrollbar-thumb{background:#94a3b847;border-radius:999px}.group-grid::-webkit-scrollbar-thumb{background:#94a3b847;border-radius:999px}.group-content-grid::-webkit-scrollbar-thumb{background:#94a3b847;border-radius:999px}.groups-list::-webkit-scrollbar-thumb:hover{background:#94a3b86b}.group-board::-webkit-scrollbar-thumb:hover{background:#94a3b86b}.group-picker-grid::-webkit-scrollbar-thumb:hover{background:#94a3b86b}.group-grid::-webkit-scrollbar-thumb:hover{background:#94a3b86b}.group-content-grid::-webkit-scrollbar-thumb:hover{background:#94a3b86b}@media (width<=1100px){.groups-layout{grid-template-columns:1fr}.groups-sidebar-panel{max-height:260px}}@media (width<=820px){.group-detail-header,.group-header-actions{flex-direction:column;align-items:flex-start;width:100%}.group-actions-row{flex-direction:column;justify-content:stretch}.group-small-btn{justify-content:center;width:100%}.group-content-card,.group-picker-content-card{grid-template-columns:88px 1fr auto;min-height:88px}.group-content-preview,.group-picker-preview{width:88px;height:88px}}.group-slide-time-card{background:#22d3ee0e;border:1px solid #22d3ee2e;border-radius:16px;align-items:center;gap:12px;min-height:50px;padding:8px 10px;display:flex}.group-slide-time-card span{color:var(--text-muted);margin-bottom:2px;font-size:.74rem;display:block}.group-slide-time-card strong{color:#fff;font-size:.95rem}.group-slide-time-control{align-items:center;gap:6px;height:36px;display:flex}.group-slide-time-control input{border:1px solid var(--line-soft);color:#fff;background:#ffffff0a;border-radius:12px;outline:none;width:72px;height:36px;padding:0 10px}.group-slide-time-control input:focus{border-color:#22d3ee57}.group-slide-time-control button{height:36px;color:var(--accent);cursor:pointer;background:#22d3ee14;border:1px solid #22d3ee2e;border-radius:12px;padding:0 12px;font-weight:800}.group-slide-time-control button:disabled{opacity:.55;cursor:not-allowed}.group-animation-button{color:#fff;cursor:pointer;background:#22d3ee0e;border:1px solid #22d3ee2e;border-radius:16px;align-items:center;gap:10px;min-height:50px;padding:8px 12px;display:flex}.group-animation-button svg{color:var(--accent)}.group-animation-button span{color:var(--text-muted);text-align:left;margin-bottom:2px;font-size:.74rem;display:block}.group-animation-button strong{color:#fff;text-align:left;font-size:.9rem;display:block}.animation-modal{border:1px solid var(--line);background:radial-gradient(circle at 100% 0,#22d3ee1f,#0000 28%),#0b1120fa;border-radius:28px;width:min(980px,100%);max-height:88vh;overflow:hidden;box-shadow:0 30px 100px #0000008c}.animation-modal-body{grid-template-columns:360px 1fr;gap:22px;padding:22px;display:grid}.animation-options{gap:10px;display:grid}.animation-option{border:1px solid var(--line-soft);color:#fff;cursor:pointer;text-align:left;background:#ffffff08;border-radius:18px;grid-template-columns:44px 1fr;align-items:center;gap:12px;width:100%;min-height:76px;padding:14px;display:grid}.animation-option:hover,.animation-option.active{background:#22d3ee14;border-color:#22d3ee52}.animation-option-icon{width:44px;height:44px;color:var(--accent);background:#22d3ee14;border:1px solid #22d3ee2e;border-radius:14px;place-items:center;display:grid}.animation-option strong{margin-bottom:5px;display:block}.animation-option span{color:var(--text-muted);font-size:.82rem;line-height:1.4}.animation-preview-panel{border:1px solid var(--line-soft);background:#ffffff06;border-radius:24px;flex-direction:column;min-width:0;padding:18px;display:flex}.animation-preview-title{color:var(--accent);align-items:center;gap:8px;margin-bottom:18px;font-weight:800;display:flex}.tv-preview-frame{flex:1;place-items:center;min-height:360px;display:grid}.tv-screen{aspect-ratio:16/9;background:linear-gradient(#ffffff09 1px,#0000 1px) 0 0/28px 28px,linear-gradient(90deg,#ffffff09 1px,#0000 1px) 0 0/28px 28px,radial-gradient(circle at 100% 0,#2563eb33,#0000 40%),#020817;border:2px solid #22d3ee47;border-radius:24px;width:min(460px,100%);padding:18px;overflow:hidden;box-shadow:0 0 60px #22d3ee1a}.tv-slide-preview{background:radial-gradient(circle at 100% 0,#22d3ee3d,#0000 36%),linear-gradient(135deg,#2563eb61,#0f172af5);border-radius:18px;place-items:center;width:100%;height:100%;animation-duration:1.45s;animation-timing-function:cubic-bezier(.22,.61,.36,1);animation-iteration-count:infinite;display:grid}.tv-content-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff14;border:1px solid #ffffff24;border-radius:18px;width:72%;padding:18px}.tv-content-card span{color:var(--accent);background:#22d3ee1f;border-radius:999px;padding:5px 9px;font-size:.75rem;font-weight:800;display:inline-flex}.tv-content-card strong{margin-top:14px;font-size:1.35rem;display:block}.tv-content-card p{color:var(--text-soft);margin:8px 0 0}.tv-slide-preview.slide-up{animation-name:tvSlideUp}.tv-slide-preview.slide-down{animation-name:tvSlideDown}.tv-slide-preview.slide-right{animation-name:tvSlideRight}.tv-slide-preview.slide-left{animation-name:tvSlideLeft}.tv-slide-preview.extinction{animation-name:tvExtinction}.animation-save-btn{width:100%;margin-top:18px}@keyframes tvSlideUp{0%{opacity:0;transform:translateY(105%)}20%,75%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-105%)}}@keyframes tvSlideDown{0%{opacity:0;transform:translateY(-105%)}20%,75%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(105%)}}@keyframes tvSlideRight{0%{opacity:0;transform:translate(-105%)}20%,75%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(105%)}}@keyframes tvSlideLeft{0%{opacity:0;transform:translate(105%)}20%,75%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-105%)}}@keyframes tvExtinction{0%{opacity:0;filter:blur(10px);transform:scale(.96)}20%,75%{opacity:1;filter:blur();transform:scale(1)}to{opacity:0;filter:blur(12px);transform:scale(1.03)}}@media (width<=900px){.animation-modal-body{grid-template-columns:1fr}.tv-preview-frame{min-height:260px}}.music-card{border:1px solid var(--line);background:radial-gradient(circle at 100% 0,#22d3ee14,#0000 40%),#0b1120;border-radius:20px;flex-direction:column;gap:14px;padding:16px;transition:all .25s;display:flex}.music-card:hover{border-color:#22d3ee66;transform:translateY(-3px)}.music-card-header{justify-content:space-between;align-items:center;display:flex}.music-left{align-items:center;gap:12px;min-width:0;display:flex}.music-icon{color:#22d3ee;background:#22d3ee14;border:1px solid #22d3ee33;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.music-info{min-width:0}.music-info h3{white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:14px;font-weight:600;overflow:hidden}.music-info p{color:var(--text-soft);margin-top:4px;font-size:12px}.music-actions{gap:8px;display:flex}.music-btn{border:1px solid var(--line);cursor:pointer;background:#ffffff08;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.music-btn:hover{background:#22d3ee1a}.music-btn.danger:hover{color:#ef4444;background:#ef444426}.music-meta{color:var(--text-soft);justify-content:space-between;font-size:12px;display:flex}.music-player{flex-direction:column;gap:8px;width:100%;margin-top:auto;display:flex}.music-controls{align-items:center;gap:12px;display:flex}.music-play{color:#22d3ee;background:#22d3ee1a;border:1px solid #22d3ee4d;border-radius:12px;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.music-progress{background:#ffffff14;border-radius:999px;flex:1;height:6px;position:relative;overflow:hidden}.music-progress-bar{border-radius:inherit;background:linear-gradient(90deg,#22d3ee,#3b82f6);width:0%;height:100%;transition:width .2s linear}.music-time{color:var(--text-soft);justify-content:space-between;font-size:11px;display:flex}.music-card-list{flex:1;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));align-content:start;gap:16px;min-height:0;padding-top:6px;padding-right:8px;display:grid;overflow-y:auto}.music-card-item{border:1px solid var(--line-soft);background:radial-gradient(circle at 100% 0,#22d3ee1a,#0000 36%),#ffffff08;border-radius:22px;grid-template-rows:auto auto;grid-template-columns:86px 1fr;gap:14px;min-width:0;padding:16px;transition:all .2s;display:grid}.music-card-item:hover{background:radial-gradient(circle at 100% 0,#22d3ee24,#0000 36%),#ffffff0b;border-color:#22d3ee38;transform:translateY(-2px)}.music-actions{flex-shrink:0;gap:8px;display:flex}.icon-btn{width:36px;height:36px;color:var(--accent);cursor:pointer;background:#22d3ee0f;border:1px solid #22d3ee2e;border-radius:12px;place-items:center;display:grid}.music-meta{color:var(--text-muted);justify-content:space-between;gap:12px;font-size:.78rem;display:flex}.music-card-list::-webkit-scrollbar{width:8px}.music-card-list::-webkit-scrollbar-thumb{background:#ffffff24;border-radius:999px}.groups-layout{flex:1;grid-template-columns:360px 1fr;gap:18px;min-height:0;display:grid;overflow:hidden}.groups-sidebar-panel,.group-workspace{border:1px solid var(--line);background:#ffffff06;border-radius:24px;min-height:0}.groups-sidebar-panel{flex-direction:column;padding:16px;display:flex;overflow:hidden}.groups-search,.group-picker-search{border:1px solid var(--line);height:50px;color:var(--text-muted);background:#ffffff09;border-radius:16px;align-items:center;gap:10px;padding:0 14px;display:flex}.groups-search input,.group-picker-search input,.group-create-form input{color:#fff;background:0 0;border:0;outline:0;width:100%;height:100%}.groups-list{flex:1;align-content:start;gap:10px;min-height:0;padding-top:14px;display:grid;overflow-y:auto}.group-list-card{border:1px solid var(--line-soft);color:#fff;cursor:pointer;text-align:left;background:#ffffff06;border-radius:18px;align-items:center;gap:12px;width:100%;padding:14px;display:flex}.group-list-card:hover,.group-list-card.active{background:#22d3ee14;border-color:#22d3ee57}.group-list-icon,.group-device-icon{width:42px;height:42px;color:var(--accent);background:#22d3ee14;border:1px solid #22d3ee2e;border-radius:14px;flex-shrink:0;place-items:center;display:grid}.group-list-card strong,.group-card-info strong{text-overflow:ellipsis;white-space:nowrap;max-width:100%;display:block;overflow:hidden}.group-list-card span,.group-card-info span{color:var(--text-muted);margin-top:5px;font-size:.8rem;display:block}.group-workspace{flex-direction:column;padding:20px;display:flex;overflow:hidden}.group-detail-header{flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;display:flex}.group-detail-header h2{letter-spacing:-.03em;margin:0;font-size:1.7rem}.group-detail-header p{color:var(--text-muted);margin:6px 0 0}.group-header-actions,.group-badges,.group-actions-row{align-items:center;gap:12px;display:flex}.group-badges span{color:var(--accent);background:#22d3ee14;border:1px solid #22d3ee2e;border-radius:999px;padding:7px 10px;font-size:.8rem;font-weight:700}.group-board{flex:1;grid-template-columns:1fr;align-content:start;gap:18px;min-height:0;padding-right:8px;display:grid;overflow-y:auto}.group-section{border:1px solid var(--line-soft);background:#ffffff06;border-radius:22px;flex-direction:column;min-width:0;min-height:240px;padding:16px;display:flex;overflow:hidden}.group-column-header{flex-shrink:0;margin-bottom:14px}.group-column-header h3{margin:0;font-size:1.1rem}.group-column-header p{color:var(--text-muted);margin:5px 0 0;font-size:.88rem}.group-grid,.group-content-grid{flex:1;align-content:start;gap:12px;min-height:0;padding-right:8px;display:grid;overflow-y:auto}.group-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.group-content-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.group-device-card{border:1px solid var(--line-soft);background:#ffffff08;border-radius:18px;grid-template-columns:44px 1fr auto;align-items:center;gap:12px;min-height:76px;padding:14px;display:grid}.group-content-card{border:1px solid var(--line-soft);background:#ffffff08;border-radius:18px;grid-template-columns:104px 1fr auto;align-items:center;min-height:104px;display:grid;overflow:hidden}.group-device-card:hover,.group-content-card:hover,.group-picker-card:hover,.group-picker-content-card:hover{background:#22d3ee12;border-color:#22d3ee3d}.group-content-preview,.group-picker-preview{width:104px;height:104px;color:var(--accent);background:#22d3ee0f;place-items:center;display:grid;overflow:hidden}.group-card-info{min-width:0}.group-actions-row{justify-content:flex-end;gap:14px;margin-top:18px;display:flex}.group-small-btn{border-radius:16px;align-items:center;gap:10px;height:48px;padding:0 20px;font-weight:700;display:inline-flex}.group-picker-modal,.group-create-modal{border:1px solid var(--line);background:#0b1120fa;border-radius:28px;overflow:hidden;box-shadow:0 30px 100px #0000008c}.group-picker-modal{flex-direction:column;width:min(920px,100%);max-height:88vh;display:flex}.group-picker-body{flex-direction:column;gap:16px;min-height:0;padding:20px;display:flex}.group-picker-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));align-content:start;gap:12px;min-height:0;max-height:56vh;padding-right:8px;display:grid;overflow-y:auto}.group-picker-grid.content-picker{grid-template-columns:repeat(auto-fill,minmax(360px,1fr))}.group-picker-card,.group-picker-content-card{border:1px solid var(--line-soft);color:#fff;cursor:pointer;text-align:left;background:#ffffff08;border-radius:18px;width:100%;min-width:0}.group-picker-card{grid-template-columns:44px 1fr auto;align-items:center;gap:12px;min-height:76px;padding:14px;display:grid}.group-picker-content-card{grid-template-columns:104px 1fr auto;align-items:center;min-height:104px;display:grid;overflow:hidden}.group-picker-card b,.group-picker-content-card b{color:var(--accent);padding-right:12px;font-size:.82rem}.group-create-modal{width:min(520px,100%)}.group-create-form{gap:16px;padding:24px;display:grid}.group-create-form label{gap:8px;display:grid}.group-create-form span{color:var(--text-muted);font-size:.85rem}.group-create-form input{border:1px solid var(--line);background:#ffffff09;border-radius:16px;height:52px;padding:0 16px}.groups-list,.group-board,.group-picker-grid,.group-grid,.group-content-grid{scrollbar-width:thin;scrollbar-color:#94a3b847 transparent}.groups-list::-webkit-scrollbar{width:8px}.group-board::-webkit-scrollbar{width:8px}.group-picker-grid::-webkit-scrollbar{width:8px}.group-grid::-webkit-scrollbar{width:8px}.group-content-grid::-webkit-scrollbar{width:8px}.groups-list::-webkit-scrollbar-thumb{background:#94a3b847;border-radius:999px}.group-board::-webkit-scrollbar-thumb{background:#94a3b847;border-radius:999px}.group-picker-grid::-webkit-scrollbar-thumb{background:#94a3b847;border-radius:999px}.group-grid::-webkit-scrollbar-thumb{background:#94a3b847;border-radius:999px}.group-content-grid::-webkit-scrollbar-thumb{background:#94a3b847;border-radius:999px}.groups-list::-webkit-scrollbar-thumb:hover{background:#94a3b86b}.group-board::-webkit-scrollbar-thumb:hover{background:#94a3b86b}.group-picker-grid::-webkit-scrollbar-thumb:hover{background:#94a3b86b}.group-grid::-webkit-scrollbar-thumb:hover{background:#94a3b86b}.group-content-grid::-webkit-scrollbar-thumb:hover{background:#94a3b86b}@media (width<=1100px){.groups-layout{grid-template-columns:1fr}}@media (width<=820px){.group-detail-header,.group-header-actions{flex-direction:column;align-items:flex-start;width:100%}.group-actions-row{flex-direction:column}.group-small-btn{justify-content:center;width:100%}.group-content-card,.group-picker-content-card{grid-template-columns:88px 1fr auto;min-height:88px}.group-content-preview,.group-picker-preview{width:88px;height:88px}}.music-picker-player{opacity:.94;border-radius:12px;width:100%;height:40px;margin-top:10px;overflow:hidden}.music-picker-player::-webkit-media-controls-panel{background:#ffffff14}.music-picker-player::-webkit-media-controls-current-time-display{color:#fff}.music-picker-player::-webkit-media-controls-time-remaining-display{color:#fff}.music-picker-player::-webkit-media-controls-play-button{filter:invert()}.music-picker-player::-webkit-media-controls-mute-button{filter:invert()}.music-picker-card{border:1px solid var(--line-soft);background:radial-gradient(circle at 100% 0,#22d3ee1a,#0000 36%),#ffffff08;border-radius:22px;grid-template-rows:auto auto;grid-template-columns:86px 1fr;gap:14px;min-width:0;padding:16px;display:grid}.music-art{width:86px;height:86px;color:var(--accent);background:radial-gradient(circle,#22d3ee38,#0000 55%),#22d3ee14;border:1px solid #22d3ee38;border-radius:18px;place-items:center;display:grid}.music-content{flex-direction:column;gap:12px;min-width:0;display:flex}.music-top{justify-content:space-between;align-items:flex-start;gap:12px;min-width:0;display:flex}.music-title{min-width:0}.music-title h3{text-overflow:ellipsis;white-space:nowrap;max-width:230px;margin:0;font-size:.98rem;overflow:hidden}.music-title span{color:var(--text-muted);margin-top:6px;font-size:.78rem;display:block}.music-add-btn{height:36px;color:var(--accent);cursor:pointer;background:#22d3ee14;border:1px solid #22d3ee38;border-radius:12px;padding:0 14px;font-weight:700}.music-player-full{grid-column:1/-1;width:100%}.custom-audio-player{background:#ffffff0b;border:1px solid #ffffff12;border-radius:16px;grid-template-columns:38px 1fr 70px;align-items:center;gap:14px;width:100%;height:48px;padding:0 14px;display:grid}.audio-progress div{border-radius:inherit;background:linear-gradient(90deg, var(--primary), var(--accent));height:100%}.admin-stats-grid,.admin-grid{align-content:start;gap:16px;display:grid}.admin-stats-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));margin-bottom:20px}.admin-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}.admin-stat-card,.admin-card,.admin-user-card,.admin-table-panel{border:1px solid var(--line-soft);background:#ffffff08;border-radius:22px}.admin-stat-card{align-items:center;gap:16px;min-height:130px;padding:18px;display:flex}.admin-stat-icon,.admin-card-icon,.admin-user-icon{width:54px;height:54px;color:var(--accent);background:#22d3ee14;border:1px solid #22d3ee2e;border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.admin-stat-card span{color:var(--text-muted);font-size:.85rem}.admin-stat-card strong{margin-top:6px;font-size:2rem;display:block}.admin-toolbar{justify-content:space-between;align-items:center;gap:14px;margin-bottom:18px;display:flex}.admin-search{border:1px solid var(--line);min-width:320px;height:50px;color:var(--text-muted);background:#ffffff09;border-radius:16px;align-items:center;gap:10px;padding:0 16px;display:flex}.admin-search input{color:#fff;background:0 0;border:0;outline:0;width:100%}.admin-tabs{border:1px solid var(--line-soft);background:#ffffff06;border-radius:16px;gap:6px;padding:5px;display:flex}.admin-tabs button{height:38px;color:var(--text-muted);cursor:pointer;background:0 0;border:0;border-radius:12px;align-items:center;gap:8px;padding:0 14px;transition:all .2s;display:flex}.admin-tabs button.active{color:#fff;background:#22d3ee1a}.admin-card{gap:16px;min-height:190px;padding:18px;display:flex}.admin-card-body{flex:1;min-width:0}.admin-card-body h3,.admin-user-info h3{text-overflow:ellipsis;white-space:nowrap;margin:0;overflow:hidden}.admin-card-body p,.admin-user-info p{color:var(--text-muted);margin-top:6px}.admin-card-meta{flex-wrap:wrap;gap:8px;margin-top:14px;display:flex}.admin-card-meta span{color:var(--text-muted);background:#ffffff0a;border-radius:999px;padding:6px 10px;font-size:.78rem}.app-card-title{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.app-current-badge{color:var(--accent);background:#22d3ee14;border:1px solid #22d3ee2e;border-radius:999px;flex-shrink:0;padding:6px 10px;font-size:.75rem;font-weight:800}.app-card-actions{align-items:center;gap:12px;margin-top:18px;display:flex}.app-card-actions a,.app-card-actions button{cursor:pointer;border:1px solid #0000;border-radius:14px;flex:1;justify-content:center;align-items:center;gap:8px;height:42px;font-size:.92rem;font-weight:800;text-decoration:none;transition:all .2s;display:flex}.app-card-actions a{color:var(--accent);background:#22d3ee0f;border-color:#22d3ee2e}.app-card-actions a:hover{background:#22d3ee1f}.app-card-actions button{color:#f87171;background:#ef444414;border-color:#ef444433}.app-card-actions button:hover{background:#ef444424}.app-card-actions svg{flex-shrink:0;width:16px;height:16px}.app-upload-form{gap:16px;padding:22px;display:grid}.app-upload-form label{gap:8px;display:grid}.app-upload-form label span{color:var(--text-muted);font-size:.85rem}.app-upload-form input,.app-upload-form select{border:1px solid var(--line);color:#fff;background:#ffffff09;border-radius:16px;outline:none;height:52px;padding:0 16px}.app-upload-form input:focus,.app-upload-form select:focus{border-color:#22d3ee5c;box-shadow:0 0 0 4px #22d3ee14}.app-file-picker{text-align:center;cursor:pointer;background:#22d3ee0b;border:1px dashed #22d3ee47;border-radius:20px;flex-direction:column;justify-content:center;align-items:center;gap:8px;min-height:130px;padding:18px;display:flex}.app-file-picker input{display:none}.app-file-picker strong{color:#fff}.app-file-picker small{color:var(--text-muted)}.admin-table-panel{padding:16px}.admin-user-list{gap:12px;display:grid}.admin-user-card{grid-template-columns:54px 1fr auto;align-items:center;gap:14px;padding:14px;display:grid}.admin-user-info{min-width:0}.admin-user-info div{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.admin-user-info span{color:var(--text-muted);font-size:.8rem}.admin-role{border:1px solid var(--line-soft);height:40px;color:var(--text-muted);cursor:pointer;background:#ffffff09;border-radius:13px;align-items:center;gap:8px;padding:0 14px;transition:all .2s;display:flex}.admin-role.active{color:var(--accent);background:#22d3ee14;border-color:#22d3ee38}.admin-table-panel::-webkit-scrollbar{width:8px}.admin-table-panel::-webkit-scrollbar-thumb{background:#94a3b847;border-radius:999px}@media (width<=820px){.admin-toolbar{flex-direction:column;align-items:stretch}.admin-search{width:100%;min-width:0}.admin-user-card{grid-template-columns:54px 1fr}.admin-role{grid-column:1/-1;justify-content:center}.app-card-actions{flex-direction:column}.app-card-actions a,.app-card-actions button{width:100%}}:root{color:#ffffffeb;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg:#0b1120;--bg-deep:#09101d;--panel:#0a1223d1;--line:#ffffff14;--line-soft:#ffffff0d;--text:#fffffff0;--text-soft:#ffffffad;--text-muted:#ffffff7a;--primary:#2563eb;--accent:#22d3ee;--danger:#ef4444;--success:#10b981;--warning:#f59e0b;--shadow:0 24px 80px #00000061;background:#0b1120;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html,body,#root{min-height:100%}body{color:var(--text);background:radial-gradient(circle at 18% 10%, #2563eb29, transparent 24%), radial-gradient(circle at 82% 8%, #22d3ee1f, transparent 20%), linear-gradient(180deg, var(--bg-deep) 0%, var(--bg) 100%);margin:0;overflow:hidden auto}a{color:inherit;text-decoration:none}button,input,select{font:inherit}button{border:0}.button{cursor:pointer;border:1px solid #0000;border-radius:15px;justify-content:center;align-items:center;gap:10px;height:50px;padding:0 18px;font-weight:650;transition:all .2s;display:inline-flex}.button-primary{color:#fff;background:linear-gradient(135deg, var(--primary), #1d4ed8);box-shadow:0 14px 30px #2563eb3d}.button-primary:hover{transform:translateY(-1px);box-shadow:0 16px 36px #2563eb52}.button-ghost,.button-secondary{color:#fff;border-color:var(--line);background:#ffffff09}.button-ghost:hover,.button-secondary:hover{background:#ffffff0f}.button-danger{color:#fff;background:#ef444429;border-color:#ef444447}.button-danger:hover{background:#ef44443d}.button:disabled{opacity:.65;cursor:not-allowed;transform:none}.form-error{color:#fecaca;background:#ef44441f;border:1px solid #ef444438;border-radius:14px;padding:12px 14px;font-size:.9rem}.empty-state{text-align:center;color:var(--text-muted);padding:34px}.status{border-radius:999px;width:fit-content;padding:6px 10px;font-size:.8rem;font-weight:700}.status.online{color:#a7f3d0;background:#10b9811f}.status.offline{color:#fecaca;background:#ef44441f}.status.warning{color:#fde68a;background:#f59e0b1f}.page{min-height:100vh;position:relative;overflow:hidden auto}.page-noise,.page-grid,.page-glow{pointer-events:none;position:absolute}.page-noise{opacity:.06;background-image:radial-gradient(circle at 20% 20%,#fff6 .5px,#0000 .5px),radial-gradient(circle at 80% 80%,#fff3 .5px,#0000 .5px);background-size:26px 26px;inset:0}.page-grid{background-image:linear-gradient(#ffffff0a 1px,#0000 1px),linear-gradient(90deg,#ffffff0a 1px,#0000 1px);background-size:64px 64px;inset:0;-webkit-mask-image:radial-gradient(circle,#000 42%,#0000 100%);mask-image:radial-gradient(circle,#000 42%,#0000 100%)}.page-glow{filter:blur(90px);opacity:.22;border-radius:999px;width:420px;height:420px}.page-glow-left{background:var(--primary);top:40px;left:-60px}.page-glow-right{background:var(--accent);top:80px;right:-100px}.container,.site-header{z-index:2;max-width:1240px;margin:0 auto;padding-left:24px;padding-right:24px;position:relative}.container{padding-bottom:80px}.site-header{justify-content:space-between;align-items:center;padding-top:28px;display:flex}.brand{align-items:center;gap:12px;display:inline-flex}.brand-logo{color:#fff;border:1px solid var(--line);background:linear-gradient(#2563eb38,#22d3ee14),#ffffff08;border-radius:16px;place-items:center;width:48px;height:48px;display:grid;overflow:hidden;box-shadow:inset 0 1px #ffffff0a}.brand-logo-image{object-fit:contain;width:26px;height:26px;display:block}.brand-title{letter-spacing:-.02em;font-size:1.1rem;font-weight:700}.brand-subtitle{color:var(--text-muted);font-size:.875rem}.site-nav{align-items:center;gap:14px;display:flex}.nav-link{color:var(--text-soft);transition:all .2s}.nav-link:hover{color:#fff}.eyebrow{color:#cfe5ff;background:#2563eb1f;border:1px solid #2563eb47;border-radius:999px;align-items:center;gap:8px;min-height:34px;padding:0 14px;font-size:.875rem;font-weight:600;display:inline-flex}.hero{grid-template-columns:1.05fr .95fr;align-items:center;gap:28px;padding-top:64px;display:grid}.hero-copy{max-width:700px}.hero-title{letter-spacing:-.055em;margin:18px 0 0;font-size:clamp(3rem,3vw,5.9rem);font-weight:800;line-height:.96}.hero-text{max-width:620px;color:var(--text-soft);margin:24px 0 0;font-size:1.25rem;line-height:1.8}.hero-actions,.cta-actions{flex-wrap:wrap;gap:14px;display:flex}.hero-actions{margin-top:32px}.hero-points{gap:12px;margin:28px 0 0;padding:0;list-style:none;display:grid}.hero-points li{color:var(--text-soft);align-items:center;gap:10px;display:flex}.hero-points svg,.feature-icon{color:var(--accent)}.hero-visual{justify-content:center;display:flex}.mockup{border:1px solid var(--line);width:100%;max-width:560px;box-shadow:var(--shadow);background:linear-gradient(#0e182cf2,#091120e0);border-radius:28px;overflow:hidden}.mockup-top{border-bottom:1px solid var(--line-soft);align-items:center;gap:8px;padding:16px 18px;display:flex}.dot{background:#ffffff29;border-radius:999px;width:10px;height:10px}.mockup-body{grid-template-columns:132px 1fr;min-height:360px;display:grid}.mockup-sidebar{border-right:1px solid var(--line-soft);background:#ffffff05;padding:16px}.mock-item{color:var(--text-soft);border-radius:12px;margin-bottom:10px;padding:12px 14px}.mock-item.active{color:#fff;background:#2563eb24;border:1px solid #2563eb3d}.mockup-screen{padding:18px}.mock-card{border:1px solid var(--line-soft);background:#ffffff06;border-radius:18px}.mock-card.large{background:radial-gradient(circle at 100% 0,#22d3ee24,#0000 35%),#ffffff06;min-height:146px;margin-bottom:14px;padding:18px}.mock-card.large h3{margin:16px 0 8px;font-size:1.4rem}.mock-card.large p{color:var(--text-soft);margin:0}.mock-badge{color:#c9f7ff;background:#22d3ee1f;border:1px solid #22d3ee38;border-radius:999px;align-items:center;height:28px;padding:0 10px;font-size:.78rem;display:inline-flex}.mock-grid,.features{gap:18px;display:grid}.mock-grid{grid-template-columns:repeat(2,1fr);gap:12px}.mock-card.small{min-height:92px}.features{grid-template-columns:repeat(3,minmax(0,1fr));margin-top:34px}.feature-card,.split-section,.cta-block{border:1px solid var(--line);box-shadow:var(--shadow);background:#ffffff06}.feature-card{border-radius:22px;padding:24px}.feature-icon{background:#22d3ee14;border:1px solid #22d3ee2e;border-radius:14px;place-items:center;width:42px;height:42px;margin-bottom:18px;display:grid}.feature-card h3{letter-spacing:-.02em;margin:0 0 10px;font-size:1.25rem}.feature-card p{color:var(--text-soft);margin:0;line-height:1.75}.split-section{border-radius:28px;grid-template-columns:1fr 420px;align-items:center;gap:28px;margin-top:72px;padding:34px;display:grid}.split-copy h2,.cta-block h2,.auth-copy-block h1,.auth-card h2{letter-spacing:-.04em;margin:14px 0 0;font-size:clamp(2rem,4vw,3.4rem);line-height:1.05}.split-copy p,.cta-block p,.auth-copy-block p,.auth-subtext{color:var(--text-soft);margin:16px 0 0;line-height:1.8}.split-panel{gap:14px;display:grid}.stat-card{border:1px solid var(--line);background:#ffffff06;border-radius:18px;padding:18px 20px}.stat-card span,.broadcast-card span{color:var(--text-muted);margin-bottom:8px;display:block}.stat-card strong{letter-spacing:-.03em;font-size:2rem}.cta-block{background:radial-gradient(circle at 0,#2563eb1f,#0000 30%),#ffffff05;border-radius:28px;justify-content:space-between;align-items:center;gap:24px;margin-top:28px;padding:34px;display:flex}.auth-page{justify-content:center;align-items:center;padding:24px;display:flex}.auth-shell{z-index:2;border:1px solid var(--line);width:100%;max-width:1120px;box-shadow:var(--shadow);background:#0a1223d1;border-radius:30px;grid-template-columns:1fr 460px;display:grid;position:relative;overflow:hidden}.auth-left{border-right:1px solid var(--line-soft);flex-direction:column;justify-content:space-between;min-height:620px;padding:30px;display:flex}.back-link{color:var(--text-soft);align-items:center;gap:8px;width:fit-content;display:inline-flex}.back-link:hover{color:#fff}.auth-copy-block{max-width:520px}.auth-card{flex-direction:column;justify-content:center;padding:36px 30px;display:flex}.auth-form{gap:14px;margin-top:28px;display:grid}.input-wrap{border:1px solid var(--line);height:54px;color:var(--text-muted);background:#ffffff08;border-radius:16px;align-items:center;gap:12px;padding:0 16px;display:flex}.input-wrap input{color:#fff;background:0 0;border:none;outline:none;flex:1;height:100%}.input-wrap input::placeholder{color:#ffffff5c}.input-wrap:focus-within{border-color:#2563eb80;box-shadow:0 0 0 4px #2563eb1f}.auth-button{width:100%;margin-top:4px}.auth-footer{text-align:center;color:var(--text-soft);margin:18px 0 0}.auth-footer a{color:#cfe5ff;font-weight:600}.dashboard-page{background:radial-gradient(circle at 20% 10%, #2563eb24, transparent 24%), radial-gradient(circle at 90% 10%, #22d3ee1a, transparent 20%), var(--bg);grid-template-columns:280px 1fr;height:100vh;display:grid;overflow:hidden}.dashboard-sidebar{border-right:1px solid var(--line);background:#ffffff05;flex-direction:column;height:100vh;padding:22px;display:flex;overflow:hidden}.dashboard-brand{align-items:center;gap:12px;margin-bottom:34px;display:flex}.dashboard-logo{border:1px solid var(--line);background:#ffffff0a;border-radius:15px;place-items:center;width:46px;height:46px;display:grid}.dashboard-logo img{width:28px;height:28px}.dashboard-brand strong{font-size:1rem;display:block}.dashboard-brand span{color:var(--text-muted);font-size:.85rem}.dashboard-menu{gap:8px;display:grid}.dashboard-menu-item,.dashboard-logout{height:46px;color:var(--text-soft);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:14px;align-items:center;gap:12px;padding:0 14px;transition:all .2s;display:flex}.dashboard-menu-item:hover,.dashboard-menu-item.active{color:#fff;background:#2563eb1f;border-color:#2563eb3d}.dashboard-logout{width:100%;margin-top:auto;font-weight:600}.dashboard-logout:hover{color:#fff;background:#ef44441a;border-color:#ef44442e}.dashboard-main{flex-direction:column;height:100vh;padding:28px;display:flex;overflow:hidden}.dashboard-header{flex-shrink:0;justify-content:space-between;align-items:center;gap:24px;margin-bottom:28px;display:flex}.dashboard-kicker{color:var(--accent);margin:0 0 8px;font-size:.9rem;font-weight:700}.dashboard-header h1{letter-spacing:-.04em;margin:0;font-size:2.5rem}.dashboard-user,.user-info,.device-header-actions{align-items:center;gap:16px;display:flex}.user-avatar{color:#fff;background:linear-gradient(135deg, var(--accent), #6366f1);border-radius:12px;justify-content:center;align-items:center;width:38px;height:38px;font-size:.95rem;font-weight:700;display:flex;box-shadow:0 6px 16px #6366f140}.user-meta{flex-direction:column;gap:2px;display:flex}.user-meta strong{color:var(--text-soft);font-size:.9rem}.user-meta span{color:var(--text-muted);font-size:.75rem}.dashboard-stats{flex-shrink:0;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:18px;display:grid}.devices-compact-stats{grid-template-columns:repeat(3,minmax(0,1fr))}.dashboard-stat-card,.dashboard-panel{border:1px solid var(--line);box-shadow:var(--shadow);background:#ffffff06;border-radius:22px}.dashboard-stat-card{padding:22px}.devices-compact-stats .dashboard-stat-card{align-items:center;gap:14px;min-height:96px;padding:16px 18px;display:flex}.stat-icon,.device-icon{width:42px;height:42px;color:var(--accent);background:#22d3ee14;border:1px solid #22d3ee2e;border-radius:14px;place-items:center;display:grid}.stat-icon{margin-bottom:18px}.devices-compact-stats .stat-icon{margin-bottom:0}.dashboard-stat-card span{color:var(--text-muted);margin-bottom:8px;display:block}.devices-compact-stats .dashboard-stat-card span{margin-bottom:4px;font-size:.9rem}.dashboard-stat-card strong{letter-spacing:-.04em;font-size:2rem}.devices-compact-stats .dashboard-stat-card strong{font-size:1.7rem}.dashboard-grid{grid-template-columns:1.3fr .85fr;gap:18px;display:grid}.dashboard-panel{padding:22px}.dashboard-panel.large{grid-row:span 2}.panel-header{color:var(--accent);justify-content:space-between;gap:18px;margin-bottom:22px;display:flex}.panel-header h2{color:#fff;margin:0;font-size:1.25rem}.panel-header p{color:var(--text-muted);margin:6px 0 0}.device-list{gap:12px;display:grid}.device-row{border:1px solid var(--line-soft);background:#ffffff06;border-radius:16px;justify-content:space-between;align-items:center;padding:16px;display:flex}.device-row strong{display:block}.device-row span{color:var(--text-muted);font-size:.9rem}.broadcast-card{border:1px solid var(--line-soft);background:#ffffff06;border-radius:18px;padding:18px}.broadcast-card strong{font-size:1.25rem;display:block}.broadcast-card p{color:var(--text-soft);margin:10px 0 0}.progress{background:#ffffff14;border-radius:999px;height:8px;margin-top:18px;overflow:hidden}.progress div{border-radius:inherit;background:linear-gradient(90deg, var(--primary), var(--accent));width:72%;height:100%}.devices-toolbar{flex-shrink:0;gap:14px;margin-bottom:18px;display:flex}.devices-search{border:1px solid var(--line);height:52px;color:var(--text-muted);background:#ffffff08;border-radius:16px;flex:1;align-items:center;gap:12px;padding:0 16px;display:flex}.devices-search input{color:#fff;background:0 0;border:none;outline:none;width:100%;height:100%}.devices-select{border:1px solid var(--line);background:var(--bg);color:#fff;border-radius:16px;outline:none;min-width:180px;height:52px;padding:0 14px}.devices-panel{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.no-panel{box-shadow:none;background:0 0;border:none;padding:0}.devices-header{flex-shrink:0;margin-bottom:18px}.devices-header h2{margin:0;font-size:1.4rem}.devices-header p{color:var(--text-muted);margin:6px 0 0}.icon-btn{width:34px;height:34px;color:var(--accent);cursor:pointer;background:#22d3ee0f;border:1px solid #22d3ee2e;border-radius:10px;flex-shrink:0;place-items:center;display:grid}.icon-btn:hover{background:#ffffff1a}.icon-btn.danger{color:var(--danger);background:#ef444414;border-color:#ef444433}.custom-audio-player{border:1px solid var(--line-soft);background:#ffffff09;border-radius:14px;grid-template-columns:34px 1fr 60px;align-items:center;gap:12px;height:44px;padding:0 12px;display:grid}.audio-play-btn{width:34px;height:34px;color:var(--accent);cursor:pointer;background:#22d3ee14;border:1px solid #22d3ee38;border-radius:11px;place-items:center;display:grid}.audio-play-btn:hover{background:#22d3ee24}.audio-progress{cursor:pointer;background:#ffffff14;border-radius:999px;height:7px;overflow:hidden}.audio-progress div{border-radius:inherit;background:linear-gradient(90deg, var(--primary), var(--accent));height:100%;transition:width .12s linear}.audio-state{color:var(--text-muted);text-align:right;font-size:.76rem}.modal-backdrop{z-index:50;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#03071261;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.device-modal,.add-device-modal,.upload-modal{border:1px solid var(--line);background:radial-gradient(circle at 100% 0,#22d3ee1f,#0000 28%),#0b1120f5;border-radius:28px;overflow:hidden;box-shadow:0 30px 100px #0000008c}.device-modal{width:min(980px,100%);max-height:88vh}.add-device-modal{width:min(520px,100%)}.upload-modal{width:min(600px,100%)}.device-modal-header{border-bottom:1px solid var(--line-soft);justify-content:space-between;align-items:flex-start;gap:20px;padding:24px;display:flex}.device-modal-header h2{letter-spacing:-.04em;margin:8px 0 4px;font-size:2rem}.device-modal-header span{color:var(--text-muted)}.modal-close,.device-modal-header button{border:1px solid var(--line);color:#fff;cursor:pointer;background:#ffffff09;border-radius:14px;width:42px;height:42px}.device-modal-body{grid-template-columns:1fr 420px;gap:24px;padding:24px;display:grid}.device-modal-info{flex-direction:column;gap:20px;display:flex}.modal-info-grid{grid-template-columns:repeat(2,1fr);gap:14px;display:grid}.modal-info-grid div{border:1px solid var(--line-soft);background:#ffffff06;border-radius:18px;padding:16px}.modal-info-grid span{color:var(--text-muted);margin-bottom:8px;font-size:.8rem;display:block}.modal-info-grid strong{color:var(--text-soft)}.rotation-controls{border:1px solid var(--line-soft);background:#ffffff06;border-radius:20px;padding:18px}.rotation-controls p{color:var(--text-soft);margin:0 0 14px;font-weight:700}.rotation-buttons{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.rotation-btn{border:1px solid var(--line);height:42px;color:var(--text-soft);cursor:pointer;background:#ffffff08;border-radius:14px;font-weight:700}.rotation-btn.active{color:#fff;background:#22d3ee24;border-color:#22d3ee59}.device-screen-preview-wrap{border:1px solid var(--line-soft);background:#ffffff06;border-radius:24px;padding:18px}.screen-label{color:var(--accent);align-items:center;gap:8px;margin-bottom:18px;font-weight:700;display:flex}.screen-stage,.audio-stage{background-color:#ffffff04;background-image:linear-gradient(#ffffff09 1px,#0000 1px),linear-gradient(90deg,#ffffff09 1px,#0000 1px),none;background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:28px 28px;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;border-radius:20px;place-items:center;height:340px;display:grid;overflow:hidden}.screen-preview{background:radial-gradient(circle at 100% 0,#22d3ee38,#0000 35%),#0f172af2;border:2px solid #22d3ee73;border-radius:18px;width:220px;height:135px;transition:transform .28s;overflow:hidden;box-shadow:0 0 40px #22d3ee24}.screen-preview-top{border-bottom:1px solid var(--line-soft);background:#22d3ee14;height:28px}.screen-preview-content{padding:14px}.preview-card{background:#2563eb47;border-radius:10px;height:34px;margin-bottom:12px}.preview-line{background:#ffffff2e;border-radius:999px;height:8px;margin-bottom:8px}.preview-line.short{width:60%}.audio-device{width:230px;height:170px;color:var(--accent);background:radial-gradient(circle at top,#22d3ee2e,#0000 45%),#0f172af2;border:1px solid #22d3ee47;border-radius:24px;place-items:center;padding:22px;display:grid;box-shadow:0 0 42px #22d3ee1f}.audio-device p{color:var(--text-soft);margin:0;font-weight:700}.eq-bars{gap:6px;height:44px}.eq-bars span{background:linear-gradient(180deg, var(--accent), var(--primary));border-radius:999px;width:8px;animation:1s ease-in-out infinite eqPulse}.eq-bars span:first-child{height:18px;animation-delay:0s}.eq-bars span:nth-child(2){height:34px;animation-delay:.12s}.eq-bars span:nth-child(3){height:24px;animation-delay:.24s}.eq-bars span:nth-child(4){height:40px;animation-delay:.36s}.eq-bars span:nth-child(5){height:22px;animation-delay:.48s}.add-device-form,.upload-list{gap:16px;display:grid}.add-device-form{padding:24px}.add-device-field{gap:8px;display:grid}.add-device-field span{color:var(--text-muted);font-size:.85rem}.add-device-field input,.upload-item input{border:1px solid var(--line);color:#fff;background:#ffffff0d;border-radius:10px;outline:none}.add-device-field input{border-radius:16px;height:52px;padding:0 16px}.add-device-field input::placeholder,.upload-item input::placeholder{color:#ffffff57}.add-device-field input:focus,.upload-item input:focus{border-color:#22d3ee5c;box-shadow:0 0 0 4px #22d3ee14}.add-device-hint{color:var(--accent);background:#22d3ee0f;border:1px solid #22d3ee29;border-radius:16px;gap:12px;padding:14px;display:flex}.add-device-hint p{color:var(--text-muted);margin:4px 0 0}.add-device-submit{width:100%}.upload-dropzone{text-align:center;cursor:pointer;border:2px dashed #22d3ee40;border-radius:20px;place-items:center;height:180px;margin:20px;transition:all .2s;display:grid;position:relative}.upload-dropzone:hover{border-color:var(--accent);background:#22d3ee0d}.upload-dropzone input{opacity:0;cursor:pointer;position:absolute;inset:0}.upload-list{max-height:160px;padding:0 20px;overflow-y:auto}.upload-item{background:#ffffff0a;border-radius:14px;justify-content:space-between;align-items:center;gap:10px;padding:10px 14px;display:flex}.upload-item input{flex:1;height:36px;padding:0 10px}.upload-btn{width:calc(100% - 40px);margin:20px}.danger-backdrop{z-index:70}.delete-modal{background:radial-gradient(circle at top,#ef444429,#0000 36%),#0b1120f5;border:1px solid #ef44443d;border-radius:26px;width:min(440px,100%);padding:26px;box-shadow:0 30px 100px #0000008c}.delete-icon{color:#f87171;background:#ef44441f;border:1px solid #ef444438;border-radius:16px;place-items:center;width:48px;height:48px;margin-bottom:18px;display:grid}.delete-modal h2{margin:0;font-size:1.7rem}.delete-modal p{color:var(--text-soft);margin:12px 0 0;line-height:1.7}.delete-actions{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}.toast{z-index:80;color:#fff;border:1px solid var(--line);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#0a1223eb;border-radius:16px;align-items:center;gap:10px;min-width:280px;padding:14px 16px;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 20px 60px #00000073}.toast.success{border-color:#10b98147}.toast.success svg{color:#34d399}.toast.error{border-color:#ef444447}.toast.error svg{color:#f87171}@keyframes eqPulse{0%,to{opacity:.65;transform:scaleY(.55)}50%{opacity:1;transform:scaleY(1)}}@media (width<=1100px){.hero,.split-section{grid-template-columns:1fr}.hero-visual{justify-content:flex-start}.features{grid-template-columns:1fr}.cta-block{flex-direction:column;align-items:flex-start}.auth-shell{grid-template-columns:1fr}.auth-left{border-right:none;border-bottom:1px solid var(--line-soft);min-height:auto}}@media (width<=1050px){.dashboard-page{grid-template-columns:1fr}.dashboard-sidebar{display:none}.dashboard-stats{grid-template-columns:repeat(2,1fr)}.dashboard-grid{grid-template-columns:1fr}}@media (width<=900px){.device-modal-body{grid-template-columns:1fr}.screen-stage,.audio-stage{height:260px}}@media (width<=850px){.devices-toolbar{flex-direction:column}}@media (width<=720px){.site-header,.container{padding-left:16px;padding-right:16px}.site-header{padding-top:20px}.hero{padding-top:42px}.hero-title{font-size:3.2rem}.hero-text{font-size:1.05rem}.mockup-body{grid-template-columns:1fr}.mockup-sidebar{border-right:none;border-bottom:1px solid var(--line-soft);flex-wrap:wrap;gap:10px;display:flex}.mock-item{margin-bottom:0}.split-section,.cta-block{padding:24px 20px}.auth-page{padding:14px}.auth-left,.auth-card{padding:22px 18px}}@media (width<=640px){.dashboard-main{padding:18px}.dashboard-header{flex-direction:column;align-items:flex-start}.dashboard-user,.device-header-actions{flex-direction:column;align-items:flex-start;width:100%}.dashboard-stats,.devices-compact-stats{grid-template-columns:1fr}.devices-card-list,.content-card-list{grid-template-columns:1fr;grid-auto-rows:auto}.device-card{width:100%}}.skeleton{border:1px solid var(--line-soft);background:linear-gradient(90deg,#ffffff06,#ffffff0f,#ffffff06) 0 0/220% 100%;border-radius:18px;animation:1.25s ease-in-out infinite skeleton-pulse}.skeleton-card{grid-template-columns:56px 1fr;gap:14px;min-height:150px;padding:16px;display:grid}.skeleton-row{grid-template-columns:44px 1fr;gap:12px;min-height:76px;padding:14px;display:grid}.skeleton-stat{height:110px;padding:16px}.skeleton-icon{background:#ffffff14;border-radius:14px;width:52px;height:52px}.skeleton-content{align-content:center;gap:10px;display:grid}.skeleton-line{background:#ffffff14;border-radius:999px;height:12px}.skeleton-line.wide{width:70%}.skeleton-line.short{width:38%}@keyframes skeleton-pulse{0%{background-position:100% 0}to{background-position:-100% 0}}.dashboard-brand-wrap{margin-bottom:28px;position:relative}.dashboard-brand{margin-bottom:0;padding-right:46px}.admin-link-button{color:#22d3ee;background:#22d3ee14;border:1px solid #22d3ee33;border-radius:12px;justify-content:center;align-items:center;width:34px;height:34px;display:flex;position:absolute;top:8px;right:8px}.admin-link-button:hover{background:#22d3ee24}
