*{margin:0;padding:0;box-sizing:border-box}:root{--bg:#0f172a;--bg2:#1e293b;--bg3:#334155;--text:#f1f5f9;--text2:#94a3b8;--accent:#3b82f6;--accent2:#2563eb;--success:#22c55e;--danger:#ef4444;--warning:#f59e0b;--border:#475569;--radius:8px}body{font-family:Segoe UI,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}a{color:var(--accent);text-decoration:none}button{padding:10px 20px;border:none;border-radius:var(--radius);cursor:pointer;font-size:14px;font-weight:600;transition:all .2s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent2)}.btn-danger{background:var(--danger);color:#fff}.btn-secondary{background:var(--bg3);color:var(--text)}.btn-success{background:var(--success);color:#fff}button:disabled{opacity:.5;cursor:not-allowed}input,select,textarea{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:14px;outline:none;transition:border .2s}input:focus,select:focus,textarea:focus{border-color:var(--accent)}textarea{resize:vertical;min-height:100px;font-size:15px;line-height:1.7}textarea.chapter-editor{font-family:TH Sarabun New,Sarabun,Noto Sans Thai,Segoe UI,sans-serif;font-size:17px;line-height:1.8;padding:16px 18px}.card{background:var(--bg2);border-radius:var(--radius);padding:24px;border:1px solid var(--border)}.container{max-width:1200px;margin:0 auto;padding:20px}.flex{gap:12px}.flex,.flex-between{display:flex;align-items:center}.flex-between{justify-content:space-between}.grid-2{grid-template-columns:1fr 1fr;grid-gap:16px}.grid-2,.grid-3{display:grid;gap:16px}.grid-3{grid-template-columns:1fr 1fr 1fr;grid-gap:16px}.mb-4{margin-bottom:16px}.mb-2{margin-bottom:8px}.mt-4{margin-top:16px}.text-sm{font-size:13px;color:var(--text2)}.text-center{text-align:center}label{display:block;margin-bottom:6px;font-size:13px;color:var(--text2);font-weight:600}h1{font-size:28px;font-weight:700}h2{font-size:22px}h2,h3{font-weight:600}h3{font-size:18px}.badge{display:inline-block;padding:2px 10px;border-radius:20px;font-size:12px;font-weight:600}.badge-owner{background:#7c3aed;color:#fff}.badge-admin{background:var(--accent);color:#fff}.badge-editor{background:var(--success);color:#fff}.badge-viewer{background:var(--bg3);color:var(--text2)}.badge-vip{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-size:11px;padding:2px 8px}.badge-done{background:var(--success);color:#fff}.badge-pending{background:var(--bg3);color:var(--text2)}.badge-generating{background:var(--warning);color:#000}.badge-failed{background:var(--danger);color:#fff}.tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:24px}.tab{padding:12px 24px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;color:var(--text2);font-weight:600;transition:all .2s}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.alert,.form-group{margin-bottom:16px}.alert{padding:12px 16px;border-radius:var(--radius);font-size:14px}.alert-error{background:#451a1a;border:1px solid var(--danger);color:#fca5a5}.alert-success{background:#14532d;border:1px solid var(--success);color:#86efac}.loading{display:inline-block;width:20px;height:20px;border:2px solid hsla(0,0%,100%,.15);border-top:2px solid var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.nav{background:var(--bg2);border-bottom:1px solid var(--border);padding:12px 24px;display:flex;justify-content:space-between;align-items:center}.nav-brand{font-size:20px;font-weight:700;color:var(--accent)}.chapter-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:12px;gap:12px}.chapter-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:16px;cursor:pointer;transition:all .2s}.chapter-card:hover{border-color:var(--accent);transform:translateY(-2px)}.member-row{gap:12px;padding:8px 0;border-bottom:1px solid var(--border)}.member-row,.modal-overlay{display:flex;align-items:center}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);justify-content:center;z-index:1000}.modal{background:var(--bg2);border-radius:var(--radius);padding:32px;width:90%;max-width:600px;max-height:80vh;overflow-y:auto}.progress-bar{width:100%;height:8px;background:var(--bg3);border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--accent);transition:width .3s ease;border-radius:4px}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));grid-gap:12px;gap:12px}.image-thumb{position:relative;aspect-ratio:2/3;border-radius:var(--radius);overflow:hidden;border:2px solid var(--border);cursor:pointer;transition:all .2s;background:var(--bg);display:flex;align-items:center;justify-content:center}@media (hover:hover){.image-thumb:hover{border-color:var(--accent);transform:translateY(-2px)}}.image-thumb img{width:100%;height:100%;object-fit:cover}.image-thumb .label{position:absolute;bottom:0;left:0;right:0;padding:4px 8px;background:rgba(0,0,0,.7);color:#fff;font-size:12px;display:flex;justify-content:space-between;align-items:center}.image-thumb.empty{border-style:dashed;color:var(--text2);font-size:12px}.image-thumb.generating{border-color:var(--warning)}.image-thumb.selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent)}.image-gen-overlay{position:absolute;inset:0;background:rgba(0,0,0,.5);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2}.image-gen-overlay .loading{width:36px;height:36px;border-width:3px}.image-cancel-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:22px;height:22px;border-radius:50%;background:hsla(0,0%,100%,.15);color:#fff;border:1px solid hsla(0,0%,100%,.3);font-size:12px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background .15s,border-color .15s}.image-cancel-btn:hover{background:var(--danger);border-color:var(--danger)}.image-delete-btn{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:50%;background:rgba(0,0,0,.6);color:#fff;border:none;font-size:16px;line-height:1;cursor:pointer;display:none;align-items:center;justify-content:center;z-index:3;padding:0}.image-delete-btn:hover{background:var(--danger)}@media (hover:hover){.image-thumb:hover .image-delete-btn{display:flex}}.image-gen-btn{position:absolute;inset:0;margin:auto;width:40px;height:40px;border-radius:50%;background:var(--accent);color:#fff;border:none;font-size:18px;font-weight:700;cursor:pointer;display:none;align-items:center;justify-content:center;z-index:3;padding:0}.image-gen-btn:hover{background:var(--accent-hover);transform:scale(1.1)}@media (hover:hover){.image-thumb:hover .image-gen-btn{display:flex}}.image-thumb.empty .image-gen-btn{display:flex}.image-rewrite-btn{position:absolute;top:4px;left:4px;width:24px;height:24px;border-radius:50%;background:rgba(0,0,0,.6);color:#fff;border:none;font-size:12px;font-weight:700;line-height:1;cursor:pointer;display:none;align-items:center;justify-content:center;z-index:3;padding:0}.image-rewrite-btn:hover{background:var(--warning)}@media (hover:hover){.image-thumb:hover .image-rewrite-btn{display:flex}}.image-time-label{color:#fca5a5;font-size:10px;font-weight:600;white-space:nowrap}.chapter-card.selected{border-color:var(--accent);background:var(--bg2)}.batch-status{font-size:13px;color:var(--text2);padding:8px 0}.batch-table{width:100%;border-collapse:collapse}.batch-table th{text-align:left;padding:8px 12px;border-bottom:2px solid var(--border);color:var(--text2);font-size:13px;font-weight:600}.batch-table td{padding:6px 12px;border-bottom:1px solid var(--border);font-size:13px}.batch-table tr.status-done td:nth-child(2){color:var(--success)}.batch-table tr.status-generating td:nth-child(2){color:var(--warning)}.batch-table tr.status-failed td:nth-child(2){color:var(--danger)}.batch-table tr.status-pending td:nth-child(2){color:var(--text2)}.batch-table tr.status-skipped td:nth-child(2){color:var(--text2);font-style:italic}.batch-summary{display:flex;gap:16px;padding:12px 0;font-size:13px;flex-wrap:wrap}.batch-table tr{transition:background .15s}.batch-table tr:hover{background:var(--bg2)}.batch-table tr.status-done td:last-child .batch-status-badge{color:var(--success)}.batch-table tr.status-failed td:last-child .batch-status-badge{color:var(--danger)}.batch-table tr.status-generating td:last-child .batch-status-badge{color:var(--warning)}.batch-status-badge{font-size:12px;font-weight:600;padding:2px 8px;border-radius:4px;display:inline-block}.batch-status-badge.succeeded{background:rgba(34,197,94,.12);color:var(--success)}.batch-status-badge.failed{background:rgba(239,68,68,.12);color:var(--danger)}.batch-status-badge.processing{background:rgba(234,179,8,.12);color:var(--warning)}.lightbox{position:fixed;top:0;left:0;right:0;bottom:0;z-index:2000;background:rgba(0,0,0,.9);display:flex;align-items:center;justify-content:center;cursor:pointer}.lightbox img{max-width:85vw;max-height:85vh;object-fit:contain;border-radius:8px}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:hsla(0,0%,100%,.15);color:#fff;border:none;width:48px;height:48px;border-radius:50%;font-size:32px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;z-index:2001;-webkit-user-select:none;-moz-user-select:none;user-select:none}.lightbox-nav:hover{background:hsla(0,0%,100%,.35)}.lightbox-prev{left:16px}.lightbox-next{right:16px}.inpaint-modal{background:var(--bg2);border-radius:var(--radius);width:95%;max-width:900px;height:95vh;overflow:hidden;display:flex;flex-direction:column;border:1px solid var(--border)}.inpaint-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}.inpaint-header h2{font-size:18px;font-weight:600;margin:0}.inpaint-body{flex:1 1;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:0;min-height:300px;flex-direction:column}.inpaint-viewport{position:relative;overflow:hidden;width:100%;flex:1 1;min-height:200px;background:var(--bg)}.inpaint-canvas-area{position:relative;display:inline-block}.inpaint-canvas-area canvas{display:block}.inpaint-canvas-area canvas+canvas{position:absolute;top:0;left:0}.brush-cursor{position:absolute;border:1.5px solid hsla(0,0%,100%,.8);border-radius:50%;pointer-events:none;z-index:20;box-shadow:0 0 0 1px rgba(0,0,0,.3)}.mask-processing{animation:mask-pulse 1s ease-in-out infinite}@keyframes mask-pulse{0%,to{opacity:1}50%{opacity:.3}}.inpaint-processing-badge{position:absolute;top:12px;right:12px;display:flex;align-items:center;gap:6px;padding:6px 14px;background:rgba(0,0,0,.75);border-radius:20px;font-size:12px;color:#ccc;z-index:10;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.inpaint-result{padding:20px;text-align:center}.inpaint-result img{max-width:100%;max-height:60vh;border-radius:var(--radius)}.inpaint-toolbar{display:flex;align-items:center;gap:12px;padding:12px 20px;border-top:1px solid var(--border);background:var(--bg);flex-wrap:wrap}.inpaint-toolbar input[type=range]{width:120px;height:4px;-webkit-appearance:none;background:var(--bg3);border-radius:4px;outline:none;border:none;padding:0}.inpaint-toolbar input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:var(--accent);border-radius:50%;cursor:pointer}.inpaint-toolbar .brush-label{font-size:13px;color:var(--accent);min-width:35px;font-weight:600}.image-inpaint-btn{position:absolute;bottom:28px;left:4px;width:24px;height:24px;border-radius:50%;background:rgba(0,0,0,.6);color:#fff;border:none;font-size:12px;font-weight:700;line-height:1;cursor:pointer;display:none;align-items:center;justify-content:center;z-index:3;padding:0}.image-inpaint-btn:hover{background:var(--accent)}@media (hover:hover){.image-thumb:hover .image-inpaint-btn{display:flex}}@media (max-width:768px){.grid-2,.grid-3{grid-template-columns:1fr}.tabs{overflow-x:auto}.image-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.chapter-layout{flex-direction:column!important}.chapter-list{width:100%!important;min-width:0!important;max-height:200px!important;flex-direction:row!important;overflow-x:auto!important;overflow-y:hidden!important}.chapter-list .chapter-card{min-width:120px}textarea.chapter-editor{font-size:16px}.inpaint-modal{width:100%;max-height:100vh;border-radius:0}}