:root{--bg-primary:#1e1e24;--bg-secondary:#2a2a32;--bg-card:#33333d;--bg-input:#3a3a44;--bg-header:linear-gradient(180deg, #4a1a1a 0%, #2d1010 100%);--text-primary:#fff;--text-secondary:#ffffffb3;--text-muted:#fff6;--nav-active:#fff;--nav-inactive:#fff9;--nav-bg:#1a1a22;--color-str:#e74c3c;--color-dex:#f0b832;--color-end:#e8d44d;--color-intl:#4fc3f7;--color-cha:#ab47bc;--color-intu:#e91e8a;--color-luc:#4caf50;--color-danger:#c0392b;--color-add:#555;--color-dice-btn:#2196f3;--font-serif:Georgia, "Times New Roman", serif;--font-sans:system-ui, -apple-system, sans-serif;--font-mono:ui-monospace, Consolas, monospace;--header-height:56px;--nav-height:64px;--radius:6px}*,:before,:after{box-sizing:border-box;margin:0;padding:0;list-style:none}::marker{box-sizing:border-box;margin:0;padding:0;list-style:none}html,body{overscroll-behavior:none;touch-action:manipulation;height:100dvh;overflow:hidden}@media (display-mode:standalone){html,body{height:100vh}}body{font-family:var(--font-sans);color:var(--text-primary);background:var(--nav-bg);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;font-size:16px;line-height:1.4}#root{flex-direction:column;max-width:480px;height:100%;margin:0 auto;display:flex;overflow:hidden}.app{flex-direction:column;height:100%;display:flex;overflow:hidden}.header{padding:8px 16px;padding-top:calc(8px + env(safe-area-inset-top,0px));height:calc(var(--header-height) + env(safe-area-inset-top,0px));background:var(--bg-header);z-index:10;flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.header-name{font-family:var(--font-serif);font-variant:small-caps;letter-spacing:1px;color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;min-width:0;padding:0;font-size:28px;font-weight:400}.header-name::placeholder{color:var(--text-muted);font-style:italic}.header-right{flex-shrink:0;align-items:center;gap:12px;display:flex}.header-level{font-family:var(--font-serif);color:var(--text-secondary);align-items:center;gap:4px;font-size:22px;display:flex}.header-level-label{font-variant:small-caps;font-size:16px}.header-level-input{width:36px;height:1em;color:var(--text-primary);font-family:var(--font-serif);text-align:center;background:0 0;border:none;outline:none;align-self:flex-start;margin-top:-4px;padding:0;font-size:22px;line-height:1}.header-level-input::-webkit-inner-spin-button{-webkit-appearance:none}.header-level-input::-webkit-outer-spin-button{-webkit-appearance:none}.hamburger-btn{cursor:pointer;background:0 0;border:none;align-items:center;padding:4px;display:flex}.hamburger-btn img{opacity:.9;width:28px;height:28px}.content-area{flex:1;position:relative;overflow:hidden}.swipe-container{will-change:transform;height:100%;display:flex}.swipe-container.animating{transition:transform .4s cubic-bezier(.25,.46,.45,.94)}.swipe-page{-webkit-overflow-scrolling:touch;flex:0 0 100%;width:100%;height:100%;padding:16px 16px 24px;overflow:hidden auto}.bottom-nav{background:var(--nav-bg);min-height:var(--nav-height);padding-bottom:max(4px, env(safe-area-inset-bottom,0px));z-index:10;flex-shrink:0;justify-content:space-around;align-items:flex-end;display:flex;position:relative}.nav-tab{cursor:pointer;color:var(--nav-inactive);background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;padding:6px 0;transition:color .15s;display:flex}.nav-tab.active{color:var(--nav-active)}.nav-tab img{opacity:.6;width:24px;height:24px;transition:opacity .15s}.nav-tab.active img{opacity:1}.nav-tab-label{font-size:10px;font-weight:500}.nav-dice-btn{cursor:pointer;background:0 0;border:none;flex:1;justify-content:center;align-items:center;padding:0;display:flex;position:relative}.nav-dice-btn-circle{background:var(--color-dice-btn);border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:transform .15s;display:flex;position:absolute;bottom:8px;box-shadow:0 2px 12px #2196f366}.nav-dice-btn-circle:active{transform:scale(.95)}.nav-dice-btn-circle img{opacity:.9;width:32px;height:32px}.page-placeholder{height:100%;color:var(--text-muted);justify-content:center;align-items:center;font-size:18px;font-style:italic;display:flex}.section-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.section-title{font-family:var(--font-serif);color:var(--text-primary);font-size:20px;font-style:italic;font-weight:400}.section-header--add-only{justify-content:flex-end}.btn-add{border-radius:var(--radius);background:var(--color-add);width:36px;height:36px;color:var(--text-primary);cursor:pointer;border:none;justify-content:center;align-items:center;font-size:22px;font-weight:300;line-height:1;display:flex}.btn-delete{border-radius:var(--radius);background:var(--color-danger);width:36px;height:36px;color:var(--text-primary);cursor:pointer;border:none;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}input,textarea{font-family:inherit;font-size:inherit;color:inherit}input[type=number]{-moz-appearance:textfield}input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none}input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none}.abilities-page{padding-bottom:24px}.portrait-section{margin:-16px -16px 16px;position:relative}.portrait-container{aspect-ratio:1;background:var(--bg-secondary);width:100%;overflow:hidden}.portrait-image{object-fit:cover;width:100%;height:100%;display:block}.vital-stats{background:linear-gradient(#0000,#000000bf);justify-content:space-between;align-items:flex-end;min-height:72px;padding:12px 16px;display:flex;position:absolute;bottom:0;left:0;right:0}.vital-group{flex-direction:column;gap:2px;display:flex}.vital-group--center{align-items:center}.vital-group--right{align-items:flex-end}.vital-values{align-items:baseline;gap:4px;display:flex}.vital-input{color:var(--text-primary);font-family:var(--font-sans);-moz-appearance:textfield;background:0 0;border:none;outline:none;padding:0}.vital-input::-webkit-inner-spin-button{-webkit-appearance:none}.vital-input::-webkit-outer-spin-button{-webkit-appearance:none}.vital-input--large{text-align:left;width:56px;font-size:32px;font-weight:700}.vital-input--small{width:40px;color:var(--text-secondary);text-align:left;font-size:20px;font-weight:500}.vital-group--right .vital-input--large{text-align:right}.vital-nat-ac{color:var(--text-secondary);font-size:18px;font-weight:500}.vital-label{color:var(--text-secondary);font-size:12px;font-weight:400}.stat-grid{grid-template-columns:1fr 1fr 1fr;gap:8px;padding:0 8px;display:grid}.stat-grid-cell--0{grid-area:1/2}.stat-grid-cell--1{grid-area:2/1}.stat-grid-cell--2{grid-area:2/3}.stat-grid-cell--3{grid-area:3/2}.stat-grid-cell--4{grid-area:4/1}.stat-grid-cell--5{grid-area:4/3}.stat-grid-cell--6{grid-area:5/2}.stat-tile{background:var(--bg-card);cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:manipulation;border-radius:8px;flex-direction:column;align-items:center;gap:4px;min-height:120px;padding:12px 8px;display:flex}.stat-diamond{justify-content:center;align-items:center;width:56px;height:56px;display:flex;position:relative}.stat-diamond-inner{border:2px solid var(--stat-color);justify-content:center;align-items:center;width:44px;height:44px;display:flex;position:relative;transform:rotate(45deg)}.stat-diamond-icon{border:1.5px solid var(--stat-color);width:18px;height:18px;position:absolute;top:-10px;left:-10px;transform:rotate(0)}.stat-value{color:var(--text-primary);font-size:24px;font-weight:600;line-height:1;transform:rotate(-45deg)}.stat-value-input{color:var(--text-primary);border:1px solid var(--stat-color);text-align:center;width:36px;font-size:22px;font-weight:600;font-family:var(--font-sans);-moz-appearance:textfield;background:#ffffff1a;border-radius:4px;outline:none;padding:2px;transform:rotate(-45deg)}.stat-value-input::-webkit-inner-spin-button{-webkit-appearance:none}.stat-value-input::-webkit-outer-spin-button{-webkit-appearance:none}.stat-label{color:var(--text-secondary);font-size:13px;font-weight:400}.stat-dice{min-height:14px;color:var(--text-muted);font-size:11px;font-family:var(--font-mono)}.strokes-of-luck{background:var(--bg-card);border-radius:8px;justify-content:space-between;align-items:center;margin-top:16px;padding:12px 16px;display:flex}.sol-header{align-items:center;gap:8px;display:flex}.sol-icon{width:24px;height:24px}.sol-title{color:var(--text-secondary);font-size:14px}.sol-reset{cursor:pointer;background:0 0;border:none;padding:4px;display:flex}.sol-reset img{opacity:.6;width:18px;height:18px}.sol-row{align-items:center;gap:8px;display:flex}.sol-decrement{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;padding:4px 8px;font-size:18px}.sol-value{text-align:center;width:48px;color:var(--color-luc);font-size:24px;font-weight:700;font-family:var(--font-sans);-moz-appearance:textfield;background:0 0;border:none;outline:none;padding:0}.sol-value::-webkit-inner-spin-button{-webkit-appearance:none}.sol-value::-webkit-outer-spin-button{-webkit-appearance:none}.sol-lucky-roll{background:var(--bg-input);border-radius:var(--radius);min-width:0;color:var(--text-primary);font-size:14px;font-family:var(--font-sans);border:none;outline:none;flex:1;padding:6px 10px}.entry-list{margin-bottom:20px;font-size:0;overflow:hidden}.entry-list>*{font-size:16px}.entry-row{margin-bottom:10px}.entry-row-top{align-items:stretch;gap:6px;display:flex}.entry-field{background:var(--bg-card);border-radius:var(--radius);color:var(--text-primary);font-size:15px;font-family:var(--font-sans);border:none;outline:none;min-width:0;padding:10px}.entry-field::placeholder{color:var(--text-muted);font-style:italic}.entry-field--wide{background:var(--bg-input);cursor:pointer;width:100%;margin-top:5px;display:block}textarea.entry-field--wide{resize:none;cursor:text;min-height:72px}.autocomplete-wrapper{min-width:0;display:flex;position:relative}.autocomplete-dropdown{z-index:20;background:var(--bg-secondary);border:1px solid var(--bg-input);border-radius:0 0 var(--radius) var(--radius);max-height:200px;list-style:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 12px #0000004d}.autocomplete-item{color:var(--text-primary);cursor:pointer;border-bottom:1px solid var(--bg-input);padding:10px 12px;font-size:15px}.autocomplete-item:last-child{border-bottom:none}.autocomplete-item:active{background:var(--bg-input)}.modal-overlay{z-index:100;background:#0009;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-secondary);border-radius:12px;width:100%;max-width:400px;max-height:80vh;padding:24px;overflow-y:auto}.delete-confirm{text-align:center}.delete-confirm-text{color:var(--text-primary);margin-bottom:20px;font-size:16px}.delete-confirm-actions{justify-content:center;gap:12px;display:flex}.btn-confirm-cancel{background:var(--bg-input);color:var(--text-primary);border-radius:var(--radius);cursor:pointer;border:none;padding:10px 24px;font-size:15px}.btn-confirm-delete{background:var(--color-danger);color:var(--text-primary);border-radius:var(--radius);cursor:pointer;border:none;padding:10px 24px;font-size:15px;font-weight:600}.textbox-editor{flex-direction:column;max-width:100%;max-height:90vh;display:flex}.textbox-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.textbox-title{font-family:var(--font-serif);color:var(--text-primary);font-size:18px;font-style:italic}.textbox-close{background:var(--bg-input);color:var(--text-primary);border-radius:var(--radius);cursor:pointer;border:none;padding:6px 16px;font-size:14px}.textbox-textarea{background:var(--bg-input);border-radius:var(--radius);width:100%;min-height:200px;color:var(--text-primary);font-size:15px;font-family:var(--font-sans);resize:vertical;border:none;outline:none;padding:12px;line-height:1.5}.dice-roller-overlay{z-index:200;background:#000000d9;flex-direction:column;justify-content:center;align-items:center;gap:16px;max-width:480px;margin:0 auto;padding:24px 16px;display:flex;position:fixed;inset:0}.dice-roller-close{color:var(--text-secondary);cursor:pointer;z-index:1;background:0 0;border:none;padding:8px;font-size:48px;line-height:1;position:absolute;top:12px;right:16px}.dice-total{color:var(--text-primary);justify-content:center;align-items:center;height:60px;font-size:48px;font-weight:700;display:flex}.dice-results{flex-wrap:wrap;justify-content:center;gap:8px;max-width:100%;height:48px;display:flex}.die-face{justify-content:center;align-items:center;width:44px;height:44px;display:flex;position:relative}.die-img{object-fit:contain;width:100%;height:100%;position:absolute;inset:0}.die-value{z-index:1;color:var(--text-primary);text-shadow:0 1px 3px #0009;font-size:16px;font-weight:700;position:relative}.die-rolling{opacity:.7}.die-landed{opacity:1}.die-exploded .die-value{color:gold}.dice-config{width:100%;max-width:320px}.dice-config-row{justify-content:center;align-items:center;gap:4px;display:flex}.dice-count-input{text-align:center;background:var(--bg-card);border:1px solid var(--bg-input);border-radius:var(--radius);width:56px;height:56px;color:var(--text-primary);font-size:32px;font-weight:700;font-family:var(--font-sans);-moz-appearance:textfield;outline:none;padding:0}.dice-count-input::-webkit-inner-spin-button{-webkit-appearance:none}.dice-count-input::-webkit-outer-spin-button{-webkit-appearance:none}.dice-chain-btns{flex-direction:column;gap:2px;display:flex}.dice-chain-btn{background:var(--color-dice-btn);color:#fff;cursor:pointer;border:none;border-radius:4px;justify-content:center;align-items:center;width:28px;height:26px;font-size:16px;font-weight:700;line-height:1;display:flex}.dice-d-label{color:var(--text-secondary);padding:0 4px;font-size:28px;font-style:italic}.dice-type-select{text-align:center;background:var(--bg-card);border:1px solid var(--bg-input);border-radius:var(--radius);width:56px;height:56px;color:var(--text-primary);font-size:32px;font-weight:700;font-family:var(--font-sans);cursor:pointer;appearance:none;outline:none;padding:0 4px}.dice-explode{width:100%;max-width:320px}.dice-explode-label{color:var(--text-primary);margin-bottom:6px;font-size:15px;font-weight:600;display:block}.dice-explode-grid{grid-template-columns:1fr 1fr;gap:2px 16px;display:grid}.dice-toggle{color:var(--text-secondary);cursor:pointer;justify-content:space-between;align-items:center;gap:8px;padding:2px 0;font-size:13px;display:flex}.dice-toggle input{display:none}.dice-radio{border:1.5px solid var(--text-muted);border-radius:50%;flex-shrink:0;width:14px;height:14px}.dice-toggle input:checked+.dice-radio{background:var(--text-primary);border-color:var(--text-primary)}.dice-swipe-bar{-webkit-user-select:none;user-select:none;touch-action:none;border-radius:var(--radius);background:#0d0d10;align-items:center;width:100%;max-width:320px;height:56px;margin-top:8px;display:flex;position:relative;overflow:hidden}.dice-swipe-bar-bg{border-radius:var(--radius);pointer-events:none;background:linear-gradient(#3a6fad 0%,#1e4f8a 100%);width:100%;height:100%;position:absolute;inset:0;box-shadow:inset 0 2px 6px #0006,inset 0 -1px 3px #0003}.dice-swipe-handle{z-index:2;cursor:grab;background:linear-gradient(#5a9fe0 0%,#3a7bc8 100%);border-radius:4px;flex-shrink:0;width:48px;height:44px;margin-left:4px;transition:transform .5s;position:relative;box-shadow:0 2px 6px #00000080}.dice-swipe-bar:active .dice-swipe-handle{cursor:grabbing;transition:none}.dice-swipe-text{z-index:1;font-family:var(--font-serif);color:var(--text-primary);pointer-events:none;justify-content:center;align-items:center;font-size:20px;font-style:italic;display:flex;position:absolute;inset:0}.power-section{margin-bottom:16px}.power-section .section-header{align-items:center;gap:8px;display:flex}.casting-stat-btn{background:var(--bg-input);border:1px solid var(--text-muted);border-radius:var(--radius);color:var(--text-primary);cursor:pointer;letter-spacing:.5px;padding:4px 12px;font-size:13px;font-weight:600}.power-roll-row{gap:4px;margin-top:2px;margin-bottom:8px;display:flex}.power-roll-btn{background:var(--color-dice-btn);color:var(--text-primary);border-radius:var(--radius);cursor:pointer;border:none;flex:1;padding:8px;font-size:14px;font-weight:600}.power-bonus-input{background:var(--bg-card);border-radius:var(--radius);width:72px;color:var(--text-primary);font-size:14px;font-family:var(--font-mono);text-align:center;border:none;outline:none;padding:8px}.power-bonus-input::placeholder{color:var(--text-muted);font-style:italic;font-family:var(--font-sans)}.power-screen{max-width:400px}.power-screen-name{font-family:var(--font-serif);color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:22px;font-weight:600}.power-screen-meta{margin-bottom:16px}.power-meta-row{color:var(--text-secondary);padding:2px 0;font-size:14px}.power-screen-roll{align-items:center;gap:8px;margin-bottom:16px;display:flex}.power-roll-label{color:var(--text-primary);font-size:16px;font-weight:600}.power-roll-input{background:var(--bg-input);border:1px solid var(--text-muted);border-radius:var(--radius);width:64px;color:var(--text-primary);font-size:18px;font-weight:700;font-family:var(--font-mono);text-align:center;-moz-appearance:textfield;outline:none;padding:6px 8px}.power-roll-input::-webkit-inner-spin-button{-webkit-appearance:none}.power-roll-input::-webkit-outer-spin-button{-webkit-appearance:none}.power-screen-result{background:var(--bg-input);border-radius:var(--radius);margin-bottom:16px;padding:12px}.power-result--failure{border-left:3px solid var(--color-danger)}.power-result-bracket{color:var(--text-muted);margin-bottom:4px;font-size:13px;font-weight:600;display:block}.power-result-text{color:var(--text-primary);white-space:pre-wrap;font-size:14px;line-height:1.6}.power-screen-close{background:var(--bg-input);width:100%;color:var(--text-primary);border-radius:var(--radius);cursor:pointer;border:none;padding:10px;font-size:15px}.hamburger-menu{position:relative}.hamburger-dropdown{background:var(--bg-secondary);border:1px solid var(--bg-input);border-radius:var(--radius);z-index:50;min-width:180px;margin-top:4px;position:absolute;top:100%;right:0;overflow:hidden;box-shadow:0 8px 24px #0006}.hamburger-item{width:100%;color:var(--text-primary);text-align:left;cursor:pointer;background:0 0;border:none;padding:12px 16px;font-size:15px;display:block}.hamburger-item:hover{background:var(--bg-input)}.hamburger-separator{background:var(--bg-input);height:1px;margin:4px 0}.load-character{max-height:70vh}.load-character-title{font-family:var(--font-serif);color:var(--text-primary);margin-bottom:16px;font-size:20px}.load-character-empty{color:var(--text-muted);text-align:center;padding:24px 0;font-style:italic}.load-character-list{flex-direction:column;gap:4px;max-height:50vh;margin-bottom:16px;display:flex;overflow-y:auto}.load-character-row{border-radius:var(--radius);align-items:center;gap:8px;padding:4px;display:flex}.load-character-row--active{background:var(--bg-input)}.load-character-name{background:var(--bg-card);border-radius:var(--radius);color:var(--text-primary);font-size:18px;font-family:var(--font-serif);text-align:left;cursor:pointer;border:none;flex:1;padding:12px}.load-character-name:hover{background:var(--bg-input)}.load-character-close{background:var(--bg-input);width:100%;color:var(--text-primary);border-radius:var(--radius);cursor:pointer;border:none;padding:10px;font-size:15px}.save-banner{background:var(--bg-secondary);border-bottom:1px solid var(--bg-input);padding:10px 16px;padding-top:calc(10px + env(safe-area-inset-top,0px));text-align:center;z-index:300;transition:transform .4s;position:fixed;top:0;left:0;right:0;transform:translateY(-100%)}.save-banner--visible{transform:translateY(0)}.save-banner-text{color:var(--text-primary);font-size:14px;font-weight:500}.app-version{bottom:calc(var(--nav-height) + env(safe-area-inset-bottom,0px) + 4px);color:var(--text-muted);pointer-events:none;z-index:1;font-size:10px;position:fixed;right:8px}
