@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Outfit:wght@400;500;600;700;800&display=swap";:root{--color-primary: #7c3aed;--color-primary-light: #a78bfa;--color-primary-dark: #5b21b6;--color-primary-bg: #f5f3ff;--color-primary-bg-hover: #ede9fe;--color-primary-border: #ddd6fe;--color-accent: #7c3aed;--color-accent-hover: #6d28d9;--color-accent-light: rgba(124, 58, 237, .08);--color-accent-secondary: #3b82f6;--color-bg: #ffffff;--color-bg-secondary: #f9fafb;--color-bg-tertiary: #f3f4f6;--color-bg-page: #f0f0f5;--color-surface: #ffffff;--color-surface-hover: #f5f3ff;--color-border: rgba(0, 0, 0, .06);--color-border-strong: rgba(0, 0, 0, .12);--color-text-primary: #111827;--color-text-secondary: #6b7280;--color-text-tertiary: #9ca3af;--color-success: #10b981;--color-success-light: #d1fae5;--color-success-dark: #065f46;--color-warning: #f59e0b;--color-warning-light: #fef3c7;--color-warning-dark: #92400e;--color-danger: #ef4444;--color-danger-light: #fee2e2;--color-danger-dark: #991b1b;--color-info: #3b82f6;--color-info-light: #dbeafe;--gradient-primary: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-primary-soft: linear-gradient(135deg, #f5f3ff 0%, #ede9fe 100%);--gradient-accent: linear-gradient(135deg, #a78bfa 0%, #7c3aed 100%);--gradient-success: linear-gradient(135deg, #d1fae5 0%, #a7f3d0 100%);--gradient-warning: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);--gradient-danger: linear-gradient(135deg, #fee2e2 0%, #fecaca 100%);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .04), 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .06), 0 2px 4px rgba(0, 0, 0, .04);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .08), 0 4px 8px rgba(0, 0, 0, .04);--shadow-xl: 0 20px 60px rgba(0, 0, 0, .1), 0 8px 16px rgba(0, 0, 0, .06);--shadow-primary: 0 8px 24px rgba(124, 58, 237, .25);--shadow-primary-sm: 0 4px 12px rgba(124, 58, 237, .15);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 24px;--radius-full: 100px;--transition: .25s cubic-bezier(.4, 0, .2, 1);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--ease-bounce: cubic-bezier(.68, -.55, .265, 1.55);--font-primary: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-display: "Outfit", "Inter", -apple-system, sans-serif;--max-width: 1200px;--header-height: 64px}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-primary);background:var(--color-bg-page);color:var(--color-text-primary);line-height:1.5;min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}.header{position:sticky;top:0;z-index:100;height:var(--header-height);background:#fffc;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--color-border);display:flex;align-items:center;padding:0 24px}.header-inner{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:var(--max-width);margin:0 auto}.header-logo{font-family:var(--font-display);font-size:1.125rem;font-weight:700;color:var(--color-text-primary);text-decoration:none;letter-spacing:-.02em;display:flex;align-items:center;gap:10px;transition:var(--transition)}.header-logo:hover{opacity:.8}.header-logo svg{width:22px;height:22px;color:var(--color-primary)}.header-nav{display:flex;align-items:center;gap:4px}.header-nav a,.header-nav button{font-size:.875rem;font-weight:500;color:var(--color-text-secondary);text-decoration:none;padding:8px 16px;border-radius:var(--radius-full);border:none;background:none;cursor:pointer;transition:var(--transition);white-space:nowrap}.header-nav a:hover,.header-nav button:hover{color:var(--color-text-primary);background:var(--color-bg-tertiary)}.header-nav a.active{color:var(--color-primary);background:var(--color-primary-bg);font-weight:600}.add-project-btn{width:36px;height:36px;padding:0!important;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary)!important;color:#fff!important;border-radius:12px!important;box-shadow:var(--shadow-primary-sm);transition:var(--transition)!important}.add-project-btn:hover{transform:translateY(-1px) scale(1.05)!important;box-shadow:var(--shadow-primary)!important}.add-project-btn svg{flex-shrink:0}.guide-btn{width:36px;height:36px;padding:0!important;display:flex;align-items:center;justify-content:center;background:var(--color-primary-bg)!important;color:var(--color-primary)!important;border-radius:50%!important;transition:var(--transition)!important;border:1.5px solid var(--color-primary-border)!important}.guide-btn:hover{background:var(--color-primary-bg-hover)!important;transform:translateY(-1px)!important;box-shadow:var(--shadow-sm)!important}.guide-btn svg{flex-shrink:0}.logout-btn{background:var(--color-danger-light)!important;color:var(--color-danger)!important;font-weight:600!important}.logout-btn:hover{background:var(--color-danger)!important;color:#fff!important}.hamburger-btn{display:none;width:40px;height:40px;padding:0;border:none;background:none;cursor:pointer;color:var(--color-text-primary);align-items:center;justify-content:center;border-radius:var(--radius-md);transition:var(--transition)}.hamburger-btn:hover{background:var(--color-bg-tertiary)}.lang-switcher{display:flex;align-items:center;background:var(--color-bg-tertiary);border-radius:var(--radius-full);padding:3px;gap:0}.lang-btn{font-size:.75rem;font-weight:600;padding:4px 10px;border:none;background:none;border-radius:var(--radius-full);cursor:pointer;color:var(--color-text-tertiary);transition:var(--transition);letter-spacing:.02em}.lang-btn.active{background:var(--color-surface);color:var(--color-primary);box-shadow:var(--shadow-sm)}.main-content{flex:1;padding:32px 24px;max-width:var(--max-width);width:100%;margin:0 auto}.page-header{margin-bottom:32px}.page-header h1{font-family:var(--font-display);font-size:2.25rem;font-weight:800;letter-spacing:-.03em;color:var(--color-text-primary);margin-bottom:6px;line-height:1.2}.page-header p{font-size:1.0625rem;color:var(--color-text-secondary);font-weight:400}.card{background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border);padding:24px;transition:var(--transition);box-shadow:var(--shadow-xs)}.card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border-strong)}.card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}.card-title{font-family:var(--font-display);font-size:1.125rem;font-weight:700;letter-spacing:-.01em;color:var(--color-text-primary)}.card-subtitle{font-size:.8125rem;color:var(--color-text-tertiary);margin-top:2px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:inherit;font-size:.875rem;font-weight:600;padding:10px 22px;border-radius:var(--radius-md);border:none;cursor:pointer;transition:var(--transition);text-decoration:none;white-space:nowrap;line-height:1.2;position:relative;overflow:hidden}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-primary-sm)}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-primary)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--color-bg-tertiary);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-primary-bg);color:var(--color-primary);border-color:var(--color-primary-border)}.btn-danger{background:var(--color-danger-light);color:var(--color-danger)}.btn-danger:hover:not(:disabled){background:var(--color-danger);color:#fff;box-shadow:0 4px 12px #ef444440}.btn-ghost{background:none;color:var(--color-text-secondary);padding:8px 12px}.btn-ghost:hover:not(:disabled){background:var(--color-primary-bg);color:var(--color-primary)}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-md);border:none;display:flex;align-items:center;justify-content:center;background:var(--color-bg-tertiary);color:var(--color-text-secondary);cursor:pointer;transition:var(--transition)}.btn-icon:hover{background:var(--color-primary-bg);color:var(--color-primary)}.btn-icon.btn-danger{background:var(--color-danger-light);color:var(--color-danger)}.btn-icon.btn-danger:hover{background:var(--color-danger);color:#fff}.btn-sm{font-size:.8125rem;padding:6px 14px}.btn-lg{font-size:1rem;padding:14px 28px;border-radius:var(--radius-lg)}.welcome-banner{background:var(--gradient-primary);border-radius:var(--radius-2xl);padding:2rem 2.5rem;margin-bottom:2rem;font-family:var(--font-display);font-size:1.625rem;font-weight:700;color:#fff;box-shadow:var(--shadow-primary);position:relative;overflow:hidden;letter-spacing:-.02em}.welcome-banner:before{content:"";position:absolute;top:-60%;right:-15%;width:350px;height:350px;background:radial-gradient(circle,rgba(255,255,255,.15) 0%,transparent 70%);border-radius:50%;pointer-events:none}.welcome-banner:after{content:"";position:absolute;bottom:-40%;left:-10%;width:250px;height:250px;background:radial-gradient(circle,rgba(255,255,255,.08) 0%,transparent 70%);border-radius:50%;pointer-events:none}.form-group{margin-bottom:20px}.form-label{display:flex;align-items:center;gap:6px;font-size:.875rem;font-weight:600;color:var(--color-text-primary);margin-bottom:8px;letter-spacing:.01em}.form-input,.form-select,.form-textarea{width:100%;font-family:inherit;font-size:.9375rem;color:var(--color-text-primary);background:var(--color-bg-secondary);border:2px solid transparent;border-radius:var(--radius-md);padding:12px 16px;transition:var(--transition);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{background:var(--color-surface);border-color:var(--color-primary);box-shadow:0 0 0 4px #7c3aed1a}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-tertiary)}.form-textarea{resize:vertical;min-height:80px}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239ca3af' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;cursor:pointer}.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:32px;padding-top:24px;border-top:1px solid var(--color-border)}.badge{display:inline-flex;align-items:center;gap:4px;font-size:.6875rem;font-weight:700;padding:4px 12px;border-radius:var(--radius-full);letter-spacing:.02em;text-transform:uppercase}.badge-low{background:var(--gradient-success);color:var(--color-success-dark);border:1px solid #6ee7b7}.badge-medium{background:var(--gradient-primary-soft);color:var(--color-primary);border:1px solid var(--color-primary-border)}.badge-high{background:var(--gradient-warning);color:var(--color-warning-dark);border:1px solid #fbbf24}.badge-critical{background:var(--gradient-danger);color:var(--color-danger-dark);border:1px solid #f87171}.projects-grid{display:grid;gap:12px}.project-card{background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border);padding:20px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;transition:var(--transition);cursor:pointer;text-decoration:none;color:inherit;box-shadow:var(--shadow-xs);position:relative;overflow:hidden}.project-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary);transform:scaleX(0);transform-origin:left;transition:transform .35s ease}.project-card:hover:before{transform:scaleX(1)}.project-card:hover{box-shadow:var(--shadow-lg);border-color:#7c3aed26;transform:translateY(-2px)}.project-info{flex:1;min-width:0}.project-name{font-family:var(--font-display);font-size:1.0625rem;font-weight:700;color:var(--color-text-primary);margin-bottom:6px;letter-spacing:-.01em}.project-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.project-meta-item{font-size:.8125rem;color:var(--color-text-tertiary);display:inline-flex;align-items:center;gap:5px;padding:4px 10px;background:var(--color-bg-secondary);border-radius:var(--radius-sm);font-weight:500}.project-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.knowledge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.knowledge-card{padding:24px;position:relative;overflow:hidden}.knowledge-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary)}.knowledge-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px;gap:12px}.knowledge-header h3{font-family:var(--font-display);font-size:1.125rem;font-weight:700;color:var(--color-text-primary);margin:0;flex:1}.knowledge-description{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:16px;line-height:1.6}.knowledge-meta{display:grid;grid-template-columns:1fr 1fr;gap:12px}.meta-item{display:flex;flex-direction:column;gap:4px}.meta-label{font-size:.6875rem;font-weight:700;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.06em}.meta-value{font-size:.875rem;color:var(--color-text-primary);font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px}.stat-card{background:var(--color-surface);border-radius:var(--radius-xl);padding:24px;border:1px solid var(--color-border);box-shadow:var(--shadow-xs);position:relative;overflow:hidden;transition:var(--transition)}.stat-card:before{content:"";position:absolute;top:0;right:0;width:100px;height:100px;border-radius:50%;transform:translate(30%,-30%);opacity:.08;pointer-events:none}.stat-card:nth-child(1):before{background:#7c3aed}.stat-card:nth-child(2):before{background:#10b981}.stat-card:nth-child(3):before{background:#3b82f6}.stat-card:nth-child(4):before{background:#f59e0b}.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.stat-card-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}.stat-card-icon.purple{background:linear-gradient(135deg,#f5f3ff,#ede9fe);color:#7c3aed}.stat-card-icon.green{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#059669}.stat-card-icon.blue{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#2563eb}.stat-card-icon.orange{background:linear-gradient(135deg,#fed7aa,#fdba74);color:#c2410c}.stat-card-value{font-family:var(--font-display);font-size:2rem;font-weight:800;color:var(--color-text-primary);line-height:1;margin-bottom:6px;letter-spacing:-.03em}.stat-card-label{font-size:.8125rem;font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.04em}.empty-state{text-align:center;padding:64px 24px}.empty-state-icon{width:80px;height:80px;margin:0 auto 20px;color:var(--color-primary-light);opacity:.6}.empty-state h3{font-family:var(--font-display);font-size:1.375rem;font-weight:700;margin-bottom:8px;color:var(--color-text-primary)}.empty-state p{font-size:1rem;color:var(--color-text-secondary);margin-bottom:24px;max-width:360px;margin-left:auto;margin-right:auto;line-height:1.6}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px;background:var(--color-bg-page);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-30%;right:-20%;width:600px;height:600px;background:radial-gradient(circle,rgba(124,58,237,.06) 0%,transparent 70%);border-radius:50%;pointer-events:none}.login-page:after{content:"";position:absolute;bottom:-30%;left:-20%;width:500px;height:500px;background:radial-gradient(circle,rgba(59,130,246,.05) 0%,transparent 70%);border-radius:50%;pointer-events:none}.login-card{width:100%;max-width:400px;text-align:center;position:relative;z-index:1;background:var(--color-surface);border-radius:var(--radius-2xl);padding:48px 36px;box-shadow:var(--shadow-lg);border:1px solid var(--color-border)}.login-logo{width:56px;height:56px;margin:0 auto 24px;color:var(--color-primary);background:var(--gradient-primary-soft);border-radius:var(--radius-lg);padding:12px}.login-card h1{font-family:var(--font-display);font-size:1.875rem;font-weight:800;letter-spacing:-.03em;margin-bottom:6px;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-card p{font-size:.9375rem;color:var(--color-text-secondary);margin-bottom:32px}.login-card .form-group{text-align:left}.login-card .btn-primary{width:100%;padding:14px;font-size:1rem;margin-top:8px}.login-error{background:var(--color-danger-light);color:var(--color-danger);font-size:.8125rem;padding:12px 16px;border-radius:var(--radius-md);margin-bottom:16px;font-weight:600;border:1px solid #fca5a5}.analysis-section{margin-bottom:32px}.analysis-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary);margin-bottom:16px;display:flex;align-items:center;gap:8px}.analysis-section-title:after{content:"";flex:1;height:1px;background:var(--color-border)}.strategy-card{background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border);padding:28px;margin-bottom:16px;transition:var(--transition);box-shadow:var(--shadow-xs);position:relative;overflow:hidden}.strategy-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.strategy-card.best-match{border-color:var(--color-primary);background:linear-gradient(135deg,#fff,#faf5ff);box-shadow:var(--shadow-primary-sm)}.strategy-card.best-match:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient-primary)}.strategy-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.strategy-name{font-family:var(--font-display);font-size:1.25rem;font-weight:700;letter-spacing:-.02em}.strategy-score{font-family:var(--font-display);font-size:2rem;font-weight:800;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.strategy-description{font-size:.9375rem;color:var(--color-text-secondary);margin-bottom:20px;line-height:1.7}.strategy-details{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.strategy-detail{background:var(--color-bg-secondary);border-radius:var(--radius-md);padding:14px 18px;border:1px solid var(--color-border)}.strategy-detail-label{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-tertiary);margin-bottom:6px}.strategy-detail-value{font-family:var(--font-display);font-size:1.125rem;font-weight:700;color:var(--color-text-primary)}.scenarios-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:20px}.scenario-card{background:var(--color-bg-secondary);border-radius:var(--radius-lg);padding:18px;text-align:center;border:1px solid var(--color-border);transition:var(--transition)}.scenario-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.scenario-card.optimistic{background:var(--color-success-light);border-color:#6ee7b7}.scenario-card.pessimistic{background:var(--color-danger-light);border-color:#fca5a5}.scenario-label{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-tertiary);margin-bottom:6px}.scenario-value{font-family:var(--font-display);font-size:1.5rem;font-weight:800;color:var(--color-text-primary)}.scenario-desc{font-size:.75rem;color:var(--color-text-secondary);margin-top:6px;line-height:1.4}.params-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px}.param-item{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:var(--color-bg-secondary);border-radius:var(--radius-md);border:1px solid var(--color-border);transition:var(--transition)}.param-item:hover{background:var(--color-primary-bg);border-color:var(--color-primary-border)}.param-label{font-size:.8125rem;color:var(--color-text-secondary);font-weight:500}.param-value{font-size:.875rem;font-weight:700;color:var(--color-text-primary)}.similar-project{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--color-bg-secondary);border-radius:var(--radius-lg);margin-bottom:10px;border:1px solid var(--color-border);transition:var(--transition)}.similar-project:hover{background:var(--color-primary-bg);border-color:var(--color-primary-border)}.similar-project-info h4{font-family:var(--font-display);font-size:.9375rem;font-weight:700;margin-bottom:3px}.similar-project-info p{font-size:.75rem;color:var(--color-text-tertiary)}.similarity-score{font-family:var(--font-display);font-size:1.25rem;font-weight:800;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.key-factors{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.key-factor{background:var(--gradient-primary-soft);color:var(--color-primary);font-size:.8125rem;font-weight:600;padding:6px 16px;border-radius:var(--radius-full);border:1px solid var(--color-primary-border);transition:var(--transition)}.key-factor:hover{background:var(--color-primary-bg-hover)}.admin-table{width:100%;border-collapse:separate;border-spacing:0}.admin-table th{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary);padding:14px 16px;text-align:left;border-bottom:2px solid var(--color-border)}.admin-table td{font-size:.875rem;padding:16px;border-bottom:1px solid var(--color-border);color:var(--color-text-primary)}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--color-primary-bg)}.role-badge{font-size:.6875rem;font-weight:700;padding:4px 12px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.03em}.role-admin{background:var(--gradient-primary-soft);color:var(--color-primary);border:1px solid var(--color-primary-border)}.role-user{background:var(--color-bg-tertiary);color:var(--color-text-secondary);border:1px solid var(--color-border)}.modal-overlay{position:fixed;inset:0;background:#00000080;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:200;padding:24px;animation:fadeIn .2s ease}.modal{background:var(--color-surface);border-radius:var(--radius-2xl);padding:36px;width:100%;max-width:440px;box-shadow:var(--shadow-xl);animation:slideUp .3s ease;border:1px solid var(--color-border)}.modal h2{font-family:var(--font-display);font-size:1.375rem;font-weight:700;letter-spacing:-.02em;margin-bottom:24px}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh}.loading-spinner{width:36px;height:36px;border:3px solid var(--color-primary-bg);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.loading-inline{display:flex;align-items:center;justify-content:center;padding:48px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.animate-in{animation:fadeInUp .5s ease both}.animate-in:nth-child(1){animation-delay:.05s}.animate-in:nth-child(2){animation-delay:.1s}.animate-in:nth-child(3){animation-delay:.15s}.animate-in:nth-child(4){animation-delay:.2s}.animate-in:nth-child(5){animation-delay:.25s}.animate-in:nth-child(6){animation-delay:.3s}.animate-in:nth-child(7){animation-delay:.35s}.animate-in:nth-child(8){animation-delay:.4s}.skeleton{background:linear-gradient(90deg,#f3f4f6,#e5e7eb,#f3f4f6);background-size:1000px 100%;animation:shimmer 2s infinite;border-radius:var(--radius-md)}@media(max-width:768px){.header{padding:0 16px}.header-inner{gap:12px}.hamburger-btn{display:flex}.header-nav{position:absolute;top:var(--header-height);left:0;right:0;background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-direction:column;align-items:stretch;gap:4px;padding:12px;display:none;box-shadow:var(--shadow-lg)}.header-nav.mobile-open{display:flex}.header-nav a,.header-nav button{font-size:.875rem;padding:12px 16px;text-align:left;justify-content:flex-start;border-radius:var(--radius-md);margin:0}.add-project-btn{width:auto!important;border-radius:var(--radius-md)!important;justify-content:flex-start;padding:12px 16px!important}.add-project-btn:after{content:attr(title);margin-left:8px}.guide-btn{width:40px!important;height:40px!important;min-width:40px;min-height:40px;border-radius:50%!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:0!important;margin:8px auto 0!important;text-align:center}.guide-btn:after{display:none!important}.header-nav .lang-switcher{align-self:center;margin-top:8px}.header-nav .lang-btn{padding:4px 12px;font-size:.875rem}.lang-switcher:hover{background:var(--color-bg-tertiary)}.main-content{padding:20px 16px}.page-header h1{font-size:1.5rem}.page-header p{font-size:.875rem}.form-grid,.scenarios-grid,.params-grid,.strategy-details{grid-template-columns:1fr}.project-card{flex-direction:column;align-items:flex-start}.project-actions{width:100%;justify-content:flex-end}.admin-table{display:block}.admin-table thead{display:none}.admin-table tbody{display:block}.admin-table tr{display:block;margin-bottom:1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1rem}.admin-table td{display:block;text-align:left;padding:.5rem 0;border:none}.admin-table td:before{content:attr(data-label);font-weight:600;color:var(--color-text-secondary);display:block;margin-bottom:.25rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.admin-table td:last-child{padding-top:1rem;border-top:1px solid var(--color-border);margin-top:.5rem}.knowledge-grid{grid-template-columns:1fr}}@media(max-width:640px){.header-logo{font-size:.9375rem}.header-nav{flex-wrap:wrap}.welcome-banner{font-size:1.25rem;padding:1.25rem 1.5rem;margin-bottom:1rem;order:1}.main-content{display:flex;flex-direction:column}.page-header{order:-1}.stats-grid{order:3;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px}.stat-card{padding:14px;border-radius:var(--radius-lg)}.stat-card-icon{width:32px;height:32px;border-radius:8px;margin-bottom:8px}.stat-card-icon svg{width:16px;height:16px}.stat-card-value{font-size:1.25rem;margin-bottom:2px}.stat-card-label{font-size:.7rem}.projects-grid,.empty-state{order:4}.toolbar{flex-direction:column;align-items:stretch;gap:.75rem}.toolbar>div:last-child{display:flex;flex-direction:column;gap:.5rem;width:100%}.toolbar .btn{width:100%;justify-content:center;font-size:.875rem;padding:10px 16px}.page-header h1{font-size:1.375rem}.card{padding:1rem;border-radius:var(--radius-lg);width:100%;box-sizing:border-box}#root,body,.app-container{max-width:100vw;overflow-x:hidden}.forecast-container{padding:0;width:100%;max-width:100%;overflow-x:hidden;box-sizing:border-box}.forecast-controls{width:100%;max-width:100%;box-sizing:border-box}.forecast-controls .btn{width:100%!important;margin-top:1rem;box-sizing:border-box}.form-grid{display:grid;grid-template-columns:1fr!important;gap:1rem;width:100%;box-sizing:border-box}.form-grid>*{min-width:0}.table-container{display:block;width:100%;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:20px;border:1px solid var(--border-color);border-radius:var(--radius-md)}.forecast-table{min-width:600px;width:100%}.form-input,.form-select,.btn,.form-group input,.form-group select{width:100%!important;max-width:100%!important;box-sizing:border-box;min-width:0}.formula-display{overflow-x:auto;width:100%;max-width:100%;display:block}.formula-display code{white-space:nowrap;display:block;min-width:max-content;padding-right:1rem}.modal{width:95%;max-width:none;margin:1rem;max-height:calc(100vh - 2rem)}.modal h2{font-size:1.25rem}.form-actions{flex-direction:column-reverse;gap:.75rem}.form-actions .btn{width:100%}.btn{min-height:44px}.btn-icon{width:40px;height:40px}.project-card{padding:1rem}.project-meta{flex-wrap:wrap;gap:.5rem}.strategy-card{padding:1.25rem}.strategy-header h3{font-size:1rem}.empty-state{padding:2rem 1rem}.empty-state h3{font-size:1.125rem}.login-card{padding:32px 24px}}.toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.progress-bar{height:6px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;border-radius:var(--radius-full);background:var(--gradient-primary);transition:width .6s cubic-bezier(.4,0,.2,1)}.progress-fill.success{background:linear-gradient(90deg,#34d399,#10b981)}.progress-fill.warning{background:linear-gradient(90deg,#fbbf24,#f59e0b)}.progress-fill.danger{background:linear-gradient(90deg,#f87171,#ef4444)}.no-analysis{text-align:center;padding:56px 24px;background:var(--gradient-primary-soft);border-radius:var(--radius-xl);border:2px dashed var(--color-primary-border)}.no-analysis p{font-size:1rem;color:var(--color-text-secondary);margin-bottom:20px;max-width:400px;margin-left:auto;margin-right:auto;line-height:1.6}.guide-page{max-width:900px;margin:0 auto}.guide-page .page-title{margin-bottom:8px}.guide-page .page-subtitle{margin-bottom:40px;color:var(--color-text-secondary);font-size:1.05rem}.guide-section{position:relative;background:var(--color-surface);border-radius:var(--radius-xl);padding:40px;margin-bottom:28px;margin-top:12px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.guide-section-number{position:absolute;top:-16px;left:32px;width:36px;height:36px;background:var(--gradient-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:.95rem;box-shadow:var(--shadow-primary-sm)}.guide-section-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--color-text);margin-bottom:12px}.guide-text{color:var(--color-text-secondary);line-height:1.7;margin-bottom:24px}.guide-steps{display:flex;flex-direction:column;gap:16px;margin-bottom:28px}.guide-step{display:flex;align-items:flex-start;gap:16px}.guide-step-badge{width:40px;height:40px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--color-primary-bg);color:var(--color-primary);border-radius:12px}.guide-step strong{display:block;font-weight:600;color:var(--color-text);margin-bottom:4px}.guide-step p{color:var(--color-text-secondary);font-size:.92rem;line-height:1.5}.guide-screenshot{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-border);margin-top:20px}.guide-screenshot img{width:100%;display:block}.guide-screenshot-caption{display:block;text-align:center;padding:10px;font-size:.85rem;color:var(--color-text-muted);background:var(--color-bg)}.guide-params-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;margin-bottom:24px}.guide-param-card{display:flex;align-items:flex-start;gap:12px;padding:14px;background:var(--color-bg);border-radius:var(--radius-md);border:1px solid var(--color-border-light)}.guide-param-icon{font-size:1.4rem;flex-shrink:0;margin-top:2px}.guide-param-card strong{display:block;font-size:.92rem;font-weight:600;color:var(--color-text);margin-bottom:2px}.guide-param-card p{font-size:.82rem;color:var(--color-text-muted);line-height:1.4}.guide-info-box{display:flex;align-items:flex-start;gap:12px;padding:16px;background:var(--color-primary-bg);border-radius:var(--radius-md);border:1px solid var(--color-primary-border)}.guide-info-box svg{flex-shrink:0;margin-top:2px}.guide-info-box p{font-size:.92rem;color:var(--color-primary-dark);line-height:1.6}.guide-mechanisms{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:28px}.guide-mechanism-card{background:var(--color-bg);border-radius:var(--radius-lg);padding:24px 20px;border:1px solid var(--color-border-light);text-align:center}.guide-mechanism-icon{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}.guide-mechanism-icon.rule-based{background:#f5f3ff;color:#7c3aed}.guide-mechanism-icon.case-based{background:#ecfdf5;color:#059669}.guide-mechanism-icon.scenario{background:#fff7ed;color:#d97706}.guide-mechanism-card h3{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--color-text);margin-bottom:8px}.guide-mechanism-card p{font-size:.85rem;color:var(--color-text-secondary);line-height:1.5;margin-bottom:14px}.guide-mechanism-weight{font-family:var(--font-display);font-size:1.4rem;font-weight:700;color:var(--color-primary)}.guide-response-flow{margin-bottom:28px}.guide-flow-step{display:flex;align-items:flex-start;gap:16px;padding:16px;background:var(--color-bg);border-radius:var(--radius-md);border:1px solid var(--color-border-light)}.guide-flow-number{width:32px;height:32px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);color:#fff;border-radius:50%;font-family:var(--font-display);font-weight:700;font-size:.85rem}.guide-flow-step strong{display:block;font-weight:600;color:var(--color-text);margin-bottom:4px}.guide-flow-step p{font-size:.9rem;color:var(--color-text-secondary);line-height:1.5}.guide-flow-connector{width:2px;height:20px;background:var(--color-primary-border);margin:0 auto}.guide-accuracy-box{background:var(--color-bg);border-radius:var(--radius-lg);padding:24px;border:1px solid var(--color-border-light);margin-bottom:28px}.guide-accuracy-box h3{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--color-text);margin-bottom:8px}.guide-accuracy-box>p{font-size:.92rem;color:var(--color-text-secondary);margin-bottom:16px}.guide-accuracy-factors{display:flex;flex-direction:column;gap:10px}.guide-accuracy-factor{display:flex;align-items:center;gap:10px;font-size:.9rem;color:var(--color-text-secondary)}.guide-accuracy-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.guide-accuracy-icon.good{background:#ecfdf5;color:#059669}.guide-accuracy-icon.warn{background:#fff7ed;color:#d97706}.guide-accuracy-icon.forecast-future{color:var(--primary-color);font-weight:600}.forecast-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin:1.5rem 0;padding:1rem;background:var(--surface-color);border-radius:8px;border:1px solid var(--border-color)}.summary-item{display:flex;flex-direction:column;gap:.5rem}.summary-label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.summary-value{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.forecast-highlight{color:var(--primary-color)}@media(max-width:768px){.guide-section{padding:28px 20px}.guide-mechanisms,.guide-params-grid{grid-template-columns:1fr}.forecast-container{padding:1rem}.forecast-metrics,.forecast-controls .form-grid,.forecast-summary,.forecast-insights{grid-template-columns:1fr}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}}.forecast-container{max-width:1200px;margin:0 auto}.forecast-controls{margin-bottom:24px}.forecast-controls h3{margin-bottom:20px;color:var(--color-text-primary)}.forecast-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.metric-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:20px;text-align:center;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s}.metric-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.metric-label{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:8px;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.metric-value{font-size:2rem;font-weight:700;color:var(--color-primary);margin-bottom:4px}.metric-unit{font-size:.75rem;color:var(--color-text-tertiary)}.forecast-insights{margin-bottom:24px}.forecast-insights h3{margin-bottom:16px;color:var(--color-text-primary)}.insight-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:16px 20px;margin-bottom:12px;border-left:4px solid var(--color-info)}.insight-card.insight-success{border-left-color:var(--color-success);background:linear-gradient(to right,var(--color-success-light),var(--color-surface))}.insight-card.insight-warning{border-left-color:var(--color-warning);background:linear-gradient(to right,var(--color-warning-light),var(--color-surface))}.insight-card.insight-info{border-left-color:var(--color-info);background:linear-gradient(to right,var(--color-info-light),var(--color-surface))}.insight-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.insight-title{font-weight:600;color:var(--color-text-primary)}.insight-value{font-size:1.25rem;font-weight:700;color:var(--color-primary)}.insight-description{margin:0;color:var(--color-text-secondary);font-size:.875rem}.forecast-table{width:100%;border-collapse:collapse;font-size:.875rem}.forecast-table thead{background:var(--color-bg-secondary);border-bottom:2px solid var(--color-border)}.forecast-table th{padding:12px 16px;text-align:left;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;font-size:.75rem;letter-spacing:.05em}.forecast-table td{padding:10px 16px;border-bottom:1px solid var(--color-border)}.forecast-table tbody tr:hover{background:var(--color-bg-secondary);transition:background .15s}.forecast-table .future-row{background:var(--color-primary-bg);font-weight:500}.forecast-table .forecast-future{color:var(--color-primary);font-weight:600}.formula-display{margin-top:24px}.formula-display h3{margin-bottom:16px;color:var(--color-text-primary)}.formula-display code{display:block;background:var(--color-bg-secondary);padding:12px 16px;border-radius:var(--radius-md);font-family:Courier New,monospace;font-size:.875rem;margin:8px 0;border-left:3px solid var(--color-primary)}.saved-runs-list{display:flex;flex-direction:column;gap:12px}.saved-run-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--color-bg-secondary);border-radius:var(--radius-md);border:1px solid var(--color-border)}.saved-run-metrics{display:flex;gap:16px;font-size:.875rem;color:var(--color-text-secondary)}.table-container{overflow-x:auto;margin-top:16px}@media(max-width:768px){.forecast-metrics{grid-template-columns:1fr}.metric-value{font-size:1.5rem}.insight-header{flex-direction:column;align-items:flex-start;gap:8px}.forecast-table{font-size:.75rem;min-width:600px}.forecast-table th,.forecast-table td{padding:6px 8px;font-size:.75rem}.saved-run-item{flex-direction:column;align-items:flex-start;gap:8px}.metric-card{min-width:unset}.summary-value{font-size:1.1rem}}@media(max-width:640px){.toolbar{flex-direction:column;align-items:stretch;gap:.75rem;text-align:left}.toolbar>div:first-child h1{text-align:left}}
