/* ============================================================================
 * Variation Fee Calculator — WordPress plugin styles.
 * Everything is scoped under .vfc-app so it can never leak into the theme,
 * and the theme's CSS can never reach in and override it (no bare `body`,
 * `*`, or unscoped class selectors). Do not add rules outside .vfc-app.
 * ============================================================================ */

.vfc-app{
  --ink:#1a2332;
  --ink-soft:#4a5568;
  --ink-faint:#8a93a3;
  --paper:#fbfaf8;
  --panel:#ffffff;
  --line:#e2e5ea;
  --line-strong:#c7cdd6;
  --accent:#1f5f5b;
  --accent-soft:#e8f1f0;
  --accent-deep:#143f3c;
  --amber:#a8651a;
  --amber-soft:#fbf0e2;
  --mono: "IBM Plex Mono","SF Mono",Consolas,monospace;
  --serif: "Source Serif 4","Georgia",serif;
  --sans: "Inter","Helvetica Neue",Arial,sans-serif;
  --radius: 3px;
  --shadow: 0 1px 2px rgba(20,30,40,0.06), 0 4px 16px rgba(20,30,40,0.04);

  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
  max-width:880px;
  margin:0 auto;
  padding:28px 20px 60px;
}
.vfc-app, .vfc-app *{ box-sizing:border-box; }

/* Header */
.vfc-app .app-head{
  display:flex;
  flex-wrap:wrap;
  align-items:baseline;
  justify-content:space-between;
  gap:8px 16px;
  margin-bottom:6px;
  border-bottom:2px solid var(--ink);
  padding-bottom:14px;
}
.vfc-app .app-head h1{
  font-family:var(--serif);
  font-weight:600;
  font-size:22px;
  letter-spacing:-0.01em;
  margin:0;
  color:var(--ink);
}
.vfc-app .app-head .tag{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:0.06em;
  text-transform:uppercase;
  color:var(--ink-faint);
}
.vfc-app .copyright{
  font-size:11.5px;
  color:var(--ink-faint);
  margin:8px 0 0;
}
.vfc-app .subhead{
  font-size:13.5px;
  color:var(--ink-soft);
  margin:10px 0 28px;
}

/* Step rail */
.vfc-app .rail{
  display:flex;
  gap:0;
  margin-bottom:26px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  background:var(--panel);
}
.vfc-app .rail-step{
  flex:1;
  padding:10px 12px;
  font-size:11.5px;
  font-family:var(--mono);
  letter-spacing:0.02em;
  color:var(--ink-faint);
  border-right:1px solid var(--line);
  position:relative;
  display:flex;
  align-items:center;
  gap:8px;
}
.vfc-app .rail-step:last-child{border-right:none;}
.vfc-app .rail-step .n{
  width:18px;height:18px;
  border-radius:50%;
  border:1px solid var(--line-strong);
  display:flex;align-items:center;justify-content:center;
  font-size:10px;
  flex-shrink:0;
  color:var(--ink-faint);
}
.vfc-app .rail-step.active{ color:var(--accent-deep); background:var(--accent-soft); }
.vfc-app .rail-step.active .n{ background:var(--accent); border-color:var(--accent); color:#fff; }
.vfc-app .rail-step.clickable{
  cursor:pointer;
  transition:background .12s ease;
}
.vfc-app .rail-step.clickable:hover{ background:var(--accent-soft); }
/* Rail steps rendered as <button> need reset */
.vfc-app button.rail-step{
  background:var(--panel);
  border:none;
  font-family:var(--mono);
  text-align:left;
  width:100%;
  padding:10px 12px;
}
.vfc-app button.rail-step.done{ background:var(--paper); }
.vfc-app button.rail-step.done:hover{ background:var(--accent-soft); }
.vfc-app .rail-step.done .n{ background:var(--ink); border-color:var(--ink); color:#fff; }
.vfc-app .rail-step.done{ color:var(--ink-soft); }
.vfc-app .rail-step .label{display:none;}
@media (min-width:560px){
  .vfc-app .rail-step .label{display:inline;}
}

/* Panels */
.vfc-app .panel{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:22px;
  margin-bottom:18px;
}
.vfc-app .panel h2{
  font-family:var(--serif);
  font-size:16px;
  font-weight:600;
  margin:0 0 4px;
  color:var(--ink);
}
.vfc-app .panel .hint{
  font-size:12.5px;
  color:var(--ink-faint);
  margin:0 0 16px;
}

/* Country grid */
.vfc-app .country-search{
  width:100%;
  padding:10px 12px;
  font-size:14px;
  border:1px solid var(--line-strong);
  border-radius:var(--radius);
  margin-bottom:14px;
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
}
.vfc-app .country-search:focus{ outline:none; border-color:var(--accent); }
.vfc-app .country-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(120px,1fr));
  gap:8px;
}
.vfc-app .country-tile{
  border:1px solid var(--line);
  background:var(--paper);
  border-radius:var(--radius);
  padding:10px 10px;
  cursor:pointer;
  text-align:left;
  font-family:var(--sans);
  transition:border-color .12s ease, background .12s ease;
}
.vfc-app .country-tile:hover{ border-color:var(--accent); background:var(--accent-soft); }
.vfc-app .country-tile.selected{ border-color:var(--accent); background:var(--accent-soft); box-shadow:inset 0 0 0 1px var(--accent); }
.vfc-app .country-tile .cc{
  font-family:var(--mono);
  font-size:11px;
  color:var(--accent-deep);
  letter-spacing:0.04em;
  display:block;
}
.vfc-app .country-tile .cn{
  font-size:13px;
  color:var(--ink);
  display:block;
  margin-top:2px;
}

/* Form fields */
.vfc-app .field-group{ margin-bottom:18px; }
.vfc-app .field-group:last-child{ margin-bottom:0; }
.vfc-app .field-label{
  display:block;
  font-size:13px;
  font-weight:600;
  color:var(--ink);
  margin-bottom:6px;
}
.vfc-app .field-label .opt{
  font-weight:400;
  color:var(--ink-faint);
  font-size:11.5px;
}
.vfc-app .pill-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.vfc-app .pill{
  border:1px solid var(--line-strong);
  background:var(--paper);
  border-radius:20px;
  padding:7px 14px;
  font-size:13px;
  cursor:pointer;
  color:var(--ink-soft);
  font-family:var(--sans);
  transition:all .12s ease;
}
.vfc-app .pill:hover{ border-color:var(--accent); color:var(--accent-deep); }
.vfc-app .pill.selected{
  background:var(--accent);
  border-color:var(--accent);
  color:#fff;
}
.vfc-app .pill[disabled]{
  opacity:0.35;
  cursor:not-allowed;
}
.vfc-app .pill[disabled]:hover{ border-color:var(--line-strong); color:var(--ink-soft); }

.vfc-app select.field-select{
  width:100%;
  padding:10px 12px;
  font-size:13.5px;
  border:1px solid var(--line-strong);
  border-radius:var(--radius);
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
}
.vfc-app select.field-select:focus{ outline:none; border-color:var(--accent); }

.vfc-app .num-row{
  display:flex;
  align-items:center;
  gap:10px;
}
.vfc-app .num-stepper{
  display:flex;
  align-items:center;
  border:1px solid var(--line-strong);
  border-radius:var(--radius);
  overflow:hidden;
  width:fit-content;
}
.vfc-app .num-stepper button{
  width:34px;height:34px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0;
  margin:0;
  line-height:1;
  border:none;
  background:var(--paper);
  color:var(--ink);
  font-size:16px;
  cursor:pointer;
  font-family:var(--sans);
}
.vfc-app .num-stepper button:hover{ background:var(--accent-soft); color:var(--accent-deep); }
.vfc-app .num-stepper input{
  width:48px;
  text-align:center;
  border:none;
  border-left:1px solid var(--line-strong);
  border-right:1px solid var(--line-strong);
  height:34px;
  font-size:14px;
  font-family:var(--mono);
  color:var(--ink);
}
.vfc-app .num-stepper input:focus{ outline:none; }

.vfc-app .note-box{
  background:var(--amber-soft);
  border:1px solid #e8cfa8;
  border-radius:var(--radius);
  padding:10px 12px;
  font-size:12.5px;
  color:#6b4517;
  margin-top:14px;
  line-height:1.5;
}
.vfc-app .note-box strong{ color:#5a3811; }

/* Nav buttons */
.vfc-app .nav-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-top:6px;
}
.vfc-app .btn{
  font-family:var(--sans);
  font-size:13.5px;
  font-weight:600;
  padding:10px 20px;
  border-radius:var(--radius);
  border:1px solid var(--line-strong);
  background:var(--paper);
  color:var(--ink);
  cursor:pointer;
  transition:all .12s ease;
}
.vfc-app .btn:hover{ border-color:var(--ink); }
.vfc-app .btn.primary{
  background:var(--accent);
  border-color:var(--accent);
  color:#fff;
}
.vfc-app .btn.primary:hover{ background:var(--accent-deep); border-color:var(--accent-deep); }
.vfc-app .btn:disabled{ opacity:0.4; cursor:not-allowed; }
.vfc-app .btn:disabled:hover{ border-color:var(--line-strong); background:var(--paper); }
.vfc-app .btn.ghost{
  border-color:transparent;
  color:var(--ink-soft);
}
.vfc-app .btn.ghost:hover{ color:var(--ink); border-color:var(--line); }

/* Variation rows (step 2: pick fee rows for the chosen country) */
.vfc-app .row-list{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.vfc-app .row-card{
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:14px 16px;
  margin-bottom:0;
  background:var(--paper);
}
.vfc-app .row-card.active{ border-color:var(--accent); background:var(--accent-soft); }
.vfc-app .row-card-top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:10px;
  cursor:default;
}
.vfc-app .row-card-title{ display:flex; flex-direction:column; gap:2px; }
.vfc-app .row-card-title .t1{ font-size:13.5px; font-weight:600; color:var(--ink); }
.vfc-app .row-card-title .t2{ font-size:12px; color:var(--ink-faint); }
.vfc-app .row-card input[type=checkbox]{
  width:18px;height:18px;
  accent-color:var(--accent);
  margin-top:1px;
  flex-shrink:0;
}
.vfc-app .row-card-body{
  margin-top:12px;
  padding-top:12px;
  border-top:1px solid var(--line);
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
@media print {
  .vfc-app{ background:#fff; }
  .vfc-app .app-head .tag, .vfc-app .subhead, .vfc-app .rail, .vfc-app .nav-row, .vfc-app .export-buttons,
  .vfc-app .src, .vfc-app button, .vfc-app .btn, .vfc-app #vfc-changelogPanel, .vfc-app #vfc-toggleChangelog { display:none !important; }
  .vfc-app{ max-width:100%; padding:0; }
  .vfc-app .result-panel{ background:#1a3a37 !important; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
  .vfc-app .panel{ border:1px solid #ccc; box-shadow:none; }
  .vfc-app .breakdown{ border:1px solid #ccc; }
  @page { margin: 1.5cm; }
}

/* Results */
.vfc-app .result-panel{
  background:var(--accent-deep);
  color:#fff;
  border-radius:var(--radius);
  padding:26px 24px;
  margin-bottom:18px;
}
.vfc-app .result-panel .rp-top-row{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  flex-wrap:wrap;
  gap:6px 16px;
  margin-bottom:8px;
}
.vfc-app .result-panel .rp-label{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#a9c9c6;
  margin-bottom:0;
}
.vfc-app .result-panel .rp-updated{
  font-family:var(--mono);
  font-size:11px;
  color:#a9c9c6;
  white-space:nowrap;
}
.vfc-app .result-panel .rp-total{
  font-family:var(--serif);
  font-size:40px;
  font-weight:600;
  letter-spacing:-0.01em;
  line-height:1;
}
.vfc-app .result-panel .rp-total .cur{ font-size:22px; font-weight:500; margin-right:6px; opacity:0.85; }
.vfc-app .result-panel .rp-sub{
  margin-top:10px;
  font-size:12.5px;
  color:#cfe2e0;
}

.vfc-app .fee-note{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-top:8px;
  padding:6px 10px;
  border-radius:var(--radius);
  font-size:11.5px;
  line-height:1.45;
  width:100%;
  box-sizing:border-box;
}
.vfc-app .fee-note--cap{
  background:#fef9ec;
  border:1px solid #e8d89a;
  color:#7a5c00;
}
.vfc-app .fee-note--group{
  background:#edf4ff;
  border:1px solid #b3cff0;
  color:#1a4a80;
}
.vfc-app .fee-note b{ font-weight:600; }
.vfc-app .fee-note .fn-label{ flex:1; }
.vfc-app .fee-note .fn-amount{
  font-family:var(--mono);
  font-weight:700;
  white-space:nowrap;
  flex-shrink:0;
}
.vfc-app .local-currency-row{
  margin-top:10px;
  padding:10px 12px;
  background:var(--accent-soft);
  border-radius:var(--radius);
  border:1px solid var(--line);
  width:100%;
  box-sizing:border-box;
}
.vfc-app .local-currency-row .lc-header{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:10px;
  margin-bottom:6px;
}
.vfc-app .local-currency-row .lc-title{
  font-size:11px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.03em;
  color:var(--ink-soft);
}
.vfc-app .local-currency-row .lc-rate{
  font-family:var(--mono);
  font-size:10.5px;
  color:var(--ink-faint);
  white-space:nowrap;
}
.vfc-app .local-currency-row .lc-items{
  margin-bottom:6px;
}
.vfc-app .local-currency-row .lc-items .bd-meta{
  color:var(--ink-soft);
}
.vfc-app .local-currency-row .lc-total{
  display:flex;
  justify-content:flex-end;
  align-items:baseline;
  gap:10px;
  padding-top:6px;
  border-top:1px solid var(--line);
}
.vfc-app .local-currency-row .lc-total-label{
  font-size:11px;
  font-weight:600;
  color:var(--ink-soft);
}
.vfc-app .local-currency-row .lc-amount{
  font-family:var(--mono);
  font-size:13px;
  font-weight:700;
  color:var(--accent-deep);
  white-space:nowrap;
}
.vfc-app .breakdown{
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  margin-bottom:18px;
}
.vfc-app .breakdown-row{
  display:flex;
  flex-direction:column;
  padding:14px 16px;
  background:var(--panel);
}
.vfc-app .breakdown-row .bd-top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  width:100%;
}
.vfc-app .breakdown-divider{
  height:1px;
  background:var(--line);
  margin:0 16px;
}
.vfc-app .breakdown-row .bd-left{ display:flex; flex-direction:column; gap:2px; min-width:0; }
.vfc-app .breakdown-row .bd-name{ font-size:13.5px; font-weight:600; color:var(--ink); }
.vfc-app .breakdown-row .bd-meta{ font-size:11.5px; color:var(--ink-faint); font-family:var(--mono); }
.vfc-app .breakdown-row .bd-meta b{ color:var(--ink-soft); font-weight:700; }
.vfc-app .breakdown-row .bd-amount-col{ display:flex; flex-direction:column; align-items:flex-end; gap:2px; flex-shrink:0; }
.vfc-app .breakdown-row .bd-amount{
  font-family:var(--mono);
  font-size:15px;
  font-weight:600;
  color:var(--ink);
  white-space:nowrap;
}
/* Grand total row */
.vfc-app .breakdown-row.total-row{
  border-top:2px solid var(--line-strong);
}
.vfc-app .breakdown-row.total-row .bd-top{ align-items:center; }
.vfc-app .breakdown-row.total-row .bd-name{
  font-size:17px;
  font-weight:700;
  color:var(--accent-deep);
  font-family:var(--mono);
}
.vfc-app .breakdown-row.total-row .bd-amount{
  font-size:17px;
  color:var(--accent-deep);
}
.vfc-app .breakdown-row.subtotal{ background:var(--accent-soft); }
.vfc-app .breakdown-row.subtotal .bd-amount{ color:var(--accent-deep); }

.vfc-app .export-buttons{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-bottom:18px;
}
.vfc-app .btn-export{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:7px 14px;
  border-radius:var(--radius);
  border:1px solid var(--line-strong);
  background:var(--panel);
  font-size:12px;
  font-family:var(--mono);
  color:var(--ink-soft);
  cursor:pointer;
  transition:background .12s, border-color .12s;
}
.vfc-app .btn-export:hover{ background:var(--accent-soft); border-color:var(--accent); color:var(--accent-deep); }
.vfc-app .btn-export svg{ flex-shrink:0; }

.vfc-app .src{
  margin-top:30px;
  padding-top:16px;
  border-top:1px solid var(--line);
  font-size:11.5px;
  color:var(--ink-faint);
  display:flex;
  flex-direction:column;
  gap:6px;
}
.vfc-app .src a{ color:var(--ink-faint); }
.vfc-app .src .fx-status-row{
  display:flex;
  justify-content:flex-end;
}

.vfc-app .badge{
  display:inline-block;
  font-family:var(--mono);
  font-size:10px;
  padding:2px 6px;
  border-radius:3px;
  background:var(--accent-soft);
  color:var(--accent-deep);
  letter-spacing:0.03em;
}

.vfc-app ::selection{ background:var(--accent-soft); }
