@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap";:root{--bg: #f1f0ea;--paper: #fcfbf7;--panel: #ffffff;--ink: #1f2a2e;--text: #1f2a2e;--muted: #58666d;--line: #d8d4c8;--accent: #0f4c5c;--accent-strong: #0a3f4d;--secondary: #c56e2c;--danger: #a12a2a;--shadow: 0 20px 50px rgba(6, 23, 28, .12);--control-bg: color-mix(in oklab, var(--paper), var(--bg) 22%);--control-bg-strong: color-mix(in oklab, var(--panel), var(--bg) 16%);--control-border: color-mix(in oklab, var(--line), var(--bg) 10%);--control-text: var(--text);--control-hover-bg: color-mix(in oklab, var(--accent), var(--panel) 88%);--viewer-page-active-bg: var(--accent-strong);--viewer-page-active-text: #f5fbff;--viewer-page-active-border: color-mix(in oklab, var(--accent-strong), #000 18%);--viewer-page-active-ring: color-mix(in oklab, var(--accent), transparent 55%);--offline-pill-border: color-mix(in oklab, var(--danger), var(--line) 32%);--offline-pill-bg: color-mix(in oklab, var(--danger), #7f1f1f 20%);--offline-pill-text: #fff;font-family:IBM Plex Sans,system-ui,sans-serif;color:var(--text);background:radial-gradient(circle at 20% 0%,#f9f5e8 0%,var(--bg) 45%,#ebe7dc 100%);line-height:1.4;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root.dark{--bg: #0f1a1e;--paper: #1a2a30;--panel: #1f3038;--ink: #e8e4d8;--text: #e8e4d8;--muted: #8fa8b0;--line: #2d4048;--shadow: 0 20px 50px rgba(0, 0, 0, .4);--control-bg: color-mix(in oklab, var(--panel), var(--bg) 18%);--control-bg-strong: color-mix(in oklab, var(--panel), var(--bg) 12%);--control-border: color-mix(in oklab, var(--line), var(--bg) 18%);--control-text: var(--text);--control-hover-bg: color-mix(in oklab, var(--accent), var(--panel) 78%);--viewer-page-active-bg: color-mix(in oklab, var(--accent), #0a1518 22%);--viewer-page-active-text: #ffffff;--viewer-page-active-border: color-mix(in oklab, var(--accent), #ffffff 16%);--viewer-page-active-ring: color-mix(in oklab, var(--accent), transparent 42%);--offline-pill-border: color-mix(in oklab, var(--danger), var(--line) 38%);--offline-pill-bg: color-mix(in oklab, var(--danger), #311314 26%);--offline-pill-text: #fff;background:radial-gradient(circle at 20% 0%,#152028 0%,var(--bg) 45%,#0a1418 100%)}*{box-sizing:border-box}html,body,#app{background-color:var(--bg)}body{margin:0;touch-action:pan-x pan-y}#app{min-height:100vh}button,input,textarea{font:inherit}button{border:1px solid var(--line);background:var(--panel);border-radius:10px;padding:.45rem .8rem;cursor:pointer;transition:.12s ease}button:hover{border-color:var(--accent);color:var(--accent)}input,textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:.55rem .65rem;background:var(--panel);color:var(--text)}a{color:var(--accent)}h1,h2,h3,p{margin:0}.app-shell{width:min(1360px,100% - 1.5rem);margin:0 auto;padding:.6rem 0 .9rem}.app-shell.viewer-route{width:100%;margin:0;padding:0;max-width:none}.app-shell.viewer-route .topbar{position:fixed;top:.65rem;left:.65rem;right:.65rem;z-index:30;grid-template-columns:auto;justify-content:end;gap:0;padding:0;border:none;border-radius:0;background:transparent;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;pointer-events:none}.app-shell.viewer-route .topbar-main{display:none}.app-shell.viewer-route .topbar-nav{display:flex;flex-wrap:wrap;justify-content:flex-end;row-gap:.35rem;pointer-events:auto}.viewer-reset-link{font-size:.82rem;font-weight:700;border-color:color-mix(in oklab,var(--line),var(--danger) 45%);color:color-mix(in oklab,var(--danger),var(--control-text) 34%)}.viewer-reset-link:hover,.viewer-reset-link:focus-visible{border-color:color-mix(in oklab,var(--danger),var(--line) 30%);background:color-mix(in oklab,var(--danger),var(--panel) 82%);color:color-mix(in oklab,#6d0f0f,var(--text) 12%)}:root.dark .viewer-reset-link{border-color:color-mix(in oklab,var(--danger),var(--line) 44%);background:color-mix(in oklab,var(--danger),var(--panel) 84%);color:#ffe9e9}:root.dark .viewer-reset-link:hover,:root.dark .viewer-reset-link:focus-visible,:root.dark .viewer-reset-link:active{border-color:color-mix(in oklab,var(--danger),#ffffff 24%);background:color-mix(in oklab,var(--danger),#ffffff 8%);color:#fff}.app-shell.viewer-route main{min-height:100vh}.topbar{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:1rem;padding:.65rem .9rem;background:linear-gradient(118deg,color-mix(in oklab,var(--paper),var(--bg) 12%),color-mix(in oklab,var(--panel),var(--bg) 26%));border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);position:sticky;top:.5rem;z-index:20;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.topbar-main{display:flex;align-items:center;gap:.72rem;flex:1 1 auto;min-width:0;width:100%}.eyebrow{font-size:.74rem;letter-spacing:.09em;text-transform:uppercase;color:var(--secondary);margin-bottom:.25rem}.topbar h1{font-size:clamp(1.35rem,1.9vw,2rem);max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-nav{display:flex;flex-wrap:nowrap;justify-content:flex-end;gap:.5rem;flex:0 0 auto}.offline-pill{display:inline-flex;align-items:center;min-height:2.35rem;padding:.35rem .75rem;border-radius:999px;border:1px solid var(--offline-pill-border);color:var(--offline-pill-text);background:var(--offline-pill-bg);font-weight:600;font-size:.86rem}.topbar-link{display:inline-flex;align-items:center;min-height:2.35rem;padding:.35rem .8rem;border:1px solid var(--control-border);border-radius:999px;background:var(--control-bg);text-decoration:none;color:var(--control-text)}.topbar-icon-link{width:2.35rem;min-width:2.35rem;height:2.35rem;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--control-border);border-radius:999px;background:var(--control-bg);color:var(--control-text);text-decoration:none}.topbar-icon-link svg{width:1.15rem;height:1.15rem}.topbar-icon-link.theme-toggle{width:auto;min-width:2.35rem;min-height:2.35rem;height:auto;padding:.35rem .75rem;gap:.42rem;box-sizing:border-box;white-space:nowrap}.theme-toggle svg{width:1.4rem;height:1.4rem;flex:0 0 auto}.theme-toggle-label{font-size:.82rem;font-weight:700;letter-spacing:.03em;line-height:1}.topbar-link:hover,.topbar-icon-link:hover,.viewer-page-pill:hover{border-color:var(--accent);background:var(--control-hover-bg);color:var(--accent)}.topbar-link:focus-visible,.topbar-icon-link:focus-visible,.viewer-page-pill:focus-visible{outline:2px solid color-mix(in oklab,var(--accent),var(--panel) 12%);outline-offset:2px}.library{margin-top:1rem;display:grid;gap:1rem}.search-panel{border:1px solid var(--line);border-radius:16px;background:var(--paper);padding:1rem;box-shadow:var(--shadow);color:var(--text)}.search-panel label{display:block;font-weight:600;margin-bottom:.45rem}@supports (-webkit-touch-callout: none){.search-panel input,.search-panel textarea{font-size:16px}}.hint{margin-top:.45rem;color:var(--muted)}.offline-actions{margin-top:.7rem;display:grid;gap:.35rem}.offline-actions-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.45rem}.offline-more{position:relative}.action-btn{min-height:2.6rem;width:100%;display:inline-flex;align-items:center;justify-content:center;gap:.45rem;font-weight:600;border-radius:12px;color:var(--control-text)}.action-btn svg{width:1rem;height:1rem}.action-filter{border-color:color-mix(in oklab,var(--accent),var(--line) 40%);color:var(--text);background:color-mix(in oklab,var(--accent),var(--panel) 88%)}.action-filter.active{color:#fff;background:var(--accent);border-color:var(--accent)}.action-download-all{border-color:color-mix(in oklab,var(--secondary),var(--line) 40%);color:var(--secondary);background:color-mix(in oklab,var(--secondary),var(--panel) 86%)}.action-verify{border-color:color-mix(in oklab,#2e7d32,var(--line) 40%);color:#2e7d32;background:color-mix(in oklab,#2e7d32,var(--panel) 88%)}.action-more{border-color:color-mix(in oklab,var(--line),var(--bg) 18%);background:color-mix(in oklab,var(--paper),var(--bg) 16%)}.action-clear{border-color:color-mix(in oklab,var(--danger),var(--line) 40%);color:var(--danger);background:color-mix(in oklab,var(--danger),var(--panel) 88%)}.offline-menu{position:absolute;right:0;top:calc(100% + .35rem);z-index:20;min-width:12rem;padding:.35rem;border-radius:10px;border:1px solid var(--line);background:var(--paper);box-shadow:0 12px 24px #06171c29}.offline-menu-item{width:100%;min-height:2.35rem;border-radius:8px;border:1px solid transparent;background:transparent;text-align:left;font-weight:600;padding:.45rem .6rem}.offline-menu-item.danger{color:var(--danger)}.offline-menu-item.danger:hover{border-color:color-mix(in oklab,var(--danger),var(--line) 40%);background:color-mix(in oklab,var(--danger),var(--panel) 88%)}.pwa-update-banner{position:fixed;left:1rem;bottom:1rem;z-index:35;min-width:min(22rem,calc(100vw - 2rem));max-width:min(28rem,calc(100vw - 2rem));border:1px solid var(--line);border-radius:12px;background:var(--paper);color:var(--text);box-shadow:0 10px 28px #06171c33;padding:.75rem;display:grid;gap:.6rem}.pwa-update-banner p{margin:0;font-weight:600}.pwa-update-actions{display:flex;justify-content:flex-end;gap:.5rem}.pwa-update-actions .action-btn{width:auto;min-height:2.2rem;padding:.35rem .7rem}.action-btn:disabled{opacity:.58;cursor:not-allowed}.action-btn:disabled:hover{color:inherit;border-color:inherit}.state{border:1px solid var(--line);border-radius:12px;background:var(--paper);padding:.9rem;color:var(--text)}.toast{position:fixed;right:1rem;bottom:1rem;z-index:30;min-width:min(24rem,calc(100vw - 2rem));max-width:min(32rem,calc(100vw - 2rem));border-radius:12px;border:1px solid var(--line);background:var(--paper);box-shadow:0 10px 28px #06171c2e;padding:.7rem .75rem;display:grid;grid-template-columns:1fr auto;align-items:center;gap:.6rem;color:var(--text)}.toast.ok{border-color:color-mix(in oklab,#2e7d32,var(--line) 40%);background:color-mix(in oklab,#2e7d32,var(--panel) 88%)}.toast.error{border-color:color-mix(in oklab,var(--danger),var(--line) 40%);background:color-mix(in oklab,var(--danger),var(--panel) 88%)}.toast-close{width:1.95rem;min-width:1.95rem;height:1.95rem;border-radius:999px;padding:0;font-size:1.15rem;line-height:1}.confirm-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;background:#05131873;display:grid;place-items:center;padding:1rem}.confirm-dialog{width:min(28rem,calc(100vw - 2rem));border:1px solid var(--line);border-radius:14px;background:var(--paper);box-shadow:0 18px 44px #06171c4d;padding:1rem;display:grid;gap:.75rem;color:var(--text)}.confirm-dialog h3{margin:0}.confirm-dialog p{margin:0;color:var(--muted)}.confirm-actions{display:flex;justify-content:flex-end;gap:.55rem}.error{color:var(--danger)}.song-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:minmax(0,1fr);gap:.9rem}.library-browser{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.8rem;align-items:start}.library-sections{display:grid;gap:1rem}.song-letter-group{display:grid;gap:.65rem;scroll-margin-top:5.5rem}.song-letter-header{display:flex;align-items:center;justify-content:space-between;gap:.8rem;padding:.35rem .2rem}.song-letter-key{display:inline-flex;align-items:center;justify-content:center;min-width:2rem;min-height:2rem;border-radius:999px;border:1px solid color-mix(in oklab,var(--line),var(--bg) 10%);background:color-mix(in oklab,var(--paper),var(--bg) 12%);font-weight:700}.song-letter-count{color:var(--muted);font-size:.84rem}.library-letter-rail{position:sticky;top:5.5rem;display:grid;grid-template-columns:1fr;gap:.28rem;padding:.45rem;border:1px solid color-mix(in oklab,var(--line),var(--bg) 16%);border-radius:14px;background:color-mix(in oklab,var(--paper),var(--bg) 10%);box-shadow:var(--shadow);z-index:6}.letter-rail-button{width:2rem;min-width:2rem;height:2rem;min-height:2rem;padding:0;border-radius:10px;font-size:.78rem;font-weight:700;color:color-mix(in oklab,var(--muted),var(--text) 40%)}.letter-rail-button.active{background:var(--accent);border-color:var(--accent);color:#fff}.letter-rail-top{border-color:color-mix(in oklab,var(--line),var(--bg) 12%);background:color-mix(in oklab,var(--panel),var(--bg) 8%);color:color-mix(in oklab,var(--accent),var(--text) 35%);font-size:.96rem}.song-card{border:1px solid var(--line);border-radius:14px;background:var(--panel);padding:.9rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;box-shadow:var(--shadow)}.song-card-main{flex:1 1 auto;min-width:0}.song-card h2{font-size:1.05rem;margin-bottom:.4rem}.song-title-button{border:0;background:transparent;padding:0;margin:0;width:100%;text-align:left;color:inherit;font:inherit;line-height:inherit;cursor:pointer}.song-title-button:hover,.song-title-button:focus-visible{color:var(--accent);text-decoration:none}.tags{color:var(--muted);font-size:.92rem;margin-top:.4rem}.actions{display:flex;align-items:center;justify-content:flex-end;gap:.45rem;flex-wrap:nowrap;margin-left:auto;flex:0 0 auto}.actions button{width:auto;flex:0 0 auto}.icon-button{width:2.75rem;min-width:2.75rem;height:2.75rem;padding:0;display:inline-flex;align-items:center;justify-content:center;color:var(--control-text)}.icon-button svg{width:1.2rem;height:1.2rem}.icon-button.is-downloaded{border-color:color-mix(in oklab,var(--accent),var(--line) 40%);color:var(--accent);background:color-mix(in oklab,var(--accent),var(--panel) 86%)}:root.dark .icon-button.is-downloaded{color:#6ecfe0;border-color:color-mix(in oklab,#6ecfe0,var(--line) 50%);background:color-mix(in oklab,#6ecfe0,var(--panel) 88%)}.icon-spin{animation:icon-spin .9s linear infinite}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes icon-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.viewer-page{margin-top:1rem;display:grid;gap:.8rem}.app-shell.viewer-route .viewer-page{margin:0;height:100vh}.sheet-viewer{border:1px solid var(--line);border-radius:16px;background:var(--paper);padding:.75rem;box-shadow:var(--shadow)}.viewer-header{display:grid;gap:.75rem}.sheet-viewer{position:relative;display:grid;gap:.85rem;padding-bottom:4.8rem}.app-shell.viewer-route .sheet-viewer{height:100vh;border:none;border-radius:0;box-shadow:none;padding:0 0 5.2rem;gap:0}.app-shell.viewer-route .viewer-shell-header{display:none}.viewer-shell-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.8rem;color:var(--text)}.viewer-heading{min-width:0}.viewer-heading h2{margin:.18rem 0 0;line-height:1.1}.viewer-kicker{margin:0;color:var(--muted);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase}.viewer-status-cluster{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:flex-end}.viewer-page-pill,.viewer-zoom-pill{border-radius:999px;border:1px solid var(--control-border);background:var(--control-bg-strong);color:var(--control-text);min-height:2.4rem;padding:.45rem .8rem;font-size:.88rem}.viewer-page-pill{font-weight:600}.viewer-zoom-pill{display:inline-flex;align-items:center}.pdf-stage{position:relative;overflow:auto;height:min(72vh,42rem);padding:3.2rem .75rem 3rem;border:1px solid var(--line);border-radius:20px;background:radial-gradient(circle at top,color-mix(in oklab,var(--panel),transparent 55%) 0%,transparent 38%),linear-gradient(180deg,color-mix(in oklab,var(--paper),var(--bg) 28%),color-mix(in oklab,var(--bg),var(--paper) 20%));touch-action:none;overscroll-behavior:contain;cursor:grab}.app-shell.viewer-route .pdf-stage{height:100vh;min-height:100vh;border:none;border-radius:0;padding:max(.8rem,env(safe-area-inset-top)) .4rem calc(4.3rem + env(safe-area-inset-bottom))}.pdf-stage:active{cursor:grabbing}.pdf-stage.is-loading .canvas-grid{visibility:hidden}.viewer-loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:5;display:grid;place-items:center;gap:.75rem;background:color-mix(in oklab,var(--bg),transparent 28%);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);pointer-events:none}.viewer-loading-spinner{width:3rem;height:3rem;border-radius:999px;border:4px solid rgba(12,33,39,.18);border-top-color:var(--accent);animation:viewer-spin .9s linear infinite}.viewer-loading-label{font-size:.88rem;font-weight:600;color:color-mix(in oklab,var(--ink),var(--muted) 18%)}@keyframes viewer-spin{to{transform:rotate(360deg)}}.viewer-stage-overlay{position:absolute;z-index:3;top:.75rem;padding:.35rem .7rem;border-radius:999px;border:1px solid var(--control-border);background:color-mix(in oklab,var(--control-bg-strong),transparent 10%);color:var(--control-text);box-shadow:0 6px 18px #0715192e;font-size:.74rem;letter-spacing:.03em;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.viewer-stage-overlay.top-left{left:.75rem}.viewer-stage-overlay.top-right{right:.75rem}.viewer-stage-overlay.is-fixed-vertical{position:fixed;top:max(.75rem,env(safe-area-inset-top));left:max(.75rem,env(safe-area-inset-left));z-index:10}.canvas-grid{display:flex;justify-content:center;align-items:flex-start;gap:.85rem;width:fit-content;min-width:100%;margin:0 auto;will-change:auto;transition:transform .12s ease-out;transform:translateZ(0);backface-visibility:hidden}.master-zoom-container{width:fit-content;min-width:100%;margin:0 auto;transform:translateZ(0);backface-visibility:hidden}.master-zoom-container.is-gesture-zooming,.canvas-grid.is-gesture-zooming{will-change:transform}.vertical-pages-strip{display:grid;grid-template-columns:minmax(0,1fr);justify-items:center;gap:1rem;width:max-content;min-width:100%;max-width:none;margin:0 auto;padding:.4rem 0 1.2rem}.vertical-page-wrapper{display:block;width:fit-content;position:relative}.vertical-page-canvas{width:auto;max-width:none}.canvas-page-wrapper{position:relative;flex:0 0 auto;line-height:0}.page-canvas{background:var(--panel);border:1px solid rgba(98,91,79,.2);border-radius:12px;box-shadow:0 12px 30px #111d1f2e;max-width:none;height:auto}.draw-canvas{position:absolute;top:0;left:0;pointer-events:none;border-radius:12px}.draw-canvas.draw-active{pointer-events:auto;cursor:crosshair}.canvas-grid.spread{justify-content:flex-start;min-width:max-content}.render-state{position:absolute;left:50%;bottom:1rem;z-index:3;transform:translate(-50%);margin:0;padding:.45rem .8rem;border-radius:999px;background:color-mix(in oklab,var(--panel),var(--bg) 20%);color:var(--text);box-shadow:0 8px 18px #0b1c221f;font-size:.9rem}.render-state.loading{display:inline-flex;align-items:center;justify-content:center;min-width:2.1rem;min-height:2.1rem;padding:.35rem}.render-spinner{width:1.05rem;height:1.05rem;border-radius:999px;border:2px solid color-mix(in oklab,var(--line),transparent 30%);border-top-color:var(--text);animation:viewer-spinner-rotate .75s linear infinite}@keyframes viewer-spinner-rotate{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){.render-spinner{animation-duration:1.8s}}.viewer-side-nav{position:fixed;top:50%;transform:translateY(-50%);z-index:7;width:3rem;height:3rem;min-width:0;min-height:0;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0;color:var(--control-text);background:color-mix(in oklab,var(--panel),var(--bg) 20%);border:1px solid color-mix(in oklab,var(--line),var(--bg) 14%);box-shadow:0 6px 20px #0715192e;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.app-shell.viewer-route:has(.sheet-viewer.overlays-hidden) .topbar{opacity:0;pointer-events:none}.viewer-side-nav--prev{left:max(.75rem,env(safe-area-inset-left))}.viewer-side-nav--next{right:max(.75rem,env(safe-area-inset-right))}.viewer-side-nav:disabled{opacity:.38;cursor:not-allowed;pointer-events:none}.viewer-pages-nav{position:fixed;right:max(.5rem,env(safe-area-inset-right));left:auto;top:50%;transform:translateY(-50%);z-index:8;display:flex;flex-direction:column;gap:.4rem;padding:.5rem 0;width:2.8rem;max-height:80vh;overflow-y:auto;overflow-x:hidden;pointer-events:auto}.viewer-pages-nav-btn{min-width:2.2rem;width:2.2rem;height:2.2rem;padding:0;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600;color:var(--control-text);background:color-mix(in oklab,var(--panel),var(--bg) 8%);border:1px solid color-mix(in oklab,var(--line),var(--bg) 10%);cursor:pointer;transition:all .12s ease-out}.viewer-pages-nav-btn:hover{background:color-mix(in oklab,var(--panel),var(--bg) 16%);border-color:color-mix(in oklab,var(--line),var(--bg) 25%)}.viewer-pages-nav-btn.active{background:var(--viewer-page-active-bg);color:var(--viewer-page-active-text);border-color:var(--viewer-page-active-border);font-weight:700;box-shadow:0 0 0 2px var(--viewer-page-active-ring)}.viewer-pages-nav-btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.viewer-pen-fab{position:fixed;right:max(.8rem,env(safe-area-inset-right));bottom:max(.85rem,env(safe-area-inset-bottom));z-index:9;width:3.4rem;height:3.4rem;min-width:0;min-height:0;padding:0;border-radius:999px;display:flex;align-items:center;justify-content:center;color:var(--control-text);box-shadow:0 12px 28px #07151938}.viewer-nav-mode-fab{position:fixed;left:max(.8rem,env(safe-area-inset-left));bottom:max(.85rem,env(safe-area-inset-bottom));z-index:9;width:3.4rem;height:3.4rem;min-width:0;min-height:0;padding:0;border-radius:999px;display:flex;align-items:center;justify-content:center;color:var(--control-text);box-shadow:0 12px 28px #07151938}.viewer-nav-mode-fab.active,.viewer-pen-fab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.draw-controls{position:fixed;left:max(0rem,env(safe-area-inset-left));right:max(0rem,env(safe-area-inset-right));bottom:max(0rem,env(safe-area-inset-bottom));z-index:10;display:grid;justify-items:center;gap:.42rem;padding:0 .55rem;pointer-events:none}.draw-controls>*{pointer-events:auto}.draw-sheet-dock{width:min(20rem,calc(100vw - env(safe-area-inset-left) - env(safe-area-inset-right) - 1.1rem));min-height:2.8rem;display:flex;align-items:center;gap:.3rem;padding:.35rem;border-radius:14px 14px 0 0;border:1px solid color-mix(in oklab,var(--line),var(--bg) 12%);background:color-mix(in oklab,var(--panel),var(--bg) 14%);box-shadow:0 10px 24px #07151933;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:box-shadow .14s ease,border-color .14s ease,transform .14s ease}.draw-sheet-toggle,.draw-color-trigger,.draw-sheet-close{min-height:2.1rem;border-radius:999px;border:1px solid color-mix(in oklab,var(--line),var(--bg) 16%);background:color-mix(in oklab,var(--control-bg-strong),var(--panel) 48%);color:var(--control-text);font-weight:600;font-size:.8rem;display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:0 .72rem;transition:background .12s ease,border-color .12s ease,color .12s ease}.draw-sheet-toggle:hover,.draw-color-trigger:hover,.draw-sheet-close:hover{border-color:var(--accent);background:color-mix(in oklab,var(--accent),var(--panel) 85%)}.draw-sheet-toggle.active,.draw-color-trigger.active{border-color:var(--accent);background:color-mix(in oklab,var(--accent),var(--panel) 78%);color:color-mix(in oklab,var(--accent),var(--text) 18%)}.draw-sheet-toggle{margin-right:0}.draw-color-trigger{padding:0 .6rem}.draw-sheet-toggle-icon{width:1rem;height:1rem;flex:0 0 auto}.draw-color-chip{width:.95rem;height:.95rem;border-radius:999px;border:2px solid color-mix(in oklab,var(--line),var(--bg) 8%);background:var(--swatch);box-shadow:inset 0 0 0 1px #ffffff47}.draw-sheet-close{border-color:color-mix(in oklab,var(--line),var(--danger) 38%);color:color-mix(in oklab,var(--danger),var(--control-text) 35%);margin-left:auto}.draw-controls.is-expanded .draw-sheet-dock{box-shadow:0 8px 18px #07151929;transform:translateY(-1px)}.draw-color-picker-panel{width:min(20rem,calc(100vw - env(safe-area-inset-left) - env(safe-area-inset-right) - 1.1rem));display:grid;justify-items:center;padding:.6rem;border-radius:14px;border:1px solid color-mix(in oklab,var(--line),var(--bg) 12%);background:color-mix(in oklab,var(--panel),var(--bg) 14%);box-shadow:0 12px 24px #0715193d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:draw-panel-enter .14s ease-out}.draw-controls-body{width:min(24rem,calc(100vw - env(safe-area-inset-left) - env(safe-area-inset-right) - 1.1rem));display:grid;gap:.42rem;padding:.55rem;border-radius:14px;border:1px solid color-mix(in oklab,var(--line),var(--bg) 12%);background:color-mix(in oklab,var(--panel),var(--bg) 14%);box-shadow:0 12px 24px #0715193d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:draw-panel-enter .14s ease-out}@keyframes draw-panel-enter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.draw-controls-body,.draw-color-picker-panel{animation:none}.draw-sheet-dock,.draw-sheet-toggle,.draw-color-trigger,.draw-sheet-close{transition:none}}.draw-control-row{display:flex;width:100%;gap:.42rem;justify-content:center}.draw-tool-row{flex-direction:row;flex-wrap:nowrap;max-width:none;align-items:center}.draw-size-row{align-items:center;gap:.6rem;padding:.2rem .45rem;border-radius:999px;border:1px solid color-mix(in oklab,var(--line),var(--bg) 14%);background:color-mix(in oklab,var(--control-bg-strong),var(--panel) 45%)}.draw-size-label{display:inline-flex;align-items:center;gap:.35rem;font-size:.74rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--control-text)}.draw-size-value{display:inline-flex;align-items:center;justify-content:center;min-width:1.75rem;height:1.6rem;padding:0 .35rem;border-radius:999px;border:1px solid color-mix(in oklab,var(--line),var(--bg) 16%);background:color-mix(in oklab,var(--panel),var(--bg) 12%);font-family:IBM Plex Mono,monospace;font-size:.72rem;font-weight:700;letter-spacing:0;text-transform:none}.draw-size-slider{flex:1;min-width:7rem;accent-color:var(--accent)}.draw-action-row{padding:.35rem;border-radius:999px;border:1px solid color-mix(in oklab,var(--line),var(--bg) 14%);background:color-mix(in oklab,var(--control-bg-strong),var(--panel) 45%);box-shadow:0 8px 18px #07151929}.draw-ctrl-btn{width:2.7rem;height:2.7rem;min-width:0;min-height:0;padding:0;border-radius:999px;display:flex;align-items:center;justify-content:center;color:var(--control-text);border-color:color-mix(in oklab,var(--line),var(--bg) 12%);background:color-mix(in oklab,var(--control-bg-strong),var(--panel) 45%);box-shadow:0 6px 16px #07151929;transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease,background .14s ease,color .14s ease}.draw-ctrl-btn:disabled{opacity:.42;cursor:not-allowed;pointer-events:none}.draw-ctrl-btn.active{border-color:var(--accent);background:color-mix(in oklab,var(--accent),var(--panel) 14%);color:var(--viewer-page-active-text);font-weight:700;transform:translateY(-1px) scale(1.04);box-shadow:0 0 0 3px var(--viewer-page-active-ring),0 10px 22px #07151942}:root.dark .draw-ctrl-btn.active{color:#fff}.draw-ctrl-btn:focus-visible{outline:3px solid color-mix(in oklab,var(--accent),transparent 45%);outline-offset:2px}:root.dark .draw-ctrl-size{color:var(--text)}.draw-ctrl-color{width:2.3rem;height:2.3rem;border:2px solid color-mix(in oklab,var(--text),var(--panel) 60%);background-color:var(--swatch)}.draw-ctrl-color.active{outline:3px solid var(--accent);outline-offset:2px;background-color:var(--swatch);border-color:var(--accent)}.draw-ctrl-tool{width:2.7rem;min-width:2.7rem;padding:0}.draw-tool-icon{width:1.28rem;height:1.28rem;transition:transform .14s ease}.draw-tool-icon--pen .tool-accent{fill:#93c5fd;stroke:#1d4ed8}.draw-ctrl-tool.active .draw-tool-icon{transform:scale(1.1)}.draw-tool-icon--highlighter .tool-accent{fill:#facc15;stroke:#b45309}.draw-tool-icon--eraser .tool-accent{fill:#f9a8d4;stroke:#be185d}@media(max-width:1180px){.icon-button{width:2.5rem;min-width:2.5rem;height:2.5rem}}@media(max-width:860px){.app-shell{width:calc(100% - 1rem);padding-top:.4rem}.topbar{grid-template-columns:minmax(0,1fr) auto;gap:.45rem;padding:.5rem .7rem;border-radius:12px;top:.35rem}.topbar-nav{width:auto;justify-content:flex-end}.topbar-link{font-size:.92rem}.topbar-icon-link{width:2.1rem;min-width:2.1rem;height:2.1rem}.topbar-icon-link.theme-toggle{width:auto;min-width:2.1rem;min-height:2.1rem;height:auto;padding-inline:.62rem;gap:.38rem}.offline-pill{font-size:.82rem}.toast{right:.5rem;bottom:.7rem;min-width:calc(100vw - 1rem);max-width:calc(100vw - 1rem)}.pwa-update-banner{left:.5rem;bottom:.6rem;min-width:calc(100vw - 1rem);max-width:calc(100vw - 1rem)}.topbar-link.current{max-width:100%}.actions{width:auto;justify-content:flex-end}.actions button{flex:0 0 auto}.icon-button{width:2.2rem;min-width:2.2rem;height:2.2rem}.icon-button svg{width:1rem;height:1rem}.controls-toggle{display:none}.offline-actions-row{grid-template-columns:repeat(2,minmax(0,1fr))}.action-btn{min-height:2.35rem;font-size:.9rem}.action-btn span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pdf-stage{height:62vh;border-radius:16px}.viewer-shell-header{flex-direction:column}.viewer-status-cluster{width:100%;justify-content:space-between}.draw-controls{left:max(0rem,env(safe-area-inset-left));right:max(0rem,env(safe-area-inset-right));bottom:max(0rem,env(safe-area-inset-bottom));gap:.42rem;padding:0 .5rem}.draw-controls-body{padding:.35rem;border-radius:14px;gap:.35rem}.draw-sheet-dock,.draw-color-picker-panel,.draw-controls-body{width:min(19rem,calc(100vw - env(safe-area-inset-left) - env(safe-area-inset-right) - 1rem))}.viewer-reset-link{font-size:.78rem;min-height:2.1rem;padding:.25rem .62rem}.draw-control-row{gap:.35rem}.draw-ctrl-btn{width:2.8rem;height:2.8rem}.draw-ctrl-color,.draw-ctrl-size{width:2.35rem;height:2.35rem}}.topbar-logo{width:clamp(2.3rem,4.2vw,3rem);height:clamp(2.3rem,4.2vw,3rem);border-radius:12px;object-fit:cover;border:1px solid color-mix(in oklab,var(--line),var(--bg) 14%);box-shadow:0 8px 18px #07151929;flex:0 0 auto}.topbar-title{min-width:0}@media(max-width:480px){.draw-controls{left:max(0rem,env(safe-area-inset-left));right:max(0rem,env(safe-area-inset-right));bottom:max(0rem,env(safe-area-inset-bottom));gap:.36rem;padding:0 .35rem}.draw-sheet-dock,.draw-color-picker-panel,.draw-controls-body{width:min(18rem,calc(100vw - env(safe-area-inset-left) - env(safe-area-inset-right) - .7rem))}.topbar-main{gap:.55rem}.topbar-logo{width:2.1rem;height:2.1rem;border-radius:10px}.draw-control-row{gap:.3rem}.draw-ctrl-btn{width:2.7rem;height:2.7rem}.draw-ctrl-color,.draw-ctrl-size{width:2.2rem;height:2.2rem}}@media(min-width:861px){.sheet-viewer{padding-right:1rem;padding-bottom:1rem}.viewer-primary-bar{left:auto;right:1rem;bottom:1rem;width:min(28rem,calc(100vw - 8rem))}.viewer-landscape .pdf-stage{height:min(78vh,46rem)}}
