/* ============================================================
   栄養バランスチェッカー — スタイル
   ============================================================ */

/* --- Reset & Base --- */
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:-apple-system,BlinkMacSystemFont,'Hiragino Kaku Gothic ProN','Noto Sans JP',sans-serif;background:#f5f6fa;color:#333;line-height:1.6}
a{color:#5b9bd5;text-decoration:none}
a:hover{text-decoration:underline}
button{cursor:pointer;font-family:inherit}
input,select,textarea{font-family:inherit;font-size:14px}

/* --- Header --- */
.header{background:#fff;border-bottom:1px solid #e0e0e0;padding:10px 16px;display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:50}
.header h1{font-size:18px;font-weight:700;color:#2c3e50;white-space:nowrap}
.header h1 small{font-size:11px;color:#999;font-weight:400;margin-left:4px}
.header-nav{margin-left:auto;display:flex;gap:8px;align-items:center}
.header-nav a,.btn-icon{padding:6px 12px;border:1px solid #ddd;border-radius:6px;font-size:12px;background:#fff;color:#555;cursor:pointer;display:inline-flex;align-items:center;gap:4px;transition:all .15s}
.header-nav a:hover,.btn-icon:hover{background:#f0f7ff;border-color:#5b9bd5;text-decoration:none}

/* --- Container --- */
.container{max-width:800px;margin:0 auto;padding:12px}

/* --- Card --- */
.card{background:#fff;border-radius:10px;box-shadow:0 1px 4px rgba(0,0,0,.08);margin-bottom:16px;overflow:hidden}
.card-header{padding:14px 16px;border-bottom:1px solid #f0f0f0;display:flex;align-items:center;gap:8px;cursor:pointer;user-select:none}
.card-header h2{font-size:15px;font-weight:600;flex:1}
.card-header .badge{font-size:11px;padding:2px 8px;border-radius:10px;background:#e3f2fd;color:#1565c0}
.card-toggle{font-size:12px;color:#999;transition:transform .2s}
.card.collapsed .card-body{display:none}
.card.collapsed .card-toggle{transform:rotate(-90deg)}
.card-body{padding:16px}

/* --- Tabs --- */
.tabs{display:flex;border-bottom:2px solid #eee;margin-bottom:16px}
.tab-btn{flex:1;padding:10px 8px;text-align:center;font-size:13px;font-weight:500;color:#888;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}
.tab-btn:hover{color:#5b9bd5}
.tab-btn.active{color:#5b9bd5;border-bottom-color:#5b9bd5}
.tab-content{display:none}
.tab-content.active{display:block}

/* --- Form Controls --- */
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:12px;font-weight:600;color:#666;margin-bottom:4px}
.form-row{display:flex;gap:10px;align-items:flex-end}
.form-row > *{flex:1}
input[type="text"],input[type="number"],input[type="date"],input[type="password"],select,textarea{
  width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;outline:none;transition:border-color .2s}
input:focus,select:focus,textarea:focus{border-color:#5b9bd5}
textarea{resize:vertical;min-height:80px}
.api-usage-tip{margin-top:8px;padding:8px 10px;background:#f0f7ff;border-left:3px solid #5b9bd5;border-radius:6px;color:#4b6475;font-size:12px;line-height:1.5}

/* --- Autocomplete --- */
.autocomplete-wrap{position:relative}
.autocomplete-list{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #ddd;border-top:none;border-radius:0 0 6px 6px;max-height:200px;overflow-y:auto;z-index:40;display:none}
.autocomplete-list.show{display:block}
.autocomplete-item{padding:8px 12px;font-size:13px;cursor:pointer}
.autocomplete-item:hover,.autocomplete-item.selected{background:#f0f7ff}

/* --- Food Item List --- */
.food-items{list-style:none;margin:8px 0}
.food-items li{display:flex;align-items:center;gap:8px;padding:6px 8px;background:#f8f9fa;border-radius:6px;margin-bottom:4px;font-size:13px}
.food-items li .name{flex:1}
.food-items li select{width:80px;padding:4px;font-size:12px}
.food-items li .remove{width:24px;height:24px;border:none;background:none;color:#e74c3c;font-size:16px}

/* --- Buttons --- */
.btn{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;transition:all .15s;display:inline-flex;align-items:center;gap:6px}
.btn:disabled{opacity:0.5;cursor:not-allowed}
.btn-primary{background:#5b9bd5;color:#fff}
.btn-primary:hover:not(:disabled){background:#4a8bc4}
.btn-success{background:#27ae60;color:#fff}
.btn-success:hover:not(:disabled){background:#219a52}
.btn-danger{background:#e74c3c;color:#fff}
.btn-danger:hover:not(:disabled){background:#c0392b}
.btn-outline{background:#fff;color:#5b9bd5;border:1px solid #5b9bd5}
.btn-outline:hover:not(:disabled){background:#f0f7ff}
.btn-sm{padding:6px 12px;font-size:12px;border-radius:6px}
.btn-block{width:100%;justify-content:center}

/* --- Dashboard --- */
.period-btns{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}
.period-btn{padding:6px 14px;border:1px solid #ddd;border-radius:16px;font-size:12px;background:#fff;color:#666;cursor:pointer;transition:all .15s}
.period-btn:hover{border-color:#5b9bd5;color:#5b9bd5}
.period-btn.active{background:#5b9bd5;color:#fff;border-color:#5b9bd5}

.bar-group{margin-bottom:20px}
.bar-group-title{font-size:13px;font-weight:600;margin-bottom:8px;padding:4px 8px;border-radius:4px;color:#fff;display:inline-block}
.bar-row{display:flex;align-items:center;gap:6px;margin-bottom:6px;font-size:13px}
.bar-label{width:100px;text-align:right;color:#555;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bar-track{flex:1;height:18px;background:#eee;border-radius:9px;position:relative;overflow:hidden}
.bar-fill{height:100%;border-radius:9px;transition:width .4s ease;min-width:2px}
.bar-value{width:60px;text-align:right;font-size:12px;color:#888;flex-shrink:0}
/* 摂取傾向バッジ（濃淡だけに頼らない表示） */
.bar-intake-badge{font-size:10px;padding:1px 7px;border-radius:10px;color:#fff;font-weight:600;flex-shrink:0;white-space:nowrap}
.bar-intake-badge.low{background:#2980b9}
.bar-intake-badge.high{background:#e67e22}
.bar-intake-badge.normal{background:#27ae60}
.bar-intake-badge.zero{background:#95a5a6}
.bar-pct{font-weight:600}

/* RDA marker line at 100% */
.bar-track::after{content:'';position:absolute;left:min(100%, calc(100% * 100 / var(--max-pct, 200)));top:0;bottom:0;width:1px;background:rgba(0,0,0,.2);z-index:1}

/* --- Alerts --- */
.alert-item{display:flex;gap:10px;padding:10px 12px;border-radius:8px;margin-bottom:8px;font-size:13px;align-items:flex-start}
.alert-item.warning{background:#fff8e1;border-left:3px solid #f39c12}
.alert-item.danger{background:#fce4ec;border-left:3px solid #e74c3c}
.alert-item.excess{background:#fff3e0;border-left:3px solid #e67e22}
.alert-icon{font-size:18px;flex-shrink:0;line-height:1}
.alert-body{flex:1}
.alert-title-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:2px}
.alert-title{font-weight:600}
.alert-label{font-size:11px;font-weight:600;padding:1px 7px;border-radius:10px;white-space:nowrap;flex-shrink:0}
.alert-label.warning{background:#f39c12;color:#fff}
.alert-label.danger{background:#e74c3c;color:#fff}
.alert-label.excess{background:#e67e22;color:#fff}
.food-suggestion{font-size:12px;margin-top:4px;padding:4px 8px;background:#f8fffe;border-radius:4px;line-height:1.5}
.fs-label{font-weight:600;color:#2E8B57}
.alert-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}
.alert-tag{font-size:11px;padding:1px 6px;border-radius:4px;background:rgba(0,0,0,.06);color:#555}

/* --- Suggestion (structured) --- */
.sg-day{background:#f8f9fa;border-radius:10px;padding:16px;margin-bottom:14px}
.sg-day-title{font-size:14px;font-weight:700;color:#5b9bd5;text-align:center;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid #e3f2fd}
.sg-meal{margin-bottom:14px}
.sg-meal:last-of-type{margin-bottom:8px}
.sg-meal-header{font-size:13px;font-weight:600;color:#444;margin-bottom:6px;display:flex;align-items:center;gap:6px}
.sg-dish{padding:6px 10px;margin-bottom:4px;background:#fff;border-radius:6px;border-left:3px solid #e0e0e0;display:flex;align-items:baseline;gap:6px;flex-wrap:wrap;font-size:13px}
.sg-cat{font-size:10px;font-weight:600;color:#fff;background:#90a4ae;padding:1px 6px;border-radius:3px;flex-shrink:0}
.sg-dish-name{font-weight:500;color:#333}
.sg-amount{font-size:12px;color:#888}
.sg-tip{width:100%;font-size:11px;color:#5b9bd5;margin-top:2px;padding-left:2px}
.sg-point{font-size:12px;color:#666;padding:8px 10px;background:#e3f2fd;border-radius:6px;line-height:1.5}

/* --- History --- */
.history-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-bottom:1px solid #f0f0f0;font-size:13px}
.history-item:last-child{border-bottom:none}
.history-date{width:75px;color:#888;flex-shrink:0;font-size:12px}
.history-type{width:36px;font-size:16px;text-align:center;flex-shrink:0}
.history-foods{flex:1;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.history-cal{color:#888;font-size:12px;flex-shrink:0}
.history-del{width:28px;height:28px;border:none;background:none;color:#ccc;font-size:16px;border-radius:4px}
.history-del:hover{color:#e74c3c;background:#fce4ec}
.history-demo{font-size:9px;padding:1px 4px;border-radius:3px;background:#e3f2fd;color:#5b9bd5;margin-left:4px}
.history-empty{text-align:center;padding:30px;color:#999;font-size:14px}
.history-actions{display:flex;gap:8px;padding:12px 0;justify-content:flex-end}

/* --- Modal --- */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:100;display:none;align-items:center;justify-content:center;padding:16px}
.modal-overlay.show{display:flex}
.modal{background:#fff;border-radius:12px;width:100%;max-width:520px;max-height:85vh;overflow-y:auto;box-shadow:0 8px 30px rgba(0,0,0,.15)}
.modal-header{padding:14px 16px;border-bottom:1px solid #eee;display:flex;align-items:center}
.modal-header h3{flex:1;font-size:16px}
.modal-close{width:32px;height:32px;border:none;background:none;font-size:20px;color:#999;border-radius:6px}
.modal-close:hover{background:#f0f0f0;color:#333}
.modal-body{padding:16px}
.modal-footer{padding:12px 16px;border-top:1px solid #eee;display:flex;gap:8px;justify-content:flex-end}

/* --- Confirm Modal Nutrients Table --- */
.nutrient-edit-table{width:100%;border-collapse:collapse;font-size:13px}
.nutrient-edit-table th{text-align:left;padding:4px 6px;color:#888;font-size:11px;font-weight:500;border-bottom:1px solid #eee}
.nutrient-edit-table td{padding:3px 6px;border-bottom:1px solid #f5f5f5}
.nutrient-edit-table input{width:80px;padding:3px 6px;border:1px solid #ddd;border-radius:4px;text-align:right;font-size:13px}
.nutrient-edit-group{font-size:11px;color:#fff;padding:2px 8px;border-radius:4px;margin:6px 0 2px;display:inline-block}

/* --- Confirm Modal Extended (Phase 1b-2) --- */
.confirm-section{margin-bottom:14px}
.confirm-section-title{font-size:12px;font-weight:600;color:#666;margin-bottom:6px;padding-bottom:4px;border-bottom:1px solid #f0f0f0}
.confirm-food-tag{display:inline-block;background:#f0f0f0;padding:2px 8px;border-radius:4px;margin:2px;font-size:12px}

/* 推定精度セクション */
.confirm-meta-section{background:#f8f9fa;border-radius:8px;padding:10px 12px;margin-bottom:14px}
.confirm-meta-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.confirm-meta-label{font-size:12px;color:#666}
.confirm-meta-note{font-size:11px;color:#aaa}
.confirm-meta-sub{font-size:11px;color:#888;font-weight:600;margin:6px 0 2px}
.confirm-meta-list{margin:0 0 4px 16px;padding:0;font-size:12px;color:#555}
.confirm-meta-list li{margin-bottom:2px}
.confirm-meta-list.uncertain li::marker{color:#e67e22}

/* 信頼度バッジ */
.confidence-badge{display:inline-block;padding:2px 10px;border-radius:10px;font-size:11px;font-weight:700}
.conf-high{background:#d4edda;color:#155724}
.conf-mid{background:#fff3cd;color:#856404}
.conf-low{background:#f8d7da;color:#721c24}

/* 注意事項 */
.confirm-warnings{margin-bottom:10px}
.confirm-warning-item{font-size:12px;color:#856404;padding:4px 10px;background:#fff3cd;border-radius:4px;margin-bottom:4px}

/* 免責表示 */
.confirm-disclaimer{font-size:11px;color:#999;padding:8px 0;border-top:1px solid #f0f0f0;margin-top:8px;line-height:1.5}

/* --- Alerts Extended --- */
.alert-sub{font-size:12px;color:#888;margin-top:2px}
.alert-footer-note{font-size:11px;color:#888;padding:8px 12px;background:#f8f9fa;border-radius:6px;margin-top:8px;line-height:1.5}

/* --- Loading --- */
.loading-overlay{position:fixed;inset:0;background:rgba(255,255,255,.85);z-index:200;display:none;align-items:center;justify-content:center;flex-direction:column;gap:12px}
.loading-overlay.show{display:flex}
.loading-spinner{width:36px;height:36px;border:3px solid #eee;border-top-color:#5b9bd5;border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-text{font-size:14px;color:#666}
.loading-tip{font-size:12px;color:#888;max-width:320px;text-align:center;line-height:1.5;min-height:36px;transition:opacity .3s;opacity:1}
.loading-tip.fade{opacity:0}
.loading-cancel{margin-top:8px}

/* --- Toast --- */
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);padding:10px 20px;border-radius:8px;font-size:13px;color:#fff;z-index:300;opacity:0;transition:opacity .3s;pointer-events:none}
.toast.show{opacity:1}
.toast.success{background:#27ae60}
.toast.error{background:#e74c3c}
.toast.info{background:#5b9bd5}

/* --- API Key Required Modal --- */
.apikey-intro{margin-bottom:14px;font-size:13px;color:#555;line-height:1.7}
.apikey-intro p{margin-bottom:6px}
.apikey-intro strong{color:#2c3e50}
.apikey-features{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.apikey-feature{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#f8f9fa;border-radius:8px;font-size:12px;color:#444}
.apikey-feature-icon{font-size:18px;flex-shrink:0;width:24px;text-align:center}
.apikey-privacy{font-size:11px;color:#999;text-align:center;padding:8px;background:#f0f7ff;border-radius:6px}

/* --- Setup Guide --- */
.setup-guide{background:#f8f9fa;border:1px solid #e8edf2;border-radius:10px;padding:16px;margin-bottom:16px}
.setup-guide h3{font-size:13px;font-weight:700;margin-bottom:12px;color:#2c3e50}
.setup-step{display:flex;gap:10px;margin-bottom:14px}
.setup-step:last-child{margin-bottom:0}
.step-number{width:26px;height:26px;border-radius:50%;background:#5b9bd5;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex-shrink:0;margin-top:1px}
.step-content{flex:1;min-width:0}
.step-title{font-size:13px;font-weight:700;color:#2c3e50;margin-bottom:3px}
.step-desc{font-size:12px;color:#555;line-height:1.6}
.step-desc strong{color:#2c3e50}
.step-note{font-size:11px;color:#aaa;margin-top:2px}
.step-list{padding-left:16px;margin:3px 0;font-size:12px;color:#555;line-height:1.6}
.step-list li{margin-bottom:2px}
.step-list strong{color:#2c3e50}
.guide-img{display:block;width:100%;max-width:360px;border-radius:6px;border:1px solid #e0e4e8;margin:5px 0}
.guide-img-sm{max-width:200px}

/* --- Demo Banner --- */
.demo-banner{background:#e3f2fd;border-radius:10px;padding:16px 20px;margin-bottom:16px;text-align:center;display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}
.demo-banner p{font-size:13px;color:#1565c0;margin:0}
.demo-banner .btn{padding:8px 16px;font-size:13px}

/* --- Photo Preview --- */
.photo-preview{max-width:100%;max-height:240px;border-radius:8px;margin:8px 0;display:none;object-fit:contain}
.photo-preview.show{display:block}

/* --- Footer --- */
.footer{text-align:center;padding:16px;font-size:11px;color:#aaa;line-height:1.5}

/* --- Custom Period --- */
.custom-period{display:none;gap:8px;align-items:center;margin-bottom:16px;flex-wrap:wrap}
.custom-period.show{display:flex}
.custom-period input{width:140px;font-size:12px;padding:6px 8px}
.custom-period label{font-size:12px;color:#888}

/* --- Empty State --- */
.empty-state{text-align:center;padding:30px;color:#ccc;font-size:14px}

/* --- Bulk Report --- */
.bulk-profile-badge{font-size:12px;color:#666;padding:8px 12px;background:#f0f7ff;border-radius:6px;margin-bottom:16px;text-align:center}
.bulk-alert-title{font-size:14px;font-weight:600;color:#333;margin:16px 0 8px;padding-top:16px;border-top:1px solid #eee}
.bulk-no-alert{text-align:center;padding:12px;color:#27ae60;font-size:13px;background:#f0fff4;border-radius:6px;margin:16px 0}
.bulk-meals-title{font-size:14px;font-weight:600;color:#333;margin:16px 0 8px;padding-top:16px;border-top:1px solid #eee}
.bulk-day-header{font-size:13px;font-weight:600;color:#5b9bd5;margin:12px 0 6px;padding:4px 8px;background:#f0f7ff;border-radius:4px}
.bulk-meal-card{background:#f8f9fa;border-radius:8px;padding:12px;margin-bottom:8px}
.bulk-meal-header{font-size:13px;font-weight:600;color:#444;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.bulk-skipped{font-size:12px;color:#999;font-style:italic;padding:4px 8px}
.bulk-item{margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid #eee}
.bulk-item:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}
.bulk-item-original{font-size:13px;font-weight:600;color:#333;margin-bottom:6px}

.bulk-interp-selector{display:flex;flex-direction:column;gap:4px}
.bulk-interp-option{display:flex;align-items:center;gap:8px;padding:8px 10px;background:#fff;border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .15s;flex-wrap:wrap}
.bulk-interp-option:hover{border-color:#5b9bd5;background:#f0f7ff}
.bulk-interp-option.selected{border-color:#5b9bd5;background:#e3f2fd}
.bulk-interp-option input[type="radio"]{margin:0;flex-shrink:0}
.bulk-interp-label{font-size:13px;font-weight:500;color:#333}
.bulk-interp-details{font-size:11px;color:#888;flex:1}
.bulk-interp-macro{font-size:11px;color:#5b9bd5;font-weight:500;white-space:nowrap}

.bulk-interp-single{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#fff;border-radius:6px;border:1px solid #eee;flex-wrap:wrap}

/* --- Responsive: Tablet --- */
@media(max-width:640px){
  .header h1{font-size:15px}
  .header h1 small{display:none}
  .container{padding:8px}
  .card-body{padding:12px}
  .bar-label{width:72px;font-size:11px}
  .bar-value{width:50px;font-size:11px}
  .form-row{flex-direction:column;gap:8px}
  .form-row > *{width:100%}
}

/* --- Responsive: Small Phone --- */
@media(max-width:375px){
  .header{padding:8px 10px;gap:8px}
  .header h1{font-size:14px}
  .bar-label{width:60px;font-size:10px}
  .bar-value{width:45px;font-size:10px}
  .bar-track{height:14px}
  .tab-btn{font-size:12px;padding:8px 4px}
  .history-date{width:60px;font-size:11px}
}

/* ============================================================
   Bulk Photo Upload (Phase 2b)
   ============================================================ */
.bp-warning{background:#fff8e1;border:1px solid #ffe082;border-radius:6px;padding:8px 12px;font-size:12px;color:#5d4037;margin-bottom:14px}
.bp-file-note{font-size:11px;color:#999;margin-top:4px}
.bp-list{display:flex;flex-wrap:wrap;gap:10px;margin:12px 0}
.bp-card{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;padding:10px;width:calc(50% - 5px);box-sizing:border-box;position:relative}
.bp-card-img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:6px;display:block;margin-bottom:8px;background:#ddd}
.bp-card-remove{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;border:none;background:rgba(0,0,0,.45);color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1}
.bp-card-remove:hover{background:rgba(0,0,0,.7)}
.bp-card-fields{display:flex;flex-direction:column;gap:6px}
.bp-card-fields label{font-size:11px;color:#666;font-weight:600;margin-bottom:0}
.bp-card-fields input[type="date"],.bp-card-fields select,.bp-card-fields input[type="text"]{font-size:12px;padding:5px 8px}
.bp-status-badge{display:inline-block;font-size:11px;padding:2px 8px;border-radius:10px;font-weight:600;margin-top:6px}
.bp-status-badge.pending{background:#eceff1;color:#546e7a}
.bp-status-badge.analyzing{background:#e3f2fd;color:#1565c0}
.bp-status-badge.done{background:#e8f5e9;color:#2e7d32}
.bp-status-badge.error{background:#ffebee;color:#c62828}
.bp-status-badge.saved{background:#e3f2fd;color:#1565c0}
.bp-actions{display:flex;gap:10px;margin:12px 0;flex-wrap:wrap}
.bp-save-info{font-size:12px;color:#666;margin:-6px 0 10px;padding:4px 0}
.bp-save-info.bp-save-success{color:#2e7d32;font-weight:600}
/* 4タブ時: 375px以下でタブ文字をひと回り小さくする */
@media(max-width:375px){.tab-btn{font-size:10px;padding:8px 2px}}
/* まとめて写真タブ: 375px以下で1列表示 */
@media(max-width:375px){.bp-card{width:100%}}

/* --- Bulk Photo: Progress (Step 5) --- */
.bp-progress{margin:10px 0}
.bp-progress-bar{height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden}
.bp-progress-fill{height:100%;background:#5b9bd5;border-radius:4px;transition:width .3s ease}
.bp-progress-label{font-size:12px;color:#666;margin-top:4px;text-align:center}

/* --- Bulk Photo: Result Summary (Step 5) --- */
.bp-card-result{margin-top:8px;padding:8px;background:#f0f8f0;border-radius:6px;border:1px solid #c8e6c9}
.bp-conf-badge{display:inline-block;font-size:10px;padding:1px 6px;border-radius:8px;font-weight:600;margin-bottom:4px}
.bp-conf-badge.conf-high{background:#e8f5e9;color:#2e7d32}
.bp-conf-badge.conf-mid{background:#fff8e1;color:#f57f17}
.bp-conf-badge.conf-low{background:#ffebee;color:#c62828}
.bp-result-calories{font-size:12px;color:#333;font-weight:600;margin-bottom:4px}
.bp-result-foods{display:flex;flex-wrap:wrap;gap:3px}
.bp-result-food-tag{font-size:11px;background:#fff;border:1px solid #c8e6c9;border-radius:10px;padding:1px 7px;color:#2e7d32}
.bp-result-food-more{font-size:11px;color:#999;align-self:center}

/* --- Bulk Photo: Error Area (Step 5) --- */
.bp-card-error{margin-top:8px;padding:8px;background:#fff3f3;border-radius:6px;border:1px solid #ffcdd2}
.bp-error-msg{font-size:11px;color:#c62828;margin-bottom:6px;word-break:break-all}
.bp-retry-btn{font-size:11px;padding:3px 10px;border:1px solid #ef9a9a;border-radius:4px;background:#fff;color:#c62828;cursor:pointer}
.bp-retry-btn:hover{background:#ffebee}

/* --- Bulk Photo: Result Area (Step 6) --- */
.bp-result-area{margin-top:8px;border:1px solid #c8e6c9;border-radius:6px;background:#f8fff8;overflow:hidden}
.bp-result-conf-row{padding:6px 10px;display:flex;align-items:center;gap:6px}
.bp-result-section{padding:8px 10px;border-top:1px solid #e8f5e9}
.bp-result-section-head{font-size:11px;font-weight:700;color:#2e7d32;margin-bottom:6px}

/* Foods */
.bp-food-list{display:flex;flex-direction:column;gap:4px;margin-bottom:4px}
.bp-food-item{display:flex;gap:4px;align-items:center}
.bp-food-name-input{flex:2;font-size:12px;padding:4px 6px;border:1px solid #ddd;border-radius:4px;min-width:0}
.bp-food-qty-input{flex:1;font-size:12px;padding:4px 6px;border:1px solid #ddd;border-radius:4px;min-width:0}
.bp-food-remove-btn{width:22px;height:22px;border:none;border-radius:50%;background:#ef9a9a;color:#c62828;font-size:13px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:0}
.bp-food-remove-btn:hover{background:#e57373}
.bp-food-add-btn{font-size:11px;padding:4px 10px;border:1px dashed #a5d6a7;border-radius:4px;background:#f1f8e9;color:#388e3c;cursor:pointer;margin-top:2px}
.bp-food-add-btn:hover{background:#e8f5e9}

/* Macro grid */
.bp-macro-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.bp-macro-item{display:flex;flex-direction:column;gap:2px}
.bp-macro-label{font-size:10px;color:#666}
.bp-macro-value-row{display:flex;align-items:center;gap:3px}
.bp-macro-input{width:64px;font-size:12px;padding:3px 5px;border:1px solid #ddd;border-radius:4px}
.bp-macro-unit{font-size:10px;color:#999}

/* Detail section */
.bp-detail-section{border-top:1px solid #e8f5e9}
.bp-detail-toggle{width:100%;text-align:left;font-size:11px;padding:6px 10px;background:#f1f8e9;border:none;color:#388e3c;cursor:pointer}
.bp-detail-toggle:hover{background:#e8f5e9}
.bp-detail-body{padding:8px 10px}
.bp-detail-group{margin-bottom:8px}
.bp-detail-group:last-child{margin-bottom:0}
.bp-detail-group-title{font-size:10px;font-weight:700;color:#888;margin-bottom:4px;border-bottom:1px solid #eee;padding-bottom:2px}
.bp-detail-row{display:flex;align-items:center;gap:4px;margin-bottom:3px}
.bp-detail-label{font-size:11px;color:#555;flex:1}
.bp-detail-input{width:64px;font-size:11px;padding:2px 4px;border:1px solid #ddd;border-radius:3px}
.bp-detail-unit{font-size:10px;color:#999;width:45px;flex-shrink:0}
