:root{color-scheme:light;--bg0:#faf8f3;--bg1:#fff;--bg2:#f3efe6;--bg3:#ebe6da;--bg4:#e0d9c9;--bg5:#d4cbb8;--bdr:#e4ddcd;--bdr-light:#d4cbb8;--t1:#1f1a14;--t2:#6b6151;--t3:#9a8f7b;--gold:#1f3a5f;--brass:#b8923e;--red:#6b2e2b;--grn:#3f6d4f;--blu:#2e6f6c;--pur:#5b4a9e;--org:#b5651d;--pnk:#a83f6e;--cyn:#2e6f6c;--error:#6b2e2b;--success:#3f6d4f;--warning:#b5651d;--info:#2e6f6c;--shadow-sm:0 1px 2px rgba(31,26,20,.06);--shadow-md:0 4px 16px rgba(31,26,20,.1)}:root[data-theme=dark]{color-scheme:dark;--bg0:#16161a;--bg1:#1c1c21;--bg2:#222226;--bg3:#2a2a30;--bg4:#33333a;--bg5:#3d3d45;--bdr:#2c2c32;--bdr-light:#3a3a42;--t1:#e7e2d6;--t2:#9c958a;--t3:#6a655d;--gold:#a8893c;--brass:#c2a86a;--red:#c25a4f;--grn:#7da183;--blu:#5fa8a3;--pur:#a99cf8;--org:#d98e32;--pnk:#e08aac;--cyn:#5fa8a3;--error:#c25a4f;--success:#7da183;--warning:#d98e32;--info:#5fa8a3;--shadow-sm:none;--shadow-md:0 4px 16px rgba(0,0,0,.35)}:root{--font-sans:var(--font-inter,"Inter"),-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-mono:var(--font-jb-mono,"JetBrains Mono"),"SF Mono",Menlo,Consolas,monospace;--font-display:var(--font-fraunces,"Fraunces"),Georgia,"Times New Roman",serif;--font-serif:var(--font-mono);--fs-2xs:10px;--fs-xs:11px;--fs-sm:12px;--fs-md:13px;--fs-base:14px;--fs-lg:16px;--fs-xl:18px;--fs-2xl:20px;--fs-3xl:24px;--fs-4xl:28px;--fs-5xl:32px;--lh-tight:1.25;--lh-normal:1.5;--lh-relaxed:1.7;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:12px;--spacing-lg:16px;--spacing-xl:24px;--spacing-2xl:32px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--trans:0.2s ease}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px}body,html{overflow-x:hidden}body{background-color:var(--bg0);color:var(--t1);font-family:var(--font-sans);font-weight:400;line-height:1.5;text-rendering:optimizeLegibility;max-width:100vw}a{color:var(--gold);text-decoration:none;transition:color var(--trans)}a:hover{color:var(--org)}button{cursor:pointer;border:none;background:none;transition:all var(--trans)}button,input,select,textarea{font-family:var(--font-sans)}.app{display:flex;height:100vh;background-color:var(--bg0);overflow:hidden}.sidebar{width:240px;background-color:var(--bg1);border-right:1px solid var(--bdr);display:flex;flex-direction:column;padding:var(--spacing-lg);overflow-y:auto;flex-shrink:0}.s-logo{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--bdr)}.logo-icon{width:112px;height:112px;object-fit:contain;flex-shrink:0}.auth-logo .logo-icon{width:220px;height:220px;margin-bottom:var(--spacing-md)}.s-nav{flex:1 1;display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-xl)}.nav-label{font-size:11px;font-weight:600;text-transform:uppercase;color:var(--t3);letter-spacing:.5px;margin-top:var(--spacing-md)}.nav-item,.nav-label{padding:var(--spacing-md) var(--spacing-md)}.nav-item{display:flex;align-items:center;gap:var(--spacing-md);border-radius:var(--radius-md);color:var(--t2);font-size:14px;cursor:pointer;transition:all var(--trans);border-left:2px solid transparent}.nav-item:hover{background-color:var(--bg3);color:var(--t1)}.nav-item.active{background-color:var(--bg3);color:var(--gold);border-left-color:var(--gold)}.s-foot{gap:var(--spacing-md);padding-top:var(--spacing-lg);border-top:1px solid var(--bdr)}.s-foot,.user-avatar{display:flex;align-items:center;flex-shrink:0}.user-avatar{width:40px;height:40px;border-radius:var(--radius-md);background:var(--gold);justify-content:center;font-weight:600;color:var(--bg0)}.user-info{flex:1 1;min-width:0}.user-name{font-size:13px;font-weight:600;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sign-out-btn{font-size:12px;color:var(--t3);padding:2px 0;transition:color var(--trans)}.sign-out-btn:hover{color:var(--red)}.main-content{flex:1 1;display:flex;flex-direction:column;overflow:hidden;background-color:var(--bg0)}.page-content{flex:1 1;overflow-y:auto;padding:var(--spacing-2xl);max-width:1600px;width:100%;margin:0 auto}.page-content h2{font-family:var(--font-display);font-size:28px;font-weight:600;color:var(--t1);margin-bottom:var(--spacing-md)}.page-content p{color:var(--t2);font-size:14px;line-height:1.6}.auth-page{display:flex;align-items:center;justify-content:center;height:100vh;width:100%;background-color:var(--bg0)}.auth-card{width:100%;max-width:380px;padding:var(--spacing-2xl);background-color:var(--bg1);border:1px solid var(--bdr);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.auth-logo{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);text-align:center;justify-content:center;flex-direction:column}.auth-subtitle{text-align:center;color:var(--t2);font-size:13px}.auth-subtitle,.auth-tabs{margin-bottom:var(--spacing-xl)}.auth-tabs{display:flex;gap:var(--spacing-sm);border-bottom:1px solid var(--bdr)}.auth-tabs button{flex:1 1;padding:var(--spacing-md);color:var(--t3);font-size:13px;font-weight:600;border-bottom:2px solid transparent;transition:all var(--trans)}.auth-tabs button.active{color:var(--gold);border-bottom-color:var(--gold)}.auth-tabs button:hover{color:var(--t2)}.auth-card form{display:flex;flex-direction:column;gap:var(--spacing-md)}.auth-card input{padding:var(--spacing-md) var(--spacing-lg);background-color:var(--bg2);border:1px solid var(--bdr);border-radius:var(--radius-md);color:var(--t1);font-size:14px;transition:all var(--trans)}.auth-card input:focus{outline:none;border-color:var(--gold);background-color:var(--bg3)}.auth-card input::placeholder{color:var(--t3)}.auth-error{padding:var(--spacing-md);background-color:color-mix(in srgb,var(--red) 10%,var(--bg1));border:1px solid var(--red);color:var(--red);font-size:13px}.auth-error,.auth-submit{border-radius:var(--radius-md)}.auth-submit{padding:var(--spacing-md) var(--spacing-lg);background:var(--gold);color:var(--bg0);font-weight:600;font-size:14px;transition:all var(--trans);margin-top:var(--spacing-sm)}.auth-submit:hover{background:color-mix(in srgb,var(--gold) 88%,#000)}.auth-submit:active{transform:translateY(1px)}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;width:100%;background-color:var(--bg0);gap:var(--spacing-lg)}.loading-logo{width:240px;height:240px;object-fit:contain;animation:loading-logo-pulse 1.8s ease-in-out infinite}@keyframes loading-logo-pulse{0%,to{opacity:.9;transform:scale(1)}50%{opacity:1;transform:scale(1.04)}}.loading-screen p{color:var(--t2);font-size:14px}.btn-primary{padding:6px 14px;background:var(--gold);color:var(--bg0);border:none;border-radius:var(--radius-sm);font-weight:700;font-size:12px;cursor:pointer;transition:all var(--trans)}.btn-primary:hover{background:color-mix(in srgb,var(--gold) 88%,#000)}.btn-secondary{padding:6px 14px;background:transparent;color:var(--t2);border:1px solid var(--bdr);border-radius:var(--radius-sm);font-weight:600;font-size:12px;cursor:pointer;transition:all var(--trans)}.btn-secondary:hover{background:var(--bg3);border-color:var(--bdr-light);color:var(--t1)}.btn-action{padding:6px 14px;background:var(--grn);color:var(--bg0);border:none;border-radius:var(--radius-sm);font-weight:700;font-size:12px;cursor:pointer;transition:all var(--trans)}.btn-action:hover{background:color-mix(in srgb,var(--grn) 88%,#000)}.btn-ghost{padding:6px 14px;background:none;color:var(--t3);border:none;font-weight:600;font-size:11px;cursor:pointer;transition:all var(--trans)}.btn-ghost:hover{color:var(--t1)}.btn-danger{padding:6px 14px;background:var(--red);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:700;font-size:12px;cursor:pointer;transition:all var(--trans)}.btn-danger:hover{background:color-mix(in srgb,var(--red) 88%,#000)}.level-badge{display:inline-flex;align-items:center;padding:3px 10px;background:var(--bg4);color:var(--gold);border-radius:var(--radius-sm);font-weight:700;font-size:12px;letter-spacing:.3px;-webkit-user-select:none;-moz-user-select:none;user-select:none}:focus-visible{outline:2px solid var(--gold);outline-offset:2px}.nav-item:focus-visible,a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--gold);outline-offset:2px}input[type=email],input[type=number],input[type=password],input[type=text],select,textarea{width:100%;padding:var(--spacing-md) var(--spacing-lg);background-color:var(--bg2);border:1px solid var(--bdr);border-radius:var(--radius-md);color:var(--t1);font-size:14px;transition:all var(--trans)}@media (max-width:768px){input[type=email],input[type=number],input[type=password],input[type=search],input[type=tel],input[type=text],input[type=url],select,textarea{font-size:16px}}input[type=email]:focus,input[type=number]:focus,input[type=password]:focus,input[type=text]:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold);background-color:var(--bg3);box-shadow:0 0 0 3px color-mix(in srgb,var(--gold) 18%,transparent)}input::placeholder,textarea::placeholder{color:var(--t3)}textarea{resize:vertical;min-height:100px;font-family:var(--font-sans)}select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23b0b8c8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right var(--spacing-lg) center;background-size:20px;padding-right:40px}.card{background-color:var(--bg2);border:1px solid var(--bdr);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--trans)}.card:hover{border-color:var(--bdr-light);box-shadow:var(--shadow-md)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg)}.card-title{font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--t1)}.card-subtitle{font-size:13px;color:var(--t2);margin-top:var(--spacing-sm)}.card-content{display:flex;flex-direction:column;gap:var(--spacing-lg)}.card-section{padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--bdr)}.card-section:last-child{border-bottom:none;padding-bottom:0}.banner{padding:var(--spacing-lg);border-radius:var(--radius-lg);border:1px solid;display:flex;gap:var(--spacing-md);align-items:flex-start}.banner-info{border-color:var(--blu);background-color:color-mix(in srgb,var(--blu) 10%,var(--bg1));color:var(--blu)}.banner-success{border-color:var(--grn);background-color:color-mix(in srgb,var(--grn) 10%,var(--bg1));color:var(--grn)}.banner-warning{border-color:var(--org);background-color:color-mix(in srgb,var(--org) 10%,var(--bg1));color:var(--org)}.banner-error{border-color:var(--red);background-color:color-mix(in srgb,var(--red) 10%,var(--bg1));color:var(--red)}.banner-icon{font-size:18px;flex-shrink:0}.banner-content{flex:1 1;font-size:13px;line-height:1.5}.banner-title{font-weight:600;margin-bottom:var(--spacing-sm)}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13px}thead{background-color:var(--bg2)}th{text-align:left;font-weight:600;color:var(--t1)}td,th{padding:var(--spacing-lg);border-bottom:1px solid var(--bdr)}td{color:var(--t2)}tbody tr:hover{background-color:var(--bg2)}.grid{display:grid;grid-gap:var(--spacing-lg);gap:var(--spacing-lg)}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.grid-4{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.flex{display:flex;gap:var(--spacing-lg)}.flex-col{flex-direction:column}.flex-between{justify-content:space-between;align-items:center}.flex-center{justify-content:center;align-items:center}h1{font-size:32px}h1,h2{font-family:var(--font-display);font-weight:600;color:var(--t1)}h2{font-size:24px}h3{font-family:var(--font-display);font-size:20px}h3,h4{font-weight:600;color:var(--t1)}h4{font-size:16px}h5{font-size:14px;color:var(--t1)}h5,h6{font-weight:600}h6{font-size:12px;text-transform:uppercase;letter-spacing:.5px}h6,p{color:var(--t2)}p{line-height:1.6}small{font-size:12px;color:var(--t3)}strong{font-weight:600;color:var(--t1)}.mt{margin-top:var(--spacing-lg)}.mb{margin-bottom:var(--spacing-lg)}.ml{margin-left:var(--spacing-lg)}.mr{margin-right:var(--spacing-lg)}.p{padding:var(--spacing-lg)}.text-center{text-align:center}.text-right{text-align:right}.text-gold{color:var(--gold)}.text-red{color:var(--red)}.text-grn{color:var(--grn)}.text-blu{color:var(--blu)}.text-pur{color:var(--pur)}.fs-2xs{font-size:var(--fs-2xs)}.fs-xs{font-size:var(--fs-xs)}.fs-sm{font-size:var(--fs-sm)}.fs-md{font-size:var(--fs-md)}.fs-base{font-size:var(--fs-base)}.fs-lg{font-size:var(--fs-lg)}.fs-xl{font-size:var(--fs-xl)}.fs-2xl{font-size:var(--fs-2xl)}@media (max-width:768px){.fs-2xs,.fs-xs{font-size:var(--fs-sm)}.fs-sm{font-size:var(--fs-md)}.fs-md{font-size:var(--fs-base)}}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.cursor-pointer{cursor:pointer}.cursor-disabled{cursor:not-allowed;opacity:.5}.character-sheet{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--spacing-xl);gap:var(--spacing-xl)}.ability-score{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-md);background-color:var(--bg2);border-radius:var(--radius-md);border:1px solid var(--bdr)}.ability-name{font-size:11px;font-weight:600;text-transform:uppercase;color:var(--t3);letter-spacing:.5px;margin-bottom:var(--spacing-sm)}.ability-value{font-family:var(--font-serif);font-size:28px;font-weight:700;color:var(--gold)}.ability-modifier{font-size:12px;color:var(--t2);margin-top:var(--spacing-sm)}.hit-points{display:flex;flex-direction:column;padding:var(--spacing-lg);background:color-mix(in srgb,var(--red) 8%,var(--bg1));border:1px solid var(--red);border-radius:var(--radius-lg)}.hp-label{font-size:12px;font-weight:600;color:var(--t3);text-transform:uppercase;margin-bottom:var(--spacing-sm)}.hp-current{font-family:var(--font-serif);font-size:36px;font-weight:700;color:var(--red)}.hp-max{font-size:14px;color:var(--t2)}.stat-row{display:flex;justify-content:space-between;padding:var(--spacing-md);border-bottom:1px solid var(--bdr);font-size:13px}.stat-row:last-child{border-bottom:none}.stat-label{color:var(--t3)}.stat-value{color:var(--t1);font-weight:600}.cheatsheet-action{padding:var(--spacing-lg);background-color:var(--bg2);border:1px solid var(--bdr);border-radius:var(--radius-md);cursor:pointer;transition:all var(--trans)}.cheatsheet-action:hover{border-color:var(--gold);background-color:var(--bg3);transform:translateY(-2px)}.action-icon{font-size:24px;margin-bottom:var(--spacing-sm)}.action-name{color:var(--t1)}.action-category,.action-name{font-weight:600;margin-bottom:var(--spacing-sm)}.action-category{display:inline-block;font-size:11px;text-transform:uppercase;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--bg3);color:var(--gold);border-radius:var(--radius-sm)}.action-dice{font-family:Courier New,monospace;color:var(--org);font-weight:600}.action-description{font-size:12px;color:var(--t2);margin-top:var(--spacing-sm)}.spell-item{padding:var(--spacing-lg);background-color:var(--bg2);border-left:4px solid var(--pur);border-radius:var(--radius-md);cursor:pointer;transition:all var(--trans)}.spell-item:hover{background-color:var(--bg3);border-left-color:var(--cyn)}.spell-level{display:inline-block;font-size:11px;text-transform:uppercase;color:var(--pur)}.spell-level,.spell-name{font-weight:700;margin-bottom:var(--spacing-sm)}.spell-name{color:var(--t1)}.spell-meta{display:flex;gap:var(--spacing-md);font-size:12px;color:var(--t2);margin-bottom:var(--spacing-md)}.spell-meta-item{display:flex;align-items:center;gap:4px}.spell-description{font-size:13px;color:var(--t2);line-height:1.5}.session-note{padding:var(--spacing-lg);background-color:var(--bg2);border-left:4px solid var(--blu);border-radius:var(--radius-md)}.note-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md)}.note-title{font-weight:700;color:var(--t1);margin-bottom:var(--spacing-sm)}.note-meta{display:flex;gap:var(--spacing-md);font-size:12px;color:var(--t3)}.note-tag{display:inline-block;font-size:11px;font-weight:600;text-transform:uppercase;padding:2px var(--spacing-md);background-color:var(--blu);color:var(--bg0);border-radius:var(--radius-sm)}.note-tag.combat{background-color:var(--red)}.note-tag.rp{background-color:var(--pur)}.note-tag.loot{background-color:var(--gold);color:var(--bg0)}.note-tag.discovery{background-color:var(--grn);color:var(--bg0)}.note-content{font-size:13px;color:var(--t2);line-height:1.6;white-space:pre-wrap}.npc-card{padding:var(--spacing-lg);background-color:var(--bg2);border:1px solid var(--bdr);border-radius:var(--radius-md);cursor:pointer;transition:all var(--trans)}.npc-card:hover{border-color:var(--pnk);background-color:var(--bg3)}.npc-icon{font-size:32px;margin-bottom:var(--spacing-md)}.npc-name{font-weight:700;color:var(--t1);margin-bottom:var(--spacing-sm)}.npc-role{font-size:12px;color:var(--gold)}.npc-description,.npc-role{margin-bottom:var(--spacing-md)}.npc-description{font-size:13px;color:var(--t2)}.npc-location{font-size:12px;color:var(--t3)}.quest-item{padding:var(--spacing-lg);background-color:var(--bg2);border-left:4px solid var(--org);border-radius:var(--radius-md)}.quest-item.completed{border-left-color:var(--grn);opacity:.7}.quest-item.failed{border-left-color:var(--red)}.quest-status{display:inline-block;font-size:11px;font-weight:600;text-transform:uppercase;padding:2px var(--spacing-md);background-color:var(--org);color:var(--bg0);border-radius:var(--radius-sm);margin-bottom:var(--spacing-md)}.quest-status.completed{background-color:var(--grn)}.quest-status.failed{background-color:var(--red)}.quest-title{font-weight:700;color:var(--t1);margin-bottom:var(--spacing-sm)}.quest-giver{font-size:12px;color:var(--t3);margin-bottom:var(--spacing-md)}.quest-description{font-size:13px;color:var(--t2);margin-bottom:var(--spacing-md)}.quest-reward{font-size:13px;color:var(--grn);font-weight:600}.compendium-item{padding:var(--spacing-lg);background-color:var(--bg2);border:1px solid var(--bdr);border-radius:var(--radius-md)}.compendium-icon{font-size:28px;margin-bottom:var(--spacing-md)}.compendium-name{font-weight:700;color:var(--t1);margin-bottom:var(--spacing-sm)}.compendium-type{font-size:11px;font-weight:600;text-transform:uppercase;color:var(--t3);margin-bottom:var(--spacing-md)}.compendium-description{font-size:13px;color:var(--t2)}.mobile-header,.mobile-nav{display:none}@media (max-width:1024px){.character-sheet{grid-template-columns:1fr}.grid-3{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width:768px){.app{flex-direction:column;height:100vh;height:100dvh}.sidebar{display:none}.mobile-header{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;grid-gap:8px;gap:8px;padding:calc(10px + env(safe-area-inset-top, 0px)) calc(16px + env(safe-area-inset-right, 0px)) 10px calc(16px + env(safe-area-inset-left, 0px));background:var(--bg1);border-bottom:1px solid var(--bdr);flex-shrink:0;z-index:100}.mobile-header .logo-icon{width:96px;height:96px;justify-self:center}.mobile-header-right{display:flex;align-items:center;gap:8px;justify-self:end}.mobile-user-btn{width:30px;height:30px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--bg0);font-size:12px;border:none;cursor:pointer}.app--sheet-mode .mobile-header{grid-template-columns:auto 1fr auto;gap:6px;padding:calc(6px + env(safe-area-inset-top, 0px)) calc(10px + env(safe-area-inset-right, 0px)) 6px calc(10px + env(safe-area-inset-left, 0px));min-height:calc(44px + env(safe-area-inset-top, 0px));background:color-mix(in srgb,var(--bg1) 92%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.app--sheet-mode .mobile-header-left{display:none}.app--sheet-mode .mobile-header .logo-icon{width:32px;height:32px;justify-self:start}.app--sheet-mode .mobile-header-right{justify-self:end}.app--sheet-mode .mobile-user-btn{width:28px;height:28px;font-size:11px}.main-content{flex:1 1;min-height:0;overflow:hidden}.page-content{height:100%;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:8px 8px 70px;max-width:100vw;box-sizing:border-box}.app--sheet-mode .page-content{padding:0;max-width:100vw}.page-content h2{font-size:20px}.mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--bg1);border-top:1px solid var(--bdr);z-index:200;padding:4px 0 max(4px,env(safe-area-inset-bottom))}.mobile-nav-item{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:6px 2px;color:var(--t3);font-size:9px;font-weight:600;cursor:pointer;background:none;border:none;gap:2px;-webkit-tap-highlight-color:transparent;transition:color .15s}.mobile-nav-item .nav-icon{font-size:18px;line-height:1}.mobile-nav-item.active{color:var(--gold)}.mobile-nav-item:active{transform:scale(.95)}.mobile-more-drawer{position:fixed;bottom:56px;bottom:calc(56px + env(safe-area-inset-bottom));left:0;right:0;background:var(--bg1);border-top:1px solid var(--bdr);z-index:199;display:flex;flex-wrap:wrap;gap:4px;padding:12px;box-shadow:var(--shadow-md)}.mobile-more-drawer button{flex:1 0 30%;padding:10px 8px;background:var(--bg2);border:1px solid var(--bdr);border-radius:8px;color:var(--t2);font-size:12px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;justify-content:center}.mobile-more-drawer button.active{background:var(--bg3);color:var(--gold);border-color:var(--gold)}.character-sheet,.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.auth-card{margin:var(--spacing-lg)}.cheatsheet-action,.nav-item,.npc-card,.spell-item,button{min-height:44px}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}}@media (max-width:480px){.page-content{padding:8px 8px 70px}.app--sheet-mode .page-content{padding:0}.page-content h2{font-size:18px}.auth-card{padding:var(--spacing-xl);max-width:95%}h1{font-size:24px}h2{font-size:20px}}.bs-layout{display:grid;grid-template-columns:340px 1fr;grid-gap:0;gap:0;min-height:500px;background:var(--bg0)}.bs-hud{background:var(--bg1);border-right:1px solid var(--bdr);padding:20px;display:flex;flex-direction:column;gap:16px;position:-webkit-sticky;position:sticky;top:var(--cs-sticky-h,96px);align-self:start;max-height:calc(100vh - var(--cs-sticky-h, 96px));overflow-y:auto;min-width:0}.bs-main{padding:0;min-width:0}.bs-bottom,.bs-main{background:var(--bg0)}.bs-bottom{border-top:2px solid var(--bdr);padding:24px 32px 48px}.bs-bottom-heading{font-family:var(--font-serif);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.38em;color:var(--t3);margin-bottom:20px;display:flex;align-items:center;gap:12px}.bs-bottom-heading:after{content:"";flex:1 1;height:1px;background:var(--bdr)}.bs-bottom-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:16px;gap:16px}.bs-portrait-block{text-align:center}.bs-portrait{position:relative;aspect-ratio:1;border:1px solid var(--bdr-light);border-radius:4px;overflow:hidden;margin-bottom:14px;background:var(--bg2);cursor:pointer;transition:border-color .15s}.bs-portrait:hover{border-color:var(--gold)}.bs-cond-pill:focus-visible,.bs-portrait:focus-visible,.bs-roll-btn:focus-visible,.bs-vital[role=button]:focus-visible{outline:2px solid var(--gold);outline-offset:2px}.bs-portrait-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:72px;color:var(--t3);font-family:var(--font-serif)}.bs-portrait-corner{position:absolute;width:14px;height:14px;border:1px solid var(--gold);opacity:.6;pointer-events:none}.bs-portrait-corner.tl{top:6px;left:6px;border-right:none;border-bottom:none}.bs-portrait-corner.tr{top:6px;right:6px;border-left:none;border-bottom:none}.bs-portrait-corner.bl{bottom:6px;left:6px;border-right:none;border-top:none}.bs-portrait-corner.br{bottom:6px;right:6px;border-left:none;border-top:none}.bs-name{font-size:15px;font-weight:700;color:var(--t1);letter-spacing:.02em;line-height:1.15}.bs-class,.bs-name{font-family:var(--font-serif);text-transform:uppercase;margin-bottom:4px}.bs-class{font-size:9px;color:var(--t2);letter-spacing:.22em}.bs-vitals{display:grid;grid-template-columns:1fr 1fr;grid-gap:6px;gap:6px}.bs-vital{padding:12px;background:var(--bg2);border:1px solid var(--bdr);border-radius:3px}.bs-vital-label{font-family:var(--font-serif);font-size:9px;letter-spacing:.28em;color:var(--t3);margin-bottom:4px;text-transform:uppercase}.bs-vital-value{font-family:var(--font-serif);font-size:22px;font-weight:700;color:var(--t1);line-height:1}.bs-cond-pill{padding:6px 10px 6px 8px;border-radius:100px;font-family:var(--font-serif);font-size:10px;letter-spacing:.12em;text-transform:uppercase;display:inline-flex;align-items:center;gap:6px;cursor:pointer;border:1px solid var(--bdr);background:var(--bg2);color:var(--t2);transition:all .12s}.bs-cond-pill:hover{border-color:var(--bdr-light);color:var(--t1)}.bs-cond-pill--active{background:color-mix(in srgb,var(--gold) 10%,transparent);border-color:var(--gold);color:var(--gold)}.bs-attack-card{padding:14px!important;background:var(--bg2)!important;border:1px solid var(--bdr)!important;border-radius:4px!important;position:relative;overflow:hidden;transition:all .15s}.bs-attack-card:before{content:"";position:absolute;top:0;left:0;width:2px;height:100%;background:var(--red);opacity:.4}.bs-attack-card:hover{border-color:var(--red)!important}.bs-attack-name{font-size:12px!important;font-weight:600;letter-spacing:.04em;color:var(--t1);margin-bottom:3px}.bs-attack-meta,.bs-attack-name{font-family:var(--font-serif);text-transform:uppercase}.bs-attack-meta{font-size:10px!important;color:var(--t3);letter-spacing:.08em;margin-bottom:12px}.bs-roll-btn{padding:8px 10px;min-height:36px;background:var(--bg0);border:1px solid var(--bdr);border-radius:3px;font-family:var(--font-serif);font-size:11px;font-weight:600;letter-spacing:.05em;color:var(--t1);cursor:pointer;transition:background .12s,border-color .12s,color .12s,transform .12s;display:inline-flex;align-items:center;gap:6px}.bs-roll-btn:hover{background:var(--bg3)}.bs-roll-btn--hit{color:var(--cyn)}.bs-roll-btn--adv{color:var(--grn);border-color:color-mix(in srgb,var(--grn) 35%,transparent)}.bs-roll-btn--dmg{color:var(--red);border-color:color-mix(in srgb,var(--red) 35%,transparent)}.cs-roll-mode-bar{display:grid;grid-template-columns:auto minmax(260px,max-content) minmax(160px,1fr);grid-gap:10px;gap:10px;align-items:center;padding:10px;border:1px solid color-mix(in srgb,var(--gold) 28%,transparent);border-radius:6px;background:color-mix(in srgb,var(--gold) 6%,var(--bg1))}.cs-roll-mode-label,.mab-roll-mode-label{color:var(--t3);font-family:var(--font-mono);font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase}.cs-roll-mode-segments,.mab-roll-mode-segments{display:inline-flex;gap:4px;padding:4px;border:1px solid var(--bdr);border-radius:8px;background:var(--bg0)}.cs-roll-mode-segments button,.mab-roll-mode-segments button{min-height:30px;padding:6px 12px;border:0;border-radius:6px;background:transparent;color:var(--t2);font-family:var(--font-mono);font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;cursor:pointer}.cs-roll-mode-segments button.active,.mab-roll-mode-segments button.active{background:var(--gold);color:var(--bg0)}.cs-roll-mode-hint{color:var(--t3);font-size:11px}.cs-attack-options-bar{display:grid;grid-template-columns:auto minmax(260px,max-content) minmax(160px,1fr);grid-gap:10px;gap:10px;align-items:center;padding:10px;border:1px solid color-mix(in srgb,var(--org) 26%,transparent);border-radius:6px;background:color-mix(in srgb,var(--org) 7%,var(--bg1))}.cs-attack-options-list,.mab-attack-options-list{display:flex;flex-wrap:wrap;gap:6px}.cs-attack-options-list button,.mab-attack-options-list button{display:inline-flex;flex-direction:column;gap:2px;align-items:flex-start;min-height:38px;padding:7px 12px;border:1px solid color-mix(in srgb,var(--gold) 32%,transparent);border-radius:7px;background:var(--bg0);color:var(--t2);cursor:pointer}.cs-attack-options-list button span,.mab-attack-options-list button span{color:inherit;font-family:var(--font-mono);font-size:11px;font-weight:900;letter-spacing:.06em;text-transform:uppercase}.cs-attack-options-list button small,.mab-attack-options-list button small{color:var(--t3);font-size:10px}.cs-attack-options-list button.active,.mab-attack-options-list button.active{border-color:var(--gold);background:color-mix(in srgb,var(--gold) 16%,transparent);color:var(--gold)}.cs-attack-options-list button.active small,.mab-attack-options-list button.active small{color:var(--gold)}.cs-attack-card--compact:not(.cs-attack-card--expanded) .cs-attack-rolls>.bs-roll-btn:not(.bs-roll-btn--hit):not(.cs-attack-base-damage):not(.cs-attack-more-toggle),.cs-attack-card--compact:not(.cs-attack-card--expanded) .cs-attack-rolls>span{display:none!important}.cs-attack-card--compact.cs-attack-card--expanded .cs-attack-rolls{padding-top:8px;border-top:1px solid var(--bdr)}.cs-attack-more-toggle{color:var(--gold);border-color:color-mix(in srgb,var(--gold) 35%,transparent)}.mab-roll-mode-bar{padding:10px;border:1px solid color-mix(in srgb,var(--gold) 26%,transparent);border-radius:10px;background:color-mix(in srgb,var(--gold) 7%,var(--bg1))}.mab-combat-view-toggle,.mab-roll-mode-bar{display:grid;grid-template-columns:auto 1fr;grid-gap:8px;gap:8px;align-items:center}.mab-combat-view-toggle{padding:9px 10px;border:1px solid color-mix(in srgb,var(--cyn) 24%,transparent);border-radius:10px;background:color-mix(in srgb,var(--cyn) 7%,var(--bg1))}.mab-combat-view-label{color:var(--t3);font-family:var(--font-mono);font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase}.mab-combat-view-segments{display:inline-flex;gap:4px;width:100%;padding:4px;border:1px solid var(--bdr);border-radius:8px;background:var(--bg0)}.mab-combat-view-segments button{flex:1 1;min-width:0;min-height:30px;padding:6px;border:0;border-radius:6px;background:transparent;color:var(--t2);font-family:var(--font-mono);font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;cursor:pointer}.mab-combat-view-segments button.active{background:var(--cyn);color:var(--bg0)}.mab-quick-help{border:1px solid color-mix(in srgb,var(--cyn) 22%,transparent);border-radius:10px;background:color-mix(in srgb,var(--cyn) 5%,var(--bg1));color:var(--t2)}.mab-quick-help summary{min-height:34px;display:flex;align-items:center;padding:7px 10px;color:var(--cyn);font-family:var(--font-mono);font-size:10px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;cursor:pointer}.mab-quick-help-body{display:grid;grid-gap:7px;gap:7px;padding:0 10px 10px;color:var(--t2);font-size:12px;line-height:1.45}.mab-quick-help-body span{display:block}.mab-attack-options-bar{display:grid;grid-template-columns:auto 1fr;grid-gap:8px;gap:8px;align-items:center;padding:10px;border:1px solid color-mix(in srgb,var(--org) 24%,transparent);border-radius:10px;background:color-mix(in srgb,var(--org) 7%,var(--bg1))}.mab-attack-options-list button{flex:1 1 150px;min-width:0}.mab-roll-mode-segments{width:100%}.mab-roll-mode-segments button{flex:1 1;min-width:0;padding-inline:6px}.mab-act-btn--more{color:var(--gold);border-color:color-mix(in srgb,var(--gold) 42%,transparent)}.mab-compact-btn-text{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mab-breath-state{justify-self:end;min-height:26px;padding:4px 8px;border:1px solid color-mix(in srgb,var(--gold) 36%,transparent);border-radius:999px;background:color-mix(in srgb,var(--gold) 10%,transparent);color:var(--gold);font-family:var(--font-mono);font-size:10px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;cursor:pointer}.mab-breath-state span{color:inherit;opacity:.75}.mab-breath-state[data-ready="1"]{border-color:color-mix(in srgb,var(--grn) 36%,transparent);background:color-mix(in srgb,var(--grn) 10%,transparent);color:var(--grn)}.mab-breath-state[data-ready="0"]{border-color:color-mix(in srgb,var(--red) 30%,transparent);background:color-mix(in srgb,var(--red) 8%,transparent);color:var(--red)}.mab-breath-state:disabled{cursor:default;opacity:.55}.mab-atk-card--compact:not(.mab-atk-card--expanded) .mab-act-btn--adv,.mab-atk-card--compact:not(.mab-atk-card--expanded) .mab-act-btn--crit,.mab-atk-card--compact:not(.mab-atk-card--expanded) .mab-act-btn--dis,.mab-atk-card--compact:not(.mab-atk-card--expanded) .mab-atk-card-extras{display:none!important}.mab-atk-card--expanded .mab-atk-card-extras{display:flex!important}.mab-atk-card--expanded .mab-atk-card-rolls{padding-bottom:8px;border-bottom:1px solid var(--bdr)}.bs-spell-slot-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(58px,1fr));grid-gap:6px;gap:6px}.bs-spell-slot{text-align:center;padding:10px 4px;background:var(--bg2);border:1px solid var(--bdr);border-radius:4px;cursor:pointer;transition:all .12s;-webkit-user-select:none;-moz-user-select:none;user-select:none}.bs-spell-slot:hover{border-color:var(--gold);background:var(--bg3)}.bs-spell-slot--empty{opacity:.35;cursor:default}.bs-spell-slot--empty:hover{border-color:var(--bdr);background:var(--bg2)}.bs-spell-slot--spent{opacity:.55}.bs-spell-slot .bs-slot-level{font-family:var(--font-serif);font-size:9px;color:var(--t3);letter-spacing:.15em;text-transform:uppercase}.bs-spell-slot .bs-slot-avail{font-family:var(--font-serif);font-size:18px;font-weight:700;color:var(--gold);line-height:1;margin:3px 0 0}.bs-spell-slot--empty .bs-slot-avail,.bs-spell-slot--spent .bs-slot-avail{color:var(--t3)}.bs-spell-slot .bs-slot-max{font-size:9px;color:var(--t3);font-family:var(--font-serif);margin-top:2px}.bs-hud [style*="var(--bg1)"],.bs-hud [style*="var(--bg2)"]{padding:12px!important;border-radius:4px!important}.bs-hud .section-label{font-size:9px;letter-spacing:.28em;margin-bottom:8px;color:var(--t3)}.bs-hud .cs-ability-grid,.bs-hud .cs-saves-row{gap:4px}.bs-hud .cs-ability-grid>div{padding:8px 4px!important}@media (max-width:900px){.bs-layout{grid-template-columns:1fr!important}.bs-hud{position:static!important;max-height:none!important;border-right:none!important;border-bottom:1px solid var(--bdr)!important;padding:16px!important}.bs-portrait{max-width:220px;margin:0 auto 14px!important}}@media (max-width:768px){.bs-cond-pill,.bs-roll-btn{min-height:44px;padding:10px 12px!important}.bs-attack-card{padding:12px!important}.bs-spell-slot-grid{grid-template-columns:repeat(auto-fit,minmax(58px,1fr))!important}.bs-bottom{padding:16px!important}.bs-bottom-grid{grid-template-columns:1fr}}@media (max-width:600px){.bs-spell-slot-grid{grid-template-columns:repeat(5,minmax(0,1fr))!important;gap:5px!important}.bs-spell-slot{padding:8px 2px!important;min-height:44px}.bs-spell-slot .bs-slot-avail{font-size:16px}}@media (max-width:480px){.bs-vitals{grid-template-columns:repeat(2,1fr)}.bs-spell-slot-grid{grid-template-columns:repeat(4,minmax(0,1fr))!important;gap:4px!important}.bs-bottom,.bs-hud{padding:12px!important}.bs-bottom-heading{font-size:9px;margin-bottom:12px}}.mab-sections-wrapper>section>*{margin-bottom:14px}.mab-sections-wrapper [style*="var(--bg1)"],.mab-sections-wrapper [style*="var(--bg2)"]{padding:12px!important;border-radius:6px!important}.mab-sections-wrapper .section-label{font-size:10px;letter-spacing:.28em}.mab-sections-wrapper .cs-ability-grid{grid-template-columns:repeat(3,1fr)!important;gap:5px!important}.mab-sections-wrapper .cs-ability-grid>div{padding:8px 4px!important}@media (max-width:768px){.mab-sections-wrapper .section-label{font-size:12px!important;letter-spacing:.18em!important}.mab-sections-wrapper .cs-ability-grid>div{padding:12px 6px!important}.mab-sections-wrapper .cs-ability-grid .ab-n,.mab-sections-wrapper .cs-ability-grid [style*="font-size: 8px"],.mab-sections-wrapper .cs-ability-grid [style*="fontSize: '8px'"]{font-size:11px!important;letter-spacing:.14em!important}.mab-sections-wrapper .cs-ability-grid [style*="font-size: 18px"],.mab-sections-wrapper .cs-ability-grid [style*="fontSize: '18px'"]{font-size:22px!important}.mab-sections-wrapper .cs-skList{gap:8px!important}.mab-sections-wrapper .cs-skList [style*="font-size: 13px"],.mab-sections-wrapper .cs-skList [style*="fontSize: '13px'"]{font-size:15px!important}.mab-sections-wrapper .cs-skList [style*="fontSize: '11px'"]{font-size:13px!important}.mab-sections-wrapper [style*="font-size: 9px"],.mab-sections-wrapper [style*="fontSize: '9px'"]{font-size:11px!important}.mab-sections-wrapper [style*="font-size: 10px"],.mab-sections-wrapper [style*="fontSize: '10px'"]{font-size:12px!important}.mab-sections-wrapper [style*="font-size: 11px"],.mab-sections-wrapper [style*="fontSize: '11px'"]{font-size:13px!important}.mab-sections-wrapper [style*="font-size: 12px"],.mab-sections-wrapper [style*="fontSize: '12px'"]{font-size:14px!important}.mab-sections-wrapper [style*="letter-spacing: 0.35em"],.mab-sections-wrapper [style*="letterSpacing: '0.35em'"]{letter-spacing:.2em!important}.mab-sections-wrapper [style*="letter-spacing: 0.3em"],.mab-sections-wrapper [style*="letterSpacing: '0.3em'"]{letter-spacing:.18em!important}.mab-sections-wrapper [style*="letter-spacing: 0.25em"],.mab-sections-wrapper [style*="letterSpacing: '0.25em'"]{letter-spacing:.15em!important}.mab-sections-wrapper [style*="letter-spacing: 0.2em"],.mab-sections-wrapper [style*="letterSpacing: '0.2em'"]{letter-spacing:.12em!important}.mab-sections-wrapper .bs-attack-name{font-size:14px!important}.mab-sections-wrapper .bs-attack-meta{font-size:12px!important;letter-spacing:.06em!important}.mab-sections-wrapper .bs-roll-btn{min-height:48px;font-size:13px!important}.mab-sections-wrapper .bs-roll-btn small{font-size:10px!important;letter-spacing:.15em!important}.mab-sections-wrapper .bs-spell-slot .bs-slot-level{font-size:11px!important}.mab-sections-wrapper .bs-spell-slot .bs-slot-avail{font-size:20px!important}.mab-sections-wrapper .bs-spell-slot .bs-slot-max{font-size:10px!important}.mab-sections-wrapper .bs-cond-pill{font-size:12px!important;letter-spacing:.08em!important;padding:7px 12px!important}.mab-sections-wrapper [style*="fontSize: '12px'"]{font-size:14px!important}.mab-sec-header{font-size:12px!important;letter-spacing:.2em!important}}@media (max-width:480px){.mab-sections-wrapper .cs-ability-grid{gap:5px!important}.mab-sections-wrapper .cs-ability-grid>div{padding:10px 4px!important}}@media (max-width:768px){[style*="font-size: 8px"],[style*="font-size: 9px"],[style*="font-size:8px"],[style*="font-size:9px"]{font-size:11px!important}[style*="font-size: 10px"],[style*="font-size: 11px"],[style*="font-size:10px"],[style*="font-size:11px"]{font-size:12px!important}}.csh-card{background:var(--bg1);border:1px solid var(--bdr);border-radius:4px;padding:14px}.csh-cardHead{font-family:JetBrains Mono,monospace;font-size:10px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.14em;margin-bottom:12px;display:flex;justify-content:space-between;align-items:center}.csh-ab{background:var(--bg1);border:1px solid var(--bdr);border-radius:8px;padding:10px 8px;text-align:center;cursor:pointer;transition:all .15s}.csh-al{font-family:JetBrains Mono,monospace;font-size:9px;color:var(--t3);font-weight:600;text-transform:uppercase;letter-spacing:.14em}.csh-av{font-family:var(--font-serif);font-size:28px;font-weight:700;color:var(--t1);margin:4px 0 2px;line-height:1.1}.csh-am{font-size:13px;color:var(--gold);font-weight:600}.csh-skList{display:flex;flex-direction:column;gap:1px}.csh-sk{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:5px;cursor:pointer;transition:all .1s}.csh-skDot{width:6px;height:6px;border-radius:50%;border:1.5px solid var(--t3);flex-shrink:0}.csh-skName{flex:1 1;font-size:12px;font-weight:500;color:var(--t2)}.csh-skMod{font-family:JetBrains Mono,monospace;font-size:12px;font-weight:600;color:var(--t1)}.csh-hpNums{display:flex;justify-content:space-between;margin-bottom:10px;font-size:13px}.csh-hpCur{font-family:var(--font-serif);font-size:28px;font-weight:700;color:var(--grn)}.csh-hpBar{width:100%;height:8px;background:var(--bg4);border-radius:4px;overflow:hidden;margin-bottom:12px}.csh-hpFill{height:100%;background:var(--grn);border-radius:4px;transition:width .5s cubic-bezier(.4,0,.2,1)}.csh-hpBtn{flex:1 1;padding:8px;min-height:44px;background:var(--bg2);border:1px solid var(--bdr);color:var(--t2);border-radius:8px;font-size:11px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,color .15s,transform .15s;text-align:center;font-family:var(--font-sans)}.csh-textarea{background:var(--bg1);border:1px solid var(--bdr);color:var(--t2);padding:14px;border-radius:12px;font-family:monospace;font-size:12px;min-height:100px;resize:vertical}.csh-cur{background:var(--bg1);border:1px solid var(--bdr);border-radius:8px;padding:10px 6px;text-align:center}.csh-curV{font-family:var(--font-serif);font-size:18px;font-weight:700;color:var(--gold);margin-bottom:4px}.csh-curL{font-family:JetBrains Mono,monospace;font-size:9px;color:var(--t3);text-transform:uppercase;letter-spacing:.1em}