:root{color:#17211b;background:#f4f0e8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0;background:linear-gradient(135deg,rgba(177,36,36,.08),transparent 30%),linear-gradient(315deg,rgba(30,91,91,.1),transparent 35%),#f4f0e8}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{width:100%;min-height:100vh;margin:0;padding:12px}.top-bar,.workspace-grid,.encounter-section{background:#fffcf5eb;border:1px solid rgba(76,61,44,.16);box-shadow:0 16px 50px #1f181114}.top-bar{display:flex;align-items:end;justify-content:space-between;gap:18px;padding:18px;border-radius:8px 8px 0 0}.title-block{display:grid;gap:6px;min-width:min(520px,100%)}.field-label{color:#6c5e4e;font-size:.82rem;font-weight:700;text-transform:uppercase}.game-title-input{width:100%;min-height:48px;padding:4px 0;border:0;border-bottom:2px solid #b33a3a;background:transparent;color:#18130f;font-size:clamp(1.75rem,3vw,3rem);font-weight:800;outline:none}.state-actions,.encounter-actions,.section-heading{display:flex;align-items:center;gap:10px}.state-actions{flex-wrap:wrap;justify-content:flex-end}.storage-pill{min-height:36px;display:inline-flex;align-items:center;padding:0 12px;border:1px solid rgba(29,95,95,.24);border-radius:999px;background:#eaf3ef;color:#1d5f5f;font-size:.88rem;font-weight:700;white-space:nowrap}.hidden-input{display:none}.workspace-grid{display:grid;grid-template-columns:minmax(0,1fr) 10px minmax(220px,var(--notes-width, 260px));gap:12px;align-items:stretch;padding:14px;border-top:0}.players-section,.notes-section,.encounter-section{min-width:0}.notes-section{display:flex;flex-direction:column;overflow:hidden}.notes-resizer{align-self:stretch;width:10px;min-width:10px;padding:0;border:0;border-radius:8px;background:transparent;cursor:col-resize;position:relative}.notes-resizer:before{content:"";position:absolute;inset:32px 4px;border-radius:999px;background:#4c3d2c2e}.notes-resizer:hover:before,.notes-resizer:focus-visible:before{background:#1d7772}.section-heading{justify-content:space-between;margin-bottom:12px}.section-heading h2{margin:0;color:#201913;font-size:1.05rem}.section-heading p{margin:3px 0 0;color:#766657}.table-wrap{width:100%;overflow-x:auto;border:1px solid rgba(76,61,44,.16);border-radius:8px;background:#fffdf8}.table-footer{display:flex;justify-content:flex-start;margin-top:12px}table{width:100%;border-collapse:collapse}th,td{border-bottom:1px solid rgba(76,61,44,.12);padding:6px;text-align:left;vertical-align:middle}th{background:#efe7da;color:#554635;font-size:.78rem;font-weight:800;text-transform:uppercase;white-space:nowrap}tbody tr:last-child td{border-bottom:0}.players-table{min-width:900px;table-layout:fixed}.encounter-table{min-width:760px;table-layout:fixed}.players-table th:nth-child(1),.players-table td:nth-child(1),.players-table th:nth-child(9),.players-table td:nth-child(9){width:50px}.encounter-table th:nth-child(5),.encounter-table td:nth-child(5){width:92px}.players-table th:nth-child(2),.players-table td:nth-child(2){width:115px}.players-table th:nth-child(3),.players-table td:nth-child(3){width:140px}.players-table th:nth-child(4),.players-table td:nth-child(4){width:116px}.players-table th:nth-child(5),.players-table td:nth-child(5){width:124px}.players-table th:nth-child(6),.players-table td:nth-child(6),.players-table th:nth-child(7),.players-table td:nth-child(7),.encounter-table th:nth-child(3),.encounter-table td:nth-child(3){width:120px}.players-table th:nth-child(6),.players-table td:nth-child(6){width:70px}.players-table th:nth-child(7),.players-table td:nth-child(7){width:92px}.players-table th:nth-child(8),.players-table td:nth-child(8){width:auto}input,select,textarea{width:100%;border:1px solid rgba(92,75,58,.24);border-radius:6px;background:#fffefb;color:#201913;outline:none;transition:border-color .18s ease,box-shadow .18s ease,background .18s ease}input,select{min-height:34px;padding:0 8px}textarea{min-height:52px;padding:8px;line-height:1.35;resize:vertical}input:focus,select:focus,textarea:focus{border-color:#1d7772;box-shadow:0 0 0 3px #1d777224}input:disabled,select:disabled{background:#f3eee5;color:#695c4d}.session-notes{flex:1;min-height:150px;height:auto;resize:none}.primary-button,.secondary-button,.icon-button,.active-icon-button,.danger-icon-button,.drag-handle{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:8px;font-weight:800;white-space:nowrap}.primary-button,.secondary-button{min-height:36px;padding:0 12px}.primary-button{background:#9f2e2e;color:#fffdf8}.secondary-button{background:#d9eadf;color:#20574d}.icon-button,.active-icon-button,.danger-icon-button,.drag-handle{width:34px;height:34px;padding:0}.icon-button{background:#1d5f5f;color:#fffdf8}.danger-icon-button{background:#f3dfdc;color:#9f2e2e}.active-icon-button{background:#e8efe4;color:#547248}.active-icon-button.is-active{background:#dff3d8;color:#1f5d32}.active-icon-button.is-active{box-shadow:inset 0 0 0 2px #1f5d324d}.encounter-table .active-combatant td{background:#edf8e9}.encounter-table .active-combatant input,.encounter-table .active-combatant select{background:#dff3d8;border-color:#1f5d326b;color:#1f5d32}.encounter-table .active-combatant td:first-child input{font-weight:800}.drag-cell,.delete-cell,.action-cell{text-align:center}.players-table .drag-cell,.players-table .delete-cell{padding:6px 4px}.delete-cell .danger-icon-button,.drag-cell .drag-handle{margin:0 auto}.action-cell{white-space:nowrap}.action-cell button+button{margin-left:6px}.drag-handle{background:#eee5d6;color:#7b674f;cursor:grab}.drag-handle:active{cursor:grabbing}.encounter-section{padding:14px;border-top:0;border-radius:0 0 8px 8px}.encounter-heading{align-items:end;flex-wrap:wrap}.encounter-title-block{display:grid;gap:4px}.encounter-title-input{width:min(360px,100%);min-height:32px;padding:0 8px;border:1px solid rgba(76,61,44,.18);background:#fffdf8;color:#5d5042;font-weight:700}.encounter-title-input:focus{border-color:#1d7772;box-shadow:0 0 0 3px #1d777224}.archive-panel{margin-top:16px;border:1px solid rgba(76,61,44,.16);border-radius:8px;background:#fffdf8}.archive-panel summary{padding:12px 14px;color:#554635;font-weight:800;cursor:pointer}.archive-empty{margin:0;padding:0 14px 14px;color:#766657}.archive-list{display:grid;gap:10px;padding:0 14px 14px}.archive-item{display:grid;gap:4px;padding:12px;border:1px solid rgba(76,61,44,.12);border-radius:8px;background:#fbf7ef}.archive-item-header{display:flex;justify-content:space-between;align-items:start;gap:12px;color:#201913}.archive-item-header div{display:grid;gap:3px;min-width:0}.archive-item-header strong,.archive-item-header span{overflow-wrap:anywhere}.archive-item span,.archive-item p{color:#766657}.archive-item p{margin:0}@media(max-width:1180px){.workspace-grid{grid-template-columns:1fr}.notes-resizer{display:none}.session-notes{min-height:260px}}@media(max-width:720px){.app-shell{padding:10px}.top-bar{align-items:stretch;flex-direction:column}.state-actions,.section-heading,.encounter-actions{align-items:stretch;justify-content:flex-start}.section-heading,.encounter-actions{flex-direction:column}.primary-button,.secondary-button{width:100%}}
