:root{--bg:#121214;--surface:#18181b;--surface-hover:#27272a;--text:#f4f4f5;--text-muted:#a1a1aa;--accent:#fb7eac;--danger:#ef4444;--border:#3f3f46;--text-on-accent:#121214;--radius:12px;--radius-sm:calc(var(--radius) * .67);--border-w:2px}html,body{background:var(--bg);color:var(--text);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;overscroll-behavior:none;width:100%;height:100dvh;margin:0;font-family:system-ui,-apple-system,sans-serif;font-size:18px;overflow:hidden}#app{flex-direction:column;height:100dvh;display:flex;overflow:hidden}#main-layout{flex-direction:column;flex:1;width:100%;height:100%;display:flex;overflow:hidden}.content{flex:1;padding:1rem;overflow-y:auto}.tab-content>:last-child{margin-bottom:0!important}.bottom-nav{background:var(--surface);border-top:var(--border-w) solid var(--border);padding-bottom:env(safe-area-inset-bottom);z-index:100;scrollbar-width:none;-webkit-overflow-scrolling:touch;display:flex;overflow-x:auto}.bottom-nav::-webkit-scrollbar{display:none}.nav-btn{min-width:0;color:var(--text-muted);cursor:pointer;text-transform:uppercase;background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:.3rem;padding:1rem .5rem;font-size:12px;font-weight:600;transition:color .15s ease-out;display:flex}.override-input:not(:placeholder-shown){text-decoration:underline}.override-input::placeholder{color:currentColor;opacity:1}.override-input:focus::placeholder{opacity:.3}.nav-btn.active{color:var(--accent)}.nav-btn .material-icons{font-size:28px}input,select,textarea{-webkit-user-select:auto;user-select:auto;box-sizing:border-box;outline:none;margin:0;font-family:inherit}input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.box-input{border:var(--border-w) solid var(--border);border-radius:var(--radius-sm);background:var(--bg);width:100%;color:var(--text);padding:.75rem;font-size:18px;transition:border-color .15s cubic-bezier(.4,0,.2,1)}.box-input:focus{border-color:var(--accent)}textarea.box-input{resize:none;min-height:140px;overflow:hidden}.line-input{border:none;border-bottom:var(--border-w) solid var(--border);width:100%;color:var(--text);background:0 0;border-radius:0;padding:.5rem .2rem;font-size:18px;transition:border-color .15s cubic-bezier(.4,0,.2,1)}.line-input:focus{border-bottom-color:var(--accent)}.btn{box-sizing:border-box;border-radius:var(--radius-sm);cursor:pointer;text-align:center;background:var(--surface-hover);width:100%;color:var(--text);justify-content:center;align-items:center;gap:.5rem;padding:.75rem;font-size:18px;font-weight:700;transition:transform .1s,filter .15s;display:flex;border:none!important;outline:none!important}.btn:active{filter:brightness(1.2);transform:scale(.97)}.btn-primary{background:var(--accent);color:var(--text-on-accent);cursor:pointer}.btn-danger{background:var(--danger);color:#fff;cursor:pointer}.btn:disabled,.btn-disabled{opacity:.5;cursor:not-allowed;background:var(--surface-hover)!important;color:var(--text-muted)!important}.btn:disabled:active,.btn-disabled:active{filter:none;transform:scale(1)}.drag-handle{width:28px;height:28px;color:var(--border);cursor:grab;justify-content:center;align-items:center;transition:color .15s;display:flex}.drag-handle:hover{color:var(--text-muted)}.drag-handle:active{cursor:grabbing}.delete-btn{width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;margin-left:.2rem;padding:0;transition:color .15s;display:flex}.delete-btn:hover{color:var(--danger)}.card{background:var(--surface);border-radius:var(--radius);margin-bottom:1rem;padding:1rem}h1,h2,h3{margin:0 0 .5rem}.grid-2{grid-template-columns:1fr 1fr;gap:.5rem;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:.5rem;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:.5rem;display:grid}.stat-box{background:var(--bg);border:var(--border-w) solid var(--border);border-radius:var(--radius-sm);text-align:center;box-sizing:border-box;flex-direction:column;justify-content:center;align-items:center;width:100%;min-width:0;padding:.5rem;display:flex;overflow:hidden;container-type:inline-size}.stat-box-header{white-space:nowrap;text-align:center;width:100%;font-size:clamp(11px,15cqw,18px);line-height:1.2;overflow:hidden}.stat-box .line-input{text-align:center;border-bottom:var(--border-w) solid transparent;margin:0;padding:0;font-size:1.4rem;font-weight:700}.stat-box .line-input:focus{border-bottom-color:var(--accent)}.slot-circle{border:var(--border-w) solid var(--accent);cursor:pointer;width:1.5rem;height:1.5rem;color:var(--accent);border-radius:50%;justify-content:center;align-items:center;margin-right:.25rem;font-size:12px;font-weight:700;transition:background .15s cubic-bezier(.4,0,.2,1),color .15s;display:flex}.slot-circle.filled{background:var(--accent);color:var(--text-on-accent)}.skills-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem;display:grid}.skill-card{background:var(--bg);border:var(--border-w) solid var(--border);border-radius:var(--radius-sm);flex-direction:column;justify-content:center;align-items:center;gap:.3rem;padding:.5rem;display:flex}.skill-card-header{text-align:center;white-space:nowrap;text-overflow:ellipsis;text-transform:uppercase;letter-spacing:.5px;width:100%;font-size:14px;overflow:hidden}.skill-card-value{font-size:1.6rem;font-weight:700}.skill-card-controls{gap:.8rem;display:flex}.skill-card-controls .slot-circle{border-width:var(--border-w);width:1.2rem;height:1.2rem;margin:0;font-size:10px}.modal-overlay{z-index:1000;background:#000c;flex-direction:column;justify-content:flex-end;display:flex;position:fixed;inset:0}.modal-content{background:var(--surface);padding:1.5rem;padding-bottom:calc(1.5rem + env(safe-area-inset-bottom));border-radius:var(--radius) var(--radius) 0 0;max-height:85vh;animation:.2s cubic-bezier(.1,.9,.2,1) slideUp;overflow-y:auto}.modal-center{justify-content:center;padding:1rem}.modal-center .modal-content{border-radius:var(--radius);max-height:90vh;margin:auto}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.toast{top:calc(1rem + env(safe-area-inset-top));background:var(--accent);color:var(--text-on-accent);border-radius:var(--radius);z-index:2000;padding:.5rem 1.5rem;font-weight:700;animation:.2s cubic-bezier(.1,.9,.2,1) fadeDown;position:fixed;left:50%;transform:translate(-50%)}@keyframes fadeDown{0%{opacity:0;transform:translate(-50%,-100%)}to{opacity:1;transform:translate(-50%)}}.list-item{background:var(--bg);border-radius:var(--radius-sm);border:var(--border-w) solid var(--border);justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:.75rem;transition:border-color .15s;display:flex}.list-item:last-child{margin-bottom:0}.tag-link{color:var(--accent);cursor:pointer;align-items:center;gap:.1rem;font-weight:500;text-decoration:underline;display:inline-flex}.search-row{align-items:center;gap:.5rem;display:flex}#dice-box-container{opacity:1;pointer-events:none!important;z-index:9999!important;width:100vw!important;height:100vh!important;position:fixed!important;top:0!important;left:0!important}#dice-box-container canvas{display:block;width:100%!important;height:100%!important}.dice-display-card{background:var(--surface);border-radius:var(--radius);flex-direction:column;justify-content:center;align-items:center;min-height:220px;margin-bottom:1rem;padding:1.5rem 1rem;display:flex}.dice-display-content{text-align:center;flex-direction:column;justify-content:space-between;align-items:center;width:100%;height:100%;display:flex}.dice-display-header{color:var(--text-muted);word-wrap:break-word;overflow-wrap:break-word;width:100%;min-height:1.68rem;font-size:1.2rem;line-height:1.4}.dice-display-center{justify-content:center;align-items:center;width:100%;height:5.5rem;margin:0;display:flex}.dice-display-footer{color:var(--text-muted);word-wrap:break-word;overflow-wrap:break-word;scrollbar-width:thin;width:100%;min-height:1.68rem;max-height:120px;font-size:1.2rem;line-height:1.4;overflow-y:auto}.dice-display-total{color:var(--accent);margin:0;font-size:4.5rem;font-weight:700;line-height:1}.dice-display-icon{margin:0;line-height:1;font-size:4.5rem!important}@keyframes spinCasino{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin-casino{color:var(--accent);animation:.8s linear infinite spinCasino}.spin-hexagon{color:var(--accent);animation:1.4s linear infinite spinCasino}.dice-entry{background:var(--bg);border:var(--border-w) solid var(--border);border-radius:var(--radius-sm);margin-bottom:.5rem;padding:1rem}.dice-result{color:var(--text);text-align:right;font-size:2.5rem;font-weight:700;line-height:1}.book-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:1rem;display:grid}.book-card{background:var(--bg);border:var(--border-w) solid var(--border);border-radius:var(--radius-sm);cursor:pointer;flex-direction:column;transition:transform .15s,border-color .15s;display:flex;overflow:hidden}.book-card:hover{border-color:var(--accent);transform:translateY(-2px)}.book-cover-img{aspect-ratio:3/4;object-fit:cover;object-position:top;border-bottom:var(--border-w) solid var(--border);background:0 0;width:100%}.book-cover-placeholder{background:var(--surface-hover);border-bottom:var(--border-w) solid var(--border);justify-content:center;align-items:center;height:180px;display:flex}.book-cover-placeholder .material-icons{color:var(--border);font-size:64px}.book-title{text-align:center;flex:1;justify-content:center;align-items:center;padding:.75rem .5rem;font-size:14px;font-weight:700;display:flex}.class-card{background:var(--bg);border:var(--border-w) solid var(--border);border-radius:var(--radius-sm);cursor:pointer;flex-direction:column;transition:transform .15s,border-color .15s;display:flex;overflow:hidden}.class-card:hover{border-color:var(--accent);transform:translateY(-2px)}.class-icon-wrapper{background:var(--surface-hover);border-bottom:var(--border-w) solid var(--border);justify-content:center;align-items:center;height:140px;display:flex}.class-icon-wrapper .material-icons{opacity:.8;font-size:64px}.class-card-title{text-align:center;flex:1;padding:.75rem .5rem .25rem;font-size:16px;font-weight:700}.class-card-subtitle{color:var(--text-muted);text-align:center;text-transform:uppercase;padding:0 .5rem .75rem;font-size:12px}.reader-header{border:var(--border-w) solid var(--border)}.reader-content{color:var(--text);font-size:1.05rem;line-height:1.6}.book-header{color:var(--accent);border-bottom:var(--border-w) solid var(--border);margin-top:2rem;margin-bottom:1rem;padding-bottom:.3rem}.book-header:first-child{margin-top:0}.book-quote{border-left:calc(var(--border-w) * 2) solid var(--accent);background:var(--surface-hover);border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin:1.5rem 0;padding:.5rem 1rem;font-style:italic}.book-inset{border:var(--border-w) solid var(--border);border-radius:var(--radius-sm);background:var(--bg);margin:1.5rem 0;padding:1rem}.book-inset.readaloud{background:var(--surface-hover);border-style:dashed}.book-inset h4{color:var(--text);margin-top:0;margin-bottom:.5rem;font-size:1.1rem}.table-wrap{border:var(--border-w) solid var(--border);border-radius:var(--radius-sm);margin:1.5rem 0;overflow-x:auto}.book-table{border-collapse:collapse;text-align:left;background:var(--bg);border:none;width:100%}.book-table th,.book-table td{border:1px solid var(--border);padding:.4rem .6rem}.book-table th{background:var(--surface-hover);color:var(--text);white-space:nowrap;border-bottom:var(--border-w) solid var(--border);font-weight:700}.book-table tbody tr:nth-child(2n){background-color:#ffffff08}.book-table tr:last-child td{border-bottom:none}.book-table p{margin:0;padding:.2rem 0}.book-image{text-align:center;margin:1.5rem 0}.book-image img{border-radius:var(--radius-sm);border:var(--border-w) solid var(--border);max-width:100%;height:auto}.book-image figcaption{color:var(--text-muted);margin-top:.5rem;font-size:14px;font-style:italic}.reader-content ul{margin:1rem 0;padding-left:1.5rem}.reader-content li{margin-bottom:.5rem}.reader-content p{margin-bottom:1rem}[v-cloak]{display:none!important}.splash-screen{background:var(--bg);z-index:10000;color:var(--accent);flex-direction:column;justify-content:center;align-items:center;transition:opacity .5s ease-out,visibility .5s ease-out;display:flex;position:fixed;inset:0}.splash-screen.fade-out{opacity:0;visibility:hidden;pointer-events:none}.book-quote{border:var(--border-w) solid var(--border);background:var(--surface-hover);border-radius:var(--radius-sm);margin:1.5rem 0;padding:1rem;font-style:italic}.book-quote cite{color:var(--text-muted);margin-top:.5rem;font-style:normal;font-weight:700;display:block}.book-inset{border-radius:var(--radius-sm);background:var(--bg);margin:1.5rem 0;padding:1rem;border:var(--border-w) solid var(--border)!important}.nav-overlay{z-index:90;background:0 0;position:fixed;inset:0}.nav-popup{bottom:calc(84px + env(safe-area-inset-bottom));background:var(--surface);border:var(--border-w) solid var(--border);border-radius:var(--radius);z-index:95;flex-direction:column;gap:.2rem;min-width:150px;padding:.5rem;display:flex;position:absolute}.nav-popup.details-menu{left:30%;transform:translate(-50%)}.nav-popup.right{left:90%;right:auto;transform:translate(-50%)}@media (width<=680px){.nav-popup.right{left:auto;right:0;transform:none}}.nav-popup button{color:var(--text);border-radius:var(--radius-sm);cursor:pointer;text-align:left;background:0 0;border:none;justify-content:flex-start;align-items:center;gap:1rem;padding:.75rem 1rem;font-size:16px;font-weight:700;display:flex}.nav-popup button .material-icons{color:var(--text-muted);justify-content:center;align-items:center;margin:0;font-size:24px;line-height:1;transition:color .15s;display:inline-flex}.nav-popup button:hover{background:var(--surface-hover);color:var(--accent)}.nav-popup button:hover .material-icons{color:var(--accent)}.class-sticky-header{background:var(--bg);z-index:10;border-bottom:var(--border-w) solid var(--border);justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:1rem 0;display:flex;position:sticky;top:0}.class-toc-select{background:var(--surface-hover);color:var(--text);border:var(--border-w) solid var(--border);border-radius:var(--radius-sm);outline:none;max-width:150px;padding:.4rem;font-size:14px}.level-separator{border:none;border-top:var(--border-w) dashed var(--border);opacity:.5;margin:3rem 0}h2,h3,h4,h5,.level-anchor,[id]{scroll-margin-top:85px}.drag-bar{background:var(--accent);border-radius:calc(var(--radius-sm) / 2);z-index:10;pointer-events:none;height:4px;position:absolute;top:-8px;left:0;right:0}.drag-bar-bottom{background:var(--accent);height:4px;margin-top:-6px;margin-bottom:-90px;position:absolute;top:0}.content>div{content-visibility:auto;contain-intrinsic-size:1px 1000px}.lazy-block{content-visibility:auto;contain-intrinsic-size:auto 200px;margin-bottom:1rem}.content{overflow-anchor:none;height:100%;overflow-y:auto}input[type=checkbox]{appearance:none;box-sizing:border-box;border:var(--border-w) solid var(--border);border-radius:calc(var(--radius-sm) / 2);cursor:pointer;vertical-align:middle;background:0 0;width:1.25rem;height:1.25rem;margin:0;position:relative}input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}input[type=checkbox]:checked:after{content:"";border:solid var(--text-on-accent);border-width:0 2px 2px 0;width:5px;height:10px;position:absolute;top:42%;left:50%;transform:translate(-50%,-50%)rotate(45deg)}input[type=color]::-webkit-color-swatch-wrapper{padding:0}input[type=color]::-webkit-color-swatch{border:none;border-radius:50%}input[type=color]::-moz-color-swatch{border:none;border-radius:50%}.flex{display:flex}.flex-col{flex-direction:column;display:flex}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.w-full{width:100%}.w-auto{width:auto}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.text-danger{color:var(--danger)}.font-bold{font-weight:700}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.sortable-fallback{display:none!important}.sortable-ghost{border:2px solid var(--accent)!important;z-index:4!important}
