:root{--parchment: #f4e4c1;--parchment-dark: #e8d3a0;--parchment-deeper: #d9c080;--ink: #1a0e00;--ink-light: #4a3520;--gold: #8b6914;--gold-light: #c4981f;--crimson: #8b1a1a;--crimson-light: #c0392b;--border: #6b4c2a;--border-light: #9b7a4a;--shadow: rgba(26, 14, 0, .2);--white: #fdf8ef;--font-display: "Cinzel Decorative", "Cinzel", serif;--font-heading: "Cinzel", serif;--font-body: "Lora", Georgia, serif;--radius: 4px;--radius-lg: 8px;--section-gap: 1.5rem;--card-padding: 1.25rem;--nav-width: 220px;--header-height: 64px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-body);background-color:var(--parchment);color:var(--ink);min-height:100dvh;line-height:1.5;background-image:radial-gradient(ellipse at 20% 10%,rgba(180,140,60,.08) 0%,transparent 60%),radial-gradient(ellipse at 80% 90%,rgba(150,100,30,.06) 0%,transparent 60%),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='400' height='400' filter='url(%23noise)' opacity='0.035'/%3E%3C/svg%3E")}#root{min-height:100dvh;display:flex;flex-direction:column}h1,h2,h3,h4{font-family:var(--font-heading);color:var(--ink);line-height:1.2}a{color:var(--gold);text-decoration:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--parchment-dark)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border)}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1.1rem;font-family:var(--font-heading);font-size:.8rem;font-weight:600;letter-spacing:.05em;border-radius:var(--radius);border:1.5px solid var(--border);background:var(--parchment);color:var(--ink);cursor:pointer;transition:background .15s,box-shadow .15s,transform .1s;white-space:nowrap;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;min-height:44px}.btn:hover{background:var(--parchment-dark);box-shadow:0 2px 6px var(--shadow)}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--gold);border-color:var(--gold);color:var(--white)}.btn-primary:hover{background:var(--gold-light);border-color:var(--gold-light)}.btn-danger{background:transparent;border-color:var(--crimson);color:var(--crimson)}.btn-danger:hover{background:var(--crimson);color:var(--white)}.btn-ghost{border-color:transparent;background:transparent}.btn-ghost:hover{background:var(--parchment-dark);border-color:var(--border-light)}.btn-icon{padding:.5rem;min-width:44px;justify-content:center}.field-group{display:flex;flex-direction:column;gap:.25rem}.field-label{font-family:var(--font-heading);font-size:.65rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gold)}.field-input,.field-textarea,.field-select{font-family:var(--font-body);font-size:.95rem;color:var(--ink);background:transparent;border:none;border-bottom:1.5px solid var(--border-light);border-radius:0;padding:.3rem .1rem;width:100%;outline:none;min-height:36px;transition:border-color .15s}.field-input:focus,.field-textarea:focus,.field-select:focus{border-bottom-color:var(--gold)}.field-textarea{resize:vertical;min-height:80px;border:1.5px solid var(--border-light);border-radius:var(--radius);padding:.5rem;background:#ffffff4d}.field-textarea:focus{border-color:var(--gold)}.field-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236b4c2a'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .4rem center;padding-right:1.5rem}.field-number{text-align:center;font-size:1.1rem;font-weight:600}.field-checkbox-row{display:flex;align-items:center;gap:.5rem;cursor:pointer;min-height:36px}.field-checkbox{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border:2px solid var(--border);border-radius:3px;background:var(--parchment);cursor:pointer;flex-shrink:0;position:relative;transition:background .15s,border-color .15s}.field-checkbox:checked{background:var(--gold);border-color:var(--gold)}.field-checkbox:checked:after{content:"";position:absolute;left:3px;top:0;width:8px;height:12px;border:2px solid white;border-top:none;border-left:none;transform:rotate(45deg)}.section-panel{background:#ffffff40;border:1.5px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--card-padding);box-shadow:0 2px 8px var(--shadow),inset 0 1px #ffffff80}.section-panel-title{font-family:var(--font-heading);font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);border-bottom:1px solid var(--border-light);padding-bottom:.5rem;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.section-panel-title:before{content:"❧";font-size:.9rem;opacity:.7}.ornament{text-align:center;color:var(--gold);font-size:1rem;opacity:.6;letter-spacing:.3em;margin:.5rem 0;-webkit-user-select:none;user-select:none}.ability-box{display:flex;flex-direction:column;align-items:center;gap:.25rem;background:var(--parchment-dark);border:2px solid var(--border);border-radius:var(--radius-lg);padding:.6rem .5rem;min-width:80px}.ability-box-label{font-family:var(--font-heading);font-size:.6rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold)}.ability-box-mod{font-family:var(--font-heading);font-size:1.6rem;font-weight:700;line-height:1;color:var(--ink)}.ability-box-score{font-size:.85rem;color:var(--ink-light)}.ability-box-score input{font-family:var(--font-body);font-size:.85rem;color:var(--ink-light);background:transparent;border:none;border-bottom:1px solid var(--border-light);width:40px;text-align:center;outline:none}.ability-box-score input:focus{border-bottom-color:var(--gold)}.stat-bubble{display:flex;flex-direction:column;align-items:center;background:var(--parchment-dark);border:2px solid var(--border);border-radius:var(--radius-lg);padding:.5rem .75rem;min-width:72px}.stat-bubble-label{font-family:var(--font-heading);font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);text-align:center}.stat-bubble-value{font-family:var(--font-heading);font-size:1.3rem;font-weight:700;color:var(--ink)}.stat-bubble-value input{font-family:var(--font-heading);font-size:1.3rem;font-weight:700;color:var(--ink);background:transparent;border:none;width:52px;text-align:center;outline:none}.prof-dot{display:inline-block;width:14px;height:14px;border-radius:50%;border:2px solid var(--border);background:transparent;cursor:pointer;flex-shrink:0;transition:background .1s}.prof-dot.half{background:linear-gradient(135deg,var(--gold) 50%,transparent 50%);border-color:var(--gold)}.prof-dot.full{background:var(--gold);border-color:var(--gold)}.prof-row{display:flex;align-items:center;gap:.5rem;padding:.25rem 0;min-height:32px}.prof-row-value{font-family:var(--font-heading);font-size:.85rem;font-weight:600;color:var(--ink);min-width:28px;text-align:right}.prof-row-label{font-family:var(--font-body);font-size:.85rem;color:var(--ink);flex:1}.prof-row-ability{font-size:.65rem;color:var(--ink-light);font-style:italic}.fantasy-table{width:100%;border-collapse:collapse;font-size:.85rem}.fantasy-table th{font-family:var(--font-heading);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);text-align:left;padding:.4rem .5rem;border-bottom:1.5px solid var(--border-light)}.fantasy-table td{padding:.4rem .5rem;border-bottom:1px solid rgba(107,76,42,.15);vertical-align:middle}.fantasy-table tr:last-child td{border-bottom:none}.fantasy-table td input,.fantasy-table td select{font-family:var(--font-body);font-size:.85rem;background:transparent;border:none;border-bottom:1px solid transparent;outline:none;width:100%;color:var(--ink);transition:border-color .15s}.fantasy-table td input:focus,.fantasy-table td select:focus{border-bottom-color:var(--gold)}.death-save-pip{display:inline-block;width:16px;height:16px;border-radius:50%;border:2px solid var(--border);cursor:pointer;transition:background .15s;flex-shrink:0}.death-save-pip.success.filled{background:var(--gold);border-color:var(--gold)}.death-save-pip.failure.filled{background:var(--crimson);border-color:var(--crimson)}.hp-bar-container{width:100%;height:8px;background:var(--parchment-deeper);border-radius:4px;overflow:hidden;border:1px solid var(--border-light)}.hp-bar-fill{height:100%;background:linear-gradient(90deg,var(--crimson-light),var(--gold));border-radius:4px;transition:width .3s ease}.spell-level-badge{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--parchment-dark);border:1.5px solid var(--border);font-family:var(--font-heading);font-size:.65rem;font-weight:700;color:var(--gold);flex-shrink:0}.slot-pip{width:16px;height:16px;border-radius:4px;border:2px solid var(--border);background:var(--parchment);cursor:pointer;transition:background .1s;flex-shrink:0}.slot-pip.used{background:var(--border)}.add-row-btn{display:flex;align-items:center;gap:.4rem;padding:.4rem .6rem;font-family:var(--font-heading);font-size:.7rem;letter-spacing:.05em;color:var(--gold);background:transparent;border:1px dashed var(--border-light);border-radius:var(--radius);cursor:pointer;width:100%;justify-content:center;margin-top:.5rem;transition:background .15s,border-color .15s;min-height:40px}.add-row-btn:hover{background:#8b691414;border-color:var(--gold)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a0e0099;z-index:100;display:flex;align-items:center;justify-content:center;padding:1rem;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--parchment);border:2px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;max-width:480px;width:100%;box-shadow:0 20px 60px #0006;max-height:90dvh;overflow-y:auto}.modal-title{font-family:var(--font-heading);font-size:1.1rem;font-weight:700;color:var(--ink);margin-bottom:1.25rem;text-align:center;letter-spacing:.05em}.modal-title:after{content:"";display:block;width:60px;height:2px;background:var(--gold);margin:.5rem auto 0;border-radius:1px}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.character-card{background:#ffffff4d;border:2px solid var(--border-light);border-radius:var(--radius-lg);padding:1.25rem;cursor:pointer;transition:border-color .2s,box-shadow .2s,transform .15s;position:relative}.character-card:hover{border-color:var(--gold);box-shadow:0 4px 16px var(--shadow);transform:translateY(-2px)}.character-card.archived{opacity:.55;filter:grayscale(.3)}.character-card-static{cursor:default}.character-card-static:hover{border-color:var(--border-light);box-shadow:0 2px 8px var(--shadow);transform:none}.character-card-name{font-family:var(--font-heading);font-size:1.15rem;font-weight:700;color:var(--ink);margin-bottom:.25rem}.character-card-sub{font-size:.8rem;color:var(--ink-light);font-style:italic}.character-card-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .5rem;background:var(--parchment-dark);border:1px solid var(--border-light);border-radius:20px;font-family:var(--font-heading);font-size:.65rem;font-weight:600;letter-spacing:.05em;color:var(--gold);margin-top:.5rem}.character-card-menu{position:absolute;top:.75rem;right:.75rem;display:flex;gap:.25rem}.roster-header{padding:1.5rem 1.5rem 1rem;border-bottom:1.5px solid var(--border-light);display:flex;align-items:center;justify-content:space-between;gap:1rem;background:#f4e4c1cc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);position:sticky;top:0;z-index:10}.roster-title{font-family:var(--font-display);font-size:1.4rem;color:var(--ink);letter-spacing:.03em}.roster-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;padding:1.5rem}.roster-section-label{grid-column:1 / -1;font-family:var(--font-heading);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-light);padding-bottom:.5rem;border-bottom:1px solid var(--border-light);margin-top:.5rem}.roster-empty{grid-column:1 / -1;text-align:center;padding:4rem 2rem;color:var(--ink-light)}.roster-empty-title{font-family:var(--font-heading);font-size:1.1rem;margin-bottom:.5rem;color:var(--ink)}.char-layout{display:flex;flex:1;min-height:0}.char-sidebar{width:var(--nav-width);flex-shrink:0;border-right:1.5px solid var(--border-light);display:flex;flex-direction:column;overflow-y:auto;background:#e8d3a080;padding:1rem 0}.char-content{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:var(--section-gap)}.char-topbar{height:var(--header-height);display:flex;align-items:center;gap:.75rem;padding:0 1rem;border-bottom:1.5px solid var(--border-light);background:#f4e4c1e6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);flex-shrink:0;overflow-x:auto}.char-topbar-name{font-family:var(--font-heading);font-size:1.05rem;font-weight:700;color:var(--ink);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.char-topbar-sub{font-size:.75rem;color:var(--ink-light);font-style:italic;white-space:nowrap}.nav-item{display:flex;align-items:center;gap:.6rem;padding:.7rem 1rem;font-family:var(--font-heading);font-size:.75rem;font-weight:600;letter-spacing:.05em;color:var(--ink-light);cursor:pointer;border:none;background:transparent;width:100%;text-align:left;transition:color .15s,background .15s;border-left:3px solid transparent;-webkit-tap-highlight-color:transparent}.nav-item:hover{color:var(--ink);background:#8b691414}.nav-item.active{color:var(--gold);border-left-color:var(--gold);background:#8b69141a}.nav-item-icon{font-size:1rem;flex-shrink:0;width:20px;text-align:center}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}.grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}.flex-row{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-start}.inspiration-toggle{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border:2px solid var(--border-light);border-radius:var(--radius-lg);background:var(--parchment-dark);cursor:pointer;font-family:var(--font-heading);font-size:.7rem;letter-spacing:.08em;color:var(--ink-light);transition:border-color .15s,color .15s,background .15s;-webkit-user-select:none;user-select:none}.inspiration-toggle.active{border-color:var(--gold);color:var(--gold);background:#8b69141a}.currency-row{display:flex;gap:.5rem;flex-wrap:wrap}.currency-coin{display:flex;flex-direction:column;align-items:center;gap:.15rem}.currency-coin-label{font-family:var(--font-heading);font-size:.6rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.currency-coin-label.cp{color:#8b6914}.currency-coin-label.sp{color:#6e7f80}.currency-coin-label.ep{color:#4a7c59}.currency-coin-label.gp{color:#c4981f}.currency-coin-label.pp{color:#7a5c9b}.currency-coin input{width:56px;text-align:center;font-family:var(--font-heading);font-size:.9rem;font-weight:700;background:var(--parchment-dark);border:1.5px solid var(--border-light);border-radius:var(--radius);padding:.3rem;color:var(--ink);outline:none}.currency-coin input:focus{border-color:var(--gold)}.expandable-card{border:1.5px solid var(--border-light);border-radius:var(--radius);overflow:hidden;margin-bottom:.5rem}.expandable-card-header{display:flex;align-items:center;gap:.5rem;padding:.6rem .75rem;background:#fff3;cursor:pointer;-webkit-user-select:none;user-select:none}.expandable-card-header:hover{background:#fff6}.expandable-card-chevron{font-size:.6rem;color:var(--gold);transition:transform .2s;flex-shrink:0}.expandable-card-chevron.open{transform:rotate(90deg)}.expandable-card-title{font-family:var(--font-heading);font-size:.85rem;font-weight:600;color:var(--ink);flex:1}.expandable-card-body{padding:.75rem;background:#ffffff1a;border-top:1px solid var(--border-light)}.autocalc-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .5rem;background:#8b69141a;border:1px solid var(--border-light);border-radius:20px;font-family:var(--font-heading);font-size:.6rem;font-weight:700;letter-spacing:.08em;color:var(--gold);text-transform:uppercase}.share-qr{display:flex;justify-content:center;margin-bottom:1rem;padding:.75rem;background:var(--parchment-dark);border:1.5px solid var(--border-light);border-radius:var(--radius)}.share-qr svg{display:block;border-radius:4px}.share-url-box{display:flex;gap:.5rem;align-items:stretch}.share-url-input{flex:1;font-family:var(--font-body);font-size:.8rem;background:var(--parchment-dark);border:1.5px solid var(--border-light);border-radius:var(--radius);padding:.5rem .75rem;color:var(--ink);outline:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.share-url-input:focus{border-color:var(--gold)}@media print{.char-topbar,.char-sidebar,.no-print,.mobile-nav-tabs{display:none!important}.char-layout{display:block}.char-content{padding:0;overflow:visible}body{background:#fff}.section-panel{break-inside:avoid;box-shadow:none;border:1px solid #ccc}.print-all-sections,.print-only{display:block!important}button:not(.print-show){display:none!important}}@media(max-width:768px){:root{--nav-width: 0px}.char-layout{flex-direction:column}.char-sidebar{display:none}.char-topbar{height:auto;flex-wrap:wrap;padding:.75rem;gap:.5rem}.char-content{padding:1rem;gap:1rem}.grid-3,.grid-2{grid-template-columns:1fr 1fr}.roster-grid{grid-template-columns:1fr;padding:1rem;gap:.75rem}}.mobile-nav-tabs{display:none;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:.5rem 1rem;gap:.5rem;border-bottom:1.5px solid var(--border-light);background:#e8d3a099;scrollbar-width:none}.mobile-nav-tabs::-webkit-scrollbar{display:none}.mobile-tab{flex-shrink:0;padding:.4rem .75rem;font-family:var(--font-heading);font-size:.7rem;letter-spacing:.05em;border:1.5px solid var(--border-light);border-radius:20px;background:transparent;color:var(--ink-light);cursor:pointer;white-space:nowrap;min-height:36px}.mobile-tab.active{border-color:var(--gold);color:var(--gold);background:#8b69141a}@media(max-width:768px){.mobile-nav-tabs{display:flex}}.toggle-switch{position:relative;display:inline-block;width:40px;height:22px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;right:0;bottom:0;left:0;background:var(--border-light);border-radius:22px;transition:background .2s}.toggle-slider:before{content:"";position:absolute;height:16px;width:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform .2s}.toggle-switch input:checked+.toggle-slider{background:var(--gold)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(18px)}.text-muted{color:var(--ink-light);font-style:italic;font-size:.85rem}.text-small{font-size:.8rem}.divider{height:1px;background:var(--border-light);margin:.75rem 0;opacity:.5}.auth-shell{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem 1rem}.auth-card{background:#ffffff59;border:2px solid var(--border-light);border-radius:var(--radius-lg);padding:2.5rem 2rem;max-width:380px;width:100%;box-shadow:0 8px 24px var(--shadow)}.auth-title{font-family:var(--font-display);font-size:1.7rem;text-align:center;color:var(--ink);margin-bottom:.25rem;letter-spacing:.06em}.auth-subtitle{text-align:center;font-size:.85rem;color:var(--ink-light);font-style:italic;margin-bottom:1.5rem}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-error{color:var(--crimson);font-size:.85rem;text-align:center;margin-top:-.25rem}.app-topbar{display:flex;align-items:center;padding:.75rem 1.5rem;background:#f4e4c1e6;border-bottom:1.5px solid var(--border-light);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);position:sticky;top:0;z-index:20;gap:1rem}.app-brand{font-family:var(--font-display);font-size:1.2rem;letter-spacing:.08em;color:var(--ink)}.app-nav{display:flex;gap:.5rem;flex:1}.app-nav-link{font-family:var(--font-heading);font-size:.75rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-light);padding:.4rem .75rem;border-radius:var(--radius);cursor:pointer}.app-nav-link:hover{color:var(--ink);background:#8b691414}.app-nav-link.active{color:var(--gold);background:#8b69141f}.session-list-shell{flex:1;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.session-list-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.session-list-title{font-family:var(--font-display);font-size:1.5rem;color:var(--ink)}.session-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.session-card{background:#ffffff4d;border:2px solid var(--border-light);border-radius:var(--radius-lg);padding:1.25rem;cursor:pointer;transition:border-color .2s,box-shadow .2s,transform .15s;display:flex;flex-direction:column;gap:.4rem}.session-card:hover{border-color:var(--gold);box-shadow:0 4px 16px var(--shadow);transform:translateY(-2px)}.session-card-name{font-family:var(--font-heading);font-size:1.05rem;font-weight:700;color:var(--ink)}.session-card-meta{font-size:.78rem;color:var(--ink-light);font-style:italic}.session-card-tone{font-size:.85rem;color:var(--ink);margin-top:.25rem}.session-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:.5rem}.wizard-shell{flex:1;padding:1.5rem;max-width:720px;margin:0 auto;width:100%;display:flex;flex-direction:column;gap:1rem}.wizard-title{font-family:var(--font-display);font-size:1.6rem;color:var(--ink);text-align:center;margin-bottom:.5rem}.wizard-step-toggle{display:flex;gap:.5rem;border:1.5px solid var(--border-light);border-radius:var(--radius);padding:.3rem;background:#ffffff4d}.wizard-step-toggle button{flex:1;padding:.5rem .75rem;font-family:var(--font-heading);font-size:.75rem;letter-spacing:.06em;text-transform:uppercase;background:transparent;border:none;border-radius:var(--radius);cursor:pointer;color:var(--ink-light)}.wizard-step-toggle button.active{background:var(--gold);color:var(--white)}.empty-state{text-align:center;padding:3rem 1rem;color:var(--ink-light)}.empty-state-title{font-family:var(--font-heading);font-size:1.05rem;color:var(--ink);margin-bottom:.5rem}.row{display:flex;gap:.75rem;align-items:center}.row-wrap{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.row-end{display:flex;gap:.75rem;justify-content:flex-end}.row-between{display:flex;gap:1rem;justify-content:space-between;align-items:baseline}.row-spread{display:flex;gap:.75rem;align-items:center;justify-content:space-between}.stack{display:flex;flex-direction:column;gap:1rem}.stack-sm{display:flex;flex-direction:column;gap:.5rem}.stack-tight{display:flex;flex-direction:column;gap:.25rem}.flex-1{flex:1}.flex-grow{flex:1;min-width:0}.mb-sm{margin-bottom:.5rem}.mb-md{margin-bottom:1rem}.mt-sm{margin-top:.5rem}.mt-md{margin-top:1rem}.center{text-align:center}.no-shrink{flex-shrink:0}.full{width:100%}.full-height-column{display:flex;flex-direction:column;flex:1;min-height:0}.label-emphasis{font-family:var(--font-heading);font-size:1.05rem;font-weight:700;color:var(--ink)}.heading-small{font-family:var(--font-heading);font-size:.85rem;font-weight:600;color:var(--ink)}.heading-tiny{font-family:var(--font-heading);font-size:.75rem;font-weight:600;color:var(--ink)}.wizard-title-aligned{text-align:left;margin-bottom:.25rem}.hero-card-name{font-family:var(--font-heading);font-size:1.05rem;font-weight:700}.session-header-summary{flex:1;min-width:200px}.settings-role-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;padding-bottom:.75rem;border-bottom:1px dashed var(--border-light)}.settings-role-row .settings-role-help{grid-column:1 / -1;margin-top:-.25rem}@media(max-width:600px){.settings-role-row{grid-template-columns:1fr}}.section-action-btn{padding:0 .5rem;font-size:.75rem;min-height:28px}.danger-link{color:var(--crimson);font-size:.75rem;min-height:36px}.divider-margin-top{margin-top:1rem}.muted-helper{margin-top:.5rem}.toggle-row{display:flex;align-items:center;gap:.75rem;cursor:pointer}.toggle-row-body{font-family:var(--font-heading);font-size:.85rem;margin-bottom:.15rem}.field-input.input-emphasis{font-size:1.05rem;font-weight:600}.section-stack{display:flex;flex-direction:column;gap:1rem}.section-stack-sm{display:flex;flex-direction:column;gap:.75rem}.empty-message{text-align:center;padding:1rem 0}.empty-message-lg{text-align:center;padding:1.5rem 0}.btn-section-action{padding:0 .5rem;font-size:.75rem;min-height:28px}.field-overflow-x{overflow-x:auto}.stat-input-inline{width:52px;text-align:center;font-family:var(--font-heading);font-size:1.3rem;font-weight:700;background:transparent;border:none;border-bottom:1px solid var(--border-light);outline:none;color:var(--ink)}.btn-link-gold{background:none;border:none;color:var(--gold);cursor:pointer;font-size:.8rem;padding:.2rem;min-height:28px}.btn-link-danger{background:none;border:none;color:var(--crimson);cursor:pointer;font-size:.8rem;padding:.2rem;min-height:28px}.btn-icon-danger{background:none;border:none;color:var(--crimson);cursor:pointer;font-size:1rem;padding:.2rem;min-height:32px;min-width:32px}.font-small{font-size:.85rem}.font-xs{font-size:.78rem}.font-xxs{font-size:.7rem}.row-baseline{display:flex;gap:.75rem;align-items:baseline}.attack-table-wide{min-width:580px}.equipment-table-wide{min-width:480px}.unequipped{opacity:.65}.abilities-row{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.prof-bonus-row{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}.game-layout{display:grid;grid-template-columns:260px 1fr;flex:1;min-height:0}.game-side{display:flex;flex-direction:column;min-height:0;border-right:1.5px solid var(--border-light);background:#e8d3a073;overflow-y:auto}.game-side .party-panel{border-right:none;background:transparent;overflow:visible;padding-top:.5rem}.error-banner{padding:.5rem 1rem}@media(max-width:900px){.game-layout{grid-template-columns:1fr}.game-layout .game-side{display:none}}.game-main{display:flex;flex-direction:column;min-height:0;min-width:0;flex:1}.game-topbar{padding:.6rem 1rem;border-bottom:1.5px solid var(--border-light);display:flex;align-items:center;gap:.75rem;background:#f4e4c1d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);flex-shrink:0}.game-topbar-name{font-family:var(--font-heading);font-size:1rem;font-weight:700;color:var(--ink);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.game-topbar-meta{font-size:.78rem;color:var(--ink-light);font-style:italic;white-space:nowrap}.party-panel{border-right:1.5px solid var(--border-light);background:#e8d3a073;overflow-y:auto;padding:.75rem;display:flex;flex-direction:column;gap:.75rem}.party-card{background:#ffffff59;border:1.5px solid var(--border-light);border-radius:var(--radius-lg);padding:.6rem .75rem;position:relative}.party-card-player{border-color:var(--gold);background:#ffffff8c}.party-card-name{font-family:var(--font-heading);font-size:.9rem;font-weight:700;color:var(--ink)}.party-card-sub{font-size:.72rem;color:var(--ink-light);font-style:italic;margin-bottom:.4rem}.party-card-hp{font-size:.78rem;color:var(--ink);display:flex;align-items:center;gap:.3rem;flex-wrap:wrap}.party-card-sep{color:var(--border-light);margin:0 .1rem}.party-card-btn{margin-top:.5rem;padding:.3rem .6rem;font-size:.7rem;min-height:32px;width:100%;justify-content:center}.party-card-divider{font-family:var(--font-heading);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-light);margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border-light)}.narrative-panel{flex:1;overflow-y:auto;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1rem;font-size:.95rem;line-height:1.7}.narrative-message{display:flex;flex-direction:column;gap:.5rem}.narrative-paragraph{margin:0}.narrative-player{background:#ffffff59;border-left:3px solid var(--gold);padding:.6rem .9rem;border-radius:0 var(--radius) var(--radius) 0;font-style:italic;color:var(--ink)}.narrative-prose,.narrative-dm{color:var(--ink)}.narrative-speaker{font-family:var(--font-heading);font-weight:700;font-size:.85rem;letter-spacing:.04em;margin-right:.35rem}.narrative-speaker-dm{color:var(--gold)}.narrative-npc-1 .narrative-speaker{color:#4a6d8a}.narrative-npc-2 .narrative-speaker{color:#6e4a82}.narrative-npc-3 .narrative-speaker{color:#7a5a2a}.narrative-npc-other .narrative-speaker{color:var(--crimson)}.narrative-thinking{color:var(--ink-light);font-style:italic;display:flex;align-items:center;gap:.5rem}.narrative-dm-streaming:after{content:"▍";display:inline-block;color:var(--gold);margin-left:.2rem;animation:blink 1s steps(1) infinite}@keyframes blink{50%{opacity:0}}.map-panel{background:#e8d3a08c;border-bottom:1.5px solid var(--border-light);padding:.5rem}.map-panel-empty{text-align:center;padding:1rem .5rem}.map-grid{display:grid;width:100%;gap:1px;background:var(--ink-light);border:1px solid var(--border);border-radius:4px;overflow:hidden;position:relative}.map-cell{position:relative;display:flex;align-items:center;justify-content:center;min-width:0;min-height:0}.map-cell-fogged{background:var(--ink)!important;opacity:.85}.map-cell-label{font-family:var(--font-heading);font-size:.5rem;font-weight:700;letter-spacing:.05em;color:var(--ink);background:#fff9;padding:0 .2rem;border-radius:2px;white-space:nowrap;pointer-events:none;max-width:calc(100% - 4px);overflow:hidden;text-overflow:ellipsis}.map-token{align-self:center;justify-self:center;width:75%;height:75%;border-radius:50%;background:var(--gold);border:1.5px solid var(--ink);display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:.55rem;font-weight:700;color:var(--white);box-shadow:0 1px 3px #0006;z-index:2}.combat-tracker{border-bottom:1.5px solid var(--border-light);background:#c0392b0f;padding:.5rem .75rem;flex-shrink:0}.combat-tracker-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:.4rem}.combat-tracker-header .heading-tiny{font-family:var(--font-heading);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--crimson)}.combat-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.3rem}.combat-row{display:flex;align-items:center;gap:.5rem;padding:.35rem .5rem;border:1.5px solid transparent;border-radius:var(--radius);background:#ffffff4d}.combat-row-active{border-color:var(--gold);background:#c4981f2e;box-shadow:0 1px 4px #0000001a}.combat-row-player .combat-name{color:var(--ink);font-weight:700}.combat-init{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--gold);min-width:24px;text-align:center}.combat-name-block{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}.combat-name{font-family:var(--font-heading);font-size:.8rem;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.combat-hp-bar{width:100%;height:5px;background:var(--parchment-deeper);border-radius:3px;overflow:hidden;border:1px solid var(--border-light)}.combat-hp-fill{height:100%;background:linear-gradient(90deg,var(--crimson-light),var(--gold));transition:width .3s ease}.combat-hp-text{font-size:.7rem;color:var(--ink)}.dice-display{display:flex;align-items:center;justify-content:center;gap:.75rem;margin:.75rem 0;flex-wrap:wrap}.die-face{width:64px;height:64px;border-radius:12px;background:var(--parchment-dark);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1.7rem;font-weight:700;color:var(--ink);box-shadow:0 4px 10px #0003,inset 0 1px #fff9;transition:transform .1s}.die-rolling{animation:die-shake .12s ease-in-out infinite alternate}@keyframes die-shake{0%{transform:translateY(-2px) rotate(-3deg)}to{transform:translateY(2px) rotate(3deg)}}.die-bonus{font-family:var(--font-heading);font-size:1.4rem;font-weight:700;color:var(--ink-light);padding:0 .5rem}.dice-result{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding-top:.5rem;border-top:1px solid var(--border-light);margin-top:.5rem}.dice-total{display:flex;align-items:baseline;gap:.5rem}.dice-total-value{font-family:var(--font-display);font-size:2.2rem;font-weight:900;color:var(--gold);line-height:1}.dice-outcome{font-family:var(--font-heading);font-size:.85rem;font-weight:700;letter-spacing:.06em;padding:.25rem .75rem;border-radius:20px}.dice-success{background:#4a7c592e;color:#2c5d3b;border:1px solid #4a7c59}.dice-failure{background:#8b1a1a1f;color:var(--crimson);border:1px solid var(--crimson)}.dice-chip{display:inline-flex;align-items:center;gap:.3rem;padding:.1rem .5rem;margin:0 .15rem;background:var(--parchment-dark);border:1px solid var(--border-light);border-radius:12px;font-family:var(--font-heading);font-size:.72rem;font-weight:600;letter-spacing:.04em;color:var(--gold)}.dice-chip-result{background:#c4981f26;border-color:var(--gold)}.player-input{border-top:1.5px solid var(--border-light);padding:.75rem 1rem;background:#f4e4c1e6;display:flex;gap:.6rem;align-items:flex-end}.player-input-textarea{flex:1;font-family:var(--font-body);font-size:.95rem;color:var(--ink);background:#fff6;border:1.5px solid var(--border-light);border-radius:var(--radius);padding:.5rem .7rem;outline:none;resize:none;min-height:48px;max-height:140px;transition:border-color .15s}.player-input-textarea:focus{border-color:var(--gold)}.player-input-actions{display:flex;flex-direction:column;gap:.4rem}.expandable-card-tight{margin-bottom:.4rem}.feature-source-meta{font-size:.7rem;color:var(--ink-light);font-style:italic}.feature-description{font-size:.85rem;line-height:1.6;white-space:pre-wrap}.spinner{display:inline-block;width:16px;height:16px;border:2px solid var(--border-light);border-top-color:var(--gold);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
