: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-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}
