.comic-app{--comic-blue-900: #05357d;--comic-blue-800: #0749b4;--comic-blue-700: #0c63df;--comic-blue-600: #1377f2;--comic-blue-100: #e8f2ff;--comic-yellow: #ffd32a;--comic-yellow-soft: #fff4c1;--comic-green: #28b947;--comic-red: #ff4d3d;--comic-ink: #0d1730;--comic-muted: #5f6b82;--comic-line: #d7e0ee;--comic-panel: #ffffff;--comic-bg: #f4f8ff;--comic-shadow: 0 10px 30px rgba(13, 23, 48, .12);--comic-radius: 8px;--comic-font: ui-rounded, "Avenir Next", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--comic-display: "Trebuchet MS", "Arial Black", Impact, sans-serif;min-height:100dvh;display:grid;grid-template-rows:auto minmax(0,1fr);overflow-x:clip;background:radial-gradient(circle at 12px 12px,rgba(255,255,255,.2) 2px,transparent 2px) 0 0 / 24px 24px,linear-gradient(135deg,#0d6ef8,#062c75);color:var(--comic-ink);font-family:var(--comic-font)}.comic-app button,.comic-app input,.comic-app textarea,.comic-app select{font:inherit}.comic-app-nav{min-height:64px;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:10px 18px;color:#fff;border-bottom:1px solid rgba(255,255,255,.16);background:radial-gradient(circle at 18px 18px,rgba(255,255,255,.16) 2px,transparent 2px) 0 0 / 28px 28px,linear-gradient(90deg,#0575f6,#07398c 55%,#05276a)}.comic-logo{position:relative;isolation:isolate;margin:2px 0 30px;width:min(205px,100%);padding:14px 8px 10px;font-family:var(--comic-display);line-height:.82;text-transform:uppercase;transform:rotate(-3deg)}.comic-logo:before{content:"";position:absolute;z-index:-1;inset:9px -7px auto 6px;height:88px;background:var(--comic-red);clip-path:polygon(8% 5%,100% 0,86% 29%,100% 50%,77% 58%,88% 92%,55% 77%,24% 100%,26% 68%,0 61%,17% 38%,0 22%);transform:rotate(2deg)}.comic-logo span{display:block;position:relative;width:min-content;max-width:190px;color:var(--comic-yellow);font-size:41px;letter-spacing:0;-webkit-text-stroke:2px #071538;text-shadow:3px 4px 0 #071538}.comic-logo strong{display:block;position:relative;margin-top:12px;margin-left:20px;color:#fff;font-size:36px;letter-spacing:0;-webkit-text-stroke:2px #071538;text-shadow:3px 4px 0 #071538}.comic-logo.compact{flex:0 0 auto;margin:0;width:auto;min-width:142px;padding:5px 6px 4px;line-height:.82;transform:rotate(-2deg)}.comic-logo.compact:before{inset:4px -5px auto 4px;height:54px}.comic-logo.compact span{max-width:none;font-size:25px;-webkit-text-stroke-width:1.3px;text-shadow:2px 3px 0 #071538}.comic-logo.compact strong{margin-top:7px;margin-left:18px;font-size:22px;-webkit-text-stroke-width:1.3px;text-shadow:2px 3px 0 #071538}.comic-nav{display:flex;align-items:center;gap:10px}.comic-nav button,.comic-nav a,.comic-nav-disabled{width:auto;display:flex;align-items:center;gap:12px;border:0;border-radius:var(--comic-radius);padding:12px 14px;background:transparent;color:#fff;font-weight:850;text-align:left;text-decoration:none;cursor:pointer}.comic-nav-disabled{opacity:.58;cursor:default}.comic-nav button:hover,.comic-nav a:hover{background:#ffffff1f}.comic-nav button.active,.comic-nav a.active{color:#091933;background:var(--comic-yellow);box-shadow:inset 0 -3px #00000024}.comic-nav-icon{width:36px;height:36px;display:grid;place-items:center;flex:0 0 auto;border-radius:var(--comic-radius);background:#ffffff29}.comic-nav button.active .comic-nav-icon,.comic-nav a.active .comic-nav-icon{background:#ffffff73}.comic-sidebar-tip{position:absolute;left:18px;right:18px;bottom:22px;padding:18px;border-radius:var(--comic-radius);background:#fffffff0;color:var(--comic-ink);box-shadow:var(--comic-shadow)}.comic-sidebar-tip strong{display:block;margin-bottom:8px;font-size:20px}.comic-sidebar-tip p{margin:0;color:#32415a;line-height:1.35}.comic-main{overflow:visible;margin:0 18px 18px;border-radius:0 0 18px 18px;background:var(--comic-bg);box-shadow:0 12px 40px #00000021}.comic-topbar{min-height:98px;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:24px 28px;border-bottom:1px solid var(--comic-line);background:#ffffffd1}.comic-topbar h1,.comic-page-rail h2,.comic-tools h2,.comic-template-picker h2{margin:0;font-family:var(--comic-display)}.comic-topbar h1{font-size:34px}.comic-title-row{display:flex;align-items:center;gap:10px;min-width:0}.comic-title-row h1{overflow-wrap:anywhere}.comic-title-edit-button{width:38px;height:38px;display:inline-grid;place-items:center;flex:0 0 auto;border:1px solid var(--comic-line);border-radius:var(--comic-radius);background:#fff;color:var(--comic-blue-800);cursor:pointer;box-shadow:0 2px 7px #0d173012}.comic-title-edit-button:hover{color:#fff;background:var(--comic-blue-600)}.comic-topbar p{margin:6px 0 0;color:var(--comic-muted);font-size:16px}.comic-save-status{display:flex;align-items:center;gap:8px;padding:11px 13px;border:1px solid #afe3bd;border-radius:var(--comic-radius);background:#e9f9ec;color:#16772b;font-weight:800;white-space:nowrap}.comic-save-status[data-state=saving]{border-color:#9fc2f8;background:#eef6ff;color:var(--comic-blue-800)}.comic-save-status[data-state=error]{border-color:#ffc3bd;background:#fff0ee;color:#b8291d}.comic-content{display:grid;grid-template-columns:288px minmax(520px,1fr) 280px;gap:20px;align-items:start;padding:24px}.comic-content>*{min-width:0}.comic-card{border:1px solid var(--comic-line);border-radius:var(--comic-radius);background:var(--comic-panel);box-shadow:0 4px 14px #0d17300f}.comic-page-rail,.comic-tools,.comic-template-picker{padding:16px}.comic-page-rail{grid-column:1 / -1}.comic-tools{position:sticky;top:24px;max-height:calc(100dvh - 48px);overflow:auto}.comic-page-rail h2,.comic-tools h2,.comic-template-picker h2{margin-bottom:12px;font-size:19px}.comic-page-rail-header{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:12px}.comic-page-rail-header h2{margin-bottom:6px}.comic-book-meta{color:var(--comic-muted);font-size:13px}.comic-thumb-list{max-width:100%;display:flex;gap:18px;overflow-x:auto;overflow-y:hidden;padding:22px 2px 42px 48px;scroll-padding-left:48px;scroll-snap-type:x proximity}.comic-thumb-item{position:relative;flex:0 0 74px;min-height:118px;border:2px solid transparent;border-radius:var(--comic-radius);background:#fff;color:inherit;scroll-snap-align:start}.comic-thumb-item.active{border-color:var(--comic-blue-600);background:var(--comic-blue-100)}.comic-thumb-select{display:grid;align-content:center;justify-items:center;gap:5px;width:100%;min-height:104px;padding:28px 6px 18px;border:0;border-radius:calc(var(--comic-radius) - 2px);background:transparent;color:inherit;text-align:left;cursor:pointer}.comic-thumb-cover-mark{position:absolute;top:10px;right:4px;left:4px;z-index:2;display:flex;align-items:center;justify-content:flex-start;gap:4px;padding:0 6px;min-height:22px;border:1px solid #a8c4aa;border-radius:7px;background:#f4fff4;color:#244a28;font-size:10px;font-weight:900;line-height:1;cursor:pointer}.comic-thumb-cover-mark input{width:12px;height:12px;margin:0}.comic-thumb-delete{display:inline-flex;align-items:center;justify-content:center;width:27px;height:24px;border:1px solid #f0b7ad;border-radius:8px;background:#fff7f5;color:var(--comic-red);cursor:pointer;transition:border-color .14s ease,background .14s ease}.comic-thumb-delete:hover{border-color:var(--comic-red);background:#ffe7e2}.comic-thumb-delete:disabled{cursor:not-allowed;opacity:.45}.comic-thumb-move-controls{position:absolute;right:-22px;bottom:-28px;display:flex;align-items:center;justify-content:center;gap:3px;padding:4px;border:1px solid #b8d3fb;border-radius:10px;background:#fffffff5;box-shadow:0 8px 18px #0d173029;z-index:4}.comic-thumb-control-divider{width:1px;height:18px;margin:0 5px;background:#bfd0e8}.comic-thumb-move{display:inline-flex;align-items:center;justify-content:center;width:27px;height:24px;border:1px solid #9fc2f8;border-radius:7px;background:#f8fbff;color:var(--comic-blue-700);cursor:pointer;transition:border-color .14s ease,background .14s ease}.comic-thumb-move:hover:not(:disabled){border-color:var(--comic-blue-600);background:#e9f3ff}.comic-thumb-move:disabled{cursor:not-allowed;opacity:.42}.comic-mini-page{box-sizing:border-box;border:2px solid #9aa8bb;border-radius:6px;background:#fff;overflow:visible}.comic-mini-page .comic-preview-panel,.comic-template-preview .comic-preview-panel{fill:#fff;stroke:#9aa8bb;stroke-width:1px;vector-effect:non-scaling-stroke}.comic-preview-text{overflow:visible}.comic-preview-shape{fill:#fff;stroke:#111;stroke-width:5px}.comic-preview-shape.caption{fill:var(--comic-yellow-soft);stroke-width:4px}.comic-preview-shape.sfx{fill:var(--comic-yellow);stroke-width:5px}.comic-thumb-page-number{position:absolute;top:-18px;left:50%;z-index:3;transform:translate(-50%);display:grid;place-items:center;width:28px;height:28px;border:2px solid #fff;border-radius:999px;background:var(--comic-blue-600);color:#fff;font-size:12px;font-weight:900;line-height:1;text-align:center;box-shadow:0 4px 10px #0d17302e}.comic-add-page{flex:0 0 auto;display:flex;align-items:center;justify-content:center;gap:8px;min-height:42px;padding:13px 10px;border:2px dashed #9fc2f8;border-radius:var(--comic-radius);background:#f8fbff;color:var(--comic-blue-700);font-weight:900;cursor:pointer}.comic-workspace{display:grid;gap:14px}.comic-template-picker{display:grid;align-content:start;gap:14px;align-self:stretch}.comic-template-picker p{margin:4px 0 0;color:var(--comic-muted);font-size:14px}.comic-template-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.comic-template-button{display:flex;align-items:center;justify-content:center;min-height:86px;padding:8px;border:1px solid var(--comic-line);border-radius:var(--comic-radius);background:#fff;color:inherit;cursor:pointer}.comic-template-button:hover,.comic-template-button.active{border-color:var(--comic-blue-600);background:var(--comic-blue-100)}.comic-template-preview{box-sizing:border-box;border:2px solid #1a2438;border-radius:5px;background:#fff;overflow:visible}.comic-paper-size-panel{display:grid;gap:10px;padding-top:14px;border-top:1px solid var(--comic-line)}.comic-paper-size-grid{display:flex;flex-wrap:wrap;gap:8px}.comic-paper-size-button{flex:0 0 174px;display:grid;grid-template-columns:38px minmax(0,1fr);gap:8px;align-items:center;min-height:56px;padding:8px;border:1px solid var(--comic-line);border-radius:var(--comic-radius);background:#fff;color:inherit;text-align:left;cursor:pointer}.comic-paper-size-button:hover,.comic-paper-size-button.active{border-color:var(--comic-blue-600);background:var(--comic-blue-100)}.comic-paper-size-button strong,.comic-paper-size-button small{display:block}.comic-paper-size-button strong{font-size:13px;font-weight:950;line-height:1.2}.comic-paper-size-button small{margin-top:3px;color:var(--comic-muted);font-size:11px;font-weight:800;line-height:1.25}.comic-paper-size-preview{display:block;width:32px;max-height:38px;justify-self:center;border:2px solid #1a2438;border-radius:4px;background:#fff}.comic-toolbar{position:sticky;top:16px;z-index:20;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px;padding:12px;background:#fffffff5;backdrop-filter:blur(8px)}.comic-tool-group{display:flex;flex-wrap:wrap;gap:10px}.comic-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;border:1px solid var(--comic-line);border-radius:var(--comic-radius);padding:9px 12px;background:#fff;color:var(--comic-ink);font-weight:850;cursor:pointer;box-shadow:0 2px 7px #0d173012}.comic-btn:hover{transform:translateY(-1px)}.comic-btn.primary{border-color:#075ec4;background:var(--comic-blue-600);color:#fff}.comic-btn.success{border-color:#179632;background:var(--comic-green);color:#fff}.comic-btn.active{border-color:var(--comic-blue-600);background:var(--comic-blue-100);color:var(--comic-blue-800)}.comic-btn.danger{color:#c93022}.comic-delete-text-button{width:100%;margin:0 0 4px}.comic-bubble-kind-panel{display:grid;gap:10px;margin:0 0 16px}.comic-bubble-kind-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}.comic-bubble-kind-grid button{display:grid;justify-items:center;align-content:center;gap:3px;min-height:58px;padding:6px 3px;border:1px solid var(--comic-line);border-radius:var(--comic-radius);background:#fff;color:var(--comic-ink);font-size:10px;font-weight:900;line-height:1.05;cursor:pointer}.comic-bubble-kind-grid button:hover,.comic-bubble-kind-grid button.active{border-color:var(--comic-blue-600);background:var(--comic-blue-100);color:var(--comic-blue-800)}.comic-bubble-kind-grid svg{width:42px;height:28px;overflow:visible}.comic-bubble-kind-shape{fill:#fff;stroke:#111;stroke-width:4px;vector-effect:non-scaling-stroke}.comic-bubble-kind-shape.caption{fill:var(--comic-yellow-soft)}.comic-bubble-kind-shape.sfx{fill:var(--comic-yellow)}.comic-editor-wrap{display:grid;align-items:start;justify-items:center;overflow:auto;padding:22px}.comic-paper{position:relative;width:min(100%,600px);aspect-ratio:var(--comic-paper-ratio-width) / var(--comic-paper-ratio-height);padding:28px;border-radius:var(--comic-radius);background:#fff;box-shadow:0 10px 28px #0d17302e}.comic-page-layout{display:block;width:100%;height:100%;overflow:visible;touch-action:none}.comic-panel-svg{fill:#fff;stroke:#111;stroke-width:4px;vector-effect:non-scaling-stroke}.comic-svg-text{cursor:grab;user-select:none;touch-action:none}.comic-svg-text:active{cursor:grabbing}.comic-svg-hitbox{fill:transparent;pointer-events:all}.comic-svg-shape{fill:#fff;stroke:#111;stroke-width:3px;vector-effect:non-scaling-stroke}.comic-svg-caption-shape{fill:var(--comic-yellow-soft)}.comic-svg-text-content{fill:var(--comic-ink);font-family:var(--comic-display);pointer-events:none;white-space:pre}.comic-svg-sfx-text{color:var(--comic-yellow);fill:var(--comic-yellow);stroke:#111;stroke-width:4px;paint-order:stroke fill}.comic-svg-selection{fill:transparent;stroke:var(--comic-blue-600);stroke-width:3px;stroke-dasharray:8 6;vector-effect:non-scaling-stroke;pointer-events:none}.comic-svg-handle{fill:var(--comic-blue-600);stroke:#fff;stroke-width:2px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.24));pointer-events:all;vector-effect:non-scaling-stroke}.comic-svg-rotate-stem{stroke:var(--comic-blue-600);stroke-width:3px;vector-effect:non-scaling-stroke;pointer-events:none}.comic-svg-handle-resize-nw,.comic-svg-handle-resize-se{cursor:nwse-resize}.comic-svg-handle-resize-ne,.comic-svg-handle-resize-sw{cursor:nesw-resize}.comic-svg-handle-rotate{cursor:grab}.comic-svg-handle-rotate:active{cursor:grabbing}.comic-books-index{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:22px;padding:24px}.comic-index-page{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;padding:24px}.comic-index-action,.comic-index-note{display:grid;grid-template-columns:58px minmax(0,1fr);gap:14px;align-items:center;min-height:150px;padding:20px;border:1px solid var(--comic-line);border-radius:var(--comic-radius);background:#fff;color:inherit;text-decoration:none;box-shadow:0 4px 14px #0d173014}.comic-index-action:hover{transform:translateY(-2px)}.comic-index-action svg,.comic-index-note svg{color:var(--comic-blue-700)}.comic-index-action strong,.comic-index-note strong{display:block;font-family:var(--comic-display);font-size:24px}.comic-index-action small,.comic-index-note small{display:block;margin-top:4px;color:var(--comic-muted);font-weight:800;line-height:1.35}.comic-book-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:16px}.comic-book-card{position:relative;display:grid;align-content:start;gap:8px;min-height:260px;padding:14px;border:1px solid var(--comic-line);border-radius:var(--comic-radius);background:#fff;color:inherit;text-decoration:none;box-shadow:0 4px 14px #0d173014}.comic-book-card:hover{transform:translateY(-2px)}.comic-book-card-link{display:grid;gap:8px;color:inherit;text-decoration:none}.comic-book-cover{display:grid;min-height:150px;place-items:center;border:4px solid #111;background:radial-gradient(circle at 72% 18%,var(--comic-yellow) 0 12px,transparent 13px),linear-gradient(135deg,#ff4d3d,#1377f2);color:#fff}.comic-book-card strong,.comic-create-book h2{margin:0;font-family:var(--comic-display);font-size:22px;line-height:1.12}.comic-book-card-link span,.comic-book-card-link small{color:var(--comic-muted);font-weight:800}.comic-book-delete-button{position:absolute;top:22px;right:22px;width:36px;height:36px;display:grid;place-items:center;border:1px solid rgba(13,23,48,.2);border-radius:var(--comic-radius);background:#ffffffeb;color:#c93022;cursor:pointer;box-shadow:0 4px 12px #0d173024}.comic-book-delete-button:hover{background:#fff0ee}.comic-book-delete-button:disabled{cursor:wait;opacity:.6}.comic-dialog-error{margin:0;color:#c93022;font-weight:850}.comic-create-book{align-self:start;padding:18px}.comic-tool-tile{width:100%;display:grid;grid-template-columns:36px minmax(0,1fr);align-items:center;gap:10px;margin-bottom:10px;padding:14px 10px;border:1px solid var(--comic-line);border-radius:var(--comic-radius);background:#fff;color:inherit;font-weight:900;text-align:left;cursor:pointer}.comic-tool-tile:hover,.comic-tool-tile.active{border-color:var(--comic-blue-600);background:var(--comic-blue-100)}.comic-tools hr{margin:16px 0;border:0;border-top:1px solid var(--comic-line)}.comic-field{display:grid;gap:7px;margin:14px 0}.comic-field span,.comic-check{color:#26344f;font-size:13px;font-weight:850}.comic-field-label-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.comic-field-label-row span{color:inherit;font:inherit}.comic-clear-text-button{border:1px solid var(--comic-line);border-radius:999px;padding:4px 9px;background:#fff;color:var(--comic-blue-700);font-size:12px;font-weight:850;cursor:pointer}.comic-clear-text-button:hover{border-color:var(--comic-blue-600);background:var(--comic-blue-100)}.comic-field textarea,.comic-field select,.comic-field input{width:100%;border:1px solid var(--comic-line);border-radius:var(--comic-radius);padding:10px;background:#fff;color:var(--comic-ink)}.comic-field textarea{min-height:90px;resize:vertical;font-family:var(--comic-display)}.comic-rotation-control{display:grid;grid-template-columns:minmax(0,1fr) 74px;align-items:center;gap:10px}.comic-field .comic-rotation-control{color:inherit;font:inherit}.comic-field .comic-rotation-control input[type=number]{padding-inline:8px}.comic-segmented{display:grid;grid-template-columns:repeat(3,1fr);overflow:hidden;border:1px solid var(--comic-line);border-radius:var(--comic-radius)}.comic-segmented button{border:0;padding:10px 4px;background:#fff;color:var(--comic-ink);text-transform:capitalize;cursor:pointer}.comic-segmented button.active{background:var(--comic-blue-100);color:var(--comic-blue-700);font-weight:900}.comic-size-options{grid-template-columns:repeat(5,1fr)}.comic-size-options button{text-transform:none}.comic-empty-note{margin:0;color:var(--comic-muted);line-height:1.4}.comic-print-actions{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:12px;padding:14px;border:1px solid var(--comic-line);border-radius:var(--comic-radius);background:#fff}.comic-print-book,.comic-print-sheet,.comic-print-slot,.comic-print-blank{display:none}.comic-check{display:flex;align-items:flex-start;gap:10px}.comic-check input{width:auto;margin-top:3px}.comic-print-tip{padding:14px;border-radius:var(--comic-radius);background:var(--comic-blue-100);color:#30405c;line-height:1.4}@media(max-width:1180px){.comic-sidebar-tip{display:none}.comic-nav{overflow:auto}.comic-main{margin:0;border-radius:0}.comic-content{grid-template-columns:1fr}.comic-template-grid{grid-template-columns:repeat(auto-fit,minmax(118px,1fr))}.comic-page-rail{grid-column:auto}.comic-tools{position:static;max-height:none;overflow:visible}.comic-books-index{grid-template-columns:1fr}}@media(max-width:700px){.comic-app-nav{align-items:stretch;flex-direction:column;gap:8px}.comic-topbar,.comic-print-actions,.comic-toolbar{align-items:stretch;flex-direction:column}.comic-nav{width:100%}.comic-nav a{justify-content:center}.comic-content{padding:12px}.comic-toolbar{top:10px}.comic-page-rail-header{align-items:stretch;flex-direction:column}.comic-add-page{width:100%}.comic-books-index,.comic-index-page{padding:12px}}@media print{@page{size:letter landscape;margin:0}html,body{width:11in;height:auto;margin:0;background:#fff;overflow:visible}.comic-sidebar,.comic-app-nav,.comic-topbar,.comic-page-rail,.comic-tools,.comic-template-picker,.comic-toolbar,.comic-print-actions{display:none!important}.comic-app,.comic-main,.comic-content,.comic-workspace,.comic-editor-wrap{display:block;width:11in;min-height:0;height:auto;margin:0;padding:0;background:#fff;box-shadow:none}.comic-editor-wrap{display:none}.comic-print-book{display:block;width:11in;height:auto;margin:0;padding:0;overflow:visible}.comic-print-sheet{box-sizing:border-box;width:11in;height:8.5in;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0;background:#fff;overflow:hidden;break-after:auto}.comic-print-sheet+.comic-print-sheet{break-before:page}.comic-print-slot{min-width:0;min-height:0;display:block}.comic-print-blank{display:block;width:100%;height:100%;background:#fff}.comic-paper{box-sizing:border-box;width:var(--comic-paper-width);height:var(--comic-paper-height);aspect-ratio:auto;padding:.4in;border-radius:0;box-shadow:none;break-after:page}.comic-print-slot .comic-paper{width:100%;height:100%;padding:.35in;page:auto;break-after:auto}.comic-paper:last-child{break-after:auto}}
