:root{color-scheme:dark;font-family:system-ui,sans-serif;--bg: #0b0d12;--bg-elev: #151923;--bg-elev-2: #1d2230;--fg: #e8ebf0;--fg-dim: #8a91a0;--accent: #5b8def;--accent-fg: #ffffff;--border: #2a3040;--danger: #e06c75}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--fg)}button{font:inherit;color:inherit;cursor:pointer}.auth{min-height:100vh;display:grid;place-items:center;padding:2rem}.auth-card{width:100%;max-width:360px;background:var(--bg-elev);border:1px solid var(--border);border-radius:12px;padding:2rem;display:flex;flex-direction:column;gap:1rem}.auth-card h1{margin:0;text-align:center;letter-spacing:.02em}.auth-tabs{display:flex;gap:.25rem;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:4px}.auth-tabs button{flex:1;background:transparent;border:none;padding:.5rem;border-radius:6px;color:var(--fg-dim)}.auth-tabs button.active{background:var(--bg-elev-2);color:var(--fg)}.auth-card label{display:flex;flex-direction:column;gap:.35rem;font-size:.85rem;color:var(--fg-dim)}.auth-card input{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:.55rem .7rem;color:var(--fg);font-size:.95rem}.auth-card input:focus{outline:none;border-color:var(--accent)}.auth-submit{background:var(--accent);color:var(--accent-fg);border:none;border-radius:8px;padding:.65rem;font-weight:600}.auth-submit:disabled{opacity:.6;cursor:default}.auth-error{margin:0;color:var(--danger);font-size:.85rem}.shell{--nav-width: 220px;height:100vh;display:grid;grid-template-columns:var(--nav-width) 1fr;transition:grid-template-columns .18s ease}.shell.nav-closed{grid-template-columns:0 1fr}.nav{background:var(--bg-elev);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:1rem .75rem;gap:1rem;overflow:hidden;min-width:0}.shell.nav-closed .nav{padding:0;border-right-color:transparent}.nav-brand{font-size:1.1rem;font-weight:400;letter-spacing:.02em;padding:.25rem .5rem;white-space:nowrap;display:flex;align-items:center;gap:.5rem;color:#fff}.nav-brand-icon{width:1em;height:1em;filter:brightness(0) invert(1)}.nav-items{display:flex;flex-direction:column;gap:.25rem}.nav-item{background:transparent;border:none;text-align:left;padding:.55rem .75rem;border-radius:6px;color:var(--fg-dim);font-size:.95rem;white-space:nowrap;display:flex;align-items:center;gap:.6rem}.nav-item:hover,.nav-item.active{background:var(--bg-elev-2);color:var(--fg)}.nav-user{margin-top:auto;display:flex;flex-direction:column;gap:.5rem;padding:.75rem .5rem .5rem;border-top:1px solid var(--border)}.nav-username{font-size:.85rem;color:var(--fg-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-logout{background:transparent;border:1px solid var(--border);color:var(--fg);border-radius:6px;padding:.4rem .75rem;font-size:.85rem;display:flex;align-items:center;gap:.5rem}.nav-logout:hover{background:var(--bg-elev-2)}.main{min-width:0;min-height:0;display:grid;grid-template-rows:auto minmax(0,1fr)}.main-header{display:flex;align-items:center;gap:.75rem;padding:.9rem 1.25rem;border-bottom:1px solid var(--border)}.main-header h1{margin:0;font-size:1.1rem;font-weight:500;color:var(--fg-dim);letter-spacing:.02em}.hamburger{width:36px;height:36px;display:grid;place-items:center;background:transparent;border:1px solid var(--border);border-radius:6px;padding:8px;font-size:1rem}.hamburger:hover{background:var(--bg-elev)}.main-content{min-width:0;overflow:auto}.guide{display:grid;grid-template-rows:auto minmax(0,1fr);gap:.5rem;padding:.5rem .75rem .75rem;height:100%}.feeds{padding:1rem 1.25rem 1.5rem;max-width:720px}.feeds-header-top{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem;margin-bottom:.5rem}.feeds-header-top p{margin:0;color:var(--fg-dim)}.feeds-header-actions{display:flex;align-items:center;gap:.5rem}.feeds-action-primary{background:var(--accent);color:var(--accent-fg);border:none;border-radius:6px;padding:.3rem .75rem;font-size:.85rem;font-weight:500;cursor:pointer}.feeds-action-primary:hover{opacity:.9}.feeds-action-secondary{background:transparent;border:1px solid var(--border);color:var(--fg);border-radius:6px;padding:.3rem .75rem;font-size:.85rem;cursor:pointer}.feeds-action-secondary:hover{border-color:var(--accent);color:var(--accent)}.feeds-action-secondary input[type=file]{display:none}.feeds-action-danger{background:transparent;border:1px solid var(--error, #e05c5c);color:var(--error, #e05c5c);border-radius:4px;padding:.3rem .7rem;font-size:.8rem;cursor:pointer;opacity:.8}.feeds-action-danger:hover{opacity:1}.add-feed-label{display:block;font-size:.8rem;color:var(--fg-dim);margin-top:.75rem;margin-bottom:.3rem}.add-feed-input{background:var(--bg2);border:1px solid var(--border);border-radius:6px;color:var(--fg);font-size:.85rem;padding:.3rem .6rem;width:100%;margin-top:0;margin-bottom:.75rem}.add-feed-input:focus{outline:none;border-color:var(--accent)}.feeds-header-refresh{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;margin-bottom:.75rem}.feeds-header h2{margin:0}.feeds-header p{margin:0 0 1.5rem;color:var(--fg-dim)}.feed-tree-refresh{background:transparent;border:none;color:var(--fg-dim);border-radius:6px;padding:.25rem .6rem;font-size:.8rem;cursor:pointer}.feed-tree-refresh input[type=file]{display:none}.feed-tree-refresh:hover:not(:disabled){color:#8ec07c}.feed-tree-refresh:disabled{opacity:.5;cursor:default}.feed-tree-refresh-msg{font-size:.8rem;color:var(--fg-dim);margin-left:.5rem}.feeds-empty{background:var(--bg-elev);border:1px dashed var(--border);border-radius:10px;padding:2rem;text-align:center}.feeds-empty p{margin:0}.feeds-hint{margin-top:.35rem!important;color:var(--fg-dim);font-size:.9rem}.feed-tree{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.35rem}.feed-tree-node{background:var(--bg-elev);border:1px solid var(--border);border-radius:6px;overflow:hidden}.feed-tree-summary{list-style:none;display:flex;align-items:center;gap:.5rem;padding:.4rem .65rem;cursor:pointer;-webkit-user-select:none;user-select:none}.feed-tree-summary::-webkit-details-marker{display:none}.feed-tree-summary:hover{background:var(--bg-elev-2)}.feed-tree-caret{width:0;height:0;border-left:5px solid var(--fg-dim);border-top:4px solid transparent;border-bottom:4px solid transparent;transition:transform .12s;transform:rotate(0)}.feed-tree-node[open]>.feed-tree-summary .feed-tree-caret{transform:rotate(90deg)}.feed-tree-title{flex:1;font-weight:500}.feed-tree-count{font-size:.8rem;color:var(--fg-dim)}.feed-tree-children{list-style:none;margin:0;padding:.3rem .5rem .4rem 1rem;display:flex;flex-direction:column;gap:.2rem;border-top:1px solid var(--border)}.feed-favicon{width:16px;height:16px;object-fit:contain;flex-shrink:0}.feed-favicon-placeholder{display:inline-block;width:16px;height:16px}.feed-tree-leaf-title,.sources-row-title{display:flex;align-items:center;gap:6px}.feed-source-stat{font-size:.75rem;color:var(--accent, #4a9eff);font-variant-numeric:tabular-nums}.feed-source-stat--dim{color:var(--fg-dim)}.feed-source-stat--error{color:var(--error, #e05c5c)}.drag-handle{flex:0 0 auto;background:transparent;border:none;color:var(--fg-dim);padding:0 .2rem;cursor:grab;display:grid;place-items:center;font-size:.75rem;touch-action:none;opacity:.4}.drag-handle:hover{opacity:1;color:var(--fg)}.drag-handle:active{cursor:grabbing}body.dragging,body.dragging *{cursor:grabbing!important}.feed-tree-children--drop-target{background:color-mix(in srgb,var(--accent) 8%,transparent);border-radius:4px}.feed-tree-children--empty{list-style:none;margin:0;border-top:none}.feed-tree-leaf--dragging-overlay{box-shadow:0 4px 16px #00000080;list-style:none}.feed-tree-leaf{display:flex;flex-direction:row;align-items:center;gap:.5rem;padding:.25rem .4rem;background:var(--bg);border:1px solid var(--border);border-radius:4px}.feed-tree-leaf-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.feed-tree-empty{margin:0;padding:.3rem .5rem .4rem 1rem;color:var(--fg-dim);font-size:.85rem;border-top:1px solid var(--border)}.sources-import{display:flex;flex-direction:column;gap:.75rem}.sources-upload{display:inline-flex;align-items:center;gap:.5rem;align-self:flex-start;background:var(--accent);color:var(--accent-fg);border-radius:8px;padding:.55rem .9rem;font-weight:500;cursor:pointer}.sources-upload input{display:none}.sources-list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.sources-list-header h3{margin:0}.sources-list-header input[type=file]{display:none}.sources-preview{background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;padding:1rem}.sources-preview p{margin:0 0 .75rem}.sources-preview code{background:var(--bg-elev-2);padding:1px 6px;border-radius:4px;font-size:.85em}.sources-preview-list,.sources-preview-feeds{list-style:none;margin:0 0 1rem;padding:0;display:flex;flex-direction:column;gap:.35rem;max-height:200px;overflow-y:auto}.sources-preview-list li,.sources-preview-feeds li{display:flex;flex-direction:column;gap:2px;padding:.4rem .6rem;background:var(--bg-elev-2);border-radius:6px}.sources-actions{display:flex;gap:.5rem}.sources-actions button{background:transparent;border:1px solid var(--border);color:var(--fg);border-radius:6px;padding:.45rem .9rem}.sources-actions .sources-primary{background:var(--accent);border-color:var(--accent);color:var(--accent-fg)}.sources-actions .feeds-action-danger{border-color:var(--error, #e05c5c);color:var(--error, #e05c5c)}.sources-error{color:var(--danger);margin:0;font-size:.9rem}.sources-success{color:#8ec07c;margin:0;font-size:.9rem}.sources-list h3{margin:0 0 .75rem;font-size:1rem;color:var(--fg-dim);font-weight:500}.sources-rows{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.sources-row{display:flex;align-items:center;gap:.75rem;padding:.65rem .8rem;background:var(--bg-elev);border:1px solid var(--border);border-radius:8px}.sources-row-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.sources-remove{flex:0 0 auto;background:transparent;border:none;color:var(--fg-dim);border-radius:4px;width:1.5rem;height:1.5rem;display:grid;place-items:center;font-size:.85rem;padding:0}.sources-remove:hover{color:var(--danger)}.sources-title{font-size:.95rem}.sources-url{font-size:.8rem;color:var(--fg-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-decoration:none}.sources-url:hover{color:var(--accent)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:grid;place-items:center;z-index:100}.modal{background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;padding:1.5rem;width:min(420px,calc(100vw - 2rem));display:flex;flex-direction:column;gap:.75rem}.modal-title{margin:0;font-size:1rem;font-weight:600}.modal-body{margin:0;color:var(--fg-dim);font-size:.9rem;line-height:1.5}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.25rem}.modal-cancel{background:transparent;border:1px solid var(--border);color:var(--fg);border-radius:6px;padding:.4rem .9rem;font-size:.9rem}.modal-cancel:hover{background:var(--bg-elev-2)}.modal-confirm{background:var(--accent);border:none;color:var(--accent-fg);border-radius:6px;padding:.4rem .9rem;font-size:.9rem;font-weight:500}.modal-confirm:hover{opacity:.9}.modal-confirm--danger{background:var(--danger)}.viewer{position:relative;width:100%;aspect-ratio:16 / 9;max-height:50vh;background:#000;border-radius:10px;overflow:hidden;border:1px solid var(--border)}.viewer>:first-child{width:100%!important;height:100%!important}.viewer-iframe{display:block;border:none}.viewer-empty{display:grid;place-items:center;height:100%;color:var(--fg-dim)}.epg{background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;overflow:hidden;display:grid;grid-template-rows:minmax(0,1fr)}.epg-scroll{overflow-x:auto;overflow-y:auto;display:grid;grid-template-columns:minmax(max-content,1fr);grid-auto-rows:max-content;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.epg-scroll::-webkit-scrollbar{height:10px;width:10px}.epg-scroll::-webkit-scrollbar-track{background:var(--bg-elev-2)}.epg-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:5px;border:2px solid var(--bg-elev-2)}.epg-scroll::-webkit-scrollbar-thumb:hover{background:var(--fg-dim)}.epg-scroll::-webkit-scrollbar-corner{background:var(--bg-elev-2)}.epg-empty{padding:2rem;text-align:center;color:var(--fg-dim)}.epg-empty p{margin:0}.epg-row{display:flex;min-height:80px;margin-bottom:4px}.epg-row:last-child{margin-bottom:0}.epg-channel{flex:0 0 var(--epg-channel-w, 170px);min-width:0;display:flex;align-items:center;padding:0 .9rem;background:var(--bg-elev-2);border-right:1px solid var(--border);font-weight:500;position:sticky;left:0;z-index:1}.epg-channel-title{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden;overflow-wrap:anywhere;line-height:1.25;font-size:.85rem}.epg-mark-all-btn{position:absolute;bottom:8px;right:10px;background:none;border:none;padding:0 2px;font-size:.8rem;line-height:1;color:var(--text-muted);cursor:pointer;opacity:0;transition:opacity .15s,color .15s}.epg-channel:hover .epg-mark-all-btn{opacity:1}.epg-mark-all-btn:hover{color:var(--accent)}.epg-resize{position:absolute;top:0;bottom:0;right:-3px;width:6px;cursor:col-resize;z-index:2}.epg-resize:hover{background:var(--accent)}.epg-track{display:flex;flex:0 0 auto;gap:0;padding:0}.epg-item{flex:0 0 220px;background:var(--bg-elev-2);border:none;text-decoration:none;color:inherit;border-right:1px solid var(--border);border-radius:0;padding:.55rem .7rem;display:flex;flex-direction:column;justify-content:space-between;align-items:flex-start;gap:.35rem;overflow:hidden;text-align:left;transition:background 80ms}.epg-item:last-child{border-right:none}.epg-item:hover{background:#242a3b}.epg-item.active{background:var(--accent);border-color:var(--accent);color:var(--accent-fg)}.epg-item.seen:not(.active){opacity:.55}.epg-item-title{font-size:.85rem;line-height:1.25;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden;width:100%}.epg-item-meta{display:flex;justify-content:space-between;width:100%;gap:.5rem;font-size:.7rem;opacity:.75}.epg-item-source{display:flex;align-items:center;gap:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.epg-item-favicon{flex:0 0 auto;display:block;opacity:.8}.epg-item-age{flex:0 0 auto}
