/* CBI Calculator v2 — Mockup C Enhanced Styles */
#cbiv2-wrap {
  --cbiv2-navy:#1D3557; --cbiv2-navy2:#202d46; --cbiv2-gold:#c6a55b; --cbiv2-gold2:#a98d4c;
  --cbiv2-slate-50:#f8fafc; --cbiv2-slate-100:#f1f5f9; --cbiv2-slate-200:#e2e8f0;
  --cbiv2-slate-400:#94a3b8; --cbiv2-slate-500:#64748b; --cbiv2-slate-700:#334155;
  --cbiv2-green:#16a34a; --cbiv2-radius:12px;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  color:#1f2937; line-height:1.5;
}

/* Strong scoped reset against theme/global button styles */
#cbiv2-wrap button,
#cbiv2-wrap input,
#cbiv2-wrap select,
#cbiv2-wrap textarea {
  font: inherit;
  line-height: 1.2;
}

#cbiv2-wrap .cbiv2-stepper button {
  appearance: none;
  -webkit-appearance: none;
  background:#fff !important;
  background-image:none !important;
  border:0 !important;
  border-radius:0 !important;
  box-shadow:none !important;
  text-shadow:none !important;
  min-width:28px;
  max-width:28px;
  width:28px;
  height:30px;
  padding:0 !important;
  margin:0 !important;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--cbiv2-navy) !important;
  font-size:15px;
  font-weight:700;
}

#cbiv2-wrap .cbiv2-stepper input {
  appearance: textfield;
  -webkit-appearance: none;
  background:transparent !important;
  border:0 !important;
  border-radius:0 !important;
  box-shadow:none !important;
  padding:0 !important;
  margin:0 !important;
  min-width:34px;
  max-width:34px;
  width:34px;
  height:30px;
  line-height:30px;
}

#cbiv2-wrap .cbiv2-seg-opt,
#cbiv2-wrap .cbiv2-extra-toggle-btn,
#cbiv2-wrap #cbiv2CalcBtn,
#cbiv2-wrap .cbiv2-btn-primary {
  appearance:none;
  -webkit-appearance:none;
  background-image:none !important;
  text-shadow:none !important;
  box-shadow:none;
}

/* INPUT SECTION */
.cbiv2-input-section { background:#fff; border:1px solid var(--cbiv2-slate-200); border-radius:var(--cbiv2-radius); margin-bottom:20px; overflow:hidden; }
.cbiv2-input-collapsed { display:flex; align-items:center; gap:12px; flex-wrap:wrap; padding:14px 20px; background:var(--cbiv2-slate-50); }
.cbiv2-summary-row { display:flex; align-items:center; gap:10px; flex-wrap:wrap; width:100%; }
.cbiv2-label-sm { font-size:13px; font-weight:600; color:var(--cbiv2-navy); }
.cbiv2-pill { display:inline-flex; align-items:center; background:var(--cbiv2-slate-100); padding:5px 12px; border-radius:99px; font-size:13px; font-weight:500; color:var(--cbiv2-slate-700); }
.cbiv2-edit-btn { margin-left:auto; background:none; border:1px solid var(--cbiv2-slate-200); border-radius:8px; padding:7px 14px; font-size:13px; font-weight:500; cursor:pointer; color:var(--cbiv2-slate-700); transition:background .15s; }
.cbiv2-edit-btn:hover { background:var(--cbiv2-slate-100); }
.cbiv2-input-expanded { padding:24px 20px 28px; }
.cbiv2-form-header { margin-bottom:20px; }
.cbiv2-form-header h2 { font-size:22px; font-weight:700; color:var(--cbiv2-navy); margin:0 0 4px; }
.cbiv2-form-header p { font-size:14px; color:var(--cbiv2-slate-500); margin:0 0 10px; }
.cbiv2-eligibility-link { font-size:13px; color:var(--cbiv2-gold2); text-decoration:none; border-bottom:1px dashed var(--cbiv2-gold2); }
.cbiv2-eligibility-link:hover { color:var(--cbiv2-navy); }

/* PANELS */
.cbiv2-panels-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:16px; }
@media(max-width:680px){ .cbiv2-panels-grid{ grid-template-columns:1fr; } }
.cbiv2-panel { border:1px solid var(--cbiv2-slate-200); border-radius:var(--cbiv2-radius); padding:18px; background:#fff; }
.cbiv2-panel--extra { background:var(--cbiv2-slate-50); margin-bottom:16px; }
.cbiv2-panel-title { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.cbiv2-panel-title h3 { font-size:14px; font-weight:700; color:var(--cbiv2-navy); margin:0; }
.cbiv2-panel-count { font-size:12px; color:var(--cbiv2-slate-500); background:var(--cbiv2-slate-100); padding:3px 10px; border-radius:99px; }
.cbiv2-person-row { display:flex; align-items:center; justify-content:space-between; padding:10px 0; border-top:1px dashed var(--cbiv2-slate-200); }
.cbiv2-person-row:first-of-type { border-top:0; padding-top:0; }
.cbiv2-person-label { font-size:14px; color:var(--cbiv2-slate-700); font-weight:500; }
.cbiv2-person-label small { display:block; color:var(--cbiv2-slate-400); font-size:12px; font-weight:400; margin-top:2px; }
.cbiv2-person-tag { display:inline-flex; padding:4px 10px; background:#ecfdf5; color:var(--cbiv2-green); border-radius:99px; font-size:12px; font-weight:600; }
.cbiv2-seg-group { display:inline-flex; border:1px solid var(--cbiv2-slate-200); border-radius:8px; overflow:hidden; }
.cbiv2-seg-opt { padding:6px 16px; font-size:13px; font-weight:500; background:#fff; color:var(--cbiv2-slate-500); border:none; cursor:pointer; transition:all .15s; }
.cbiv2-seg-opt.active { background:var(--cbiv2-navy); color:#fff; }
.cbiv2-seg-opt:not(.active):hover { background:var(--cbiv2-slate-100); }

/* AGE GRID & STEPPER */
.cbiv2-age-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:8px; }
.cbiv2-age-grid--2col { grid-template-columns:repeat(2,1fr); }
@media(max-width:480px){ .cbiv2-age-grid{ grid-template-columns:repeat(2,1fr); } }
.cbiv2-age-cell { display:flex; flex-direction:column; align-items:center; gap:6px; padding:10px 6px; background:var(--cbiv2-slate-50); border-radius:8px; border:1px solid var(--cbiv2-slate-200); }
.cbiv2-age-cell--split {
  grid-column: span 2;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
  gap: 6px 8px;
  padding: 10px 8px;
  align-items: center;
  justify-items: center;
}
.cbiv2-age-label { font-size:11px; font-weight:600; color:var(--cbiv2-slate-500); text-transform:uppercase; letter-spacing:.4px; text-align:center; }
.cbiv2-age-label--second { margin-top:6px; }
.cbiv2-stepper { display:inline-flex; align-items:center; border:1px solid var(--cbiv2-slate-200); border-radius:8px; overflow:hidden; background:#fff; }
.cbiv2-stepper button { width:28px; height:30px; background:#fff; border:none; font-size:15px; font-weight:700; color:var(--cbiv2-navy); cursor:pointer; transition:background .15s; line-height:1; }
.cbiv2-stepper button:hover { background:var(--cbiv2-slate-100); }
.cbiv2-stepper input { width:34px; height:30px; border:none; text-align:center; font-weight:700; font-size:13px; background:transparent; color:var(--cbiv2-navy); -moz-appearance:textfield; appearance:textfield; outline:none; }
.cbiv2-stepper input::-webkit-outer-spin-button,.cbiv2-stepper input::-webkit-inner-spin-button{ -webkit-appearance:none; margin:0; }
.cbiv2-field-hint { font-size:12px; color:var(--cbiv2-slate-400); margin:8px 0 0; }
.cbiv2-extra-toggle { display:inline-flex; align-items:center; gap:6px; color:var(--cbiv2-gold2); font-size:14px; font-weight:600; cursor:pointer; background:none; border:none; padding:0; }
.cbiv2-extra-toggle:hover { text-decoration:underline; }
.cbiv2-optional-tag { font-size:12px; color:var(--cbiv2-slate-400); font-weight:400; }
.cbiv2-extra-section { margin-top:16px; display:none; grid-template-columns:repeat(2,1fr); gap:16px; }
.cbiv2-extra-section.open { display:grid; }
@media(max-width:600px){ .cbiv2-extra-section.open{ grid-template-columns:1fr; } }
.cbiv2-calc-row { display:flex; align-items:center; gap:16px; flex-wrap:wrap; margin-top:8px; }
.cbiv2-calc-btn { background:var(--cbiv2-gold); color:#fff; font-weight:700; padding:14px 32px; border-radius:10px; font-size:16px; border:none; cursor:pointer; transition:all .15s; box-shadow:0 4px 12px -2px rgba(198,165,91,.4); }
.cbiv2-calc-btn:hover { background:var(--cbiv2-gold2); transform:translateY(-1px); }
.cbiv2-calc-hint { font-size:13px; color:var(--cbiv2-slate-400); margin:0; }

/* TOOLBAR */
.cbiv2-toolbar { position:sticky; top:0; z-index:50; background:#fff; border:1px solid var(--cbiv2-slate-200); border-radius:var(--cbiv2-radius); box-shadow:0 2px 8px rgba(0,0,0,.07); margin-bottom:20px; }
.cbiv2-toolbar-inner { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; padding:12px 18px; }
.cbiv2-toolbar-left { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.cbiv2-edit-btn-sm { background:none; border:1px solid var(--cbiv2-slate-200); border-radius:8px; padding:6px 12px; font-size:13px; font-weight:500; cursor:pointer; color:var(--cbiv2-slate-700); transition:background .15s; }
.cbiv2-edit-btn-sm:hover { background:var(--cbiv2-slate-100); }
.cbiv2-ta-toggle-wrap { display:flex; align-items:center; gap:10px; background:#fffbeb; border:1px solid #fcd34d; border-radius:10px; padding:8px 14px; }
.cbiv2-ta-label { font-size:13px; font-weight:600; color:#92400e; }
.cbiv2-toggle { width:44px; height:24px; background:var(--cbiv2-slate-200); border-radius:999px; position:relative; cursor:pointer; transition:background .2s; flex-shrink:0; }
.cbiv2-toggle.on { background:var(--cbiv2-gold); }
.cbiv2-toggle::after { content:''; position:absolute; top:2px; left:2px; width:20px; height:20px; background:#fff; border-radius:50%; transition:transform .2s; box-shadow:0 1px 3px rgba(0,0,0,.2); }
.cbiv2-toggle.on::after { transform:translateX(20px); }

/* PRELOADER */
.cbiv2-preloader {
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:16px;
  padding:60px 20px;
  color:var(--cbiv2-slate-500);
  font-size:14px;
  position:fixed;
  inset:0;
  z-index:9999;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(2px);
}
.cbiv2-spinner { width:40px; height:40px; border:3px solid var(--cbiv2-slate-200); border-top-color:var(--cbiv2-gold); border-radius:50%; animation:cbiv2spin .8s linear infinite; }
@keyframes cbiv2spin{ to{ transform:rotate(360deg); } }
.cbiv2-reset-spin{ display:inline-block; transform-origin:center; animation:cbiv2spin 0.6s linear reverse; }

/* SPLIT LAYOUT */
.cbiv2-split { display:grid; grid-template-columns:360px 1fr; gap:20px; align-items:start; }
@media(max-width:900px){ .cbiv2-split{ grid-template-columns:1fr; } }

/* PROGRAM LIST */
.cbiv2-list-rail { background:#fff; border:1px solid var(--cbiv2-slate-200); border-radius:var(--cbiv2-radius); overflow:hidden; position:sticky; top:70px; }
.cbiv2-list-header { padding:14px 18px; border-bottom:1px solid var(--cbiv2-slate-100); background:var(--cbiv2-slate-50); }
.cbiv2-list-title { font-size:11px; text-transform:uppercase; letter-spacing:.8px; color:var(--cbiv2-slate-500); font-weight:700; }
.cbiv2-list-sub { font-size:13px; color:var(--cbiv2-slate-700); margin-top:3px; }
.cbiv2-prog-item { display:flex; align-items:center; gap:10px; padding:12px 16px; cursor:pointer; transition:background .15s; border-left:3px solid transparent; position:relative; }
.cbiv2-prog-item:last-child { border-bottom:0; }
.cbiv2-prog-item:hover { background:var(--cbiv2-slate-50); }
.cbiv2-prog-item.active { background:linear-gradient(90deg,rgba(198,165,91,.1),transparent); border-left:3px solid var(--cbiv2-gold); padding-left:13px; }
.cbiv2-prog-item.winner .cbiv2-rank { background:var(--cbiv2-green); color:#fff; }
.cbiv2-prog-item.active .cbiv2-rank { background:var(--cbiv2-navy); color:#fff; }
.cbiv2-prog-item.disabled { opacity:.5; cursor:not-allowed; }
.cbiv2-prog-item.disabled:hover { background:transparent; }
.cbiv2-rank { width:28px; height:28px; border-radius:50%; background:var(--cbiv2-slate-100); color:var(--cbiv2-slate-500); font-weight:700; font-size:13px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.cbiv2-prog-flag { height:22px; width:auto; border-radius:2px; box-shadow:0 1px 2px rgba(0,0,0,.1); }
.cbiv2-prog-info { flex:1; min-width:0; }
.cbiv2-prog-name { font-size:13px; font-weight:600; color:#0f172a; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cbiv2-prog-sub { font-size:12px; color:var(--cbiv2-slate-500); }
.cbiv2-winner-badge { position:absolute; top:0; left:0; font-size:9px; background:#dcfce7; color:#166534; padding:1px 8px; border-radius:0 0 6px 0; font-weight:700; letter-spacing:.3px; }
.cbiv2-prog-cost { text-align:right; flex-shrink:0; }
.cbiv2-prog-total { font-size:13px; font-weight:700; color:var(--cbiv2-navy); }
.cbiv2-delta { font-size:11px; }
.cbiv2-delta--cheap { color:var(--cbiv2-green); font-weight:600; }
.cbiv2-delta--over { color:var(--cbiv2-slate-400); }
.cbiv2-delta--na { color:var(--cbiv2-slate-400); font-style:italic; }

/* DETAIL PANEL */
.cbiv2-detail-panel { background:#fff; border:1px solid var(--cbiv2-slate-200); border-radius:var(--cbiv2-radius); overflow:hidden; min-height:300px; }
.cbiv2-detail-placeholder { display:flex; align-items:center; justify-content:center; padding:60px 20px; color:var(--cbiv2-slate-400); font-size:14px; }
.cbiv2-detail-header { padding:20px 24px; border-bottom:1px solid var(--cbiv2-slate-100); }
.cbiv2-detail-header--winner { background:linear-gradient(135deg,#f0fdf4,#fff); }
.cbiv2-winner-bar { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.8px; color:#166534; margin-bottom:10px; }
.cbiv2-detail-header-inner { display:flex; align-items:flex-start; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.cbiv2-detail-left { display:flex; align-items:flex-start; gap:14px; }
.cbiv2-detail-flag { height:40px; width:auto; border-radius:3px; box-shadow:0 2px 6px rgba(0,0,0,.15); }
.cbiv2-detail-country { font-size:20px; font-weight:700; color:var(--cbiv2-navy); margin:0 0 4px; }
.cbiv2-detail-program { font-size:14px; color:var(--cbiv2-slate-500); margin:0 0 2px; }
.cbiv2-detail-processing { font-size:12px; color:var(--cbiv2-slate-400); margin:0; }
.cbiv2-type-badge { display:inline-block; font-size:9px; font-weight:700; text-transform:uppercase; letter-spacing:.8px; padding:2px 7px; border-radius:99px; vertical-align:middle; margin-left:6px; }
.cbiv2-type-badge--donation { background:#eef2ff; color:#4338ca; }
.cbiv2-type-badge--invest { background:#fef3c7; color:#92400e; }
.cbiv2-detail-right { text-align:right; }
.cbiv2-detail-total-label { font-size:11px; text-transform:uppercase; letter-spacing:.6px; color:var(--cbiv2-slate-500); font-weight:600; }
.cbiv2-detail-total { font-size:36px; font-weight:800; color:var(--cbiv2-navy); line-height:1.1; }
.cbiv2-detail-per-passport { font-size:12px; color:var(--cbiv2-slate-500); margin-top:2px; }
.cbiv2-detail-saving { font-size:12px; color:var(--cbiv2-green); font-weight:600; }
.cbiv2-detail-ta-hint { font-size:12px; color:#92400e; font-weight:500; }

/* TABS */
.cbiv2-tab-strip { display:flex; gap:2px; padding:0 20px; background:#fff; border-bottom:1px solid var(--cbiv2-slate-200); overflow-x:auto; flex-wrap:nowrap; }
.cbiv2-tab { background:none; border:0; padding:13px 14px; font:inherit; font-size:13px; font-weight:600; color:var(--cbiv2-slate-500); cursor:pointer; border-bottom:3px solid transparent; white-space:nowrap; transition:all .15s; display:inline-flex; align-items:center; gap:5px; }
.cbiv2-tab:hover { color:var(--cbiv2-navy); }
.cbiv2-tab.active { color:var(--cbiv2-navy); border-bottom-color:var(--cbiv2-gold); }
.cbiv2-tab-icon { font-size:14px; }
.cbiv2-tab-pane { padding:22px 24px; }

/* COSTS PANE */
.cbiv2-costs-grid { display:grid; grid-template-columns:1fr 1fr; gap:32px; }
@media(max-width:640px){ .cbiv2-costs-grid{ grid-template-columns:1fr; } }
.cbiv2-section-label { font-size:11px; text-transform:uppercase; letter-spacing:.8px; color:var(--cbiv2-slate-500); font-weight:700; margin-bottom:12px; }
.cbiv2-donut-wrap { display:flex; align-items:center; gap:20px; flex-wrap:wrap; }
.cbiv2-donut-bg { stroke:var(--cbiv2-slate-200); }
.cbiv2-donut-fg { transform:rotate(-90deg); transform-origin:50% 50%; }
.cbiv2-donut-legend { display:flex; flex-direction:column; gap:12px; flex:1; min-width:140px; }
.cbiv2-legend-row { display:flex; align-items:center; gap:8px; font-size:13px; }
.cbiv2-legend-dot { width:12px; height:12px; border-radius:3px; flex-shrink:0; }
.cbiv2-notes { font-size:14px; color:var(--cbiv2-slate-700); line-height:1.6; margin:0; }
.cbiv2-vs-avg-val { font-size:14px; margin-top:6px; }

/* TOOLTIPS */
.cbiv2-has-tip { cursor:help; position:relative; border-bottom:1px dotted var(--cbiv2-slate-400); flex:1; }
.cbiv2-tip-content { display:none; }
#cbiv2Tip { position:fixed; padding:12px 14px; background:var(--cbiv2-navy2); color:#fff; border-radius:8px; font-size:13px; line-height:1.5; width:280px; max-width:80vw; box-shadow:0 8px 24px rgba(0,0,0,.25); border:1px solid var(--cbiv2-gold); opacity:0; pointer-events:none; transition:opacity .15s; z-index:9999; }
#cbiv2Tip strong { color:var(--cbiv2-gold); }
#cbiv2Tip ul { margin:6px 0 0; padding:0; list-style:none; }
#cbiv2Tip li { padding-left:12px; position:relative; }
#cbiv2Tip li::before { content:'·'; position:absolute; left:0; color:var(--cbiv2-gold); font-weight:700; }

/* TA PANE */
.cbiv2-ta-pane { max-width:600px; }
.cbiv2-ta-headline { font-size:18px; font-weight:700; color:var(--cbiv2-navy); margin:6px 0 16px; }
.cbiv2-ta-amount { color:#92400e; }
.cbiv2-ta-box { background:#fffbeb; border:1px solid #fcd34d; border-radius:12px; padding:20px; margin-bottom:16px; }
.cbiv2-ta-row { display:flex; justify-content:space-between; padding:10px 0; border-bottom:1px solid rgba(0,0,0,.06); font-size:14px; }
.cbiv2-ta-row:last-child { border-bottom:0; }
.cbiv2-ta-row--discount span:last-child { color:var(--cbiv2-green); font-weight:600; }
.cbiv2-ta-row--total { border-top:2px solid var(--cbiv2-gold)!important; margin-top:8px; padding-top:14px!important; font-size:16px; font-weight:700; }
.cbiv2-ta-row--total span:last-child { font-size:22px; color:var(--cbiv2-gold2); }
.cbiv2-refund-block { background:#f0fdf4; border:1px solid #bbf7d0; border-radius:12px; padding:16px; margin-bottom:16px; }
.cbiv2-refund-total { font-size:28px; font-weight:800; color:#166534; }
.cbiv2-ta-note { font-size:13px; color:var(--cbiv2-slate-500); line-height:1.6; }
.cbiv2-ta-note a { color:var(--cbiv2-gold2); font-weight:600; }

/* PASSPORT PANE */
.cbiv2-passport-pane { display:grid; grid-template-columns:1fr 1fr; gap:32px; max-width:700px; }
@media(max-width:640px){ .cbiv2-passport-pane{ grid-template-columns:1fr; } }
.cbiv2-passport-grade { display:inline-block; padding:8px 20px; background:var(--cbiv2-navy); color:#fff; border-radius:99px; font-weight:700; font-size:18px; text-decoration:none; }
.cbiv2-passport-grade:hover { background:var(--cbiv2-gold); }
.cbiv2-renewal-period { font-size:16px; font-weight:700; color:#0f172a; margin-bottom:8px; }

/* PROS/CONS */
.cbiv2-pros-cons { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
@media(max-width:560px){ .cbiv2-pros-cons{ grid-template-columns:1fr; } }
.cbiv2-pros h4,.cbiv2-cons h4 { font-size:11px; text-transform:uppercase; letter-spacing:1px; color:var(--cbiv2-slate-500); font-weight:700; margin:0 0 10px; }
.cbiv2-pros ul,.cbiv2-cons ul { list-style:none; padding:0; margin:0; }
.cbiv2-pros li,.cbiv2-cons li { padding:6px 0 6px 22px; position:relative; font-size:14px; line-height:1.5; color:var(--cbiv2-slate-700); }
.cbiv2-pros li::before { content:'✓'; position:absolute; left:0; color:var(--cbiv2-green); font-weight:700; }
.cbiv2-cons li::before { content:'✕'; position:absolute; left:0; color:#dc2626; font-weight:700; }
.cbiv2-no-cons { color:var(--cbiv2-slate-400)!important; font-style:italic; }
.cbiv2-no-cons::before { content:'' !important; }

/* FAMILY PANE */
.cbiv2-family-pane { max-width:600px; }
.cbiv2-future-summary { background:var(--cbiv2-slate-50); border:1px solid var(--cbiv2-slate-200); border-radius:10px; padding:14px 16px; margin-bottom:16px; }
.cbiv2-future-short { font-size:16px; font-weight:600; color:#0f172a; }
.cbiv2-future-full { font-size:13px; color:var(--cbiv2-slate-500); margin-top:4px; }
.cbiv2-future-fees { margin-bottom:16px; }
.cbiv2-fee-row { display:flex; justify-content:space-between; font-size:13px; padding:7px 0; border-bottom:1px solid var(--cbiv2-slate-100); }
.cbiv2-fee-row:last-child { border-bottom:0; }
.cbiv2-fee-who { color:var(--cbiv2-slate-500); }
.cbiv2-fee-amount { font-weight:600; color:var(--cbiv2-navy); }
.cbiv2-fee-na { font-size:13px; color:var(--cbiv2-slate-400); font-style:italic; }
.cbiv2-compare-btn { display:inline-flex; align-items:center; gap:8px; margin-top:4px; padding:10px 20px; background:var(--cbiv2-navy); color:#fff; border:none; border-radius:8px; font-size:13px; font-weight:600; cursor:pointer; transition:all .15s; }
.cbiv2-compare-btn:hover { background:var(--cbiv2-gold); }
.cbiv2-caveat { background:#fef3c7; border:1px solid #fcd34d; border-radius:8px; padding:12px 14px; margin-top:16px; font-size:13px; color:#92400e; }

/* DETAIL CTA */
.cbiv2-detail-cta { padding:16px 24px; background:var(--cbiv2-slate-50); border-top:1px solid var(--cbiv2-slate-100); display:flex; flex-wrap:wrap; align-items:center; gap:12px; justify-content:space-between; }
.cbiv2-detail-cta p { font-size:13px; color:var(--cbiv2-slate-500); margin:0; }
.cbiv2-cta-btn { background:var(--cbiv2-gold); color:#fff; font-weight:700; padding:10px 22px; border-radius:8px; border:none; cursor:pointer; font-size:14px; transition:background .15s; }
.cbiv2-cta-btn:hover { background:var(--cbiv2-gold2); }

/* PARTNER INFO */
.cbiv2-partner-block { background:var(--cbiv2-slate-50); border:1px solid var(--cbiv2-slate-200); border-radius:var(--cbiv2-radius); padding:24px 28px; margin-top:24px; font-size:14px; color:var(--cbiv2-slate-700); line-height:1.7; }
.cbiv2-partner-block p { margin:0 0 12px; }
.cbiv2-partner-block p:last-child { margin:0; }
.cbiv2-partner-block a { color:var(--cbiv2-gold2); font-weight:600; }

/* MODALS */
.cbiv2-modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.5); backdrop-filter:blur(4px); z-index:10000; display:none; padding:20px; overflow-y:auto; }
.cbiv2-modal-overlay.active { display:flex; align-items:flex-start; justify-content:center; }
.cbiv2-modal-container { background:#fff; border-radius:16px; max-width:640px; width:100%; max-height:calc(100vh - 40px); overflow:hidden; display:flex; flex-direction:column; box-shadow:0 20px 60px rgba(0,0,0,.3); margin-top:40px; margin-bottom:40px; position:relative; }
/* Eligibility modal gets JS positioning */
#cbiv2EligibilityModal.active .cbiv2-modal-container { margin-top:0; margin-bottom:0; }
.cbiv2-modal-wide { max-width:1100px; }
.cbiv2-modal-header { display:flex; justify-content:space-between; align-items:center; padding:18px 24px; border-bottom:1px solid var(--cbiv2-slate-200); }
.cbiv2-modal-header h3 { font-size:16px; font-weight:700; color:var(--cbiv2-navy); margin:0; }
.cbiv2-modal-close { width:34px; height:34px; border-radius:50%; border:none; background:var(--cbiv2-slate-100); color:var(--cbiv2-slate-500); font-size:20px; cursor:pointer; transition:all .15s; line-height:1; }
.cbiv2-modal-close:hover { background:var(--cbiv2-slate-200); }
.cbiv2-modal-body { padding:22px 24px; overflow-y:auto; flex:1; }
.cbiv2-modal-footer { padding:14px 24px; background:var(--cbiv2-slate-50); border-top:1px solid var(--cbiv2-slate-200); }
.cbiv2-modal-note { font-size:13px; color:#92400e; background:#fef3c7; border:1px solid #fcd34d; border-radius:8px; padding:10px 14px; margin:0 0 18px; }
.cbiv2-modal-caveat { font-size:12px; color:var(--cbiv2-slate-500); margin:0; }
.cbiv2-btn-primary { background:var(--cbiv2-navy); color:#fff; font-weight:600; padding:10px 24px; border-radius:8px; border:none; cursor:pointer; font-size:14px; transition:background .15s; }
.cbiv2-btn-primary:hover { background:var(--cbiv2-gold); }

/* ELIGIBILITY TABLE */
.cbiv2-elig-table-wrap { overflow-x:auto; }
.cbiv2-elig-table { width:100%; border-collapse:collapse; font-size:13px; }
.cbiv2-elig-table th { background:var(--cbiv2-navy); color:#fff; padding:10px 12px; text-align:left; font-weight:600; font-size:12px; white-space:nowrap; }
.cbiv2-elig-table td { padding:10px 12px; border-bottom:1px solid var(--cbiv2-slate-100); color:var(--cbiv2-slate-700); vertical-align:top; }
.cbiv2-elig-table tr:nth-child(even) td { background:var(--cbiv2-slate-50); }
.cbiv2-elig-table td:first-child { font-weight:600; color:var(--cbiv2-navy); white-space:nowrap; }

/* FAMILY MODAL GRID */
.cbiv2-family-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
@media(max-width:700px){ .cbiv2-family-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:480px){ .cbiv2-family-grid { grid-template-columns:1fr; } }
.cbiv2-family-col { background:var(--cbiv2-slate-50); border-radius:10px; padding:14px; }
.cbiv2-family-col h4 { font-size:13px; font-weight:700; color:var(--cbiv2-navy); margin:0 0 10px; text-align:center; }

/* CONTACT MODAL FORM */
.cbiv2-contact-intro { font-size:14px; color:var(--cbiv2-slate-500); margin:0 0 20px; }
.cbiv2-form-row { margin-bottom:14px; }
.cbiv2-form-row--2col { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media(max-width:560px){ .cbiv2-form-row--2col{ grid-template-columns:1fr; } }
.cbiv2-form-group { display:flex; flex-direction:column; gap:5px; }
.cbiv2-form-group--full { width:100%; }
.cbiv2-form-group label { font-size:13px; font-weight:600; color:var(--cbiv2-slate-700); }
.cbiv2-req { color:#dc2626; }
.cbiv2-autofill { font-size:11px; font-weight:400; color:var(--cbiv2-slate-400); }
.cbiv2-optional { font-size:11px; font-weight:400; color:var(--cbiv2-slate-400); }
.cbiv2-form-group input,
.cbiv2-form-group select,
.cbiv2-form-group textarea {
  padding:9px 12px;
  border:1px solid var(--cbiv2-slate-200);
  border-radius:8px;
  font-size:14px;
  font-family:inherit;
  color:var(--cbiv2-slate-700);
  background:#fff;
  transition:border-color .15s, box-shadow .15s;
  width:100%;
  box-sizing:border-box;
}
.cbiv2-form-group input:focus,
.cbiv2-form-group select:focus,
.cbiv2-form-group textarea:focus {
  outline:none;
  border-color:var(--cbiv2-gold);
  box-shadow:0 0 0 3px rgba(198,165,91,.15);
}
.cbiv2-form-group input[readonly],
.cbiv2-form-group textarea[readonly] {
  background:var(--cbiv2-slate-50);
  color:var(--cbiv2-slate-500);
  cursor:default;
}
.cbiv2-form-group input.cbiv2-field-error,
.cbiv2-form-group select.cbiv2-field-error,
input.cbiv2-field-error,
select.cbiv2-field-error {
  border-color:#dc2626 !important;
  box-shadow:0 0 0 3px rgba(220,38,38,.1);
}
.cbiv2-contact-error {
  background:#fef2f2;
  border:1px solid #fecaca;
  border-radius:8px;
  padding:10px 14px;
  font-size:13px;
  color:#dc2626;
  margin-top:12px;
}
.cbiv2-contact-footer { display:flex; gap:10px; }
.cbiv2-btn-secondary {
  background:#fff;
  border:1px solid var(--cbiv2-slate-200);
  color:var(--cbiv2-slate-700);
  font-weight:600;
  padding:10px 20px;
  border-radius:8px;
  cursor:pointer;
  font-size:14px;
  transition:background .15s;
}
.cbiv2-btn-secondary:hover { background:var(--cbiv2-slate-100); }

/* Contact success state */
.cbiv2-contact-success { text-align:center; padding:20px 10px; }
.cbiv2-success-icon {
  width:64px; height:64px;
  background:#dcfce7;
  color:var(--cbiv2-green);
  font-size:32px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 16px;
}
.cbiv2-contact-success h3 { font-size:20px; font-weight:700; color:var(--cbiv2-navy); margin:0 0 10px; }
.cbiv2-contact-success p { font-size:14px; color:var(--cbiv2-slate-500); margin:0 0 8px; }

/* TOOLTIP */
#cbiv2Tip {
  display:none;
  position:fixed;
  z-index:99999;
  background:#202d46;
  color:#fff;
  font-size:13px;
  line-height:1.6;
  padding:12px 16px;
  border-radius:8px;
  max-width:320px;
  box-shadow:0 8px 24px rgba(0,0,0,.25);
  pointer-events:auto;
  user-select:text;
  -webkit-user-select:text;
  transition:opacity 0.15s ease;
}
#cbiv2Tip ul { margin:6px 0 0; padding-left:16px; }
#cbiv2Tip ul li { margin-bottom:3px; }
#cbiv2Tip strong { color:#c6a55b; display:block; margin-top:6px; }
.cbiv2-has-tip { cursor:help; }
.cbiv2-donut-wrap { display:flex; align-items:center; gap:16px; }
.cbiv2-donut-wrap svg { flex-shrink:0; }
.cbiv2-donut-legend { max-width:250px; }
.cbiv2-legend-row { display:flex; align-items:center; gap:8px; margin-bottom:6px; }
.cbiv2-legend-row .cbiv2-has-tip { white-space:nowrap; flex:1; }
.cbiv2-legend-row--ta-return { margin-top:6px; padding-top:6px; border-top:1px dashed #bbf7d0; color:#166534; }
.cbiv2-legend-dot { width:12px; height:12px; border-radius:3px; flex-shrink:0; }
.cbiv2-costs-grid { display:grid; grid-template-columns:1fr minmax(0,220px); gap:20px; }
@media(max-width:700px){ .cbiv2-costs-grid{ grid-template-columns:1fr; } }

/* TA SAVINGS STRIP — compact block below costs grid */
.cbiv2-ta-strip { margin-top:16px; padding:14px 18px; background:linear-gradient(135deg,#f0fdf4,#ecfdf5); border:1px solid #bbf7d0; border-radius:8px; }
.cbiv2-ta-strip-label { font-size:11px; text-transform:uppercase; letter-spacing:.8px; color:#166534; font-weight:700; margin-bottom:8px; }
.cbiv2-ta-strip-rows { display:flex; flex-wrap:wrap; gap:4px 24px; align-items:baseline; }
.cbiv2-ta-strip-row { display:flex; align-items:baseline; gap:6px; font-size:13px; color:#374151; white-space:nowrap; }
.cbiv2-ta-strip-row span:last-child { font-weight:600; color:#166534; }
.cbiv2-ta-strip-total { border-left:2px solid #86efac; padding-left:16px; font-size:14px; font-weight:700; color:#166534 !important; }
.cbiv2-ta-strip-total span { color:#166534 !important; }
@media(max-width:700px){ .cbiv2-ta-strip-rows{ flex-direction:column; gap:4px; } .cbiv2-ta-strip-total{ border-left:none; padding-left:0; border-top:1px solid #bbf7d0; padding-top:8px; margin-top:4px; } }

/* =========================================================================
 * MOBILE RESPONSIVE LAYER
 * Breakpoint: 1024px. Below, hide desktop split view, show #cbiv2Mobile.
 * Above, hide the mobile container and show the original desktop UI.
 * ===================================================================== */
.cbiv2-desktop-only { display:block; }
.cbiv2-mobile-only  { display:none !important; }
@media (max-width:1023px) {
  .cbiv2-desktop-only { display:none !important; }
  .cbiv2-mobile-only  { display:block !important; }
  /* Grid-typed desktop containers */
  #cbiv2Split.cbiv2-desktop-only { display:none !important; }
}

/* ---------- INPUT FORM — touch friendly ---------- */
@media (max-width:1023px) {
  /* Tighter wrap padding */
  #cbiv2InputSection { padding:16px !important; border-radius:14px !important; }
  #cbiv2InputSection h2.text-2xl { font-size:20px !important; }

  /* Children grid: 5 cells get cramped — split into rows */
  #cbiv2InputSection .grid.grid-cols-5 { grid-template-columns:repeat(2,1fr) !important; }

  /* Adults panel — stack spouse row */
  #cbiv2InputSection .border.rounded-xl > .flex.items-center.justify-between { flex-wrap:wrap; gap:8px; }

  /* Pull-to-refresh guard — prevent accidental reload mid-form */
  #cbiv2-wrap { overscroll-behavior-y:contain; }

  /* Bigger, easier-to-tap steppers — 16px prevents iOS zoom */
  #cbiv2-wrap .cbiv2-stepper button { min-width:40px !important; max-width:40px !important; width:40px !important; height:44px !important; font-size:18px !important; }
  #cbiv2-wrap .cbiv2-stepper input  { min-width:44px !important; max-width:44px !important; width:44px !important; height:44px !important; font-size:16px !important; line-height:44px !important; }
  #cbiv2-wrap .cbiv2-age-cell { padding:12px 6px; }
  #cbiv2-wrap .cbiv2-age-label { font-size:12px; }

  /* Segmented Yes/No — bigger */
  #cbiv2-wrap .cbiv2-seg-opt { padding:9px 18px; font-size:14px; }

  /* Extended family toggle — cleaner layout */
  .cbiv2-extra-toggle-btn { flex-wrap:nowrap !important; }
  .cbiv2-toggle-label { flex:1; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

  /* Extended family section — fix cramped layout */
  #cbiv2ExtraSection { display:none; }
  #cbiv2ExtraSection[style*="grid"] { display:grid !important; }
  #cbiv2ExtraSection.grid-cols-4,
  #cbiv2ExtraSection .grid-cols-4 { grid-template-columns:repeat(2,1fr) !important; gap:8px !important; }
  #cbiv2ExtraSection .grid-cols-2 { gap:8px !important; }
  #cbiv2ExtraSection .cbiv2-age-cell { padding:10px 4px; }
  #cbiv2ExtraSection .cbiv2-age-label { font-size:10px; }
  /* Smaller steppers for extended family grid */
  #cbiv2ExtraSection .cbiv2-stepper button { min-width:32px !important; width:32px !important; height:36px !important; font-size:16px !important; }
  #cbiv2ExtraSection .cbiv2-stepper input { min-width:36px !important; width:36px !important; height:36px !important; font-size:14px !important; line-height:36px !important; }

  /* Calculate + Reset — single row, Calculate bigger */
  #cbiv2InputSection .flex.items-center.gap-3.flex-wrap { flex-wrap:nowrap !important; gap:10px; }
  #cbiv2CalcBtn { flex:1; padding:16px !important; font-size:16px !important; white-space:nowrap; }
  #cbiv2ResetBtn { flex:0 0 auto; padding:14px 18px !important; font-size:14px !important; white-space:nowrap; }
  #cbiv2InputSection .flex.items-center.gap-3.flex-wrap > p { display:none; } /* hide hint on mobile */
}

/* ---------- MOBILE TOOLBAR (sticky family pill + TA) ---------- */
.cbiv2-mtoolbar {
  position:sticky; top:0; z-index:40;
  background:#fff;
  border-bottom:1px solid var(--cbiv2-slate-200);
  padding:10px 12px;
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
  margin: -16px -16px 16px;
  border-radius:0;
}
.cbiv2-mtoolbar-edit {
  display:inline-flex; align-items:center; gap:6px;
  background:var(--cbiv2-slate-100); border:0; padding:8px 12px;
  border-radius:999px; font-size:13px; font-weight:600;
  color:var(--cbiv2-navy); cursor:pointer;
}
.cbiv2-mtoolbar-edit:hover { background:var(--cbiv2-slate-200); }
.cbiv2-mtoolbar-family {
  font-size:12px; color:var(--cbiv2-slate-500);
  flex:1; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.cbiv2-mtoolbar-ta {
  display:inline-flex; align-items:center; gap:8px;
  background:#fffbeb; border:1px solid #fcd34d; border-radius:999px;
  padding:5px 10px; font-size:11px; font-weight:600; color:#92400e;
  white-space:nowrap;
}

/* ---------- ACCORDION CARDS ---------- */
#cbiv2MobileList { display:flex; flex-direction:column; gap:10px; }
.cbiv2-mcard {
  background:#fff;
  border:1px solid var(--cbiv2-slate-200);
  border-radius:14px;
  overflow:hidden;
  transition:box-shadow .2s, border-color .2s;
}
.cbiv2-mcard.open {
  border-color:var(--cbiv2-gold);
  box-shadow:0 8px 24px -8px rgba(29,53,87,.18);
}
.cbiv2-mcard.winner { border-color:#bbf7d0; }
.cbiv2-mcard.winner.open { border-color:var(--cbiv2-gold); }
.cbiv2-mcard.disabled { opacity:.55; }

.cbiv2-mcard-head {
  width:100%;
  display:flex; align-items:center; gap:12px;
  padding:14px 14px;
  background:transparent; border:0;
  cursor:pointer; text-align:left;
  position:relative;
  font:inherit; color:inherit;
  -webkit-tap-highlight-color: rgba(198,165,91,.15);
}
.cbiv2-mcard-head:disabled { cursor:not-allowed; }
.cbiv2-mcard.winner .cbiv2-mcard-head::before {
  content:'BEST VALUE';
  position:absolute; top:0; left:14px;
  background:#dcfce7; color:#166534;
  font-size:9px; font-weight:700; letter-spacing:.5px;
  padding:2px 8px; border-radius:0 0 6px 6px;
}
.cbiv2-mcard-head .cbiv2-rank { width:32px; height:32px; font-size:14px; }
.cbiv2-mcard.winner .cbiv2-mcard-head .cbiv2-rank { background:var(--cbiv2-green); color:#fff; }
.cbiv2-mcard-head .cbiv2-prog-flag { height:24px; }
.cbiv2-mcard-head .cbiv2-prog-info { flex:1; min-width:0; padding-top:6px; }
.cbiv2-mcard-head .cbiv2-prog-name { font-size:14px; }
.cbiv2-mcard-head .cbiv2-prog-sub  { font-size:12px; }
.cbiv2-mcard-head .cbiv2-prog-cost { text-align:right; padding-top:6px; }
.cbiv2-mcard-head .cbiv2-prog-total { font-size:16px; font-weight:800; color:var(--cbiv2-navy); }
.cbiv2-mcard-head .cbiv2-delta { font-size:11px; }
.cbiv2-mcard-arrow {
  width:24px; height:24px; flex-shrink:0;
  display:inline-flex; align-items:center; justify-content:center;
  font-size:11px; color:var(--cbiv2-slate-400);
  transition:transform .2s;
  margin-left:4px;
}
.cbiv2-mcard.open .cbiv2-mcard-arrow { transform:rotate(180deg); color:var(--cbiv2-gold); }

.cbiv2-mcard-body {
  border-top:1px solid var(--cbiv2-slate-200);
  background:var(--cbiv2-slate-50);
  display:none;
}
.cbiv2-mcard.open .cbiv2-mcard-body { display:block; animation:cbiv2-mexpand .25s ease-out; }
@keyframes cbiv2-mexpand {
  from { opacity:0; transform:translateY(-4px); }
  to   { opacity:1; transform:translateY(0); }
}

/* Tab strip inside mobile card — horizontal scroll with button pills */
.cbiv2-mcard-body .cbiv2-tab-strip {
  padding:10px 0 10px 12px;
  background:#f8fafc;
  border-bottom:1px solid var(--cbiv2-slate-200);
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  display:flex;
  gap:6px;
}
.cbiv2-mcard-body .cbiv2-tab-strip::-webkit-scrollbar { display:none; }
/* Add padding at end so last button has breathing room */
.cbiv2-mcard-body .cbiv2-tab-strip::after {
  content:''; flex-shrink:0; width:12px;
}
/* Button-style tabs */
.cbiv2-mcard-body .cbiv2-tab {
  flex-shrink:0;
  display:inline-flex;
  align-items:center;
  gap:5px;
  padding:8px 14px;
  font-size:12px;
  font-weight:500;
  color:var(--cbiv2-slate-600);
  background:#fff;
  border:1px solid var(--cbiv2-slate-200);
  border-radius:999px;
  white-space:nowrap;
  cursor:pointer;
  transition:all .15s ease;
}
.cbiv2-mcard-body .cbiv2-tab:active { transform:scale(0.98); }
.cbiv2-mcard-body .cbiv2-tab.active {
  background:var(--cbiv2-navy);
  color:#fff;
  border-color:var(--cbiv2-navy);
}
.cbiv2-mcard-body .cbiv2-tab-icon { font-size:13px; }
.cbiv2-mcard-body .cbiv2-tab-pane { padding:16px 14px; background:#fff; }
.cbiv2-mcard-body .cbiv2-detail-cta {
  padding:14px;
  flex-direction:column;
  align-items:stretch;
  gap:10px;
  background:#fff;
  border-top:1px solid var(--cbiv2-slate-200);
}
.cbiv2-mcard-body .cbiv2-detail-cta p { text-align:center; }
.cbiv2-mcard-body .cbiv2-cta-btn { width:100%; padding:14px; font-size:15px; }

/* Tablet range (768px-1023px): donut + legend side by side with smaller sizing */
@media (min-width:768px) and (max-width:1023px) {
  .cbiv2-donut-wrap svg { width:140px; height:140px; }
  .cbiv2-donut-wrap { flex-direction:row; gap:16px; align-items:center; }
  .cbiv2-donut-legend { width:auto; max-width:200px; }
}

/* Mobile (<768px): stack donut above legend */
@media (max-width:767px) {
  .cbiv2-donut-wrap svg { width:140px; height:140px; }
  .cbiv2-donut-wrap { flex-direction:column; gap:12px; align-items:flex-start; }
  .cbiv2-donut-legend { width:100%; max-width:none; }
  .cbiv2-detail-total { font-size:28px !important; }
  .cbiv2-passport-grade { font-size:16px; padding:6px 16px; }
  .cbiv2-section-label { font-size:10px; }
}

/* ---------- MODAL → BOTTOM SHEET on phones ---------- */
@media (max-width:767px) {
  .cbiv2-modal-overlay { padding:0; align-items:flex-end !important; }
  .cbiv2-modal-overlay.active { align-items:flex-end !important; }
  .cbiv2-modal-container {
    margin:0 !important;
    border-radius:18px 18px 0 0 !important;
    max-height:90vh;
    width:100% !important;
    max-width:none !important;
    animation:cbiv2-sheetup .25s ease-out;
  }
  /* Eligibility modal absolute-positioning fights bottom sheet — force it to behave */
  #cbiv2EligibilityModal.active .cbiv2-modal-container {
    position:relative !important;
    top:auto !important; left:auto !important;
    transform:none !important;
  }
  .cbiv2-modal-header { padding:14px 18px; }
  .cbiv2-modal-header::before {
    /* drag handle */
    content:''; position:absolute; top:8px; left:50%; transform:translateX(-50%);
    width:40px; height:4px; background:var(--cbiv2-slate-200); border-radius:2px;
  }
  .cbiv2-modal-header { position:relative; padding-top:20px; }
  .cbiv2-modal-body { padding:16px 18px; }
  .cbiv2-modal-footer { padding:12px 18px; }
}
@keyframes cbiv2-sheetup {
  from { transform:translateY(100%); }
  to   { transform:translateY(0); }
}

/* ---------- MOBILE TIP DOCK (tooltip becomes bottom sheet on small) ---------- */
@media (max-width:767px) {
  #cbiv2Tip {
    position:fixed !important;
    left:12px !important;
    right:12px !important;
    bottom:12px !important;
    top:auto !important;
    width:auto !important;
    max-width:none !important;
  }
}

/* ---------- HEADER / DETAIL HEADER on mobile (used inside mcard expansion) ---------- */
.cbiv2-mcard-body .cbiv2-detail-header { padding:14px; }
.cbiv2-mcard-body .cbiv2-detail-header-inner { gap:10px; }
.cbiv2-mcard-body .cbiv2-detail-flag { height:32px; }
.cbiv2-mcard-body .cbiv2-detail-country { font-size:16px; }
.cbiv2-mcard-body .cbiv2-detail-program { font-size:13px; }

/* Small phones */
@media (max-width:380px) {
  .cbiv2-mcard-head { padding:12px 10px; gap:8px; }
  .cbiv2-mcard-head .cbiv2-prog-name { font-size:13px; }
  .cbiv2-mcard-head .cbiv2-prog-total { font-size:15px; }
  .cbiv2-mtoolbar { padding:8px 10px; }
}
