@import"https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Inter+Tight:wght@400;600;700;800&family=Inter:wght@400;500;600;700&display=swap";.kohola-app{min-height:100vh;position:relative;overflow-x:hidden;background-color:var(--kohola-page-bg);color:var(--kohola-text);font-family:Inter,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.kohola-auth-overlay{position:fixed;inset:0;z-index:150;display:flex;align-items:center;justify-content:center;background:#000000b3;backdrop-filter:blur(16px)}.kohola-auth-panel{max-width:390px;width:min(92vw,390px);margin-bottom:0;background:#1e1e1ef2;border-radius:16px;padding:32px 24px}.kohola-auth-wordmark{font-family:Inter Tight,system-ui,sans-serif;font-size:1.5rem;font-weight:800;color:#ffffffe6;letter-spacing:-.03em;margin-bottom:4px}.kohola-auth-tagline{font-size:.85rem;color:#ffffff4d;margin-bottom:24px}.kohola-auth-tabs{display:flex;gap:4px;background:#ffffff0a;border-radius:10px;padding:3px;margin-bottom:20px}.kohola-auth-tab{flex:1;border:none;background:transparent;padding:8px 0;border-radius:8px;font-size:.9rem;font-weight:600;color:#ffffff59;cursor:pointer;transition:all .2s}.kohola-auth-tab.active{background:#ffffff14;color:#ffffffd9}.kohola-auth-form{display:flex;flex-direction:column;gap:12px}.kohola-auth-label{font-size:.75rem;font-weight:600;color:#ffffff59;text-transform:uppercase;letter-spacing:.06em}.kohola-auth-submit{margin-top:6px}.kohola-auth-error{background:#ff505014;color:#ff5050b3;padding:12px;border-radius:10px;font-size:.85rem}.kohola-auth-banner{background:#ffb4320f;color:#ffb43299;padding:12px;border-radius:10px;font-size:.85rem;margin-bottom:16px}.kohola-auth-alert{background:#50b4ff0f;color:#50b4ff99;padding:12px;border-radius:10px;font-size:.85rem;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.kohola-auth-retry{padding:8px 14px;font-size:.8rem;box-shadow:none}.kohola-auth-guest{margin:18px auto 0;display:block;background:transparent;border:none;font-size:.8rem;color:#ffffff40;cursor:pointer}.kohola-auth-guest span{color:#50b4ff99}.kohola-field-hint{font-size:.75rem;color:#ff783299;margin-top:-6px}.kohola-navbar{position:fixed;top:0;left:0;right:0;z-index:100;background:var(--kohola-surface-strong);backdrop-filter:blur(20px)}.kohola-navbar-content{max-width:900px;margin:0 auto;padding:12px 16px;display:flex;align-items:center;gap:12px}.kohola-logo{font-family:Inter Tight,system-ui,sans-serif;font-size:1.125rem;font-weight:800;color:var(--kohola-text);letter-spacing:-.03em}.kohola-nav-buttons{display:flex;gap:4px;flex:1;justify-content:center;align-items:center}.kohola-nav-button{padding:6px 14px;background:transparent;border:none;border-radius:6px;font-size:.85rem;font-weight:500;color:var(--kohola-text-muted);cursor:pointer;transition:all .2s}.kohola-nav-button:hover{color:var(--kohola-text-secondary);background:var(--kohola-surface-input)}.kohola-nav-button.active{color:var(--kohola-text);background:var(--kohola-surface-input)}.kohola-navbar-actions{display:flex;justify-content:flex-end;min-width:36px}.kohola-avatar-menu{position:relative}.kohola-avatar-button{width:28px;height:28px;border-radius:4px;border:none;background:var(--kohola-accent-surface);color:var(--kohola-accent-muted);font-size:.7rem;font-weight:600;cursor:pointer;transition:background .2s}.kohola-avatar-button:hover{background:var(--kohola-accent-surface)}.kohola-avatar-dropdown{position:absolute;top:40px;right:0;background:var(--kohola-surface-strong);backdrop-filter:blur(20px);border-radius:10px;box-shadow:0 8px 32px #0006;border:1px solid var(--kohola-border-subtle);min-width:160px;overflow:hidden;z-index:20}.kohola-avatar-name{padding:10px 14px;font-size:.75rem;color:var(--kohola-text-faint);font-weight:600}.kohola-avatar-signout{width:100%;border:none;background:transparent;padding:10px 14px;font-size:.85rem;color:var(--kohola-error-muted);text-align:left;cursor:pointer;font-weight:500}.kohola-avatar-signout:hover{background:var(--kohola-error-surface)}.kohola-guest-signin{border:none;background:transparent;color:var(--kohola-accent-muted);font-size:.85rem;font-weight:600;cursor:pointer}.kohola-content{position:relative;z-index:10;padding:68px 16px 40px}.kohola-view-container{max-width:600px;margin:0 auto}.kohola-fetch-error-banner{background:var(--kohola-warning-surface);border-bottom:1px solid var(--kohola-border-subtle);padding:10px 16px;border-radius:8px;display:flex;align-items:center;gap:10px;margin:0 auto 16px;max-width:600px}.kohola-fetch-error-text{font-size:.8rem;color:var(--kohola-warning);flex:1}.kohola-fetch-error-dismiss{border:none;background:transparent;color:var(--kohola-text-muted);cursor:pointer;font-size:.8rem;padding:4px}.kohola-fetch-error-dismiss:hover{color:var(--kohola-text-secondary)}.kohola-account-sync-banner{background:var(--kohola-accent-surface-faint);color:var(--kohola-accent-muted);padding:10px 16px;border-radius:8px;font-size:.85rem;font-weight:500;margin:0 auto 16px;max-width:600px;text-align:center}.kohola-guest-seed-error{background:var(--kohola-error-surface);color:var(--kohola-error-muted);padding:10px 16px;border-radius:8px;font-size:.85rem;font-weight:500;margin:0 auto 16px;max-width:600px;text-align:center}.kohola-panel{background:var(--kohola-surface);border-radius:0;padding:24px 20px;margin-bottom:8px}.kohola-panel-centered{max-width:600px;margin:0 auto 8px}.kohola-panel-title{font-family:Inter,system-ui,sans-serif;font-size:1.25rem;font-weight:700;color:var(--kohola-text);margin:0 0 4px;letter-spacing:-.02em}.kohola-panel-subtitle{font-size:.85rem;color:var(--kohola-text-muted);margin:0 0 20px}.kohola-section-label{font-size:.625rem;font-weight:400;letter-spacing:.15em;color:var(--kohola-text-faint);text-transform:uppercase;padding:4px 0}.kohola-text-display{font-family:Playfair Display,Georgia,serif;font-size:1.125rem;line-height:2;color:var(--kohola-text-secondary);white-space:pre-wrap;margin:16px 0}.kohola-text-display.transliteration{font-family:Inter,sans-serif;font-size:.95rem;color:var(--kohola-text-muted);font-style:italic}.kohola-annotation-marker{display:inline;font-family:Inter,system-ui,sans-serif;font-size:.65em;vertical-align:super;color:var(--kohola-accent-muted);cursor:pointer;margin-left:1px;font-weight:700}.kohola-annotations{margin-top:24px;padding-top:16px;border-top:1px solid var(--kohola-border-subtle)}.kohola-annotation-item{font-size:.85rem;line-height:1.6;color:var(--kohola-text-muted);margin-bottom:12px}.kohola-annotation-number{display:inline-block;font-weight:700;color:var(--kohola-accent-muted);margin-right:8px;font-size:.8rem}.kohola-drawer-scrim{position:fixed;inset:0;background:#0006;z-index:200;opacity:0;pointer-events:none;transition:opacity .3s ease}.kohola-drawer-scrim.open{opacity:1;pointer-events:auto}.kohola-drawer{position:fixed;bottom:0;left:0;right:0;max-width:600px;margin:0 auto;background:var(--kohola-surface-strong);backdrop-filter:blur(20px);z-index:210;transform:translateY(100%);transition:transform .35s cubic-bezier(.32,.72,0,1);max-height:60vh;overflow-y:auto}.kohola-drawer.open{transform:translateY(0)}.kohola-drawer-handle{display:flex;justify-content:center;padding:10px}.kohola-drawer-handle-bar{width:36px;height:4px;background:var(--kohola-text-ghost);border-radius:2px}.kohola-drawer-item{padding:12px 24px;display:flex;flex-direction:column;gap:8px}.kohola-drawer-item-header{display:flex;align-items:center;gap:8px}.kohola-drawer-item-badge{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:var(--kohola-accent-surface);font-family:Inter,system-ui,sans-serif;font-size:.625rem;font-weight:700;color:var(--kohola-accent-muted)}.kohola-drawer-item-word{font-family:Playfair Display,Georgia,serif;font-size:.875rem;font-weight:600;font-style:italic;color:var(--kohola-text-secondary)}.kohola-drawer-item-note{font-size:.8125rem;color:var(--kohola-text-muted);line-height:1.7}.kohola-drawer-footer{padding:8px 24px 36px;text-align:center;font-size:.6875rem;color:var(--kohola-text-faint)}.kohola-list{display:flex;flex-direction:column;gap:4px}.kohola-list-item{background:var(--kohola-surface);padding:14px 16px;cursor:pointer;transition:background .2s;display:flex;align-items:center;gap:12px}.kohola-list-item:hover{background:var(--kohola-surface-strong)}.kohola-list-item.active{background:var(--kohola-accent-surface-faint)}.kohola-list-item-title{font-size:.8125rem;font-weight:500;color:var(--kohola-text-secondary);margin:0 0 2px}.kohola-list-item-meta{font-size:.625rem;color:var(--kohola-text-faint);display:flex;gap:6px;align-items:center}.kohola-mastery-dots{display:flex;align-items:center;gap:2px}.kohola-mastery-dot{width:6px;height:6px;border-radius:50%}.kohola-mastery-dot.filled{background:var(--kohola-accent)}.kohola-mastery-dot.half{background:var(--kohola-accent-muted)}.kohola-mastery-dot.empty{background:transparent;border:.6px solid var(--kohola-text-ghost)}.kohola-progress-bar{height:3px;background:var(--kohola-surface-input);border-radius:2px;overflow:hidden;margin:6px 0}.kohola-progress-fill{height:100%;background:var(--kohola-accent-muted);border-radius:2px;transition:width .3s ease}.kohola-button{padding:12px 24px;background:var(--kohola-accent-surface);color:var(--kohola-accent);border:none;border-radius:0;font-family:Inter,system-ui,sans-serif;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.kohola-button:hover{background:var(--kohola-accent-surface);filter:brightness(1.2)}.kohola-button:not(.kohola-button-secondary):active{background:var(--kohola-accent-surface);filter:brightness(.9)}.kohola-button-secondary{background:var(--kohola-surface-input);color:var(--kohola-text-muted)}.kohola-button-secondary:hover{background:var(--kohola-surface-input);filter:brightness(1.2)}.kohola-button-secondary:active{background:var(--kohola-surface-input);filter:brightness(.9)}.kohola-input{width:100%;padding:12px 16px;background:var(--kohola-surface-input);border:1px solid var(--kohola-border-subtle);border-radius:0;font-family:Inter,system-ui,sans-serif;font-size:.875rem;color:var(--kohola-text);transition:all .2s}.kohola-input:focus{outline:none;border-color:var(--kohola-accent-muted);background:var(--kohola-surface-input)}.kohola-input::placeholder{color:var(--kohola-text-faint)}.kohola-textarea{width:100%;min-height:200px;padding:16px;background:var(--kohola-surface-input);border:1px solid var(--kohola-border-subtle);border-radius:0;font-family:Playfair Display,Georgia,serif;font-size:1rem;line-height:2;color:var(--kohola-text-secondary);resize:vertical;transition:all .2s}.kohola-textarea:focus{outline:none;border-color:var(--kohola-accent-muted);background:var(--kohola-surface-input)}.kohola-textarea::placeholder{color:var(--kohola-text-faint)}.kohola-diff{font-family:JetBrains Mono,Consolas,monospace;font-size:.85rem;line-height:1.8;background:var(--kohola-surface-subtle);padding:16px;margin:16px 0}.kohola-diff-line{margin:4px 0}.kohola-diff-match{color:#50c878b3}.kohola-diff-mismatch{color:var(--kohola-error-muted);background:var(--kohola-error-surface);padding:2px 4px}.kohola-diff-typo{color:var(--kohola-warning);background:var(--kohola-warning-surface);padding:2px 4px}.kohola-tree{margin:16px 0}.kohola-tree-node{margin-left:20px;margin-bottom:4px}.kohola-tree-node-header{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--kohola-surface);cursor:pointer;transition:background .2s}.kohola-tree-node-header:hover{background:var(--kohola-surface-strong)}.kohola-tree-node-icon{font-size:.85rem;color:var(--kohola-text-faint)}.kohola-tree-node-name{flex:1;font-weight:500;font-size:.8125rem;color:var(--kohola-text-secondary)}.kohola-tree-node-status{font-size:.6875rem;padding:3px 8px;font-weight:600}.kohola-tree-node-status.mastered{background:#50c87814;color:#50c87899}.kohola-tree-node-status.in-progress{background:var(--kohola-warning-surface);color:var(--kohola-warning)}.kohola-tree-node-status.not-started{background:var(--kohola-surface-input);color:var(--kohola-text-faint)}.kohola-stats-row{display:flex;gap:8px}.kohola-stat-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 12px;background:var(--kohola-surface);flex:1}.kohola-stat-value{font-family:Inter Tight,system-ui,sans-serif;font-size:1.375rem;font-weight:700;color:var(--kohola-text-secondary)}.kohola-stat-value.accent{color:var(--kohola-accent-muted)}.kohola-stat-label{font-size:.5625rem;color:var(--kohola-text-faint)}.kohola-queue-item{display:flex;align-items:center;padding:14px 16px;gap:12px;background:var(--kohola-surface)}.kohola-queue-item.done{background:var(--kohola-surface-subtle)}.kohola-queue-item.current{background:var(--kohola-accent-surface-faint)}.kohola-queue-item-title{font-size:.8125rem;font-weight:500;color:var(--kohola-text-secondary)}.kohola-queue-item-title.done{color:var(--kohola-text-muted);text-decoration:line-through}.kohola-queue-item-meta{font-size:.625rem;color:var(--kohola-text-faint)}.kohola-fading-alert{display:flex;align-items:center;padding:14px 16px;gap:12px;background:var(--kohola-warning-surface)}.kohola-fading-alert-bar{width:4px;height:20px;background:var(--kohola-warning)}.kohola-fading-alert-title{font-size:.75rem;font-weight:500;color:var(--kohola-warning)}.kohola-fading-alert-subtitle{font-size:.625rem;color:var(--kohola-text-faint)}.kohola-settings-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--kohola-border-subtle)}.kohola-settings-label{flex:1;font-size:.8125rem;font-weight:500;color:var(--kohola-text-secondary)}.kohola-settings-value{font-size:.8125rem;color:var(--kohola-text-faint);text-align:right}@media(min-width:768px){.kohola-content{padding:80px 24px 40px}.kohola-panel{padding:32px 28px}}.kohola-loading{text-align:center;padding:40px;color:var(--kohola-text-muted);font-size:.9rem}.kohola-loading-overlay{position:fixed;inset:0;z-index:140;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000000b3;backdrop-filter:blur(10px);gap:12px}.kohola-loading-wordmark{font-family:Inter Tight,system-ui,sans-serif;font-size:1.5rem;font-weight:800;color:#ffffffe6;letter-spacing:-.03em}.kohola-loading-message{font-size:.85rem;color:#ffffff4d}.kohola-spinner{width:24px;height:24px;border-radius:50%;border:2px solid var(--kohola-text-ghost);border-top-color:var(--kohola-accent-muted);animation:spin 1s linear infinite}.kohola-error{background:var(--kohola-error-surface);color:var(--kohola-error-muted);padding:14px 16px;font-size:.85rem;margin:8px 0}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}@keyframes spin{to{transform:rotate(360deg)}}.recite-reveal-container{font-family:Playfair Display,Georgia,serif;font-size:1.125rem;line-height:2;white-space:pre-wrap}.recite-word{display:inline;transition:opacity .4s ease,text-shadow .6s ease;cursor:default}.recite-word--hidden{opacity:.06;color:var(--kohola-text-muted)}.recite-word--interim{opacity:.4;color:var(--kohola-text-secondary);text-shadow:0 0 8px rgba(80,180,255,.15)}.recite-word--revealed{opacity:.85;color:var(--kohola-text)}.recite-word--just-revealed{text-shadow:0 0 20px rgba(80,180,255,.3)}.recite-word--hinted{animation:hintPulse 2s ease-in-out forwards}@keyframes hintPulse{0%{opacity:.06;text-shadow:none}20%{opacity:.5;text-shadow:0 0 15px rgba(80,180,255,.25)}70%{opacity:.5;text-shadow:0 0 15px rgba(80,180,255,.25)}to{opacity:.06;text-shadow:none}}.recite-mic-indicator{display:flex;align-items:center;gap:6px;padding:6px 12px;font-size:.75rem;font-weight:600}.recite-mic-dot{width:6px;height:6px;border-radius:999px;flex-shrink:0}.recite-mic-indicator--connecting{background:var(--kohola-accent-surface-faint);color:var(--kohola-accent-muted);animation:micPulse 2s ease-in-out infinite}.recite-mic-indicator--active{background:var(--kohola-accent-surface);color:var(--kohola-accent-strong);animation:micPulse 1s ease-in-out infinite}.recite-mic-indicator--idle{background:var(--kohola-surface-input);color:var(--kohola-text-muted)}.recite-mic-indicator--error{background:var(--kohola-error-surface);color:var(--kohola-error-muted)}.recite-mic-nudge{font-size:11px;color:var(--kohola-text-muted);text-align:right}.recite-mic-error-msg{font-size:11px;color:var(--kohola-error-muted);text-align:right}@keyframes micPulse{0%,to{box-shadow:0 0 #50b4ff26}50%{box-shadow:0 0 0 6px #50b4ff00}}.recite-progress{height:2px;background:var(--kohola-surface-input);overflow:hidden;margin:6px 0}.recite-progress-fill{height:100%;background:var(--kohola-accent-muted);transition:width .4s ease}.recite-hint-panel{background:var(--kohola-accent-surface-faint);padding:14px 16px;margin-top:12px;border-left:2px solid var(--kohola-accent-surface)}.recite-hint-label{font-size:.625rem;text-transform:uppercase;letter-spacing:.12em;color:var(--kohola-text-faint);font-weight:400;margin-bottom:4px}.recite-hint-word{font-family:Playfair Display,Georgia,serif;font-size:1.25rem;font-weight:600;color:var(--kohola-accent-muted)}.recite-complete{text-align:center;padding:24px}.recite-complete-title{font-family:Playfair Display,Georgia,serif;font-size:1.5rem;font-weight:600;color:#50c878b3;margin-bottom:8px}.recite-complete-stats{font-size:.85rem;color:var(--kohola-text-muted)}.recite-actions{display:flex;gap:8px;margin-top:16px}.recite-actions .kohola-button{flex:1}.kohola-greeting-header{display:flex;flex-direction:column;gap:4px;padding:24px 24px 16px}.kohola-greeting-title{color:var(--kohola-text);font-family:Playfair Display,system-ui,sans-serif;font-size:26px;font-weight:600;line-height:32px}.kohola-greeting-date{color:var(--kohola-text-faint);font-family:Inter,system-ui,sans-serif;font-size:12px;line-height:16px}.kohola-mode-shortcut{display:flex;align-items:center;background-color:var(--kohola-surface-strong);cursor:pointer;flex:1;gap:8px;padding:14px 16px}.kohola-mode-shortcut-bar{flex-shrink:0;height:24px;width:4px}.kohola-section-header-row{display:flex;align-items:center;gap:8px;padding-bottom:4px}.kohola-nav-dropdown{background-color:var(--kohola-surface-strong);border-radius:8px;box-shadow:0 8px 32px #00000080;display:flex;flex-direction:column;left:0;min-width:180px;overflow:hidden;position:absolute;top:100%;margin-top:8px;z-index:100}.kohola-nav-dropdown-item{display:flex;align-items:center;background:none;border:none;color:var(--kohola-text-muted);cursor:pointer;font-family:Inter,system-ui,sans-serif;font-size:14px;font-weight:400;gap:10px;padding:12px 16px;text-align:left;transition:background-color .15s;width:100%}.kohola-nav-dropdown-item:hover{background-color:#ffffff0a}.kohola-nav-dropdown-item--active{background:#ffffff14;color:var(--kohola-text);font-weight:600}
