@font-face{font-family:DM Serif Display;font-style:italic;font-weight:400;font-display:swap;src:url(../media/26a0a19eb96a029d-s.f2d931fb.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Serif Display;font-style:italic;font-weight:400;font-display:swap;src:url(../media/fad69795a077455b-s.p.81e64049.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Serif Display Fallback;src:local(Times New Roman);ascent-override:94.37%;descent-override:30.51%;line-gap-override:0.0%;size-adjust:109.78%}.dm_serif_display_48fdf946-module__gn8dba__className{font-family:DM Serif Display,DM Serif Display Fallback;font-style:italic;font-weight:400}.dm_serif_display_48fdf946-module__gn8dba__variable{--font-dm-serif:"DM Serif Display","DM Serif Display Fallback"}
:root{--bg:#0a0a0f;--surface:#12121a;--surface2:#1a1a26;--border:#ffffff12;--border2:#ffffff21;--accent:#c084fc;--accent2:#f0abfc;--accent-glow:#c084fc4d;--acc-bg:#c084fc1a;--scan:#00b4d8;--scan-glow:#00b4d880;--scan-bg:#00b4d821;--group-scan:#00b4d8;--group-scan-glow:#00b4d880;--group-scan-bg:#00b4d81a;--text:#f1f0f5;--text-dim:#f1f0f573;--text-faint:#f1f0f533;--base-font:16px;--kana-font:18px}[data-fontsize=small]{--base-font:13px;--kana-font:15px}[data-fontsize=medium]{--base-font:16px;--kana-font:18px}[data-fontsize=large]{--base-font:20px;--kana-font:22px}[data-theme=light]{--bg:#f5f3f0;--surface:#fff;--surface2:#eeece8;--border:#00000014;--border2:#00000026;--accent:#7c3aed;--accent2:#6d28d9;--accent-glow:#7c3aed40;--acc-bg:#7c3aed14;--scan:#0096b7;--scan-glow:#0096b766;--scan-bg:#0096b71a;--group-scan:#0096b7;--group-scan-glow:#0096b766;--group-scan-bg:#0096b714;--text:#1a1714;--text-dim:#1a171480;--text-faint:#1a171447}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html,body{overscroll-behavior:none;background:var(--bg);height:100dvh;color:var(--text);font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif;transition:background .3s,color .3s;overflow:hidden}html{width:100%;position:fixed;top:0;left:0}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(at 20% 20%,#c084fc0d 0%,#0000 50%),radial-gradient(at 80% 80%,#60a5fa0a 0%,#0000 50%);position:fixed;inset:0}[data-theme=light] body:before{background:radial-gradient(at 20% 20%,#7c3aed0a 0%,#0000 50%),radial-gradient(at 80% 80%,#05966908 0%,#0000 50%)}.app{z-index:1;grid-template-rows:auto auto auto auto minmax(0,1fr);gap:5px;max-width:900px;height:100dvh;margin:0 auto;padding:6px 16px 4px;display:grid;position:relative;overflow:hidden}.header{justify-content:space-between;align-items:center;padding:2px 0;display:flex}.logo{font-family:var(--font-dm-serif),"DM Serif Display",serif;background:linear-gradient(135deg,var(--accent2),var(--accent));-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;background-clip:text;font-size:26px;font-style:italic}.header-right{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.btn-header{background:var(--surface);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;font-size:11px;font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif;white-space:nowrap;border-radius:20px;padding:5px 10px;transition:all .2s}.btn-header:hover{border-color:var(--accent);color:var(--accent)}.btn-header.scan-active{background:var(--group-scan-bg);border-color:var(--group-scan);color:var(--group-scan);font-weight:700}.btn-header.theme{padding:5px 8px;font-size:13px}.btn-header.caregiver-active{color:#fbbf24;background:#fbbf2426;border-color:#fbbf24;font-weight:700}.btn-header.touch-active{color:#a855f7;background:#a855f726;border-color:#a855f7;font-weight:700}.caregiver-badge{color:#fbbf24;background:#fbbf2426;border:1px solid #fbbf24;border-radius:12px;padding:2px 10px;font-size:11px;font-weight:700;animation:1.5s infinite pulse}.caregiver-mode .group-scanning,.caregiver-mode .item-scanning,.caregiver-mode .row-group-scanning{border-color:var(--border)!important;box-shadow:none!important;background:var(--surface)!important;transform:none!important}.scan-indicator{color:var(--text-dim);align-items:center;gap:6px;font-size:11px;display:flex}.scan-dot{background:var(--border2);border-radius:50%;width:6px;height:6px;transition:all .3s}.scan-dot.on{background:var(--group-scan);box-shadow:0 0 8px var(--group-scan-glow);animation:1.2s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.output-area{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:8px 16px;transition:border-color .3s,box-shadow .3s;position:relative;overflow:visible}.output-area:before{content:"";pointer-events:none;z-index:0;background:linear-gradient(135deg,#c084fc08,#0000);border-radius:16px;position:absolute;inset:0}.output-text,.ai-suggestions,.output-actions{z-index:1;position:relative}.output-area.group-scanning{border-color:var(--group-scan);box-shadow:0 0 20px var(--group-scan-glow),inset 0 0 20px #34d39908}.output-text{letter-spacing:.02em;min-height:26px;color:var(--text);word-break:break-all;font-size:20px;font-weight:300;line-height:1.3}.cursor{background:var(--accent);vertical-align:middle;width:2px;height:26px;margin-left:2px;animation:1s infinite blink;display:inline-block}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.output-actions{flex-wrap:wrap;gap:5px;margin-top:4px;display:flex}.btn-action{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;font-size:var(--base-font,12px);font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif;background:0 0;border-radius:20px;align-items:center;gap:6px;padding:4px 10px;transition:all .2s;display:flex}.btn-action:hover{border-color:var(--accent);color:var(--accent);background:var(--acc-bg)}.btn-action.primary{background:linear-gradient(135deg,var(--accent),#8b5cf6);color:#fff;box-shadow:0 4px 20px var(--accent-glow);border-color:#0000}.btn-action.primary:hover{box-shadow:0 6px 25px var(--accent-glow);transform:translateY(-1px)}.btn-action.item-scanning{background:var(--scan-bg);border-color:var(--scan);color:var(--scan);box-shadow:0 0 12px var(--scan-glow);transform:scale(1.05)}.btn-action.selected-flash{background:var(--acc-bg);border-color:var(--accent2);color:var(--accent2)}.btn-action.emergency{color:#ef4444;border-color:#ef44444d}.btn-action.emergency:hover{color:#ef4444;background:#ef44441a;border-color:#ef4444}.ai-suggestions{flex-wrap:wrap;gap:8px;margin-top:6px;display:flex}.suggestion-chip{background:var(--acc-bg);color:var(--accent2);cursor:pointer;font-size:12px;font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif;border:1px solid #c084fc33;border-radius:20px;padding:4px 12px;transition:all .2s}.suggestion-chip:hover{background:#c084fc33;transform:translateY(-1px)}.suggestion-chip.loading{opacity:.5;pointer-events:none}.emotion-bar{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-wrap:wrap;gap:4px;padding:3px 8px;transition:border-color .3s,box-shadow .3s;display:flex}.emotion-bar.group-scanning{border-color:var(--group-scan);box-shadow:0 0 20px var(--group-scan-glow)}.emotion-quick{background:var(--surface2);border:1px solid var(--border);cursor:pointer;font-size:17px;font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif;border-radius:10px;align-items:center;gap:5px;padding:3px 8px;transition:all .2s;display:flex}.emotion-quick span.ql{font-size:var(--base-font,10px);color:var(--text-dim)}.emotion-quick:hover{border-color:var(--border2);transform:translateY(-2px)}.history-toggle-btn{color:var(--accent);border-color:var(--accent)!important}.history-quick{border-color:var(--border2)}.history-quick .ql{color:var(--text)!important}.history-quick.item-scanning{background:var(--group-scan-bg)!important;border-color:var(--group-scan)!important;color:var(--group-scan)!important;box-shadow:0 0 12px var(--group-scan-glow)!important}.history-quick.item-scanning .ql{color:var(--group-scan)!important}.emotion-quick.item-scanning{background:var(--scan-bg);border-color:var(--scan);box-shadow:0 0 12px var(--scan-glow);transform:scale(1.05)}.tabs{background:var(--surface);border:1px solid var(--border);border-radius:14px;gap:4px;padding:4px;transition:border-color .3s,box-shadow .3s;display:flex}.tabs.group-scanning{border-color:var(--group-scan);box-shadow:0 0 20px var(--group-scan-glow)}.tab{color:var(--text-dim);cursor:pointer;font-size:12px;font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif;text-align:center;background:0 0;border:none;border-radius:10px;flex:1;padding:6px 10px;transition:all .2s}.tab.active{background:var(--surface2);color:var(--text);box-shadow:0 1px 8px #0003}.tab:hover:not(.active){color:var(--text)}.tab.item-scanning{box-shadow:0 0 12px var(--scan-glow);background:var(--scan-bg)!important;color:var(--scan)!important}.panel{display:none}.panel.active{scrollbar-width:thin;scrollbar-color:var(--border)transparent;flex-direction:column;min-height:0;max-height:100%;display:flex;overflow-y:auto}.panel.group-scanning{outline:2px solid var(--group-scan);outline-offset:-2px;box-shadow:0 0 20px var(--group-scan-glow);border-radius:14px}.phrase-list.group-scanning{outline:2px solid var(--group-scan);outline-offset:-2px;box-shadow:0 0 20px var(--group-scan-glow);border-radius:12px}.kana-rows-wrap{flex-direction:column;gap:2px;display:flex}.kana-row-group{border-radius:8px;flex-wrap:wrap;align-items:stretch;gap:6px;padding:1px 0;transition:all .2s;display:flex}.kana-row-actions{grid-template-columns:repeat(3,1fr);gap:3px;width:100%;padding-left:28px;display:grid}.row-label{color:var(--text-faint);flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:0;width:22px;font-size:11px;display:flex}.row-label-expandable{cursor:pointer}.row-label-expandable:hover{color:var(--accent)}.expand-indicator{font-size:8px;line-height:1;transition:transform .2s}.kana-row-group.expanded .expand-indicator{transform:rotate(90deg)}.kana-row-chars{flex:1;grid-template-columns:repeat(5,1fr);gap:3px;display:grid}.kana-extra{display:none}.kana-row-group.expanded .kana-extra.kana-row-actions{display:grid}.kana-row-group.expanded .kana-btn.kana-extra{justify-content:center;align-items:center;display:flex}.kana-row-action{color:var(--text-dim)!important;background:var(--surface2)!important;border-color:var(--border2)!important;font-size:11px!important}.kana-row-group.row-group-scanning{background:var(--group-scan-bg);box-shadow:0 0 12px var(--group-scan-glow);border-radius:8px}.kana-row-group.row-group-scanning .kana-btn:not(.empty){border-color:var(--group-scan);box-shadow:0 0 8px var(--group-scan-glow)}.kana-btn{background:var(--surface);border:1px solid var(--border);height:34px;color:var(--text);font-size:var(--kana-font,15px);font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif;cursor:pointer;border-radius:8px;transition:all .15s;position:relative;overflow:hidden}.kana-btn:hover{background:var(--surface2);border-color:#c084fc66;transform:translateY(-1px)}.kana-btn.item-scanning{background:var(--scan-bg);border-color:var(--scan);box-shadow:0 0 16px var(--scan-glow),inset 0 0 12px #a78bfa0d;transform:scale(1.05)}.kana-btn.selected-flash{background:var(--acc-bg);border-color:var(--accent2)}.kana-btn.empty{pointer-events:none;background:0 0;border-color:#0000}.special-keys{grid-template-columns:repeat(4,1fr);gap:3px;margin-top:3px;display:grid}.special-btn{background:var(--surface);border:1px solid var(--border);height:32px;color:var(--text-dim);font-size:12px;font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif;cursor:pointer;border-radius:10px;transition:all .15s}.special-btn:hover{color:var(--text);border-color:#c084fc4d}.special-btn.item-scanning{background:var(--scan-bg);border-color:var(--scan);box-shadow:0 0 12px var(--scan-glow)}.special-keys.row-group-scanning .special-btn{border-color:var(--group-scan);background:var(--group-scan-bg);box-shadow:0 0 8px var(--group-scan-glow)}.scan-controls{background:var(--surface);border:1px solid var(--border);border-radius:10px;align-items:center;gap:10px;margin-top:3px;padding:4px 12px;display:flex}.scan-controls label{color:var(--text-dim);white-space:nowrap;font-size:11px}.scan-controls .speed-labels{color:var(--text-faint);justify-content:space-between;font-size:9px;display:flex}.scan-controls .speed-wrap{flex-direction:column;flex:1;gap:1px;display:flex}.scan-controls input[type=range]{width:100%;accent-color:var(--accent);height:4px}.scan-controls span{color:var(--accent);text-align:right;min-width:30px;font-size:11px}.emotion-section{border:1px solid #0000;border-radius:12px;margin-bottom:4px;padding:2px;transition:all .2s}.emotion-section.group-scanning{border-color:var(--group-scan);box-shadow:0 0 16px var(--group-scan-glow)}.emotion-back{color:var(--text-dim)!important;background:var(--surface2)!important;border-color:var(--border2)!important}.emotion-grid{grid-template-columns:repeat(4,1fr);gap:6px;display:grid}.emotion-btn{background:var(--surface);border:1px solid var(--border);cursor:pointer;text-align:center;font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif;border-radius:14px;padding:8px 4px;transition:all .2s}.emotion-btn:hover{border-color:var(--border2);transform:translateY(-2px)}.emotion-btn .emoji{margin-bottom:3px;font-size:24px;display:block}.emotion-btn .label{font-size:var(--base-font,10px);color:var(--text-dim);font-weight:500;display:block}.emotion-btn.item-scanning{background:var(--scan-bg);border-color:var(--scan);box-shadow:0 0 14px var(--scan-glow);transform:scale(1.04)}.section-label{color:var(--text-faint);letter-spacing:.1em;text-transform:uppercase;margin-top:10px;margin-bottom:6px;font-size:10px}.section-label:first-child{margin-top:0}.phrase-list{flex-direction:column;gap:5px;margin-bottom:10px;display:flex}.phrase-item{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:12px;align-items:center;gap:10px;padding:10px 14px;transition:all .2s;display:flex}.phrase-item:hover{background:var(--surface2);border-color:#c084fc4d;transform:translate(3px)}.phrase-item.item-scanning{background:var(--scan-bg);border-color:var(--scan);box-shadow:0 0 14px var(--scan-glow)}.phrase-item .phrase-text{font-size:var(--base-font,14px);flex:1}.phrase-item .phrase-tag{color:var(--text-faint);background:#ffffff0d;border-radius:8px;padding:3px 8px;font-size:10px}.phrase-item .delete-btn{color:var(--text-faint);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:2px 6px;font-size:14px}.phrase-item .delete-btn:hover{color:#f87171;background:#f871711a}.phrase-item.phrase-fixed{opacity:.85;border-color:#ffffff0a}.phrase-item.phrase-fixed:hover{opacity:1}.add-phrase{gap:8px;margin-top:8px;display:flex}.add-phrase input{background:var(--surface);border:1px solid var(--border);color:var(--text);font-size:13px;font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif;border-radius:10px;outline:none;flex:1;padding:8px 14px;transition:border-color .2s}.add-phrase input:focus{border-color:#c084fc80}.add-phrase input::placeholder{color:var(--text-faint)}.add-phrase button{background:linear-gradient(135deg,var(--accent),#8b5cf6);color:#fff;cursor:pointer;font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif;border:none;border-radius:10px;padding:8px 16px;font-size:13px;transition:all .2s}.add-phrase button:hover{box-shadow:0 4px 15px var(--accent-glow);transform:translateY(-1px)}.settings-section{background:var(--surface);border:1px solid var(--border);border-radius:14px;margin-bottom:10px;padding:14px}.settings-section.group-scanning{border-color:var(--group-scan);box-shadow:0 0 20px var(--group-scan-glow)}.settings-title{color:var(--text-dim);letter-spacing:.08em;margin-bottom:12px;font-size:12px;font-weight:500}.setting-row{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.setting-row:last-child{margin-bottom:0}.setting-label{color:var(--text);font-size:13px}.setting-sub{color:var(--text-faint);margin-top:2px;font-size:10px}.setting-row input[type=range]{width:120px;accent-color:var(--accent)}.setting-row select{background:var(--surface2);border:1px solid var(--border);color:var(--text);font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif;border-radius:8px;outline:none;padding:6px 10px;font-size:12px}.setting-val{color:var(--accent);text-align:right;min-width:30px;font-size:11px}.setting-controls{align-items:center;gap:6px;display:flex}.setting-btn{background:var(--surface2);border:1px solid var(--border);width:36px;height:32px;color:var(--text);cursor:pointer;font-size:14px;font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif;border-radius:8px;justify-content:center;align-items:center;transition:all .15s;display:flex}.setting-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--acc-bg)}.setting-btn.item-scanning{background:var(--scan-bg);border-color:var(--scan);color:var(--scan);box-shadow:0 0 12px var(--scan-glow);transform:scale(1.1)}.setting-btn.selected-flash{background:var(--acc-bg);border-color:var(--accent2)}.setting-btn.active-setting{background:var(--acc-bg);border-color:var(--accent);color:var(--accent);font-weight:700}.setting-current{color:var(--accent);text-align:center;white-space:nowrap;text-overflow:ellipsis;min-width:50px;font-size:12px;overflow:hidden}.api-input-wrap{gap:8px;margin-top:8px;display:flex}.api-input-wrap input{background:var(--surface2);border:1px solid var(--border);color:var(--text);letter-spacing:.05em;border-radius:8px;outline:none;flex:1;padding:8px 12px;font-family:monospace;font-size:12px}.api-input-wrap input:focus{border-color:#c084fc80}.api-input-wrap button{background:var(--surface2);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;font-size:12px;font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif;border-radius:8px;padding:8px 14px;transition:all .2s}.api-input-wrap button:hover{border-color:var(--accent);color:var(--accent)}.badge-pro{color:#fff;letter-spacing:.05em;background:linear-gradient(135deg,#f59e0b,#f97316);border-radius:8px;margin-left:6px;padding:2px 7px;font-size:9px;font-weight:700}.panel-scroll{overflow:visible}.emergency-overlay{z-index:10000;background:#dc2626f2;flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.emergency-countdown,.emergency-alerting{color:#fff;text-align:center;flex-direction:column;align-items:center;gap:16px;display:flex}.emergency-icon{font-size:80px}.emergency-count{font-size:120px;font-weight:700;font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif}.emergency-msg{font-size:24px;font-weight:500;font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif}.emergency-cancel{opacity:.7;font-size:16px;font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif;margin-top:20px}.emergency-alert-text{font-size:32px;font-weight:700;font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif;animation:1s infinite pulse-text}.pulse-emergency{animation:.5s infinite pulse-text}@keyframes pulse-text{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.history-area{background:var(--surface);border:1px solid var(--border);scrollbar-width:thin;scrollbar-color:var(--border)transparent;border-radius:12px;max-height:120px;padding:6px 10px;transition:border-color .3s,box-shadow .3s;overflow-y:auto}.history-area.group-scanning{border-color:var(--group-scan);box-shadow:0 0 20px var(--group-scan-glow)}.history-toggle{color:var(--text-dim);cursor:pointer;font-size:11px;font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif;background:0 0;border:none;padding:2px 4px;transition:color .2s}.history-toggle:hover{color:var(--text)}.history-list{flex-direction:column;gap:3px;margin-top:4px;display:flex}.history-item{background:var(--surface2);border:1px solid var(--border);border-radius:8px;align-items:center;gap:8px;padding:4px 8px;transition:all .15s;display:flex}.history-item.item-scanning{background:var(--scan-bg);border-color:var(--scan);box-shadow:0 0 10px var(--scan-glow)}.history-text{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:12px;overflow:hidden}.history-resend{cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:14px;transition:transform .2s}.history-resend:hover{transform:scale(1.2)}.toast{background:var(--text);color:var(--bg);font-size:13px;font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif;opacity:0;pointer-events:none;z-index:999;white-space:nowrap;border-radius:20px;padding:8px 20px;transition:all .25s;position:fixed;bottom:24px;left:50%;transform:translate(-50%)translateY(10px);box-shadow:0 8px 30px #0006}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}.scan-hint{background:var(--group-scan-bg);border:1px solid var(--group-scan);color:var(--group-scan);font-size:11px;font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif;pointer-events:none;z-index:50;opacity:0;white-space:nowrap;border-radius:20px;padding:4px 16px;transition:opacity .3s;position:fixed;bottom:8px;left:50%;transform:translate(-50%)}.scan-hint.show{opacity:1}.offline-badge{color:#fbbf24;z-index:100;font-size:10px;font-weight:600;font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif;pointer-events:none;background:#fbbf2426;border:1px solid #fbbf24;border-radius:12px;padding:2px 12px;position:fixed;top:4px;left:50%;transform:translate(-50%)}@media (min-height:600px) and (orientation:landscape){html,body{height:100dvh;overflow:hidden}}@media (max-height:599px),(orientation:portrait){.app{height:100dvh;padding-bottom:8px;overflow:hidden}.tabs{flex-wrap:wrap}.tab{flex:none;padding:5px 8px;font-size:11px}.kana-row-group{gap:3px}.kana-row-chars{grid-template-columns:repeat(5,1fr);gap:2px}.kana-btn{height:30px;font-size:14px}.kana-row-action{white-space:nowrap;min-width:0!important;padding:2px 4px!important;font-size:9px!important}}.tutorial-overlay{z-index:9000;background:#000000d9;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:20px;display:flex;position:fixed;inset:0}.tutorial-card{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:20px;width:100%;max-width:420px;padding:32px 28px}.tutorial-card h2{color:var(--text);font-size:22px;font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif;margin-bottom:12px}.tutorial-card p{color:var(--text-dim);font-size:15px;line-height:1.6;font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif;margin-bottom:16px}.tutorial-card .tutorial-icon{margin-bottom:12px;font-size:48px;display:block}.tutorial-progress{justify-content:center;gap:6px;margin-bottom:16px;display:flex}.tutorial-progress .dot{background:var(--border2);border-radius:50%;width:8px;height:8px;transition:background .2s}.tutorial-progress .dot.active{background:var(--accent)}.tutorial-actions{justify-content:center;gap:10px;display:flex}.tutorial-btn{cursor:pointer;font-size:14px;font-weight:600;font-family:var(--font-zen-kaku),"Zen Kaku Gothic New",sans-serif;border:none;border-radius:12px;padding:10px 24px;transition:all .2s}.tutorial-btn.primary{background:linear-gradient(135deg,var(--accent),#8b5cf6);color:#fff;box-shadow:0 4px 15px var(--accent-glow)}.tutorial-btn.primary:hover{transform:translateY(-1px)}.tutorial-btn.secondary{background:var(--surface2);border:1px solid var(--border);color:var(--text-dim)}.tutorial-btn.secondary:hover{border-color:var(--accent);color:var(--accent)}.tutorial-highlight{z-index:9001;border-radius:14px;position:relative;box-shadow:0 0 0 4px var(--accent),0 0 20px var(--accent-glow)!important}
