:root{--text: #1a2b3c;--text-muted: #5a6b7c;--bg: #f7f9fc;--surface: #ffffff;--border: #d8e0ea;--accent: #2563eb;--accent-hover: #1d4ed8;--info-bg: #eff6ff;--info-border: #bfdbfe;--error-bg: #fef2f2;--error-border: #fecaca;--error-text: #b91c1c;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color:var(--text);background-color:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100svh}#root{min-height:100svh}.app{max-width:480px;margin:0 auto;padding:1.5rem 1.25rem 2.5rem;min-height:100svh;display:flex;flex-direction:column;gap:1.5rem}.app__header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;margin-bottom:.5rem}.app__header h1{margin:0;font-size:1.75rem;font-weight:700;letter-spacing:-.02em}.app__profile-button{flex-shrink:0;min-height:36px;padding:.35rem .65rem;font-size:.8rem;font-weight:600;color:var(--text-muted);background:var(--surface);border:1px solid var(--border);border-radius:999px;cursor:pointer;touch-action:manipulation}.app__profile-button:hover{background:var(--bg)}.app__tagline{margin:0;color:var(--text-muted);font-size:1.05rem}.app__info{background:var(--info-bg);border:1px solid var(--info-border);border-radius:12px;padding:1rem 1.1rem}.app__info p{margin:0;font-size:.95rem;color:var(--text-muted)}.app__scan{display:flex;flex-direction:column;align-items:center;gap:1rem}.app__file-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.app__button{width:100%;max-width:320px;min-height:56px;padding:.875rem 1.5rem;font-size:1.125rem;font-weight:600;color:#fff;background:var(--accent);border:none;border-radius:14px;cursor:pointer;touch-action:manipulation;transition:background-color .15s ease}.app__button:not(:disabled):hover{background:var(--accent-hover)}.app__button:disabled{opacity:.55;cursor:not-allowed}.app__button--secondary{color:var(--text);background:var(--surface);border:1px solid var(--border)}.app__button--secondary:not(:disabled):hover{background:var(--bg)}.app__preview{width:100%;display:flex;flex-direction:column;gap:1rem}.app__preview-image{width:100%;max-height:320px;object-fit:contain;border-radius:12px;border:1px solid var(--border);background:var(--surface)}.app__actions,.app__result-actions{display:flex;flex-direction:column;align-items:center;gap:.75rem;width:100%}.app__part-status{margin:0;padding:.75rem .875rem;font-size:.92rem;color:var(--text-muted);background:var(--info-bg);border:1px solid var(--info-border);border-radius:10px;line-height:1.5}.session-history{display:flex;flex-direction:column;gap:.75rem;padding:1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:14px}.session-history__header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.session-history__title{margin:0;font-size:1.1rem;font-weight:600}.session-history__clear{border:none;background:none;padding:0;font:inherit;font-size:.85rem;font-weight:600;color:var(--text-muted);cursor:pointer;text-decoration:underline}.session-history__intro,.session-history__empty{margin:0;font-size:.92rem;color:var(--text-muted);line-height:1.5}.session-history__list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.5rem}.session-history__item{display:flex;gap:.35rem;align-items:stretch}.session-history__open{flex:1;display:flex;flex-direction:column;align-items:flex-start;gap:.2rem;padding:.75rem .875rem;font:inherit;text-align:left;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:12px;cursor:pointer}.session-history__open--active{border-color:var(--accent);background:var(--info-bg)}.session-history__label{font-size:.92rem;font-weight:600}.session-history__meta{font-size:.8rem;color:var(--text-muted)}.session-history__summary{font-size:.85rem;color:var(--text-muted);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.session-history__remove{flex-shrink:0;width:36px;min-height:36px;align-self:center;font-size:1.25rem;line-height:1;color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:8px;cursor:pointer}.read-support{display:flex;flex-direction:column;gap:.75rem}.read-support h2{margin:0}.read-support__intro,.read-support__part{margin:0;font-size:.92rem;color:var(--text-muted);line-height:1.5}.read-support__list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.75rem}.read-support__item{padding:1rem;background:var(--bg);border:1px solid var(--border);border-radius:12px;display:flex;flex-direction:column;gap:.65rem}.read-support__no,.read-support__native{margin:0;font-size:.95rem;line-height:1.55}.read-support__native{color:var(--text-muted);padding-top:.65rem;border-top:1px solid var(--border)}.read-support__flag{margin-right:.35rem}.read-support__lang{display:block;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;margin-bottom:.25rem;color:var(--text-muted)}.app__status{margin:0;text-align:center;color:var(--text-muted);font-size:.95rem}.app__error{margin:0;padding:.875rem 1rem;background:var(--error-bg);border:1px solid var(--error-border);border-radius:12px;color:var(--error-text);font-size:.95rem}.app__result{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:1.25rem;display:flex;flex-direction:column;gap:.75rem}.app__result h2{margin:.5rem 0 0;font-size:1.1rem;font-weight:600}.app__result h2:first-child{margin-top:0}.app__summary{margin:0;color:var(--text)}.app__keywords{margin:0;padding:0;list-style:none;display:flex;flex-wrap:wrap;gap:.5rem}.app__keywords li{background:var(--info-bg);border:1px solid var(--info-border);border-radius:999px;padding:.25rem .75rem;font-size:.9rem}.app__questions{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:1rem}.learning-results__intro{margin:0 0 .5rem;font-size:.95rem;color:var(--text-muted)}.learning-results__mode-intro{margin:0;font-size:.92rem;color:var(--text-muted);line-height:1.5}.learning-results__subheading{margin:.75rem 0 0;font-size:1rem;font-weight:600}.learning-results__empty{margin:0;padding:1rem;font-size:.95rem;color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:12px}.learning-results__panel{display:flex;flex-direction:column;gap:.75rem}.view-mode-picker{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;width:100%}@media(min-width:420px){.view-mode-picker{grid-template-columns:repeat(3,1fr)}}.view-mode-picker__button{display:flex;flex-direction:column;align-items:flex-start;gap:.15rem;min-height:56px;padding:.625rem .75rem;font:inherit;text-align:left;color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:12px;cursor:pointer;touch-action:manipulation;transition:background-color .15s ease,border-color .15s ease,color .15s ease}.view-mode-picker__button--active{color:#fff;background:var(--accent);border-color:var(--accent)}.view-mode-picker__label{font-size:.95rem;font-weight:600}.view-mode-picker__hint{font-size:.78rem;line-height:1.3;opacity:.9}.view-mode-picker__button:not(.view-mode-picker__button--active) .view-mode-picker__hint{opacity:.85}.question-card{display:flex;flex-direction:column;gap:.75rem;padding:1rem;border:1px solid var(--border);border-radius:12px;background:var(--bg)}.question-card__number{margin:0;font-size:.85rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.question-card__question{margin:0;font-weight:500}.question-card__toggle{width:100%;min-height:44px;padding:.625rem 1rem;font-size:1rem;font-weight:600;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:10px;cursor:pointer;touch-action:manipulation;transition:background-color .15s ease}.question-card__toggle:hover{background:var(--bg)}.question-card__answer{margin:0;padding:.75rem .875rem;font-size:.95rem;color:var(--text-muted);background:var(--info-bg);border:1px solid var(--info-border);border-radius:8px}.question-card__answer strong{color:var(--text)}.source-limit-banner{width:100%;padding:1rem 1.1rem;background:var(--info-bg);border:1px solid var(--info-border);border-radius:12px}.source-limit-banner p{margin:0;font-size:.92rem;color:var(--text-muted);line-height:1.55}.source-gallery{width:100%;display:flex;flex-direction:column;gap:.75rem}.source-gallery__count{margin:0;font-size:.9rem;font-weight:600;color:var(--text-muted)}.source-gallery__list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.75rem}.source-gallery__item{display:flex;gap:.75rem;padding:.75rem;background:var(--surface);border:1px solid var(--border);border-radius:12px}.source-gallery__thumb{width:72px;height:72px;object-fit:cover;border-radius:8px;border:1px solid var(--border);flex-shrink:0}.source-gallery__meta{flex:1;display:flex;flex-direction:column;justify-content:space-between;gap:.5rem;min-width:0}.source-gallery__label{font-size:.9rem;font-weight:600}.source-gallery__controls{display:flex;flex-wrap:wrap;gap:.5rem}.source-gallery__control{min-height:36px;padding:.35rem .65rem;font-size:.85rem;font-weight:600;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:8px;cursor:pointer;touch-action:manipulation}.source-gallery__control:disabled{opacity:.45;cursor:not-allowed}.source-gallery__control--danger{color:var(--error-text);background:var(--error-bg);border-color:var(--error-border)}.app__add-more{width:100%;display:flex;flex-direction:column;gap:.75rem}.source-picker{display:flex;flex-wrap:wrap;gap:.5rem;width:100%}.source-picker__button{flex:1 1 calc(33.333% - .5rem);min-width:88px;min-height:44px;padding:.5rem .35rem;font-size:.9rem;font-weight:600;color:var(--text-muted);background:var(--surface);border:1px solid var(--border);border-radius:10px;cursor:pointer;touch-action:manipulation}.source-picker__button--active{color:#fff;background:var(--accent);border-color:var(--accent)}.source-picker__button:disabled{opacity:.55;cursor:not-allowed}.text-source{width:100%;display:flex;flex-direction:column;gap:.5rem}.text-source__label{font-size:.95rem;font-weight:600}.text-source__input{width:100%;padding:.875rem 1rem;font:inherit;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:12px;resize:vertical;min-height:160px}.field-with-clear{position:relative;width:100%}.field-with-clear--has-clear .field-with-clear__input,.field-with-clear--input.field-with-clear--has-clear .field-with-clear__input{padding-right:2.75rem}.clear-field-btn{position:absolute;top:.5rem;right:.5rem;display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;font-size:1.35rem;line-height:1;color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:8px;cursor:pointer}.field-with-clear--input .clear-field-btn{top:50%;transform:translateY(-50%)}.clear-field-btn:hover:not(:disabled){color:var(--text);border-color:var(--text-muted)}.clear-field-btn:disabled{opacity:.5;cursor:not-allowed}.doc-source__meta-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.doc-source__meta-header .clear-field-btn{position:static;transform:none;flex-shrink:0}.text-source__hint,.doc-source__hint{margin:0;font-size:.9rem;color:var(--text-muted)}.doc-source{width:100%;display:flex;flex-direction:column;gap:.75rem}.doc-source__intro{margin:0;font-size:.92rem;color:var(--text-muted);line-height:1.55}.doc-source__meta{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:var(--surface);border:1px solid var(--border);border-radius:12px}.doc-source__meta p{margin:0}.doc-source__range{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.doc-source__range label{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem;font-weight:600}.doc-source__range input{min-height:44px;padding:.5rem .75rem;font:inherit;border:1px solid var(--border);border-radius:8px;background:var(--bg)}.url-source{width:100%;display:flex;flex-direction:column;gap:.5rem}.url-source__label{font-size:.95rem;font-weight:600}.url-source__input{width:100%;min-height:48px;padding:.75rem 1rem;font:inherit;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:12px}.url-source__section-label{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem;font-weight:600}.url-source__section-select{min-height:48px;padding:.5rem .75rem;font:inherit;border:1px solid var(--border);border-radius:8px;background:var(--bg)}.url-source__preview,.url-source__hint{margin:0;font-size:.9rem;color:var(--text-muted);line-height:1.5}.session-recommendation{margin:0 0 .25rem;padding:.75rem .875rem;font-size:.92rem;color:var(--text-muted);background:var(--info-bg);border:1px solid var(--info-border);border-radius:10px}.language-help{display:flex;flex-direction:column;gap:.75rem;padding-top:.5rem;border-top:1px solid var(--border)}.language-help--standalone{padding-top:0;border-top:none}.language-help h2{margin:0}.language-help__intro{margin:0;font-size:.92rem;color:var(--text-muted)}.language-help__bilingual-grid{display:grid;gap:.75rem}.language-help__lang-label{margin:0 0 .35rem;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted)}.language-help__phrases{display:flex;flex-direction:column;gap:.75rem}.language-help__grammar ul{margin:0;padding-left:1.1rem}.language-help__grammar-native{margin:.35rem 0 0;font-size:.92rem;color:var(--text-muted);line-height:1.5}.language-help__more-hint{margin:0;font-size:.9rem;color:var(--text-muted);font-style:italic}.phrase-card{padding:1rem;background:var(--bg);border:1px solid var(--border);border-radius:12px;display:flex;flex-direction:column;gap:.5rem}.phrase-card__original{margin:0;font-size:1rem;font-weight:600}.phrase-card p{margin:0;font-size:.92rem;line-height:1.5}.phrase-card__field{display:flex;flex-direction:column;gap:.25rem}.phrase-card__native-line{color:var(--text-muted)}.profile-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:flex-end;justify-content:center}.profile-modal__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#1a2b3c73}.profile-modal__panel{position:relative;width:100%;max-width:480px;max-height:90svh;overflow-y:auto;padding:1.5rem 1.25rem 2rem;background:var(--surface);border-radius:20px 20px 0 0;box-shadow:0 -8px 32px #1a2b3c26}@media(min-width:640px){.profile-modal{align-items:center;padding:1.5rem}.profile-modal__panel{max-height:calc(100svh - 3rem);border-radius:20px;box-shadow:0 12px 40px #1a2b3c33}}.profile-modal__panel h2{margin:0 0 .5rem;font-size:1.25rem}.profile-modal__intro{margin:0 0 1rem;font-size:.92rem;color:var(--text-muted)}.profile-modal__form{display:flex;flex-direction:column;gap:1rem}.profile-modal__field{display:flex;flex-direction:column;gap:.35rem;font-size:.95rem;font-weight:600}.profile-modal__field select{min-height:48px;padding:.5rem .75rem;font:inherit;border:1px solid var(--border);border-radius:10px;background:var(--bg)}.profile-modal__levels{margin:0;padding:0;border:none;display:flex;flex-direction:column;gap:.5rem}.profile-modal__levels legend{font-size:.95rem;font-weight:600;margin-bottom:.35rem}.profile-modal__level{display:flex;gap:.75rem;align-items:flex-start;padding:.75rem;border:1px solid var(--border);border-radius:10px;cursor:pointer}.profile-modal__level input{margin-top:.2rem}.profile-modal__level span{display:flex;flex-direction:column;gap:.15rem}.profile-modal__level small{font-size:.85rem;color:var(--text-muted);font-weight:400}.profile-modal__notice{margin:0;font-size:.85rem;color:var(--text-muted);line-height:1.5}.profile-modal__actions{display:flex;flex-direction:column;gap:.75rem}
