*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f0f0f;--surface: #1c1c1c;--surface2: #272727;--border: #2a2a2a;--text: #e0e0e0;--text-muted: #888;--accent: #ff0000;--accent-dim: rgba(255,0,0,.15);--sidebar-w: 220px;--header-h: 56px}body{background:var(--bg);color:var(--text);font-family:Noto Sans JP,sans-serif;font-weight:400;min-height:100vh}.app-layout{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{position:fixed;top:0;left:0;right:0;height:var(--header-h);z-index:200;background:#0f0f0ff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:16px;padding:0 20px}.app-logo{font-size:1.1rem;font-weight:500;letter-spacing:.04em;color:var(--text);white-space:nowrap;-webkit-user-select:none;user-select:none}.app-logo span{color:var(--accent);margin-right:2px}.app-body{display:flex;margin-top:var(--header-h);height:calc(100vh - var(--header-h));overflow:hidden}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);overflow-y:auto;padding:12px 0}.sidebar-label{font-size:.68rem;letter-spacing:.1em;color:var(--text-muted);padding:8px 16px 4px;text-transform:uppercase}.sidebar-btn{display:block;width:100%;padding:10px 16px;background:none;border:none;color:var(--text-muted);font-family:inherit;font-size:.85rem;text-align:left;cursor:pointer;transition:background .15s,color .15s;border-left:3px solid transparent}.sidebar-btn:hover{background:var(--surface2);color:var(--text)}.sidebar-btn.active{background:var(--accent-dim);color:var(--text);border-left-color:var(--accent)}.main-content{flex:1;overflow-y:auto;padding:20px}.searchbar-wrap{flex:1;max-width:680px;display:flex;flex-direction:column;gap:0}.searchbar{display:flex;align-items:center;gap:8px}.searchbar-input{flex:1;background:var(--surface2);border:1px solid var(--border);color:var(--text);font-family:inherit;font-size:.88rem;padding:6px 12px;border-radius:2px;outline:none;transition:border-color .2s}.searchbar-input::placeholder{color:var(--text-muted)}.searchbar-input:focus{border-color:var(--accent)}.searchbar-select{background:var(--surface2);border:1px solid var(--border);color:var(--text);font-family:inherit;font-size:.82rem;padding:6px 10px;border-radius:2px;outline:none;cursor:pointer;white-space:nowrap}.searchbar-select:focus{border-color:var(--accent)}.searchbar-filter-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text-muted);font-size:.85rem;padding:5px 9px;border-radius:2px;cursor:pointer;flex-shrink:0;transition:color .15s,border-color .15s}.searchbar-filter-btn:hover,.searchbar-filter-btn.active{color:var(--text);border-color:var(--accent)}.searchbar-cross-label{display:flex;align-items:center;gap:5px;font-size:.78rem;color:var(--text-muted);cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none}.searchbar-cross-checkbox{accent-color:var(--accent);cursor:pointer}.filter-panel{background:var(--surface);border:1px solid var(--border);border-top:none;padding:10px 12px;display:flex;flex-direction:column;gap:8px;animation:filter-slide .15s ease}@keyframes filter-slide{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.filter-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.filter-label{font-size:.75rem;color:var(--text-muted);white-space:nowrap}.filter-input{background:var(--surface2);border:1px solid var(--border);color:var(--text);font-family:inherit;font-size:.8rem;padding:4px 8px;border-radius:2px;outline:none;transition:border-color .2s;color-scheme:dark}.filter-input:focus{border-color:var(--accent)}.filter-select{background:var(--surface2);border:1px solid var(--border);color:var(--text);font-family:inherit;font-size:.8rem;padding:4px 8px;border-radius:2px;outline:none;cursor:pointer}.filter-select:focus{border-color:var(--accent)}.filter-check-label{display:flex;align-items:center;gap:5px;font-size:.78rem;color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none}.filter-check-label input{accent-color:var(--accent);cursor:pointer}.filter-reset-btn{background:none;border:1px solid var(--border);color:var(--text-muted);font-family:inherit;font-size:.75rem;padding:3px 10px;border-radius:2px;cursor:pointer;transition:color .15s,border-color .15s;margin-left:auto}.filter-reset-btn:hover{color:var(--text);border-color:#555}.stats-btn{background:none;border:1px solid var(--border);color:var(--text-muted);font-family:inherit;font-size:.82rem;padding:5px 12px;border-radius:2px;cursor:pointer;flex-shrink:0;margin-left:auto;transition:color .15s,border-color .15s,background .15s;white-space:nowrap}.stats-btn:hover{color:var(--text);border-color:#555}.stats-btn.active{color:var(--text);border-color:var(--accent);background:var(--accent-dim)}.stats-page{display:flex;flex-direction:column;gap:28px;padding-bottom:40px;animation:card-in .2s ease both}.stats-page-header{display:flex;align-items:center;gap:16px}.stats-page-title{font-size:1.2rem;font-weight:500;color:var(--text)}.stats-section{display:flex;flex-direction:column;gap:14px}.stats-section-title{font-size:.78rem;font-weight:500;letter-spacing:.1em;color:var(--text-muted);text-transform:uppercase;padding-bottom:8px;border-bottom:1px solid var(--border)}.stats-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.stats-card{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:20px 16px 16px;display:flex;flex-direction:column;gap:6px}.stats-card-value{font-size:1.5rem;font-weight:500;color:var(--text);line-height:1.2}.stats-card-label{font-size:.72rem;color:var(--text-muted);letter-spacing:.06em;margin-bottom:4px}.stats-channel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}.stats-channel-card{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:16px;display:flex;flex-direction:column;gap:8px}.stats-channel-name{font-size:.9rem;font-weight:500;color:var(--text);padding-bottom:8px;border-bottom:1px solid var(--border);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stats-channel-row{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.stats-channel-key{font-size:.75rem;color:var(--text-muted);flex-shrink:0}.stats-channel-val{font-size:.82rem;color:var(--text);text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stats-channel-bars{display:flex;flex-direction:column;gap:6px;margin-top:4px}.stats-channel-bar-row{display:flex;align-items:center;gap:8px}.stats-channel-bar-label{font-size:.7rem;color:var(--text-muted);width:38px;flex-shrink:0}.stats-bar-track{flex:1;display:flex;align-items:center;gap:6px;min-width:0}.stats-bar-fill{height:6px;border-radius:3px;min-width:2px;transition:width .4s ease;flex-shrink:0}.stats-bar-label{font-size:.72rem;color:var(--text-muted);white-space:nowrap;min-width:32px}.stats-table-wrap{overflow-x:auto;background:var(--surface);border:1px solid var(--border);border-radius:6px}.stats-table{width:100%;border-collapse:collapse;font-size:.82rem;min-width:700px}.stats-table th{text-align:left;padding:10px 14px;color:var(--text-muted);font-size:.72rem;font-weight:500;letter-spacing:.06em;border-bottom:1px solid var(--border);white-space:nowrap;background:var(--surface2)}.stats-table td{padding:10px 14px;border-bottom:1px solid var(--border);vertical-align:middle}.stats-table tr:last-child td{border-bottom:none}.stats-table tr:hover td{background:var(--surface2)}.stats-td-name{color:var(--text);font-weight:500;white-space:nowrap}.stats-td-num{color:var(--text);white-space:nowrap;text-align:right}.stats-td-bar{min-width:120px}.stats-td-date{color:var(--text-muted);white-space:nowrap;font-size:.75rem}.video-grid-wrap{display:flex;flex-direction:column;gap:16px}.video-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}.video-grid-empty{text-align:center;padding:80px 0;color:var(--text-muted);font-size:.9rem}.pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:8px 0 4px}.pagination-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text-muted);font-family:inherit;font-size:.82rem;padding:6px 14px;border-radius:2px;cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap}.pagination-btn:hover:not(:disabled){color:var(--text);border-color:#555}.pagination-btn:disabled{opacity:.35;cursor:default}.pagination-info{font-size:.82rem;color:var(--text-muted);min-width:80px;text-align:center}@keyframes card-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.video-card{cursor:pointer;background:var(--surface);border-radius:4px;overflow:hidden;animation:card-in .3s ease both;transition:transform .2s ease}.video-card:hover{transform:scale(1.02)}.video-card-thumb{position:relative;width:100%;aspect-ratio:16 / 9;background:#111;overflow:hidden}.video-card-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}.video-card:hover .video-card-thumb img{transform:scale(1.05)}.video-card-placeholder{width:100%;height:100%;background:#1a1a1a;display:flex;align-items:center;justify-content:center;color:#333;font-size:2rem}.video-card-duration{position:absolute;bottom:6px;right:6px;background:#000c;color:#fff;font-size:.72rem;padding:2px 5px;border-radius:2px;letter-spacing:.03em}.video-card-chat-badge{position:absolute;top:6px;right:6px;font-size:.75rem;background:#000000b3;padding:2px 4px;border-radius:2px}.video-card-resume-badge{position:absolute;bottom:6px;left:6px;background:#ff0000bf;color:#fff;font-size:.68rem;font-weight:500;padding:2px 6px;border-radius:2px;letter-spacing:.03em}.video-card-info{padding:8px 10px 10px}.video-card-title{font-size:.82rem;font-weight:500;line-height:1.4;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;color:var(--text)}.video-card-meta{display:flex;align-items:center;justify-content:space-between;margin-top:4px;gap:6px}.video-card-date{font-size:.72rem;color:var(--text-muted)}.video-card-duration-text{font-size:.72rem;color:var(--text-muted);white-space:nowrap}.video-card-chat-count-meta{font-size:.7rem;color:#4a9eff;white-space:nowrap;margin-left:auto;flex-shrink:0}.video-card-channel-badge{margin-top:4px;font-size:.68rem;color:#4a9eff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-screen{display:flex;flex-direction:column;height:100%}.player-topbar{display:flex;align-items:center;gap:12px;margin-bottom:12px}.btn-back{background:var(--surface2);border:1px solid var(--border);color:var(--text-muted);font-family:inherit;font-size:.82rem;padding:6px 12px;cursor:pointer;border-radius:2px;transition:color .15s,border-color .15s;white-space:nowrap}.btn-back:hover{color:var(--text);border-color:#555}.player-title{font-size:.95rem;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-main{display:grid;grid-template-columns:1fr 320px;gap:12px;flex:1;min-height:0}.player-video-wrap{background:#000;border-radius:4px;overflow:hidden;display:flex;align-items:center;justify-content:center}.player-video-wrap video{width:100%;max-height:100%;display:block}.chat-panel{background:var(--surface);border-radius:4px;display:flex;flex-direction:column;min-height:0;overflow:hidden}.chat-header{padding:10px 12px;border-bottom:1px solid var(--border);font-size:.8rem;font-weight:500;color:var(--text-muted);flex-shrink:0}.chat-list{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:6px}.chat-list::-webkit-scrollbar{width:4px}.chat-list::-webkit-scrollbar-track{background:transparent}.chat-list::-webkit-scrollbar-thumb{background:#333;border-radius:2px}.chat-item{font-size:.8rem;line-height:1.45;animation:card-in .2s ease both;display:flex;gap:6px;flex-wrap:wrap;align-items:baseline}.chat-item-time{color:var(--text-muted);font-size:.72rem;flex-shrink:0;font-variant-numeric:tabular-nums;letter-spacing:.02em}.chat-item-author{color:var(--accent);font-weight:500;flex-shrink:0}.chat-item-text{color:var(--text);word-break:break-all}.chat-empty,.chat-loading{padding:20px;text-align:center;color:var(--text-muted);font-size:.8rem}.loading{text-align:center;padding:80px 0;color:var(--text-muted);font-size:.88rem;letter-spacing:.1em}.fetch-error{display:flex;align-items:center;gap:10px;margin:40px auto;max-width:480px;padding:16px 20px;background:#ff50501a;border:1px solid rgba(255,80,80,.3);border-radius:4px;color:#ff8080;font-size:.88rem;line-height:1.5}@media (max-width: 1024px){.stats-summary-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){:root{--sidebar-w: 160px}.app-header{padding:0 12px;gap:10px}.app-logo{font-size:.95rem}.searchbar-input{font-size:.82rem}.video-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}.player-main{grid-template-columns:1fr;grid-template-rows:auto 1fr}.chat-panel{min-height:200px;max-height:300px}}@media (max-width: 480px){:root{--sidebar-w: 0px}.sidebar{display:none}.video-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.main-content{padding:12px}.stats-summary-grid{grid-template-columns:1fr 1fr}}.main-content::-webkit-scrollbar{width:6px}.main-content::-webkit-scrollbar-track{background:transparent}.main-content::-webkit-scrollbar-thumb{background:#2a2a2a;border-radius:3px}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:#2a2a2a;border-radius:2px}.sidebar-add-btn{display:block;width:calc(100% - 16px);margin:10px 8px 4px;padding:8px 12px;background:none;border:1px dashed var(--border);color:var(--text-muted);font-family:inherit;font-size:.8rem;text-align:center;cursor:pointer;border-radius:3px;transition:border-color .15s,color .15s}.sidebar-add-btn:hover{border-color:var(--accent);color:var(--accent)}.sidebar-history-btn{padding-top:7px;padding-bottom:7px}.sidebar-history-title{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.78rem;line-height:1.4}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;background:#000000b3;display:flex;align-items:center;justify-content:center;animation:modal-fade .15s ease}@keyframes modal-fade{0%{opacity:0}to{opacity:1}}.modal-box{background:var(--surface);border:1px solid var(--border);border-radius:6px;width:420px;max-width:calc(100vw - 40px);display:flex;flex-direction:column;animation:modal-slide .15s ease}@keyframes modal-slide{0%{transform:translateY(-12px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);font-size:.9rem;font-weight:500;color:var(--text)}.modal-close{background:none;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;padding:2px 6px;border-radius:3px;transition:color .15s}.modal-close:hover{color:var(--text)}.modal-body{padding:16px;display:flex;flex-direction:column;gap:10px}.modal-label{font-size:.78rem;color:var(--text-muted)}.modal-hint{font-size:.72rem;color:var(--text-muted);opacity:.7}.modal-input{background:var(--surface2);border:1px solid var(--border);color:var(--text);font-family:inherit;font-size:.85rem;padding:7px 10px;border-radius:3px;outline:none;transition:border-color .2s;width:100%}.modal-input::placeholder{color:var(--text-muted);opacity:.6}.modal-input:focus{border-color:var(--accent)}.modal-error{font-size:.78rem;color:#ff8080;padding:6px 10px;background:#ff50501a;border:1px solid rgba(255,80,80,.25);border-radius:3px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 16px;border-top:1px solid var(--border)}.modal-btn-cancel{background:none;border:1px solid var(--border);color:var(--text-muted);font-family:inherit;font-size:.82rem;padding:6px 16px;border-radius:3px;cursor:pointer;transition:color .15s,border-color .15s}.modal-btn-cancel:hover:not(:disabled){color:var(--text);border-color:#555}.modal-btn-cancel:disabled{opacity:.4;cursor:default}.modal-btn-submit{background:var(--accent);border:none;color:#fff;font-family:inherit;font-size:.82rem;font-weight:500;padding:6px 18px;border-radius:3px;cursor:pointer;transition:opacity .15s}.modal-btn-submit:hover:not(:disabled){opacity:.85}.modal-btn-submit:disabled{opacity:.4;cursor:default}.chat-filter-wrap{padding:6px 8px;border-bottom:1px solid var(--border);flex-shrink:0;display:flex;align-items:center;gap:4px}.chat-filter-input{flex:1;background:var(--surface2);border:1px solid var(--border);color:var(--text);font-family:inherit;font-size:.78rem;padding:4px 8px;border-radius:2px;outline:none;transition:border-color .2s}.chat-filter-input::placeholder{color:var(--text-muted);opacity:.6}.chat-filter-input:focus{border-color:var(--accent)}.chat-filter-clear{background:none;border:none;color:var(--text-muted);font-size:.75rem;cursor:pointer;padding:2px 6px;border-radius:2px;flex-shrink:0;transition:color .15s}.chat-filter-clear:hover{color:var(--text)}.video-card-fav-btn{position:absolute;top:6px;left:6px;background:#000000a6;border:none;color:#aaa;font-size:.95rem;line-height:1;width:26px;height:26px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s,color .15s,background .15s}.video-card:hover .video-card-fav-btn,.video-card-fav-btn.is-fav{opacity:1}.video-card-fav-btn.is-fav{color:#f5c518;background:#000000bf}.video-card-fav-btn:hover{color:#f5c518;background:#000000d9}.player-fav-btn{background:none;border:1px solid var(--border);color:var(--text-muted);font-size:1rem;padding:4px 10px;border-radius:2px;cursor:pointer;flex-shrink:0;transition:color .15s,border-color .15s;line-height:1}.player-fav-btn:hover,.player-fav-btn.is-fav{color:#f5c518;border-color:#f5c518}.video-card-tag-btn{position:absolute;top:6px;left:36px;background:#000000a6;border:none;color:#aaa;font-size:.85rem;line-height:1;width:26px;height:26px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s,color .15s,background .15s}.video-card:hover .video-card-tag-btn,.video-card-tag-btn.is-tagged{opacity:1}.video-card-tag-btn.is-tagged{color:#4caf50;background:#000000bf}.video-card-tag-btn:hover{color:#4caf50;background:#000000d9}.video-card-watched-badge{font-size:.7rem;color:#4caf50;margin-top:2px}.all-videos-page{display:flex;flex-direction:column;height:100%;overflow:hidden}.all-videos-toolbar{display:flex;align-items:center;gap:10px;padding:10px 16px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--bg);flex-wrap:wrap}.all-videos-toolbar-left{flex-shrink:0}.all-videos-toolbar-center{flex:1;min-width:160px}.all-videos-toolbar-right{display:flex;gap:8px;align-items:center;flex-shrink:0}.all-videos-count{font-size:.8rem;color:var(--text-muted);white-space:nowrap}.all-videos-search{width:100%;background:var(--surface);border:1px solid var(--border);color:var(--text);padding:5px 10px;border-radius:3px;font-size:.85rem}.all-videos-search:focus{border-color:var(--accent);outline:none}.all-videos-sort{background:var(--surface);border:1px solid var(--border);color:var(--text);padding:4px 8px;border-radius:3px;font-size:.8rem;cursor:pointer}.all-videos-exclude-btn{background:var(--surface);border:1px solid var(--border);color:var(--text-muted);padding:4px 10px;border-radius:3px;font-size:.8rem;cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s,background .15s}.all-videos-exclude-btn:hover{border-color:var(--accent);color:var(--text)}.all-videos-exclude-btn.active{background:#4caf5026;border-color:#4caf50;color:#4caf50}.all-videos-page .video-grid-wrap{flex:1;overflow-y:auto}.sidebar-all-btn{font-size:.78rem;margin-bottom:4px;border:1px solid transparent}.sidebar-all-btn.active{border-color:var(--accent);color:var(--accent)}
