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