:root{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background-color:#eef2f8;color:#111827;font-size:16px}#root{min-height:100vh}.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;font-family:Inter,Noto Sans JP,Hiragino Kaku Gothic ProN,Yu Gothic,Meiryo,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.auth-card{width:100%;max-width:380px;background-color:#fff;border:1px solid #d0d7e6;border-radius:14px;padding:2.5rem 2rem;text-align:center}.auth-title{margin:0 0 .3rem;font-size:1.4rem;color:#1f2937}.auth-subtitle{margin:0 0 1.5rem;color:#526075;font-size:.9rem}.auth-form{display:flex;flex-direction:column;gap:.75rem}.auth-input{width:100%;border:1px solid #c8d1e4;border-radius:10px;padding:.65rem .85rem;font:inherit;font-size:1rem;box-sizing:border-box}.auth-input:focus{outline:2px solid #8eacff;border-color:#6b92ff}.auth-button{border:none;border-radius:10px;padding:.65rem 1rem;background-color:#2c68ff;color:#fff;font-size:1rem;font-weight:600;cursor:pointer}.auth-button:disabled{background-color:#9db2ed;cursor:not-allowed}.auth-button:not(:disabled):hover{background-color:#1f56e6}.auth-error{margin:0;color:#b91c1c;font-size:.88rem}.auth-loading-text{margin:0;color:#526075;font-size:.95rem}.app-shell{min-height:100vh;display:grid;grid-template-columns:280px 1fr;gap:1rem;width:min(1320px,100%);margin:0 auto;padding:1rem;box-sizing:border-box;font-size:16px}.app-shell,.chat-panel,.chat-bubble,.chat-input-area textarea{font-family:Inter,Noto Sans JP,Hiragino Kaku Gothic ProN,Yu Gothic,Meiryo,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.left-panel{border:1px solid #d0d7e6;border-radius:14px;padding:1rem;background-color:#f8faff;color:#1f2937;display:flex;flex-direction:column;gap:.75rem;overflow:hidden}.sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.left-panel h1{margin:0;font-size:1rem}.left-panel p{margin:0;font-size:.88rem;color:#526075}.new-chat-sidebar-button{border:1px solid #d2daf1;background-color:#fff;color:#334155;border-radius:8px;padding:.32rem .55rem;font-size:.78rem;cursor:pointer}.sidebar-nav-link{display:block;text-align:center;padding:.5rem .7rem;background-color:#edf2ff;color:#2545a8;border:1px solid #cad7ff;border-radius:10px;font-size:.88rem;font-weight:500;text-decoration:none;transition:background-color .12s}.sidebar-nav-link:hover{background-color:#dce6ff}.conversation-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.4rem;padding-right:.2rem}.conversation-item{border:1px solid #d6deef;background-color:#fff;border-radius:10px;position:relative;padding:.32rem}.conversation-main{width:100%;border:none;background:transparent;text-align:left;cursor:pointer;border-radius:8px;padding:.4rem 2.9rem .4rem .4rem;display:flex;flex-direction:column;gap:.2rem}.conversation-item strong{font-size:.84rem;color:#18253a;font-weight:600}.conversation-item span{font-size:.78rem;color:#5d697d;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-item.active{border-color:#94b1ff;background-color:#edf3ff}.conversation-delete-button{position:absolute;top:.44rem;right:.44rem;border:1px solid #dfc6c6;color:#991b1b;background-color:#fff7f7;border-radius:999px;width:1.7rem;height:1.7rem;padding:0;display:inline-flex;align-items:center;justify-content:center;gap:.3rem;overflow:hidden;cursor:pointer;transition:width .12s ease-in-out,background-color .12s ease-in-out}.conversation-delete-x{font-size:.88rem;line-height:1}.conversation-delete-label{opacity:0;width:0;font-size:.68rem;white-space:nowrap;transition:opacity .12s ease-in-out}.conversation-delete-button:hover{width:4.8rem}.conversation-delete-button:hover{background-color:#ffe8e8}.conversation-delete-button:hover .conversation-delete-label{opacity:1;width:auto}.empty-conversations{padding:.7rem;background-color:#fff;border:1px dashed #ccd6eb;border-radius:10px;color:#68758a;font-size:.84rem}.chat-panel{border:1px solid #d0d7e6;border-radius:14px;background-color:#fff;display:grid;grid-template-rows:auto auto 1fr auto;min-height:calc(100vh - 2rem);overflow:hidden}.chat-header{border-bottom:1px solid #e6eaf3;display:flex;align-items:center;gap:.6rem;padding:.7rem 1rem;background:linear-gradient(to right,#f8faff,#fff)}.model-pill{background-color:#edf2ff;color:#2545a8;border:1px solid #cad7ff;border-radius:999px;font-size:.78rem;font-weight:500;padding:.25rem .7rem;letter-spacing:.01em}.reset-chat-button{margin-left:auto;border:1px solid #d2daf1;background-color:#fff;color:#334155;border-radius:8px;padding:.32rem .65rem;font-size:.78rem;font-weight:500;cursor:pointer;transition:background-color .12s,border-color .12s}.reset-chat-button:hover{background-color:#edf2ff;border-color:#b8c8f5}.model-selector-row{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-bottom:1px solid #eef1f7}.model-selector-row label{font-size:.86rem;color:#5f6c82}.model-selector-row select{border:1px solid #c8d2ea;border-radius:8px;padding:.28rem .42rem;background-color:#fff;font:inherit;font-size:.86rem}.chat-feed{overflow-y:auto;display:flex;flex-direction:column;gap:.8rem;padding:1.1rem;background-color:#f9fbff;font-size:1rem}.chat-bubble{max-width:min(84%,800px);padding:.8rem .95rem;border-radius:14px;line-height:1.6;white-space:pre-wrap;word-break:break-word}.chat-bubble.user{margin-left:auto;background-color:#2c68ff;color:#fff;border-bottom-right-radius:6px}.chat-bubble.assistant{margin-right:auto;background-color:#fff;color:#111827;border:1px solid #d8deea;border-bottom-left-radius:6px}.typing-indicator{display:inline-flex;align-items:center;gap:.25rem}.typing-indicator i{width:6px;height:6px;background-color:#6b7280;border-radius:999px;display:inline-block;animation:pulse 1s infinite ease-in-out}.typing-indicator i:nth-child(2){animation-delay:.16s}.typing-indicator i:nth-child(3){animation-delay:.32s}@keyframes pulse{0%,to{opacity:.35}50%{opacity:1}}.message-text{display:block;font-size:1rem;line-height:1.6}.assistant-markdown{display:block}.assistant-markdown p{margin:0 0 .7rem}.assistant-markdown p:last-child{margin-bottom:0}.assistant-markdown ul,.assistant-markdown ol{margin:.2rem 0 .8rem 1.2rem;padding:0}.assistant-markdown li{margin:.15rem 0}.assistant-markdown strong{font-weight:700}.assistant-markdown code{background-color:#eef2ff;border-radius:6px;padding:.08rem .34rem;font-size:.9em}.kanji-term{position:relative;cursor:help;text-decoration:underline dotted rgba(59,130,246,.55);text-underline-offset:2px;border-radius:4px;padding:0 2px;transition:background-color .12s ease-in-out,color .12s ease-in-out}.kanji-term:after{content:attr(data-reading);position:absolute;left:50%;bottom:calc(100% + 8px);transform:translate(-50%);padding:.18rem .4rem;border-radius:6px;background-color:#111827;color:#f9fafb;font-size:.74rem;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .12s ease-in-out;z-index:10}.kanji-term:hover:after{opacity:1}.kanji-term:hover{background-color:#dbeafe;color:#1d4ed8}.chat-input-area{border-top:1px solid #e6eaf3;padding:.75rem 1rem 1rem;background-color:#fff}.chat-input-area textarea{width:100%;resize:none;border:1px solid #c8d1e4;border-radius:12px;padding:.7rem .85rem;font:inherit;font-size:1rem;line-height:1.45;box-sizing:border-box}.chat-input-area textarea:focus{outline:2px solid #8eacff;border-color:#6b92ff}.input-actions{margin-top:.55rem;display:flex;justify-content:space-between;align-items:center}.input-actions small{color:#64748b}.input-actions button{border:none;border-radius:10px;padding:.56rem .9rem;background-color:#2c68ff;color:#fff;font-weight:600;cursor:pointer}.input-actions button:disabled{background-color:#9db2ed;cursor:not-allowed}.error-text{margin:0 0 .5rem;color:#b91c1c;font-size:.88rem}.sidebar-toggle-button{display:none;border:none;background:transparent;color:#334155;cursor:pointer;padding:.25rem;border-radius:6px}.sidebar-toggle-button:hover{background-color:#f0f4ff}.sidebar-close-button{display:none;border:none;background:transparent;color:#64748b;font-size:1.5rem;line-height:1;cursor:pointer;padding:.15rem .4rem;border-radius:6px}.sidebar-close-button:hover{background-color:#e8ecf4;color:#1f2937}.sidebar-header-actions{display:flex;align-items:center;gap:.4rem}.sidebar-backdrop{display:none}@media(max-width:980px){.app-shell{grid-template-columns:1fr;width:100%}.left-panel{display:none;position:fixed;top:0;left:0;bottom:0;width:min(300px,85vw);z-index:100;border-radius:0 14px 14px 0;box-shadow:4px 0 24px #0000002e;transform:translate(-100%);transition:transform .25s ease-in-out}.left-panel.open{display:flex;transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;inset:0;background-color:#00000059;z-index:99}.sidebar-toggle-button,.sidebar-close-button{display:inline-flex}}.kana-page{min-height:100vh;width:min(1100px,100%);margin:0 auto;padding:1rem;box-sizing:border-box;font-family:Inter,Noto Sans JP,Hiragino Kaku Gothic ProN,Yu Gothic,Meiryo,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.kana-top-bar{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.kana-back-link{color:#2c68ff;text-decoration:none;font-size:.9rem;font-weight:500;padding:.35rem .7rem;border:1px solid #cad7ff;border-radius:8px;background-color:#f5f8ff;transition:background-color .12s;white-space:nowrap}.kana-back-link:hover{background-color:#e4ecff}.kana-page-title{margin:0;font-size:1.3rem;color:#1f2937;flex:1;text-align:center}.kana-spacer{width:110px}.kana-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;justify-content:center}.kana-tab{border:1px solid #d0d7e6;background-color:#fff;color:#526075;border-radius:10px;padding:.55rem 1.4rem;font-size:.95rem;font-weight:500;cursor:pointer;transition:background-color .12s,color .12s,border-color .12s;font-family:inherit}.kana-tab:hover{background-color:#f0f4ff}.kana-tab.active{background-color:#2c68ff;color:#fff;border-color:#2c68ff}.kana-content{display:flex;flex-direction:column;gap:2rem;padding-bottom:2rem}.kana-section h2{font-size:1.05rem;color:#1f2937;margin:0 0 .75rem;padding-bottom:.4rem;border-bottom:1px solid #e6eaf3}.kana-grid{display:flex;flex-direction:column;gap:2px}.kana-grid-header,.kana-grid-row{display:grid;gap:2px}.basic-grid .kana-grid-header,.basic-grid .kana-grid-row{grid-template-columns:48px repeat(5,1fr)}.combo-grid .kana-grid-header,.combo-grid .kana-grid-row{grid-template-columns:48px repeat(3,1fr)}.kana-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.5rem .25rem;border-radius:8px;min-height:56px;transition:background-color .12s,transform .12s}.kana-cell.filled{background-color:#fff;border:1px solid #dfe4ee;cursor:default}.kana-cell.filled:hover{background-color:#edf2ff;transform:scale(1.06);border-color:#94b1ff;z-index:1}.kana-cell.empty{background-color:transparent}.header-cell{font-size:.78rem;font-weight:600;color:#6b7fa0;text-transform:uppercase;letter-spacing:.05em;min-height:28px;background-color:transparent}.row-label{font-size:.78rem;font-weight:600;color:#6b7fa0;min-height:56px;background-color:transparent}.kana-char{font-size:1.5rem;line-height:1;color:#111827}.kana-romaji{font-size:.72rem;color:#6b7fa0;margin-top:.2rem}@media(max-width:640px){.kana-page{padding:.5rem}.kana-page-title{font-size:1.1rem}.kana-spacer{display:none}.kana-cell{min-height:48px;padding:.35rem .15rem}.kana-char{font-size:1.2rem}.kana-romaji{font-size:.65rem}.basic-grid .kana-grid-header,.basic-grid .kana-grid-row{grid-template-columns:36px repeat(5,1fr)}.combo-grid .kana-grid-header,.combo-grid .kana-grid-row{grid-template-columns:36px repeat(3,1fr)}.row-label,.header-cell{font-size:.68rem}}
