:root{--bg0:#0a0d13;--bg1:#0f141c;--bg2:#131924;--bg3:#1a2130;--bg4:#252f42;--bg5:#2a3548;--bdr:#1f2836;--bdr-light:#2a3548;--t1:#e6ecf5;--t2:#8a95a8;--t3:#4a5468;--gold:#d4af37;--red:#ff4a4a;--grn:#00d97e;--blu:#00d4ff;--pur:#a58cff;--org:#ff8c3a;--pnk:#ff5baa;--cyn:#00d4ff;--error:#ff4a4a;--success:#00d97e;--warning:#ff8c3a;--info:#00d4ff;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-serif:"JetBrains Mono","SF Mono",Menlo,Consolas,monospace;--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);background-image:radial-gradient(ellipse at 20% 0,rgba(0,212,255,.035),transparent 55%),radial-gradient(ellipse at 100% 100%,rgba(255,74,74,.025),transparent 50%);background-attachment:fixed;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{gap:var(--spacing-md);margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--bdr)}.logo-icon,.s-logo{display:flex;align-items:center}.logo-icon{width:36px;height:36px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--gold),var(--org));justify-content:center;font-size:18px;color:var(--bg0);flex-shrink:0}.logo-icon,.s-logo h1{font-family:var(--font-serif);font-weight:700}.s-logo h1{font-size:20px;color:var(--t1)}.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:linear-gradient(135deg,var(--pur),var(--blu));justify-content:center;font-weight:600;color:var(--t1)}.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-serif);font-size:28px;font-weight:700;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);background-image:radial-gradient(circle at 20% 50%,rgba(61,106,175,.1) 0,transparent 50%),radial-gradient(circle at 80% 80%,rgba(242,112,156,.1) 0,transparent 50%)}.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:0 20px 60px rgba(0,0,0,.3)}.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-logo .logo-icon{margin-bottom:var(--spacing-sm)}.auth-logo h1{font-family:var(--font-serif);font-size:32px;font-weight:700;color:var(--t1)}.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:hsla(0,100%,71%,.1);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:linear-gradient(135deg,var(--gold),var(--org));color:var(--bg0);font-weight:600;font-size:14px;transition:all var(--trans);margin-top:var(--spacing-sm)}.auth-submit:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(244,208,63,.3)}.auth-submit:active{transform:translateY(0)}.loading-screen{flex-direction:column;height:100vh;width:100%;background-color:var(--bg0);gap:var(--spacing-lg)}.loading-logo,.loading-screen{display:flex;align-items:center;justify-content:center}.loading-logo{width:48px;height:48px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--gold),var(--org));font-family:var(--font-serif);font-weight:700;font-size:24px;color:var(--bg0)}.loading-screen p{color:var(--t2);font-size:14px}.btn{padding:var(--spacing-md) var(--spacing-lg);background-color:var(--bg3);color:var(--t1);border:1px solid var(--bdr);border-radius:var(--radius-md);font-size:14px;font-weight:500;transition:all var(--trans);cursor:pointer}.btn:hover{background-color:var(--bg4);border-color:var(--bdr-light)}.btn-p{background:linear-gradient(135deg,var(--pur),var(--blu));border:none;color:var(--t1)}.btn-p:hover{box-shadow:0 8px 20px rgba(177,151,252,.3)}.btn-g{background:linear-gradient(135deg,var(--gold),var(--org));border:none;color:var(--bg0);font-weight:600}.btn-g:hover{box-shadow:0 8px 20px rgba(244,208,63,.3)}.btn-sm{padding:var(--spacing-sm) var(--spacing-md);font-size:12px}.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{box-shadow:0 4px 12px rgba(244,208,63,.3);transform:translateY(-1px)}.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:#000;border:none;border-radius:var(--radius-sm);font-weight:700;font-size:12px;cursor:pointer;transition:all var(--trans)}.btn-action:hover{box-shadow:0 4px 12px rgba(81,207,102,.3);transform:translateY(-1px)}.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{box-shadow:0 4px 12px hsla(0,100%,71%,.3)}.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)}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 rgba(244,208,63,.1)}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:0 8px 20px rgba(0,0,0,.2)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg)}.card-title{font-family:var(--font-serif);font-size:18px;font-weight:700;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:rgba(116,192,252,.1);color:var(--blu)}.banner-success{border-color:var(--grn);background-color:rgba(81,207,102,.1);color:var(--grn)}.banner-warning{border-color:var(--org);background-color:rgba(255,169,77,.1);color:var(--org)}.banner-error{border-color:var(--red);background-color:hsla(0,100%,71%,.1);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-serif);font-weight:700;color:var(--t1)}h2{font-size:24px}h3{font-family:var(--font-serif);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)}.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:linear-gradient(135deg,hsla(0,100%,71%,.1),hsla(0,100%,71%,.05));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:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--bg1);border-bottom:1px solid var(--bdr);flex-shrink:0;z-index:100}.mobile-header .logo-icon{width:28px;height:28px;font-size:14px}.mobile-header h1{font-family:var(--font-serif);font-size:16px;color:var(--t1);margin:0}.mobile-header-left,.mobile-header-right{display:flex;align-items:center;gap:8px}.mobile-user-btn{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--pur),var(--blu));display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--t1);font-size:12px;border:none;cursor:pointer}.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}.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:0 -10px 30px rgba(0,0,0,.4)}.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}.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:0;align-self:start;max-height:100vh;overflow-y:auto}.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:linear-gradient(135deg,var(--bg3),var(--bg2));cursor:pointer;transition:border-color .15s}.bs-portrait:hover{border-color:var(--gold)}.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}@media (max-width:900px){.bs-layout{grid-template-columns:1fr}.bs-hud{position:static;max-height:none;border-right:none;border-bottom:1px solid var(--bdr)}}.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:rgba(212,175,55,.08);border-color:var(--gold);color:var(--gold)}.bs-attack-card{padding:14px!important;background:linear-gradient(180deg,var(--bg2),var(--bg3))!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;transform:translateY(-1px);box-shadow:0 8px 24px rgba(255,74,74,.08)}.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;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:all .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:rgba(0,217,126,.3)}.bs-roll-btn--dmg{color:var(--red);border-color:rgba(255,74,74,.3)}.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:180px;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-portrait{max-width:140px}.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}}.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:linear-gradient(90deg,var(--grn),#40c057);border-radius:4px;transition:width .5s cubic-bezier(.4,0,.2,1)}.csh-hpBtn{flex:1 1;padding:8px;background:var(--bg2);border:1px solid var(--bdr);color:var(--t2);border-radius:8px;font-size:11px;font-weight:500;cursor:pointer;transition:all .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}