.dashboard{width:100%}.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.dashboard-header h1{font-size:1.5rem;font-weight:700;color:var(--gray-800)}.loading,.error{padding:2rem;text-align:center;color:var(--gray-500)}.error{color:var(--error)}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:8px;border:1px solid var(--gray-200)}.empty-state svg{color:var(--gray-400);margin-bottom:1rem}.empty-state h2{font-size:1.25rem;color:var(--gray-700);margin-bottom:.5rem}.empty-state p{color:var(--gray-500);margin-bottom:1.5rem}.stories-table{background:#fff;border-radius:8px;border:1px solid var(--gray-200);overflow:hidden}.stories-table table{width:100%;border-collapse:collapse}.stories-table th,.stories-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--gray-200)}.stories-table th{background:var(--gray-50);font-weight:600;font-size:.75rem;text-transform:uppercase;color:var(--gray-600);letter-spacing:.05em}.stories-table tr:last-child td{border-bottom:none}.stories-table tr:hover{background:var(--gray-50)}.story-cover{width:48px;height:64px;border-radius:4px;overflow:hidden;background:var(--gray-100)}.story-cover img{width:100%;height:100%;object-fit:cover}.cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--gray-400)}.story-title-cell{display:flex;flex-direction:column;gap:.125rem}.story-title-cell strong{color:var(--gray-800)}.story-title-cell .subtitle{font-size:.875rem;color:var(--gray-500)}.actions{display:flex;align-items:center;gap:.5rem}.action-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;border:1px solid var(--gray-200);background:#fff;color:var(--gray-600);cursor:pointer;transition:all .2s;text-decoration:none}.action-btn:hover{background:var(--gray-100);color:var(--gray-800)}.action-delete:hover{background:#fef2f2;color:var(--error);border-color:#fecaca}.action-btn:disabled{opacity:.5;cursor:not-allowed}.edit-story-page{display:flex;flex-direction:column;height:calc(100vh - 64px - 4rem)}.editor-header{display:flex;align-items:center;gap:1rem;padding-bottom:1rem;border-bottom:1px solid var(--gray-200);margin-bottom:1rem}.editor-header h1{flex:1;font-size:1.25rem;font-weight:600}.header-actions{display:flex;align-items:center;gap:.75rem}.editor-layout{display:grid;grid-template-columns:240px 1fr 280px;gap:1.5rem;flex:1;min-height:0}.page-sidebar{background:#fff;border-radius:8px;border:1px solid var(--gray-200);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid var(--gray-200)}.sidebar-header h2{font-size:.875rem;font-weight:600;color:var(--gray-700)}.page-list{flex:1;overflow-y:auto;padding:.5rem}.page-item{display:flex;align-items:center;padding:.5rem;border-radius:6px;cursor:pointer;margin-bottom:.25rem;transition:all .15s}.page-item:hover{background:var(--gray-100)}.page-item.active{background:var(--primary);color:#fff}.page-item.active .page-number{color:#fff}.page-item.active .page-status-icons{color:#ffffffb3}.drag-handle{display:flex;padding:.25rem;cursor:grab;color:var(--gray-400);border:none;background:none}.drag-handle:active{cursor:grabbing}.page-item-content{flex:1;min-width:0}.page-number{font-weight:500;font-size:.875rem;color:var(--gray-700)}.page-title{display:block;font-size:.75rem;color:var(--gray-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.page-status-icons{display:flex;gap:.25rem;color:var(--gray-400);margin-top:.25rem}.delete-btn{padding:.25rem;border:none;background:none;color:var(--gray-400);cursor:pointer;opacity:0;transition:all .15s}.page-item:hover .delete-btn{opacity:1}.delete-btn:hover{color:var(--error)}.page-editor{background:#fff;border-radius:8px;border:1px solid var(--gray-200);padding:1.5rem;overflow-y:auto}.editor-section{margin-bottom:2rem}.editor-section h3{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:var(--gray-700);margin-bottom:.75rem}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.section-header h3{margin-bottom:0}.image-area{min-height:200px}.image-preview{position:relative;display:inline-block}.image-preview img{max-width:100%;max-height:300px;border-radius:6px}.remove-image{position:absolute;top:.5rem;right:.5rem;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--gray-300);border-radius:50%;cursor:pointer;transition:all .15s}.remove-image:hover{background:var(--error);color:#fff;border-color:var(--error)}.upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:2rem;border:2px dashed var(--gray-300);border-radius:8px;background:var(--gray-50);cursor:pointer;transition:all .15s;color:var(--gray-500)}.upload-zone:hover{border-color:var(--primary);background:#6366f10d}.upload-zone.small{padding:1rem}.upload-zone span{font-size:.875rem}.text-editor{width:100%;min-height:200px;padding:1rem;border:1px solid var(--gray-300);border-radius:6px;font-family:Georgia,serif;font-size:1rem;line-height:1.8;resize:vertical}.text-editor:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.audio-controls{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--gray-50);border-radius:6px}.audio-info{font-size:.875rem;color:var(--gray-600)}.no-page-selected{display:flex;align-items:center;justify-content:center;height:100%;color:var(--gray-500)}.info-sidebar{background:#fff;border-radius:8px;border:1px solid var(--gray-200);padding:1rem;overflow-y:auto}.info-section{margin-bottom:1.5rem}.info-section h3{font-size:.75rem;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.cover-area{aspect-ratio:3/4;max-width:150px}.cover-preview img{width:100%;height:100%;object-fit:cover;border-radius:6px}.info-list{font-size:.875rem}.info-list dt{color:var(--gray-500);margin-top:.5rem}.info-list dd{color:var(--gray-800);font-weight:500}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:#fff;border-radius:8px;padding:1.5rem;width:100%;max-width:480px;max-height:80vh;overflow-y:auto}.modal h2{font-size:1.125rem;margin-bottom:1.5rem}.btn-sm{padding:.375rem .625rem;font-size:.75rem}.status-badge{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500;text-transform:capitalize}.status-draft{background:var(--gray-100);color:var(--gray-600)}.status-published{background:#dcfce7;color:#166534}.status-archived{background:#fef3c7;color:#92400e}.new-story-page h1{font-size:1.5rem;font-weight:700;color:var(--gray-800);margin-bottom:1.5rem}.story-form{max-width:640px}.form-error{padding:.75rem 1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:var(--error);margin-bottom:1.5rem}.form-section{margin-bottom:2rem}.form-section h2{font-size:1rem;font-weight:600;color:var(--gray-700);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--gray-200)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.required{color:var(--error)}.checkbox-group{margin-top:.5rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary)}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--gray-200)}*{box-sizing:border-box;margin:0;padding:0}:root{--primary: #6366f1;--primary-dark: #4f46e5;--success: #10b981;--error: #ef4444;--warning: #f59e0b;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;background:var(--gray-100);color:var(--gray-900);line-height:1.5}.app{min-height:100vh;display:flex;flex-direction:column}.nav{background:#fff;border-bottom:1px solid var(--gray-200);padding:0 1.5rem;height:64px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}.nav-brand a{display:flex;align-items:center;gap:.5rem;font-size:1.25rem;font-weight:700;color:var(--primary);text-decoration:none}.nav-links{display:flex;align-items:center;gap:1rem}.nav-link{color:var(--gray-600);text-decoration:none;font-weight:500;padding:.5rem 1rem;border-radius:6px;transition:all .2s}.nav-link:hover{color:var(--gray-900);background:var(--gray-100)}.main{flex:1;padding:2rem;max-width:1400px;margin:0 auto;width:100%}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;border-radius:6px;font-weight:500;font-size:.875rem;text-decoration:none;cursor:pointer;border:none;background:var(--primary);color:#fff!important;transition:all .2s}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;border-radius:6px;font-weight:500;font-size:.875rem;text-decoration:none;cursor:pointer;background:#fff;color:var(--gray-700);border:1px solid var(--gray-300);transition:all .2s}.btn-secondary:hover{border-color:var(--gray-400);background:var(--gray-50)}.btn-danger{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;border-radius:6px;font-weight:500;font-size:.875rem;cursor:pointer;background:var(--error);color:#fff;border:none;transition:all .2s}.btn-danger:hover{background:#dc2626}.form-group{margin-bottom:1.25rem}.form-label{display:block;font-weight:500;margin-bottom:.5rem;color:var(--gray-700)}.form-input,.form-textarea,.form-select{width:100%;padding:.625rem .875rem;border:1px solid var(--gray-300);border-radius:6px;font-size:.875rem;transition:all .2s}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.form-textarea{min-height:120px;resize:vertical}.form-hint{font-size:.75rem;color:var(--gray-500);margin-top:.25rem}.card{background:#fff;border-radius:8px;border:1px solid var(--gray-200);padding:1.5rem}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--gray-200)}.card-title{font-size:1.125rem;font-weight:600;color:var(--gray-800)}.text-error{color:var(--error)}.text-success{color:var(--success)}.text-muted{color:var(--gray-500)}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mb-4{margin-bottom:1rem}.gap-2{gap:.5rem}.gap-4{gap:1rem}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}
