/* ═══════════════════════════════════════════════════════════════
   不動産AI分析システム — ライトテーマ
   ═══════════════════════════════════════════════════════════════ */
:root {
  --bg:         #f0f4f8;
  --bg-card:    #ffffff;
  --bg-alt:     #e8edf4;
  --border:     #d1d9e6;
  --border-l:   #e4eaf4;
  --primary:    #3b5bdb;
  --primary-l:  rgba(59,91,219,.12);
  --accent:     #0891b2;
  --accent2:    #be185d;
  --green:      #059669;
  --green-l:    rgba(5,150,105,.1);
  --yellow:     #b45309;
  --yellow-l:   rgba(180,83,9,.1);
  --red:        #dc2626;
  --red-l:      rgba(220,38,38,.1);
  --orange:     #ea580c;
  --text:       #1e293b;
  --text2:      #334155;
  --muted:      #64748b;
  --muted2:     #94a3b8;
  --r:          10px;
  --shadow-sm:  0 1px 4px rgba(0,0,0,.08);
  --shadow:     0 3px 12px rgba(0,0,0,.10);
  --shadow-lg:  0 6px 24px rgba(0,0,0,.12);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Segoe UI','Yu Gothic UI',system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.55;font-size:14px}
.container{max-width:1280px;margin:0 auto;padding:0 20px}
a{color:var(--primary);text-decoration:none}

/* ── HEADER ─────────────────────────────────────────────────── */
.header{position:sticky;top:0;z-index:200;background:#fff;border-bottom:2px solid var(--primary);box-shadow:var(--shadow-sm)}
.header-inner{max-width:1280px;margin:0 auto;padding:10px 20px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.logo{display:flex;align-items:center;gap:8px}
.logo-icon{font-size:1.3rem}
.logo-text{font-size:1.05rem;font-weight:800;color:var(--text)}
.logo-text .accent{color:var(--primary)}
.header-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.btn-pdf{display:flex;align-items:center;gap:5px;padding:6px 14px;background:var(--primary);color:#fff;border:none;border-radius:6px;font-size:.8rem;font-weight:700;cursor:pointer;transition:opacity .2s}
.btn-pdf:hover{opacity:.85}
.header-badge{font-size:.68rem;font-weight:600;letter-spacing:.06em;color:var(--primary);border:1px solid var(--primary);padding:2px 8px;border-radius:12px}
/* AIモードスイッチ */
.ai-mode-switch{display:flex;align-items:center;gap:5px;border:1px solid var(--border);border-radius:20px;padding:3px 8px;background:var(--bg)}
.mode-switch-label{font-size:.65rem;font-weight:700;color:var(--muted);letter-spacing:.04em;white-space:nowrap}
.mode-btns{display:flex;gap:2px;background:var(--border-l);border-radius:12px;padding:2px}
.mode-btn{background:transparent;color:var(--muted);border:none;border-radius:10px;padding:3px 10px;font-size:.72rem;cursor:pointer;transition:.15s;white-space:nowrap}
.mode-btn:hover{background:rgba(59,91,219,.1);color:var(--primary)}
.mode-btn.active{background:var(--primary);color:#fff;font-weight:700}
.mode-btn:disabled{opacity:.35;cursor:not-allowed}
/* APIキーキャンセルボタン */
.btn-cancel-key{padding:8px 14px;border:1.5px solid var(--border);border-radius:7px;background:#fff;color:var(--muted);font-size:.82rem;cursor:pointer;font-weight:600}
.btn-cancel-key:hover{border-color:var(--muted)}

/* ── INPUT SECTION ──────────────────────────────────────────── */
.input-section{background:linear-gradient(135deg,#ebf0ff 0%,#f0f7ff 100%);padding:16px 0;border-bottom:1px solid var(--border)}
.input-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:14px 18px;box-shadow:var(--shadow-sm)}
.input-row{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap}
.input-group{display:flex;flex-direction:column;gap:4px;flex:1;min-width:120px}
.btn-group{flex:0 0 auto}
label{font-size:.7rem;font-weight:700;color:var(--muted);letter-spacing:.04em;text-transform:uppercase}
.url-input-wrap{display:flex;align-items:center;background:#f8fafc;border:1.5px solid var(--border);border-radius:7px;padding:0 10px;gap:6px;transition:border-color .2s,box-shadow .2s}
.url-input-wrap:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-l)}
input[type="url"]{flex:1;background:transparent;border:none;outline:none;color:var(--text);font-size:.88rem;padding:8px 0}
input[type="number"]{background:#f8fafc;border:1.5px solid var(--border);border-radius:7px;padding:7px 10px;color:var(--text);font-size:.88rem;width:100%;outline:none;transition:border-color .2s,box-shadow .2s}
input[type="number"]:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-l)}
.btn-analyze{display:flex;align-items:center;gap:6px;padding:9px 20px;border:none;border-radius:7px;background:var(--primary);color:#fff;font-size:.88rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:opacity .2s,transform .15s;box-shadow:0 2px 8px rgba(59,91,219,.3)}
.btn-analyze:hover{opacity:.9;transform:translateY(-1px)}
.btn-analyze:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* ── LOADING ────────────────────────────────────────────────── */
.loading-wrap{display:flex;align-items:center;gap:10px;padding:8px 0}
.loading-spinner{width:18px;height:18px;border-radius:50%;border:2px solid var(--border);border-top-color:var(--primary);animation:spin .8s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-text{color:var(--muted);font-size:.82rem}

/* ── SECTIONS ───────────────────────────────────────────────── */
.section{padding:20px 0}
.alt-section{background:var(--bg-alt);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.section-title{font-size:.92rem;font-weight:800;color:var(--text);margin-bottom:12px;padding-bottom:6px;border-bottom:2px solid var(--primary);display:inline-block;letter-spacing:.02em}

/* ── PROP TITLE BAR ──────────────────────────────────────────── */
.prop-title-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;flex-wrap:wrap;gap:8px}
.prop-title-bar span{font-size:.95rem;font-weight:700}
.prop-url-link{font-size:.72rem;color:var(--primary);border:1px solid var(--primary);padding:2px 8px;border-radius:10px}
.prop-url-link:hover{background:var(--primary-l)}

/* ── KPI TABS (モード切替) ────────────────────────────────────── */
.kpi-mode-tabs{display:flex;gap:4px;margin-bottom:10px;flex-wrap:wrap}
.kpi-mode-tab{padding:6px 16px;border:1.5px solid var(--border);background:#fff;color:var(--muted);border-radius:20px;cursor:pointer;font-size:.78rem;font-weight:700;transition:all .2s}
.kpi-mode-tab.active{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px 6px rgba(59,91,219,.25)}
.kpi-mode-tab:hover:not(.active){border-color:var(--primary);color:var(--primary)}

/* ── KPI ROW ─────────────────────────────────────────────────── */
.kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:8px;margin-bottom:12px}
.kpi-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--r);padding:10px 12px;text-align:center;box-shadow:var(--shadow-sm);transition:border-color .2s,transform .15s}
.kpi-card:hover{transform:translateY(-1px);box-shadow:var(--shadow)}
.kpi-card.c-green{border-top:3px solid var(--green)}
.kpi-card.c-blue{border-top:3px solid var(--accent)}
.kpi-card.c-purple{border-top:3px solid var(--accent2)}
.kpi-card.c-orange{border-top:3px solid var(--orange)}
.kpi-card.c-primary{border-top:3px solid var(--primary)}
.kpi-label{font-size:.64rem;color:var(--muted);font-weight:700;margin-bottom:4px;letter-spacing:.03em}
.kpi-value{font-size:1.4rem;font-weight:800;color:var(--text);line-height:1}
.kpi-card.c-green .kpi-value{color:var(--green)}
.kpi-card.c-blue .kpi-value{color:var(--accent)}
.kpi-card.c-purple .kpi-value{color:var(--accent2)}
.kpi-card.c-orange .kpi-value{color:var(--orange)}
.kpi-card.c-primary .kpi-value{color:var(--primary)}
.kpi-unit{font-size:.64rem;color:var(--muted2);margin-top:2px}
.kpi-sub{font-size:.62rem;color:var(--muted);margin-top:2px;font-style:italic}

/* ── TWO-COL GRID ────────────────────────────────────────────── */
.two-col-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:768px){.two-col-grid{grid-template-columns:1fr}}

/* ── PANEL ───────────────────────────────────────────────────── */
.panel{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:14px;box-shadow:var(--shadow-sm)}
.panel-title{font-size:.75rem;font-weight:800;color:var(--muted);margin-bottom:10px;text-transform:uppercase;letter-spacing:.05em}

/* ── DETAIL LIST ─────────────────────────────────────────────── */
.detail-list{display:flex;flex-direction:column;gap:0}
.detail-row{display:flex;gap:8px;font-size:.78rem;padding:4px 0;border-bottom:1px solid var(--border-l)}
.detail-row:last-child{border-bottom:none}
.d-label{color:var(--muted);min-width:80px;flex-shrink:0;font-weight:600}
.d-value{color:var(--text2);font-weight:500;word-break:break-all}

/* ── RISK LIST ───────────────────────────────────────────────── */
.risk-list{display:flex;flex-direction:column;gap:5px}
.risk-item{border-left:3px solid;border-radius:0 6px 6px 0;padding:6px 10px}
.risk-item.high{border-color:var(--red);background:var(--red-l)}
.risk-item.medium{border-color:var(--yellow);background:var(--yellow-l)}
.risk-item.low{border-color:var(--green);background:var(--green-l)}
.risk-header{display:flex;align-items:center;gap:6px;margin-bottom:2px}
.risk-badge{font-size:.62rem;font-weight:700;padding:1px 6px;border-radius:3px}
.risk-item.high .risk-badge{background:var(--red);color:#fff}
.risk-item.medium .risk-badge{background:var(--yellow);color:#fff}
.risk-item.low .risk-badge{background:var(--green);color:#fff}
.risk-name{font-weight:700;font-size:.78rem;color:var(--text)}
.risk-desc{color:var(--muted);font-size:.72rem;line-height:1.4}

/* ── LAND PRICE ──────────────────────────────────────────────── */
.land-price-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:8px;margin-bottom:8px}
.lp-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:10px 12px;box-shadow:var(--shadow-sm)}
.lp-label{font-size:.64rem;color:var(--muted);font-weight:700;margin-bottom:4px;text-transform:uppercase}
.lp-value{font-size:1rem;font-weight:800;color:var(--primary)}
.lp-total{font-size:.72rem;color:var(--green);font-weight:600;margin-top:2px}
.lp-unit{font-size:.62rem;color:var(--muted2);margin-top:1px}
.value-factors{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:12px;margin-bottom:8px;box-shadow:var(--shadow-sm)}
.vf-title{font-size:.72rem;font-weight:800;color:var(--muted);margin-bottom:6px;text-transform:uppercase}
.vf-list{display:flex;flex-direction:column;gap:3px}
.vf-item{display:flex;align-items:flex-start;gap:6px;font-size:.75rem;padding:3px 0;border-bottom:1px solid var(--border-l)}
.vf-item:last-child{border-bottom:none}
.vf-factor{font-weight:700;min-width:100px;flex-shrink:0;color:var(--text2)}
.vf-desc{color:var(--muted)}
.lp-comment{font-size:.75rem;color:var(--text2);line-height:1.6;background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:10px 12px;box-shadow:var(--shadow-sm)}

/* ── SIMULATION HEADER ───────────────────────────────────────── */
.sim-header{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:12px 16px;margin-bottom:10px;box-shadow:var(--shadow-sm)}
.sim-top-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:10px}
.sim-price-row{display:flex;align-items:center;gap:8px;flex:1;min-width:250px}
.sim-price-label{font-size:.72rem;color:var(--muted);font-weight:700;white-space:nowrap}
input[type="range"]{flex:1;-webkit-appearance:none;height:4px;background:var(--border);border-radius:2px;cursor:pointer}
input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--primary);box-shadow:0 0 4px rgba(59,91,219,.4)}
.price-input-box{display:flex;align-items:center;gap:4px;background:#f8fafc;border:1.5px solid var(--border);border-radius:7px;padding:4px 8px}
.price-input-box input{background:transparent;border:none;outline:none;color:var(--text);font-size:.88rem;font-weight:700;width:70px;padding:0}
.price-input-box span{color:var(--muted);font-size:.75rem}

/* 入居率スライダー */
.occ-row{display:flex;align-items:center;gap:8px;flex:1;min-width:200px}
.occ-label{font-size:.72rem;color:var(--muted);font-weight:700;white-space:nowrap}
.occ-value{font-size:.82rem;font-weight:800;color:var(--primary);min-width:36px}

/* シミュモードタブ */
.sim-mode-tabs{display:flex;gap:4px;flex-wrap:wrap}
.sim-mode-tab{padding:5px 12px;border:1.5px solid var(--border);background:#f8fafc;color:var(--muted);border-radius:6px;cursor:pointer;font-size:.75rem;font-weight:700;transition:all .2s}
.sim-mode-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.sim-mode-tab:hover:not(.active){border-color:var(--primary);color:var(--primary);background:var(--primary-l)}

/* 年数タブ */
.year-tabs{display:flex;gap:4px}
.year-tab{padding:5px 12px;border:1.5px solid var(--border);background:#f8fafc;color:var(--muted);border-radius:6px;cursor:pointer;font-size:.75rem;font-weight:700;transition:all .2s}
.year-tab.active,.year-tab:hover{background:var(--accent);color:#fff;border-color:var(--accent)}

/* 損益分岐点バッジ */
.be-badge{display:inline-flex;align-items:center;gap:4px;background:var(--green-l);border:1.5px solid var(--green);border-radius:6px;padding:4px 10px;font-size:.75rem;font-weight:700;color:var(--green)}

/* ── CHARTS ──────────────────────────────────────────────────── */
.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
@media(max-width:768px){.charts-grid{grid-template-columns:1fr}}
.chart-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:14px;box-shadow:var(--shadow-sm)}
.chart-title{font-size:.72rem;font-weight:800;color:var(--muted);margin-bottom:10px;text-transform:uppercase;letter-spacing:.04em}

/* ── TABLE ───────────────────────────────────────────────────── */
.table-scroll{overflow-x:auto}
.sim-table{width:100%;border-collapse:collapse;font-size:.75rem}
.sim-table th{background:#f0f4ff;color:var(--muted);padding:6px 8px;text-align:right;font-weight:700;border-bottom:2px solid var(--border);font-size:.7rem}
.sim-table th:first-child{text-align:center}
.sim-table td{padding:5px 8px;text-align:right;border-bottom:1px solid var(--border-l);color:var(--text2)}
.sim-table td:first-child{text-align:center;font-weight:700;color:var(--primary)}
.sim-table tr:hover{background:#f8fafc}
.sim-table tr.milestone{background:#f0f4ff}
.sim-table tr.milestone td{font-weight:700;color:var(--text)}
.sim-table tr.be-row td{background:rgba(5,150,105,.08);font-weight:700}
.sim-table tr.maint-row td{background:rgba(180,83,9,.05)}
.negative{color:var(--red)!important}
.positive{color:var(--green)!important}

/* ── EXPENSE LIST ────────────────────────────────────────────── */
.expense-list{display:flex;flex-direction:column;gap:3px;margin-bottom:8px}
.expense-row{display:flex;justify-content:space-between;font-size:.75rem;padding:4px 0;border-bottom:1px solid var(--border-l)}
.expense-row:last-child{border-bottom:none;font-weight:700}
.expense-label{color:var(--muted)}
.expense-value{font-weight:600;color:var(--text2)}

/* ── TARGET PRICE MINI ───────────────────────────────────────── */
.target-price-mini{background:#f0f4ff;border:1.5px solid var(--primary);border-radius:var(--r);padding:10px 12px;margin-top:8px}
.tp-label{font-size:.68rem;color:var(--muted);font-weight:700;text-transform:uppercase}
.tp-value{font-size:1.4rem;font-weight:800;color:var(--primary)}
.tp-desc{font-size:.7rem;color:var(--muted);margin-top:2px}

/* ── REPAIR GRID ──────────────────────────────────────────────── */
.repair-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:8px}
.repair-item{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:10px 12px;box-shadow:var(--shadow-sm)}
.repair-item.total{border-color:var(--accent2);border-width:2px;grid-column:1/-1}
.repair-label{font-size:.68rem;color:var(--muted);font-weight:700;margin-bottom:4px;text-transform:uppercase}
.repair-range{font-size:.88rem;font-weight:700;color:var(--text2)}
.repair-item.total .repair-range{font-size:1rem;color:var(--accent2)}

/* ── LAND USE LIST ────────────────────────────────────────────── */
.land-use-list{display:flex;flex-direction:column;gap:7px}
.land-use-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--r);padding:12px;box-shadow:var(--shadow-sm)}
.land-use-card.high{border-left:4px solid var(--green)}
.land-use-card.medium{border-left:4px solid var(--yellow)}
.land-use-card.low{border-left:4px solid var(--red)}
.lu-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}
.lu-type{font-size:.88rem;font-weight:800;color:var(--text)}
.lu-badge{font-size:.65rem;font-weight:700;padding:2px 8px;border-radius:10px}
.land-use-card.high .lu-badge{background:var(--green-l);color:var(--green);border:1px solid var(--green)}
.land-use-card.medium .lu-badge{background:var(--yellow-l);color:var(--yellow);border:1px solid var(--yellow)}
.land-use-card.low .lu-badge{background:var(--red-l);color:var(--red);border:1px solid var(--red)}
.lu-income{font-size:.82rem;font-weight:700;color:var(--primary);margin-bottom:4px}
.lu-reason{font-size:.72rem;color:var(--muted);line-height:1.4;margin-bottom:4px}
.lu-caution{font-size:.68rem;color:var(--yellow);background:var(--yellow-l);padding:4px 8px;border-radius:4px;border:1px solid var(--yellow)}

/* ── REGIONAL INFO ────────────────────────────────────────────── */
.regional-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:768px){.regional-grid{grid-template-columns:1fr}}
.regional-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:12px;box-shadow:var(--shadow-sm)}
.regional-card-title{font-size:.72rem;font-weight:800;color:var(--muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.04em;display:flex;align-items:center;gap:5px}
.regional-list{display:flex;flex-direction:column;gap:3px}
.regional-item{font-size:.75rem;color:var(--text2);padding:3px 0;border-bottom:1px solid var(--border-l);display:flex;align-items:flex-start;gap:4px}
.regional-item:last-child{border-bottom:none}
.regional-item-icon{flex-shrink:0}
.subsidy-item{background:#f0f4ff;border-radius:5px;padding:5px 8px;font-size:.72rem;margin-bottom:4px}
.subsidy-name{font-weight:700;color:var(--primary);margin-bottom:1px}
.subsidy-amount{font-size:.68rem;color:var(--green);font-weight:600}
.subsidy-desc{font-size:.68rem;color:var(--muted);margin-top:1px}
.pop-trend{font-size:.82rem;line-height:1.6;color:var(--text2)}
.area-comment{font-size:.75rem;color:var(--text2);line-height:1.6;background:#f8fafc;border-radius:6px;padding:8px 10px;border:1px solid var(--border-l);margin-top:6px}
.livability-badge{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;font-weight:700;padding:3px 10px;border-radius:10px;margin-top:6px}
.livability-badge.high{background:var(--green-l);color:var(--green);border:1px solid var(--green)}
.livability-badge.medium{background:var(--yellow-l);color:var(--yellow);border:1px solid var(--yellow)}
.livability-badge.low{background:var(--red-l);color:var(--red);border:1px solid var(--red)}

/* ── VERDICT ──────────────────────────────────────────────────── */
.verdict-card{border-radius:var(--r);padding:14px;border:2px solid;display:flex;gap:12px;align-items:flex-start;box-shadow:var(--shadow-sm)}
.verdict-card.buy{border-color:var(--green);background:var(--green-l)}
.verdict-card.caution{border-color:var(--yellow);background:var(--yellow-l)}
.verdict-card.avoid{border-color:var(--red);background:var(--red-l)}
.verdict-icon{font-size:2rem;line-height:1;flex-shrink:0}
.v-label{font-size:.68rem;font-weight:700;letter-spacing:.08em;margin-bottom:4px}
.verdict-card.buy .v-label{color:var(--green)}
.verdict-card.caution .v-label{color:var(--yellow)}
.verdict-card.avoid .v-label{color:var(--red)}
.v-title{font-size:.92rem;font-weight:800;margin-bottom:6px;color:var(--text)}
.v-comment{font-size:.75rem;color:var(--text2);line-height:1.6}
.v-summary{font-size:.72rem;color:var(--muted);margin-top:6px;line-height:1.5}
.ai-error-box{background:var(--red-l);border:1.5px solid var(--red);border-radius:var(--r);padding:12px;font-size:.78rem;color:var(--red)}

/* ── API KEY BANNER ──────────────────────────────────────────── */
.api-key-banner{background:linear-gradient(135deg,#fffbeb,#fef3c7);border-bottom:2px solid #f59e0b;padding:12px 0}
.api-key-card{display:flex;align-items:flex-start;gap:14px;background:#fff;border:1.5px solid #f59e0b;border-radius:var(--r);padding:16px 20px;box-shadow:var(--shadow-sm)}
.api-key-icon{font-size:2rem;line-height:1}
.api-key-body{flex:1}
.api-key-title{font-weight:700;font-size:.95rem;color:var(--text);margin-bottom:4px}
.api-key-desc{font-size:.8rem;color:var(--muted);margin-bottom:10px}
.api-key-desc a{color:var(--primary);text-decoration:underline}
.api-key-row{display:flex;gap:8px;flex-wrap:wrap}
.api-key-input{flex:1;min-width:240px;padding:7px 12px;border:1.5px solid var(--border);border-radius:6px;font-size:.85rem;font-family:monospace}
.api-key-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-l)}
.btn-set-key{padding:7px 18px;background:var(--primary);color:#fff;border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;white-space:nowrap}
.btn-set-key:hover{background:#2f4abf}
.api-key-msg{font-size:.8rem;margin-top:6px;min-height:18px}

/* ── PROPERTY CHECK ITEMS ────────────────────────────────────── */
.check-items-list{display:grid;grid-template-columns:repeat(2,1fr);gap:4px;margin-top:6px}
@media(max-width:600px){.check-items-list{grid-template-columns:1fr}}
.check-item{display:flex;flex-direction:column;gap:2px;padding:6px 8px;border-radius:6px;font-size:.75rem;border:1px solid transparent;min-width:0}
.check-item-header{display:flex;align-items:center;gap:5px}
.check-icon{font-size:.85rem;flex-shrink:0;width:18px;text-align:center}
.check-label{color:var(--text2);font-weight:600;white-space:nowrap}
.check-value{font-size:.73rem;font-weight:600;padding-left:23px;line-height:1.4;word-break:break-all}
.check-ok{background:#f0fdf4;border-color:#bbf7d0}.check-ok .check-value{color:var(--green)}
.check-alert{background:#fef2f2;border-color:#fecaca}.check-alert .check-value{color:var(--red)}
.check-unknown{background:var(--bg);border-color:var(--border-l)}.check-unknown .check-value{color:var(--muted)}

/* ── FOOTER ───────────────────────────────────────────────────── */
.footer{text-align:center;padding:14px;color:var(--muted);font-size:.72rem;border-top:1px solid var(--border);background:#fff;margin-top:16px}

/* ── PRINT ────────────────────────────────────────────────────── */
@media print {
  .header,.input-section,.btn-pdf,.year-tabs,.sim-mode-tabs,.kpi-mode-tabs,.sim-header{display:none!important}
  .section,.alt-section{padding:8px 0;break-inside:avoid}
  .chart-card,.panel,.kpi-card,.regional-card{box-shadow:none;break-inside:avoid}
  body{font-size:11px;background:#fff}
  .container{max-width:100%;padding:0 12px}
}

/* ── BREAK-EVEN COST BREAKDOWN ───────────────────────────────── */
.be-cost-breakdown{margin-bottom:14px}
.be-breakdown-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:16px;box-shadow:var(--shadow-sm)}
.be-breakdown-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.be-breakdown-title{font-size:.88rem;font-weight:700;color:var(--text)}
.be-status{font-size:.78rem;font-weight:600;padding:4px 10px;border-radius:20px}
.be-status-ok{background:var(--green-l);color:var(--green);border:1px solid var(--green)}
.be-status-ng{background:var(--yellow-l);color:var(--yellow);border:1px solid var(--yellow)}
.be-breakdown-body{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:640px){.be-breakdown-body{grid-template-columns:1fr}}
.be-side{}
.be-side-title{font-size:.8rem;font-weight:700;color:var(--text2);margin-bottom:8px;padding-bottom:4px;border-bottom:1px solid var(--border-l)}
.loss-title{color:var(--red)}
.gain-title{color:var(--green)}
.be-items{display:flex;flex-direction:column;gap:6px}
.be-item{}
.be-item-row{display:flex;align-items:center;gap:6px;margin-bottom:3px}
.be-item-icon{font-size:.9rem;width:18px;text-align:center}
.be-item-label{flex:1;font-size:.75rem;color:var(--text2)}
.be-item-value{font-size:.78rem;font-weight:700;color:var(--text);white-space:nowrap}
.be-item-pct{font-size:.7rem;color:var(--muted);width:36px;text-align:right}
.be-bar-bg{height:5px;background:var(--bg-alt);border-radius:3px;overflow:hidden}
.be-bar-fill{height:100%;border-radius:3px;transition:width .4s ease}
.be-net{font-size:1.4rem;font-weight:800;margin-top:6px}
.be-net.positive{color:var(--green)}
.be-net.negative{color:var(--red)}

/* ── BE ITEM EDITABLE INPUT ──────────────────────────────────── */
.be-item-input{width:80px;padding:3px 6px;border:1.5px solid var(--primary);border-radius:5px;font-size:.8rem;font-weight:600;color:var(--text);background:#f8faff;text-align:right;margin-left:auto}
.be-item-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--primary-l)}
.be-item-unit{font-size:.73rem;color:var(--muted);flex-shrink:0}
.be-hint{font-size:.68rem;font-weight:400;color:var(--muted);margin-left:8px}
