:root{--sand:#d4a373;--sand-deep:#b9824f;--ocean:#0891b2;--forest:#166534;--warning:#ca8a04;--error:#dc2626;--bg:#fffdf7;--card:#fff;--ink:#3a2e22;--muted:#8a7a66;--line:#ece3d5;--sheet:#dc2626;--sheet-2:#b91c1c;--shadow:0 1px 3px #50381c14, 0 8px 22px #50381c12;--radius:12px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--ink);-webkit-text-size-adjust:100%;font-family:system-ui,-apple-system,Segoe UI,Hiragino Sans,Noto Sans JP,sans-serif}.app{flex-direction:column;max-width:860px;min-height:100%;margin:0 auto;display:flex}.topbar{border-bottom:1px solid var(--line);background:var(--card);z-index:5;align-items:center;gap:10px;padding:12px 16px;display:flex;position:sticky;top:0}.brand{color:var(--sand-deep);letter-spacing:.02em;font-size:18px;font-weight:800}.brand-icon{flex-shrink:0;width:24px;height:24px}.brand-sub{color:var(--muted);font-size:12px}.content{flex:1;padding:16px}.btn{font:inherit;border:1px solid var(--line);background:var(--card);color:var(--ink);cursor:pointer;border-radius:10px;padding:9px 14px;transition:filter .12s,background .12s,border-color .12s}.btn:hover{border-color:var(--sand)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn.primary{background:var(--sand);border-color:var(--sand-deep);color:#3a2613;font-weight:700}.btn.primary:hover{background:var(--sand-deep);border-color:var(--sand-deep);color:#fff}.btn.ghost{color:var(--muted);background:0 0;border-color:#0000}.btn.sm{padding:6px 10px;font-size:13px}.btn.big{width:100%;padding:16px;font-size:17px}.panel-head{align-items:center;gap:12px;margin-bottom:16px;display:flex}.panel-head h2{flex:1;margin:0;font-size:20px}.muted{color:var(--muted)}.empty{text-align:center;padding:48px 16px}.bookshelf{border:1px solid var(--line);background:linear-gradient(#efe0cb,#e6d3b8);border-radius:14px;padding:18px 16px 8px;box-shadow:inset 0 1px #fff9}.book-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));align-items:start;gap:26px 18px;display:grid}.book{border-bottom:4px solid var(--sand-deep);flex-direction:column;align-items:center;padding-bottom:8px;display:flex;position:relative;box-shadow:0 4px #78542c40}.book-cover{aspect-ratio:.7;cursor:pointer;background:var(--card);border:none;border-radius:2px 5px 5px 2px;width:100%;padding:0;transition:transform .12s;position:relative;overflow:hidden;box-shadow:inset 5px 0 6px -4px #00000080,inset 2px 0 #0000002e,2px 5px 10px #3c281459}.book-cover:hover{transform:translateY(-3px)}.book-cover img{object-fit:cover;width:100%;height:100%;display:block}.cover-fallback{width:100%;height:100%;color:var(--ink);text-align:center;word-break:break-word;justify-content:center;align-items:center;padding:8px;font-size:12px;font-weight:700;display:flex}.book-title{-webkit-line-clamp:2;line-clamp:2;text-align:center;-webkit-box-orient:vertical;max-width:100%;min-height:2.7em;margin-top:8px;font-size:12.5px;font-weight:700;line-height:1.35;display:-webkit-box;overflow:hidden}.book-meta{color:var(--muted);margin-top:1px;font-size:11px}.book-badge{vertical-align:middle;border-radius:8px;margin-left:6px;padding:0 5px;font-size:10px;font-weight:700;display:inline-block}.book-badge.cloud{color:#2a6f97;background:#e3f0f7}.book-badge.local{color:#9a6a00;background:#fbf0d9}.book-actions{gap:2px;margin-top:2px;display:flex}.book-actions .btn{padding:4px 8px;font-size:12px}.chip{color:var(--muted);background:#f0ece4;border-radius:999px;padding:2px 8px;font-size:12px}.dropzone{border:2px dashed var(--line);background:var(--card);text-align:center;cursor:pointer;border-radius:16px;padding:40px 20px}.dropzone:hover{border-color:var(--sand)}.dz-big{margin:0 0 4px;font-size:18px;font-weight:700}.dz-sub{color:var(--muted);margin:0 0 18px}.dz-note{color:var(--muted);max-width:380px;margin:0 auto;font-size:12px;line-height:1.6}.progress-box,.ready-box,.error-box{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px}.error-detail{border:1px solid var(--line);white-space:pre-wrap;word-break:break-word;-webkit-user-select:text;user-select:text;background:#0000000d;border-radius:10px;max-height:40vh;margin:12px 0;padding:12px;font-size:12px;line-height:1.5;overflow:auto}.build-tag{text-align:center;color:var(--muted);margin-top:24px;font-size:11px}.bar{background:#eee;border-radius:999px;height:10px;margin:10px 0;overflow:hidden}.bar-fill{background:var(--ocean);height:100%;transition:width .2s}.big-count{font-size:16px}.field{flex-direction:column;gap:6px;margin:14px 0;font-size:14px;display:flex}.field input{font:inherit;border:1px solid var(--line);border-radius:10px;padding:10px}.row{justify-content:flex-end;gap:10px;display:flex}.reviewer{flex-direction:column;gap:14px;display:flex}.review-bar{align-items:center;gap:12px;display:flex}.review-progress{font-variant-numeric:tabular-nums;text-align:center;flex:1;font-weight:700}.deck-name-sm{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;max-width:30%;font-size:12px;overflow:hidden}.page-scroll{-webkit-overflow-scrolling:touch;background:var(--bg);border-radius:8px;height:calc(100dvh - 196px);min-height:220px;overflow:auto}.tuner-preview .page-scroll{height:auto;max-height:56vh;display:block}.viewer:fullscreen{background:var(--bg);box-sizing:border-box;padding:10px 14px}.viewer:fullscreen .page-scroll{height:auto}.continuous-scroll{-webkit-overflow-scrolling:touch;background:var(--bg);border-radius:8px;height:calc(100dvh - 196px);min-height:220px;padding:8px 0;position:relative;overflow:auto}.viewer:fullscreen .continuous-scroll{height:auto}.viewer .page-scroll,.continuous-scroll{cursor:grab;touch-action:none}.grabbing,.grabbing *{-webkit-user-select:none;user-select:none;cursor:grabbing!important}@media (pointer:coarse){.viewer .continuous-scroll,.viewer .page-scroll{border-radius:0;margin-inline:-16px}}.page-slot{box-shadow:var(--shadow);background:#fff;border-radius:4px;margin:0 auto 12px;line-height:0;position:relative;overflow:hidden}.page-slot .page-canvas{width:100%;display:block}.page-stage{box-shadow:var(--shadow);background:#fff;border-radius:6px;margin:0 auto;line-height:0;position:relative;overflow:hidden}.page-canvas{display:block}.mask{background:linear-gradient(var(--sheet), var(--sheet-2));cursor:pointer;border-radius:3px;position:absolute;box-shadow:inset 0 0 0 1px #00000014}.edit-bar{background:var(--card);border-bottom:1px solid var(--line);flex-wrap:wrap;align-items:center;gap:10px;padding:8px 12px;display:flex}.edit-bar-spacer{flex:auto}.mask.mask-edit{box-shadow:none;cursor:pointer;background:#e23b3b47;border:1px dashed #e23b3b}.draw-surface{z-index:5;touch-action:none;cursor:crosshair;position:absolute;inset:0}.draw-rect{pointer-events:none;background:#e23b3b38;border:1.5px dashed #e23b3b;position:absolute}.draw-rect-del{background:#2563eb29;border-color:#2563eb}.star-badge{color:#f5b301;text-shadow:0 0 2px #0009;pointer-events:none;font-size:11px;line-height:1;position:absolute;top:-6px;right:-4px}.reveal-zone{cursor:pointer;border-radius:3px;position:absolute;box-shadow:inset 0 0 0 1px #e23b3b4d}.highlight{pointer-events:none;background:#16653442;border-radius:2px;outline:1.5px solid #166534e6;position:absolute}@media (pointer:fine){.mask:after,.reveal-zone:after{content:"";left:0;right:0;top:calc(-1 * var(--tap-pad,4px));bottom:calc(-1 * var(--tap-pad,4px));position:absolute}}.sheet-host{flex-direction:column;flex:1;min-height:0;display:flex;position:relative}.red-sheet{z-index:6;pointer-events:none;background:#c83c3c24;position:absolute;bottom:0;left:0;right:0}.continuous-scroll.manual .mask{pointer-events:none;box-shadow:none;background:#c83c3ceb}.continuous-scroll.manual .mask.sheet-reveal{box-shadow:none;background:0 0}.red-sheet-grip{z-index:7;cursor:ns-resize;touch-action:none;background:0 0;width:56px;height:20px;position:absolute;left:50%;transform:translate(-50%)}.red-sheet-grip:before{content:"";background:#c83c3c57;border-radius:3px;width:32px;height:6px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.settings .section{border-top:1px solid var(--line);margin:22px 0 8px;padding-top:14px;font-size:15px}.preset-row{flex-wrap:wrap;gap:8px;margin-bottom:10px;display:flex}.tuner-preview{background:var(--card);border:1px solid var(--line);border-radius:12px;margin-bottom:12px;padding:10px}.slider-row{flex-direction:column;gap:4px;margin:10px 0;font-size:13px;display:flex}.slider-label{color:var(--muted);justify-content:space-between;display:flex}.slider-val{font-variant-numeric:tabular-nums;color:var(--ink);font-weight:700}.slider-row input[type=range]{width:100%;accent-color:var(--sand-deep)}.ok-note{color:var(--forest);font-weight:700}.small{font-size:12px}body:has(.viewer){overflow:hidden}.viewer{flex-direction:column;gap:12px;height:100dvh;min-height:0;padding:10px 0 14px;display:flex;overflow:hidden}.viewer .page-scroll,.viewer .continuous-scroll{flex:auto;height:auto;min-height:220px}.viewer-nav{background:linear-gradient(transparent, var(--bg) 40%);justify-content:space-between;align-items:center;gap:12px;padding:8px 0;display:flex;position:sticky;bottom:0}.viewer-controls{background:linear-gradient(transparent, var(--bg) 30%);flex-wrap:wrap;align-items:center;gap:6px 8px;padding:8px 0 4px;display:flex;position:sticky;bottom:0}.page-slider{min-width:110px;accent-color:var(--ocean);flex:1}.page-input{width:60px;font:inherit;border:1px solid var(--line);text-align:center;background:var(--card);color:var(--ink);border-radius:8px;padding:6px 8px}.zoom-field{align-items:center;gap:2px;display:inline-flex}.zoom-input{width:3.4em;font:inherit;border:1px solid var(--line);text-align:right;background:var(--card);color:var(--ink);border-radius:8px;padding:6px}.zoom-suffix{color:var(--muted);font-size:12px}.book-title-bar{text-align:center;min-width:0;color:var(--ink);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;font-weight:600;overflow:hidden}.page-status{white-space:nowrap;color:var(--muted);font-variant-numeric:tabular-nums;align-items:baseline;gap:8px;margin-left:auto;font-size:12px;display:inline-flex}.page-pct{color:var(--ink);font-weight:700}.drawer-backdrop{z-index:20;background:#0006;justify-content:flex-end;display:flex;position:fixed;inset:0}.drawer{background:var(--card);flex-direction:column;gap:10px;width:min(360px,86vw);height:100%;padding:16px;display:flex;overflow:auto;box-shadow:-4px 0 24px #0000002e}.drawer-head{justify-content:space-between;align-items:center;display:flex}.drawer-head h3{margin:0}.toc-list{flex-direction:column;gap:4px;margin:6px 0 0;padding:0;list-style:none;display:flex}.toc-item{align-items:center;gap:6px;display:flex}.toc-jump{border:1px solid var(--line);cursor:pointer;color:var(--ink);font:inherit;text-align:left;background:0 0;border-radius:8px;flex:1;justify-content:space-between;align-items:center;gap:10px;padding:9px 12px;display:flex}.toc-jump:hover{background:var(--bg)}.toc-title{text-overflow:ellipsis;white-space:nowrap;font-weight:600;overflow:hidden}.toc-page{color:var(--muted);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:12px}.centered{text-align:center;flex-direction:column;align-items:center;gap:14px;padding:56px 16px;display:flex}.done-title{font-size:20px;font-weight:800}.tools-row{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:14px;display:flex}.sort-control{color:var(--muted);align-items:center;gap:6px;margin-left:auto;font-size:13px;display:inline-flex}.sort-control select{font:inherit;border:1px solid var(--line);background:var(--card);color:var(--ink);cursor:pointer;border-radius:8px;padding:6px 8px;font-size:13px}.fav-btn{width:32px;height:32px;box-shadow:var(--shadow);color:#cbb893;cursor:pointer;background:#ffffffd9;border:none;border-radius:16px;justify-content:center;align-items:center;padding:0;font-size:18px;line-height:1;display:flex;position:absolute;top:6px;right:6px}.fav-btn.on{color:var(--sand)}.brand-btn{cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;padding:0;display:inline-flex}.home{flex-direction:column;gap:8px;display:flex}.center{text-align:center}.hero{text-align:center;padding:40px 8px 28px}.hero-title{color:var(--ink);letter-spacing:.01em;margin:0 0 16px;font-size:clamp(26px,6vw,40px);line-height:1.25}.hero-lead{max-width:540px;color:var(--muted);margin:0 auto 24px;font-size:16px;line-height:1.8}.hero-cta{flex-direction:column;align-items:center;gap:8px;display:flex}.big-cta{border-radius:999px;padding:14px 36px;font-size:17px;font-weight:800}.hero-note{color:var(--muted);margin:0;font-size:12.5px}.demo-section{text-align:center;margin:28px 0}.demo-heading{color:var(--sand-deep);margin:0 0 14px;font-size:20px}.demo{text-align:left;max-width:560px;margin:0 auto}.demo-toolbar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;display:flex}.demo-hint{color:var(--muted);font-size:13px}.demo-page{border:1px solid var(--line);box-shadow:var(--shadow);color:#2a2a2a;background:#fff;border-radius:14px;padding:20px 22px;font-size:16px;line-height:2.15}.demo-line{margin:0 0 6px}.demo-line:last-child{margin-bottom:0}.demo-mask{color:#0000;cursor:pointer;-webkit-user-select:none;user-select:none;background:linear-gradient(#e23b3b,#d63333);border-radius:3px;margin:0 1px;padding:1px 5px;transition:background .15s,color .15s;box-shadow:inset 0 0 0 1px #00000014}.demo-mask.on{color:#2a2a2a;box-shadow:none;cursor:default;background:0 0}.demo-note{color:var(--muted);margin-top:12px;font-size:13px}.features{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin:24px 0;display:grid}.feature-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}.feature-card h3{margin:8px 0 6px;font-size:16px}.feature-card p{color:var(--muted);margin:0;font-size:13.5px;line-height:1.7}.feature-emoji{font-size:30px;line-height:1}.section-title{text-align:center;margin:8px 0 18px;font-size:22px}.steps-section{margin:28px 0}.steps{flex-direction:column;gap:14px;max-width:560px;margin:0 auto;padding:0;list-style:none;display:flex}.step{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);align-items:flex-start;gap:14px;padding:16px;display:flex}.step-no{background:var(--sand);color:#3a2613;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-weight:800;display:flex}.step h4{margin:2px 0 4px;font-size:15px}.step p{color:var(--muted);margin:0;font-size:13.5px;line-height:1.7}.platforms{margin:24px 0}.platforms-note{max-width:480px;margin:0 auto;line-height:1.8}.home-final-cta{text-align:center;border:1px solid var(--line);background:linear-gradient(#efe0cb,#e6d3b8);border-radius:16px;margin:24px 0;padding:32px 16px}.home-final-cta h2{color:#3a2613;margin:0 0 18px;font-size:20px}.home-footer{text-align:center;border-top:1px solid var(--line);flex-direction:column;align-items:center;gap:4px;margin-top:12px;padding:28px 12px 36px;font-size:12.5px;display:flex}.home-footer-links{gap:14px;margin-top:6px;display:flex}.home-footer-links a,.link-btn{color:var(--ocean);font:inherit;cursor:pointer;background:0 0;border:none;padding:0;text-decoration:none}.home-footer-links a:hover,.link-btn:hover{text-decoration:underline}.topbar-info{margin-left:auto}.auth-panel{max-width:420px;margin:0 auto}.auth-form{flex-direction:column;gap:12px;margin-top:8px;display:flex}.auth-links{flex-wrap:wrap;justify-content:space-between;gap:8px;margin:12px 0;display:flex}.linklike{color:var(--ocean);font:inherit;cursor:pointer;background:0 0;border:none;padding:4px 0;font-size:13px}.auth-msg{color:#c0392b;margin:2px 0;font-size:13px}.btn.danger{color:#fff;background:#c0392b;border-color:#c0392b;font-weight:700}.btn.danger:hover{color:#fff;background:#a93226;border-color:#a93226}.btn.danger-outline{background:var(--card);color:#c0392b;border-color:#e0a99f;font-weight:600}.btn.danger-outline:hover{color:#fff;background:#c0392b;border-color:#c0392b}.danger-zone{border-top:1px dashed var(--line);margin-top:14px;padding-top:12px}.danger-link{color:#c0392b}.delete-account{flex-direction:column;gap:8px;max-width:360px;display:flex}.del-pw{font:inherit;border:1px solid var(--line);background:var(--card);color:var(--ink);border-radius:8px;padding:8px 10px}.del-actions{gap:8px;display:flex}.usage-line{margin:4px 0;font-size:14px}.modal-backdrop{z-index:50;background:#281c0c80;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:10px;width:100%;max-width:460px;max-height:84vh;padding:18px;display:flex;overflow:auto}.section-label{color:var(--ink);margin:8px 0 2px;font-size:13px;font-weight:700}.limit-book-list{flex-direction:column;gap:6px;margin:2px 0;padding:0;list-style:none;display:flex}.limit-book-list li{border:1px solid var(--line);border-radius:8px}.limit-book-list li.sel{border-color:var(--ocean);background:#0891b212}.limit-book-list label{cursor:pointer;align-items:center;gap:8px;padding:8px 10px;display:flex}.limit-book-name{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:14px;overflow:hidden}.limit-book-device{color:var(--muted);white-space:nowrap;font-size:11px}.cloud-section{margin-top:20px}.cloud-list{flex-direction:column;gap:6px;margin:6px 0 0;padding:0;list-style:none;display:flex}.cloud-item{border:1px solid var(--line);background:var(--card);border-radius:8px;flex-wrap:wrap;align-items:center;gap:10px;padding:8px 12px;display:flex}.cloud-error{color:#c0392b;flex-basis:100%;margin:0;font-size:12px;line-height:1.5}.cloud-locked{color:var(--muted);font-size:12px;font-weight:600}.cloud-name{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:14px;overflow:hidden}.cloud-device{color:var(--muted);white-space:nowrap;font-size:11px}.cloud-badge{white-space:nowrap;border-radius:8px;padding:1px 6px;font-size:10px;font-weight:700}.cloud-badge.ok{color:#2a6f97;background:#e3f0f7}.cloud-badge.warn{color:#9a6a00;background:#fbf0d9}.plan-compare{gap:10px;margin:8px 0;display:flex}.plan-col{border:1px solid var(--line);background:var(--card);border-radius:10px;flex:1;padding:12px}.plan-col.pro{border-color:var(--sand)}.plan-col.current{outline:2px solid var(--ocean)}.plan-col h4{margin:0 0 4px;font-size:15px}.plan-price{margin:0 0 8px;font-size:18px;font-weight:800;line-height:1.3}.plan-col ul{flex-direction:column;gap:3px;margin:0;padding-left:18px;font-size:13px;display:flex}.hero-buttons{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.pricing{max-width:920px;margin:0 auto;padding:8px 16px 64px}.pricing-hero{text-align:center;padding:28px 0 8px;position:relative}.pricing-back{position:absolute;top:8px;left:0}.pricing-title{letter-spacing:-.01em;margin:8px 0 6px;font-size:30px;font-weight:800}.pricing-lead{color:var(--muted);margin:0 0 18px;font-size:15px}.pricing-toggle{background:var(--card);border:1px solid var(--line);border-radius:999px;gap:4px;padding:4px;display:inline-flex}.pricing-toggle button{font:inherit;color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:999px;align-items:center;gap:6px;padding:8px 18px;font-size:14px;display:inline-flex}.pricing-toggle button.on{background:var(--ink);color:#fff}.pricing-toggle .save{color:var(--forest);background:#1665341a;border-radius:999px;padding:1px 6px;font-size:11px;font-weight:700}.pricing-toggle button.on .save{color:#bbf7d0;background:#ffffff26}.plan-cards{grid-template-columns:repeat(2,1fr);gap:18px;margin:28px 0 10px;display:grid}@media (width<=640px){.plan-cards{grid-template-columns:1fr}}.plan-card{border:1px solid var(--line);background:var(--card);box-shadow:var(--shadow);border-radius:16px;flex-direction:column;padding:24px 22px;display:flex;position:relative}.plan-card.highlight{border-color:var(--sand);border-width:2px}.plan-badge{background:var(--sand);color:#fff;border-radius:999px;padding:3px 12px;font-size:12px;font-weight:700;position:absolute;top:-11px;left:22px}.plan-card-name{margin:2px 0;font-size:20px;font-weight:800}.plan-card-tagline{color:var(--muted);min-height:36px;margin:0 0 14px;font-size:13px}.plan-card-price{align-items:baseline;gap:2px;margin:0;display:flex}.plan-card-price .amount{letter-spacing:-.02em;font-size:34px;font-weight:800}.plan-card-price .period{color:var(--muted);font-size:15px}.plan-card-sub{margin:2px 0 16px}.plan-card-features{flex-direction:column;flex:1;gap:9px;margin:0 0 20px;padding:0;list-style:none;display:flex}.plan-card-features li{padding-left:24px;font-size:14px;position:relative}.plan-card-features li:before{content:"✓";color:var(--forest);font-weight:800;position:absolute;left:0}.pricing-note{margin:4px 0 8px}.compare-section{margin-top:44px}.compare-wrap{overflow-x:auto}.compare-table{border-collapse:collapse;width:100%;margin-top:10px}.compare-table th,.compare-table td{text-align:center;border-bottom:1px solid var(--line);padding:12px 14px;font-size:14px}.compare-table th{font-size:15px;font-weight:800}.compare-table .compare-feature{text-align:left;color:var(--ink)}.compare-table .pro-col{background:#d4a37314}.pricing-final{text-align:center;flex-direction:column;align-items:center;gap:12px;margin-top:48px;display:flex}.pricing-final h2{margin:0}.mkt-nav{border-bottom:1px solid var(--line);align-items:center;gap:12px;padding:12px 16px;display:flex}.mkt-brand{color:var(--sand-deep);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;padding:4px;font-size:18px;font-weight:800;display:inline-flex}.mkt-links{gap:2px;margin-left:6px;display:flex}.mkt-link{font:inherit;color:var(--ink);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:6px 12px;font-size:14px}.mkt-link:hover{background:#0000000a}.mkt-link.active{color:var(--sand-deep);font-weight:700}.mkt-actions{align-items:center;gap:8px;margin-left:auto;display:flex}@media (width<=560px){.mkt-nav{flex-wrap:wrap;gap:8px}.mkt-links{order:3;justify-content:center;width:100%;margin-left:0}}.page-hero{text-align:center;max-width:720px;margin:0 auto;padding:28px 16px 8px}.page-title{margin:8px 0;font-size:30px;font-weight:800}.page-lead{color:var(--muted);margin:0;font-size:15px;line-height:1.7}.home-more{margin:10px 0 0}.site-footer{border-top:1px solid var(--line);background:var(--card);margin-top:48px;padding:24px 16px}.site-footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.site-footer-brand{flex-direction:column;gap:4px;display:flex}.site-footer-links{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.site-footer-links a{color:var(--ocean);font-size:13px;text-decoration:none}.site-footer-copy{text-align:center;margin:16px 0 0}.import-color{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.import-color-label{color:var(--muted);font-size:13px}.info-section{margin-bottom:4px}.info-page .section{border-top:1px solid var(--line);margin:20px 0 10px;padding-top:14px;font-size:15px}.info-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);flex-direction:column;gap:8px;padding:14px;font-size:14px;line-height:1.7;display:flex}.info-card p{margin:0}.info-card .btn{align-self:flex-start}.info-links{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.info-links a{color:var(--ocean);text-decoration:none}.info-links a:hover{text-decoration:underline}.faq{border-bottom:1px solid var(--line)}.faq-q{width:100%;font:inherit;color:var(--ink);cursor:pointer;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;gap:10px;padding:12px 2px;font-weight:600;display:flex}.faq-a{color:var(--muted);margin:0 2px 12px;font-size:13.5px;line-height:1.7}@media (prefers-color-scheme:dark){:root{--bg:#1b1712;--card:#26211a;--ink:#efe6d8;--muted:#a99a86;--line:#3a3228;--sand:#d4a373;--sand-deep:#e0b487;--shadow:0 1px 3px #00000073, 0 8px 22px #00000052}.page-stage{background:#fff}.btn.primary{color:#2a1c0c}.chip{background:#332b21}.chip.due{color:#6fd0e6;background:#123440}.chip.new{background:#3a2c18}.bar{background:#3a3228}}.downgrade .book-grid{margin-top:14px}.trim-book{appearance:none;cursor:pointer;font:inherit;color:inherit;background:0 0;border:2px solid #0000;border-radius:10px;flex-direction:column;align-items:center;padding:6px;display:flex;position:relative}.trim-book .book-cover{width:100%}.trim-book.sel{border-color:var(--sand);background:#d4a3731f}.trim-badge{background:var(--sand);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-weight:800;display:flex;position:absolute;top:10px;right:10px;box-shadow:0 1px 3px #0000004d}.downgrade-actions{justify-content:space-between;margin-top:20px}.dev-panel{border:1px dashed var(--sand-deep);background:#d4a37312;border-radius:10px;flex-direction:column;gap:8px;margin-top:18px;padding:12px 14px;display:flex}.dev-title{color:var(--sand-deep);margin:0;font-size:13px;font-weight:700}.dev-row{flex-wrap:wrap;gap:8px;display:flex}.device-name-field{margin:12px 0}.device-name-field>label{color:var(--ink);margin-bottom:6px;font-size:13px;font-weight:700;display:block}.device-name-row{align-items:center;gap:8px;display:flex}.device-name-input{min-width:0;font:inherit;border:1px solid var(--line);background:var(--card);color:var(--ink);border-radius:8px;flex:1;padding:8px 10px}.quiz-quota{margin:4px 0 12px;font-size:14px}.quiz-tabs{gap:8px;margin-bottom:14px;display:flex}.quiz-generate{flex-direction:column;gap:12px;display:flex}.gen-controls{flex-direction:column;gap:10px;display:flex}.gen-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.gen-label{color:var(--ink);min-width:72px;font-size:13px;font-weight:700}.gen-hint{min-width:160px;font:inherit;border:1px solid var(--line);background:var(--card);color:var(--ink);border-radius:8px;flex:1;padding:7px 10px}.range-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.range-num{width:80px;font:inherit;border:1px solid var(--line);background:var(--card);color:var(--ink);border-radius:8px;padding:7px 8px}.page-picker{grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:12px;display:grid}.page-card{cursor:pointer;font:inherit;color:inherit;background:0 0;border:2px solid #0000;border-radius:8px;flex-direction:column;gap:4px;padding:4px;display:flex}.page-card.sel{border-color:var(--sand);background:#d4a3731f}.page-thumb{aspect-ratio:.7;background:var(--card);border:1px solid var(--line);border-radius:4px;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.page-thumb img{object-fit:cover;width:100%;height:100%}.page-check{background:var(--sand);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-weight:800;display:flex;position:absolute;top:4px;right:4px}.page-gen{color:#fff;background:#0f766e;border-radius:6px;padding:1px 5px;font-size:10px;font-weight:800;position:absolute;top:4px;left:4px}.gen-count{color:#0f766e;font-size:12px;font-weight:700}.page-card-meta{justify-content:space-between;font-size:12px;display:flex}.gen-footer{flex-wrap:wrap;align-items:center;gap:12px;padding-top:6px;display:flex}.quiz-warn{color:var(--sand-deep)}.quiz-msg{background:#d4a3731a;border-radius:8px;margin-top:8px;padding:10px 12px;font-size:14px}.solve-list{flex-direction:column;gap:12px;display:flex}.solve-all{align-self:flex-start}.solve-pages{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;margin:0;padding:0;list-style:none;display:grid}.solve-page-btn{border:1px solid var(--line);background:var(--card);cursor:pointer;width:100%;font:inherit;color:var(--ink);border-radius:8px;justify-content:space-between;padding:10px 12px;display:flex}.solve-session{flex-direction:column;gap:16px;max-width:640px;margin:0 auto;display:flex}.solve-progress{justify-content:space-between;align-items:center;display:flex}.solve-statement{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px;font-size:18px;line-height:1.7}.solve-choices{gap:12px;display:flex}.solve-choices .btn{flex:1;padding:14px;font-size:16px}.btn.maru{border-color:var(--ocean);color:var(--ocean);background:#e7f3ff}.btn.batsu{border-color:var(--sheet);color:var(--sheet-2);background:#fdeaea}.solve-reveal{flex-direction:column;gap:10px;display:flex}.solve-verdict{font-size:16px;font-weight:800}.solve-verdict.right{color:var(--forest)}.solve-verdict.wrong{color:var(--sheet-2)}.solve-explain{line-height:1.6}.solve-done{text-align:center;flex-direction:column;gap:12px;padding:24px;display:flex}.solve-done-actions{justify-content:center;gap:12px;display:flex}.trim-list{flex-direction:column;gap:6px;margin:14px 0;padding:0;list-style:none;display:flex}.trim-row{border:1px solid var(--line);background:var(--card);width:100%;color:var(--ink);font:inherit;cursor:pointer;text-align:left;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;display:flex}.trim-row.sel{border-color:var(--sand);background:#d4a3731f}.trim-check{background:var(--card);border:1px solid var(--line);color:#fff;border-radius:50%;flex:none;justify-content:center;align-items:center;width:22px;height:22px;font-weight:800;display:flex}.trim-row.sel .trim-check{background:var(--sand);border-color:var(--sand)}.trim-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.trim-device{flex:none}.page-pills{gap:3px;display:flex;position:absolute;top:4px;left:4px}.page-pills .page-gen{position:static}.page-gen.mc4{background:#7c3aed}.page-state{border-radius:4px;justify-content:center;align-items:center;font-size:22px;font-weight:800;display:flex;position:absolute;inset:0}.page-state.wait{background:#786e5f40}.page-state.run{background:#fffdf78c}.page-state.done{color:#fff;background:#0f766e73}.page-state.fail{color:#fff;background:#c0392b66}.page-spinner{border:3px solid #0f766e40;border-top-color:#0f766e;border-radius:50%;width:26px;height:26px;animation:.8s linear infinite pgspin}@keyframes pgspin{to{transform:rotate(360deg)}}.gen-run{flex-direction:column;gap:8px;width:100%;display:flex}.gen-bar{background:var(--line);border-radius:5px;height:10px;overflow:hidden}.gen-bar-fill{background:var(--sand);height:100%;transition:width .3s}.gen-run-row{justify-content:space-between;align-items:center;gap:10px;display:flex}.gen-run-done{flex-direction:column;gap:8px;display:flex}.gen-run-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.qlist{flex-direction:column;gap:10px;display:flex}.qlist-page{border:1px solid var(--line);background:var(--card);border-radius:10px;overflow:hidden}.qlist-page-head{border-bottom:1px solid var(--line);padding:8px 12px;font-weight:800}.qlist-group+.qlist-group{border-top:1px solid var(--line)}.qlist-group-head{width:100%;font:inherit;color:var(--ink);cursor:pointer;background:0 0;border:none;justify-content:space-between;align-items:center;gap:10px;padding:8px 12px;display:flex}.qlist-body{padding:0 12px 10px}.qlist-items{flex-direction:column;gap:10px;margin:0;padding-left:20px;display:flex}.qlist-stmt{margin:0 0 4px;line-height:1.6}.qlist-ans{color:var(--forest);margin:0;font-weight:700}.qlist-choices{margin:0 0 4px;padding-left:22px}.qlist-choices .is-answer{color:var(--forest);font-weight:800}.qlist-actions{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.practice-setup{flex-direction:column;gap:12px;display:flex}.practice-setup .solve-all{align-self:flex-start}.btn.locked{opacity:.75}.solve-mc4{flex-direction:column;gap:10px;display:flex}.btn.mc4-choice{text-align:left;background:var(--card);border:1px solid var(--line);align-items:center;gap:10px;padding:13px 14px;font-size:15px;line-height:1.5;display:flex}.btn.mc4-choice:hover{border-color:var(--sand)}.mc4-no{background:var(--bg);border:1px solid var(--line);border-radius:50%;flex:none;justify-content:center;align-items:center;width:24px;height:24px;font-size:13px;font-weight:800;display:inline-flex}.review-card{cursor:pointer;text-align:left;width:100%;color:var(--ink);font:inherit;background:#0f766e14;border:1px solid #0f766e;border-radius:12px;flex-direction:column;align-items:flex-start;gap:4px;margin:4px 0 12px;padding:14px 16px;display:flex}.review-card:hover{background:#0f766e24}.review-card-title{color:#0f766e;font-size:16px;font-weight:800}.review-card-sub{color:var(--muted);font-size:12.5px}.review-card.locked{border-color:var(--line);background:var(--card)}.review-card.locked .review-card-title{color:var(--muted)}.qlist-topic{color:var(--muted);margin-left:10px;font-size:12.5px;font-weight:600}.range-topics{margin:2px 0 0;line-height:1.7}.qlist-chapter{color:var(--ink);margin:12px 2px 0;font-size:14.5px;font-weight:800}.chapter-chips{flex-wrap:wrap;gap:8px;display:flex}.chapter-chip{border:1px solid var(--line);background:var(--card);cursor:pointer;border-radius:999px;align-items:center;gap:8px;padding:8px 14px;font-size:14px;display:inline-flex}.chapter-chip:hover{border-color:var(--sand)}.chapter-chip-title{color:var(--ink);font-weight:700}.chapter-chip-count{color:var(--muted);font-size:12.5px}.toc-hint{line-height:1.7}.toc-link{font:inherit;color:var(--ocean);cursor:pointer;background:0 0;border:none;margin-left:6px;padding:0;text-decoration:underline}
