:root{font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html{width:100%;height:100%;margin:0;padding:0}body{margin:0;padding:0;width:100%;height:100%}#root{width:100%;height:100%}:root{--radius-sm: 12px;--radius-md: 16px;--radius-lg: 20px;--radius-xl: 24px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .35s ease;--font-regular: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700}:root,:root[data-theme=technical-artisan-light],:root[data-theme=light-coral]{color-scheme:light;--color-bg-page: #fafafa;--color-bg-page-elevated: #f1f4f8;--color-bg-surface: #ffffff;--color-bg-surface-alt: #f6f8fb;--color-bg-panel: #ecf1f6;--color-bg-inset: #e2e8f0;--color-bg-overlay: rgb(15 23 42 / .35);--color-bg-overlay-strong: rgb(15 23 42 / .5);--color-bg-disabled: #9aa5b1;--color-bg-glass: rgb(255 255 255 / .8);--color-border: #d5dde7;--color-border-soft: #e4eaf2;--color-border-strong: #b9c4d2;--color-border-focus: #0070f3;--color-text-primary: #331f19;--color-text-secondary: #465363;--color-text-muted: #627285;--color-text-subtle: #8a97a8;--color-text-on-accent: #ffffff;--color-text-link: #0070f3;--color-text-link-hover: #005fc8;--color-brand-roast: #331f19;--color-brand-roast-hover: #452a22;--color-brand-roast-soft: #efe9e7;--color-accent-primary: #0070f3;--color-accent-primary-hover: #005fd0;--color-accent-primary-soft: #e8f1ff;--color-accent-secondary: #331f19;--color-accent-primary-rgb: 0 112 243;--color-success: #1e8f4d;--color-success-highlight: #38c976;--color-success-soft: #e7f8ed;--color-success-border: #a7e0bb;--color-success-text: #146438;--color-warning: #b56a1f;--color-warning-highlight: #e9a450;--color-warning-soft: #fff3e3;--color-warning-border: #f2cc9b;--color-warning-text: #8a4f11;--color-danger: #c43d2f;--color-danger-soft: #fdeeed;--color-danger-border: #f3c2bd;--color-danger-text: #982c21;--color-info: #0070f3;--color-info-soft: #eaf3ff;--color-info-border: #b8d2ff;--color-info-text: #0f4ca8;--color-skeleton: #c1ccd8;--color-focus-ring: rgb(0 112 243 / .23);--shadow-sm: 0 2px 8px rgb(15 23 42 / .06);--shadow-md: 0 6px 18px rgb(15 23 42 / .1);--shadow-lg: 0 12px 32px rgb(15 23 42 / .14);--shadow-xl: 0 18px 52px rgb(15 23 42 / .18);--sage-light: var(--color-bg-page);--sage-medium: var(--color-bg-page-elevated);--sage-dark: var(--color-bg-panel);--cream-light: var(--color-bg-surface);--cream-base: var(--color-bg-surface-alt);--cream-dark: var(--color-bg-panel);--peach-light: #3691ff;--peach-base: var(--color-accent-primary);--peach-dark: var(--color-accent-primary-hover);--peach-hover: #004fae;--text-primary: var(--color-text-primary);--text-secondary: var(--color-text-secondary);--text-tertiary: var(--color-text-muted);--text-light: var(--color-text-subtle);--beige-light: var(--color-border-soft);--beige-base: var(--color-border);--beige-dark: var(--color-border-strong);--brown-medium: var(--color-skeleton)}:root[data-theme=technical-artisan-dark],:root[data-theme=dark-coral]{color-scheme:dark;--color-bg-page: #08090a;--color-bg-page-elevated: #0f141b;--color-bg-surface: #131a23;--color-bg-surface-alt: #182230;--color-bg-panel: #1e2a3b;--color-bg-inset: #233347;--color-bg-overlay: rgb(2 6 23 / .45);--color-bg-overlay-strong: rgb(2 6 23 / .65);--color-bg-disabled: #58677a;--color-bg-glass: rgb(19 26 35 / .8);--color-border: #2a3a4d;--color-border-soft: #33465c;--color-border-strong: #44607a;--color-border-focus: #4b9dff;--color-text-primary: #f2f5fb;--color-text-secondary: #c4cfdd;--color-text-muted: #9fb0c4;--color-text-subtle: #8496ad;--color-text-on-accent: #f7fbff;--color-text-link: #8bc0ff;--color-text-link-hover: #abd3ff;--color-brand-roast: #c9b4aa;--color-brand-roast-hover: #d8c3b9;--color-brand-roast-soft: #2f2420;--color-accent-primary: #4b9dff;--color-accent-primary-hover: #2a87ff;--color-accent-primary-soft: #182b45;--color-accent-secondary: #c9b4aa;--color-accent-primary-rgb: 75 157 255;--color-success: #56d28d;--color-success-highlight: #83e7af;--color-success-soft: #163326;--color-success-border: #2d6547;--color-success-text: #9ee9c2;--color-warning: #e7af69;--color-warning-highlight: #f3c28f;--color-warning-soft: #3d2d1d;--color-warning-border: #6b4e33;--color-warning-text: #f2c89a;--color-danger: #ff8c84;--color-danger-soft: #402329;--color-danger-border: #794046;--color-danger-text: #ffb6b0;--color-info: #78b2ff;--color-info-soft: #1d2d45;--color-info-border: #35527b;--color-info-text: #a7ceff;--color-skeleton: #4f6075;--color-focus-ring: rgb(75 157 255 / .34);--shadow-sm: 0 2px 8px rgb(0 0 0 / .28);--shadow-md: 0 4px 16px rgb(0 0 0 / .34);--shadow-lg: 0 8px 32px rgb(0 0 0 / .45);--shadow-xl: 0 12px 48px rgb(0 0 0 / .56);--sage-light: var(--color-bg-page);--sage-medium: var(--color-bg-page-elevated);--sage-dark: var(--color-bg-panel);--cream-light: var(--color-bg-surface);--cream-base: var(--color-bg-surface-alt);--cream-dark: var(--color-bg-panel);--peach-light: #77b8ff;--peach-base: var(--color-accent-primary);--peach-dark: var(--color-accent-primary-hover);--peach-hover: #1d6fd8;--text-primary: var(--color-text-primary);--text-secondary: var(--color-text-secondary);--text-tertiary: var(--color-text-muted);--text-light: var(--color-text-subtle);--beige-light: var(--color-border-soft);--beige-base: var(--color-border);--beige-dark: var(--color-border-strong);--brown-medium: var(--color-skeleton)}.gradient-sage{background:linear-gradient(135deg,var(--sage-light) 0%,var(--sage-medium) 50%,var(--sage-dark) 100%)}.gradient-peach{background:linear-gradient(135deg,var(--peach-light) 0%,var(--peach-base) 50%,var(--peach-hover) 100%)}.gradient-cream{background:linear-gradient(135deg,var(--color-bg-surface) 0%,var(--cream-light) 50%,var(--cream-base) 100%)}.theme-card{background:var(--cream-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--beige-base);transition:all var(--transition-base)}.theme-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.theme-button{border-radius:var(--radius-full);font-weight:var(--font-semibold);transition:all var(--transition-base);border:none;cursor:pointer}.theme-button-primary{background:linear-gradient(135deg,var(--peach-base) 0%,var(--peach-hover) 100%);color:var(--color-text-on-accent)}.theme-button-primary:hover{background:linear-gradient(135deg,var(--peach-hover) 0%,var(--peach-base) 100%);transform:translateY(-2px);box-shadow:0 8px 24px rgb(var(--color-accent-primary-rgb) / .35)}.theme-button-secondary{background:var(--cream-base);color:var(--text-primary);border:2px solid var(--beige-base)}.theme-button-secondary:hover{background:var(--beige-light);border-color:var(--beige-dark);transform:translateY(-1px)}.theme-input{background:var(--color-bg-surface);border:2px solid var(--beige-light);border-radius:var(--radius-md);color:var(--text-primary);transition:all var(--transition-fast)}.theme-input:focus{border-color:var(--peach-base);box-shadow:0 0 0 4px var(--color-focus-ring);outline:none}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-accent{color:var(--peach-base)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse-soft{0%,to{opacity:1}50%{opacity:.8}}.animate-float{animation:float 3s ease-in-out infinite}.animate-pulse-soft{animation:pulse-soft 2s ease-in-out infinite}*{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--sage-light);color:var(--text-primary);line-height:1.6}#root{width:100%;min-height:100vh}.app-container{width:100%;min-height:100vh;background:linear-gradient(135deg,var(--sage-light) 0%,var(--sage-medium) 100%);position:relative;overflow:hidden;display:flex;flex-direction:column}.app-container:before{content:"";position:absolute;top:-20%;right:-10%;width:40%;height:40%;background:radial-gradient(circle,var(--peach-light) 0%,transparent 70%);opacity:.3;filter:blur(80px);pointer-events:none}.app-container:after{content:"";position:absolute;bottom:-20%;left:-10%;width:40%;height:40%;background:radial-gradient(circle,var(--beige-light) 0%,transparent 70%);opacity:.4;filter:blur(80px);pointer-events:none}.app-header{width:100%;background:var(--cream-light);border-bottom:none;padding:1.5rem 0;box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;z-index:10;transition:opacity var(--transition-base)}.app-header-content{width:100%;margin:0;padding:0 3rem;display:flex;align-items:center;justify-content:space-between;box-sizing:border-box}.app-header-left{display:flex;align-items:center;gap:1rem}.header-actions{display:flex;align-items:center;gap:.75rem}.theme-switcher{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem;border-radius:var(--radius-full);background:var(--color-bg-panel);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.theme-switcher-button{border:none;border-radius:var(--radius-full);background:transparent;color:var(--color-text-muted);font-size:.8125rem;font-weight:var(--font-semibold);line-height:1;padding:.45rem .7rem;cursor:pointer;transition:all var(--transition-fast)}.theme-switcher-button:hover{color:var(--color-text-primary);background:var(--color-bg-surface)}.theme-switcher-button.active{background:var(--color-accent-primary);color:var(--color-text-on-accent)}.theme-switcher-button:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px}@media (min-width: 1920px){.app-header-content{padding:0 4rem}}@media (max-width: 768px){.app-header-content{padding:0 1.5rem}}@media (max-width: 480px){.app-title{font-size:1.25rem}.app-subtitle{display:none}}.app-logo{width:56px;height:56px;border-radius:var(--radius-md);display:block;object-fit:cover;box-shadow:0 4px 12px rgb(var(--color-accent-primary-rgb) / .2);transition:transform var(--transition-base)}.app-logo:hover{transform:rotate(-5deg) scale(1.05)}@media (max-width: 768px){.app-logo{width:48px;height:48px}}@media (max-width: 480px){.app-logo{width:44px;height:44px}}.coffee-button{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:linear-gradient(135deg,var(--peach-base) 0%,var(--peach-dark) 100%);color:var(--color-text-on-accent);text-decoration:none;border-radius:var(--radius-full);font-size:.875rem;font-weight:var(--font-semibold);transition:all var(--transition-base);box-shadow:0 2px 8px rgb(var(--color-accent-primary-rgb) / .25);white-space:nowrap;position:relative;overflow:hidden}.coffee-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgb(255 255 255 / .2),transparent);transition:left .5s}.coffee-button:hover:before{left:100%}.coffee-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgb(var(--color-accent-primary-rgb) / .35);background:linear-gradient(135deg,var(--peach-dark) 0%,var(--peach-hover) 100%)}.coffee-icon{flex-shrink:0}.coffee-text{display:inline-block}@media (max-width: 768px){.header-actions{gap:.5rem}.theme-switcher-button{padding:.4rem .65rem}.coffee-button{padding:.5rem 1rem;font-size:.8125rem}.coffee-text{display:none}.coffee-button{padding:.625rem;border-radius:var(--radius-md)}.coffee-icon{width:18px;height:18px}}@media (max-width: 480px){.app-header-content{padding:0 1rem}.theme-switcher-button{padding:.4rem .55rem;font-size:.75rem}.coffee-button{padding:.5rem}.coffee-icon{width:16px;height:16px}}.app-title{font-size:1.875rem;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.02em;line-height:1}.app-subtitle{font-size:.875rem;color:var(--text-secondary);margin:0;line-height:1.2}.app-main{width:100%;margin:0;padding:2rem 3rem;padding-top:50px;box-sizing:border-box;flex:1 0 auto}@media (min-width: 1920px){.app-main{padding:2rem 4rem}}@media (max-width: 768px){.app-main{padding:2rem 1.5rem;padding-top:40px}}@media (max-width: 480px){.app-main{padding:1.5rem 1rem;padding-top:30px}}.error-alert{background:var(--color-danger-soft);border:1px solid var(--color-danger-border);border-radius:var(--radius-md);padding:1rem;margin-bottom:2rem;display:flex;align-items:center;gap:.75rem;box-shadow:var(--shadow-sm)}.error-icon{color:var(--color-danger);flex-shrink:0}.error-text{color:var(--color-danger-text);font-weight:500}.form-container{width:100%;margin:0;padding:0;box-sizing:border-box}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;width:100%}@media (min-width: 1920px){.form-grid{gap:3rem}}@media (max-width: 1024px) and (orientation: portrait){.form-grid{grid-template-columns:1fr 1fr;gap:1.5rem}}@media (max-width: 768px){.form-grid{grid-template-columns:1fr;gap:1rem}}@media (max-width: 480px){.form-grid{gap:.75rem}}.input-section{background:var(--cream-light);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-md);border:1px solid var(--beige-base);transition:all var(--transition-base);position:relative}.input-section:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}@media (max-width: 768px){.input-section{padding:1.5rem}}@media (max-width: 480px){.input-section{padding:1rem;border-radius:8px}}.section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.section-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--peach-light) 0%,var(--peach-base) 100%);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--color-text-on-accent);box-shadow:0 2px 8px rgb(var(--color-accent-primary-rgb) / .25)}.section-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0;letter-spacing:-.01em}.toggle-container{background:var(--beige-light);border-radius:var(--radius-full);padding:4px;display:flex;margin-bottom:1.5rem;box-shadow:inset 0 2px 4px #0000001a}.toggle-button{flex:1;padding:.5rem 1rem;border:none;background:transparent;border-radius:var(--radius-full);font-size:.875rem;font-weight:500;color:var(--color-text-muted);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}@media (max-width: 480px){.toggle-button{padding:.5rem .75rem;font-size:.8125rem;gap:.375rem}.toggle-button svg{width:14px;height:14px}}.toggle-button.active{background:var(--color-bg-surface);color:var(--text-primary);box-shadow:var(--shadow-sm);font-weight:var(--font-semibold)}.toggle-button:hover:not(.active){color:var(--text-primary);background:var(--color-bg-glass)}.text-input{width:100%;padding:.875rem;border:2px solid var(--beige-light);border-radius:var(--radius-md);font-size:.875rem;line-height:1.5;resize:vertical;min-height:200px;transition:all var(--transition-fast);background:var(--color-bg-surface);color:var(--text-primary)}@media (max-width: 768px){.text-input{min-height:180px;font-size:.875rem}}@media (max-width: 480px){.text-input{min-height:150px;padding:.625rem;font-size:.8125rem}}.text-input:focus{outline:none;border-color:var(--peach-base);box-shadow:0 0 0 4px var(--color-focus-ring);background:var(--color-bg-surface)}.text-input::placeholder{color:var(--text-tertiary)}.file-upload-area{border:2px dashed var(--beige-base);border-radius:var(--radius-md);padding:2rem;text-align:center;transition:all var(--transition-base);cursor:pointer;position:relative;background:var(--color-bg-surface)}.file-upload-area:hover{border-color:var(--peach-base);background:var(--cream-base);transform:translateY(-1px)}.file-upload-area.drag-over{border-color:var(--peach-dark);background:linear-gradient(135deg,rgb(var(--color-accent-primary-rgb) / .1) 0%,var(--color-accent-primary-soft) 100%)}.file-upload-input{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer}.file-upload-icon{width:48px;height:48px;background:linear-gradient(135deg,var(--peach-light) 0%,var(--peach-base) 100%);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;color:var(--color-text-on-accent);box-shadow:0 4px 12px rgb(var(--color-accent-primary-rgb) / .25)}.file-upload-text{font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:.25rem}.file-upload-subtext{font-size:.875rem;color:var(--text-secondary);margin-bottom:.25rem}.file-upload-hint{font-size:.75rem;color:var(--text-tertiary)}.action-section{background:var(--cream-light);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-md);border:1px solid var(--beige-base);margin-top:2rem;margin-bottom:0;display:flex;justify-content:center}.action-buttons{display:flex;gap:1rem;max-width:600px;width:100%;justify-content:center}@media (max-width: 768px){.action-section{padding:1.5rem;margin-top:1.5rem}}@media (max-width: 640px){.action-buttons{flex-direction:column;align-items:center}.action-button{width:100%;max-width:320px}}@media (max-width: 480px){.action-section{padding:1rem;border-radius:8px}}.action-button{flex:1;padding:.875rem 1.5rem;border:none;border-radius:var(--radius-full);font-size:.875rem;font-weight:var(--font-semibold);cursor:pointer;transition:all var(--transition-base);display:flex;align-items:center;justify-content:center;gap:.5rem}.action-button:disabled{opacity:.5;cursor:not-allowed}.action-button.primary{background:linear-gradient(135deg,var(--peach-base) 0%,var(--peach-dark) 100%);color:var(--color-text-on-accent);border-radius:var(--radius-full);font-weight:var(--font-semibold);letter-spacing:-.01em}.action-button.primary:hover:not(:disabled){box-shadow:0 8px 24px rgb(var(--color-accent-primary-rgb) / .35);transform:translateY(-2px);background:linear-gradient(135deg,var(--peach-dark) 0%,var(--peach-hover) 100%)}.action-button.secondary{background:var(--cream-base);color:var(--text-primary);border:2px solid var(--beige-base);border-radius:var(--radius-full);font-weight:var(--font-semibold)}.action-button.secondary:hover:not(:disabled){background:var(--beige-light);border-color:var(--beige-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.loading-spinner{width:16px;height:16px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes skeleton-pulse{0%,to{opacity:.4}50%{opacity:.15}}.skeleton-card{opacity:1!important}.skeleton-line{height:14px;background:var(--brown-medium);border-radius:6px;margin-bottom:12px;animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-circle{width:80px;height:80px;border-radius:50%;background:var(--brown-medium);animation:skeleton-pulse 1.5s ease-in-out infinite;flex-shrink:0}.pdf-gen-overlay{position:fixed;inset:0;background:var(--color-bg-overlay);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease}.pdf-gen-modal{background:linear-gradient(135deg,var(--color-bg-surface) 0%,var(--cream-light) 100%);border:1px solid var(--beige-base);border-radius:var(--radius-xl);padding:2.5rem;max-width:480px;width:90%;text-align:center;box-shadow:var(--shadow-xl)}.pdf-gen-icon{color:var(--peach-base);margin-bottom:1rem;animation:pulse-icon 2s ease-in-out infinite}@keyframes pulse-icon{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}.pdf-gen-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem}.pdf-gen-subtitle{font-size:.875rem;color:var(--text-secondary);margin:0 0 1.5rem}.pdf-gen-progress-bar{width:100%;height:6px;background:var(--beige-light);border-radius:3px;overflow:hidden;margin-bottom:1.5rem}.pdf-gen-progress-fill{height:100%;background:linear-gradient(90deg,var(--peach-base),var(--peach-dark));border-radius:3px;animation:pdf-progress 60s ease-out forwards}@keyframes pdf-progress{0%{width:0%}10%{width:15%}30%{width:40%}60%{width:65%}80%{width:80%}to{width:95%}}.pdf-gen-tip{font-size:.85rem;color:var(--text-secondary);font-style:italic;margin:0;min-height:2.5rem;animation:tipFadeIn .5s ease}@keyframes tipFadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.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}.suggestions{margin-top:2rem;margin-bottom:2rem;position:relative;z-index:1}.suggestions-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}@media (max-width: 1024px) and (orientation: portrait){.suggestions-grid{grid-template-columns:1fr 1fr;gap:1rem}}@media (max-width: 768px){.suggestions-grid{grid-template-columns:1fr;gap:1rem}.suggestions{margin-top:1.5rem}}@media (max-width: 480px){.suggestions-grid{gap:.75rem}.suggestions{margin-top:1rem}}.suggestion-card{background:var(--cream-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;border:1px solid var(--beige-base);transition:all var(--transition-base)}.suggestion-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.suggestion-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--beige-light);background:linear-gradient(135deg,var(--cream-base) 0%,var(--cream-dark) 100%)}.suggestion-title{font-size:1.125rem;font-weight:var(--font-semibold);color:var(--text-primary);margin:0;letter-spacing:-.01em}.suggestion-content{padding:1.5rem}.suggestion-content pre{white-space:pre-wrap;word-wrap:break-word;font-family:inherit;font-size:.875rem;line-height:1.6;margin:0;color:var(--color-text-secondary)}.markdown-content{max-height:600px;overflow-y:auto;padding-right:.5rem}.markdown-content::-webkit-scrollbar{width:6px}.markdown-content::-webkit-scrollbar-track{background:var(--cream-dark);border-radius:3px}.markdown-content::-webkit-scrollbar-thumb{background:var(--beige-base);border-radius:3px}.markdown-content::-webkit-scrollbar-thumb:hover{background:var(--beige-dark)}.markdown-content h2{color:var(--color-text-link);margin-top:2rem;margin-bottom:1rem;border-bottom:2px solid var(--color-border-soft);padding-bottom:.5rem;font-size:1.25rem;font-weight:600}.markdown-content h3{color:var(--color-text-link-hover);margin-top:1.5rem;margin-bottom:.75rem;font-size:1.1rem;font-weight:600}.markdown-content p{margin-bottom:1rem;line-height:1.8}.markdown-content li{margin-bottom:.5rem;line-height:1.6}.markdown-content li:has(>input[type=checkbox]){list-style:none;margin-left:-1.5rem}.markdown-content li>input[type=checkbox]{margin-right:.5rem}.markdown-content strong{font-weight:600;color:var(--color-text-secondary)}.markdown-content ul,.markdown-content ol{margin-left:1.5rem;margin-bottom:1rem}.markdown-content em{font-style:italic;color:var(--color-text-muted)}.markdown-content hr{margin:1.5rem 0;border:0;border-top:2px solid var(--color-border-soft)}.markdown-content code{background-color:var(--color-bg-panel);padding:.125rem .5rem;border-radius:.25rem;font-size:.875em;font-family:Courier New,monospace}.application-questions-card{grid-column:1 / -1}.qa-accordion{display:flex;flex-direction:column;gap:.75rem}.qa-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--beige-light)}.qa-counter{font-size:.875rem;color:var(--text-secondary);font-weight:var(--font-medium)}.qa-expand-all{padding:.5rem 1rem;background:var(--cream-base);border:1px solid var(--beige-base);border-radius:var(--radius-full);font-size:.875rem;font-weight:var(--font-medium);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base)}.qa-expand-all:hover{background:var(--beige-light);color:var(--text-primary);border-color:var(--beige-dark)}.qa-item{border:1px solid var(--beige-light);border-radius:var(--radius-md);overflow:hidden;transition:all var(--transition-base);background:var(--color-bg-surface)}.qa-item:hover{border-color:var(--beige-base);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.qa-question{width:100%;padding:1rem 1.25rem;background:var(--color-bg-surface);border:none;text-align:left;font-size:.875rem;font-weight:var(--font-semibold);color:var(--text-primary);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;transition:all var(--transition-fast)}.qa-question:hover{background:var(--cream-light)}.qa-question.expanded{background:var(--cream-base);color:var(--text-primary);border-bottom:1px solid var(--beige-light)}.qa-question-text{flex:1;line-height:1.5;font-weight:600}.qa-icon{width:16px;height:16px;color:var(--text-secondary);transition:transform var(--transition-fast);flex-shrink:0}.qa-icon.expanded{transform:rotate(180deg);color:var(--peach-base)}.qa-answer{padding:1.25rem;background:var(--color-bg-surface);border-top:1px solid var(--cream-base);font-size:.875rem;line-height:1.6;color:var(--text-secondary);white-space:pre-wrap;animation:slideDown .3s ease-out;font-weight:400;word-wrap:break-word}.qa-answer p{margin-bottom:.75rem}.qa-answer p:last-child{margin-bottom:0}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.qa-no-questions{text-align:center;padding:2rem;color:var(--text-secondary);font-style:italic}.qa-section{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.qa-section-header{display:flex;align-items:center;gap:.5rem;font-size:.75rem;font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);padding:.25rem 0;border-bottom:1px solid var(--beige-light);margin-bottom:.25rem}.qa-section-count{background:var(--beige-light);color:var(--text-secondary);border-radius:var(--radius-full);font-size:.7rem;padding:.1rem .45rem;font-weight:var(--font-medium)}.app-footer{width:100%;background:var(--cream-light);border-top:1px solid var(--beige-light);padding:1.5rem 0;margin-top:auto;box-shadow:0 -2px 10px #00000026;position:relative;z-index:10;flex-shrink:0}.footer-content{width:100%;margin:0;padding:0 3rem;text-align:center;box-sizing:border-box}.footer-text{margin:0;font-size:.875rem;color:var(--text-secondary);font-weight:var(--font-medium);letter-spacing:.01em}.footer-love,.footer-support{margin:.5rem 0 0;font-size:.8125rem;color:var(--text-tertiary);font-weight:var(--font-regular)}.footer-coffee-link{color:var(--peach-base);text-decoration:none;font-weight:var(--font-medium);transition:all var(--transition-fast);border-bottom:1px solid transparent}.footer-coffee-link:hover{color:var(--peach-dark);border-bottom-color:var(--peach-dark)}.heart{display:inline-block;color:var(--peach-dark);animation:heartbeat 1.5s ease-in-out infinite;transform-origin:center}@keyframes heartbeat{0%{transform:scale(1)}14%{transform:scale(1.1)}28%{transform:scale(1)}42%{transform:scale(1.1)}70%{transform:scale(1)}}@media (min-width: 1920px){.footer-content{padding:0 4rem}}@media (max-width: 768px){.footer-content{padding:0 1.5rem}.app-footer{padding:1.25rem 0}}@media (max-width: 480px){.footer-content{padding:0 1rem}.app-footer{padding:1rem 0}.footer-text{font-size:.8125rem}}.ats-score-card{background:var(--cream-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:2rem;margin-bottom:2rem;border:1px solid var(--beige-base);transition:all var(--transition-base)}.ats-score-header{margin-bottom:2rem}.ats-score-main{display:flex;align-items:center;gap:2rem}.ats-score-circle-container{position:relative;width:120px;height:120px;flex-shrink:0}.ats-score-circle{width:100%;height:100%;transform:rotate(0)}.ats-score-value{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.ats-score-number{font-size:2rem;font-weight:700;line-height:1;display:block}.ats-score-max{font-size:.875rem;color:var(--color-text-muted);font-weight:500}.score-excellent,.score-excellent .ats-score-number{color:var(--color-success)}.score-good,.score-good .ats-score-number{color:var(--peach-dark)}.score-needs-work,.score-needs-work .ats-score-number{color:var(--color-warning)}.ats-score-info{flex:1}.ats-score-title{font-size:1.5rem;font-weight:var(--font-bold);margin:0 0 .5rem;color:var(--text-primary)}.ats-score-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:600;margin-bottom:.75rem}.badge-pass{background-color:var(--color-success-soft);color:var(--color-success-text)}.badge-improve{background-color:var(--color-warning-soft);color:var(--color-warning-text)}.badge-revision{background-color:var(--color-danger-soft);color:var(--color-danger-text)}.ats-score-summary{color:var(--text-secondary);line-height:1.6;margin:.5rem 0 0;font-size:.95rem}.ats-score-breakdown{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--beige-base)}.ats-breakdown-title{font-size:1.125rem;font-weight:var(--font-semibold);margin:0 0 1.5rem;color:var(--text-primary)}.ats-breakdown-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.25rem}.score-component{background:var(--color-bg-glass);padding:1rem;border-radius:var(--radius-md);border:1px solid var(--beige-base)}.score-component-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.score-component-label{font-weight:var(--font-semibold);font-size:.875rem;color:var(--text-primary)}.score-component-weight{font-size:.75rem;color:var(--text-tertiary);font-weight:var(--font-medium)}.score-component-bar-container{display:flex;align-items:center;gap:.75rem}.score-component-bar-bg{flex:1;height:8px;background:var(--beige-light);border-radius:var(--radius-full);overflow:hidden}.score-component-bar-fill{height:100%;border-radius:9999px;transition:width .5s ease-in-out}.score-component-bar-fill.score-excellent{background:linear-gradient(90deg,var(--color-success),var(--color-success-highlight))}.score-component-bar-fill.score-good{background:linear-gradient(90deg,var(--peach-base),var(--peach-light))}.score-component-bar-fill.score-needs-work{background:linear-gradient(90deg,var(--color-warning),var(--color-warning-highlight))}.score-component-value{font-weight:700;font-size:1rem;min-width:2rem;text-align:right}.ats-score-insights{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--beige-base);display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.ats-insight-section{background:var(--color-bg-glass);padding:1.25rem;border-radius:var(--radius-md);border-left:4px solid var(--peach-base)}.ats-insight-title{font-size:.95rem;font-weight:var(--font-semibold);margin:0 0 1rem;color:var(--color-warning-text)}.ats-skill-tags{display:flex;flex-wrap:wrap;gap:.5rem}.ats-skill-tag{display:inline-block;padding:.35rem .75rem;background:var(--cream-light);border:1px solid var(--peach-base);border-radius:var(--radius-sm);font-size:.875rem;font-weight:var(--font-medium);color:var(--color-warning-text)}.ats-issue-list{margin:0;padding-left:1.5rem;color:var(--color-warning-text)}.ats-issue-list li{margin-bottom:.5rem;font-size:.875rem;line-height:1.5}.ats-score-details{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--beige-base)}.ats-details-summary{font-weight:var(--font-semibold);color:var(--color-success);cursor:pointer;padding:.75rem;background:var(--color-success-soft);border-radius:var(--radius-md);transition:background var(--transition-base);-webkit-user-select:none;user-select:none}.ats-details-summary:hover{background:color-mix(in srgb,var(--color-success-soft) 80%,var(--color-success) 20%)}.ats-details-content{margin-top:1.5rem;display:grid;gap:1.25rem}.ats-detail-item{padding:1.25rem;background:var(--color-bg-glass);border-radius:var(--radius-md);border-left:3px solid var(--sage-dark)}.ats-detail-title{font-size:1rem;font-weight:var(--font-semibold);margin:0 0 .5rem;color:var(--color-success)}.ats-detail-description{color:var(--text-secondary);line-height:1.6;margin:0 0 .75rem;font-size:.9rem}.ats-detail-list{font-size:.875rem;color:var(--text-tertiary);margin-top:.5rem}.ats-detail-list strong{color:var(--text-primary)}@media (max-width: 768px){.ats-score-main{flex-direction:column;text-align:center}.ats-breakdown-grid,.ats-score-insights{grid-template-columns:1fr}.ats-score-card{padding:1.5rem}}.history-overlay{position:fixed;inset:0;background:transparent;z-index:99}.history-dropdown{position:absolute;top:100%;right:0;margin-top:8px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:8px;box-shadow:var(--shadow-lg);min-width:350px;max-width:450px;max-height:400px;overflow:hidden;z-index:100;display:flex;flex-direction:column}.history-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--color-border);background:var(--color-bg-panel);flex-shrink:0}.history-header h4{margin:0;font-size:14px;font-weight:600;color:var(--color-text-primary)}.clear-all-btn{background:none;border:none;color:var(--color-danger);font-size:12px;font-weight:500;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background .2s}.clear-all-btn:hover{background:var(--color-danger-soft)}.history-list{list-style:none;padding:0;margin:0;overflow-y:auto;flex:1}.history-item{display:flex;border-bottom:1px solid var(--color-border);transition:background .2s}.history-item:last-child{border-bottom:none}.history-item:hover{background:var(--color-bg-panel)}.history-item-content{flex:1;padding:12px 16px;text-align:left;border:none;background:none;cursor:pointer;display:flex;flex-direction:column;gap:4px}.preview{font-size:13px;color:var(--color-text-primary);line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.timestamp{font-size:11px;color:var(--color-text-muted);font-weight:500}.delete-btn{padding:8px 12px;border:none;background:none;color:var(--color-danger);cursor:pointer;font-size:24px;line-height:1;transition:background .2s;align-self:center}.delete-btn:hover{background:var(--color-danger-soft)}.section-header-with-history{position:relative}.history-toggle-btn{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:6px;padding:6px 12px;font-size:12px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;color:var(--color-text-secondary);transition:all .2s;white-space:nowrap}.history-toggle-btn:hover{background:var(--color-bg-panel);border-color:var(--color-border-strong)}.history-toggle-btn.active{background:var(--color-info-soft);border-color:var(--color-info);color:var(--color-info-text)}.history-toggle-btn svg{width:14px;height:14px}.email-button{display:inline-flex;align-items:center;gap:.75rem;padding:1rem 2rem;background:linear-gradient(135deg,var(--color-accent-primary) 0%,var(--color-accent-primary-hover) 100%);color:var(--color-text-on-accent);border:none;border-radius:12px;font-weight:700;font-size:1.1rem;cursor:pointer;transition:all .3s ease;box-shadow:0 6px 20px rgb(var(--color-accent-primary-rgb) / .4);position:relative;overflow:hidden}.email-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgb(255 255 255 / .2),transparent);transition:left .5s}.email-button:hover:before{left:100%}.email-button:hover{transform:translateY(-3px);box-shadow:0 10px 25px rgb(var(--color-accent-primary-rgb) / .5)}.email-button:active{transform:translateY(-1px);box-shadow:0 5px 15px rgb(var(--color-accent-primary-rgb) / .4)}.email-icon{flex-shrink:0}.email-modal-overlay{position:fixed;inset:0;background:var(--color-bg-overlay-strong);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.email-modal{background:var(--color-bg-surface);border-radius:12px;max-width:500px;width:100%;border:1px solid var(--color-border);box-shadow:var(--shadow-xl);animation:modalSlideIn .3s ease}.email-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--color-border-soft)}.email-modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-text-primary)}.email-modal-close{background:none;border:none;font-size:2rem;line-height:1;cursor:pointer;color:var(--color-text-muted);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.email-modal-close:hover{background:var(--color-bg-panel);color:var(--color-text-primary)}.email-modal-close:disabled{opacity:.4;cursor:not-allowed}.email-modal-body{padding:1.5rem}.email-form-group{margin-bottom:1.25rem}.email-form-group label{display:block;font-weight:500;margin-bottom:.5rem;color:var(--color-text-secondary);font-size:.95rem}.email-input{width:100%;padding:.75rem;border:1px solid var(--color-border-strong);border-radius:6px;font-size:1rem;transition:all .2s ease;box-sizing:border-box;color:var(--color-text-primary);background:var(--color-bg-surface)}.email-input:focus{outline:none;border-color:var(--color-border-focus);box-shadow:0 0 0 3px var(--color-focus-ring)}.email-input:disabled{background:var(--color-bg-panel);cursor:not-allowed}.email-checkbox-group{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1.25rem;padding:1rem;background:var(--color-bg-panel);border-radius:6px}.email-checkbox-group input[type=checkbox]{margin-top:.25rem;width:18px;height:18px;cursor:pointer;flex-shrink:0;accent-color:var(--color-accent-primary)}.email-checkbox-group label{cursor:pointer;color:var(--color-text-secondary);font-size:.95rem;-webkit-user-select:none;user-select:none}.email-info{background:var(--color-info-soft);border:1px solid var(--color-info-border);border-radius:6px;padding:1rem;color:var(--color-info-text);font-size:.9rem;line-height:1.6}.email-info ul{margin:.5rem 0 0 1.5rem;padding:0}.email-info li{margin:.25rem 0}.email-error{background:var(--color-danger-soft);border:1px solid var(--color-danger-border);border-radius:6px;padding:.75rem;color:var(--color-danger-text);font-size:.9rem;margin-bottom:1rem}.email-success{padding:3rem 1.5rem;text-align:center}.success-icon{color:var(--color-success);margin:0 auto 1rem}.email-success p{font-size:1.1rem;font-weight:500;color:var(--color-success-text);margin:0}.email-sending{padding:2rem 1.5rem 2.25rem;text-align:center}.email-sending-spinner{width:42px;height:42px;border-width:3px;color:var(--color-accent-primary);margin:0 auto 1rem}.email-sending-title{margin:0 0 .5rem;font-size:1.15rem;color:var(--color-text-primary)}.email-sending-subtitle{margin:0 0 1rem;color:var(--color-text-secondary);line-height:1.5;font-size:.95rem}.email-sending-progress-bar{width:100%;height:6px;background:var(--color-bg-panel);border-radius:999px;overflow:hidden;margin:0 0 .9rem}.email-sending-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-accent-primary),var(--color-accent-primary-hover));border-radius:999px;animation:emailProgress 65s ease-out forwards}@keyframes emailProgress{0%{width:0%}20%{width:30%}45%{width:58%}70%{width:78%}to{width:94%}}.email-sending-status{margin:0 0 .75rem;color:var(--color-text-primary);font-size:.92rem;font-weight:500;min-height:1.4rem;animation:emailMessageFadeIn .35s ease}.email-sending-tip{margin:0;color:var(--color-text-secondary);font-size:.85rem;font-style:italic;min-height:2.6rem;animation:emailMessageFadeIn .35s ease}@keyframes emailMessageFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.email-modal-footer{display:flex;gap:.75rem;padding:1.5rem;border-top:1px solid var(--color-border-soft);justify-content:flex-end}.email-modal-button{padding:.75rem 1.5rem;border-radius:6px;font-weight:500;font-size:1rem;cursor:pointer;transition:all .2s ease;border:none}.email-modal-button:disabled{opacity:.5;cursor:not-allowed}.email-modal-button-secondary{background:var(--color-bg-surface);color:var(--color-text-secondary);border:1px solid var(--color-border-strong)}.email-modal-button-secondary:hover:not(:disabled){background:var(--color-bg-panel)}.email-modal-button-primary{background:linear-gradient(135deg,var(--color-accent-primary) 0%,var(--color-accent-primary-hover) 100%);color:var(--color-text-on-accent)}.email-modal-button-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 6px rgb(var(--color-accent-primary-rgb) / .25)}@media (max-width: 640px){.email-modal{margin:1rem}.email-button{width:100%;justify-content:center}}.coffee-modal-overlay{position:fixed;inset:0;background:var(--color-bg-overlay-strong);display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.coffee-modal{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:90%;max-width:480px;position:relative;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.coffee-modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;color:var(--text-tertiary);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-fast);z-index:1}.coffee-modal-close:hover{background:var(--beige-light);color:var(--text-primary)}.coffee-modal-content{padding:2.5rem;text-align:center}.coffee-icon-large{width:80px;height:80px;margin:0 auto 1.5rem;background:linear-gradient(135deg,var(--peach-light) 0%,var(--peach-base) 100%);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:var(--color-text-on-accent);box-shadow:0 8px 24px rgb(var(--color-accent-primary-rgb) / .35);animation:bounce .6s ease-out}@keyframes bounce{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.coffee-modal-content h3{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 1rem;letter-spacing:-.02em}.coffee-message{font-size:1rem;color:var(--text-secondary);line-height:1.6;margin:0 0 1.5rem}.coffee-modal-buttons{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.coffee-modal-button{padding:.875rem 1.5rem;border:none;border-radius:var(--radius-full);font-size:.9375rem;font-weight:var(--font-semibold);cursor:pointer;transition:all var(--transition-base);display:flex;align-items:center;justify-content:center;gap:.5rem;text-decoration:none}.coffee-modal-button-primary{background:linear-gradient(135deg,var(--peach-base) 0%,var(--peach-hover) 100%);color:var(--color-text-on-accent);box-shadow:0 4px 12px rgb(var(--color-accent-primary-rgb) / .3)}.coffee-modal-button-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgb(var(--color-accent-primary-rgb) / .4);background:linear-gradient(135deg,var(--peach-hover) 0%,var(--peach-base) 100%)}.coffee-modal-button-secondary{background:var(--cream-base);color:var(--text-primary);border:2px solid var(--beige-base)}.coffee-modal-button-secondary:hover{background:var(--beige-light);border-color:var(--beige-dark);transform:translateY(-1px)}.coffee-note{font-size:.8125rem;color:var(--text-tertiary);margin:0;font-style:italic}@media (max-width: 480px){.coffee-modal{width:95%;max-width:none}.coffee-modal-content{padding:2rem 1.5rem}.coffee-icon-large{width:64px;height:64px}.coffee-icon-large svg{width:36px;height:36px}.coffee-modal-content h3{font-size:1.25rem}.coffee-message{font-size:.9375rem}.coffee-modal-button{padding:.75rem 1.25rem;font-size:.875rem}}
