.category-filter{display:flex;gap:8px;padding:12px 20px;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none}.category-filter::-webkit-scrollbar{display:none}.category-tab{padding:8px 16px;font-size:14px;font-weight:500;color:#666;background:none;border:none;border-bottom:2px solid transparent;border-radius:0;cursor:pointer;transition:color .2s,border-color .2s;font-family:inherit;flex-shrink:0}.category-tab:hover{color:#333}.category-tab-active{color:#3498db;border-bottom-color:#3498db}@media(max-width:480px){.category-filter{padding:8px 16px}.category-tab{padding:6px 12px;font-size:13px}}.like-button-wrapper{display:inline-flex;align-items:center;gap:6px;position:relative}.like-button{background:none;border:none;cursor:pointer;padding:4px;font-size:20px;line-height:1;transition:transform .15s ease,opacity .15s ease;font-family:inherit}.like-button:hover:not(:disabled){transform:scale(1.15)}.like-button:disabled{opacity:.5;cursor:default}.like-button--liked .like-button__icon{color:#e74c3c}.like-button--not-liked .like-button__icon{color:#666}.like-button--not-liked:hover:not(:disabled) .like-button__icon{color:#e74c3c}.like-button__error{font-size:12px;color:#d32f2f;white-space:nowrap;animation:like-error-fade-in .2s ease-out}@keyframes like-error-fade-in{0%{opacity:0}to{opacity:1}}@media(max-width:480px){.like-button{font-size:18px;padding:3px}.like-button__error{font-size:11px}}.subscription-banner{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;padding:20px 24px;margin-bottom:20px;color:#fff}.subscription-banner-content{display:flex;align-items:center;justify-content:space-between;gap:16px}.subscription-banner-text{flex:1}.subscription-banner-title{margin:0 0 4px;font-size:18px;font-weight:600}.subscription-banner-description{margin:0;font-size:14px;opacity:.9}.subscription-banner-cta{padding:10px 24px;font-size:14px;font-weight:600;color:#667eea;background-color:#fff;border:none;border-radius:6px;cursor:pointer;white-space:nowrap;transition:background-color .2s,transform .1s}.subscription-banner-cta:hover{background-color:#f0f0f0;transform:translateY(-1px)}.subscription-banner-cta:active{transform:translateY(0)}.video-lock-badge{position:absolute;top:8px;left:8px;padding:4px 8px;background-color:#000000b3;color:#fff;font-size:12px;border-radius:4px;display:flex;align-items:center;gap:4px}.video-lock-badge svg{width:12px;height:12px}@media(max-width:600px){.subscription-banner-content{flex-direction:column;text-align:center}.subscription-banner-cta{width:100%}}.video-catalog{width:100%;padding:20px;box-sizing:border-box}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:16px}.spinner{width:48px;height:48px;border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-state p{font-size:16px;color:#666;margin:0}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:16px;padding:20px}.error-message{font-size:16px;color:#d32f2f;text-align:center;margin:0;max-width:500px}.retry-button{padding:12px 24px;font-size:16px;font-weight:500;color:#fff;background-color:#3498db;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.retry-button:hover{background-color:#2980b9}.retry-button:active{background-color:#1f6fa6}.empty-state{display:flex;align-items:center;justify-content:center;min-height:300px}.empty-state p{font-size:16px;color:#666;margin:0}.video-grid{display:grid;gap:24px;grid-template-columns:1fr}@media(min-width:600px){.video-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:900px){.video-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1200px){.video-grid{grid-template-columns:repeat(4,1fr)}}.video-card{display:flex;flex-direction:column;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s;cursor:pointer}.video-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.video-thumbnail{position:relative;width:100%;padding-top:56.25%;background-color:#f0f0f0;overflow:hidden}.video-thumbnail img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.video-duration{position:absolute;bottom:8px;right:8px;padding:4px 8px;background-color:#000c;color:#fff;font-size:12px;font-weight:500;border-radius:4px}.video-info{padding:16px}.video-title{margin:0;font-size:16px;font-weight:500;color:#333;line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.video-card__like{margin-top:8px}.video-player{width:100%;max-width:1200px;margin:0 auto;background-color:#000;border-radius:8px;overflow:hidden;box-shadow:0 4px 6px #0000001a}.video-container{position:relative;width:100%;padding-top:56.25%;background-color:#000}.video-element{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:contain}.video-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.video-controls{display:flex;align-items:center;gap:12px;padding:12px 16px;background-color:#1a1a1a;color:#fff}.control-button{background:none;border:none;color:#fff;font-size:20px;cursor:pointer;padding:8px 12px;border-radius:4px;transition:background-color .2s;display:flex;align-items:center;justify-content:center}.control-button:hover{background-color:#ffffff1a}.control-button:active{background-color:#fff3}.time-display{font-size:14px;font-family:monospace;white-space:nowrap;min-width:100px}.seek-bar{flex:1;height:6px;border-radius:3px;background:#ffffff4d;outline:none;cursor:pointer;-webkit-appearance:none;appearance:none}.seek-bar::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#fff;cursor:pointer;transition:transform .2s}.seek-bar::-webkit-slider-thumb:hover{transform:scale(1.2)}.seek-bar::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#fff;cursor:pointer;border:none;transition:transform .2s}.seek-bar::-moz-range-thumb:hover{transform:scale(1.2)}.volume-control{display:flex;align-items:center;gap:8px}.volume-icon{font-size:18px}.volume-bar{width:80px;height:6px;border-radius:3px;background:#ffffff4d;outline:none;cursor:pointer;-webkit-appearance:none;appearance:none}.volume-bar::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:#fff;cursor:pointer}.volume-bar::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:#fff;cursor:pointer;border:none}.video-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;background-color:#1a1a1a;color:#fff;text-align:center;min-height:300px}.error-icon{font-size:48px;margin-bottom:16px}.error-message{font-size:16px;margin-bottom:24px;max-width:400px;line-height:1.5}.retry-button{padding:10px 24px;background-color:#4a90e2;color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s}.retry-button:hover{background-color:#357abd}.retry-button:active{background-color:#2a5f99}@media(max-width:768px){.video-controls{gap:8px;padding:10px 12px}.control-button{font-size:18px;padding:6px 10px}.time-display{font-size:12px;min-width:90px}.volume-control{display:none}}@media(max-width:480px){.time-display{font-size:11px;min-width:80px}.seek-bar{height:4px}}.paywall-gate{position:relative;width:100%}.paywall-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:20;border-radius:8px}.paywall-overlay-content{text-align:center;color:#fff;padding:32px 24px;max-width:400px}.paywall-lock-icon{font-size:48px;margin-bottom:16px}.paywall-overlay-content h3{font-size:22px;margin:0 0 12px;font-weight:600}.paywall-overlay-content p{font-size:15px;color:#ccc;margin:0 0 24px;line-height:1.5}.paywall-subscribe-button{padding:12px 32px;background-color:#007bff;color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s}.paywall-subscribe-button:hover{background-color:#0056b3}.paywall-subscribe-button:active{background-color:#004494}.login-form-container{width:100%;max-width:440px;margin:0 auto;padding:40px 20px}.login-form-title{font-size:28px;font-weight:600;color:#333;margin:0 0 8px;text-align:center}.login-form-subtitle{font-size:14px;color:#666;margin:0 0 32px;text-align:center}.social-signin-section{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.social-button{width:100%;padding:12px;font-size:15px;font-weight:500;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:background-color .2s,opacity .2s;font-family:inherit}.social-button:disabled{opacity:.7;cursor:not-allowed}.social-button-google{background-color:#fff;color:#3c4043;border:1px solid #dadce0}.social-button-google:hover:not(:disabled){background-color:#f7f8f8}.social-button-apple{background-color:#000;color:#fff;border:1px solid #000}.social-button-apple:hover:not(:disabled){background-color:#1a1a1a}.social-button-icon{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;font-size:16px}.login-divider{display:flex;align-items:center;gap:16px;margin-bottom:24px}.login-divider-line{flex:1;height:1px;background-color:#e0e0e0}.login-divider-text{font-size:13px;color:#888;white-space:nowrap}.login-form{display:flex;flex-direction:column;gap:20px}.login-auth-error-banner{padding:10px 12px;background-color:#fdecea;border:1px solid #f5c6cb;border-radius:4px;font-size:13px;color:#d32f2f;margin:0}.forgot-password-link{color:#3498db;background:none;border:none;cursor:pointer;font-size:13px;padding:0;text-decoration:none;font-family:inherit;align-self:flex-end;margin-top:-12px}.forgot-password-link:hover{text-decoration:underline}.forgot-password-link:disabled{opacity:.5;cursor:not-allowed}.login-submit-button{width:100%;padding:12px;font-size:16px;font-weight:500;color:#fff;background-color:#3498db;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;justify-content:center;gap:8px}.login-submit-button:hover:not(:disabled){background-color:#2980b9}.login-submit-button:active:not(:disabled){background-color:#1f6fa6}.login-submit-button:disabled{opacity:.7;cursor:not-allowed}.login-footer{text-align:center;font-size:14px;color:#666;margin-top:4px}.login-footer-link{color:#3498db;background:none;border:none;cursor:pointer;font-size:14px;padding:0;text-decoration:none;font-family:inherit}.login-footer-link:hover{text-decoration:underline}@media(max-width:480px){.login-form-container{padding:24px 16px}.login-form-title{font-size:24px}}.register-form-container{width:100%;max-width:440px;margin:0 auto;padding:40px 20px}.register-form-title{font-size:28px;font-weight:600;color:#333;margin:0 0 8px;text-align:center}.register-form-subtitle{font-size:14px;color:#666;margin:0 0 32px;text-align:center}.register-form{display:flex;flex-direction:column;gap:20px}.checkbox-field{display:flex;align-items:flex-start;gap:8px}.checkbox-input{margin-top:2px;width:16px;height:16px;cursor:pointer;accent-color:#3498db}.checkbox-label{font-size:13px;color:#555;line-height:1.4;cursor:pointer}.checkbox-label a{color:#3498db;text-decoration:none}.checkbox-label a:hover{text-decoration:underline}.register-submit-button{width:100%;padding:12px;font-size:16px;font-weight:500;color:#fff;background-color:#3498db;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;justify-content:center;gap:8px}.register-submit-button:hover:not(:disabled){background-color:#2980b9}.register-submit-button:active:not(:disabled){background-color:#1f6fa6}.register-submit-button:disabled{opacity:.7;cursor:not-allowed}.register-footer{text-align:center;font-size:14px;color:#666;margin-top:4px}.register-footer-link{color:#3498db;background:none;border:none;cursor:pointer;font-size:14px;padding:0;text-decoration:none;font-family:inherit}.register-footer-link:hover{text-decoration:underline}@media(max-width:480px){.register-form-container{padding:24px 16px}.register-form-title{font-size:24px}}.email-verification-container{width:100%;max-width:440px;margin:0 auto;padding:40px 20px}.email-verification-title{font-size:28px;font-weight:600;color:#333;margin:0 0 8px;text-align:center}.email-verification-subtitle{font-size:14px;color:#666;margin:0;text-align:center}.email-verification-email{font-size:15px;font-weight:600;color:#333;margin:4px 0 0;text-align:center;word-break:break-all}.email-verification-instructions{font-size:14px;color:#666;margin:16px 0 24px;text-align:center;line-height:1.5}.verification-form{display:flex;flex-direction:column;gap:20px}.verification-code-input{text-align:center;font-size:20px;letter-spacing:6px;font-weight:500}.code-hint{font-size:12px;color:#888;margin:0}.verification-success-banner{padding:10px 12px;background-color:#e8f5e9;border:1px solid #c8e6c9;border-radius:4px;font-size:13px;color:#2e7d32;margin:0 0 16px;text-align:center}.verify-submit-button{width:100%;padding:12px;font-size:16px;font-weight:500;color:#fff;background-color:#3498db;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;justify-content:center;gap:8px}.verify-submit-button:hover:not(:disabled){background-color:#2980b9}.verify-submit-button:active:not(:disabled){background-color:#1f6fa6}.verify-submit-button:disabled{opacity:.7;cursor:not-allowed}.resend-section{margin-top:24px;text-align:center}.resend-text{font-size:14px;color:#666;margin:0 0 8px}.resend-success{font-size:13px;color:#2e7d32;margin:0 0 8px}.resend-button{color:#3498db;background:none;border:none;cursor:pointer;font-size:14px;padding:4px 8px;font-family:inherit;transition:color .2s}.resend-button:hover:not(:disabled){text-decoration:underline;color:#2980b9}.resend-button:disabled{color:#999;cursor:not-allowed}.verification-footer{text-align:center;font-size:14px;color:#666;margin-top:16px}.verification-footer-link{color:#3498db;background:none;border:none;cursor:pointer;font-size:14px;padding:0;text-decoration:none;font-family:inherit}.verification-footer-link:hover{text-decoration:underline}@media(max-width:480px){.email-verification-container{padding:24px 16px}.email-verification-title{font-size:24px}}.forgot-password-container{width:100%;max-width:440px;margin:0 auto;padding:40px 20px}.forgot-password-title{font-size:28px;font-weight:600;color:#333;margin:0 0 8px;text-align:center}.forgot-password-subtitle{font-size:14px;color:#666;margin:0 0 32px;text-align:center}.forgot-password-form{display:flex;flex-direction:column;gap:20px}.forgot-password-submit-button{width:100%;padding:12px;font-size:16px;font-weight:500;color:#fff;background-color:#3498db;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;justify-content:center;gap:8px}.forgot-password-submit-button:hover:not(:disabled){background-color:#2980b9}.forgot-password-submit-button:active:not(:disabled){background-color:#1f6fa6}.forgot-password-submit-button:disabled{opacity:.7;cursor:not-allowed}.forgot-password-success{padding:16px;background-color:#e8f5e9;border:1px solid #c8e6c9;border-radius:4px;font-size:14px;color:#2e7d32;margin:0 0 24px;text-align:center;line-height:1.5}.forgot-password-login-button{width:100%;padding:12px;font-size:16px;font-weight:500;color:#fff;background-color:#3498db;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.forgot-password-login-button:hover{background-color:#2980b9}.forgot-password-footer{text-align:center;font-size:14px;color:#666;margin-top:4px}.forgot-password-footer-link{color:#3498db;background:none;border:none;cursor:pointer;font-size:14px;padding:0;text-decoration:none;font-family:inherit}.forgot-password-footer-link:hover{text-decoration:underline}.forgot-password-footer-link:disabled{opacity:.5;cursor:not-allowed}@media(max-width:480px){.forgot-password-container{padding:24px 16px}.forgot-password-title{font-size:24px}}.skip-to-content{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;z-index:1000;padding:8px 16px;background-color:#3498db;color:#fff;font-size:14px;text-decoration:none;border-radius:0 0 4px 4px}.skip-to-content:focus{position:fixed;left:16px;top:0;width:auto;height:auto;overflow:visible}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.form-field{display:flex;flex-direction:column;gap:6px}.form-label{font-size:14px;font-weight:500;color:#333}.form-input{width:100%;padding:10px 12px;font-size:14px;border:1px solid #ccc;border-radius:4px;outline:none;transition:border-color .2s;box-sizing:border-box;font-family:inherit}.form-input:focus{border-color:#3498db;box-shadow:0 0 0 2px #3498db26}.form-input:focus-visible{border-color:#3498db;box-shadow:0 0 0 3px #3498db59;outline:2px solid transparent}.form-input.input-error{border-color:#d32f2f}.form-input.input-error:focus{box-shadow:0 0 0 2px #d32f2f26}.form-input.input-error:focus-visible{box-shadow:0 0 0 3px #d32f2f59}.field-error{font-size:12px;color:#d32f2f;margin:0}.auth-error-banner{padding:10px 12px;background-color:#fdecea;border:1px solid #f5c6cb;border-radius:4px;font-size:13px;color:#d32f2f;margin:0}.button-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.password-strength{display:flex;align-items:center;gap:8px;margin-top:2px}.strength-bar-track{flex:1;height:4px;background-color:#e0e0e0;border-radius:2px;overflow:hidden}.strength-bar-fill{height:100%;border-radius:2px;transition:width .3s,background-color .3s}.strength-bar-fill.strength-weak{width:33%;background-color:#d32f2f}.strength-bar-fill.strength-medium{width:66%;background-color:#f57c00}.strength-bar-fill.strength-strong{width:100%;background-color:#388e3c}.strength-label{font-size:12px;font-weight:500;min-width:52px;text-align:right}.strength-label.strength-weak{color:#d32f2f}.strength-label.strength-medium{color:#f57c00}.strength-label.strength-strong{color:#388e3c}.password-requirements{list-style:none;padding:0;margin:4px 0 0;display:flex;flex-direction:column;gap:2px}.password-requirements li{font-size:12px;color:#d32f2f}button:focus-visible,[role=button]:focus-visible{outline:2px solid #3498db;outline-offset:2px}a:focus-visible{outline:2px solid #3498db;outline-offset:2px}.user-profile{position:relative;display:inline-flex;align-items:center}.user-profile-trigger{display:flex;align-items:center;gap:8px;padding:4px 8px;background:none;border:1px solid transparent;border-radius:6px;cursor:pointer;font-family:inherit;font-size:14px;color:#333;transition:background-color .2s,border-color .2s}.user-profile-trigger:hover{background-color:#f5f5f5;border-color:#e0e0e0}.user-profile-avatar{width:32px;height:32px;border-radius:50%;background-color:#3498db;color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;flex-shrink:0}.user-profile-name{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-profile-auth-badge{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;font-size:11px;font-weight:600;flex-shrink:0}.auth-badge-email{background-color:#e8f4fd;color:#3498db;font-size:12px}.auth-badge-google{background-color:#fce8e6;color:#ea4335;font-size:12px;font-weight:700}.auth-badge-apple{background-color:#f0f0f0;color:#000;font-size:12px}.user-profile-menu{position:absolute;top:calc(100% + 4px);right:0;min-width:220px;background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 12px #0000001a;z-index:100;overflow:hidden}.user-profile-menu-header{padding:12px 16px}.user-profile-menu-email{margin:0;font-size:14px;font-weight:500;color:#333;word-break:break-all}.user-profile-menu-name{margin:2px 0 0;font-size:13px;color:#666}.user-profile-menu-member-since{margin:6px 0 0;font-size:12px;color:#999}.user-profile-menu-divider{height:1px;background-color:#e0e0e0}.user-profile-logout-button{width:100%;padding:10px 16px;background:none;border:none;text-align:left;font-size:14px;font-family:inherit;color:#d32f2f;cursor:pointer;transition:background-color .15s}.user-profile-logout-button:hover{background-color:#fdecea}.error-toast{position:fixed;bottom:20px;right:20px;padding:12px 16px;border-radius:6px;display:flex;align-items:center;gap:12px;box-shadow:0 4px 12px #0003;z-index:1100;max-width:420px;animation:error-toast-slide-in .25s ease-out}.error-toast--error{background-color:#d32f2f;color:#fff}.error-toast--warning{background-color:#fff3cd;color:#856404;border:1px solid #ffc107}.error-toast__message{flex:1;font-size:14px;line-height:1.4}.error-toast__actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.error-toast__retry{padding:4px 12px;font-size:13px;font-weight:600;border-radius:4px;cursor:pointer;border:none;transition:background-color .15s}.error-toast--error .error-toast__retry{background-color:#fff3;color:#fff}.error-toast--error .error-toast__retry:hover{background-color:#ffffff59}.error-toast--warning .error-toast__retry{background-color:#ffc107;color:#333}.error-toast--warning .error-toast__retry:hover{background-color:#e0a800}.error-toast__dismiss{background:none;border:none;font-size:18px;cursor:pointer;padding:0 4px;line-height:1}.error-toast--error .error-toast__dismiss{color:#fff}.error-toast--warning .error-toast__dismiss{color:#856404}@keyframes error-toast-slide-in{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.share-button-wrapper{display:inline-flex;align-items:center;gap:6px;position:relative}.share-button{background:none;border:none;cursor:pointer;padding:4px;font-size:20px;line-height:1;transition:transform .15s ease,opacity .15s ease;font-family:inherit;color:#666}.share-button:hover:not(:disabled){transform:scale(1.15);color:#1a73e8}.share-button:disabled{opacity:.5;cursor:default}.share-button__toast{font-size:12px;color:#2e7d32;white-space:nowrap;animation:share-toast-fade 2.5s ease-out forwards}@keyframes share-toast-fade{0%{opacity:0}10%{opacity:1}80%{opacity:1}to{opacity:0}}.share-button__error{font-size:12px;color:#d32f2f;white-space:nowrap;animation:share-error-fade-in .2s ease-out}@keyframes share-error-fade-in{0%{opacity:0}to{opacity:1}}@media(max-width:480px){.share-button{font-size:18px;padding:3px}.share-button__toast,.share-button__error{font-size:11px}}.comment-section{display:flex;flex-direction:column;gap:16px;width:100%}.comment-section__form{display:flex;flex-direction:column;gap:8px}.comment-section__textarea{width:100%;min-height:80px;padding:10px;border:1px solid #ccc;border-radius:6px;font-family:inherit;font-size:14px;resize:vertical;transition:border-color .15s ease;box-sizing:border-box}.comment-section__textarea:focus{outline:none;border-color:#1a73e8}.comment-section__textarea--error{border-color:#d32f2f}.comment-section__footer{display:flex;justify-content:space-between;align-items:center}.comment-section__char-counter{font-size:12px;color:#666}.comment-section__char-counter--over{color:#d32f2f;font-weight:600}.comment-section__submit{padding:6px 16px;background-color:#1a73e8;color:#fff;border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:background-color .15s ease,opacity .15s ease}.comment-section__submit:hover:not(:disabled){background-color:#1557b0}.comment-section__submit:disabled{opacity:.5;cursor:default}.comment-section__error{font-size:12px;color:#d32f2f;animation:comment-error-fade-in .2s ease-out}@keyframes comment-error-fade-in{0%{opacity:0}to{opacity:1}}.comment-section__list{display:flex;flex-direction:column;gap:12px;list-style:none;margin:0;padding:0}.comment-section__item{padding:10px;background-color:#f9f9f9;border-radius:6px;border:1px solid #eee}.comment-section__item-text{font-size:14px;color:#333;margin:0 0 6px;white-space:pre-wrap;word-break:break-word}.comment-section__item-date{font-size:12px;color:#888}.comment-section__empty{font-size:14px;color:#888;text-align:center;padding:16px 0}@media(max-width:480px){.comment-section__textarea{min-height:60px;font-size:13px}.comment-section__submit{font-size:13px;padding:5px 12px}.comment-section__item-text{font-size:13px}}.playlist-create-form__overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.playlist-create-form{background-color:#fff;border-radius:8px;padding:24px;width:100%;max-width:420px;box-shadow:0 4px 24px #00000026;animation:playlist-form-fade-in .2s ease-out}@keyframes playlist-form-fade-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.playlist-create-form__title{margin:0 0 16px;font-size:18px;font-weight:600;color:#333}.playlist-create-form__form{display:flex;flex-direction:column;gap:8px}.playlist-create-form__label{font-size:14px;font-weight:500;color:#555}.playlist-create-form__input{width:100%;padding:10px;border:1px solid #ccc;border-radius:6px;font-family:inherit;font-size:14px;transition:border-color .15s ease;box-sizing:border-box}.playlist-create-form__input:focus{outline:none;border-color:#1a73e8}.playlist-create-form__input--error{border-color:#d32f2f}.playlist-create-form__footer{display:flex;justify-content:flex-end}.playlist-create-form__char-counter{font-size:12px;color:#666}.playlist-create-form__char-counter--over{color:#d32f2f;font-weight:600}.playlist-create-form__error{font-size:12px;color:#d32f2f;animation:playlist-error-fade-in .2s ease-out}@keyframes playlist-error-fade-in{0%{opacity:0}to{opacity:1}}.playlist-create-form__actions{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}.playlist-create-form__cancel{padding:6px 16px;background-color:transparent;color:#555;border:1px solid #ccc;border-radius:4px;font-size:14px;cursor:pointer;transition:background-color .15s ease}.playlist-create-form__cancel:hover{background-color:#f5f5f5}.playlist-create-form__submit{padding:6px 16px;background-color:#1a73e8;color:#fff;border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:background-color .15s ease,opacity .15s ease}.playlist-create-form__submit:hover:not(:disabled){background-color:#1557b0}.playlist-create-form__submit:disabled{opacity:.5;cursor:default}@media(max-width:480px){.playlist-create-form{margin:0 16px;padding:20px}.playlist-create-form__input{font-size:13px}.playlist-create-form__cancel,.playlist-create-form__submit{font-size:13px;padding:5px 12px}}.playlist-detail{width:100%;padding:20px;box-sizing:border-box}.playlist-detail__header{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.playlist-detail__title{font-size:24px;font-weight:600;color:#333;margin:0}.playlist-detail__actions{display:flex;gap:8px}.playlist-detail__back-button{background:none;border:none;color:#1a73e8;font-size:14px;cursor:pointer;padding:0;transition:color .15s ease}.playlist-detail__back-button:hover{color:#1557b0}.playlist-detail__delete-button{padding:6px 16px;background-color:#d32f2f;color:#fff;border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:background-color .15s ease,opacity .15s ease}.playlist-detail__delete-button:hover:not(:disabled){background-color:#b71c1c}.playlist-detail__delete-button:disabled{opacity:.5;cursor:default}.playlist-detail__inline-error{padding:8px 12px;margin-bottom:16px;background-color:#fdecea;color:#d32f2f;border-radius:4px;font-size:14px}.playlist-detail__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:16px}.playlist-detail__spinner{width:48px;height:48px;border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;animation:playlist-detail-spin 1s linear infinite}@keyframes playlist-detail-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.playlist-detail__loading p{font-size:16px;color:#666;margin:0}.playlist-detail__error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:16px;padding:20px}.playlist-detail__error-message{font-size:16px;color:#d32f2f;text-align:center;margin:0;max-width:500px}.playlist-detail__retry-button{padding:12px 24px;font-size:16px;font-weight:500;color:#fff;background-color:#3498db;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.playlist-detail__retry-button:hover{background-color:#2980b9}.playlist-detail__empty{display:flex;align-items:center;justify-content:center;min-height:200px}.playlist-detail__empty p{font-size:16px;color:#666;margin:0;text-align:center}.playlist-detail__list{display:flex;flex-direction:column;gap:12px}.playlist-detail__card{display:flex;align-items:center;gap:16px;padding:12px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}.playlist-detail__card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.playlist-detail__index{flex-shrink:0;width:28px;text-align:center;font-size:14px;font-weight:600;color:#999}.playlist-detail__thumbnail{position:relative;flex-shrink:0;width:120px;height:68px;border-radius:4px;overflow:hidden;background-color:#f0f0f0}.playlist-detail__thumbnail img{width:100%;height:100%;object-fit:cover}.playlist-detail__no-thumbnail{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#e0e0e0;font-size:24px}.playlist-detail__duration{position:absolute;bottom:4px;right:4px;padding:2px 6px;background-color:#000c;color:#fff;font-size:11px;font-weight:500;border-radius:3px}.playlist-detail__info{flex:1;min-width:0}.playlist-detail__video-title{margin:0;font-size:16px;font-weight:500;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.playlist-detail__remove-button{flex-shrink:0;padding:6px 12px;background-color:transparent;color:#d32f2f;border:1px solid #d32f2f;border-radius:4px;font-size:13px;cursor:pointer;transition:background-color .15s ease,opacity .15s ease}.playlist-detail__remove-button:hover:not(:disabled){background-color:#fdecea}.playlist-detail__remove-button:disabled{opacity:.5;cursor:default}@media(max-width:480px){.playlist-detail__thumbnail{width:80px;height:45px}.playlist-detail__index{width:20px;font-size:12px}.playlist-detail__remove-button{padding:4px 8px;font-size:12px}}.library-view{width:100%;padding:20px;box-sizing:border-box}.library-view__title{font-size:24px;font-weight:600;color:#333;margin:0 0 20px}.library-view__tabs{display:flex;gap:0;border-bottom:2px solid #e0e0e0;margin-bottom:24px}.library-view__tab{padding:12px 24px;font-size:15px;font-weight:500;color:#666;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:color .2s,border-color .2s}.library-view__tab:hover{color:#333}.library-view__tab--active{color:#007bff;border-bottom-color:#007bff}.library-view__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;gap:16px}.library-view__spinner{width:40px;height:40px;border:3px solid #f3f3f3;border-top:3px solid #3498db;border-radius:50%;animation:library-spin 1s linear infinite}@keyframes library-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.library-view__loading p{font-size:15px;color:#666;margin:0}.library-view__error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;gap:12px;padding:20px}.library-view__error p{font-size:15px;color:#d32f2f;text-align:center;margin:0}.library-view__retry-button{padding:10px 20px;font-size:14px;font-weight:500;color:#fff;background-color:#3498db;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.library-view__retry-button:hover{background-color:#2980b9}.library-view__empty{display:flex;align-items:center;justify-content:center;min-height:200px}.library-view__empty p{font-size:15px;color:#666;margin:0;text-align:center}.library-view__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.library-view__card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s}.library-view__card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.library-view__card--with-like{cursor:default;position:relative}.library-view__card-clickable{cursor:pointer}.library-view__thumbnail{position:relative;width:100%;aspect-ratio:16 / 9;background-color:#f0f0f0;overflow:hidden}.library-view__thumbnail img{width:100%;height:100%;object-fit:cover}.library-view__no-thumbnail{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#e0e0e0;font-size:32px}.library-view__duration{position:absolute;bottom:6px;right:6px;background:#000000bf;color:#fff;font-size:12px;padding:2px 6px;border-radius:3px}.library-view__card-info{padding:10px 12px}.library-view__card-title{margin:0;font-size:14px;font-weight:500;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.library-view__like-action{padding:0 12px 10px;display:flex;justify-content:flex-end}.library-view__unlike-button{background:none;border:none;font-size:20px;color:#e74c3c;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background-color .2s}.library-view__unlike-button:hover{background-color:#fde8e8}.library-view__playlists-header{display:flex;justify-content:flex-end;margin-bottom:16px}.library-view__create-playlist-button{padding:10px 20px;font-size:14px;font-weight:500;color:#fff;background-color:#007bff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.library-view__create-playlist-button:hover{background-color:#0056b3}.library-view__playlist-card{display:flex;align-items:center;gap:16px;padding:16px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:transform .2s,box-shadow .2s}.library-view__playlist-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.library-view__playlist-icon{font-size:32px;flex-shrink:0}.library-view__playlist-info{flex:1;min-width:0}.library-view__playlist-name{margin:0 0 4px;font-size:16px;font-weight:500;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.library-view__playlist-count{margin:0;font-size:13px;color:#666}@media(max-width:600px){.library-view__grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.library-view__tabs{overflow-x:auto}.library-view__tab{padding:10px 16px;font-size:14px;white-space:nowrap}}.subscription-plans{display:flex;flex-direction:column;gap:16px}.subscription-plans__title{font-size:18px;font-weight:600;color:#333;margin:0 0 4px}.subscription-plans__subtitle{font-size:14px;color:#666;margin:0 0 12px}.subscription-plans__cards{display:flex;gap:16px}.subscription-plans__card{flex:1;border:1px solid #e0e0e0;border-radius:8px;padding:20px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;transition:border-color .2s}.subscription-plans__card:hover{border-color:#3498db}.subscription-plans__card--recommended{border-color:#3498db;position:relative}.subscription-plans__badge{position:absolute;top:-10px;background-color:#3498db;color:#fff;font-size:11px;font-weight:600;padding:2px 10px;border-radius:10px}.subscription-plans__plan-name{font-size:16px;font-weight:600;color:#333;margin:0}.subscription-plans__price{font-size:24px;font-weight:700;color:#333;margin:0}.subscription-plans__price-period{font-size:14px;font-weight:400;color:#666}.subscription-plans__trial{font-size:13px;color:#666;margin:0}.subscription-plans__cta{margin-top:8px;padding:10px 24px;font-size:14px;font-weight:600;color:#fff;background-color:#3498db;border:none;border-radius:6px;cursor:pointer;width:100%;transition:background-color .2s}.subscription-plans__cta:hover:not(:disabled){background-color:#2980b9}.subscription-plans__cta:disabled{background-color:#bdc3c7;cursor:not-allowed}.subscription-plans__error{font-size:13px;color:#d32f2f;margin:0;text-align:center}@media(max-width:500px){.subscription-plans__cards{flex-direction:column}}.subscription-manager{display:flex;flex-direction:column;gap:12px}.subscription-manager__status{border:1px solid #e0e0e0;border-radius:8px;padding:20px}.subscription-manager__status-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.subscription-manager__status-badge{display:inline-block;padding:2px 10px;font-size:12px;font-weight:600;border-radius:10px;color:#fff;background-color:#27ae60}.subscription-manager__status-badge--canceled{background-color:#e67e22}.subscription-manager__plan-name{font-size:18px;font-weight:600;color:#333;margin:0}.subscription-manager__details{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.subscription-manager__detail{font-size:14px;color:#555;margin:0}.subscription-manager__detail strong{color:#333}.subscription-manager__cancel-notice{font-size:13px;color:#e67e22;background-color:#fef5e7;border-radius:6px;padding:10px 14px;margin:0 0 12px}.subscription-manager__manage-btn{padding:10px 24px;font-size:14px;font-weight:600;color:#fff;background-color:#3498db;border:none;border-radius:6px;cursor:pointer;align-self:flex-start;transition:background-color .2s}.subscription-manager__manage-btn:hover{background-color:#2980b9}.subscription-manager__loading{display:flex;align-items:center;gap:12px;padding:20px;color:#666;font-size:14px}.subscription-manager__spinner{width:24px;height:24px;border:3px solid #f3f3f3;border-top:3px solid #3498db;border-radius:50%;animation:sub-manager-spin 1s linear infinite}@keyframes sub-manager-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.settings-view{width:100%;max-width:600px;margin:0 auto;padding:20px;box-sizing:border-box}.settings-title{font-size:24px;font-weight:600;color:#333;margin:0 0 20px}.settings-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:16px}.settings-spinner{width:48px;height:48px;border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;animation:settings-spin 1s linear infinite}@keyframes settings-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.settings-loading p{font-size:16px;color:#666;margin:0}.settings-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:16px;padding:20px}.settings-error-message{font-size:16px;color:#d32f2f;text-align:center;margin:0;max-width:500px}.settings-retry-button{padding:12px 24px;font-size:16px;font-weight:500;color:#fff;background-color:#3498db;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.settings-retry-button:hover{background-color:#2980b9}.settings-fieldset{border:1px solid #e0e0e0;border-radius:8px;padding:16px;margin:0 0 16px}.settings-legend{font-size:16px;font-weight:500;color:#333;padding:0 8px}.settings-options{display:flex;gap:24px;margin-top:8px}.settings-option{display:flex;align-items:center;gap:8px;font-size:16px;color:#333;cursor:pointer}.settings-option input[type=radio]{accent-color:#3498db;width:18px;height:18px;cursor:pointer}.settings-saved{margin-top:12px;padding:8px 16px;font-size:14px;font-weight:500;color:#2e7d32;background-color:#e8f5e9;border-radius:4px;text-align:center}.settings-subscription-section{margin-top:8px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}#root{min-height:100vh}
