:root{--bg:#121214;--surface:#18181b;--surface-hover:#27272a;--text:#f4f4f5;--text-muted:#a1a1aa;--accent:#fb7eac;--danger:#ef4444;--border:#3f3f46}body{background:var(--bg);color:var(--text);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;margin:0;font-family:system-ui,-apple-system,sans-serif;font-size:18px}#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{padding:1rem;padding-bottom:calc(1rem + env(safe-area-inset-bottom));flex:1;overflow-y:auto}.bottom-nav{background:var(--surface);border-top:2px 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:2px solid var(--border);background:var(--bg);width:100%;color:var(--text);border-radius:8px;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:2px 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;cursor:pointer;text-align:center;background:var(--surface-hover);width:100%;color:var(--text);border-radius:8px;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:#000;cursor:pointer}.btn-danger{background:var(--danger);color:#fff;cursor:pointer}.btn-disabled{background:var(--border);color:var(--text-muted);cursor:not-allowed}.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:12px;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}.stat-box{background:var(--bg);border:2px solid var(--border);text-align:center;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;padding:.5rem;display:flex}.stat-box .line-input{text-align:center;border-bottom:2px solid #0000;margin:0;padding:0;font-size:1.4rem;font-weight:700}.stat-box .line-input:focus{border-bottom-color:var(--accent)}.slot-circle{border:2px 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(--bg)}.skills-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem;display:grid}.skill-card{background:var(--bg);border:2px solid var(--border);border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:.3rem;padding:.5rem;display:flex}.skill-card-header{color:var(--text-muted);text-align:center;white-space:nowrap;text-overflow:ellipsis;text-transform:uppercase;letter-spacing:.5px;width:100%;font-size:13px;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:2px;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:20px 20px 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:12px;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:#000;z-index:2000;border-radius:20px;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:2px solid var(--border);border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:.75rem;transition:border-color .15s;display:flex}.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:12px;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:2px solid var(--border);border-radius:8px;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:2px solid var(--border);cursor:pointer;border-radius:8px;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:2px solid var(--border);background:0 0;width:100%}.book-cover-placeholder{background:var(--surface-hover);border-bottom:2px 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:2px solid var(--border);cursor:pointer;border-radius:8px;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:2px 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:2px solid var(--border)}.reader-content{color:var(--text);font-size:1.05rem;line-height:1.6}.book-header{color:var(--accent);border-bottom:2px solid var(--border);margin-top:2rem;margin-bottom:1rem;padding-bottom:.3rem}.book-header:first-child{margin-top:0}.book-quote{border-left:4px solid var(--accent);background:var(--surface-hover);border-radius:0 8px 8px 0;margin:1.5rem 0;padding:.5rem 1rem;font-style:italic}.book-inset{border:2px solid var(--border);background:var(--bg);border-radius:8px;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:2px solid var(--border);border-radius:8px;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:2px 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:2px solid var(--border);border-radius:8px;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:2px solid var(--border);background:var(--surface-hover);border-radius:8px;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{background:var(--bg);border-radius:8px;margin:1.5rem 0;padding:1rem;border:2px solid var(--border)!important}.nav-overlay{z-index:90;background:0 0;position:fixed;inset:0}.nav-popup{bottom:calc(80px + env(safe-area-inset-bottom));background:var(--surface);border:2px solid var(--border);z-index:95;border-radius:12px;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);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;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:2px 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:1px solid var(--border);border-radius:6px;outline:none;max-width:150px;padding:.4rem;font-size:14px}.level-separator{border:none;border-top:2px dashed var(--border);opacity:.5;margin:3rem 0}h2,h3,h4,h5,.level-anchor,[id]{scroll-margin-top:85px}.drag-bar{background:var(--accent);z-index:10;pointer-events:none;border-radius:2px;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;border:2px solid var(--border);cursor:pointer;vertical-align:middle;background:0 0;border-radius:4px;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(--bg);border-width:0 2px 2px 0;width:5px;height:10px;position:absolute;top:1px;left:5px;transform:rotate(45deg)}.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}
