*{box-sizing:border-box}:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;font-weight:400;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}h1,h2,h3,h4,h5,h6{margin:0}a{color:#667eea;text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer}button:focus,button:focus-visible{outline:2px solid #667eea;outline-offset:2px}.dashboard-container{display:flex;flex-direction:column;height:100vh;overflow:hidden}.dashboard-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:16px 24px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a;z-index:100}.header-left{display:flex;align-items:center;gap:16px}.menu-toggle{background:#fff3;border:none;color:#fff;font-size:24px;padding:8px 12px;border-radius:6px;cursor:pointer;transition:background-color .2s}.menu-toggle:hover{background:#ffffff4d}.dashboard-header h1{margin:0;font-size:24px;font-weight:600}.logout-button{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s}.logout-button:hover{background:#ffffff4d}.dashboard-content{display:flex;flex:1;overflow:hidden}.sidebar{background:#f8f9fa;border-right:1px solid #e0e0e0;width:250px;transition:transform .3s ease;overflow-y:auto}.sidebar.closed{transform:translate(-100%);width:0;border-right:none}.sidebar-nav{padding:16px 0}.nav-item{display:block;padding:12px 24px;color:#333;text-decoration:none;transition:background-color .2s;border-left:3px solid transparent}.nav-item:hover{background-color:#e9ecef}.nav-item.active{background-color:#e9ecef;border-left-color:#667eea;font-weight:500}.main-content{flex:1;overflow-y:auto;padding:24px;background:#fff}@media(max-width:768px){.sidebar{position:fixed;left:0;top:64px;height:calc(100vh - 64px);z-index:99;box-shadow:2px 0 8px #0000001a}.sidebar.closed{transform:translate(-100%)}.main-content{padding:16px}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:12px;padding:40px;box-shadow:0 10px 40px #0000001a;width:100%;max-width:400px}.login-card h1{margin:0 0 8px;color:#333;font-size:28px;text-align:center}.login-subtitle{text-align:center;color:#666;margin:0 0 32px;font-size:14px}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:500;color:#333;font-size:14px}.form-group input{padding:12px;border:1px solid #ddd;border-radius:6px;font-size:16px;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#667eea}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:6px;font-size:14px;border:1px solid #fcc}.config-error{background-color:#fff3cd;color:#856404;border-color:#ffc107;margin-bottom:20px}.config-error strong{display:block;margin-bottom:8px}.config-error small{display:block;margin-top:8px;opacity:.8}.login-button{padding:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:500;cursor:pointer;transition:opacity .2s}.login-button:hover:not(:disabled){opacity:.9}.login-button:disabled{opacity:.6;cursor:not-allowed}.fairytales-container{max-width:1200px;margin:0 auto}.fairytales-header{margin-bottom:24px}.fairytales-header h2{margin:0;color:#333;font-size:28px}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:6px;margin-bottom:24px;border:1px solid #fcc}.empty-state{text-align:center;padding:60px 20px;color:#666;font-size:16px}.fairytales-list{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.fairytale-item-link{text-decoration:none;color:inherit;display:block}.fairytale-item{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:20px;transition:box-shadow .2s}.fairytale-item:hover{box-shadow:0 2px 8px #0000001a}.fairytale-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;gap:16px}.fairytale-title{margin:0;color:#333;font-size:20px;font-weight:600;flex:1}.fairytale-status{padding:4px 12px;border-radius:12px;color:#fff;font-size:12px;font-weight:500;text-transform:uppercase;white-space:nowrap}.fairytale-meta{display:flex;gap:24px;margin-bottom:8px;flex-wrap:wrap}.fairytale-date{color:#666;font-size:14px}.fairytale-error{color:#dc3545;font-size:14px;margin-top:8px;padding:8px;background-color:#fee;border-radius:4px}.pagination{display:flex;justify-content:center;gap:12px;margin-top:32px}.pagination-button{padding:10px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:opacity .2s}.pagination-button:hover:not(:disabled){opacity:.9}.pagination-button:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.fairytale-header{flex-direction:column;align-items:flex-start}.fairytale-meta{flex-direction:column;gap:8px}}.console-log-container{background:#1e1e1e;border-radius:6px;overflow:hidden;max-height:300px;display:flex;flex-direction:column}.console-log-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;background:#2d2d2d;color:#ccc;font-size:.85rem;font-weight:500}.console-log-spinner{animation:spin 1s linear infinite;color:#28a745}.console-log-content{padding:.5rem;overflow-y:auto;flex:1;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.8rem}.console-log-entry{display:flex;gap:.75rem;padding:.35rem .5rem;border-radius:3px;margin-bottom:2px}.console-log-entry:hover{background:#ffffff0d}.log-time{color:#888;flex-shrink:0;min-width:70px}.log-level{flex-shrink:0;min-width:55px;font-weight:600;font-size:.75rem}.console-log-info .log-level{color:#4ec9b0!important}.console-log-warning .log-level{color:#d29922!important}.console-log-error .log-level{color:#f85149!important}.log-message{color:#fff!important;word-break:break-word}.console-log-error .log-message{color:#f85149!important}.audio-generation-panel{margin-bottom:1.5rem}.audio-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.audio-panel-header h3{margin:0;color:#555}.spinner-large{width:48px;height:48px;border:4px solid rgba(40,167,69,.2);border-top-color:#28a745;border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.audio-generation-progress{margin-top:1rem;padding:1.5rem;background:#f8f9fa;border:2px dashed #28a745;border-radius:8px}.progress-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.progress-info{flex:1}.progress-title{margin:0;font-weight:600;color:#333}.progress-subtitle{margin:.25rem 0 0;font-size:.9rem;color:#666}.audio-empty-state{padding:1rem;background:#fff;border-radius:4px;border:1px solid #dee2e6}.audio-empty-state p{margin:0;color:#666}.primary-audio-section{margin-top:1rem}.audio-section-title{margin:0 0 .75rem;color:#555;font-size:1rem;font-weight:600}.audio-section-description{margin:0 0 1rem;color:#666;font-size:.9rem}.all-audios-section{margin-top:2rem;padding:1.5rem;background:#f8f9fa;border-radius:8px;border:1px solid #dee2e6}.audios-list{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.audio-item{padding:1rem;background:#fff;border:2px solid #dee2e6;border-radius:8px;transition:all .2s}.audio-item:hover{border-color:#adb5bd}.audio-item-primary{border-color:#28a745;background:#f8fff9}.audio-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.audio-item-number{font-weight:600;color:#555;font-size:.95rem}.audio-item-badge{padding:.25rem .75rem;background:#28a745;color:#fff;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.audio-item-player{width:100%;max-width:100%;margin-bottom:.75rem}.set-primary-button{padding:.5rem 1rem;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background-color .2s}.set-primary-button:hover{background:#0056b3}.audio-item-metadata{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;font-size:.8rem}.audio-item-provider{padding:.15rem .5rem;background:#e9ecef;color:#495057;border-radius:4px;text-transform:capitalize}.audio-item-voice{padding:.15rem .5rem;background:#f8f9fa;color:#6c757d;border-radius:4px;font-family:monospace}.audio-item-date{color:#6c757d}.audio-item-duration{padding:.15rem .5rem;background:#d4edda;color:#155724;border-radius:4px;font-weight:600}.audio-item-warning{color:#856404;font-style:italic}.audio-item-badge-timing{background:#17a2b8}.audio-item-legacy{border-style:dashed;opacity:.85}.audio-timing-warning{margin-top:1rem;padding:.75rem 1rem;background:#fff3cd;border:1px solid #ffc107;border-radius:4px}.audio-timing-warning p{margin:0;color:#856404;font-size:.9rem}.audio-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.audio-modal-content{background:#fff;border-radius:8px;max-width:550px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 6px #0000001a}.audio-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #dee2e6}.audio-modal-header h3{margin:0;color:#333;font-size:1.25rem}.audio-modal-close{background:none;border:none;font-size:2rem;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;line-height:1}.audio-modal-close:hover{color:#333}.audio-modal-body{padding:1.5rem}.audio-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid #dee2e6}.settings-section{margin-bottom:1.5rem}.settings-section:last-child{margin-bottom:0}.section-label{display:block;margin-bottom:.75rem;font-weight:600;color:#333;font-size:.95rem}.provider-selection{display:flex;flex-direction:column;gap:.75rem}.provider-option{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;border:2px solid #dee2e6;border-radius:8px;cursor:pointer;transition:all .2s}.provider-option:hover{border-color:#adb5bd}.provider-option:has(input:checked){border-color:#28a745;background:#f8fff9}.provider-option input[type=radio]{margin-top:2px;accent-color:#28a745}.provider-info{display:flex;flex-direction:column;gap:.25rem}.provider-name{font-weight:600;color:#333}.provider-desc{font-size:.85rem;color:#666}.settings-group{margin-bottom:1.25rem}.setting-description{font-size:.85rem;color:#666;margin-top:.5rem;line-height:1.4}.voice-select{width:100%;padding:.75rem;border:1px solid #dee2e6;border-radius:4px;font-size:1rem;background:#fff}.voice-select:focus{outline:none;border-color:#28a745;box-shadow:0 0 0 2px #28a74526}.chatterbox-settings,.elevenlabs-settings{padding:1rem;background:#f8f9fa;border-radius:8px;border:1px solid #dee2e6}.fairytale-detail-container{padding:2rem;max-width:1200px;margin:0 auto}.fairytale-detail-header{margin-bottom:2rem}.back-link{display:inline-block;margin-bottom:1rem;color:#007bff;text-decoration:none;font-size:.9rem}.fairytale-detail-header h1{margin:0;color:#333}.fairytale-info-section{background:#f8f9fa;padding:1.5rem;border-radius:8px;margin-bottom:2rem}.fairytale-info-section h2{margin-top:0;margin-bottom:1.5rem;color:#333}.audio-section{margin-bottom:1.5rem}.audio-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.audio-section h3{margin:0;color:#555}.audio-player{width:100%;max-width:600px;margin-top:.5rem}.audio-metadata{margin-top:1rem;padding:.75rem;background:#f8f9fa;border-radius:4px;display:flex;flex-wrap:wrap;gap:1rem}.audio-metadata-item{font-size:.9rem;color:#666}.audio-metadata-item strong{color:#555;font-weight:600}.audio-timing-section{margin-top:1rem;padding:1rem;background:#f8f9fa;border-radius:4px;border:1px solid #dee2e6}.audio-timing-section h4{margin:0 0 .75rem;color:#555;font-size:1rem;font-weight:600}.audio-timing-grid{display:flex;flex-direction:column;gap:.5rem}.timing-item{display:flex;justify-content:space-between;align-items:flex-start;padding:.5rem;background:#fff;border-radius:4px;font-size:.9rem}.timing-item strong{color:#555;font-weight:600;margin-right:.5rem}.timing-item span{color:#666;text-align:right;flex:1}.timing-item.total{background:#e7f3ff;font-weight:600}.timing-item.total strong,.timing-item.total span{color:#0056b3}.audio-generate-section{padding:1rem;background:#fff;border-radius:4px;border:1px solid #dee2e6;display:flex;flex-direction:column;gap:1rem;align-items:flex-start}.audio-generate-section p{margin:0;color:#666}.generate-audio-button{padding:.75rem 1.5rem;background:#28a745;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:500;transition:background-color .2s;display:flex;align-items:center;gap:.5rem}.generate-audio-button:hover:not(:disabled){background:#218838}.generate-audio-button:disabled{background:#6c757d;cursor:not-allowed;opacity:.8}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.spinner-large{width:48px;height:48px;border:4px solid rgba(40,167,69,.2);border-top-color:#28a745;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.audio-loading-state{margin-top:1rem;padding:2rem;background:#f8f9fa;border:2px dashed #28a745;border-radius:8px;text-align:center}.loading-indicator{display:flex;flex-direction:column;align-items:center}.loading-indicator p{margin:.5rem 0 0;color:#555;font-weight:500}.loading-indicator .loading-note{margin-top:.5rem;font-size:.9rem;color:#666;font-weight:400}.info-grid{display:flex;flex-direction:column;gap:1.5rem}.info-item{display:flex;flex-direction:column;gap:.5rem}.info-item strong{color:#555;font-weight:600}.info-item.paragraphs{gap:1rem}.paragraphs-list{display:flex;flex-direction:column;gap:1rem}.paragraph{margin:0;padding:1rem;background:#fff;border-radius:4px;line-height:1.6;color:#333}.fairytale-image{max-width:100%;max-height:400px;object-fit:contain;border-radius:4px;margin-top:.5rem}.source-link{color:#007bff;text-decoration:none;word-break:break-all}.source-link:hover{text-decoration:underline}.videos-section{background:#f8f9fa;padding:1.5rem;border-radius:8px;margin-bottom:1.5rem}.videos-section:last-of-type{margin-bottom:0}.videos-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.videos-header h2{margin:0;color:#333}.create-video-button{padding:.75rem 1.5rem;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:500}.create-video-button:hover{background:#0056b3}.create-video-button.image-video-button{background:linear-gradient(135deg,#6f42c1,#5a32a3)}.create-video-button.image-video-button:hover{background:linear-gradient(135deg,#5a32a3,#4a2892)}.empty-state{text-align:center;padding:2rem;color:#666}.videos-list{display:flex;flex-direction:column;gap:1rem}.video-item{background:#fff;padding:1.5rem;border-radius:4px;display:flex;justify-content:space-between;align-items:flex-start;box-shadow:0 1px 3px #0000001a}.video-info{flex:1;display:flex;flex-direction:column;gap:.5rem}.video-id{font-weight:600;color:#333}.video-date{font-size:.9rem;color:#666}.video-status{font-size:.9rem;color:#007bff}.video-error{font-size:.9rem;color:#dc3545}.video-actions{display:flex;gap:.5rem}.edit-button,.delete-button{padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.edit-button{background:#28a745;color:#fff}.edit-button:hover{background:#218838}.delete-button{background:#dc3545;color:#fff}.delete-button:hover{background:#c82333}.delete-button:disabled{background:#ccc;cursor:not-allowed}.loading,.error-message{text-align:center;padding:2rem}.error-message{color:#dc3545}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:8px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 6px #0000001a}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #dee2e6}.modal-header h3{margin:0;color:#333;font-size:1.25rem}.modal-close{background:none;border:none;font-size:2rem;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;line-height:1}.modal-close:hover{color:#333}.modal-body{padding:1.5rem}.settings-group{margin-bottom:1.5rem}.settings-group:last-child{margin-bottom:0}.settings-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#555}.setting-value{color:#007bff;font-weight:600}.setting-slider{width:100%;margin:.5rem 0}.setting-description{font-size:.875rem;color:#666;margin-top:.5rem;line-height:1.4}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid #dee2e6}.modal-button{padding:.75rem 1.5rem;border:none;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:500;transition:background-color .2s}.modal-button.cancel{background:#6c757d;color:#fff}.modal-button.cancel:hover{background:#5a6268}.modal-button.confirm{background:#28a745;color:#fff}.modal-button.confirm:hover{background:#218838}.video-edit-container{padding:1.5rem;max-width:1600px;margin:0 auto;min-height:100vh;background:#f8f9fa}.video-edit-header{margin-bottom:1.5rem}.back-link{display:inline-block;margin-bottom:.75rem;color:#007bff;text-decoration:none;font-size:.9rem}.video-edit-header h1{margin:0;color:#333;font-size:1.5rem}.error-message{background:#f8d7da;color:#721c24;padding:1rem;border-radius:8px;margin-bottom:1.5rem}.loading{text-align:center;padding:3rem;color:#666;font-size:1.1rem}.status-badge{display:inline-block;padding:.2rem .6rem;border-radius:12px;font-size:.75rem;font-weight:500;color:#fff;text-transform:uppercase}.style-guide-bar{background:#fff;border-radius:12px;padding:1rem 1.5rem;margin-bottom:1.5rem;box-shadow:0 2px 4px #0000000d}.style-guide-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.style-guide-actions{display:flex;align-items:center;gap:.75rem}.style-guide-fields{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem}@media(max-width:1200px){.style-guide-fields{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.style-guide-fields{grid-template-columns:1fr}}.style-field{display:flex;flex-direction:column;gap:.3rem}.style-field label{font-size:.75rem;font-weight:600;color:#666;text-transform:uppercase}.style-field input{padding:.5rem .75rem;border:1px solid #ddd;border-radius:6px;font-size:.85rem}.style-field input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.style-field input:disabled{background:#f5f5f5;cursor:not-allowed}.batch-actions-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:0 .5rem}.three-column-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:2rem}@media(max-width:1200px){.three-column-grid{grid-template-columns:1fr}}.scene-column{background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 2px 4px #0000000d;position:relative}.scene-column.first:before,.scene-column:not(.last):after{display:none}@media(min-width:1201px){.scene-column:not(.last):after{content:"→";position:absolute;right:-1.25rem;top:50%;transform:translateY(-50%);font-size:1.5rem;color:#007bff;font-weight:700;z-index:1}}.scene-header{margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #eee}.scene-header h3{margin:0;font-size:1rem;color:#333}.paragraph-card{background:#f8f9fa;border-radius:8px;padding:1rem;margin-bottom:1rem;max-height:120px;overflow-y:auto}.paragraph-card p{margin:0;font-size:.9rem;color:#555;line-height:1.5}.prompt-section{margin-bottom:1rem}.prompt-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.prompt-header label{font-size:.85rem;font-weight:600;color:#333}.prompt-section textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:.85rem;font-family:inherit;resize:vertical;min-height:60px}.prompt-section textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.prompt-section textarea:disabled{background:#f5f5f5;cursor:not-allowed}.prompt-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.5rem}.transition-hint{font-size:.75rem;color:#666;font-style:italic;margin-top:.5rem;padding:.5rem;background:#f0f7ff;border-radius:4px}.media-preview{margin-bottom:1rem}.media-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.media-header label{font-size:.85rem;font-weight:600;color:#333}.media-container{background:#f0f0f0;border-radius:8px;overflow:hidden;aspect-ratio:9 / 16;display:flex;align-items:center;justify-content:center;max-height:400px;margin:0 auto}.media-container img{width:100%;height:100%;object-fit:contain}.media-container video{width:100%;height:100%;object-fit:contain}.media-placeholder{color:#999;font-size:.85rem}.loading-skeleton{width:100%;height:100%;min-height:300px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.loading-skeleton.video{min-height:300px;background-color:#333;background:linear-gradient(90deg,#333 25%,#444,#333 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.flow-arrow{display:none;text-align:center;font-size:1.5rem;color:#007bff;padding:.5rem 0}@media(max-width:1200px){.flow-arrow{display:block;transform:rotate(90deg)}}.generate-btn{padding:.6rem 1.2rem;background:#007bff;color:#fff;border:none;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .2s}.generate-btn:hover:not(:disabled){background:#0056b3}.generate-btn:disabled{background:#ccc;cursor:not-allowed}.generate-btn.small{padding:.4rem .8rem;font-size:.8rem}.generate-btn.full-width{width:100%;margin-top:.5rem}.save-btn{padding:.6rem 1.2rem;background:#28a745;color:#fff;border:none;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .2s}.save-btn:hover:not(:disabled){background:#1e7e34}.save-btn.small{padding:.4rem .8rem;font-size:.8rem}.video-edit-actions{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d}.cancel-button{padding:.75rem 1.5rem;background:#6c757d;color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s}.preview-button{padding:.75rem 1.5rem;background:#17a2b8;color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s}.preview-button:hover{background:#138496}.placeholder-text{color:#666;font-size:.9rem;font-style:italic;text-align:center;padding:1rem}.final-video-section{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 2px 4px #0000000d;border:2px solid #28a745}.final-video-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #eee}.final-video-header h2{margin:0;font-size:1.25rem;color:#333}.final-video-status{display:flex;align-items:center;gap:.5rem}.final-video-preview{display:flex;flex-direction:column;gap:1rem}.final-video-player{width:auto;max-width:100%;max-height:600px;aspect-ratio:9 / 16;margin:0 auto;border-radius:8px;box-shadow:0 4px 12px #00000026}.final-video-actions{display:flex;justify-content:center;gap:1rem;margin-top:1rem}.final-video-placeholder{text-align:center;padding:2rem;background:#f8f9fa;border-radius:8px}.final-video-placeholder p{margin:0 0 1rem;color:#666;font-size:1rem}.final-video-placeholder .warning-text{color:#856404;background:#fff3cd;padding:.75rem;border-radius:6px;margin-top:1rem}.generate-btn.large{padding:1rem 2rem;font-size:1.1rem}.download-btn{display:inline-block;padding:.75rem 1.5rem;background:#28a745;color:#fff;text-decoration:none;border-radius:6px;font-size:.9rem;font-weight:500;transition:background .2s}.download-btn:hover{background:#1e7e34;color:#fff}.assembly-logs-container{background:#f8f9fa;border-radius:8px;padding:1rem;margin-bottom:1rem;max-height:400px;overflow-y:auto;border:1px solid #dee2e6}.assembly-logs-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid #dee2e6}.assembly-logs-header h3{margin:0;font-size:.95rem;color:#333;font-weight:600}.spinner{display:inline-block;animation:spin 1s linear infinite;font-size:1.2rem;color:#007bff}.assembly-logs{display:flex;flex-direction:column;gap:.5rem}.assembly-log-entry{display:grid;grid-template-columns:auto auto 1fr;gap:.75rem;padding:.5rem .75rem;border-radius:4px;font-size:.85rem;font-family:Monaco,Menlo,Ubuntu Mono,monospace;align-items:center}.assembly-log-info{background:#e7f3ff;color:#004085;border-left:3px solid #007bff}.assembly-log-warning{background:#fff3cd;color:#856404;border-left:3px solid #ffc107}.assembly-log-error{background:#f8d7da;color:#721c24;border-left:3px solid #dc3545}.log-time{color:#666;font-size:.75rem;min-width:80px}.log-level{font-weight:600;font-size:.7rem;min-width:50px;text-align:center;padding:.15rem .4rem;border-radius:3px;background:#0000001a}.assembly-log-info .log-level{background:#007bff33}.assembly-log-warning .log-level{background:#ffc10733}.assembly-log-error .log-level{background:#dc354533}.log-message{color:inherit;word-break:break-word}.finetune-overlay-content{background:#fff;border-radius:16px;max-width:1100px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}.finetune-overlay-body{padding:24px;overflow-y:auto;display:flex;flex-direction:column;gap:24px}.finetune-main-section{display:grid;grid-template-columns:1fr 1fr;gap:24px}@media(max-width:768px){.finetune-main-section{grid-template-columns:1fr}}.finetune-image-preview{display:flex;align-items:center;justify-content:center;background:#f8f9fa;border-radius:12px;overflow:hidden;aspect-ratio:9 / 16;max-height:450px;position:relative}.prompt-label{font-size:.85rem;font-weight:600;color:#555}.original-prompt-display{background:#f8f9fa;padding:12px 16px;border-radius:8px;font-size:.9rem;line-height:1.6;color:#555;border:1px solid #e0e0e0;max-height:120px;overflow-y:auto}.finetune-prompt-section textarea{padding:12px 16px;border:1px solid #ddd;border-radius:8px;font-size:.95rem;font-family:inherit;resize:vertical;min-height:100px;line-height:1.6}.temperature-control{display:flex;flex-direction:column;gap:6px;padding:12px 0}.temperature-control label{font-size:.85rem;color:#555;font-weight:500}.temperature-control input[type=range]:disabled{cursor:not-allowed;opacity:.5}.finetune-gallery-section{border-top:1px solid #e0e0e0;padding-top:20px}.gallery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.gallery-header h4{margin:0;font-size:1rem;color:#333;font-weight:600}.use-as-base-btn{background:#28a745;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.use-as-base-btn:hover:not(:disabled){background:#218838;transform:translateY(-1px);box-shadow:0 2px 8px #28a7454d}.use-as-base-btn:disabled{background:#ccc;cursor:not-allowed}.finetune-gallery{display:flex;gap:12px;overflow-x:auto;padding:8px 0}.gallery-thumbnail{position:relative;flex-shrink:0;width:80px;height:120px;border-radius:8px;overflow:hidden;border:3px solid transparent;cursor:pointer;transition:all .2s;background:#f0f0f0;padding:0}.gallery-thumbnail img{width:100%;height:100%;object-fit:cover}.gallery-thumbnail:hover:not(:disabled){transform:scale(1.05);border-color:#007bff}.gallery-thumbnail.selected{border-color:#007bff;box-shadow:0 0 0 3px #007bff33}.gallery-thumbnail.active{border-color:#28a745}.gallery-thumbnail.selected.active{border-color:#007bff;box-shadow:0 0 0 3px #007bff33}.gallery-thumbnail:disabled{cursor:not-allowed;opacity:.6}.thumbnail-badges{position:absolute;top:4px;right:4px;display:flex;flex-direction:column;gap:4px;align-items:flex-end}.active-badge{background:#28a745;color:#fff;padding:2px 6px;border-radius:4px;font-size:.6rem;font-weight:600;text-transform:uppercase;box-shadow:0 1px 3px #0003}.selected-badge{background:#007bff;color:#fff;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;box-shadow:0 1px 3px #0003}.gallery-hint{margin:12px 0 0;font-size:.8rem;color:#888;font-style:italic}.image-video-edit-container{max-width:1400px;margin:0 auto;padding:20px}.image-video-edit-header{margin-bottom:24px}.image-video-edit-header h1{margin:12px 0 0;font-size:1.75rem;color:#1a1a2e}.back-link{color:#007bff;text-decoration:none;font-size:.9rem}.status-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:500;color:#fff;text-transform:uppercase;letter-spacing:.5px}.error-message{background-color:#ffebee;border:1px solid #ef5350;color:#c62828;padding:12px 16px;border-radius:8px;margin-bottom:16px}.loading{text-align:center;padding:48px;color:#666;font-size:1.1rem}.generation-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;background:#f8f9fa;border-radius:12px;margin:24px 0;border:2px dashed #007bff}.generation-loading .loading-spinner{font-size:3rem;color:#007bff;animation:spin 1s linear infinite;margin-bottom:16px}.generation-loading p{margin:0;font-size:1rem;color:#555;font-weight:500}.style-guide-bar{background:linear-gradient(135deg,#f8f9fa,#fff);border:1px solid #e0e0e0;border-radius:12px;padding:16px 20px;margin-bottom:24px;box-shadow:0 2px 8px #0000000d}.style-guide-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.style-guide-header h2{margin:0;font-size:1.1rem;color:#333;cursor:pointer;-webkit-user-select:none;user-select:none}.style-guide-header h2:hover{color:#007bff}.style-guide-actions{display:flex;align-items:center;gap:12px}.style-guide-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-top:16px;padding-top:16px;border-top:1px solid #e0e0e0}.style-field{display:flex;flex-direction:column;gap:6px}.style-field label{font-size:.85rem;font-weight:600;color:#555}.style-field input{padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:.9rem;transition:border-color .2s}.style-field input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.placeholder-text{color:#888;font-style:italic;margin:0;grid-column:1 / -1}.batch-actions-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:12px 16px;background:#f0f4f8;border-radius:8px}.batch-actions-row h2{margin:0;font-size:1.1rem;color:#333}.generate-btn{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;border:none;padding:10px 18px;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.generate-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #007bff4d}.generate-btn:disabled{background:#ccc;cursor:not-allowed;transform:none;box-shadow:none}.generate-btn.small{padding:6px 12px;font-size:.8rem}.generate-btn.large{padding:14px 28px;font-size:1rem}.save-btn{background:#28a745;color:#fff;border:none;padding:10px 18px;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.save-btn:hover:not(:disabled){background:#218838}.save-btn:disabled{background:#ccc;cursor:not-allowed}.save-btn.small{padding:6px 12px;font-size:.8rem}.cancel-button{background:#6c757d;color:#fff;border:none;padding:10px 18px;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s}.cancel-button:hover{background:#5a6268}.download-btn{display:inline-block;background:#17a2b8;color:#fff;border:none;padding:10px 18px;border-radius:6px;font-size:.9rem;font-weight:500;text-decoration:none;cursor:pointer;transition:background .2s}.download-btn:hover{background:#138496;color:#fff}.storyboard-grid{display:flex;flex-direction:column;gap:24px;margin-bottom:32px}.paragraph-storyboard{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000000d}.paragraph-header{margin-bottom:12px}.paragraph-header h3{margin:0;font-size:1.1rem;color:#333}.paragraph-text{background:#f8f9fa;padding:12px 16px;border-radius:8px;margin-bottom:16px}.paragraph-text p{margin:0;font-size:.95rem;line-height:1.6;color:#444}.frames-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}@media(max-width:900px){.frames-row{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.frames-row{grid-template-columns:1fr}}.frame-cell{background:#fafafa;border:1px solid #e8e8e8;border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:10px}.frame-header{display:flex;justify-content:space-between;align-items:flex-start}.frame-label-group{display:flex;flex-direction:column;gap:2px}.frame-label{font-size:.85rem;font-weight:600;color:#555}.shot-type-hint{font-size:.7rem;color:#888;font-weight:400}.frame-image-container{aspect-ratio:9 / 16;background:#e8e8e8;border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center;position:relative}.frame-image-container img{width:100%;height:100%;object-fit:cover}.frame-image-container .loading-skeleton{width:100%;height:100%;background:linear-gradient(90deg,#e0e0e0 25%,#f0f0f0,#e0e0e0 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.image-placeholder{color:#999;font-size:.85rem;text-align:center}.edit-image-btn{position:absolute;bottom:8px;right:8px;background:#007bffe6;color:#fff;border:none;padding:6px 12px;border-radius:6px;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s;opacity:1;box-shadow:0 2px 8px #0003}.edit-image-btn:hover:not(:disabled){background:#007bff;transform:scale(1.05);box-shadow:0 4px 12px #007bff66}.edit-image-btn:disabled{background:#80808080;cursor:not-allowed;opacity:.6}.image-variants-strip{display:flex;gap:8px;padding:8px 0;overflow-x:auto;border-top:1px solid #e0e0e0;border-bottom:1px solid #e0e0e0;margin:8px 0}.variant-thumbnail{position:relative;flex-shrink:0;width:60px;height:80px;border-radius:6px;overflow:hidden;border:2px solid transparent;cursor:pointer;transition:all .2s;background:#f0f0f0;padding:0}.variant-thumbnail img{width:100%;height:100%;object-fit:cover}.variant-thumbnail:hover:not(:disabled){transform:scale(1.05);border-color:#007bff}.variant-thumbnail.active{border-color:#28a745;box-shadow:0 0 0 2px #28a74533}.variant-thumbnail:disabled{cursor:not-allowed;opacity:.6}.active-indicator{position:absolute;top:2px;right:2px;background:#28a745;color:#fff;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;box-shadow:0 2px 4px #0003}.finetune-overlay-backdrop{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.finetune-overlay-content{background:#fff;border-radius:16px;max-width:900px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.finetune-overlay-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e0e0e0;background:linear-gradient(135deg,#f8f9fa,#fff)}.finetune-overlay-header h3{margin:0;font-size:1.3rem;color:#333;font-weight:600}.close-btn{background:#f0f0f0;border:none;width:32px;height:32px;border-radius:50%;font-size:1.2rem;color:#666;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;padding:0}.close-btn:hover:not(:disabled){background:#e0e0e0;color:#333;transform:scale(1.1)}.close-btn:disabled{cursor:not-allowed;opacity:.5}.finetune-overlay-body{padding:24px;overflow-y:auto;display:grid;grid-template-columns:1fr 1fr;gap:24px}@media(max-width:768px){.finetune-overlay-body{grid-template-columns:1fr}}.finetune-image-preview{display:flex;align-items:center;justify-content:center;background:#f8f9fa;border-radius:12px;overflow:hidden;aspect-ratio:9 / 16;max-height:500px;position:relative}.finetune-image-preview img{width:100%;height:100%;object-fit:contain}.generating-overlay{position:absolute;inset:0;background:#f8f9faf2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}.generating-overlay .loading-spinner{font-size:3rem;color:#007bff;animation:spin 1s linear infinite}.generating-overlay p{margin:0;font-size:1rem;color:#555;font-weight:500}.finetune-prompt-section{display:flex;flex-direction:column;gap:16px}.original-prompt-display{background:#f8f9fa;padding:12px 16px;border-radius:8px;font-size:.9rem;line-height:1.6;color:#555;border:1px solid #e0e0e0;max-height:150px;overflow-y:auto}.finetune-prompt-section textarea{padding:12px 16px;border:1px solid #ddd;border-radius:8px;font-size:.95rem;font-family:inherit;resize:vertical;min-height:120px;line-height:1.6}.finetune-prompt-section textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.hint-text{font-weight:400;color:#888;font-size:.85rem}.generating-hint{text-align:center;color:#007bff;font-size:.9rem;margin:12px 0 0;padding:12px;background:#007bff0d;border-radius:6px;border:1px solid rgba(0,123,255,.2)}.finetune-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:auto;padding-top:16px;border-top:1px solid #e0e0e0}.frame-prompt-section{display:flex;flex-direction:column;gap:8px}.prompt-label{font-size:.8rem;font-weight:600;color:#555}.frame-prompt-section textarea{padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:.85rem;font-family:inherit;resize:vertical;min-height:100px;max-height:250px;line-height:1.5;overflow-y:auto}.frame-prompt-section textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.temperature-control{display:flex;flex-direction:column;gap:4px;padding:8px 0}.temperature-control label{font-size:.8rem;color:#666;font-weight:500}.temperature-control input[type=range]{width:100%;cursor:pointer;accent-color:#007bff}.frame-actions{display:flex;gap:8px;justify-content:flex-end}.final-video-section{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;padding:24px;margin-bottom:24px;color:#fff}.final-video-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.final-video-header h2{margin:0;font-size:1.3rem;color:#fff;font-weight:600}.final-video-status .status-badge{font-size:.8rem}.final-video-preview{display:flex;flex-direction:column;align-items:center;gap:20px}.final-video-player{max-width:400px;width:100%;border-radius:12px;box-shadow:0 8px 24px #0000004d}.final-video-actions{display:flex;gap:16px;flex-wrap:wrap;justify-content:center}.final-video-placeholder{text-align:center;padding:32px 20px}.final-video-placeholder p{margin:0 0 20px;font-size:1rem;color:#ffffffe6}.final-video-placeholder .placeholder-text{color:#fffc;font-style:italic}.warning-text{color:#ffc107!important;margin-top:12px!important;font-size:.9rem!important}.assembly-logs-wrapper{margin-bottom:20px}.videos-grid-container{display:flex;flex-direction:column;gap:20px}.videos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}@media(max-width:768px){.videos-grid{grid-template-columns:1fr}}.video-card{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:16px;position:relative;transition:all .3s ease}.video-card:hover{background:#ffffff26;border-color:#ffffff4d;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.video-card.latest{border:2px solid #4dd0e1;background:#4dd0e11a}.latest-badge{position:absolute;top:12px;right:12px;background:linear-gradient(135deg,#4dd0e1,#26c6da);color:#fff;padding:4px 10px;border-radius:12px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 6px #0003}.video-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.video-card-header h4{margin:0;font-size:1rem;font-weight:600;color:#fff}.video-date{font-size:.75rem;color:#ffffffb3;font-family:monospace}.video-card-preview{width:100%;margin-bottom:12px;border-radius:8px;overflow:hidden;background:#0000004d}.video-player-small{width:100%;max-height:400px;display:block;border-radius:8px}.video-card-actions{display:flex;gap:8px;justify-content:flex-end}.download-btn.small{padding:6px 12px;font-size:.8rem}.videos-actions{display:flex;justify-content:center;gap:12px;padding-top:16px;border-top:1px solid rgba(255,255,255,.2)}.youtube-upload-btn{background:linear-gradient(135deg,red,#c00);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}.youtube-upload-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #ff00004d}.youtube-upload-btn:disabled{background:#999;cursor:not-allowed;transform:none;box-shadow:none}.youtube-status-row{display:flex;align-items:center;gap:12px;margin-top:12px;padding:12px 16px;background:#ffffff1a;border-radius:8px}.youtube-link{color:#ff6b6b;text-decoration:none;font-weight:500;transition:color .2s}.youtube-link:hover{color:red;text-decoration:underline}.error-text{color:#ff6b6b;font-size:.85rem}.image-video-edit-actions{display:flex;justify-content:flex-start;gap:16px;padding-top:16px;border-top:1px solid #e0e0e0}.posts-container{max-width:1200px;margin:0 auto}.posts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.posts-header h2{margin:0;color:#333;font-size:28px}.trigger-btn{padding:10px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:opacity .2s}.trigger-btn:hover:not(:disabled){opacity:.9}.trigger-btn:disabled{opacity:.5;cursor:not-allowed}.posts-list{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.post-item{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:20px;transition:box-shadow .2s}.post-item:hover{box-shadow:0 2px 8px #0000001a}.post-item-header{margin-bottom:12px}.post-title-row{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:8px}.post-title-link{text-decoration:none;flex:1}.post-title-link:hover .post-title{color:#667eea}.post-title{margin:0;color:#333;font-size:18px;font-weight:600;transition:color .2s}.post-status{padding:4px 12px;border-radius:12px;color:#fff;font-size:12px;font-weight:500;text-transform:uppercase;white-space:nowrap}.post-processing-step{color:#007bff;font-size:12px;font-style:italic;white-space:nowrap}.post-meta{display:flex;gap:16px;flex-wrap:wrap}.post-date,.post-created-by,.post-news-source{color:#666;font-size:13px}.post-created-by{padding:1px 8px;background:#f0f0f0;border-radius:4px}.post-platform-statuses{display:flex;gap:8px;margin-top:6px}.platform-badge{padding:2px 10px;border-radius:10px;color:#fff;font-size:11px;font-weight:500;white-space:nowrap}.post-body{display:flex;gap:16px;margin-bottom:12px}.post-thumbnail{flex-shrink:0;width:80px;height:80px;border-radius:6px;overflow:hidden}.post-thumbnail img{width:100%;height:100%;object-fit:cover}.post-content{flex:1;min-width:0}.post-description{margin:0 0 8px;color:#444;font-size:14px;line-height:1.5}.post-hashtags{display:flex;flex-wrap:wrap;gap:6px}.post-actions{display:flex;gap:8px;padding-top:12px;border-top:1px solid #f0f0f0}.post-action-btn{padding:6px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;text-decoration:none;transition:opacity .2s}.post-action-btn:hover{opacity:.9;color:#fff}.post-action-btn.secondary{background:#f0f0f0;color:#555}.post-action-btn.secondary:hover{background:#e0e0e0;color:#333}@media(max-width:768px){.posts-header{flex-direction:column;align-items:flex-start;gap:12px}.post-title-row{flex-direction:column;align-items:flex-start}.post-body{flex-direction:column}.post-thumbnail{width:100%;height:120px}.post-meta{flex-direction:column;gap:4px}.post-actions{flex-wrap:wrap}}.youtube-modal-backdrop{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:youtubeModalFadeIn .2s ease-out}@keyframes youtubeModalFadeIn{0%{opacity:0}to{opacity:1}}.youtube-modal-content{background:#fff;border-radius:16px;max-width:600px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:youtubeModalSlideUp .3s ease-out}.youtube-modal-content.youtube-modal-success{max-width:400px}@keyframes youtubeModalSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.youtube-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e0e0e0;background:linear-gradient(135deg,red,#c00)}.youtube-modal-header h3{margin:0;font-size:1.3rem;color:#fff;font-weight:600}.youtube-modal-header .close-btn{background:#fff3;border:none;width:32px;height:32px;border-radius:50%;font-size:1.2rem;color:#fff;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;padding:0}.youtube-modal-header .close-btn:hover:not(:disabled){background:#ffffff4d;transform:scale(1.1)}.youtube-modal-header .close-btn:disabled{cursor:not-allowed;opacity:.5}.youtube-modal-body{padding:24px;overflow-y:auto;display:flex;flex-direction:column;gap:20px}.youtube-success-content{display:flex;flex-direction:column;align-items:center;gap:16px;padding:24px 0;text-align:center}.youtube-icon-large{width:80px;height:80px;background:red;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;color:#fff}.youtube-success-content p{margin:0;font-size:1.1rem;color:#333}.youtube-link-button{background:red;color:#fff;text-decoration:none;padding:12px 24px;border-radius:8px;font-weight:600;transition:all .2s}.youtube-link-button:hover{background:#c00;transform:translateY(-2px);box-shadow:0 4px 12px #ff00004d}.youtube-error-message{background:#fff5f5;border:1px solid #feb2b2;color:#c53030;padding:12px 16px;border-radius:8px;font-size:.9rem}.youtube-form-group{display:flex;flex-direction:column;gap:8px;position:relative}.youtube-form-group label{font-size:.9rem;font-weight:600;color:#333}.label-with-button{display:flex;justify-content:space-between;align-items:center}.youtube-form-group input[type=text],.youtube-form-group textarea,.youtube-form-group select{padding:12px 16px;border:1px solid #ddd;border-radius:8px;font-size:.95rem;font-family:inherit;transition:border-color .2s,box-shadow .2s}.youtube-form-group input[type=text]:focus,.youtube-form-group textarea:focus,.youtube-form-group select:focus{outline:none;border-color:red;box-shadow:0 0 0 3px #ff00001a}.youtube-form-group textarea{resize:vertical;min-height:120px;line-height:1.6}.youtube-form-group select{cursor:pointer;background:#fff}.char-count{position:absolute;right:12px;bottom:12px;font-size:.75rem;color:#888}.generate-ai-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:6px 12px;border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.generate-ai-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.generate-ai-btn:disabled{background:#ccc;cursor:not-allowed}.tags-input-container{display:flex;gap:8px}.tags-input-container input{flex:1}.add-tag-btn{background:#28a745;color:#fff;border:none;padding:12px 16px;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s}.add-tag-btn:hover:not(:disabled){background:#218838}.add-tag-btn:disabled{background:#ccc;cursor:not-allowed}.tags-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.tag-chip{display:inline-flex;align-items:center;gap:6px;background:#f0f0f0;padding:6px 10px;border-radius:16px;font-size:.85rem;color:#333}.remove-tag-btn{background:none;border:none;color:#666;cursor:pointer;font-size:.75rem;padding:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.remove-tag-btn:hover:not(:disabled){background:#ddd;color:#333}.remove-tag-btn:disabled{cursor:not-allowed;opacity:.5}.youtube-modal-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:16px;border-top:1px solid #e0e0e0;margin-top:8px}.cancel-button{background:#6c757d;color:#fff;border:none;padding:12px 20px;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .2s}.cancel-button:hover:not(:disabled){background:#5a6268}.cancel-button:disabled{background:#aaa;cursor:not-allowed}.upload-button{background:linear-gradient(135deg,red,#c00);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.upload-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #ff00004d}.upload-button:disabled{background:#ccc;cursor:not-allowed;transform:none;box-shadow:none}.schedule-datetime-input{padding:12px 16px;border:1px solid #ddd;border-radius:8px;font-size:.95rem;font-family:inherit;transition:border-color .2s,box-shadow .2s}.schedule-datetime-input:focus{outline:none;border-color:red;box-shadow:0 0 0 3px #ff00001a}.schedule-hint{font-size:.8rem;color:#888;font-style:italic}.upload-hint{text-align:center;color:red;font-size:.9rem;margin:12px 0 0;padding:12px;background:#ff00000d;border-radius:6px;border:1px solid rgba(255,0,0,.2)}.label-hint{font-weight:400;font-size:.8rem;color:#888}.hashtag-chip-yt{background:#ff000014;color:#c00;font-weight:500}.tag-char-counter{font-size:.75rem;color:#888}.tag-char-counter.warning{color:#e53e3e;font-weight:600}.tag-char-counter.over-limit{color:#c53030;font-weight:700}.tag-suggestions-panel{background:#f8f9ff;border:1px solid #d4d8f0;border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:12px}.tag-suggestions-header{display:flex;justify-content:space-between;align-items:center}.tag-suggestions-header strong{font-size:.9rem;color:#333}.apply-suggestions-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:6px 14px;border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.apply-suggestions-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.tag-suggestions-section{display:flex;flex-direction:column;gap:6px}.tag-suggestions-section-label{font-size:.75rem;font-weight:600;color:#667;text-transform:uppercase;letter-spacing:.5px}.tag-suggestions-chips{display:flex;flex-wrap:wrap;gap:6px}.suggested-tag-chip{display:inline-flex;align-items:center;padding:5px 10px;border-radius:16px;font-size:.8rem;cursor:pointer;transition:all .2s;background:#fff;border:1px solid #d4d8f0;color:#555;-webkit-user-select:none;user-select:none}.suggested-tag-chip:hover{border-color:#667eea;background:#667eea0d}.suggested-tag-chip.selected{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent}@media(max-width:480px){.youtube-modal-content{margin:10px;max-height:95vh}.youtube-modal-actions{flex-direction:column}.label-with-button{flex-direction:column;align-items:flex-start;gap:8px}}.instagram-modal-backdrop{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:instagramModalFadeIn .2s ease-out}@keyframes instagramModalFadeIn{0%{opacity:0}to{opacity:1}}.instagram-modal-content{background:#fff;border-radius:16px;max-width:600px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:instagramModalSlideUp .3s ease-out}@keyframes instagramModalSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.instagram-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e0e0e0;background:linear-gradient(135deg,#833ab4,#fd1d1d,#fcb045)}.instagram-modal-header h3{margin:0;font-size:1.3rem;color:#fff;font-weight:600}.instagram-modal-header .close-btn{background:#fff3;border:none;width:32px;height:32px;border-radius:50%;font-size:1.2rem;color:#fff;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;padding:0}.instagram-modal-header .close-btn:hover:not(:disabled){background:#ffffff4d;transform:scale(1.1)}.instagram-modal-header .close-btn:disabled{cursor:not-allowed;opacity:.5}.instagram-modal-body{padding:24px;overflow-y:auto;display:flex;flex-direction:column;gap:20px}.instagram-error-message{background:#fff5f5;border:1px solid #feb2b2;color:#c53030;padding:12px 16px;border-radius:8px;font-size:.9rem}.instagram-success-message{background:#f0fff4;border:1px solid #9ae6b4;color:#276749;padding:12px 16px;border-radius:8px;font-size:.9rem}.instagram-form-group{display:flex;flex-direction:column;gap:8px}.instagram-form-group label{font-size:.9rem;font-weight:600;color:#333}.label-with-count{display:flex;justify-content:space-between;align-items:center}.instagram-form-group textarea,.instagram-form-group input[type=text]{padding:12px 16px;border:1px solid #ddd;border-radius:8px;font-size:.95rem;font-family:inherit;transition:border-color .2s,box-shadow .2s}.instagram-form-group textarea:focus,.instagram-form-group input[type=text]:focus{outline:none;border-color:#833ab4;box-shadow:0 0 0 3px #833ab41a}.instagram-form-group textarea{resize:vertical;min-height:120px;line-height:1.6}.instagram-caption-meta{display:flex;justify-content:space-between;align-items:center}.char-count{font-size:.75rem;color:#888}.char-count.warning{color:#e53e3e;font-weight:600}.preview-hint{font-size:.75rem;color:#888;font-style:italic}.hashtag-count{font-size:.8rem;color:#888}.hashtag-count.warning{color:#e53e3e;font-weight:600}.hashtag-input-container{display:flex;gap:8px}.hashtag-input-container input{flex:1}.add-hashtag-btn{background:#833ab4;color:#fff;border:none;padding:12px 16px;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s}.add-hashtag-btn:hover:not(:disabled){background:#6d2f96}.add-hashtag-btn:disabled{background:#ccc;cursor:not-allowed}.hashtag-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.hashtag-chip{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,#833ab41a,#fd1d1d1a);padding:6px 10px;border-radius:16px;font-size:.85rem;color:#833ab4;font-weight:500}.remove-hashtag-btn{background:none;border:none;color:#833ab4;cursor:pointer;font-size:.75rem;padding:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.remove-hashtag-btn:hover:not(:disabled){background:#833ab433}.remove-hashtag-btn:disabled{cursor:not-allowed;opacity:.5}.instagram-preview{background:#fafafa;border:1px solid #e0e0e0;border-radius:8px;padding:16px;max-height:200px;overflow-y:auto}.preview-text{margin:0;font-size:.9rem;color:#333;line-height:1.6;white-space:pre-wrap;word-break:break-word}.instagram-modal-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:16px;border-top:1px solid #e0e0e0;margin-top:8px}.instagram-modal-actions .cancel-button{background:#6c757d;color:#fff;border:none;padding:12px 20px;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .2s}.instagram-modal-actions .cancel-button:hover:not(:disabled){background:#5a6268}.instagram-modal-actions .cancel-button:disabled{background:#aaa;cursor:not-allowed}.save-button{background:linear-gradient(135deg,#833ab4,#fd1d1d);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.save-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #833ab44d}.save-button:disabled{background:#ccc;cursor:not-allowed;transform:none;box-shadow:none}.instagram-upload-button{background:linear-gradient(135deg,#833ab4,#fd1d1d,#fcb045);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.instagram-upload-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #833ab44d}.instagram-upload-button:disabled{background:#ccc;cursor:not-allowed;transform:none;box-shadow:none}.upload-hint{font-size:.85rem;color:#666;font-style:italic;text-align:center;margin-top:8px}@media(max-width:480px){.instagram-modal-content{margin:10px;max-height:95vh}.instagram-modal-actions{flex-direction:column}.label-with-count{flex-direction:column;align-items:flex-start;gap:4px}}.post-detail-container{max-width:1200px;margin:0 auto}.post-detail-header{margin-bottom:24px}.back-link{color:#667eea;text-decoration:none;font-size:14px;display:inline-block;margin-bottom:12px}.back-link:hover{text-decoration:underline}.post-detail-title-row{display:flex;align-items:flex-start;gap:16px;margin-bottom:8px}.post-detail-title-row h1{margin:0;color:#333;font-size:28px;font-weight:700;flex:1}.post-detail-title-row .post-status{padding:4px 12px;border-radius:12px;color:#fff;font-size:12px;font-weight:500;text-transform:uppercase;white-space:nowrap;margin-top:6px}.post-detail-meta{display:flex;gap:16px;flex-wrap:wrap;color:#666;font-size:13px}.meta-badge{padding:1px 8px;background:#f0f0f0;border-radius:4px}.processing-step{color:#007bff;font-style:italic}.news-source{color:#888}.post-detail-section{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:20px;margin-bottom:16px}.post-detail-section h2{margin:0 0 16px;color:#333;font-size:20px;font-weight:600}.placeholder-text{color:#999;font-size:14px}.video-preview{border-radius:8px;overflow:hidden}.video-player{width:100%;max-height:500px;background:#000;border-radius:8px}.thumbnail-preview{text-align:center}.thumbnail-preview img{max-width:400px;border-radius:8px;margin-bottom:8px}.post-detail-description{color:#444;font-size:15px;line-height:1.6;margin:0 0 12px;white-space:pre-wrap}.post-detail-hashtags{display:flex;flex-wrap:wrap;gap:6px}.hashtag{color:#667eea;font-size:12px;background:#f0f2ff;padding:2px 8px;border-radius:4px}.youtube-section{border-color:#ffcdd2}.youtube-section-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.youtube-section-header h2{margin:0}.status-badge{padding:4px 12px;border-radius:12px;color:#fff;font-size:12px;font-weight:500;text-transform:uppercase;white-space:nowrap}.youtube-upload-btn{padding:10px 24px;background:linear-gradient(135deg,red,#c00);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:opacity .2s}.youtube-upload-btn:hover:not(:disabled){opacity:.9}.youtube-upload-btn:disabled{opacity:.5;cursor:not-allowed}.youtube-uploaded{display:flex;flex-direction:column;gap:16px}.youtube-link-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,red,#c00);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;text-decoration:none;cursor:pointer;transition:opacity .2s;width:fit-content}.youtube-link-btn:hover{opacity:.9;color:#fff}.youtube-stats-card{display:flex;gap:32px;padding:16px 24px;background:#fafafa;border:1px solid #e0e0e0;border-radius:8px;width:fit-content}.youtube-stats-card .loading-stats{color:#999;font-size:14px;margin:0}.stat-item{display:flex;flex-direction:column;align-items:center;gap:4px}.stat-value{font-size:24px;font-weight:700;color:#333}.stat-label{font-size:12px;color:#888;text-transform:uppercase;letter-spacing:.5px}.youtube-uploading{display:flex;align-items:center;gap:12px;padding:16px;background:#e3f2fd;border-radius:8px}.youtube-uploading .loading-spinner{font-size:24px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.youtube-uploading p{margin:0;color:#1565c0;font-size:14px}.youtube-error{display:flex;flex-direction:column;gap:12px}.post-detail-nav{display:flex;gap:8px;margin-top:8px;margin-bottom:24px}.nav-link-btn{padding:8px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;text-decoration:none;cursor:pointer;transition:opacity .2s}.nav-link-btn:hover{opacity:.9;color:#fff}.nav-link-btn.secondary{background:#f0f0f0;color:#555}.nav-link-btn.secondary:hover{background:#e0e0e0;color:#333}.loading{text-align:center;padding:40px;color:#666;font-size:16px}.instagram-section{border-color:#e1bee7}.instagram-section-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.instagram-section-header h2{margin:0}.instagram-edit-btn{padding:10px 24px;background:linear-gradient(135deg,#833ab4,#fd1d1d,#fcb045);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:opacity .2s;margin-top:12px}.instagram-edit-btn:hover:not(:disabled){opacity:.9}.instagram-edit-btn:disabled{background:#ccc;cursor:not-allowed}.instagram-uploading{display:flex;align-items:center;gap:12px;padding:16px;background:#f3e5f5;border-radius:8px;margin-top:12px}.instagram-uploading .loading-spinner{font-size:24px;animation:spin 1s linear infinite}.instagram-uploading p{margin:0;color:#6a1b9a;font-size:14px}.instagram-published{display:flex;flex-direction:column;gap:12px;margin-top:12px}.instagram-link-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,#833ab4,#fd1d1d,#fcb045);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;text-decoration:none;cursor:pointer;transition:opacity .2s;width:fit-content}.instagram-link-btn:hover{opacity:.9;color:#fff}.instagram-error{display:flex;flex-direction:column;gap:12px;margin-top:12px}.platform-preview{background:#fafafa;border:1px solid #e0e0e0;border-radius:8px;padding:16px;margin-bottom:12px}.platform-preview-title{margin:0 0 8px;font-size:16px;font-weight:600;color:#333}.platform-preview-description{margin:0 0 12px;color:#444;font-size:14px;line-height:1.6;white-space:pre-wrap}.platform-preview-tags{display:flex;flex-wrap:wrap;gap:4px;align-items:center;margin-top:8px}.tags-label{font-size:11px;color:#888;font-weight:600;text-transform:uppercase;margin-right:4px}.tag-small{font-size:11px;color:#666;background:#f0f0f0;padding:1px 6px;border-radius:3px}.hashtag-youtube{color:#c00;background:#fff0f0}.hashtag-instagram{color:#833ab4;background:#f8f0ff}@media(max-width:768px){.post-detail-title-row{flex-direction:column;align-items:flex-start}.post-detail-meta{flex-direction:column;gap:4px}.youtube-stats-card{gap:16px;width:100%;justify-content:space-around}.post-detail-nav{flex-wrap:wrap}}.settings-container{max-width:800px;margin:0 auto}.settings-header{margin-bottom:24px}.settings-header h2{margin:0;color:#333;font-size:28px}.settings-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:24px;margin-bottom:16px}.settings-card h3{margin:0 0 16px;color:#333;font-size:18px;font-weight:600}.youtube-status{display:flex;align-items:center;gap:16px;margin-bottom:16px}.youtube-channel-thumbnail{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid #e0e0e0}.youtube-channel-info{flex:1}.youtube-channel-name{font-weight:600;color:#333;font-size:16px}.youtube-channel-meta{color:#666;font-size:13px;margin-top:2px}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;color:#fff;font-size:12px;font-weight:500;text-transform:uppercase}.status-badge.connected{background-color:#28a745}.status-badge.expired,.status-badge.error{background-color:#dc3545}.status-badge.disconnected{background-color:#6c757d}.settings-actions{display:flex;gap:8px;margin-top:16px}.connect-btn{padding:10px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:opacity .2s}.connect-btn:hover:not(:disabled){opacity:.9}.connect-btn:disabled{opacity:.5;cursor:not-allowed}.disconnect-btn{padding:10px 24px;background:#f0f0f0;color:#dc3545;border:1px solid #dc3545;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.disconnect-btn:hover:not(:disabled){background:#fff3f3}.disconnect-btn:disabled{opacity:.5;cursor:not-allowed}.warning-box{background:#fff3cd;color:#856404;padding:12px 16px;border-radius:6px;border:1px solid #ffeeba;margin-bottom:16px;font-size:14px}.error-message{background:#fff3f3;color:#dc3545;padding:12px 16px;border-radius:6px;border:1px solid #f5c6cb;margin-bottom:16px;font-size:14px}.success-message{background:#f0fff4;color:#28a745;padding:12px 16px;border-radius:6px;border:1px solid #c3e6cb;margin-bottom:16px;font-size:14px}.not-connected-text{color:#666;font-size:14px;margin-bottom:8px}#root{width:100%;height:100vh;margin:0;padding:0}
