.environment-indicator{position:fixed;top:10px;right:10px;background:#fffffff2;backdrop-filter:blur(10px);border-radius:8px;border-left:4px solid #2196F3;box-shadow:0 2px 10px #0000001a;padding:8px 12px;z-index:1000;display:flex;align-items:center;gap:8px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;transition:all .3s ease;min-width:120px}.environment-indicator:hover{transform:translateY(-2px);box-shadow:0 4px 20px #00000026}.env-badge{background:#2196f3;color:#fff;padding:2px 6px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;min-width:60px;text-align:center}.version-badge{color:#666;font-size:10px;font-weight:500}.env-badge.env-development{background:#4caf50}.env-badge.env-uat{background:#ff9800}.env-badge.env-production{background:#f44336}.layout{min-height:100vh;display:flex;flex-direction:column}.header{background:#fff;box-shadow:0 2px 8px #0000001a;position:sticky;top:0;z-index:100}.header-content{display:flex;justify-content:space-between;align-items:center;padding:1rem 0}.logo{text-decoration:none;color:inherit}.logo h1{font-size:1.75rem;font-weight:700;color:#993386;margin:0}.tagline{font-size:.875rem;color:#666;margin-left:8px}.navigation{display:flex;gap:2rem;align-items:center}.nav-link{color:#333;text-decoration:none;font-weight:500;padding:.5rem 1rem;border-radius:6px;transition:all .2s ease;border:none;background:none;cursor:pointer;font-size:inherit;font-family:inherit}.nav-link:hover{background:#f5f5f5;color:#993386}.nav-link.active{background:#993386;color:#fff}.logout-btn{background:#dc3545!important;color:#fff!important}.logout-btn:hover{background:#c82333!important;color:#fff!important}.user-section{display:flex;align-items:center;gap:1rem}.user-info{font-size:.875rem;color:#666;font-weight:500}.main{flex:1;padding:2rem 0}.footer{background:#f8f9fa;border-top:1px solid #e9ecef;padding:2rem 0;margin-top:auto}.footer p{margin:0;color:#666;text-align:center;font-size:.75rem;font-weight:400}@media (max-width: 768px){.header-content{flex-direction:column;gap:1rem;text-align:center}.navigation{gap:1rem;flex-wrap:wrap;justify-content:center}.nav-link{padding:.375rem .75rem;font-size:.875rem}.main{padding:1rem 0}.logo h1{font-size:1.5rem}.tagline{display:block;margin-left:0;margin-top:4px}}.volume-control{position:relative;display:flex;align-items:center;gap:.5rem;z-index:100}.volume-button{background:#ffffffe6;border:2px solid rgba(142,68,173,.3);border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;backdrop-filter:blur(10px);box-shadow:0 4px 12px #0000001a}.volume-button:hover{background:#fff;border-color:#8e44ad99;transform:scale(1.05);box-shadow:0 6px 16px #00000026}.volume-button:active{transform:scale(.95)}.volume-icon{font-size:1.2rem;user-select:none}.volume-slider-container{position:absolute;left:50px;top:50%;transform:translateY(-50%);background:#fffffff2;backdrop-filter:blur(15px);border-radius:25px;padding:.75rem 1rem;display:flex;align-items:center;gap:.75rem;box-shadow:0 8px 24px #00000026;border:1px solid rgba(142,68,173,.2);opacity:0;visibility:hidden;transition:all .3s ease;white-space:nowrap;min-width:150px}.volume-slider-container.visible{opacity:1;visibility:visible}.volume-slider{width:80px;height:4px;background:linear-gradient(to right,#e0e0e0 0% 100%);border-radius:2px;outline:none;cursor:pointer;-webkit-appearance:none;appearance:none}.volume-slider::-webkit-slider-track{width:100%;height:4px;background:linear-gradient(to right,#8e44ad 0%,#8e44ad var(--volume-percentage, 100%),#e0e0e0 var(--volume-percentage, 100%),#e0e0e0 100%);border-radius:2px}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:#8e44ad;border-radius:50%;cursor:pointer;box-shadow:0 2px 6px #8e44ad4d;transition:all .2s ease}.volume-slider::-webkit-slider-thumb:hover{background:#9b59b6;transform:scale(1.2);box-shadow:0 4px 8px #8e44ad66}.volume-slider::-moz-range-track{width:100%;height:4px;background:#e0e0e0;border-radius:2px;border:none}.volume-slider::-moz-range-thumb{width:16px;height:16px;background:#8e44ad;border-radius:50%;cursor:pointer;border:none;box-shadow:0 2px 6px #8e44ad4d;transition:all .2s ease}.volume-slider::-moz-range-thumb:hover{background:#9b59b6;transform:scale(1.2);box-shadow:0 4px 8px #8e44ad66}.volume-percentage{font-size:.85rem;font-weight:600;color:#8e44ad;min-width:35px;text-align:center}.volume-control.top-right{position:fixed;top:20px;right:20px;z-index:1000}.volume-control.header{position:relative;display:inline-flex}@media (max-width: 768px){.volume-control.top-right{top:15px;right:15px}.volume-button{width:40px;height:40px}.volume-icon{font-size:1.1rem}.volume-slider-container{left:45px;min-width:130px;padding:.6rem .8rem}.volume-slider{width:70px}.volume-percentage{font-size:.8rem;min-width:30px}}@media (hover: none) and (pointer: coarse){.volume-control:hover .volume-slider-container,.volume-control:focus-within .volume-slider-container{opacity:1;visibility:visible}.volume-button:active{background:#fff;border-color:#8e44adcc}.volume-slider::-webkit-slider-thumb{width:20px;height:20px}.volume-slider::-moz-range-thumb{width:20px;height:20px}}@media (prefers-color-scheme: dark){.volume-button{background:#2a2a2ae6;border-color:#ffffff4d;color:#fff}.volume-button:hover{background:#2a2a2a;border-color:#fff9}.volume-slider-container{background:#2a2a2af2;border-color:#fff3}.volume-slider::-webkit-slider-track{background:linear-gradient(to right,#9b59b6 0%,#9b59b6 var(--volume-percentage, 100%),#555 var(--volume-percentage, 100%),#555 100%)}.volume-slider::-moz-range-track{background:#555}.volume-percentage{color:#9b59b6}}.volume-control:focus-within .volume-slider-container{opacity:1;visibility:visible}.volume-button:focus{outline:2px solid #8e44ad;outline-offset:2px}.volume-slider:focus{outline:2px solid #8e44ad;outline-offset:2px}.star-rating{display:flex;flex-direction:column;align-items:center;gap:8px;margin:10px 0}.stars-container{display:flex;gap:2px}.star{background:none;border:none;cursor:pointer;color:#ddd;transition:color .2s ease,transform .1s ease;padding:0;margin:0;font-family:inherit;line-height:1}.star:hover{transform:scale(1.1)}.star:focus{outline:2px solid #007bff;outline-offset:2px;border-radius:2px}.star:disabled{cursor:not-allowed;transform:none}.star-small{font-size:16px}.star-medium{font-size:20px}.star-large{font-size:24px}.star-empty{color:#ddd}.star-filled{color:#ffc107}.star-partial{background:linear-gradient(90deg,#ffc107 50%,#ddd 50%);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;color:#ffc107}.star-rating.interactive .star:hover{color:#ffb300}.star-rating.readonly .star{cursor:default}.star-rating.readonly .star:hover{transform:none}.rating-info{display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center}.rating-text{font-size:14px;color:#666;font-weight:500}.hover-text{font-size:12px;color:#999;font-style:italic}.rating-loading{font-size:12px;color:#007bff;font-style:italic}@media (max-width: 768px){.star-rating{gap:6px}.stars-container{gap:1px}.star-small{font-size:14px}.star-medium{font-size:18px}.star-large{font-size:22px}.rating-text{font-size:13px}.hover-text{font-size:11px}}@media (prefers-color-scheme: dark){.star-empty{color:#555}.rating-text{color:#ccc}.hover-text{color:#999}.rating-loading{color:#66b3ff}}.star-rating.interactive .star:focus-visible{outline:2px solid #007bff;outline-offset:2px;border-radius:2px}.star-rating.submitting .star-filled{animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.content-filter{position:fixed;top:70px;right:10px;background:#fffffff2;backdrop-filter:blur(10px);border-radius:6px;border-left:3px solid #2196F3;box-shadow:0 2px 8px #0000001a;padding:8px 10px;z-index:999;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;transition:all .3s ease;max-width:160px;white-space:nowrap}.content-filter:hover{transform:translateY(-2px);box-shadow:0 4px 20px #00000026}.filter-label{font-size:10px;font-weight:600;color:#666;margin-bottom:6px;text-transform:uppercase;letter-spacing:.3px}.filter-toggles{display:flex;flex-direction:column;gap:4px}.filter-toggle{display:flex;align-items:center;gap:6px;cursor:pointer;padding:2px 0;transition:opacity .2s ease}.filter-toggle:hover{opacity:.7}.filter-toggle input[type=checkbox]{width:14px;height:14px;accent-color:#2196F3;cursor:pointer}.toggle-text{font-size:11px;font-weight:500;color:#333;user-select:none}@media (max-width: 768px){.content-filter{position:static;margin:10px;width:auto;min-width:unset}.filter-toggles{flex-direction:row;flex-wrap:wrap;gap:12px}}.user-home-page{display:flex;align-items:center;justify-content:center;background:#f5f5f5;padding:15px;min-height:70vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.main-container{max-width:1200px;width:100%;text-align:center}.brand-header{margin-bottom:30px}.brand-header h1{font-size:2.8em;font-weight:700;color:#333;margin:0 0 8px;letter-spacing:-1px}.brand-header .subtitle{font-size:1em;color:#007acc;margin:0;font-weight:500}.welcome-section{display:flex;flex-direction:column;align-items:center;gap:30px}.joke-display,.content-display{display:flex;gap:40px;align-items:flex-start;background:#fff;border-radius:20px;padding:40px;box-shadow:0 10px 30px #0000001a;max-width:1000px;margin:0 auto}.avatar-section{flex-shrink:0}.conversation-section{flex:1;display:flex;flex-direction:column;gap:20px;min-height:200px}.character-frame{position:relative;display:inline-block;border:4px solid #007acc;border-radius:20px;padding:20px;background:#fff;box-shadow:0 8px 25px #0000001a;overflow:hidden;width:min(500px,40vw);height:min(350px,28vw);flex-shrink:0}.character-frame.small{padding:15px;width:min(450px,36vw);height:min(320px,25vw)}.mike-avatar{width:100%;height:100%;object-fit:cover;border-radius:15px;display:block}.video-overlay{position:absolute;inset:20px;border-radius:15px;overflow:hidden;z-index:10;background:#0000000d;display:flex;align-items:center;justify-content:center}.character-frame.small .video-overlay{inset:15px}.overlay-video{width:100%;height:100%;object-fit:cover;border-radius:15px;border:none;outline:none}.welcome-message{max-width:600px}.welcome-message p{font-size:1.5em;color:#666;margin:0;font-style:italic;line-height:1.4}.tell-joke-btn{background:#8e44ad;color:#fff;border:none;padding:20px 40px;border-radius:50px;font-size:1.4em;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #8e44ad4d;min-width:250px}.tell-joke-btn:hover:not(:disabled){background:#9b59b6;transform:translateY(-2px);box-shadow:0 6px 20px #8e44ad66}.tell-joke-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.joke-bubbles{display:flex;flex-direction:column;gap:20px;flex:1}.dots-container{display:flex;justify-content:flex-start;margin:10px 0;min-height:40px;align-items:center;padding-left:25px}.animated-dots{display:flex;gap:8px;align-items:center}.animated-dots span{font-size:2.5em;color:#8e44ad;font-weight:700;opacity:0;animation:dotBounce 1.5s infinite}.animated-dots span:nth-child(1){animation-delay:0s}.animated-dots span:nth-child(2){animation-delay:.3s}.animated-dots span:nth-child(3){animation-delay:.6s}.animated-dots span:nth-child(4){animation-delay:.9s}.animated-dots span:nth-child(5){animation-delay:1.2s}@keyframes dotBounce{0%,80%,to{opacity:0;transform:scale(.8)}40%{opacity:1;transform:scale(1.2)}}.setup-bubble,.punchline-bubble{background:#f8f9fa;border-radius:30px;padding:25px;box-shadow:0 4px 20px #0000001a;position:relative;margin-left:20px;max-width:500px}.setup-bubble:before,.punchline-bubble:before{content:"";position:absolute;left:-25px;top:60%;transform:translateY(-50%);width:18px;height:18px;background:inherit;border-radius:50%;border:inherit;z-index:1}.setup-bubble:after,.punchline-bubble:after{content:"";position:absolute;left:-40px;top:70%;transform:translateY(-50%);width:12px;height:12px;background:inherit;border-radius:50%;border:inherit;z-index:2}.setup-bubble,.punchline-bubble{position:relative}.setup-bubble:hover:before,.punchline-bubble:hover:before{animation:thoughtBubble 2s ease-in-out infinite}.setup-bubble:hover:after,.punchline-bubble:hover:after{animation:thoughtBubble 2s ease-in-out infinite .2s}@keyframes thoughtBubble{0%,to{transform:translateY(-50%) scale(1);opacity:1}50%{transform:translateY(-50%) scale(1.1);opacity:.8}}.setup-bubble,.punchline-bubble{box-shadow:0 4px 20px #0000001a,-50px calc(60% + 15px) 0 -3px var(--bubble-bg, #f8f9fa),-50px calc(60% + 15px) 0 -1px var(--bubble-border, #007acc)}.setup-bubble{--bubble-bg: #f8f9fa;--bubble-border: #007acc}.punchline-bubble{--bubble-bg: #f8f6ff;--bubble-border: #8e44ad}.punchline-bubble{background:#f8f6ff;border:2px solid #8e44ad}.setup-bubble{border:2px solid #007acc}.setup-bubble p,.punchline-bubble p{font-size:1.1em;line-height:1.5;margin:0;color:#333;text-align:left}.joke-actions{display:flex;justify-content:center;margin-top:30px}.next-joke-btn{background:#007acc;color:#fff;border:none;padding:15px 30px;border-radius:25px;font-size:1.1em;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:200px;box-shadow:0 4px 15px #007acc4d}.next-joke-btn:hover:not(:disabled){background:#0056b3;transform:translateY(-2px);box-shadow:0 6px 20px #007acc66}.next-joke-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.content-actions{display:flex;justify-content:center;align-items:center;gap:15px;margin-top:30px;flex-wrap:wrap}.next-content-btn{background:#007acc;color:#fff;border:none;padding:15px 30px;border-radius:25px;font-size:1.1em;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:200px;box-shadow:0 4px 15px #007acc4d}.next-content-btn:hover:not(:disabled){background:#0056b3;transform:translateY(-2px);box-shadow:0 6px 20px #007acc66}.next-content-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.repeat-joke-btn{background:#8e44ad;color:#fff;border:none;padding:15px 30px;border-radius:25px;font-size:1.1em;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:180px;box-shadow:0 4px 15px #8e44ad4d}.repeat-joke-btn:hover:not(:disabled){background:#9b59b6;transform:translateY(-2px);box-shadow:0 6px 20px #8e44ad66}.repeat-joke-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.meme-display{display:flex;flex-direction:column;gap:20px;flex:1;align-items:center}.meme-image-container{max-width:100%;max-height:600px;overflow:hidden;border-radius:15px;box-shadow:0 8px 25px #0000001a;background:#fff;padding:10px}.meme-image{width:100%;height:auto;max-height:580px;object-fit:contain;border-radius:10px;display:block}.meme-title{background:#f8f9fa;border-radius:15px;padding:15px 25px;border-left:5px solid #8e44ad;box-shadow:0 2px 10px #0000000d;max-width:500px;text-align:center}.meme-title p{font-size:1.2em;line-height:1.5;margin:0;color:#333;font-weight:600}@media (max-width: 480px){.brand-header h1{font-size:2.2em}.welcome-message p{font-size:1.3em}.character-frame{width:380px;height:260px;padding:15px}.character-frame.small{width:340px;height:240px;padding:12px}.tell-joke-btn{font-size:1.2em;padding:18px 35px}.joke-display,.content-display{flex-direction:column;padding:25px;align-items:center;gap:30px}.conversation-section{width:100%}.meme-image-container{max-height:400px}.meme-image{max-height:380px}.meme-title{max-width:100%}.meme-title p{font-size:1.1em}}.voice-controls{margin-top:1rem;padding-top:1rem;border-top:1px solid #e0e0e0;display:flex;align-items:center;gap:1rem;justify-content:center}.voice-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:25px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 8px #667eea4d;display:flex;align-items:center;gap:.5rem}.voice-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 12px #667eea66;background:linear-gradient(135deg,#764ba2,#667eea)}.voice-btn:disabled{background:#6c757d;cursor:not-allowed;transform:none;box-shadow:none}.voice-btn.stop{background:linear-gradient(135deg,#ff6b6b,#ee5a52);box-shadow:0 4px 8px #ff6b6b4d}.voice-btn.stop:hover{background:linear-gradient(135deg,#ee5a52,#ff6b6b);box-shadow:0 6px 12px #ff6b6b66}.voice-error{color:#dc3545;font-size:.9rem;font-style:italic}.punchline-bubble .voice-controls{background:#ffffff1a;border-radius:15px;padding:1rem;margin-top:1rem}.voice-btn.stop{animation:pulse-red 2s infinite}@keyframes pulse-red{0%{box-shadow:0 4px 8px #ff6b6b4d}50%{box-shadow:0 6px 16px #ff6b6b99}to{box-shadow:0 4px 8px #ff6b6b4d}}.quip-bubble{background:linear-gradient(135deg,#f39c12,#e67e22);border-radius:20px 20px 20px 5px;padding:20px;margin:15px 0;box-shadow:0 4px 15px #f39c124d;position:relative;border-left:4px solid #d35400;animation:quipSlideIn .5s ease-out;max-width:500px}.quip-bubble.intro-quip{background:linear-gradient(135deg,#3498db,#2980b9);border-left-color:#2471a3;box-shadow:0 4px 15px #3498db4d}.quip-bubble.outro-quip{background:linear-gradient(135deg,#9b59b6,#8e44ad);border-left-color:#7d3c98;box-shadow:0 4px 15px #9b59b64d}.quip-bubble p{font-size:1.1em;line-height:1.5;margin:0;color:#fff;font-weight:500;font-style:italic;text-align:left}.quip-indicator{position:absolute;top:-8px;right:15px;font-size:1.5em;background:#fff;border-radius:50%;width:35px;height:35px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0003}@keyframes quipSlideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.meme-display{display:flex!important;flex-direction:column!important;align-items:center!important;gap:20px!important;width:100%!important;margin:20px 0!important;padding:20px!important;background:#ffffffe6!important;border-radius:20px!important;box-shadow:0 4px 20px #0000001a!important;border:2px solid #007acc!important;position:relative!important;clear:both!important}.meme-image-container{display:block!important;width:100%!important;max-width:600px!important;margin:0 auto!important;text-align:center!important;border-radius:15px!important;box-shadow:0 8px 25px #00000026!important;overflow:hidden!important;background:#fff!important}.meme-image{width:auto!important;height:auto!important;max-width:100%!important;max-height:500px!important;min-height:200px!important;object-fit:contain!important;border-radius:15px!important;border:3px solid #007acc!important;background:#fff!important;display:block!important;margin:0 auto!important;aspect-ratio:auto!important;vertical-align:top!important}.meme-title{text-align:center!important;margin:15px auto 0!important;padding:10px 20px!important;background:#007acc1a!important;border-radius:10px!important;border-left:4px solid #007acc!important;width:fit-content!important;max-width:100%!important}.meme-title p{font-size:1.2em!important;font-weight:600!important;color:#333!important;margin:0!important;line-height:1.4!important}.meme-rating{margin:20px auto 0!important;display:flex!important;flex-direction:column!important;align-items:center!important;gap:10px!important;background:#fffffff2!important;padding:20px 30px!important;border-radius:15px!important;box-shadow:0 4px 15px #0000001a!important;border:1px solid #e0e0e0!important;width:fit-content!important;clear:both!important;position:relative!important}@media (max-width: 768px){.meme-display{padding:15px;margin:15px 0}.meme-image{max-width:90vw;min-width:250px;max-height:400px}.meme-rating{padding:15px 20px;margin-top:15px}.meme-title p{font-size:1.1em}}@media (max-width: 480px){.meme-image{min-width:200px;max-height:350px}.meme-display{padding:10px}}@media (max-width: 480px){.user-home-page{padding:10px}.brand-header h1{font-size:2em}.content-display{flex-direction:column;gap:20px;padding:20px}.character-frame.small{width:min(250px,90vw);height:min(180px,60vw);align-self:center}.joke-bubbles,.meme-display{margin-left:0}.setup-bubble,.punchline-bubble{max-width:100%}.meme-image-container{max-width:100%;max-height:500px}.meme-image{max-width:100%;max-height:480px}.next-content-btn,.repeat-joke-btn{font-size:.9rem;padding:10px 16px}}.video-display{display:flex;flex-direction:column;align-items:center;gap:20px;margin-left:20px;max-width:600px}.video-container{width:100%;background:#000;border-radius:12px;overflow:hidden;box-shadow:0 8px 24px #0003}.video-player{width:100%;height:auto;max-height:400px;border:none;outline:none}.video-title{text-align:center;background:#f8f9fa;border-radius:20px;padding:15px 25px;border-left:5px solid #007acc;max-width:100%}.video-title p{margin:0;font-size:1.1rem;color:#333;font-weight:500;line-height:1.4}.video-fallback{margin-top:20px;padding:20px;background:#f8f9fa;border-radius:12px;border-left:4px solid #007acc}.video-fallback .setup-bubble,.video-fallback .punchline-bubble{background:#fff;margin:10px 0;padding:15px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.video-fallback .setup-bubble p,.video-fallback .punchline-bubble p{margin:0;font-size:.95rem;color:#555;line-height:1.4}@media (max-width: 480px){.video-display{margin-left:0;max-width:100%}.video-container{border-radius:8px}.video-title{padding:12px 20px}.video-title p{font-size:1rem}}.joke-rating{margin-top:20px;padding:15px;background:#fffffff2;border-radius:15px;box-shadow:0 4px 12px #0000001a;text-align:center}.meme-rating{margin-top:15px;padding:15px;background:#fffffff2;border-radius:15px;box-shadow:0 4px 12px #0000001a;text-align:center}.meme-display{display:flex;flex-direction:column;align-items:center;gap:20px;width:100%;margin:20px 0;padding:20px;background:#fffc;border-radius:20px;box-shadow:0 4px 20px #0000000d}.meme-image-container{display:flex;justify-content:center;align-items:center;width:100%;max-width:600px}.meme-image{max-width:100%;width:auto;height:auto;min-width:300px;max-height:500px;border-radius:15px;box-shadow:0 8px 25px #0000001a;object-fit:contain;border:2px solid #007acc}.meme-title{text-align:center;margin-top:10px}.meme-title p{font-size:1.3em;font-weight:600;color:#333;margin:0;padding:0 20px;line-height:1.4}.meme-rating{margin-top:20px;display:flex;flex-direction:column;align-items:center;gap:10px;background:#ffffffe6;padding:15px 25px;border-radius:15px;box-shadow:0 4px 15px #0000001a;border:1px solid #e0e0e0}@media (max-width: 768px){.joke-rating,.meme-rating{margin-top:15px;padding:12px;border-radius:12px}.meme-image{max-width:90vw;width:auto;height:auto;min-width:250px;max-height:400px}.meme-title p{font-size:1.1em;padding:0 15px}.meme-rating{padding:12px 20px;margin-top:15px}}.sso-login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.sso-login-card{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003;padding:40px;max-width:400px;width:100%;text-align:center}.sso-login-card h1{color:#333;margin-bottom:10px;font-size:24px}.sso-login-card h2{color:#666;margin-bottom:30px;font-size:18px;font-weight:400}.sso-login-card p{color:#666;margin-bottom:30px;line-height:1.5}.sso-btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;border-radius:8px;border:none;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none;margin:10px;min-width:200px}.sso-btn:disabled{opacity:.6;cursor:not-allowed}.sso-btn-azure{background:#0078d4;color:#fff}.sso-btn-azure:hover:not(:disabled){background:#106ebe;transform:translateY(-1px)}.sso-btn-primary{background:#667eea;color:#fff}.sso-btn-primary:hover:not(:disabled){background:#5a6fd8;transform:translateY(-1px)}.sso-btn-icon{margin-right:8px;font-size:18px}.sso-error{background:#fee;border:1px solid #fcc;border-radius:6px;padding:12px;margin-bottom:20px;color:#c33}.sso-info{margin-top:20px;padding-top:20px;border-top:1px solid #eee}.sso-info p{margin:0;color:#999;font-size:12px}.user-info{background:#f8f9fa;border-radius:6px;padding:20px;margin:20px 0;text-align:left}.user-info p{margin:8px 0;color:#333}.backup-login-section{margin-top:30px;padding-top:20px;border-top:1px solid #eee}.backup-toggle-btn{background:#dc3545;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:12px;cursor:pointer;transition:all .2s}.backup-toggle-btn:hover{background:#c82333}.backup-login-form{margin-top:15px;padding:20px;background:#fff8dc;border:1px solid #ffc107;border-radius:6px}.backup-login-form h3{margin:0 0 10px;color:#856404;font-size:16px}.backup-input{width:100%;padding:10px;margin:8px 0;border:1px solid #ddd;border-radius:4px;font-size:14px;box-sizing:border-box}.sso-btn-emergency{background:#dc3545;color:#fff;margin-top:10px}.sso-btn-emergency:hover:not(:disabled){background:#c82333}.content-player{background:#fff;border-radius:var(--border-radius);box-shadow:var(--shadow);padding:20px;margin:15px 0;transition:box-shadow .3s ease}.content-player:hover{box-shadow:var(--shadow-hover)}.content-player-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:15px}.mode-selector{display:flex;gap:8px;background-color:var(--background-light);padding:4px;border-radius:var(--border-radius)}.mode-button{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 12px;border:none;border-radius:calc(var(--border-radius) - 2px);background:transparent;cursor:pointer;transition:all .3s ease;position:relative;min-width:60px}.mode-button.available{color:var(--text-primary)}.mode-button.available:hover{background-color:#fff;box-shadow:0 2px 4px #0000001a}.mode-button.active{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;box-shadow:0 2px 8px #667eea4d}.mode-button.unavailable{color:var(--text-secondary);cursor:not-allowed;opacity:.6}.mode-icon{font-size:1.2em;line-height:1}.mode-label{font-size:.85em;font-weight:600;text-transform:capitalize}.unavailable-indicator{position:absolute;top:-2px;right:-2px;font-size:.7em;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.availability-status{display:flex;align-items:center;gap:8px;font-size:.9em}.status-label{color:var(--text-secondary);font-weight:500}.status-indicator{padding:2px 8px;border-radius:12px;font-size:.8em;font-weight:600}.status-indicator.available{background-color:var(--success-color);color:#fff}.status-indicator.unavailable{background-color:var(--border-color);color:var(--text-secondary)}.content-area{position:relative;min-height:120px;margin-bottom:15px}.error-message{background-color:#f8d7da;color:#721c24;padding:12px;border-radius:var(--border-radius);border:1px solid #f5c6cb;margin-bottom:15px;display:flex;align-items:center;gap:10px}.error-icon{font-size:1.1em}.error-message button{margin-left:auto;background:none;border:none;color:#721c24;text-decoration:underline;cursor:pointer}.text-content{text-align:center;padding:20px}.setup{margin-bottom:20px}.setup p{font-size:1.2em;line-height:1.6;color:var(--text-primary);margin:0}.reveal-button{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;border:none;padding:12px 24px;border-radius:var(--border-radius);font-size:1em;font-weight:600;cursor:pointer;transition:all .3s ease;margin-bottom:20px}.reveal-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}.punchline{animation:fadeIn .5s ease-in;margin-bottom:20px}.punchline p{font-size:1.3em;font-weight:600;color:var(--primary-color);line-height:1.5;margin:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.joke-meta{margin-top:20px}.categories{display:flex;justify-content:center;gap:8px;flex-wrap:wrap}.category-tag{background-color:var(--primary-color);color:#fff;padding:4px 12px;border-radius:12px;font-size:.85em;font-weight:500}.voice-content,.video-content{display:flex;justify-content:center;align-items:center;padding:20px}.voice-content audio,.video-content video{width:100%;max-width:500px;border-radius:var(--border-radius)}.voice-placeholder,.video-placeholder{display:flex;justify-content:center;align-items:center;padding:40px 20px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:var(--border-radius);text-align:center}.placeholder-content{max-width:400px}.placeholder-icon{font-size:3em;margin-bottom:15px;display:block}.placeholder-content h3{color:var(--primary-color);margin:0 0 10px;font-size:1.3em}.placeholder-content p{color:var(--text-secondary);margin:0 0 20px;line-height:1.5}.fallback-text{background:#fff;padding:15px;border-radius:var(--border-radius);border-left:4px solid var(--primary-color);text-align:left;font-size:.9em;line-height:1.6}.loading-overlay{position:absolute;inset:0;background:#ffffffe6;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:15px;border-radius:var(--border-radius)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top:3px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.content-info{display:flex;justify-content:space-between;align-items:center;padding-top:15px;border-top:1px solid var(--border-color);font-size:.9em;color:var(--text-secondary);flex-wrap:wrap;gap:10px}.current-mode strong{color:var(--primary-color);text-transform:capitalize}@media (max-width: 768px){.content-player-header{flex-direction:column;align-items:stretch}.mode-selector{justify-content:center}.availability-status{justify-content:center;flex-wrap:wrap}.mode-button{flex:1;min-width:auto}.content-info{flex-direction:column;text-align:center;gap:5px}.text-content .setup p{font-size:1.1em}.text-content .punchline p{font-size:1.2em}}@media (max-width: 480px){.content-player{padding:15px;margin:10px 0}.mode-selector{gap:4px}.mode-button{padding:6px 8px;min-width:50px}.mode-icon{font-size:1em}.mode-label{font-size:.8em}}.meme-content{text-align:center}.meme-description{font-size:1.3em;font-weight:600;color:var(--text-primary);margin-bottom:20px;line-height:1.4}.meme-image{margin:20px 0;display:flex;justify-content:center}.meme-image img{max-width:100%;max-height:400px;border-radius:var(--border-radius);box-shadow:var(--shadow);object-fit:contain}.quip-content{text-align:center}.quip-text{font-size:1.2em;font-style:italic;color:var(--accent-color);margin-bottom:15px;line-height:1.4}.quip-text p{margin:0;padding:15px;background:var(--background-light);border-radius:var(--border-radius);border-left:4px solid var(--accent-color)}.joke-browser-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:20px}.page-header{text-align:center;margin-bottom:30px;padding:20px;background:#fff;border-radius:var(--border-radius);box-shadow:var(--shadow)}.page-header h1{color:var(--primary-color);margin:0 0 10px;font-size:2.5em;font-weight:700}.page-header p{color:var(--text-secondary);margin:0;font-size:1.1em;line-height:1.5}.demo-mode-banner{background:linear-gradient(135deg,#ffeaa7,#fab1a0);color:#2d3436;padding:10px 15px;border-radius:var(--border-radius);margin-top:15px;display:flex;align-items:center;justify-content:center;gap:15px;font-weight:600}.demo-mode-banner button{background:#fff;color:var(--primary-color);border:none;padding:5px 12px;border-radius:15px;font-size:.9em;font-weight:600;cursor:pointer;transition:all .3s ease}.demo-mode-banner button:hover{background:var(--primary-color);color:#fff}.content-layout{display:grid;grid-template-columns:280px 1fr;gap:30px;align-items:start}.filters-sidebar{background:#fff;border-radius:var(--border-radius);box-shadow:var(--shadow);padding:20px;position:sticky;top:20px;max-height:calc(100vh - 40px);overflow-y:auto}.filter-group{margin-bottom:25px}.filter-group:last-child{margin-bottom:0}.filter-group h3{color:var(--primary-color);margin:0 0 15px;font-size:1.1em;font-weight:600;padding-bottom:8px;border-bottom:2px solid var(--border-color)}.filter-checkbox,.mode-radio{display:flex;align-items:center;gap:8px;margin-bottom:8px;cursor:pointer;padding:5px;border-radius:4px;transition:background-color .3s ease}.filter-checkbox:hover,.mode-radio:hover{background-color:var(--background-light)}.filter-checkbox input,.mode-radio input{margin:0;cursor:pointer}.category-name,.mode-name{font-size:.95em;color:var(--text-primary);text-transform:capitalize;font-weight:500}.mode-selector-filters{display:flex;flex-direction:column;gap:8px}.jokes-content{display:flex;flex-direction:column;gap:20px}.selected-joke-player{background:#fff;border-radius:var(--border-radius);box-shadow:var(--shadow-hover);border:2px solid var(--primary-color);overflow:hidden;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.player-header{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;padding:15px 20px;display:flex;justify-content:space-between;align-items:center}.player-header h2{margin:0;font-size:1.3em;font-weight:600}.close-player{background:none;border:none;color:#fff;font-size:1.5em;cursor:pointer;padding:5px;border-radius:50%;transition:background-color .3s ease;line-height:1}.close-player:hover{background:#fff3}.jokes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.joke-card{background:#fff;border-radius:var(--border-radius);box-shadow:var(--shadow);padding:20px;cursor:pointer;transition:all .3s ease;border:2px solid transparent;position:relative;overflow:hidden}.joke-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.joke-card.selected{border-color:var(--primary-color);box-shadow:var(--shadow-hover);background:linear-gradient(135deg,#fff,#f8f9fa)}.joke-card.selected:before{content:"▶️";position:absolute;top:10px;right:10px;font-size:1.2em;animation:pulse 2s infinite}.joke-content{margin-bottom:15px}.setup{font-size:1.1em;font-weight:600;color:var(--text-primary);line-height:1.5;margin-bottom:10px}.punchline-preview{font-size:.95em;color:var(--text-secondary);line-height:1.4;font-style:italic}.joke-meta{margin-bottom:15px}.categories{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.category-tag{background:var(--primary-color);color:#fff;padding:3px 8px;border-radius:12px;font-size:.8em;font-weight:500;text-transform:capitalize}.category-tag.more{background:var(--text-secondary)}.joke-stats{display:flex;gap:12px;font-size:.9em;color:var(--text-secondary)}.joke-stats span{display:flex;align-items:center;gap:3px}.joke-actions{display:flex;gap:8px;justify-content:flex-end}.action-button{background:none;border:1px solid var(--border-color);padding:6px 12px;border-radius:var(--border-radius);cursor:pointer;transition:all .3s ease;font-size:.9em;font-weight:500}.action-button.play{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;border:none}.action-button.play:hover{transform:scale(1.05);box-shadow:var(--shadow)}.action-button:not(.play):hover{background:var(--background-light);border-color:var(--primary-color)}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;background:#fff;border-radius:var(--border-radius);box-shadow:var(--shadow)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top:3px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:15px}.error{background:#f8d7da;color:#721c24;padding:20px;border-radius:var(--border-radius);border:1px solid #f5c6cb;text-align:center}.error button{background:#721c24;color:#fff;border:none;padding:8px 16px;border-radius:var(--border-radius);margin:5px;cursor:pointer;font-weight:500}.error button:hover{background:#5a1a1a}.no-jokes{text-align:center;padding:60px 20px;background:#fff;border-radius:var(--border-radius);box-shadow:var(--shadow)}.no-jokes p{color:var(--text-secondary);font-size:1.1em;margin-bottom:20px}.no-jokes button{background:var(--primary-color);color:#fff;border:none;padding:10px 20px;border-radius:var(--border-radius);font-weight:600;cursor:pointer;transition:all .3s ease}.no-jokes button:hover{background:var(--secondary-color);transform:translateY(-1px)}@media (max-width: 1024px){.content-layout{grid-template-columns:250px 1fr;gap:20px}.jokes-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media (max-width: 768px){.joke-browser-page{padding:15px}.content-layout{grid-template-columns:1fr;gap:15px}.filters-sidebar{position:static;max-height:none;order:2}.jokes-content{order:1}.jokes-grid{grid-template-columns:1fr;gap:15px}.page-header h1{font-size:2em}.filter-group{margin-bottom:20px}.demo-mode-banner{flex-direction:column;gap:10px;text-align:center}}@media (max-width: 480px){.joke-browser-page{padding:10px}.page-header{padding:15px}.page-header h1{font-size:1.8em}.joke-card,.filters-sidebar{padding:15px}.player-header{padding:12px 15px}.joke-actions{flex-wrap:wrap;justify-content:center}.action-button{font-size:.8em;padding:5px 10px}}.user-rating{display:flex;align-items:center;justify-content:center;margin-bottom:8px}.rating-loading{font-size:.8em;color:#666;font-style:italic}.player-rating{margin-top:20px;padding:20px;background:#fff;border-radius:var(--border-radius);box-shadow:0 2px 8px #0000001a;text-align:center}.player-rating h4{margin:0 0 15px;color:var(--primary-color);font-size:1.1em;font-weight:600}@media (max-width: 768px){.player-rating{margin-top:15px;padding:15px}.player-rating h4{font-size:1em;margin-bottom:12px}}.voice-generator{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:20px;margin:20px 0;max-width:600px}.voice-generator h3{margin:0 0 20px;color:#333;font-size:1.5rem}.voice-generator h4{margin:15px 0 10px;color:#555;font-size:1.1rem}.voice-status{margin-bottom:20px;padding:15px;background:#fff;border-radius:6px;border:1px solid #e9ecef}.status-indicator{display:inline-block;padding:4px 8px;border-radius:4px;font-size:.9rem;font-weight:500;margin-left:10px}.status-indicator.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.status-indicator.warning{background:#fff3cd;color:#856404;border:1px solid #ffeaa7}.voice-available{margin-top:10px}.voice-player{width:100%;margin-top:10px;border-radius:4px}.voice-settings{background:#fff;padding:15px;border-radius:6px;border:1px solid #e9ecef;margin-bottom:20px}.setting-group{margin-bottom:15px}.setting-group label{display:flex;align-items:center;gap:10px;font-weight:500;color:#555}.setting-group input[type=range]{flex:1;margin-left:10px}.setting-group input[type=checkbox]{margin-right:8px}.voice-actions{display:flex;gap:10px;margin-bottom:15px}.btn{padding:10px 20px;border:none;border-radius:4px;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-danger{background:#dc3545;color:#fff}.error-message{background:#f8d7da;color:#721c24;padding:10px;border-radius:4px;border:1px solid #f5c6cb;margin-top:10px;font-size:.9rem}.joke-preview{background:#fff;padding:15px;border-radius:6px;border:1px solid #e9ecef;margin-top:15px}.joke-content p{margin:5px 0;line-height:1.4}.joke-content strong{color:#333}@media (max-width: 768px){.voice-generator{padding:15px;margin:15px 0}.voice-actions{flex-direction:column}.btn{width:100%}.setting-group label{flex-direction:column;align-items:flex-start;gap:5px}.setting-group input[type=range]{width:100%;margin-left:0}}.recreation-history{background:#fff;border:1px solid #e9ecef;border-radius:6px;padding:15px;margin-top:15px}.recreation-history h4{margin:0 0 10px;font-size:14px;color:#495057}.recreation-history ul{list-style:none;padding:0;margin:0}.recreation-history li{padding:4px 0;border-bottom:1px solid #f1f3f4}.recreation-history li:last-child{border-bottom:none}.btn-outline{background:#fff;border:1px solid #993386;color:#993386;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s ease}.btn-outline:hover{background:#993386;color:#fff;transform:translateY(-1px)}.btn-outline:disabled{opacity:.6;cursor:not-allowed;transform:none}.joke-editor{display:flex;flex-direction:column;height:100vh;background:#f8f9fa}.joke-editor.loading{justify-content:center;align-items:center}.editor-header{background:#fff;padding:.5rem 1rem;border-bottom:1px solid #e9ecef;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center}.editor-header h1{margin:0;color:#2c3e50;font-size:1.2rem}.editor-header p{margin:.15rem 0 0;color:#6c757d;font-size:.75rem}.editor-content{display:flex;flex-direction:column;flex:1;overflow:hidden}.editor-content-main{display:flex;flex:1;overflow:hidden}.jokes-panel{width:320px;background:#fff;border-right:1px solid #e9ecef;display:flex;flex-direction:column;flex-shrink:0;box-sizing:border-box;overflow:hidden}.jokes-panel .joke-item>*{width:100%!important;box-sizing:border-box!important}.search-and-filters{padding:.5rem .75rem;border-bottom:1px solid #e9ecef;background:#f8f9fa;display:flex!important;gap:.5rem;align-items:center;flex-wrap:nowrap;width:100%;box-sizing:border-box;overflow-x:auto}.search-box{flex:1;min-width:200px}.search-input{width:100%;padding:.4rem .5rem;border:1px solid #ced4da;border-radius:4px;font-size:.85rem}.search-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.filter-controls{display:flex!important;gap:.4rem;align-items:center;flex-wrap:nowrap;flex-shrink:0}.filter-section{display:flex;align-items:center;gap:.25rem;white-space:nowrap;flex-shrink:0}.filter-label{font-size:.65rem;font-weight:500;color:#495057;margin:0;flex-shrink:0}.filter-select{padding:.2rem .3rem;border:1px solid #ced4da;border-radius:3px;font-size:.7rem;background:#fff;cursor:pointer;transition:border-color .2s ease;min-width:70px;max-width:85px;flex-shrink:0}.filter-select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.filter-controls button{padding:.2rem .4rem;font-size:.65rem;border-radius:3px;white-space:nowrap;flex-shrink:0}.clear-filters-btn{padding:.25rem .5rem;background:#6c757d;color:#fff;border:none;border-radius:3px;font-size:.7rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;height:fit-content}.clear-filters-btn:hover{background:#5a6268;transform:translateY(-1px)}.jokes-list{flex:1;overflow-y:auto;width:100%}.list-header{padding:.5rem .75rem .3rem;background:#f8f9fa;border-bottom:1px solid #e9ecef}.count{font-weight:600;color:#6c757d;font-size:.8rem}.joke-item{padding:.4rem .75rem;border-bottom:1px solid #f1f3f4;cursor:pointer;transition:all .2s ease;display:flex!important;flex-direction:column!important;width:100%!important;box-sizing:border-box;align-items:stretch}.joke-item.meme-item{background:#fff8f0;border-left:3px solid #ff9800}.joke-item.joke-item-type{background:#f0f8ff;border-left:3px solid #2196f3}.joke-item.quip-item{background:#f8f0ff;border-left:3px solid #9c27b0}.content-header{display:flex!important;align-items:center;justify-content:flex-start!important;gap:.5rem;margin-bottom:.5rem;width:100%!important;box-sizing:border-box}.content-type-icon{font-size:1.2rem}.content-type-label{background:#e0e0e0;color:#333;padding:.2rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase}.meme-item .content-type-label{background:#ff9800;color:#fff}.joke-item-type .content-type-label{background:#2196f3;color:#fff}.quip-item .content-type-label{background:#9c27b0;color:#fff}.has-image{color:#ff9800;font-size:1rem}.joke-item:hover{background:#f8f9fa}.joke-item.selected{background:#e3f2fd;border-left:4px solid #2196f3}.joke-setup{font-weight:500;color:#2c3e50;margin-bottom:.3rem;line-height:1.3;font-size:.85rem;width:100%!important;padding:0!important;margin:0 0 .3rem!important;display:block!important;text-align:left!important;box-sizing:border-box}.joke-meta{display:flex!important;align-items:center;justify-content:flex-start!important;gap:.5rem;font-size:.75rem;width:100%!important;margin:0!important;padding:0!important;box-sizing:border-box}.status.approved{color:#28a745}.status.review{color:#ffc107}.category{background:#e9ecef;padding:.2rem .5rem;border-radius:12px;color:#495057;font-weight:500}.has-script{color:#17a2b8;font-size:1rem}.details-panel{flex:1;background:#fff;overflow-y:auto}.create-content-panel{position:fixed;inset:80px 0 0;background:#fff;z-index:20;overflow-y:auto;padding:1rem;border-top:3px solid #007bff;box-shadow:0 -2px 10px #0000001a}.no-selection{display:flex;flex-direction:column;justify-content:flex-start;align-items:center;padding:2rem 1rem;color:#6c757d;text-align:center;font-size:.9rem}.joke-details{padding:.75rem}.details-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid #e9ecef}.details-header h2{margin:0;color:#2c3e50;font-size:1.1rem}.action-buttons{display:flex;gap:.75rem}.meme-image-container{margin-bottom:2rem;padding:1rem;border:2px dashed #dee2e6;border-radius:8px;background:#f8f9fa;text-align:center}.meme-review-header{margin-bottom:1rem;text-align:left}.meme-review-header h3{margin:0 0 .5rem;color:#495057;font-size:1.1rem}.mismatch-warning{background:#fff3cd;border:1px solid #ffeaa7;border-radius:4px;padding:.75rem;color:#856404;font-size:.9rem;text-align:left}.meme-image{max-width:100%;max-height:400px;width:auto;height:auto;border-radius:8px;box-shadow:0 4px 8px #0000001a;background:#fff;margin:1rem 0}.image-path{color:#6c757d;font-size:.85rem;font-family:Courier New,monospace;background:#e9ecef;padding:.5rem;border-radius:4px;margin-top:.5rem}.image-error{color:#6c757d;font-style:italic;padding:2rem}.hidden{display:none}.image-selector{display:flex;flex-direction:column;gap:.5rem}.selector-hint{background:#e7f3ff;border:1px solid #b3d7ff;border-radius:4px;padding:.75rem;color:#06c;font-size:.9rem;text-align:left}.joke-editor .backup-controls{display:flex;flex-direction:row;gap:.5rem;align-items:center;flex-wrap:wrap}.backup-btn{background:#17a2b8;color:#fff;border:none;padding:.4rem .7rem;border-radius:4px;cursor:pointer;font-size:.8rem;font-weight:500;transition:background-color .2s}.backup-btn:hover{background:#138496}.backups-panel{background:#fff;border-bottom:1px solid #e9ecef;padding:1.5rem 2rem;box-shadow:inset 0 2px 4px #0000000d}.backups-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.backups-header h3{margin:0;color:#2c3e50;font-size:1.2rem}.close-btn{background:#dc3545;color:#fff;border:none;padding:.4rem .8rem;border-radius:4px;cursor:pointer;font-size:.8rem}.close-btn:hover{background:#c82333}.backups-list{display:flex;flex-direction:column;gap:.75rem;max-height:300px;overflow-y:auto}.backup-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;transition:border-color .2s}.backup-item:hover{border-color:#17a2b8}.backup-info{flex:1}.backup-date{font-weight:600;color:#2c3e50;margin-bottom:.25rem}.backup-reason{color:#6c757d;font-size:.9rem;margin-bottom:.25rem}.backup-stats{color:#17a2b8;font-size:.85rem;font-weight:500}.restore-btn{background:#28a745;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.85rem;font-weight:500;transition:background-color .2s}.restore-btn:hover{background:#218838}.no-backups{text-align:center;color:#6c757d;font-style:italic;padding:2rem}.btn-primary,.btn-secondary{padding:.6rem 1.2rem;border:none;border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .2s ease}.btn-primary:hover{background:#0056b3;transform:translateY(-1px)}.btn-secondary:hover{background:#545b62;transform:translateY(-1px)}.joke-form{max-width:800px}.form-group{margin-bottom:1rem}.form-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem;margin-bottom:1rem}.form-group label{display:block;margin-bottom:.3rem;font-weight:600;color:#495057;font-size:.85rem}.joke-input,.joke-select{width:100%;padding:.5rem;border:1px solid #ced4da;border-radius:4px;font-size:.9rem;transition:border-color .2s ease;font-family:inherit}.joke-input:focus,.joke-select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.joke-input.script{background:#f8f9fa;font-family:Courier New,monospace;font-size:.95rem}.joke-input.score{width:80px}.joke-display{padding:.75rem;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;min-height:2.5rem;display:flex;align-items:center}.joke-display.setup{font-weight:500;color:#2c3e50;line-height:1.5;min-height:4rem;align-items:flex-start;padding-top:1rem}.joke-display.punchline{font-weight:600;color:#e74c3c;line-height:1.4;min-height:3rem;align-items:flex-start;padding-top:1rem}.joke-display.script{background:#f1f3f4;font-family:Courier New,monospace;font-size:.95rem;line-height:1.6;min-height:5rem;align-items:flex-start;padding-top:1rem;white-space:pre-wrap}.meme-image{max-width:100%;max-height:400px;border-radius:8px;margin:1rem 0;box-shadow:0 4px 8px #0000001a}.meme-image-container{text-align:center;padding:1rem;background:#f8f9fa;border-radius:8px;margin:1rem 0}.meme-image-error{color:#dc3545;font-style:italic;padding:2rem;text-align:center;background:#f8d7da;border-radius:8px}.joke-display.meme-title{font-weight:600;color:#ff9800;font-size:1.2rem}.joke-display.description{font-style:italic;color:#666;line-height:1.5}.joke-display.status.approved{color:#28a745;font-weight:600}.joke-display.status.pending{color:#ffc107;font-weight:600}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:400}.checkbox-label input[type=checkbox]{margin:0;width:1.2rem;height:1.2rem}.status-controls{display:flex;flex-direction:column;gap:.75rem}.status-display{display:flex;flex-direction:column;gap:.5rem}.checkbox-label.archive-control{color:#dc3545;font-weight:500}.checkbox-label.archive-control input[type=checkbox]{accent-color:#dc3545}.joke-display.status.archived{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb;padding:.5rem 1rem;border-radius:15px;font-weight:600;display:inline-block}.joke-meta .status.archived{background:#6c757d;color:#fff;padding:.2rem .4rem;border-radius:12px;font-size:.8rem;font-weight:600}.batch-controls-panel{background:#fdfdfd;border:1px solid #e9ecef;border-radius:8px;margin:.5rem 1rem 0;padding:1rem;box-shadow:0 2px 8px #0000000d}.batch-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid #e9ecef}.batch-header h3{margin:0;color:#2c3e50;font-size:1.1rem}.selection-stats{display:flex;flex-direction:column;gap:.5rem}.selection-stats>div:first-child{display:flex;gap:.5rem;align-items:center}.selected-count{background:#007bff;color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.8rem;font-weight:600}.estimated-cost{background:#28a745;color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.8rem;font-weight:600}.selection-quality-stats{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.quality-metrics{background:#6f42c1;color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:600}.voice-stats{background:#fd7e14;color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:600}.score-indicators{display:flex;gap:.25rem;align-items:center;margin:.25rem 0}.user-score{padding:.15rem .4rem;border-radius:8px;font-size:.7rem;font-weight:600;display:flex;align-items:center;gap:.2rem}.user-score.excellent{background:#28a745;color:#fff}.user-score.good{background:#ffc107;color:#212529}.user-score.fair{background:#6c757d;color:#fff}.vote-count{font-size:.6rem;opacity:.8}.quality-score{padding:.15rem .4rem;border-radius:8px;font-size:.7rem;font-weight:600}.quality-score.high{background:#6f42c1;color:#fff}.quality-score.medium{background:#17a2b8;color:#fff}.quality-score.low{background:#e9ecef;color:#6c757d}.batch-actions-compact{margin-top:.5rem}.batch-controls-row{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:#fff;border:1px solid #e9ecef;border-radius:6px;flex-wrap:wrap}.selection-dropdown{padding:.25rem .5rem;border:1px solid #dee2e6;border-radius:4px;background:#fff;color:#495057;font-size:.75rem;cursor:pointer;outline:none;min-width:140px}.selection-dropdown:focus{border-color:#993386;box-shadow:0 0 0 2px #9933861a}.selected-badge{background:#993386;color:#fff;padding:.2rem .5rem;border-radius:12px;font-size:.7rem;font-weight:600;white-space:nowrap;border:none;cursor:pointer;transition:all .15s ease}.selected-badge.clickable:hover{background:#7a285d;transform:translateY(-1px)}.btn-primary-compact,.btn-warning-compact{padding:.25rem .6rem;border:none;border-radius:4px;cursor:pointer;font-size:.75rem;font-weight:600;transition:all .15s ease;white-space:nowrap}.btn-primary-compact{background:#993386;color:#fff}.btn-primary-compact:hover:not(:disabled){background:#7a285d;transform:translateY(-1px)}.btn-warning-compact{background:#ffc107;color:#212529}.btn-warning-compact:hover:not(:disabled){background:#e0a800;transform:translateY(-1px)}.btn-primary-compact:disabled,.btn-warning-compact:disabled{background:#adb5bd;color:#fff;cursor:not-allowed;transform:none}.selected-jokes-compact{margin-top:.5rem;background:#fff;border:1px solid #e9ecef;border-radius:6px;padding:.5rem}.selected-jokes-list-compact{display:flex;flex-direction:column;gap:.25rem;max-height:120px;overflow-y:auto}.selected-joke-item-compact{display:flex;justify-content:space-between;align-items:center;padding:.3rem .5rem;background:#f8f9fa;border-radius:4px;font-size:.7rem;border:1px solid #e9ecef}.joke-setup-preview-compact{flex:1;margin-right:.5rem;color:#495057;line-height:1.2}.joke-actions-compact{display:flex;align-items:center;gap:.3rem}.joke-voice-status-compact{font-size:.8rem}.joke-voice-status-compact.has-voice{color:#28a745}.joke-voice-status-compact.no-voice{color:#dc3545}.remove-joke-btn-compact{background:none;border:none;cursor:pointer;padding:.1rem .2rem;font-size:.7rem;color:#dc3545;transition:all .15s ease;border-radius:2px}.remove-joke-btn-compact:hover{background:#f5c6cb;transform:scale(1.1)}.btn-primary{padding:.4rem .8rem;background:#993386;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.8rem;font-weight:600;transition:all .15s ease;box-shadow:0 1px 3px #99338633}.btn-primary:hover:not(:disabled){background:#7a285d;transform:translateY(-1px);box-shadow:0 2px 4px #9933864d}.btn-primary:disabled{background:#adb5bd;cursor:not-allowed;box-shadow:none;transform:none}.btn-warning{padding:.4rem .8rem;background:#ffc107;color:#212529;border:none;border-radius:6px;cursor:pointer;font-size:.8rem;font-weight:600;transition:all .15s ease;box-shadow:0 1px 3px #ffc10733}.btn-warning:hover:not(:disabled){background:#e0a800;transform:translateY(-1px);box-shadow:0 2px 4px #ffc1074d}.btn-warning:disabled{background:#adb5bd;color:#fff;cursor:not-allowed;box-shadow:none;transform:none}.btn-danger{padding:.75rem 1.5rem;background:#dc3545;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:600;transition:background-color .2s}.btn-danger:hover:not(:disabled){background:#c82333}.btn-danger:disabled{background:#6c757d;color:#fff;cursor:not-allowed}.video-upload{border:1px solid #dee2e6;border-radius:6px;padding:1rem;background:#f8f9fa;margin-bottom:1rem}.video-upload-controls{display:flex;flex-direction:column;gap:.75rem}.video-upload-input{padding:.5rem;border:1px solid #ced4da;border-radius:4px;background:#fff}.video-preview{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:#fff;border:1px solid #dee2e6;border-radius:4px}.video-info{font-size:.9rem;color:#28a745;font-weight:500}.current-video-info{font-size:.9rem;color:#17a2b8;padding:.5rem;background:#e1f5fe;border-radius:4px;border:1px solid #b3e5fc}.remove-video-btn{background:#dc3545;color:#fff;border:none;padding:.25rem .5rem;border-radius:3px;font-size:.8rem;cursor:pointer;align-self:flex-start}.remove-video-btn:hover{background:#c82333}.batch-results{margin-top:1rem;padding-top:1rem;border-top:1px solid #e9ecef}.batch-results h4{margin:0 0 .75rem;color:#495057;font-size:.9rem}.selected-jokes-section{margin-top:1rem;padding-top:1rem;border-top:1px solid #e9ecef}.selected-jokes-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.selected-jokes-header h4{margin:0;color:#495057;font-size:.9rem;font-weight:600}.toggle-list-btn{background:none;border:none;color:#007bff;cursor:pointer;font-size:.8rem;padding:.2rem .4rem;border-radius:3px;transition:background-color .2s}.toggle-list-btn:hover{background:#f8f9fa}.selected-jokes-list{max-height:150px;overflow-y:auto;border:1px solid #e9ecef;border-radius:4px;background:#fff}.selected-joke-item{padding:.4rem .6rem;border-bottom:1px solid #f8f9fa;display:flex;justify-content:space-between;align-items:center;font-size:.8rem}.selected-joke-item:last-child{border-bottom:none}.selected-joke-item:hover{background:#f8f9fa}.joke-setup-preview{flex:1;min-width:0;margin-right:.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.joke-voice-status{font-size:.7rem;padding:.1rem .3rem;border-radius:10px;font-weight:600}.has-voice{background:#d4edda;color:#155724}.no-voice{background:#f8d7da;color:#721c24}.remove-joke-btn{background:none;border:none;color:#dc3545;cursor:pointer;padding:.1rem .3rem;border-radius:2px;font-size:.7rem;margin-left:.3rem}.remove-joke-btn:hover{background:#f5c6cb}.results-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.result-item{background:#fff;padding:1rem;border-radius:6px;box-shadow:0 1px 3px #0000001a;text-align:center}.result-item.success{border-left:4px solid #28a745}.result-item.error{border-left:4px solid #dc3545}.result-item.skipped{border-left:4px solid #ffc107}.result-item.cost{border-left:4px solid #17a2b8}.result-item .label{display:block;font-size:.9rem;color:#6c757d;margin-bottom:.5rem}.result-item .value{display:block;font-size:1.5rem;font-weight:600;color:#2c3e50}.joke-item{position:relative}.joke-item.batch-selected{background:#e3f2fd;border-left:4px solid #2196f3}.joke-item-content{flex:1;cursor:pointer}.batch-checkbox{position:absolute;top:10px;right:10px;z-index:10}.checkbox-container{display:block;position:relative;cursor:pointer;font-size:18px;user-select:none}.checkbox-container input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.checkmark{position:absolute;top:0;left:0;height:20px;width:20px;background-color:#eee;border:2px solid #ddd;border-radius:4px;transition:all .2s}.checkbox-container:hover input~.checkmark{background-color:#ccc}.checkbox-container input:checked~.checkmark{background-color:#2196f3;border-color:#2196f3}.checkmark:after{content:"";position:absolute;display:none}.checkbox-container input:checked~.checkmark:after{display:block}.checkbox-container .checkmark:after{left:6px;top:2px;width:5px;height:10px;border:solid white;border-width:0 3px 3px 0;transform:rotate(45deg)}.has-voice{background:#28a745;color:#fff;padding:.2rem .4rem;border-radius:12px;font-size:.8rem;font-weight:600}.has-video{background:#007bff;color:#fff;padding:.2rem .4rem;border-radius:12px;font-size:.8rem;font-weight:600}.form-group.voice-management{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:1rem;margin:1rem 0}.voice-controls{display:flex;flex-direction:column;gap:1rem}.voice-status{display:flex;align-items:center;gap:1rem}.voice-indicator{padding:.5rem 1rem;border-radius:20px;font-weight:600;display:flex;align-items:center;gap:.5rem}.voice-indicator.has-voice{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.voice-indicator.no-voice{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.voice-error{color:#dc3545;font-size:.9rem;font-style:italic;background:#f8d7da;padding:.3rem .8rem;border-radius:15px;border:1px solid #f5c6cb}.voice-actions{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.voice-btn{padding:.6rem 1.2rem;border:none;border-radius:20px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.5rem;font-size:.9rem}.voice-btn.play{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;box-shadow:0 2px 4px #28a7454d}.voice-btn.play:hover:not(:disabled){background:linear-gradient(135deg,#20c997,#28a745);transform:translateY(-1px);box-shadow:0 4px 8px #28a74566}.voice-btn.stop{background:linear-gradient(135deg,#ffc107,#fd7e14);color:#fff;box-shadow:0 2px 4px #ffc1074d;animation:pulse-orange 2s infinite}.voice-btn.stop:hover{background:linear-gradient(135deg,#fd7e14,#ffc107);transform:translateY(-1px);box-shadow:0 4px 8px #ffc10766}.voice-btn.delete{background:linear-gradient(135deg,#dc3545,#c82333);color:#fff;box-shadow:0 2px 4px #dc35454d}.voice-btn.delete:hover:not(:disabled){background:linear-gradient(135deg,#c82333,#dc3545);transform:translateY(-1px);box-shadow:0 4px 8px #dc354566}.voice-btn:disabled{background:#6c757d;cursor:not-allowed;transform:none;box-shadow:none;opacity:.6}.voice-hint{margin:0;color:#6c757d;font-style:italic;font-size:.9rem;padding:.5rem 1rem;background:#e9ecef;border-radius:15px;border-left:4px solid #007bff}@keyframes pulse-orange{0%{box-shadow:0 2px 4px #ffc1074d}50%{box-shadow:0 4px 12px #ffc10799}to{box-shadow:0 2px 4px #ffc1074d}}.backup-btn.active{background:#007bff;color:#fff}@media (max-width: 768px){.editor-content{flex-direction:column}.jokes-panel{width:100%;height:40vh}.details-panel{height:60vh}.form-row{grid-template-columns:1fr;gap:1rem}.batch-controls-row{flex-direction:column;align-items:stretch;gap:.75rem}.selection-dropdown{min-width:auto;width:100%}.results-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}.batch-controls-panel{margin:.5rem}.selected-jokes-list-compact{max-height:100px}.selected-joke-item-compact{font-size:.65rem;padding:.25rem .4rem}}.video-preview{margin-top:.5rem}.video-preview video{max-width:100%;border:1px solid #ddd;border-radius:4px;box-shadow:0 2px 4px #0000001a}.video-preview-container{margin:1rem 0;display:flex;justify-content:center}.video-preview-loading{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.video-preview-loading .loading-spinner{width:20px;height:20px;border:2px solid #e9ecef;border-top:2px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}.video-preview-error{padding:.75rem;background:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:8px;text-align:center;font-size:.9rem}.current-video-preview{margin:1rem 0;padding:1rem;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px}.current-video-preview .video-info{font-weight:600;color:#495057;margin-bottom:.5rem;text-align:center}.file-preview{margin-top:.5rem;padding:.5rem;background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;font-size:.9rem;color:#495057}.file-preview.video-preview{background:linear-gradient(135deg,#e3f2fd,#f3e5f5);border-color:#2196f3}.queue-panel{background:#fff;border:1px solid #e9ecef;border-radius:var(--border-radius);margin:1rem 0;box-shadow:var(--shadow)}.queue-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:var(--border-radius) var(--border-radius) 0 0}.queue-header h3{margin:0;font-size:1.1rem}.queue-actions{display:flex;gap:.5rem}.clear-queue-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:.25rem .75rem;border-radius:4px;font-size:.9rem;cursor:pointer;transition:all .3s ease}.clear-queue-btn:hover:not(:disabled){background:#ffffff4d}.clear-queue-btn:disabled{opacity:.5;cursor:not-allowed}.queue-content{padding:1.5rem}.empty-queue{text-align:center;color:#666;font-style:italic;padding:2rem}.queue-list{display:flex;flex-direction:column;gap:.75rem}.queue-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;transition:all .3s ease}.queue-item:hover{background:#e9ecef;border-color:#667eea}.queue-position{font-weight:700;color:#667eea;font-size:1.1rem;min-width:30px}.queue-joke-content{flex:1}.queue-setup{font-weight:500;color:#333;margin-bottom:.25rem;line-height:1.4}.queue-meta{font-size:.85rem;color:#666}.remove-from-queue-btn{background:#dc3545;color:#fff;border:none;border-radius:50%;width:24px;height:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.7rem;transition:all .3s ease}.remove-from-queue-btn:hover{background:#c82333;transform:scale(1.1)}.queue-buttons{display:flex;gap:.5rem;margin-top:.5rem}.queue-btn{background:#f8f9fa;border:1px solid #dee2e6;padding:.25rem .75rem;border-radius:4px;font-size:.8rem;cursor:pointer;transition:all .3s ease;font-weight:500}.queue-btn:hover{background:#e9ecef;border-color:#adb5bd}.queue-btn.next-btn.is-next{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;border-color:#28a745;font-weight:700}.queue-btn.add-btn.in-queue{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea}.voice-controls-panel{background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;padding:1rem;margin-top:.5rem}.voice-status{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.voice-indicator{font-weight:600;color:#28a745}.voice-error{color:#dc3545;font-size:.9rem}.voice-buttons{display:flex;gap:.5rem;margin-bottom:.5rem}.voice-btn{padding:.5rem 1rem;border:none;border-radius:4px;font-size:.9rem;cursor:pointer;transition:all .2s ease;min-width:80px}.voice-btn:disabled{opacity:.6;cursor:not-allowed}.voice-url-info{font-size:.8rem;color:#6c757d;word-break:break-all;background:#e9ecef;padding:.5rem;border-radius:4px;margin-top:.5rem}.btn-accent{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-weight:500;transition:all .2s ease;display:inline-flex;align-items:center;gap:.5rem}.btn-accent:hover:not(:disabled){background:linear-gradient(135deg,#5a6fd8,#6a4190);transform:translateY(-1px);box-shadow:0 4px 8px #667eea4d}.btn-accent:disabled{opacity:.7;cursor:not-allowed;transform:none}.meme-review-container{max-width:1400px;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.review-header{text-align:center;margin-bottom:30px;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px}.review-header h1{margin:0 0 10px;font-size:2.5em;font-weight:700}.review-header p{margin:0 0 15px;font-size:1.2em;opacity:.9}.progress{font-size:1.1em;font-weight:600;background:#fff3;padding:8px 16px;border-radius:20px;display:inline-block}.review-content{display:grid;gap:30px}.meme-display{display:grid;grid-template-columns:1fr 1fr;gap:30px;background:#fff;border-radius:12px;padding:25px;box-shadow:0 4px 20px #0000001a}.meme-image-section h3,.description-section h3{margin:0 0 20px;color:#333;font-size:1.4em;font-weight:600}.image-container{display:flex;justify-content:center;align-items:center;background:#f8f9fa;border-radius:8px;padding:20px;margin-bottom:15px;min-height:300px}.image-container img{max-width:100%;max-height:400px;border-radius:8px;box-shadow:0 2px 10px #0000001a;object-fit:contain}.image-info{text-align:center;color:#666;font-size:.9em;background:#f0f0f0;padding:8px 12px;border-radius:6px}.current-description{background:#f8f9fa;padding:15px;border-radius:8px;margin-bottom:20px;border-left:4px solid #dc3545}.current-description strong{color:#dc3545;display:block;margin-bottom:8px}.current-description p{margin:0;color:#333;line-height:1.5}.edit-description{margin-bottom:25px}.edit-description label{display:block;margin-bottom:8px;font-weight:600;color:#333}.edit-description textarea{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;font-family:inherit;resize:vertical;transition:border-color .3s ease}.edit-description textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.description-tips{background:#e8f4fd;padding:15px;border-radius:8px;border-left:4px solid #17a2b8}.description-tips h4{margin:0 0 10px;color:#17a2b8;font-size:1.1em}.description-tips ul{margin:0;padding-left:20px}.description-tips li{margin-bottom:5px;color:#333;font-size:.9em}.review-actions{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:25px;border-radius:12px;box-shadow:0 4px 20px #0000001a}.save-btn{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.save-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 15px #28a7454d}.save-btn:disabled{background:#6c757d;cursor:not-allowed;transform:none;box-shadow:none}.navigation{display:flex;align-items:center;gap:15px}.nav-btn{background:#667eea;color:#fff;border:none;padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.nav-btn:hover:not(:disabled){background:#5a6fd8;transform:translateY(-1px)}.nav-btn:disabled{background:#6c757d;cursor:not-allowed;transform:none}.nav-info{font-weight:600;color:#333;padding:0 10px}.meme-list{background:#fff;padding:25px;border-radius:12px;box-shadow:0 4px 20px #0000001a}.meme-list h3{margin:0 0 20px;color:#333;font-size:1.4em;font-weight:600}.meme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:15px}.meme-thumbnail{border:2px solid #e0e0e0;border-radius:8px;overflow:hidden;cursor:pointer;transition:all .3s ease;background:#fff}.meme-thumbnail:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 15px #0000001a}.meme-thumbnail.active{border-color:#28a745;box-shadow:0 0 0 3px #28a74533}.meme-thumbnail img{width:100%;height:120px;object-fit:cover;display:block}.thumbnail-info{padding:10px}.meme-id{font-weight:600;color:#667eea;font-size:.9em;margin-bottom:5px}.description-preview{font-size:.8em;color:#666;line-height:1.3}.loading,.no-memes{text-align:center;padding:60px 20px;color:#666;font-size:1.2em}@media (max-width: 768px){.meme-display{grid-template-columns:1fr;gap:20px;padding:20px}.review-actions{flex-direction:column;gap:20px;align-items:stretch}.navigation{justify-content:center}.meme-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.review-header h1{font-size:2em}}.migration-panel{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:24px;margin:20px 0;color:#fff;box-shadow:0 8px 32px #667eea4d}.migration-panel h3{margin:0 0 16px;font-size:24px;font-weight:600;display:flex;align-items:center;gap:8px}.migration-description{margin:0 0 24px;font-size:16px;opacity:.9;line-height:1.5}.loading{text-align:center;padding:20px;font-size:16px;opacity:.8}.migration-error{background:#dc354533;border:1px solid rgba(220,53,69,.5);border-radius:8px;padding:16px;margin:16px 0}.migration-error h4{margin:0 0 8px;font-size:18px}.migration-error p{margin:0 0 12px;line-height:1.4}.migration-status{background:#ffffff1a;border-radius:8px;padding:16px;margin:16px 0;backdrop-filter:blur(10px)}.migration-status h4{margin:0 0 12px;font-size:18px}.status-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.status-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#ffffff1a;border-radius:6px}.status-label{font-weight:500}.status-value{font-weight:600}.status-value.success{color:#28a745}.status-value.warning{color:#ffc107}.prerequisites-errors,.prerequisites-warnings{margin:12px 0}.prerequisites-errors h5,.prerequisites-warnings h5{margin:0 0 8px;font-size:14px;font-weight:600}.prerequisites-errors ul,.prerequisites-warnings ul{margin:0;padding-left:20px;font-size:14px;line-height:1.4}.prerequisites-errors{color:#ff6b6b}.prerequisites-warnings{color:#ffd93d}.last-migration{background:#ffffff1a;border-radius:8px;padding:16px;margin:16px 0}.last-migration h4{margin:0 0 12px;font-size:18px}.last-migration p{margin:0 0 8px;font-size:14px}.migration-stats{display:flex;gap:16px;font-size:14px;font-weight:500}.migration-stats .error-count{color:#ff6b6b}.migration-actions{background:#ffffff1a;border-radius:8px;padding:20px;margin:16px 0}.migration-actions h4{margin:0 0 16px;font-size:18px}.action-buttons{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.migration-info{font-size:14px;line-height:1.5}.migration-info p{margin:0 0 8px;font-weight:600}.migration-info ul{margin:0;padding-left:20px}.migration-info li{margin:4px 0}.confirmation-dialog{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000}.dialog-content{background:#fff;color:#333;border-radius:12px;padding:24px;max-width:500px;width:90%;box-shadow:0 16px 48px #0000004d}.dialog-content h4{margin:0 0 16px;font-size:20px;color:#dc3545}.dialog-content p{margin:0 0 12px;line-height:1.5}.dialog-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}.migration-result{background:#28a74533;border:1px solid rgba(40,167,69,.5);border-radius:8px;padding:16px;margin:16px 0}.migration-result h4{margin:0 0 12px;font-size:18px;color:#28a745}.result-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px;margin:12px 0}.stat-item{display:flex;justify-content:space-between;padding:6px 12px;background:#ffffff1a;border-radius:4px;font-size:14px}.stat-item.error{background:#dc354533;color:#ff6b6b}.result-message{margin:12px 0 8px;font-weight:600;font-size:16px}.result-timestamp{margin:0;font-size:12px;opacity:.8}@media (max-width: 768px){.migration-panel{padding:16px;margin:16px 0}.status-grid{grid-template-columns:1fr}.action-buttons{flex-direction:column}.action-buttons .admin-btn{width:100%}.dialog-content{padding:20px}.dialog-actions{flex-direction:column}.dialog-actions .admin-btn{width:100%}.result-stats{grid-template-columns:1fr}}.migration-panel .admin-btn{border:1px solid rgba(255,255,255,.3);transition:all .3s ease}.migration-panel .admin-btn:hover:not(:disabled){background:#ffffff1a;border-color:#ffffff80;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.migration-panel .admin-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.migration-panel .admin-btn-lg{padding:12px 24px;font-size:16px;font-weight:600;min-height:48px}.environment-manager{max-width:1200px;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #e9ecef}.header h1{color:#2c3e50;margin:0;font-size:2.2rem}.refresh-info{color:#6c757d;font-size:.9rem;background:#f8f9fa;padding:8px 12px;border-radius:6px;border:1px solid #dee2e6}.status-section{background:#fff;border:1px solid #dee2e6;border-radius:8px;padding:24px;margin-bottom:24px;box-shadow:0 2px 4px #0000001a}.status-section h2{color:#2c3e50;margin:0 0 20px;font-size:1.4rem;border-bottom:1px solid #e9ecef;padding-bottom:10px}.environment-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.env-card{border:1px solid #dee2e6;border-radius:8px;padding:20px;background:#fff}.env-card.development{border-left:4px solid #28a745}.env-card.production{border-left:4px solid #dc3545}.env-card h3{margin:0 0 16px;color:#2c3e50}.service-status{margin-bottom:16px}.service{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f8f9fa}.service:last-child{border-bottom:none}.service span:first-child{font-weight:500;color:#495057}.env-controls{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.env-status-note{color:#6c757d;font-style:italic;padding:8px;background:#f8f9fa;border-radius:4px;border:1px solid #e9ecef}.aws-status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.aws-service{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f8f9fa;border-radius:6px;border:1px solid #e9ecef}.service-name{font-weight:500;color:#495057}.backup-status{display:grid;grid-template-columns:2fr 1fr;gap:20px;align-items:start}.backup-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.backup-item{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:#f8f9fa;border-radius:6px;border:1px solid #e9ecef}.backup-item span:first-child{font-weight:500;color:#495057}.backup-controls,.alerts{display:flex;flex-direction:column;gap:10px}.alert{padding:12px 16px;border-radius:6px;border:1px solid;font-weight:500}.alert.success{background:#d4edda;border-color:#c3e6cb;color:#155724}.alert.warning{background:#fff3cd;border-color:#ffeaa7;color:#856404}.alert.error{background:#f8d7da;border-color:#f5c6cb;color:#721c24}.btn-primary,.btn-secondary{padding:8px 16px;border:none;border-radius:4px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:center;min-width:100px}.btn-primary{background:#007bff;color:#fff}.btn-primary:hover:not(:disabled){background:#0056b3}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background:#545b62}.btn-primary:disabled,.btn-secondary:disabled{background:#e9ecef;color:#6c757d;cursor:not-allowed}.loading,.error{text-align:center;padding:40px 20px;color:#6c757d;font-size:1.1rem}.error{color:#dc3545}@media (max-width: 768px){.environment-grid,.backup-status{grid-template-columns:1fr}.header{flex-direction:column;align-items:start;gap:10px}.env-controls{justify-content:stretch}.env-controls button{flex:1}}.video-tracking-dashboard{padding:20px;background:#f8f9fa;min-height:100vh;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.dashboard-header h1{margin:0;color:#2c3e50;font-size:2rem;font-weight:600}.dashboard-header p{margin:5px 0 0;color:#7f8c8d;font-size:1rem}.header-actions{display:flex;gap:12px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:#fff;padding:20px;border-radius:12px;box-shadow:0 2px 8px #0000001a;text-align:center;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.stat-number{font-size:2.5rem;font-weight:700;margin-bottom:8px}.stat-label{color:#7f8c8d;font-size:.9rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.stat-card.total .stat-number{color:#34495e}.stat-card.pending .stat-number{color:#f39c12}.stat-card.processing .stat-number{color:#3498db}.stat-card.completed .stat-number{color:#27ae60}.stat-card.failed .stat-number{color:#e74c3c}.stat-card.success-rate .stat-number{color:#9b59b6}.stat-card.quota .stat-number{color:#e67e22}.stat-card.processing-time .stat-number{color:#16a085}.create-request-form{background:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:30px;border-left:4px solid #3498db}.create-request-form h3{margin:0 0 20px;color:#2c3e50;font-size:1.3rem}.form-row{display:flex;gap:20px;align-items:end;flex-wrap:wrap}.form-group{flex:1;min-width:200px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#34495e;font-size:.9rem}.form-input,.form-select{width:100%;padding:10px 12px;border:2px solid #e8e8e8;border-radius:8px;font-size:.95rem;transition:border-color .2s ease,box-shadow .2s ease;background:#fff}.form-input:focus,.form-select:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.form-actions{display:flex;gap:12px;margin-top:20px}.filters-section{background:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:30px}.filters-section h3{margin:0 0 20px;color:#2c3e50;font-size:1.3rem}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;align-items:start}.filter-group label{display:block;margin-bottom:8px;font-weight:500;color:#34495e;font-size:.9rem}.checkbox-group{display:flex;flex-wrap:wrap;gap:12px}.checkbox-label{display:flex;align-items:center;gap:6px;font-size:.9rem;cursor:pointer;padding:4px 8px;border-radius:6px;transition:background-color .2s ease}.checkbox-label:hover{background-color:#f8f9fa}.checkbox-label input[type=checkbox]{margin:0;cursor:pointer}.filter-actions{display:flex;align-items:end;justify-content:end}.requests-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.section-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e8e8e8;background:#fafbfc}.section-header h3{margin:0;color:#2c3e50;font-size:1.3rem}.pagination-info{color:#7f8c8d;font-size:.9rem}.requests-table{overflow-x:auto}.table-header,.table-row{display:grid;grid-template-columns:120px 180px 100px 160px 120px 80px 140px;gap:16px;padding:16px 24px;align-items:center;border-bottom:1px solid #e8e8e8}.table-header{background:#f8f9fa;font-weight:600;color:#34495e;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.table-row{transition:background-color .2s ease}.table-row:hover{background-color:#f8f9fa}.table-row:last-child{border-bottom:none}.status-badge,.priority-badge,.test-badge{display:inline-block;padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.status-pending{background:#fff3cd;color:#856404}.status-requested{background:#d1ecf1;color:#0c5460}.status-processing{background:#cce5ff;color:#004085}.status-completed{background:#d4edda;color:#155724}.status-failed{background:#f8d7da;color:#721c24}.status-cancelled{background:#e2e3e5;color:#383d41}.priority-high{background:#f8d7da;color:#721c24}.priority-normal{background:#d1ecf1;color:#0c5460}.priority-low{background:#e2e3e5;color:#383d41}.test-badge{background:#fff3cd;color:#856404;margin-left:4px;font-size:.65rem}.joke-id{font-weight:500;color:#2c3e50;font-size:.9rem}.heygen-id{font-size:.75rem;color:#7f8c8d;margin-top:2px}.created-date{font-size:.85rem;color:#2c3e50}.completed-date,.failed-date{font-size:.75rem;margin-top:2px}.completed-date{color:#27ae60}.failed-date{color:#e74c3c}.retry-count{font-weight:500;color:#34495e;font-size:.9rem}.action-buttons{display:flex;gap:6px;align-items:center}.btn-action{padding:6px 8px;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;transition:all .2s ease;min-width:28px;height:28px}.btn-execute{background:#27ae60;color:#fff}.btn-execute:hover{background:#229954}.btn-cancel{background:#e74c3c;color:#fff}.btn-cancel:hover{background:#c0392b}.btn-retry{background:#f39c12;color:#fff}.btn-retry:hover{background:#e67e22}.btn-download{background:#3498db;color:#fff}.btn-download:hover{background:#2980b9}.btn-action:disabled{opacity:.6;cursor:not-allowed}.error-details{font-size:.75rem;color:#e74c3c;margin-top:4px;cursor:help}.btn-primary,.btn-secondary,.btn-retry,.btn-pagination{padding:10px 16px;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:6px}.btn-primary{background:#3498db;color:#fff}.btn-primary:hover:not(:disabled){background:#2980b9;transform:translateY(-1px)}.btn-primary.active{background:#2c3e50}.btn-secondary{background:#95a5a6;color:#fff}.btn-secondary:hover:not(:disabled){background:#7f8c8d}.btn-retry{background:#e74c3c;color:#fff}.btn-retry:hover{background:#c0392b}.btn-pagination{background:#ecf0f1;color:#2c3e50;margin:0 8px}.btn-pagination:hover:not(:disabled){background:#bdc3c7}.btn-pagination:disabled{opacity:.5;cursor:not-allowed}.no-requests{text-align:center;padding:60px 20px;color:#7f8c8d}.no-requests p:first-child{font-size:1.2rem;margin-bottom:8px}.no-requests p:last-child{font-size:.95rem;color:#95a5a6}.pagination{display:flex;justify-content:center;align-items:center;padding:20px;background:#fafbfc;border-top:1px solid #e8e8e8}.pagination-current{font-weight:500;color:#34495e;font-size:.9rem}.video-tracking-dashboard.loading,.video-tracking-dashboard.error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center}.video-tracking-dashboard.loading h1,.video-tracking-dashboard.error h1{margin-bottom:20px;color:#2c3e50}.error-message{background:#fff;padding:30px;border-radius:12px;box-shadow:0 2px 8px #0000001a;border-left:4px solid #e74c3c}.error-message p{margin-bottom:20px;color:#e74c3c;font-size:1.1rem}@media (max-width: 1200px){.table-header,.table-row{grid-template-columns:100px 140px 80px 120px 100px 60px 120px;gap:12px;padding:12px 16px;font-size:.85rem}}@media (max-width: 900px){.dashboard-header{flex-direction:column;gap:20px;text-align:center}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.form-row{flex-direction:column}.filters-grid{grid-template-columns:1fr}.table-header,.table-row{grid-template-columns:1fr;gap:8px;padding:16px}.table-header>div,.table-row>div{display:flex;justify-content:space-between;align-items:center;padding:4px 0}.table-header>div:before,.table-row>div:before{content:attr(data-label);font-weight:600;color:#7f8c8d;font-size:.8rem}}@media (max-width: 600px){.video-tracking-dashboard{padding:10px}.dashboard-header{padding:16px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.stat-card{padding:16px}.stat-number{font-size:2rem}.action-buttons{justify-content:center;flex-wrap:wrap}}.requests-table::-webkit-scrollbar{height:8px}.requests-table::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.requests-table::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.requests-table::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.btn-primary:focus,.btn-secondary:focus,.btn-action:focus,.form-input:focus,.form-select:focus{outline:2px solid #3498db;outline-offset:2px}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.btn-action:disabled{animation:pulse 1.5s infinite}.pending-videos-manager{padding:20px;max-width:1200px;margin:0 auto}.header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px;flex-wrap:wrap;gap:20px}.header h1{margin:0;color:#333;font-size:2rem}.header p{margin:5px 0 0;color:#666;font-size:1.1rem}.header-actions{display:flex;gap:10px;flex-wrap:wrap}.btn{padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s;text-decoration:none;display:inline-flex;align-items:center;gap:5px}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover{background-color:#0056b3}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#545b62}.btn-small{padding:6px 12px;font-size:12px}.btn:disabled{opacity:.6;cursor:not-allowed}.last-refresh{background-color:#f8f9fa;padding:10px 15px;border-radius:6px;margin-bottom:20px;font-size:14px;color:#666;border-left:4px solid #007bff}.error-message{background-color:#f8d7da;color:#721c24;padding:15px;border-radius:6px;margin-bottom:20px;border-left:4px solid #dc3545}.no-pending{text-align:center;padding:60px 20px;background-color:#f8f9fa;border-radius:12px;color:#28a745;font-size:1.2rem;border:2px dashed #28a745}.no-pending p{margin-top:10px;color:#666;font-size:1rem}.summary{background-color:#e3f2fd;padding:15px;border-radius:6px;margin-bottom:20px;font-weight:500;color:#1565c0;border-left:4px solid #2196f3}.videos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:20px;margin-bottom:30px}.video-card{background-color:#fff;border:2px solid #e9ecef;border-radius:12px;padding:20px;box-shadow:0 2px 4px #0000001a;transition:transform .2s,box-shadow .2s}.video-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.video-card.requested{border-left-color:#ffc107}.video-card.processing{border-left-color:#17a2b8}.video-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.status-badge{background-color:#e9ecef;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase}.video-card.requested .status-badge{background-color:#fff3cd;color:#856404}.video-card.processing .status-badge{background-color:#d1ecf1;color:#0c5460}.started-time{font-size:12px;color:#666}.joke-preview{background-color:#f8f9fa;padding:12px;border-radius:6px;margin-bottom:15px;font-style:italic;border-left:3px solid #6c757d}.video-details{margin-bottom:15px}.detail-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:14px}.detail-row strong{color:#333;min-width:80px}.video-id{font-family:Courier New,monospace;background-color:#f8f9fa;padding:2px 6px;border-radius:4px;font-size:12px;color:#007bff;border:1px solid #dee2e6;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.video-id.clickable{cursor:pointer;transition:background-color .2s}.video-id.clickable:hover{background-color:#e9ecef}.error-detail{background-color:#f8d7da;color:#721c24;padding:8px;border-radius:4px;font-size:12px;margin-top:10px}.video-actions{display:flex;gap:10px;flex-wrap:wrap}.help-section{background-color:#f8f9fa;padding:20px;border-radius:12px;border-left:4px solid #17a2b8}.help-section h3{margin-top:0;color:#0c5460}.help-section ul{margin:15px 0 0;padding-left:20px}.help-section li{margin-bottom:8px;line-height:1.5}.help-section strong{color:#0c5460}@media (max-width: 768px){.pending-videos-manager{padding:15px}.header{flex-direction:column;align-items:stretch}.header-actions{justify-content:center}.videos-grid{grid-template-columns:1fr}.detail-row{flex-direction:column;align-items:flex-start;gap:4px}.video-id{max-width:100%}}.content-type-selector{max-width:800px;margin:0 auto;padding:2rem}.selector-title{font-size:2rem;font-weight:600;color:var(--text-primary, #333);margin-bottom:.5rem;text-align:center}.selector-subtitle{font-size:1.1rem;color:var(--text-secondary, #666);text-align:center;margin-bottom:2rem}.type-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.type-option{background:var(--card-background, #fff);border:2px solid var(--border-color, #e0e0e0);border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:flex-start;gap:1rem;text-align:left;width:100%;font-family:inherit}.type-option:hover:not(.disabled){border-color:var(--primary-color, #007bff);box-shadow:0 4px 12px #007bff26;transform:translateY(-2px)}.type-option.selected{border-color:var(--primary-color, #007bff);background:var(--primary-light, #f8f9ff);box-shadow:0 4px 12px #007bff33}.type-option.disabled{opacity:.6;cursor:not-allowed}.option-icon{font-size:2.5rem;flex-shrink:0;margin-top:.25rem}.option-content{flex:1}.option-title{font-size:1.3rem;font-weight:600;color:var(--text-primary, #333);margin:0 0 .5rem}.option-description{font-size:1rem;color:var(--text-secondary, #666);margin:0 0 .75rem;line-height:1.4}.option-media-info{font-size:.85rem;color:var(--text-muted, #888);font-style:italic;margin:0}.selected-info{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;background:var(--success-light, #f0f8f0);border:1px solid var(--success-color, #28a745);border-radius:8px;font-size:1rem}.info-icon{font-size:1.2rem}@media (max-width: 768px){.content-type-selector{padding:1rem}.type-options{grid-template-columns:1fr;gap:1rem}.type-option{padding:1rem}.selector-title{font-size:1.5rem}.option-title{font-size:1.1rem}.option-icon{font-size:2rem}}@media (prefers-color-scheme: dark){.type-option{background:var(--card-background-dark, #2a2a2a);border-color:var(--border-color-dark, #444)}.selector-title{color:var(--text-primary-dark, #fff)}.selector-subtitle{color:var(--text-secondary-dark, #ccc)}.option-title{color:var(--text-primary-dark, #fff)}.option-description{color:var(--text-secondary-dark, #ccc)}.option-media-info{color:var(--text-muted-dark, #aaa)}}.content-creator{min-height:100vh;background:var(--background-light, #f8f9fa);padding:2rem 0}.creator-header{max-width:1200px;margin:0 auto 3rem;padding:0 2rem;text-align:center}.creator-title{font-size:2.5rem;font-weight:700;color:var(--text-primary, #333);margin-bottom:2rem}.step-indicator{display:flex;justify-content:center;align-items:center;gap:2rem;max-width:600px;margin:0 auto}.step{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;opacity:.5;transition:all .3s ease}.step.active{opacity:1;color:var(--primary-color, #007bff)}.step.completed{opacity:1;color:var(--success-color, #28a745)}.step-number{width:3rem;height:3rem;border-radius:50%;background:var(--border-color, #e0e0e0);color:var(--text-secondary, #666);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.1rem;transition:all .3s ease}.step.active .step-number{background:var(--primary-color, #007bff);color:#fff}.step.completed .step-number{background:var(--success-color, #28a745);color:#fff}.step-label{font-size:.9rem;font-weight:500;text-align:center}.creator-content{max-width:1200px;margin:0 auto;padding:0 2rem}.creation-complete{text-align:center;padding:3rem 2rem;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;max-width:600px;margin:0 auto}.success-icon{font-size:4rem;margin-bottom:1.5rem}.creation-complete h2{font-size:2rem;font-weight:600;color:var(--text-primary, #333);margin-bottom:1rem}.creation-complete p{font-size:1.1rem;color:var(--text-secondary, #666);margin-bottom:2rem}.completion-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn{padding:12px 24px;border-radius:8px;font-size:1rem;font-weight:500;border:none;cursor:pointer;transition:all .3s ease;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;min-width:160px}.btn-primary{background:var(--primary-color, #007bff);color:#fff}.btn-primary:hover{background:var(--primary-dark, #0056b3);transform:translateY(-2px);box-shadow:0 4px 12px #007bff4d}.btn-secondary{background:var(--secondary-color, #6c757d);color:#fff}.btn-secondary:hover{background:var(--secondary-dark, #545b62);transform:translateY(-2px);box-shadow:0 4px 12px #6c757d4d}@media (max-width: 768px){.content-creator{padding:1rem 0}.creator-header{padding:0 1rem;margin-bottom:2rem}.creator-title{font-size:2rem}.step-indicator{gap:1rem}.step{padding:.5rem}.step-number{width:2.5rem;height:2.5rem;font-size:1rem}.step-label{font-size:.8rem}.creator-content{padding:0 1rem}.creation-complete{padding:2rem 1rem}.creation-complete h2{font-size:1.5rem}.completion-actions{flex-direction:column;align-items:center}.btn{width:100%;max-width:280px}}.error{background:var(--error-light, #f8d7da);color:var(--error-color, #721c24);padding:1rem;border-radius:8px;border:1px solid var(--error-border, #f5c6cb);margin:1rem 0;text-align:center}.loading{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:2rem;color:var(--text-secondary, #666)}.loading:before{content:"";width:1rem;height:1rem;border:2px solid var(--border-color, #e0e0e0);border-top:2px solid var(--primary-color, #007bff);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.app{min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.demo-banner{background:linear-gradient(90deg,#ff6b6b,#ee5a52);color:#fff;padding:8px 16px;font-size:14px;font-weight:500;text-align:center;box-shadow:0 2px 4px #0000001a}.demo-banner a{color:#fff;text-decoration:underline;margin-left:8px}.loading{display:flex;justify-content:center;align-items:center;min-height:200px;font-size:18px;color:#666}.loading:before{content:"⏳ ";margin-right:8px}.error{padding:16px;background:#fee;border:1px solid #fcc;border-radius:4px;color:#c00;margin:16px 0}.error:before{content:"⚠️ ";margin-right:8px}.card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:24px;margin:16px 0}.card h3{margin-top:0;color:#333}.btn{display:inline-block;padding:12px 24px;border:none;border-radius:6px;font-size:16px;font-weight:500;text-decoration:none;text-align:center;cursor:pointer;transition:all .2s ease}.btn-primary{background:#993386;color:#fff}.btn-primary:hover{background:#7a285d;transform:translateY(-1px)}.btn-secondary{background:#f5f5f5;color:#333;border:1px solid #ddd}.btn-secondary:hover{background:#e5e5e5}.container{max-width:1200px;margin:0 auto;padding:0 20px}@media (max-width: 768px){.container{padding:0 16px}.btn{width:100%;margin:8px 0}}.admin-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;font-family:inherit;line-height:1.4;cursor:pointer;text-decoration:none;transition:all .2s ease;white-space:nowrap;min-height:36px;box-shadow:0 1px 2px #0000001a}.admin-btn:focus{outline:2px solid #007bff;outline-offset:2px}.admin-btn:disabled{cursor:not-allowed;opacity:.6;transform:none!important}.admin-btn-primary{background:#007bff;color:#fff}.admin-btn-primary:hover:not(:disabled){background:#0056b3;transform:translateY(-1px);box-shadow:0 2px 4px #00000026}.admin-btn-primary:active{transform:translateY(0)}.admin-btn-secondary{background:#6c757d;color:#fff}.admin-btn-secondary:hover:not(:disabled){background:#545b62;transform:translateY(-1px);box-shadow:0 2px 4px #00000026}.admin-btn-success{background:#28a745;color:#fff}.admin-btn-success:hover:not(:disabled){background:#218838;transform:translateY(-1px);box-shadow:0 2px 4px #00000026}.admin-btn-warning{background:#ffc107;color:#212529}.admin-btn-warning:hover:not(:disabled){background:#e0a800;transform:translateY(-1px);box-shadow:0 2px 4px #00000026}.admin-btn-danger{background:#dc3545;color:#fff}.admin-btn-danger:hover:not(:disabled){background:#c82333;transform:translateY(-1px);box-shadow:0 2px 4px #00000026}.admin-btn-info{background:#17a2b8;color:#fff}.admin-btn-info:hover:not(:disabled){background:#138496;transform:translateY(-1px);box-shadow:0 2px 4px #00000026}.admin-btn-light{background:#f8f9fa;color:#495057;border:1px solid #dee2e6}.admin-btn-light:hover:not(:disabled){background:#e2e6ea;border-color:#adb5bd;transform:translateY(-1px);box-shadow:0 2px 4px #00000026}.admin-btn-sm{padding:.25rem .75rem;font-size:.75rem;min-height:28px}.admin-btn-lg{padding:.75rem 1.5rem;font-size:1rem;min-height:44px}.admin-btn.active{box-shadow:inset 0 2px 4px #0003;transform:translateY(1px)}.admin-btn-primary.active{background:#0056b3}.admin-btn-secondary.active{background:#545b62}.admin-btn-info.active{background:#138496}.admin-btn-icon{padding:.5rem;min-width:36px;justify-content:center}.admin-btn-icon.admin-btn-sm{padding:.25rem;min-width:28px}.admin-btn-group{display:inline-flex;gap:.5rem;align-items:center}.admin-btn-group .admin-btn{margin:0}.admin-btn-group-compact{display:inline-flex;border-radius:6px;overflow:hidden;box-shadow:0 1px 2px #0000001a}.admin-btn-group-compact .admin-btn{border-radius:0;margin:0;border-right:1px solid rgba(255,255,255,.2);box-shadow:none}.admin-btn-group-compact .admin-btn:last-child{border-right:none}.admin-btn-group-compact .admin-btn:hover:not(:disabled){transform:none;box-shadow:none}.admin-btn.loading{position:relative;pointer-events:none}.admin-btn.loading:before{content:"";position:absolute;top:50%;left:50%;width:16px;height:16px;margin:-8px 0 0 -8px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:admin-btn-spin 1s linear infinite}.admin-btn.loading>*{opacity:0}@keyframes admin-btn-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.admin-btn{padding:.6rem 1rem;font-size:.9rem;min-height:40px}.admin-btn-sm{padding:.4rem .8rem;font-size:.8rem;min-height:32px}.admin-btn-group{flex-wrap:wrap;gap:.75rem}}.backup-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;font-family:inherit;line-height:1.4;cursor:pointer;text-decoration:none;transition:all .2s ease;white-space:nowrap;min-height:36px;box-shadow:0 1px 2px #0000001a;background:#17a2b8;color:#fff}.backup-btn:hover:not(:disabled){background:#138496;transform:translateY(-1px);box-shadow:0 2px 4px #00000026}.backup-btn:focus{outline:2px solid #007bff;outline-offset:2px}.backup-btn:disabled{cursor:not-allowed;opacity:.6;transform:none!important}.backup-btn.active{background:#138496;box-shadow:inset 0 2px 4px #0003;transform:translateY(1px)}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;line-height:1.5}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background-color:#f8f9fa;color:#333;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;margin-bottom:.5em}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.75rem}h4{font-size:1.5rem}h5{font-size:1.25rem}h6{font-size:1rem}p{margin-bottom:1em}a{color:#993386;text-decoration:none}a:hover{text-decoration:underline}button:focus,input:focus,select:focus,textarea:focus{outline:2px solid #993386;outline-offset:2px}.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}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mb-0{margin-bottom:0}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}
