:root {
  --vm-blue: #215ae5;
  --vm-blue-dark: #163d96;
  --vm-yellow: #d9a51d;
  --vm-yellow-dark: #a67708;
  --vm-green: #12936a;
  --vm-gas: #1d8a67;
  --vm-text: #172033;
  --vm-text-soft: #5b6778;
  --vm-bg-page: #edf2f7;
  --vm-border: #dbe3ef;
  --vm-border-soft: #edf2f7;
  --vm-footer-bg: #ffffff;
  --vm-shadow: 0 18px 48px rgba(19, 35, 59, 0.10);
  --vm-shadow-soft: 0 10px 28px rgba(19, 35, 59, 0.07);
  --vm-radius-xl: 28px;
  --vm-container: 1180px;
}
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; min-width: 320px; background: var(--vm-bg-page); color: var(--vm-text); font-family: Inter, Arial, Helvetica, sans-serif; font-size: 15px; line-height: 1.45; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; height: auto; }
table { width: 100%; border-collapse: collapse; }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }
.vm-container { width: min(100% - 32px, var(--vm-container)); margin-inline: auto; }
.vm-site-header { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,.96); border-bottom: 1px solid var(--vm-border); backdrop-filter: blur(14px); }
.vm-header-row { min-height: 82px; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.vm-header-left {
  display: flex;
  align-items: center;
  min-width: 0;
}
.vm-brand img { width: 260px; height: auto; object-fit: contain; }
.vm-header-actions { display: flex; align-items: center; gap: 10px; margin-left: auto; }
.vm-main-nav { display: inline-flex; align-items: center; gap: 4px; }
.vm-main-nav a { display: inline-flex; align-items: center; justify-content: center; min-height: 36px; padding: 0 12px; border-radius: 999px; color: #384557; font-size: 13px; font-weight: 850; white-space: nowrap; }
.vm-main-nav a:hover { color: var(--vm-blue); background: #eef4ff; }
.vm-header-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 18px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--vm-blue), var(--vm-green));
  color: #fff;
  font-size: 13px;
  font-weight: 950;
  white-space: nowrap;
  box-shadow: 0 12px 24px rgba(22, 87, 216, 0.18);
}
.vm-lang-switch { display: inline-flex; align-items: center; gap: 2px; padding: 2px; border: 1px solid var(--vm-border); border-radius: 999px; background: #fff; }
.vm-lang-switch a { display: inline-flex; align-items: center; justify-content: center; min-width: 32px; min-height: 30px; padding: 0 8px; border-radius: 999px; color: var(--vm-text-soft); font-size: 11px; font-weight: 950; }
.vm-lang-switch a.is-active { background: #edf4ff; color: var(--vm-blue); }
.vm-main { display: block; }
.vm-hero, .vm-catalog-section, .vm-partners, .vm-prices { padding: 20px 0; }
.vm-app-frame { border: 1px solid var(--vm-border); border-radius: var(--vm-radius-xl); background: #fff; box-shadow: var(--vm-shadow); }
.vm-hero-frame-clean { padding: 30px; background: radial-gradient(circle at 84% 16%, rgba(33,90,229,.08), transparent 28%), linear-gradient(135deg,#fff 0%,#f8fbff 62%,#edf4ff 100%); }
.vm-hero-grid-clean { display: grid; grid-template-columns: minmax(0,1fr) 360px; gap: 26px; align-items: center; }
.vm-eyebrow, .vm-section-kicker { margin: 0 0 8px; color: var(--vm-blue); font-size: 11px; font-weight: 950; letter-spacing: .12em; text-transform: uppercase; }
.vm-hero-copy h1 { margin: 0; color: var(--vm-text); font-size: clamp(40px,6vw,72px); line-height: .95; letter-spacing: -.06em; font-weight: 950; }
.vm-lead { max-width: 620px; margin: 18px 0 0; color: var(--vm-text-soft); font-size: 17px; font-weight: 700; }
.vm-hero-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 22px; }
.vm-primary-btn, .vm-secondary-btn { display: inline-flex; align-items: center; justify-content: center; min-height: 46px; padding: 0 20px; border-radius: 999px; font-size: 14px; font-weight: 950; }
.vm-primary-btn { background: linear-gradient(135deg,var(--vm-blue),var(--vm-green)); color: #fff; box-shadow: 0 16px 30px rgba(22,87,216,.20); }
.vm-secondary-btn { background: #fff; color: var(--vm-blue); border: 1px solid #dbe7ff; }
.vm-gift-inline { display: inline-flex; flex-direction: column; gap: 3px; margin-top: 18px; padding: 12px 14px; border: 1px solid #ffe4a0; border-radius: 16px; background: #fff8e4; color: #7b5604; }
.vm-gift-inline small { font-size: 11px; font-weight: 950; text-transform: uppercase; letter-spacing: .08em; }
.vm-gift-inline strong { font-size: 15px; font-weight: 950; }
.vm-gift-inline span { font-size: 13px; font-weight: 700; }
.vm-stats-card { border: 1px solid var(--vm-border); border-radius: 24px; background: rgba(255,255,255,.86); box-shadow: var(--vm-shadow-soft); padding: 18px; }
.vm-stats-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 10px; }
.vm-stat-box { min-height: 108px; display: flex; flex-direction: column; justify-content: space-between; padding: 14px; border: 1px solid var(--vm-border); border-radius: 18px; background: #fff; }
.vm-stat-box small { color: var(--vm-text-soft); font-size: 12px; line-height: 1.2; font-weight: 850; }
.vm-stat-box strong { color: var(--vm-text); font-size: 36px; line-height: 1; font-weight: 950; letter-spacing: -.04em; }
.vm-stat-box--blue { background: #f4f8ff; border-color: #cfe0ff; }
.vm-stat-box--blue strong { color: var(--vm-blue); }
.vm-stat-box--yellow { background: #fff9ea; border-color: #f1dd98; }
.vm-stat-box--yellow strong { color: var(--vm-yellow-dark); }
.vm-catalog-frame, .vm-partners-frame { padding: 24px; }
.vm-catalog-topline { display: flex; justify-content: space-between; gap: 16px; align-items: end; margin-bottom: 18px; }
.vm-catalog-topline h2 { margin: 0; font-size: clamp(24px,3vw,38px); line-height: 1.06; letter-spacing: -.04em; }
.vm-updated { color: var(--vm-text-soft); font-size: 12px; font-weight: 850; white-space: nowrap; }
.vm-market-tabs { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 8px; padding: 7px; margin-bottom: 12px; border: 1px solid var(--vm-border); border-radius: 18px; background: #f7f9fd; }
.vm-market-tab { min-height: 44px; border: 0; border-radius: 13px; background: transparent; color: #4a5568; font-size: 13px; font-weight: 950; }
.vm-market-tab.is-active { background: #fff; color: var(--vm-blue); box-shadow: 0 8px 20px rgba(17,28,48,.08); }
.vm-panel, .vm-subpanel { display: none; }
.vm-panel.is-active, .vm-subpanel.is-active { display: block; }
.vm-subswitcher { display: inline-flex; gap: 6px; padding: 5px; margin: 0 0 12px; border: 1px solid var(--vm-border); border-radius: 999px; background: #fff; }
.vm-subswitch { min-height: 34px; padding: 0 14px; border: 0; border-radius: 999px; background: transparent; color: #4a5568; font-size: 12.5px; font-weight: 950; }
.vm-subswitch.is-active { background: var(--vm-blue); color: #fff; }
#yellow-panel .vm-subswitch.is-active { background: var(--vm-yellow-dark); }
#gas-panel .vm-subswitch.is-active { background: var(--vm-gas); }
.vm-table-headline { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin: 2px 0 10px; color: var(--vm-text); font-size: 14px; font-weight: 950; }
.vm-table-wrap { max-width: 100%; overflow-x: auto; border: 1px solid var(--vm-border); border-radius: 18px; background: #fff; -webkit-overflow-scrolling: touch; }
.vm-table-wrap--blue { border-color: #cfe0ff; }
.vm-table-wrap--yellow { border-color: #f0de9d; }
.vm-table-wrap--gas { border-color: #cde5db; }
.vm-table { min-width: 940px; }
.vm-table th { position: sticky; top: 0; z-index: 1; padding: 11px 10px; background: #f3f7fc; color: #536074; border-bottom: 1px solid var(--vm-border); text-align: left; font-size: 11px; font-weight: 950; text-transform: uppercase; letter-spacing: .035em; white-space: nowrap; }
.vm-table--blue th { background: #eef4ff; }
.vm-table--yellow th { background: #fff8e7; }
.vm-table--gas th { background: #edf8f3; }
.vm-table td { padding: 11px 10px; border-bottom: 1px solid var(--vm-border-soft); color: #253044; font-size: 13px; font-weight: 720; vertical-align: middle; }
.vm-table tbody tr:hover { background: #fbfdff; }
.vm-program-cell { min-width: 220px; font-weight: 900 !important; color: #172033 !important; }
.vm-final-price { font-weight: 950 !important; white-space: nowrap; }
.vm-table--blue .vm-final-price { color: var(--vm-blue) !important; }
.vm-table--yellow .vm-final-price { color: var(--vm-yellow-dark) !important; }
.vm-table--gas .vm-final-price { color: var(--vm-gas) !important; }
.vm-action-col, .vm-action-cell { width: 88px; min-width: 88px; text-align: center !important; }
.vm-action-cell { position: sticky; right: 0; background: #fff; box-shadow: -10px 0 16px rgba(255,255,255,.86); }
.vm-table tbody tr:hover .vm-action-cell { background: #fbfdff; }
.vm-online-pill { display: inline-flex; align-items: center; justify-content: center; min-width: 66px; min-height: 30px; padding: 0 12px; border-radius: 999px; border: 1.5px solid transparent; background: #fff; font-size: 11px; font-weight: 950; }
.vm-online-pill--blue { color: var(--vm-blue); border-color: #9fbcff; }
.vm-online-pill--yellow { color: var(--vm-yellow-dark); border-color: #ebcf78; }
.vm-online-pill--gas { color: var(--vm-gas); border-color: #9ed1be; }
.vm-empty-action { display: inline-block; width: 1px; min-height: 30px; }
.vm-empty { padding: 22px !important; color: var(--vm-text-soft) !important; font-weight: 850 !important; text-align: center !important; }
.vm-disclaimer { margin: 12px 2px 0; color: var(--vm-text-soft); font-size: 12.5px; font-weight: 740; }
.vm-gas-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 12px; }
.vm-gas-card, .vm-gas-info-card { border: 1px solid var(--vm-border); border-radius: 18px; background: #fff; padding: 16px; box-shadow: var(--vm-shadow-soft); }
.vm-gas-provider { margin: 0; color: var(--vm-gas); font-size: 12px; font-weight: 950; text-transform: uppercase; }
.vm-gas-card h3 { margin: 8px 0 12px; font-size: 18px; line-height: 1.15; }
.vm-gas-metrics { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 8px; }
.vm-gas-metrics span { padding: 9px; border-radius: 12px; background: #f6f8fc; color: #263347; font-size: 12px; font-weight: 780; }
.vm-gas-notes { margin: 10px 0 0; color: var(--vm-text-soft); font-size: 12.5px; }
.vm-gas-action { margin-top: 14px; }
.vm-gas-info-card p { margin: 0; color: var(--vm-text-soft); font-weight: 800; }
.vm-logos { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 14px; }
.vm-logo-box { min-height: 112px; display: flex; align-items: center; justify-content: center; padding: 20px; border: 1px solid var(--vm-border); border-radius: 18px; background: #fff; }
.vm-logo-box img { max-width: 170px; max-height: 52px; object-fit: contain; }
.vm-logo-box-zenith {
  max-width: 220px !important;
  max-height: 82px !important;
}
.vm-site-footer { margin-top: 24px; background: #ffffff; border-top: 1px solid var(--vm-border); }
.vm-footer-grid { display: grid; grid-template-columns: minmax(0,1.6fr) repeat(3,minmax(0,.8fr)); gap: 22px; padding: 28px 0 20px; }
.vm-footer-main p { max-width: 540px; margin: 14px 0 0; color: var(--vm-text-soft); font-size: 14px; line-height: 1.6; }
.vm-footer-logo { width: 180px; }
.vm-footer-col h3 { margin: 0 0 12px; color: var(--vm-text); font-size: 13px; font-weight: 950; text-transform: uppercase; letter-spacing: .04em; }
.vm-footer-col a, .vm-footer-col span { display: block; margin: 0 0 8px; color: var(--vm-text-soft); font-size: 14px; font-weight: 700; }
.vm-footer-powered img { width: 140px; }
.vm-footer-bottom { padding: 14px 0 18px; border-top: 1px solid #d8e1ec; color: var(--vm-text-soft); font-size: 12px; font-weight: 700; text-align: center; }
@media (max-width: 1080px) { .vm-brand img { width: 230px; } .vm-header-tagline-minute span { font-size: 32px; } .vm-header-tagline-minute sup { font-size: 22px; } .vm-hero-grid-clean { grid-template-columns: 1fr; } .vm-stats-card { order: 2; } .vm-footer-grid { grid-template-columns: repeat(2,minmax(0,1fr)); } }
@media (max-width: 820px) { .vm-header-row { min-height: auto; padding: 12px 0; flex-direction: column; align-items: stretch; } .vm-header-left, .vm-header-actions { width: 100%; } .vm-header-left {
  display: flex;
  align-items: center;
  min-width: 0;
} .vm-brand img { width: 210px; } .vm-header-tagline { min-height: 38px; padding-left: 14px; gap: 8px; } .vm-header-tagline-minute span { font-size: 30px; } .vm-header-tagline-minute sup { font-size: 20px; } .vm-header-tagline-copy { font-size: 14px; } .vm-header-actions { justify-content: space-between; } .vm-main-nav a { padding: 0 10px; } .vm-market-tabs { grid-template-columns: 1fr; } .vm-gas-grid, .vm-logos, .vm-footer-grid { grid-template-columns: 1fr; } }
@media (max-width: 640px) { .vm-container { width: min(100% - 20px,var(--vm-container)); } .vm-header-left {
  display: flex;
  align-items: center;
  min-width: 0;
} .vm-header-actions { flex-wrap: wrap; gap: 8px; } .vm-main-nav { order: 3; width: 100%; justify-content: flex-start; overflow-x: auto; } .vm-hero-frame-clean, .vm-catalog-frame, .vm-partners-frame { padding: 18px; } .vm-hero-copy h1 { font-size: 46px; } .vm-lead { font-size: 15px; } .vm-primary-btn, .vm-secondary-btn { width: 100%; } .vm-stats-grid { grid-template-columns: 1fr 1fr; } .vm-stat-box { min-height: 92px; } .vm-catalog-topline { flex-direction: column; align-items: flex-start; } .vm-subswitcher { width: 100%; justify-content: space-between; } .vm-subswitch { flex: 1 1 auto; } .vm-gas-metrics { grid-template-columns: 1fr; } .vm-footer-bottom { text-align: left; } }


/* FINAL5 footer refinement */
.vm-site-footer {
  background: #ffffff;
}
.vm-footer-bottom {
  background: #ffffff;
}


/* FINAL6: clearer row separation by tariff color */
.vm-table--blue tbody tr:nth-child(odd) td {
  background: #ffffff;
}
.vm-table--blue tbody tr:nth-child(even) td {
  background: #f4f8ff;
}
.vm-table--yellow tbody tr:nth-child(odd) td {
  background: #ffffff;
}
.vm-table--yellow tbody tr:nth-child(even) td {
  background: #fff8e8;
}
.vm-table--gas tbody tr:nth-child(odd) td {
  background: #ffffff;
}
.vm-table--gas tbody tr:nth-child(even) td {
  background: #f1faf6;
}

/* keep sticky action column aligned with the row color */
.vm-table--blue tbody tr:nth-child(odd) .vm-action-cell {
  background: #ffffff;
}
.vm-table--blue tbody tr:nth-child(even) .vm-action-cell {
  background: #f4f8ff;
}
.vm-table--yellow tbody tr:nth-child(odd) .vm-action-cell {
  background: #ffffff;
}
.vm-table--yellow tbody tr:nth-child(even) .vm-action-cell {
  background: #fff8e8;
}
.vm-table--gas tbody tr:nth-child(odd) .vm-action-cell {
  background: #ffffff;
}
.vm-table--gas tbody tr:nth-child(even) .vm-action-cell {
  background: #f1faf6;
}

/* hover stays slightly stronger but consistent */
.vm-table--blue tbody tr:hover td {
  background: #eaf2ff;
}
.vm-table--yellow tbody tr:hover td {
  background: #fff2cf;
}
.vm-table--gas tbody tr:hover td {
  background: #e8f7f0;
}
.vm-table--blue tbody tr:hover .vm-action-cell {
  background: #eaf2ff;
}
.vm-table--yellow tbody tr:hover .vm-action-cell {
  background: #fff2cf;
}
.vm-table--gas tbody tr:hover .vm-action-cell {
  background: #e8f7f0;
}


/* FINAL7: mobile header/menu cleanup */
@media (max-width: 640px) {
  .vm-site-header {
    position: static;
  }

  .vm-header-row {
    padding: 16px 0 18px;
    gap: 16px;
  }

  .vm-header-left {
    width: 100%;
    justify-content: center;
    align-items: center;
  }

  .vm-brand {
    justify-content: center;
  }

  .vm-brand img {
    width: min(285px, 82vw);
  }

  .vm-header-actions {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 12px;
  }

  .vm-main-nav {
    display: none !important;
  }

  .vm-header-cta {
    width: 100%;
    min-height: 48px;
    padding: 0 18px;
    font-size: 15px;
  }

  .vm-lang-switch {
    justify-self: end;
    min-height: 48px;
    padding: 3px;
  }

  .vm-lang-switch a {
    min-width: 43px;
    min-height: 40px;
    font-size: 13px;
  }
}

@media (max-width: 390px) {
  .vm-header-actions {
    grid-template-columns: 1fr;
  }

  .vm-lang-switch {
    justify-self: center;
  }
}


/* CAMPAIGN ENGINE: full-width banner below menu */
.vm-campaign-hero {
  padding: 18px 0 0;
  background: linear-gradient(180deg,#f7f9fd 0%,#ffffff 100%);
}
.vm-campaign-hero-card {
  display: grid;
  grid-template-columns: minmax(0,1.25fr) minmax(280px,.75fr);
  gap: 18px;
  align-items: stretch;
  padding: 18px;
  border: 1px solid #dbe7fb;
  border-radius: 24px;
  background: #ffffff;
  box-shadow: 0 16px 40px rgba(12,31,66,.10);
  overflow: hidden;
}
.vm-campaign-visual {
  min-height: 250px;
  border-radius: 18px;
  overflow: hidden;
  background: #eef4ff;
}
.vm-campaign-visual img {
  width: 100%;
  height: 100%;
  min-height: 250px;
  display: block;
  object-fit: cover;
}
.vm-campaign-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 10px;
  padding: 12px 8px;
}
.vm-campaign-kicker {
  margin: 0;
  color: var(--vm-blue);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.vm-campaign-copy h2 {
  margin: 0;
  color: var(--vm-text);
  font-size: clamp(26px,3vw,42px);
  line-height: 1.05;
  letter-spacing: -.03em;
}
.vm-campaign-copy p {
  margin: 0;
  color: var(--vm-text-soft);
  font-size: 15px;
  font-weight: 760;
  line-height: 1.45;
}
.vm-campaign-scope {
  display: inline-flex;
  width: fit-content;
  padding: 7px 10px;
  border-radius: 999px;
  background: #f1f6ff;
  color: #2e456a;
  font-size: 12px;
  font-weight: 900;
}
.vm-campaign-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 42px;
  margin-top: 4px;
  padding: 0 16px;
  border-radius: 999px;
  background: var(--vm-blue);
  color: #ffffff;
  font-size: 13px;
  font-weight: 950;
  text-decoration: none;
}
.vm-action-stack {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
}
.vm-campaign-plan-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 3px 7px;
  border-radius: 999px;
  background: #fff1c2;
  color: #7a5200;
  font-size: 10px;
  font-weight: 950;
  line-height: 1;
  white-space: nowrap;
}
@media (max-width: 900px) {
  .vm-campaign-hero-card {
    grid-template-columns: 1fr;
  }
  .vm-campaign-copy {
    padding: 2px 4px 4px;
  }
}
@media (max-width: 640px) {
  .vm-campaign-hero {
    padding-top: 10px;
  }
  .vm-campaign-hero-card {
    padding: 12px;
    border-radius: 20px;
    gap: 12px;
  }
  .vm-campaign-visual,
  .vm-campaign-visual img {
    min-height: 190px;
  }
  .vm-campaign-copy h2 {
    font-size: 26px;
  }
  .vm-campaign-btn {
    width: 100%;
  }
}

/* FINAL10: VoltMarket premium white + compact mobile header
   Ενιαίο τελικό CSS override.
   Περιλαμβάνει:
   - premium λευκή βάση
   - soft shadows
   - καθαρά λευκά cards
   - σωστό compact mobile header
   - κρύψιμο επάνω CTA μόνο στο mobile
   Δεν αλλάζει DB, campaigns, switch, admin ή importer.
*/
:root {
  --vm-page-bg: #ffffff;
  --vm-card-bg: #ffffff;
  --vm-soft-border: #e8eef7;
  --vm-soft-shadow: 0 18px 48px rgba(15, 23, 42, 0.075);
  --vm-soft-shadow-sm: 0 10px 28px rgba(15, 23, 42, 0.055);
}

html,
body {
  background: #ffffff !important;
}

body {
  background:
    radial-gradient(circle at 8% 5%, rgba(37, 99, 235, 0.055), transparent 30%),
    radial-gradient(circle at 92% 12%, rgba(16, 185, 129, 0.050), transparent 28%),
    linear-gradient(180deg, #ffffff 0%, #ffffff 48%, #fbfdff 100%) !important;
}

.vm-site-header {
  background: rgba(255, 255, 255, 0.96) !important;
  border-bottom: 1px solid rgba(226, 232, 240, 0.95) !important;
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.045);
  backdrop-filter: blur(14px);
}

.vm-hero,
.vm-section,
.vm-catalog-section,
.vm-partners,
.vm-prices,
.vm-how,
.vm-faq,
.vm-providers-section {
  background: transparent !important;
}

.vm-hero-card,
.vm-card,
.vm-stat-card,
.vm-provider-card,
.vm-price-card,
.vm-program-card,
.vm-filter-card,
.vm-catalog-panel,
.vm-section-card,
.vm-table-wrap,
.vm-steps-card,
.vm-faq-card,
.vm-partner-card {
  background: var(--vm-card-bg) !important;
  border: 1px solid var(--vm-soft-border) !important;
  box-shadow: var(--vm-soft-shadow-sm) !important;
}

.vm-hero-card {
  box-shadow: var(--vm-soft-shadow) !important;
}

.vm-campaign-banner,
.vm-campaign-hero,
.vm-campaign-card,
.vm-active-campaign {
  background: #ffffff !important;
  border: 1px solid var(--vm-soft-border) !important;
  box-shadow: var(--vm-soft-shadow) !important;
}

.vm-campaign-banner img,
.vm-campaign-hero img,
.vm-campaign-card img,
.vm-active-campaign img {
  box-shadow: none !important;
}

.vm-table,
.vm-table thead,
.vm-table tbody,
.vm-program-table,
.vm-program-table thead,
.vm-program-table tbody {
  background: #ffffff !important;
}

.vm-table tr,
.vm-program-table tr {
  background: #ffffff;
}

.vm-table tr:nth-child(even),
.vm-program-table tr:nth-child(even) {
  background: #fbfdff;
}

.vm-btn,
.vm-primary-btn,
.vm-cta,
.vm-header-cta,
.vm-switch-btn {
  box-shadow: 0 12px 28px rgba(37, 99, 235, 0.18);
}

.vm-btn-light,
.vm-secondary-btn,
.vm-main-nav a,
.vm-lang-switch {
  background: #ffffff !important;
  border-color: var(--vm-soft-border) !important;
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.045);
}

.vm-main-nav a:hover,
.vm-lang-switch a.is-active,
.vm-lang-switch a.active {
  background: #f7fbff !important;
}

/* Mobile: compact header, no giant top CTA */
@media (max-width: 640px) {
  body {
    background:
      radial-gradient(circle at 10% 3%, rgba(37, 99, 235, 0.045), transparent 28%),
      linear-gradient(180deg, #ffffff 0%, #ffffff 55%, #fbfdff 100%) !important;
  }

  .vm-site-header {
    position: static;
    background: #ffffff !important;
    border-bottom: 1px solid #e6edf6 !important;
    box-shadow: 0 8px 22px rgba(15, 23, 42, 0.04);
    backdrop-filter: none;
  }

  .vm-site-header .vm-container {
    width: min(100% - 28px, var(--vm-container));
  }

  .vm-header-row {
    min-height: 0;
    padding: 12px 0 13px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
  }

  .vm-header-left {
    width: 100%;
    justify-content: center;
  }

  .vm-brand {
    display: inline-flex;
    justify-content: center;
  }

  .vm-brand img {
    width: min(235px, 72vw);
    max-width: 235px;
    height: auto;
  }

  .vm-header-actions {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 8px;
  }

  .vm-header-cta {
    display: none !important;
  }

  .vm-main-nav {
    order: 0;
    width: 100%;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
    overflow: visible;
  }

  .vm-main-nav a {
    min-height: 36px;
    padding: 0 10px;
    border: 1px solid #dce5f1;
    border-radius: 999px;
    background: #ffffff !important;
    color: #334155;
    font-size: 12.5px;
    font-weight: 900;
    box-shadow: 0 6px 16px rgba(19,35,59,.045);
  }

  .vm-main-nav a:hover {
    background: #f6f9ff !important;
    color: var(--vm-blue);
  }

  .vm-lang-switch {
    justify-self: end;
    min-height: 36px;
    padding: 2px;
    border-radius: 999px;
    background: #ffffff !important;
    border: 1px solid #dce5f1;
    box-shadow: 0 6px 16px rgba(19,35,59,.045);
  }

  .vm-lang-switch a {
    min-width: 34px;
    min-height: 30px;
    padding: 0 7px;
    font-size: 11.5px;
  }

  .vm-hero,
  .vm-catalog-section,
  .vm-partners,
  .vm-prices {
    padding-top: 14px;
  }

  .vm-hero-card,
  .vm-campaign-banner,
  .vm-campaign-hero,
  .vm-campaign-card,
  .vm-active-campaign {
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.065) !important;
  }
}

@media (max-width: 390px) {
  .vm-header-actions {
    grid-template-columns: 1fr;
  }

  .vm-lang-switch {
    justify-self: center;
  }
}

/* VOLT ecosystem v2: one-line mobile header/menu patch */
.vm-mobile-menu{display:none;position:relative;margin-left:auto}
.vm-mobile-menu summary{list-style:none;display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:0 14px;border-radius:999px;background:#215ae5;color:#fff;font-size:13px;font-weight:950;box-shadow:0 10px 22px rgba(33,90,229,.18);cursor:pointer}
.vm-mobile-menu summary::-webkit-details-marker{display:none}
.vm-mobile-menu-panel{position:absolute;right:0;top:calc(100% + 9px);width:min(285px,calc(100vw - 24px));background:#fff;border:1px solid #dbe3ef;border-radius:20px;padding:10px;box-shadow:0 22px 48px rgba(15,23,42,.18);z-index:100}
.vm-mobile-menu-panel a{display:flex;align-items:center;justify-content:space-between;padding:12px 13px;border-radius:14px;color:#163d96;font-weight:900}
.vm-mobile-menu-panel a:hover{background:#f6f9ff}
.vm-mobile-lang{display:flex;gap:6px;padding:8px 4px 2px}
.vm-mobile-lang a{flex:1;justify-content:center;border:1px solid #dbe3ef}
@media (max-width:640px){
  .vm-header-row{min-height:64px!important;padding:8px 0!important;display:flex!important;flex-direction:row!important;align-items:center!important;justify-content:space-between!important;gap:10px!important}
  .vm-header-left{width:auto!important;justify-content:flex-start!important}
  .vm-brand{justify-content:flex-start!important}
  .vm-brand img{width:min(168px,52vw)!important;max-width:168px!important;height:auto!important}
  .vm-header-actions--desktop{display:none!important}
  .vm-mobile-menu{display:block!important}
}
@media (max-width:380px){.vm-brand img{width:min(150px,49vw)!important}.vm-mobile-menu summary{padding:0 12px;font-size:12.5px}}

/* VOLT ecosystem common footer for VoltMarket */
.vm-ecosystem-footer {
  margin-top: 34px;
  background: #ffffff !important;
  border-top: 1px solid #e4ebf5;
  box-shadow: 0 -12px 38px rgba(15, 23, 42, 0.035);
}

.vm-ecosystem-footer-grid {
  display: grid;
  grid-template-columns: minmax(240px, 1.35fr) repeat(3, minmax(170px, .75fr));
  gap: 26px;
  padding: 32px 0 22px;
}

.vm-ecosystem-footer-main p {
  max-width: 380px;
  margin: 12px 0 0;
  color: #52627a;
  font-size: 14px;
  line-height: 1.55;
  font-weight: 750;
}

.vm-footer-logo-link,
.vm-energys-logo-link {
  display: inline-flex !important;
  width: fit-content;
  margin: 0 0 10px !important;
}

.vm-ecosystem-footer .vm-footer-logo {
  width: 176px;
  height: auto;
  object-fit: contain;
}

.vm-ecosystem-footer .vm-footer-col h3 {
  margin: 0 0 13px;
  color: #10233f;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .075em;
}

.vm-ecosystem-footer .vm-footer-col a,
.vm-ecosystem-footer .vm-footer-col span {
  display: block;
  width: fit-content;
  margin: 0 0 9px;
  color: #506176;
  font-size: 14px;
  font-weight: 800;
  line-height: 1.25;
  text-decoration: none;
}

.vm-ecosystem-footer .vm-footer-col a:hover {
  color: var(--vm-blue);
}

.vm-ecosystem-footer .vm-footer-powered img {
  width: 138px;
  height: auto;
  object-fit: contain;
}

.vm-ecosystem-footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 15px 0 18px;
  border-top: 1px solid #dde6f1;
  color: #66758a;
  font-size: 12px;
  font-weight: 800;
  text-align: left;
}

.vm-legal-page {
  padding: 28px 0 46px;
}

.vm-legal-card {
  padding: 30px;
  border: 1px solid #e4ebf5;
  border-radius: 28px;
  background: #ffffff;
  box-shadow: 0 18px 48px rgba(15, 23, 42, 0.07);
}

.vm-legal-card h2 {
  margin: 24px 0 10px;
  color: #10233f;
  font-size: 22px;
  line-height: 1.2;
  letter-spacing: -.02em;
}

.vm-legal-card h2:first-child {
  margin-top: 0;
}

.vm-legal-card p,
.vm-legal-card li {
  color: #52627a;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.65;
}

.vm-legal-card ul {
  margin: 8px 0 0;
  padding-left: 20px;
}

.vm-legal-card a {
  color: var(--vm-blue);
  font-weight: 900;
}

@media (max-width: 1080px) {
  .vm-ecosystem-footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .vm-ecosystem-footer {
    margin-top: 24px;
  }

  .vm-ecosystem-footer-grid {
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 26px 0 18px;
  }

  .vm-ecosystem-footer .vm-footer-logo {
    width: 168px;
  }

  .vm-ecosystem-footer-bottom {
    display: grid;
    gap: 7px;
    padding-bottom: 20px;
  }

  .vm-legal-card {
    padding: 22px;
    border-radius: 22px;
  }

  .vm-legal-card h2 {
    font-size: 20px;
  }
}
