body,#root{min-height:100vh;margin:0;padding:0}*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f0f0f;--bg-card:#1a1a2e;--bg-input:#16213e;--text:#e0e0e0;--text-muted:#888;--primary:#4285f4;--primary-hover:#3367d6;--border:#2a2a4a;--error:#f44;--radius:12px}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.app{min-height:100vh;padding:1.5rem}.container{max-width:900px;margin:0 auto}.header{text-align:center;margin-bottom:1.5rem}.header h1{margin-bottom:.25rem;font-size:1.75rem;font-weight:700}.subtitle{color:var(--text-muted);font-size:.95rem}.connect-section{margin-bottom:1.5rem}.connect-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);text-align:center;padding:1.5rem}.connect-title{margin-bottom:.5rem;font-size:1.1rem;font-weight:600}.connect-desc{color:var(--text-muted);margin-bottom:1.25rem;font-size:.9rem}.connect-actions{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.get-token-btn{background:var(--primary);color:#fff;border-radius:8px;align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:background .2s;display:inline-flex}.get-token-btn:hover{background:var(--primary-hover)}.paste-token-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:8px;padding:.75rem 1.25rem;font-size:.9rem;transition:border-color .2s}.paste-token-btn:hover{border-color:var(--primary)}.token-form{flex-direction:column;gap:.75rem;display:flex}.token-input{background:var(--bg-input);border:2px solid var(--border);width:100%;color:var(--text);border-radius:8px;outline:none;padding:.75rem 1rem;font-family:monospace;font-size:.9rem;transition:border-color .2s}.token-input:focus{border-color:var(--primary)}.token-actions{justify-content:center;gap:.5rem;display:flex}.connect-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.625rem 1.5rem;font-size:.9rem;font-weight:500}.connect-btn:hover{background:var(--primary-hover)}.cancel-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;padding:.625rem 1.5rem;font-size:.9rem}.cancel-btn:hover{border-color:var(--text-muted)}.token-hint{color:var(--text-muted);text-align:left;background:#4285f414;border-radius:8px;padding:.75rem 1rem;font-size:.8rem;line-height:1.6}.user-bar{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.user-avatar{border-radius:50%;width:36px;height:36px}.avatar-placeholder{background:var(--bg-input);border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;display:flex}.user-info{flex-direction:column;flex:1;display:flex}.user-name{font-size:.9rem;font-weight:500}.user-email{color:var(--text-muted);font-size:.75rem}.logout-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;margin-left:auto;padding:.375rem .75rem;font-size:.8rem}.logout-btn:hover{border-color:var(--error);color:var(--error)}.error{color:var(--error);margin-bottom:1rem;padding:0 .25rem;font-size:.875rem}.drive-section{margin-bottom:1.5rem}.drive-section h2{margin-bottom:.75rem;font-size:1.1rem}.loading,.empty-drive{text-align:center;color:var(--text-muted);background:var(--bg-card);border-radius:var(--radius);padding:2rem}.video-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem;max-height:400px;padding-right:.25rem;display:grid;overflow-y:auto}.video-grid::-webkit-scrollbar{width:6px}.video-grid::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.video-card{background:var(--bg-card);cursor:pointer;text-align:left;color:var(--text);border:2px solid #0000;border-radius:10px;transition:border-color .2s,transform .15s;overflow:hidden}.video-card:hover{border-color:var(--primary);transform:translateY(-2px)}.video-card.active{border-color:var(--primary)}.video-thumb{background:#000;width:100%;padding-bottom:56.25%;position:relative;overflow:hidden}.video-thumb img{object-fit:cover;width:100%;height:100%;position:absolute;top:0;left:0}.video-placeholder-thumb{background:#111;justify-content:center;align-items:center;width:100%;height:100%;font-size:2rem;display:flex;position:absolute;top:0;left:0}.play-overlay{opacity:0;background:#000000b3;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:.75rem;transition:opacity .2s;display:flex;position:absolute;bottom:6px;right:6px}.video-card:hover .play-overlay{opacity:1}.video-info{padding:.5rem}.video-name{white-space:nowrap;text-overflow:ellipsis;margin-bottom:.125rem;font-size:.8rem;font-weight:500;overflow:hidden}.video-meta{color:var(--text-muted);font-size:.7rem}.divider{color:var(--text-muted);align-items:center;margin-bottom:1rem;font-size:.8rem;display:flex}.divider:before,.divider:after{content:"";background:var(--border);flex:1;height:1px}.divider span{padding:0 .75rem}.input-form{margin-bottom:1.5rem}.input-wrapper{gap:.75rem;display:flex}.url-input{background:var(--bg-input);border:2px solid var(--border);border-radius:var(--radius);color:var(--text);outline:none;flex:1;padding:.875rem 1rem;font-size:1rem;transition:border-color .2s}.url-input:focus{border-color:var(--primary)}.url-input::placeholder{color:var(--text-muted)}.play-btn{background:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:none;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;transition:background .2s}.play-btn:hover{background:var(--primary-hover)}.player-section{margin-bottom:1.5rem}.player-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.video-title{white-space:nowrap;text-overflow:ellipsis;max-width:70%;font-size:.9rem;font-weight:500;overflow:hidden}.player-actions{gap:.5rem;display:flex}.action-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:8px;padding:.5rem .75rem;font-size:.8rem}.action-btn:hover{background:var(--border)}.close-btn:hover{border-color:var(--error);color:var(--error)}.player-wrapper{border-radius:var(--radius);background:#000;width:100%;padding-bottom:56.25%;position:relative;overflow:hidden}.player-wrapper iframe{border:none;width:100%;height:100%;position:absolute;top:0;left:0}.placeholder{text-align:center;background:var(--bg-card);border-radius:var(--radius);border:2px dashed var(--border);margin-bottom:1.5rem;padding:3rem 2rem}.placeholder-icon{margin-bottom:.75rem;font-size:3rem}.placeholder p{color:var(--text-muted)}.history-section{background:var(--bg-card);border-radius:var(--radius);padding:1rem}.history-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.history-header h3{font-size:.95rem}.clear-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:.8rem}.clear-btn:hover{color:var(--error)}.history-list{flex-direction:column;gap:.5rem;display:flex}.history-item{background:var(--bg-input);border:1px solid var(--border);width:100%;color:var(--text);cursor:pointer;text-align:left;border-radius:8px;justify-content:space-between;align-items:center;padding:.625rem .75rem;transition:border-color .2s;display:flex}.history-item:hover{border-color:var(--primary)}.history-id{white-space:nowrap;text-overflow:ellipsis;max-width:70%;font-size:.85rem;overflow:hidden}.history-time{color:var(--text-muted);white-space:nowrap;font-size:.75rem}.footer{text-align:center;margin-top:2rem}.footer p{color:var(--text-muted);font-size:.8rem}@media (width<=600px){.header h1{font-size:1.35rem}.input-wrapper{flex-direction:column}.play-btn{width:100%}.connect-actions{flex-direction:column}.video-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}
