:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#f5f5f7;--bg-stripe:#11182705;--bg-stripe-period:10px;--ink:#1f2937;--muted:#6b7280;--line:#d1d5db;--plot:#fef08a;--character:#bfdbfe;--theme:#bbf7d0;--column-min-width:180px;--board-surface:#f1f2f6;--column-empty-bg:#fff}*{box-sizing:border-box}body{background-color:var(--bg);background-image:repeating-linear-gradient(90deg, transparent 0, transparent calc(var(--bg-stripe-period) - 1px), var(--bg-stripe) calc(var(--bg-stripe-period) - 1px), var(--bg-stripe) var(--bg-stripe-period));color:var(--ink);margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}.app{--app-padding-inline:20px;flex-direction:column;min-height:100vh;padding:20px;display:flex}.view.hidden,.hidden{display:none}.topbar{justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:16px;display:flex}.landing-topbar{text-align:center;justify-content:center}.landing-brand h1,.landing-brand .subtitle{text-align:center}.dashboard-topbar{grid-template-columns:1fr auto 1fr;align-items:center;display:grid}.dashboard-topbar-left{justify-self:start}.dashboard-topbar-center{justify-self:center}.dashboard-topbar-center h1{text-align:center}.dashboard-topbar-right{justify-self:end}.editor-topbar{grid-template-columns:1fr auto 1fr;align-items:center;display:grid}.editor-topbar-left{justify-self:start;align-items:center;gap:8px;display:flex}.editor-topbar-center{justify-self:center}.editor-topbar-center h1{text-align:center}.editor-topbar-right{justify-self:end}.editor-topbar-actions{align-items:center;gap:8px;display:flex}.board-actions-trigger{align-items:center;gap:6px;display:inline-flex}.back-arrow-button{min-width:44px;padding:6px 10px;font-size:1.25rem;line-height:1}h1{margin:0;font-size:1.3rem}.subtitle{color:var(--muted);margin:4px 0 0}.toolbar{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.home-create,.empty-state,.home-import,.home-custom-structure,.home-create-group{border:1px solid var(--line);background:#fff;border-radius:12px;margin-bottom:14px;padding:14px}.landing-hero{border:1px solid var(--line);background:linear-gradient(135deg,#fff 0%,#eef2ff 55%,#fef9c3 100%);border-radius:14px;margin-bottom:16px;padding:22px}.landing-hero h2{margin:0 0 8px}.landing-hero p{color:#374151;max-width:880px;margin:0 0 12px}.landing-hero button{color:#fff;cursor:pointer;background:#111827;border:1px solid #111827;border-radius:8px;padding:9px 12px;font-size:.95rem}.landing-hero-actions{flex-wrap:wrap;gap:8px;display:flex}.landing-grid{grid-template-columns:repeat(2,minmax(260px,1fr));align-items:start;gap:14px;display:grid}.landing-stack{gap:14px;display:grid}.landing-card{border:1px solid var(--line);background:#fff;border-radius:12px;min-height:146px;padding:16px}.landing-card h3{margin:0 0 8px;font-size:1rem}.landing-card p{color:#4b5563;margin:0}.landing-demos-card{min-height:466px}.demo-map{color:#374151;gap:8px;margin:0;padding-left:18px;display:grid}.landing-card.card-plot{background:linear-gradient(180deg, color-mix(in srgb, var(--plot) 45%, white) 0%, #fff 100%)}.landing-card.card-character{background:linear-gradient(180deg, color-mix(in srgb, var(--character) 45%, white) 0%, #fff 100%)}.landing-card.card-theme{background:linear-gradient(180deg, color-mix(in srgb, var(--theme) 45%, white) 0%, #fff 100%)}.landing-card.card-neutral{background:linear-gradient(#f3f4f6 0%,#fff 100%)}.home-create h2{margin:0 0 10px;font-size:1rem}.help-card{border:1px solid var(--line);background:#fff;border-radius:12px;margin-bottom:14px;padding:14px}.help-card h2{margin:0 0 8px;font-size:1rem}.help-card ul{gap:6px;margin:0;padding-left:18px;display:grid}.help-faq-item{border:1px solid var(--line);background:#fafafa;border-radius:10px;margin-top:10px;overflow:hidden}.help-faq-item summary{cursor:pointer;justify-content:space-between;align-items:center;padding:12px 14px;font-weight:600;list-style:none;display:flex}.help-faq-item summary::-webkit-details-marker{display:none}.help-faq-item summary:after{content:"▾";color:#374151;margin-left:8px;font-size:.95rem;transition:transform .14s}.help-faq-item[open] summary:after{transform:rotate(180deg)}.help-faq-content{color:#374151;padding:0 14px 14px}.help-faq-content p{margin:0 0 10px}.help-faq-content p:last-child{margin-bottom:0}.help-faq-content ul{gap:4px;margin:0 0 10px;padding-left:18px;display:grid}.create-board-form{grid-template-columns:minmax(220px,1fr) auto;gap:8px;display:grid}.home-create .ghost-button{margin-top:10px}.home-dev-reset{justify-content:flex-end;gap:8px;margin-bottom:14px;display:flex}.create-board-form input{border:1px solid var(--line);font:inherit;border-radius:8px;grid-column:1/-1;padding:8px 10px}.create-board-form select{border:1px solid var(--line);font:inherit;background:#fff;border-radius:8px;padding:8px 10px}.create-board-form button,.ghost-button{border:1px solid var(--line);cursor:pointer;background:#f0f5f8;border-radius:8px;padding:8px 10px;font-size:.92rem}.app-nav{align-items:center;gap:8px;display:flex}.boards-list{gap:10px;display:grid}.dashboard-section{margin-bottom:18px}.dashboard-section-title{color:#374151;margin:0 0 8px;font-size:.95rem;font-weight:700}.home-list-controls{grid-column:1/-1;justify-content:flex-start;margin:8px 0 12px;display:flex}.link-button{color:#2563eb;font:inherit;cursor:pointer;text-underline-offset:2px;background:0 0;border:0;padding:0;font-size:.9rem;text-decoration:underline}.link-button:hover{color:#1d4ed8}.link-button:focus-visible{outline-offset:2px;border-radius:4px;outline:2px solid #93c5fd}#groups-list,#boards-list{grid-template-columns:repeat(auto-fill,minmax(440px,1fr));align-items:start}.group-board-stack{gap:14px;display:grid}.group-board-card{background:0 0;border:none;border-radius:0;padding:0}#group-view:not(.hidden) .group-board-stack{margin-left:calc(-1 * var(--app-padding-inline));margin-right:calc(-1 * var(--app-padding-inline));gap:2.5rem;padding-bottom:8px}.group-board-head{padding-left:max(var(--app-padding-inline), env(safe-area-inset-left,0px));padding-right:max(var(--app-padding-inline), env(safe-area-inset-right,0px));justify-content:space-between;align-items:start;gap:10px;margin-bottom:10px;display:flex}.group-board-head-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.group-board-head h2{margin:0;font-size:1rem}.group-board-preview{pointer-events:none}#group-view .group-board-preview.board{border:0;border-top:1px solid var(--line);border-left:1px solid var(--line);background:0 0;border-radius:0;gap:0;padding-bottom:0;overflow:hidden}#group-view .group-board-preview .column{border:none;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff;border-radius:0;min-height:0;padding:16px 12px 18px}#group-view .group-board-preview .column.column-empty{background:var(--column-empty-bg)}#group-view .group-board-preview .phase-head{margin-bottom:12px}.group-board-preview .note.group-note-readonly{pointer-events:auto}.group-note-readonly .note-head{margin-bottom:4px}.group-note-text{white-space:pre-wrap;word-break:break-word}.reorder-list{gap:8px;margin-top:10px;display:grid}.reorder-item{border:1px solid var(--line);cursor:grab;background:#fff;border-radius:8px;align-items:center;gap:8px;padding:8px 10px;transition:transform .14s,box-shadow .14s,border-color .14s;display:flex}.reorder-item:active{cursor:grabbing}.reorder-item.is-dragging{border-color:#60a5fa;box-shadow:0 8px 20px #3b82f62e}.reorder-handle{color:#6b7280;font-size:.95rem}.reorder-placeholder{background:#9ca3af1a;border:2px dashed #9ca3af;border-radius:8px;height:40px;transition:all .12s}.reorder-status{color:#065f46;opacity:0;min-height:1.2em;margin:8px 0 0;font-size:.9rem;transition:opacity .15s}.reorder-status.is-visible{opacity:1}.home-import h2{margin:0 0 6px;font-size:1rem}.import-actions{margin-top:10px}.home-custom-structure h2{margin:0 0 6px;font-size:1rem}.collapsible-panel summary{cursor:pointer;justify-content:space-between;align-items:center;list-style:none;display:flex}.collapsible-panel summary::-webkit-details-marker{display:none}.collapsible-panel summary:after{content:"▾";color:#4b5563;font-size:1.25rem;font-weight:700;line-height:1;transition:transform .16s}.collapsible-panel:not([open]) summary{margin-bottom:0}.collapsible-panel[open] summary:after{transform:rotate(180deg)}.collapsible-panel summary h2{margin:0;font-size:1rem;font-weight:600}.collapsible-panel form,.collapsible-panel .subtitle,.collapsible-panel .ghost-button{margin-top:10px}.home-create-group .create-group-form{gap:10px;display:grid}.create-group-name-label{color:#374151;font-size:.9rem;font-weight:600}.create-group-form input[type=text]{border:1px solid var(--line);font:inherit;border-radius:8px;width:100%;max-width:420px;padding:8px 10px}.create-group-boards-fieldset{border:1px solid var(--line);border-radius:10px;margin:0;padding:10px 12px}.create-group-boards-fieldset legend{color:#374151;padding:0 6px;font-size:.85rem;font-weight:600}.create-group-boards-list{gap:8px;max-height:240px;margin-top:6px;display:grid;overflow:auto}.create-group-board-row{cursor:pointer;align-items:flex-start;gap:10px;font-size:.92rem;line-height:1.35;display:flex}.create-group-board-row input{flex-shrink:0;margin-top:3px}.create-group-form .ghost-button[type=submit]{justify-self:end;width:auto}.add-board-to-group-list .group-picker-item{text-align:left;width:100%}#add-board-to-group-modal-overlay .add-board-to-group-intro{margin-bottom:14px}#add-board-to-group-modal-overlay .add-board-to-group-empty{color:var(--muted);margin-bottom:0}#add-board-to-group-modal-overlay .add-board-to-group-list:empty{min-height:0;margin:0}.board-actions-modal .ghost-button:disabled{opacity:.45;cursor:not-allowed}.create-structure-form{gap:10px;display:grid}.create-structure-form input{border:1px solid var(--line);font:inherit;border-radius:8px;padding:8px 10px}.structure-phases-list{gap:8px;display:grid}.structure-phase-row{grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:8px;display:grid}.phase-row-index{color:var(--muted);text-align:right;min-width:22px}.structure-form-actions{justify-content:space-between;gap:8px;display:flex}.board-card{border:1px solid var(--line);cursor:pointer;background:#fff;border-radius:10px;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:8px;padding:10px 12px;display:grid}.board-card>div:first-child{min-width:0}.board-card:focus-visible{outline-offset:2px;outline:2px solid #2563eb}.board-actions{gap:6px;display:flex}.board-card button{color:#166534;cursor:pointer;background:#f0f5f8;border:1px solid #16a34a;border-radius:8px;padding:6px 10px}.action-button{align-items:center;gap:6px;display:inline-flex}.action-icon{line-height:1}.board-actions-modal-list{gap:8px;display:grid}.board-actions-modal-list .ghost-button{text-align:left;width:100%}.board-card .danger-button{color:#b91c1c;background:#f8f8f8;border-color:#ef4444}.board-meta{color:var(--muted);font-size:.82rem}.board-meta-line+.board-meta-line{margin-top:2px}.group-board-list{margin:4px 0 2px;padding:0;list-style:none}.group-board-list-item{font-weight:700;line-height:1.25}.group-board-list-item+.group-board-list-item{margin-top:2px}.toolbar select,.toolbar button{border:1px solid var(--line);background:#fff;border-radius:8px;padding:8px 10px;font-size:.95rem}.toolbar button{color:#fff;cursor:pointer;background:#111827}.board{grid-template-columns:repeat(12, minmax(var(--column-min-width), 1fr));align-items:start;gap:12px;padding-bottom:12px;display:grid;overflow-x:auto}#editor-view:not(.hidden) #board.board{margin-left:calc(-1 * var(--app-padding-inline));margin-right:calc(-1 * var(--app-padding-inline));border:0;border-top:1px solid var(--line);border-left:1px solid var(--line);background:0 0;border-radius:0;gap:0;padding:0;overflow-x:auto}#editor-view:not(.hidden) #board.board .column{border:none;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff;border-radius:0;min-height:0;padding:16px 12px 18px}#editor-view:not(.hidden) #board.board .column.column-empty{background:var(--column-empty-bg)}#editor-view:not(.hidden) #board.board .phase-head{margin-bottom:12px}.board.wrap-columns{grid-template-columns:repeat(auto-fit, minmax(var(--column-min-width), 1fr));align-items:stretch;overflow-x:visible}.board.wrap-columns .column{height:100%;min-height:0}.options-button{align-items:center;gap:6px;display:inline-flex}.options-wrap{position:relative}.options-menu{border:1px solid var(--line);z-index:30;background:#fff;border-radius:10px;min-width:180px;padding:6px;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 8px 20px #1118271f}.options-menu.hidden{display:none}.column{border:1px solid var(--line);background:#fff;border-radius:12px;min-height:420px;padding:10px}.board .column.column-empty{background:var(--column-empty-bg)}.phase-title{letter-spacing:.03em;color:#374151;margin:0;font-size:.82rem}.phase-head{justify-content:space-between;align-items:center;gap:8px;margin-bottom:10px;display:flex;position:relative}.phase-title-wrap{align-items:center;gap:6px;min-width:0;display:inline-flex}.phase-drag{color:#6b7280;cursor:grab;background:0 0;border:0;flex:0 0 16px;width:16px;padding:0;font-size:.95rem}.phase-drag:active{cursor:grabbing}.phase-add{border:1px solid var(--line);cursor:pointer;background:#f8f8f8;border-radius:8px;width:28px;height:28px;font-weight:700}.column-menu{border:1px solid var(--line);z-index:20;background:#fff;border-radius:10px;width:210px;padding:6px;position:absolute;top:34px;right:0;box-shadow:0 8px 20px #1118271f}.column-menu.hidden,.submenu.hidden{display:none}.menu-item{text-align:left;cursor:pointer;background:0 0;border:0;border-radius:8px;width:100%;padding:7px 8px}.menu-item:hover{background:#f3f4f6}.danger-menu-item{color:#b91c1c}.danger-menu-item:hover{background:#fee2e2}.submenu{border-top:1px solid var(--line);gap:4px;margin-top:6px;padding-top:6px;display:grid}.submenu-title{color:var(--muted);padding:0 8px;font-size:.78rem}.notes{gap:8px;display:grid}.note-drop-placeholder{background:#9ca3af1f;border:2px dashed #9ca3af;border-radius:8px;height:56px}.note{cursor:default;background:var(--note-bg,#f3f4f6);border:1px solid #11182733;border-radius:4px;padding:8px;font-size:.85rem;line-height:1.3;box-shadow:0 1px 1px #1118271a}.note.is-dragging{opacity:.55}.phase-drop-placeholder{background:#9ca3af1f;border:2px dashed #9ca3af;border-radius:12px;min-height:420px}.note-head{justify-content:space-between;align-items:center;gap:6px;min-width:0;margin-bottom:6px;display:flex}.note-head-actions{align-items:center;gap:4px;display:inline-flex}.collapsed-preview{white-space:nowrap;text-overflow:ellipsis;color:#374151;flex:1;width:0;min-width:0;max-width:100%;font-size:.78rem;font-weight:600;overflow:hidden}.badge{background:#ffffffb3;border-radius:999px;padding:2px 8px;font-size:.72rem;font-weight:600}.delete{cursor:pointer;background:0 0;border:0;font-size:.9rem}.note.is-collapsed .note-head{margin-bottom:0}.note textarea,.note input,.note select{width:100%;font:inherit;background:#ffffffc7;border:1px solid #11182738;border-radius:6px;padding:6px}.note-readonly-text{white-space:pre-wrap;word-break:break-word;margin-top:4px;line-height:1.35}.note-readonly-character{background:#ffffffa6;border:1px solid #11182726;border-radius:8px;margin-top:4px;padding:6px 8px;font-weight:600}.note textarea{resize:vertical;min-height:74px}.character-fields{grid-template-columns:minmax(120px,38%) minmax(0,1fr);gap:6px;margin-bottom:6px;display:grid}.modal-overlay{z-index:50;background:#11182773;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.modal-overlay.hidden{display:none}.modal{border:1px solid var(--line);background:#fff;border-radius:12px;width:min(560px,100%);padding:16px}.phase-order-conflict-modal{width:min(860px,100%)}.phase-order-columns{grid-template-columns:1fr 1fr;gap:14px;margin-top:10px;display:grid}.phase-order-columns section{border:1px solid var(--line);background:#fafafa;border-radius:10px;padding:10px}.phase-order-columns h3{margin:0 0 8px;font-size:.95rem}.phase-order-columns ol{gap:4px;max-height:280px;margin:0;padding-left:0;list-style:none;display:grid;overflow:auto}.phase-order-item{grid-template-columns:auto 1fr;align-items:baseline;gap:8px;display:grid}.phase-order-index{font-variant-numeric:tabular-nums;color:#6b7280;font-weight:600}.phase-order-item.is-first-mismatch{background:#fee2e2b3;border:1px solid #fca5a5;border-radius:6px;padding:3px 6px}.phase-order-conflict-hint{color:#374151;margin:10px 0 0;font-size:.92rem}.modal h2{margin:0 0 6px;font-size:1.05rem}.modal input[type=range]{width:100%;margin-top:12px}.modal-actions{justify-content:flex-end;align-items:center;gap:10px;margin-top:10px;display:flex}.color-grid{grid-template-columns:repeat(6,minmax(0,1fr));gap:8px;margin-top:12px;display:grid}.color-swatch{aspect-ratio:1;cursor:pointer;border:1px solid #11182740;border-radius:8px;width:100%}.color-swatch.selected{outline-offset:1px;outline:3px solid #111827}.modal-edit-note-types{max-width:min(520px,100vw - 32px)}.edit-note-types-list{flex-direction:column;gap:16px;max-height:min(52vh,420px);margin-top:12px;padding-right:4px;display:flex;overflow-y:auto}.edit-note-type-row{border:1px solid var(--line);background:#fafafa;border-radius:10px;padding:10px 12px}.edit-note-type-row-title{color:var(--muted);letter-spacing:.02em;margin:0 0 8px;font-size:.75rem;font-weight:600}.edit-note-type-fields{gap:8px;display:grid}.edit-note-type-label-field label,.edit-note-type-hex-field label{color:#374151;margin-bottom:4px;font-size:.78rem;font-weight:600;display:block}.edit-note-type-label-input{border:1px solid var(--line);width:100%;font:inherit;border-radius:8px;padding:8px 10px}.edit-note-type-hex-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.edit-note-type-hex-input{border:1px solid var(--line);border-radius:8px;flex:1;min-width:120px;padding:8px 10px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.85rem}.edit-note-type-swatch-preview{border:1px solid #11182740;border-radius:8px;flex-shrink:0;width:36px;height:36px}.color-grid.color-grid--edit-row{grid-template-columns:repeat(6,minmax(0,1fr));gap:6px;margin-top:8px}.edit-note-type-row-delete{justify-content:flex-end;margin-top:10px;display:flex}.color-grid.color-grid--edit-row .color-swatch{aspect-ratio:1}.app-footer{color:var(--muted);text-align:center;margin-top:auto;padding-top:16px;font-size:.85rem}.app-footer>p{margin:0}.app-footer a{color:inherit;text-decoration:underline}.app-footer-version{font-variant-numeric:tabular-nums;font-weight:600}.app-footer-version:empty{display:none}@media (width<=900px){.landing-grid{grid-template-columns:1fr}.landing-demos-card{min-height:0}}@media (width<=640px){.app{--app-padding-inline:14px;padding:14px}.landing-hero{padding:16px}.landing-grid,.landing-stack{gap:10px}.landing-card{min-height:0;padding:13px}.demo-map{gap:6px;padding-left:16px}.board-card{grid-template-columns:minmax(0,1fr) auto;gap:10px}#groups-list,#boards-list{grid-template-columns:1fr}.board-actions{justify-content:flex-end}.action-label{display:none}.action-button{justify-content:center;min-width:40px}.create-board-form{grid-template-columns:1fr}.structure-form-actions{flex-direction:column}.editor-topbar{grid-template-columns:auto 1fr auto;align-items:start}.editor-topbar-center{justify-self:end;padding-top:2px}.editor-topbar-center h1{text-align:right;font-size:1.1rem}.editor-topbar-center .subtitle{text-align:right;margin-top:2px;font-size:.88rem}.options-menu .menu-item-desktop-only,.options-button .options-button-label,#editor-view .options-wrap-desktop-only,.board-actions-trigger-label{display:none}.dashboard-topbar-center{justify-self:end}.dashboard-topbar-center h1{text-align:right}}
