/* GAIKO LAB 外構見積シミュレーター - Styles v3.1 */
/* Extracted from gaiko-simulator.js for performance optimization */

* { box-sizing: border-box; margin: 0; padding: 0; }
.sim-root { font-family: 'DM Sans', sans-serif; background: #F7F4EF; min-height: 100vh; color: #3B352C; -webkit-font-smoothing: antialiased; }
.sim-body { padding: 24px 16px 160px; max-width: 680px; margin: 0 auto; }
@media (min-width: 768px) { .sim-body { padding: 32px 32px 160px; } }
.sim-intro { background: #1A2530; border-radius: 14px; padding: 28px 24px; margin-bottom: 22px; }
.sim-intro-en { font-family: 'Cormorant Garamond', serif; font-size: 22px; letter-spacing: 0.18em; color: #C5A059; font-weight: 600; margin-bottom: 4px; }
.sim-intro-jp { font-size: 13px; font-weight: 600; color: rgba(255,255,255,0.7); letter-spacing: 0.05em; margin-bottom: 16px; }
.sim-intro-sep { height: 1px; background: rgba(255,255,255,0.12); margin-bottom: 16px; }
.sim-intro-body { font-size: 13px; color: rgba(255,255,255,0.75); line-height: 1.9; }
.sim-intro-note { font-size: 11px; color: rgba(255,255,255,0.38); margin-top: 12px; display: flex; align-items: center; gap: 6px; }
.sim-header { background: #1A2530; padding: 14px 16px 0; position: sticky; top: 0; z-index: 99; }
.sim-header-row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.sim-logo { font-family: 'Cormorant Garamond', serif; color: #FFF; font-size: 16px; letter-spacing: 0.15em; display: flex; align-items: center; gap: 8px; }
.sim-logo-badge { font-size: 9px; color: #C5A059; border: 1px solid #C5A059; padding: 2px 6px; border-radius: 2px; font-family: 'DM Sans', sans-serif; letter-spacing: 0.08em; }
.sim-step-num { font-size: 11px; color: rgba(255,255,255,0.45); }
.sim-step-num strong { font-size: 14px; color: #C5A059; font-weight: 600; }
.sim-progress { height: 2px; background: rgba(255,255,255,0.1); }
.sim-progress-fill { height: 100%; background: #C5A059; transition: width 0.35s ease; }
.sim-step-head { margin-bottom: 18px; }
.sim-step-title { font-family: 'Cormorant Garamond', serif; font-size: 26px; font-weight: 600; color: #1A2530; line-height: 1.2; }
.sim-step-sub { font-size: 12px; color: #7A7368; margin-top: 7px; line-height: 1.75; }
.sim-step-sub strong { color: #3B352C; }
.sim-skip { width: 100%; padding: 16px 20px; background: #FFF; border: 2px dashed #C5A059; border-radius: 12px; color: #9A7A2E; font-size: 14px; font-weight: 600; font-family: inherit; cursor: pointer; margin-bottom: 22px; letter-spacing: 0.02em; transition: background 0.15s; text-align: center; }
.sim-skip:hover { background: #FDF8EF; }
.sim-card { background: #FFF; border: 1px solid #DDD8CE; border-radius: 14px; padding: 20px; margin-bottom: 14px; }
.sim-card-title { font-size: 13px; font-weight: 700; color: #1A2530; margin-bottom: 16px; padding-bottom: 12px; border-bottom: 1px solid #F0EBE1; display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.sim-card-title-text { flex: 1; }
.sim-clear-btn { font-size: 11px; color: #7A7368; background: none; border: 1px solid #DDD8CE; border-radius: 99px; padding: 4px 12px; cursor: pointer; font-family: inherit; font-weight: 400; white-space: nowrap; flex-shrink: 0; }
.sim-clear-btn:hover { border-color: #8A4A4A; color: #8A4A4A; }
.sim-row-item { background: #F7F4EF; border: 1px solid #DDD8CE; border-radius: 10px; padding: 14px; padding-right: 44px; margin-bottom: 10px; position: relative; }
.sim-row-label { font-size: 10px; font-weight: 700; color: #C5A059; letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 12px; }
.sim-row-del { position: absolute; top: 12px; right: 12px; width: 28px; height: 28px; border: 1px solid #DDD8CE; background: #FFF; border-radius: 6px; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 16px; color: #7A7368; line-height: 1; }
.sim-row-del:hover { background: #FFF8F8; border-color: #E6C9C9; color: #8A4A4A; }
.sim-add-btn { width: 100%; padding: 13px; border: 1.5px dashed #DDD8CE; border-radius: 10px; background: none; color: #7A7368; font-size: 13px; font-family: inherit; cursor: pointer; margin-top: 6px; transition: all 0.15s; }
.sim-add-btn:hover { border-color: #C5A059; color: #9A7A2E; background: #FFFDF7; }
.sim-label { font-size: 12px; font-weight: 600; color: #3B352C; margin-bottom: 8px; display: block; }
.sim-hint { font-size: 11px; color: #7A7368; margin: -4px 0 10px; line-height: 1.6; }
.sim-error { display: flex; align-items: flex-start; gap: 8px; background: #FFF5F5; border: 1.5px solid #E8A0A0; border-radius: 8px; padding: 10px 14px; margin-top: 8px; margin-bottom: 4px; font-size: 12px; color: #8A3030; line-height: 1.6; }
.sim-error-icon { font-size: 14px; flex-shrink: 0; margin-top: 1px; }
.sim-select { width: 100%; height: 52px; padding: 0 40px 0 14px; border: 1.5px solid #DDD8CE; border-radius: 8px; font-family: 'DM Sans', sans-serif; font-size: 15px; background: #FFF; color: #3B352C; -webkit-appearance: none; appearance: none; cursor: pointer; background-image: url('data:image/svg+xml,%3Csvg xmlns=%22http://www.w3.org/2000/svg%22 width=%2212%22 height=%228%22 viewBox=%220 0 12 8%22%3E%3Cpath d=%22M1 1l5 5 5-5%22 stroke=%22%237A7368%22 stroke-width=%221.5%22 fill=%22none%22/%3E%3C/svg%3E'); background-repeat: no-repeat; background-position: right 14px center; background-size: 12px; margin-bottom: 12px; }
.sim-select:focus { outline: none; border-color: #C5A059; }
.sim-stepper { display: flex; align-items: center; border: 1.5px solid #DDD8CE; border-radius: 8px; overflow: hidden; background: #FFF; margin-bottom: 12px; }
.sim-stepper-btn { width: 52px; height: 52px; background: none; border: none; cursor: pointer; font-size: 22px; color: #C5A059; display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: background 0.1s; }
.sim-stepper-btn:active { background: #F0EBE1; }
.sim-stepper-val { flex: 1; text-align: center; font-size: 18px; font-weight: 500; color: #3B352C; }
.sim-stepper-unit { font-size: 12px; color: #7A7368; padding-right: 14px; }
.sim-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; }
.sim-chip { padding: 10px 16px; border: 2px solid #DDD8CE; border-radius: 99px; background: #FFF; color: #3B352C; font-size: 13px; font-family: inherit; cursor: pointer; transition: all 0.12s; font-weight: 400; line-height: 1; }
.sim-chip.active { border-color: #C5A059; background: #FDF8EF; color: #1A2530; font-weight: 600; }
.sim-check { display: flex; align-items: center; gap: 12px; padding: 14px; border: 1.5px solid #DDD8CE; border-radius: 10px; cursor: pointer; margin-bottom: 10px; background: #FFF; transition: all 0.12s; }
.sim-check.on { border-color: #C5A059; background: #FDF8EF; }
.sim-check-box { width: 22px; height: 22px; border-radius: 6px; border: 2px solid #DDD8CE; flex-shrink: 0; display: flex; align-items: center; justify-content: center; transition: all 0.12s; }
.sim-check.on .sim-check-box { background: #C5A059; border-color: #C5A059; }
.sim-check-label { flex: 1; font-size: 13px; font-weight: 500; }
.sim-check-price { font-size: 11px; color: #7A7368; }
.sim-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.sim-divider { height: 1px; background: #F0EBE1; margin: 16px 0; }
.sim-info { background: #F7F4EF; border-left: 3px solid #C5A059; padding: 10px 14px; border-radius: 0 8px 8px 0; margin-bottom: 12px; font-size: 12px; color: #7A7368; line-height: 1.7; }
.sim-nav { position: sticky; bottom: 0; background: #1A2530; border-top: 2px solid #C5A059; padding: 10px 16px 14px; z-index: 200; }
.sim-nav-total { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 10px; padding-bottom: 10px; border-bottom: 1px solid rgba(255,255,255,0.1); cursor: pointer; -webkit-tap-highlight-color: transparent; }
.sim-nav-total-lbl { font-size: 10px; color: rgba(255,255,255,0.4); letter-spacing: 0.1em; text-transform: uppercase; }
.sim-nav-total-hint { display: inline-flex; align-items: center; gap: 3px; font-size: 10px; color: #C5A059; letter-spacing: 0; text-transform: none; margin-left: 8px; opacity: 0.85; transition: opacity 0.2s; }
.sim-nav-total:active .sim-nav-total-hint { opacity: 1; }
.sim-nav-total-hint svg { transition: transform 0.25s ease; }
.sim-nav-total-hint.open svg { transform: rotate(180deg); }
.sim-nav-total-amt { font-family: 'Cormorant Garamond', serif; font-size: 26px; color: #C5A059; font-weight: 600; line-height: 1; }
.sim-nav-total-rng { font-size: 10px; color: rgba(255,255,255,0.35); margin-left: 6px; }
.sim-nav-btns { display: flex; gap: 10px; }
.sim-nav-prev { flex: 0 0 80px; height: 52px; background: rgba(255,255,255,0.1); border: none; border-radius: 8px; color: rgba(255,255,255,0.6); font-size: 14px; font-family: inherit; cursor: pointer; }
.sim-nav-next { flex: 1; height: 52px; background: #FFF; border: none; border-radius: 8px; color: #1A2530; font-size: 14px; font-weight: 600; font-family: inherit; cursor: pointer; letter-spacing: 0.04em; }
.sim-nav-next.gold { background: #C5A059; color: #FFF; }
.sim-result-box { background: #1A2530; border-radius: 16px; padding: 26px 22px; margin-bottom: 18px; }
.sim-result-id { font-size: 10px; letter-spacing: 0.12em; color: #C5A059; margin-bottom: 14px; font-weight: 600; }
.sim-result-lbl { font-size: 10px; color: rgba(255,255,255,0.4); letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 10px; }
.sim-result-range { display: flex; align-items: baseline; flex-wrap: wrap; gap: 4px 8px; margin-bottom: 6px; }
.sim-result-amt { font-family: 'Cormorant Garamond', serif; font-size: 34px; color: #FFF; font-weight: 600; line-height: 1; }
.sim-result-amt span { font-size: 15px; color: #C5A059; margin-right: 2px; }
.sim-result-tilde { font-family: 'Cormorant Garamond', serif; font-size: 24px; color: rgba(255,255,255,0.35); font-weight: 400; }
.sim-result-amthi { font-family: 'Cormorant Garamond', serif; font-size: 34px; color: #C5A059; font-weight: 600; line-height: 1; }
.sim-result-amthi span { font-size: 15px; margin-right: 2px; }
.sim-result-note-range { font-size: 11px; color: rgba(255,255,255,0.35); line-height: 1.7; margin-top: 10px; }
.sim-result-sep { height: 1px; background: rgba(255,255,255,0.1); margin: 16px 0; }
.sim-result-row { display: flex; justify-content: space-between; font-size: 12px; color: rgba(255,255,255,0.55); margin-bottom: 6px; }
.sim-result-row-v { color: #FFF; font-weight: 500; }
.sim-breakdown { background: #FFF; border: 1px solid #DDD8CE; border-radius: 12px; padding: 18px; margin-bottom: 16px; }
.sim-bd-title { font-size: 11px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: #C5A059; margin-bottom: 12px; }
.sim-bd-row { display: flex; justify-content: space-between; font-size: 13px; padding: 8px 0; border-bottom: 1px solid #F0EBE1; color: #3B352C; }
.sim-bd-row:last-child { border-bottom: none; }
.sim-cta { width: 100%; padding: 18px; background: #C5A059; border: none; border-radius: 10px; color: #FFF; font-size: 16px; font-weight: 600; font-family: inherit; cursor: pointer; margin-bottom: 12px; letter-spacing: 0.04em; }
.sim-result-note { font-size: 11px; color: #7A7368; text-align: center; line-height: 1.8; }
.sim-nav-bd-panel { position: absolute; left: 0; right: 0; bottom: 100%; background: #1A2530; border-top: 2px solid #C5A059; padding: 0 16px; max-height: 0; overflow: hidden; transition: max-height 0.3s cubic-bezier(0.4,0,0.2,1), padding 0.3s ease; }
.sim-nav-bd-panel.open { max-height: 60vh; padding: 14px 16px 10px; overflow-y: auto; }
.sim-nav-bd-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.sim-nav-bd-title { font-size: 10px; font-weight: 600; letter-spacing: 0.1em; color: #C5A059; text-transform: uppercase; }
.sim-nav-bd-close { background: none; border: 1px solid rgba(255,255,255,0.15); border-radius: 6px; color: rgba(255,255,255,0.5); font-size: 11px; padding: 4px 10px; cursor: pointer; font-family: inherit; -webkit-tap-highlight-color: transparent; }
.sim-nav-bd-row { display: flex; justify-content: space-between; align-items: baseline; font-size: 12px; color: rgba(255,255,255,0.6); padding: 6px 0; border-bottom: 1px solid rgba(255,255,255,0.05); }
.sim-nav-bd-row:last-child { border-bottom: none; }
.sim-nav-bd-row-v { color: #FFF; font-weight: 500; white-space: nowrap; padding-left: 12px; }
.sim-nav-bd-sep { height: 1px; background: rgba(255,255,255,0.1); margin: 8px 0; }
.sim-nav-bd-overhead { color: rgba(255,255,255,0.45); font-size: 12px; }
.sim-nav-bd-overhead .sim-nav-bd-row-v { color: rgba(255,255,255,0.65); }
.sim-info-icon { display: inline-flex; align-items: center; justify-content: center; width: 18px; height: 18px; border-radius: 50%; border: 1px solid rgba(255,255,255,0.25); font-size: 11px; font-style: italic; color: rgba(255,255,255,0.45); cursor: pointer; margin-left: 8px; -webkit-tap-highlight-color: transparent; flex-shrink: 0; }
.sim-tooltip-overlay { position: fixed; top: 0; left: 0; right: 0; bottom: 0; z-index: 400; display: flex; align-items: flex-end; justify-content: center; padding: 0 16px 120px; background: rgba(0,0,0,0.4); animation: simFadeIn 0.15s ease; }
.sim-tooltip-box { background: #2A3540; border: 1px solid rgba(255,255,255,0.12); border-radius: 12px; padding: 16px 18px; font-size: 13px; color: rgba(255,255,255,0.8); line-height: 1.8; max-width: 340px; width: 100%; box-shadow: 0 8px 24px rgba(0,0,0,0.4); }
.sim-tooltip-close { display: block; margin-top: 10px; text-align: right; font-size: 12px; color: #C5A059; cursor: pointer; background: none; border: none; font-family: inherit; padding: 4px 0; }
.sim-card-breakdown { background: #F7F4EF; border-radius: 8px; padding: 10px 12px; margin-top: 12px; }
.sim-card-bd-title { font-size: 10px; font-weight: 600; color: #7A7368; letter-spacing: 0.06em; margin-bottom: 6px; }
.sim-card-bd-row { display: flex; justify-content: space-between; font-size: 11px; color: #7A7368; padding: 2px 0; }
.sim-enter { animation: simFadeIn 0.2s ease; }
@keyframes simFadeIn { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
.sim-mode-wrap { display: flex; flex-direction: column; gap: 14px; margin-bottom: 24px; }
.sim-mode-card { border: 2px solid #DDD8CE; border-radius: 16px; padding: 22px 20px; background: #FFF; cursor: pointer; transition: all 0.18s; text-align: left; font-family: inherit; width: 100%; position: relative; }
.sim-mode-card:hover { border-color: #C5A059; background: #FFFDF7; }
.sim-mode-card-en { font-family: 'Cormorant Garamond', serif; font-size: 13px; letter-spacing: 0.14em; color: #C5A059; font-weight: 600; margin-bottom: 6px; display: flex; align-items: center; gap: 8px; }
.sim-mode-card-title { font-size: 16px; font-weight: 700; color: #1A2530; margin-bottom: 6px; }
.sim-mode-card-sub { font-size: 12px; color: #7A7368; line-height: 1.7; }
.sim-mode-badge { display: inline-block; background: #C5A059; color: #FFF; font-size: 10px; font-weight: 700; letter-spacing: 0.1em; padding: 2px 8px; border-radius: 2px; }
.sim-mode-arrow { position: absolute; right: 20px; top: 50%; transform: translateY(-50%); font-size: 20px; color: #DDD8CE; transition: color 0.18s; }
.sim-mode-card:hover .sim-mode-arrow { color: #C5A059; }
.ai-diag-wrap { padding-bottom: 8px; }
.sim-body.ai-mode { padding-bottom: 40px; }
.ai-diag-head { background: #1A2530; border-radius: 14px; padding: 20px 20px 16px; margin-bottom: 20px; }
.ai-diag-head-label { font-size: 10px; letter-spacing: 0.2em; color: #C5A059; font-weight: 700; text-transform: uppercase; margin-bottom: 8px; display: flex; align-items: center; gap: 8px; }
.sim-bd-acc-badge-ai { display: inline-block; font-size: 9px; font-weight: 700; letter-spacing: 0.08em; padding: 1px 6px; border-radius: 2px; background: rgba(197,160,89,0.15); color: #9A7A2E; border: 1px solid rgba(197,160,89,0.4); }
.ai-diag-head-q { font-size: 17px; font-weight: 600; color: #FFF; line-height: 1.5; }
.ai-diag-head-hint { font-size: 11px; color: rgba(255,255,255,0.45); margin-top: 6px; line-height: 1.6; }
.ai-diag-options { display: flex; flex-direction: column; gap: 10px; }
.ai-diag-opt { border: 2px solid #DDD8CE; border-radius: 12px; padding: 16px 18px; background: #FFF; cursor: pointer; font-family: inherit; text-align: left; width: 100%; transition: all 0.15s; }
.ai-diag-opt:hover { border-color: #C5A059; background: #FFFDF7; }
.ai-diag-opt.selected { border-color: #C5A059; background: #FDF8EF; }
.ai-diag-opt-label { font-size: 14px; font-weight: 600; color: #1A2530; display: flex; align-items: center; gap: 10px; }
.ai-diag-opt-sub { font-size: 11px; color: #7A7368; margin-top: 3px; padding-left: 28px; }
.ai-diag-opt-icon { width: 20px; height: 20px; border-radius: 50%; border: 2px solid #DDD8CE; flex-shrink: 0; display: flex; align-items: center; justify-content: center; transition: all 0.15s; }
.ai-diag-opt.selected .ai-diag-opt-icon { background: #C5A059; border-color: #C5A059; }
.ai-diag-multi { display: flex; flex-direction: column; gap: 10px; }
.ai-diag-multi-opt { border: 2px solid #DDD8CE; border-radius: 12px; padding: 14px 18px; background: #FFF; cursor: pointer; font-family: inherit; text-align: left; width: 100%; transition: all 0.15s; display: flex; align-items: center; gap: 12px; }
.ai-diag-multi-opt:hover { border-color: #C5A059; background: #FFFDF7; }
.ai-diag-multi-opt.selected { border-color: #C5A059; background: #FDF8EF; }
.ai-diag-multi-box { width: 22px; height: 22px; border-radius: 6px; border: 2px solid #DDD8CE; flex-shrink: 0; display: flex; align-items: center; justify-content: center; transition: all 0.15s; }
.ai-diag-multi-opt.selected .ai-diag-multi-box { background: #C5A059; border-color: #C5A059; }
.ai-diag-multi-text { flex: 1; }
.ai-diag-multi-label { font-size: 13px; font-weight: 600; color: #1A2530; }
.ai-diag-multi-sub { font-size: 11px; color: #7A7368; margin-top: 2px; }
.ai-diag-nav { display: flex; gap: 10px; margin-top: 20px; }
.ai-diag-back { flex: 0 0 72px; height: 48px; background: #F0EBE1; border: none; border-radius: 8px; color: #7A7368; font-size: 13px; font-family: inherit; cursor: pointer; white-space: nowrap; }
.ai-diag-next { flex: 1; height: 48px; background: #C5A059; border: none; border-radius: 8px; color: #FFF; font-size: 14px; font-weight: 600; font-family: inherit; cursor: pointer; letter-spacing: 0.04em; }
.ai-diag-next:disabled { background: #DDD8CE; cursor: not-allowed; }
.ai-diag-progress-dots { display: flex; gap: 6px; justify-content: center; margin-bottom: 20px; }
.ai-diag-dot { width: 6px; height: 6px; border-radius: 50%; background: #DDD8CE; transition: all 0.2s; }
.ai-diag-dot.active { background: #C5A059; width: 18px; border-radius: 3px; }
.ai-diag-dot.done { background: #C5A059; }
.ai-done-banner { background: linear-gradient(135deg, #1A2530, #2A3540); border-radius: 14px; padding: 24px 20px; margin-bottom: 20px; text-align: center; }
.ai-done-icon { font-size: 32px; margin-bottom: 10px; }
.ai-done-title { font-size: 17px; font-weight: 700; color: #FFF; margin-bottom: 6px; }
.ai-done-sub { font-size: 12px; color: rgba(255,255,255,0.6); line-height: 1.7; }
.ai-done-next { width: 100%; margin-top: 18px; padding: 16px; background: #C5A059; border: none; border-radius: 10px; color: #FFF; font-size: 15px; font-weight: 600; font-family: inherit; cursor: pointer; letter-spacing: 0.04em; }
.ai-diag-switch-btn { background: none; border: none; font-family: inherit; font-size: 12px; color: #7A7368; text-decoration: underline; cursor: pointer; padding: 4px; }
.sim-bd-accordion { background: #FFF; border: 1px solid #DDD8CE; border-radius: 14px; overflow: hidden; margin-bottom: 14px; }
.sim-bd-acc-row { display: flex; align-items: center; justify-content: space-between; padding: 14px 16px; cursor: pointer; border-bottom: 1px solid #F0EBE1; transition: background 0.12s; -webkit-tap-highlight-color: transparent; }
.sim-bd-acc-row:last-child { border-bottom: none; }
.sim-bd-acc-row:hover { background: #FFFDF7; }
.sim-bd-acc-row.open { background: #FFFDF7; }
.sim-bd-acc-left { display: flex; align-items: center; gap: 10px; flex: 1; min-width: 0; }
.sim-bd-acc-icon { width: 28px; height: 28px; border-radius: 50%; flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.sim-bd-acc-icon.filled { background: #C5A059; }
.sim-bd-acc-icon.empty { background: #F0EBE1; }
.sim-bd-acc-name { font-size: 13px; font-weight: 600; color: #1A2530; }
.sim-bd-acc-badges { display: flex; gap: 4px; flex-wrap: wrap; margin-top: 2px; }
.sim-bd-acc-badge-manual { display: inline-block; font-size: 9px; font-weight: 700; letter-spacing: 0.08em; padding: 1px 6px; border-radius: 2px; background: rgba(26,37,48,0.08); color: #7A7368; border: 1px solid rgba(26,37,48,0.15); }
.sim-bd-acc-right { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.sim-bd-acc-amt { font-size: 13px; font-weight: 600; color: #3B352C; white-space: nowrap; }
.sim-bd-acc-amt.zero { color: #DDD8CE; }
.sim-bd-acc-chevron { transition: transform 0.2s ease; color: #7A7368; flex-shrink: 0; }
.sim-bd-acc-chevron.open { transform: rotate(180deg); }
.sim-bd-acc-body { background: #F7F4EF; border-top: 1px solid #EDE8DF; }
.sim-bd-acc-detail { padding: 12px 16px; border-bottom: 1px solid #EDE8DF; }
.sim-bd-acc-detail:last-child { border-bottom: none; }
.sim-bd-acc-edit { display: flex; align-items: center; gap: 6px; margin-top: 10px; }
.sim-bd-acc-edit-btn { flex: 1; padding: 9px 14px; background: #1A2530; border: none; border-radius: 8px; color: #FFF; font-size: 12px; font-weight: 600; font-family: inherit; cursor: pointer; letter-spacing: 0.04em; }
.sim-bd-acc-edit-btn:hover { background: #2A3540; }
.sim-back-to-result { background: #1A2530; border-radius: 10px; padding: 12px 16px; margin-bottom: 16px; display: flex; align-items: center; justify-content: space-between; }
.sim-back-to-result-text { font-size: 12px; color: rgba(255,255,255,0.6); }
.sim-back-to-result-btn { background: #C5A059; border: none; border-radius: 6px; padding: 7px 14px; color: #FFF; font-size: 12px; font-weight: 600; font-family: inherit; cursor: pointer; white-space: nowrap; }
.sim-ai-note-banner { background: rgba(197,160,89,0.1); border: 1px solid rgba(197,160,89,0.3); border-radius: 10px; padding: 10px 14px; margin-bottom: 14px; font-size: 12px; color: #7A6230; line-height: 1.7; display: flex; gap: 8px; align-items: flex-start; }
.sim-ai-note-icon { font-size: 14px; flex-shrink: 0; margin-top: 1px; }
@keyframes aiLoadBar { from { width: 0%; } to { width: 100%; } }
.ai-loading-bar { animation: aiLoadBar 1.5s ease-in-out forwards; }
@keyframes aiCursor { 0%,100%{opacity:1} 50%{opacity:0} }
@keyframes typingDot { 0%,60%,100%{transform:translateY(0)} 30%{transform:translateY(-6px)} }
@keyframes chatFadeUp { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:none} }
@keyframes simFadeIn2 { from{opacity:0} to{opacity:1} }
.sim-bd-acc-chips { display:flex; flex-wrap:wrap; gap:6px; padding:12px 16px 4px; }
.sim-bd-chip { display:inline-flex; align-items:center; padding:4px 10px; border-radius:20px; font-size:11px; font-weight:500; background:#F0EBE1; color:#3B352C; border:1px solid #DDD8CE; white-space:nowrap; }
.sim-bd-chip.ai { background:rgba(197,160,89,0.12); border-color:rgba(197,160,89,0.4); color:#7A6230; }
.sim-bd-acc-actions { padding:8px 16px 14px; }
.sim-bd-acc-edit-btn { width:100%; padding:10px 14px; background:#1A2530; border:none; border-radius:8px; color:#FFF; font-size:12px; font-weight:600; font-family:inherit; cursor:pointer; letter-spacing:0.04em; }
.sim-bd-acc-edit-btn:hover { background:#2A3540; }