*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary-50: #f4f6fb;--primary-100: #e7ecf6;--primary-200: #c4d1e8;--primary-300: #93aeda;--primary-400: #5f86c7;--primary-500: #3b63b0;--primary-600: #294c92;--primary-700: #223e78;--primary-800: #1b2c55;--primary-900: #131b34;--primary-950: #0a0e1c;--accent-50: #fff5f2;--accent-100: #ffe6e0;--accent-200: #ffc9ba;--accent-300: #ffa28a;--accent-400: #ff7455;--accent-500: #ff4a22;--accent-600: #ed3209;--success-50: #f0fdf6;--success-100: #dcfce9;--success-400: #4ade80;--success-500: #22c55e;--success-600: #16a34a;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--warning-100: #fefce8;--warning-500: #eab308;--danger-100: #fef2f2;--danger-500: #ef4444;--font-sans: "Inter", "Noto Sans SC", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--radius-sm: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--radius-2xl: 2rem;--radius-full: 9999px;--shadow-sm: 0 2px 4px rgba(15, 23, 42, .04), 0 1px 2px rgba(15, 23, 42, .02);--shadow-md: 0 4px 12px rgba(15, 23, 42, .05), 0 2px 4px rgba(15, 23, 42, .03);--shadow-lg: 0 12px 24px rgba(15, 23, 42, .06), 0 4px 8px rgba(15, 23, 42, .04);--shadow-xl: 0 24px 48px rgba(15, 23, 42, .08), 0 8px 16px rgba(15, 23, 42, .04);--shadow-glow-primary: 0 8px 20px -4px rgba(59, 99, 176, .4);--shadow-glow-accent: 0 8px 20px -4px rgba(255, 74, 34, .4);--bg-app: #f4f6fb;--bg-card: rgba(255, 255, 255, .85);--bg-card-hover: rgba(255, 255, 255, .95);--border-glass: rgba(255, 255, 255, .5);--border-light: rgba(148, 163, 184, .15);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-smooth: .4s cubic-bezier(.16, 1, .3, 1)}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);color:var(--gray-800);background:var(--bg-app);background-image:radial-gradient(circle at 15% 50%,rgba(59,99,176,.04) 0%,transparent 50%),radial-gradient(circle at 85% 30%,rgba(255,74,34,.04) 0%,transparent 50%);min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}.page-container{max-width:800px;margin:0 auto;padding:var(--space-6) var(--space-4);padding-bottom:120px;width:100%;flex:1}.card{background:var(--bg-card);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-glass);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-md);transition:all var(--transition-smooth);position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.8),transparent);opacity:.5}.card:hover{background:var(--bg-card-hover);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.page-title{font-size:var(--font-size-3xl);font-weight:800;color:var(--primary-900);margin-bottom:var(--space-2);letter-spacing:-.03em;line-height:1.2}.page-subtitle{font-size:var(--font-size-base);color:var(--gray-500);margin-bottom:var(--space-8);line-height:1.6;max-width:90%}.section-title{font-size:var(--font-size-xl);font-weight:700;color:var(--gray-900);margin-bottom:var(--space-5);display:flex;align-items:center;gap:var(--space-3);letter-spacing:-.01em}.section-title:before{content:"";display:inline-block;width:5px;height:1.4em;background:linear-gradient(180deg,var(--accent-400),var(--accent-600));border-radius:var(--radius-full)}.form-group{margin-bottom:var(--space-6)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:600;color:var(--gray-700);margin-bottom:var(--space-2);letter-spacing:.01em}.form-label .required{color:var(--accent-500);margin-left:var(--space-1)}.form-input{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--font-size-base);font-family:var(--font-sans);color:var(--gray-900);background:#ffffffb3;border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:inset 0 2px 4px #00000005;outline:none;transition:all var(--transition-base)}.form-input:hover{background:#ffffffe6;border-color:#5f86c766}.form-input:focus{background:#fff;border-color:var(--primary-400);box-shadow:0 0 0 4px #3b63b026,inset 0 1px 2px #00000003;transform:translateY(-1px)}.form-input::placeholder{color:var(--gray-400);transition:opacity var(--transition-fast)}.form-input:focus::placeholder{opacity:.6}.form-input.error{border-color:var(--danger-500);box-shadow:0 0 0 4px #ef444426;animation:shake .4s cubic-bezier(.36,.07,.19,.97) both}@keyframes shake{10%,90%{transform:translate3d(-1px,0,0)}20%,80%{transform:translate3d(2px,0,0)}30%,50%,70%{transform:translate3d(-3px,0,0)}40%,60%{transform:translate3d(3px,0,0)}}.form-textarea{resize:vertical;min-height:120px;line-height:1.6}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:var(--font-size-base);font-weight:600;font-family:var(--font-sans);border:none;border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;letter-spacing:.01em}.btn:active:not(:disabled){transform:scale(.96)}.btn:disabled{opacity:.6;cursor:not-allowed;filter:grayscale(.5)}.btn-primary{background:linear-gradient(135deg,var(--accent-400),var(--accent-600));color:#fff;box-shadow:var(--shadow-glow-accent)}.btn-primary:hover:not(:disabled){box-shadow:0 12px 24px -6px #ff4a2280;transform:translateY(-2px)}.btn-secondary{background:#fff;color:var(--primary-700);border:1px solid var(--primary-200);box-shadow:var(--shadow-sm)}.btn-secondary:hover:not(:disabled){background:var(--primary-50);border-color:var(--primary-300);transform:translateY(-1px)}.btn-accent{background:linear-gradient(135deg,var(--success-400),var(--success-600));color:#fff;box-shadow:0 8px 16px -4px #22c55e66}.btn-accent:hover:not(:disabled){box-shadow:0 12px 24px -6px #22c55e80;transform:translateY(-2px)}.btn-danger{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#dc2626;border:1.5px solid rgba(239,68,68,.3);font-weight:700}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#fecaca,#fca5a5);border-color:var(--danger-500);box-shadow:0 4px 12px #ef444433;transform:translateY(-1px)}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);border-radius:var(--radius-md)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--font-size-lg);border-radius:var(--radius-xl)}.btn-block{width:100%}.btn-icon{width:36px;height:36px;padding:0;border-radius:var(--radius-md);font-size:var(--font-size-lg)}.badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs);font-weight:600;border-radius:var(--radius-full)}.badge-primary{background:var(--primary-100);color:var(--primary-700)}.badge-accent{background:var(--accent-100);color:var(--accent-600)}.badge-warning{background:var(--warning-100);color:var(--warning-600)}.badge-danger{background:var(--danger-100);color:var(--danger-600)}.badge-high{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#b91c1c}.badge-medium{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.badge-low{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46}.list-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);background:#fff9;border:1px solid var(--border-light);border-radius:var(--radius-xl);margin-bottom:var(--space-3);transition:all var(--transition-base)}.list-item:hover{background:#fffffff2;border-color:var(--primary-200);box-shadow:var(--shadow-sm);transform:translate(2px)}.list-item-content{display:flex;align-items:center;gap:var(--space-4);flex:1;min-width:0}.list-item-number{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--primary-100);color:var(--primary-700);font-size:var(--font-size-sm);font-weight:700;border-radius:var(--radius-full);flex-shrink:0}.list-item-name{font-size:var(--font-size-lg);font-weight:600;color:var(--gray-900);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-item-actions{display:flex;gap:var(--space-2);flex-shrink:0}.tip-bar{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:#f4f6fbd9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--primary-200);border-radius:var(--radius-xl);margin-bottom:var(--space-6);box-shadow:inset 0 2px 4px #ffffff80}.tip-bar-icon{font-size:var(--font-size-xl);flex-shrink:0;margin-top:2px}.tip-bar-text{font-size:var(--font-size-base);color:var(--primary-900);font-weight:500;line-height:1.6}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) var(--space-6);text-align:center;background:#fff6;border:1px dashed var(--gray-300);border-radius:var(--radius-xl);margin:var(--space-6) 0}.empty-state-icon{font-size:3.5rem;margin-bottom:var(--space-5);opacity:.6}.empty-state-text{font-size:var(--font-size-base);color:var(--gray-500);font-weight:500}.divider{height:1px;background:linear-gradient(90deg,transparent,var(--gray-200),transparent);margin:var(--space-6) 0}.tabs{display:flex;background:#ffffff80;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border-light);border-radius:var(--radius-xl);padding:4px;margin-bottom:var(--space-6);overflow-x:auto;box-shadow:inset 0 2px 4px #00000005}.tab{flex:1;padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);font-weight:600;color:var(--gray-500);background:transparent;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;font-family:var(--font-sans);text-align:center;letter-spacing:.01em}.tab.active{background:#fff;color:var(--primary-700);box-shadow:var(--shadow-sm)}.tab:hover:not(.active){color:var(--gray-800);background:#ffffff4d}.spinner{width:48px;height:48px;border:3px solid var(--primary-100);border-top-color:var(--accent-500);border-right-color:var(--primary-400);border-radius:50%;animation:spin .8s cubic-bezier(.4,0,.2,1) infinite;position:relative}.spinner:after{content:"";position:absolute;top:5px;right:5px;bottom:5px;left:5px;border:3px solid transparent;border-top-color:var(--primary-300);border-radius:50%;animation:spin 1.2s cubic-bezier(.4,0,.2,1) infinite reverse}@keyframes spin{to{transform:rotate(360deg)}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) var(--space-4);gap:var(--space-4)}.loading-text{font-size:var(--font-size-base);color:var(--gray-600);font-weight:600;letter-spacing:.01em}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:var(--space-4)}.modal-content{background:#fff;border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;width:100%;max-width:640px;max-height:80vh;overflow-y:auto;padding:var(--space-6);animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-5)}.modal-title{font-size:var(--font-size-xl);font-weight:700;color:var(--gray-900)}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--gray-100);border:none;border-radius:var(--radius-full);cursor:pointer;font-size:var(--font-size-lg);color:var(--gray-500);transition:all var(--transition-fast)}.modal-close:hover{background:var(--gray-200);color:var(--gray-700)}.toast{position:fixed;top:var(--space-5);left:50%;transform:translate(-50%);padding:var(--space-3) var(--space-6);background:var(--gray-800);color:#fff;font-size:var(--font-size-sm);font-weight:600;border-radius:var(--radius-full);box-shadow:var(--shadow-xl);z-index:200;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);letter-spacing:.01em}.toast-success{background:linear-gradient(135deg,var(--success-500),var(--success-600))}.toast-error{background:linear-gradient(135deg,#ef4444,#dc2626)}.analysis-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-lg);border:1px solid var(--gray-200);margin-bottom:var(--space-5)}.analysis-table{width:100%;min-width:600px;border-collapse:collapse;font-size:var(--font-size-sm)}.analysis-table th{padding:var(--space-3) var(--space-3);background:var(--gray-50);font-weight:600;color:var(--gray-600);text-align:left;border-bottom:2px solid var(--gray-200);white-space:nowrap;position:sticky;top:0}.analysis-table td{padding:var(--space-3);border-bottom:1px solid var(--gray-100);vertical-align:top}.analysis-table tr:last-child td{border-bottom:none}.analysis-table tr:hover td{background:var(--gray-50)}.analysis-table .cell-input{width:100%;padding:var(--space-2);font-size:var(--font-size-sm);border:1px solid var(--gray-200);border-radius:var(--radius-sm);font-family:var(--font-sans);outline:none;transition:border-color var(--transition-fast)}.analysis-table .cell-input:focus{border-color:var(--primary-400)}.analysis-table .cell-select{padding:var(--space-2);font-size:var(--font-size-sm);border:1px solid var(--gray-200);border-radius:var(--radius-sm);background:#fff;cursor:pointer;font-family:var(--font-sans);outline:none}.analysis-table .stakeholder-name{font-weight:600;color:var(--primary-700);white-space:nowrap}.ai-card{padding:var(--space-4);background:#fff;border:1px solid var(--gray-100);border-radius:var(--radius-lg);margin-bottom:var(--space-3);transition:all var(--transition-fast)}.ai-card:hover{box-shadow:var(--shadow-md)}.ai-card-header{display:flex;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-3)}.ai-card-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);font-size:var(--font-size-base);flex-shrink:0}.ai-card-icon.issue{background:var(--warning-100)}.ai-card-icon.suggestion{background:var(--primary-100)}.ai-card-icon.strategy{background:var(--accent-100)}.ai-card-title{font-size:var(--font-size-base);font-weight:600;color:var(--gray-800)}.ai-card-target{font-size:var(--font-size-xs);color:var(--gray-500);margin-top:var(--space-1)}.ai-card-body{font-size:var(--font-size-sm);color:var(--gray-600);line-height:1.7;margin-bottom:var(--space-3)}.ai-card-actions{display:flex;gap:var(--space-2);justify-content:flex-end}.ai-card.adopted{border-color:var(--accent-200);background:var(--accent-50)}.ai-card.ignored{opacity:.5}.report-section{margin-bottom:var(--space-6)}.report-section-title{font-size:var(--font-size-base);font-weight:600;color:var(--gray-700);padding-bottom:var(--space-2);border-bottom:2px solid var(--primary-100);margin-bottom:var(--space-4)}.report-info-grid{display:grid;grid-template-columns:auto 1fr;gap:var(--space-2) var(--space-4);font-size:var(--font-size-sm)}.report-info-label{color:var(--gray-500);font-weight:500}.report-info-value{color:var(--gray-800)}.matrix-container{background:#fff;border-radius:var(--radius-lg);padding:var(--space-4);border:1px solid var(--gray-200);margin-bottom:var(--space-5)}.matrix-title{font-size:var(--font-size-base);font-weight:600;color:var(--gray-700);text-align:center;margin-bottom:var(--space-3)}.step-indicator{display:flex;align-items:center;justify-content:center;gap:var(--space-2);margin-bottom:var(--space-6)}.step-dot{width:8px;height:8px;border-radius:var(--radius-full);background:var(--gray-200);transition:all var(--transition-smooth)}.step-dot.active{width:28px;background:linear-gradient(135deg,var(--accent-400),var(--accent-600));box-shadow:0 2px 8px #ff4a224d}.step-dot.completed{background:var(--accent-500);box-shadow:0 1px 4px #ff4a2233}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid var(--gray-100);padding:var(--space-3) var(--space-4);padding-bottom:max(var(--space-3),env(safe-area-inset-bottom));z-index:50}.bottom-nav-inner{max-width:640px;margin:0 auto;display:flex;gap:var(--space-3)}.settings-group{margin-bottom:var(--space-5)}.settings-group-title{font-size:var(--font-size-sm);font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-3)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease-out}@media (min-width: 768px){.page-container{padding:var(--space-8);padding-bottom:120px}.modal-content{border-radius:var(--radius-2xl);margin-bottom:var(--space-4)}.modal-overlay{align-items:center}}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.export-options{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-5)}.export-option{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--gray-50);border:1.5px solid var(--gray-200);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.export-option:hover{border-color:var(--primary-300);background:var(--primary-50)}.export-option.selected{border-color:var(--primary-400);background:var(--primary-50)}.export-option-icon{font-size:1.5rem}.export-option-info{flex:1}.export-option-title{font-size:var(--font-size-base);font-weight:600;color:var(--gray-800)}.export-option-desc{font-size:var(--font-size-xs);color:var(--gray-500)}.checkbox-wrapper{display:flex;align-items:center;gap:var(--space-2);cursor:pointer}.checkbox-wrapper input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary-500);cursor:pointer}.checkbox-label{font-size:var(--font-size-sm);color:var(--gray-700)}.strategy-card{padding:var(--space-4) var(--space-5);background:linear-gradient(135deg,#f4f6fbcc,#fff5f280);border:1px solid var(--primary-100);border-radius:var(--radius-lg);transition:all var(--transition-base);position:relative;overflow:hidden}.strategy-card:before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:linear-gradient(180deg,var(--accent-400),var(--primary-400));border-radius:0 var(--radius-full) var(--radius-full) 0}.strategy-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.strategy-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3)}.strategy-quadrant{font-size:var(--font-size-xs);font-weight:700;padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm)}.strategy-name{font-size:var(--font-size-base);font-weight:700;color:var(--gray-800)}.strategy-detail{display:flex;align-items:flex-start;gap:var(--space-2);margin-bottom:var(--space-2);font-size:var(--font-size-sm);color:var(--gray-600);line-height:1.6}.strategy-detail-label{font-weight:600;color:var(--gray-700);flex-shrink:0}
