/* Premium Design System Stylesheet */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap');

:root {
  --font-display: 'Outfit', sans-serif;
  --font-body: 'Plus Jakarta Sans', sans-serif;

  /* Color Palette - Cyberpunk / Premium Energy */
  --bg-main: #060913;
  --bg-card: rgba(10, 15, 30, 0.7);
  --border-color: rgba(255, 255, 255, 0.07);
  --border-focus: rgba(0, 242, 254, 0.4);

  --accent-cyan: #00f2fe;
  --accent-blue: #4facfe;
  --accent-indigo: #667eea;
  --accent-purple: #764ba2;
  --accent-green: #38ef7d;
  --accent-yellow: #f9d423;
  --accent-orange: #ff758c;
  
  --text-main: #f3f4f6;
  --text-muted: #9ca3af;
  --text-dark: #4b5563;

  --transition-smooth: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
  --glow-cyan: 0 0 15px rgba(0, 242, 254, 0.3);
  --glow-indigo: 0 0 15px rgba(102, 126, 234, 0.3);
  --glow-green: 0 0 15px rgba(56, 239, 125, 0.3);
}

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

code {
  font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace;
  font-size: 0.88em;
  background: rgba(255, 255, 255, 0.06);
  padding: 0.1em 0.35em;
  border-radius: 4px;
  color: var(--accent-cyan);
  word-break: break-all;
}

body {
  font-family: var(--font-body);
  background-color: var(--bg-main);
  background-image: 
    radial-gradient(circle at 10% 20%, rgba(102, 126, 234, 0.08) 0%, transparent 40%),
    radial-gradient(circle at 90% 80%, rgba(0, 242, 254, 0.08) 0%, transparent 40%);
  color: var(--text-main);
  min-height: 100vh;
  line-height: 1.6;
  overflow-x: hidden;
}

/* Scrollbar Customization */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}
::-webkit-scrollbar-track {
  background: var(--bg-main);
}
::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
  background: var(--accent-blue);
}

/* Glassmorphism Classes */
.glass-panel {
  background: var(--bg-card);
  backdrop-filter: blur(16px) saturate(140%);
  -webkit-backdrop-filter: blur(16px) saturate(140%);
  border: 1px solid var(--border-color);
  border-radius: 16px;
  box-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.3);
  transition: var(--transition-smooth);
}

.glass-panel:hover {
  border-color: rgba(255, 255, 255, 0.12);
}

/* Header & Container */
.app-container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 2rem 1.5rem;
}

header {
  margin-bottom: 2.5rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.logo-section h1 {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 2.2rem;
  background: linear-gradient(135deg, var(--accent-cyan), var(--accent-indigo));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.logo-section p {
  color: var(--text-muted);
  font-size: 0.95rem;
  margin-top: 0.2rem;
}

/* Main Grid Layout */
.dashboard-grid {
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 1.5rem;
}

@media (max-width: 1100px) {
  .dashboard-grid {
    grid-template-columns: 1fr;
  }
}

/* Configuration Sidebar (Left Panel) */
.sidebar {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.section-title {
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--text-main);
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  padding-bottom: 0.5rem;
}

.section-title svg {
  color: var(--accent-cyan);
}

.form-group {
  margin-bottom: 1.2rem;
}

.form-group label {
  display: flex;
  justify-content: space-between;
  font-size: 0.85rem;
  color: var(--text-muted);
  margin-bottom: 0.4rem;
}

.form-group label span.val-badge {
  color: var(--accent-cyan);
  font-family: var(--font-display);
  font-weight: 600;
}

/* Styled Sliders */
input[type="range"] {
  -webkit-appearance: none;
  width: 100%;
  height: 6px;
  border-radius: 3px;
  background: rgba(255, 255, 255, 0.1);
  outline: none;
  transition: var(--transition-smooth);
}

input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--accent-cyan);
  box-shadow: var(--glow-cyan);
  cursor: pointer;
  transition: var(--transition-smooth);
}

input[type="range"]::-webkit-slider-thumb:hover {
  transform: scale(1.2);
  background: #ffffff;
}

/* Custom Toggle Switches */
.switch-control {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.75rem;
  padding: 0.8rem;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.03);
  margin-bottom: 1rem;
  transition: var(--transition-smooth);
}

.switch-control:hover {
  background: rgba(255, 255, 255, 0.04);
}

.switch-label-desc {
  display: flex;
  flex-direction: column;
  min-width: 0;   /* laat de tekst afbreken i.p.v. de toggle uit z'n box te duwen */
}

.switch-label-desc strong {
  font-size: 0.9rem;
  color: var(--text-main);
}

.switch-label-desc span {
  font-size: 0.75rem;
  color: var(--text-muted);
}

.toggle-switch {
  position: relative;
  display: inline-block;
  width: 44px;
  height: 24px;
  flex-shrink: 0;   /* nooit krimpen → geschoven knop blijft binnen de track/box */
}

.toggle-switch input {
  position: absolute;
  opacity: 0;
  width: 100%;
  height: 100%;
  top: 0; left: 0;
  margin: 0; padding: 0;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  z-index: 2;
}

.slider-round {
  position: absolute;
  cursor: pointer;
  top: 0; left: 0; right: 0; bottom: 0;
  background-color: rgba(255, 255, 255, 0.05);
  border: 1.5px solid rgba(255, 255, 255, 0.4);
  background-clip: padding-box;
  transition: .4s;
  border-radius: 24px;
  z-index: 1;
}

.slider-round:before {
  position: absolute;
  content: "";
  height: 14px;
  width: 14px;
  left: 3.5px;
  bottom: 3.5px;
  background-color: white;
  transition: .4s;
  border-radius: 50%;
}

input:checked + .slider-round {
  background-color: var(--accent-cyan);
}

input:checked + .slider-round:before {
  transform: translateX(20px);
}

/* Sub-panels for EV & Battery Params */
.expandable-panel {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease-out, padding 0.3s ease;
  background: rgba(0, 0, 0, 0.2);
  border-radius: 12px;
  padding: 0 0.8rem;
  margin-top: -0.5rem;
  margin-bottom: 1rem;
}

.expandable-panel.open {
  max-height: 500px;
  padding: 0.8rem;
  border: 1px solid rgba(255, 255, 255, 0.03);
}

/* Home Assistant connection panel */
.ha-card {
  padding: 1.2rem;
}

.ha-inputs {
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
  margin-top: 0.8rem;
}

.ha-inputs input {
  background: rgba(0, 0, 0, 0.3);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  padding: 0.6rem 0.8rem;
  color: var(--text-main);
  font-family: var(--font-body);
  font-size: 0.85rem;
  outline: none;
  transition: var(--transition-smooth);
}

.ha-inputs input:focus {
  border-color: var(--accent-cyan);
  box-shadow: 0 0 8px rgba(0, 242, 254, 0.2);
}

.btn-primary {
  background: linear-gradient(135deg, var(--accent-cyan), var(--accent-blue));
  border: none;
  border-radius: 8px;
  padding: 0.65rem 1rem;
  color: #060913;
  font-weight: 700;
  font-family: var(--font-display);
  cursor: pointer;
  transition: var(--transition-smooth);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  font-size: 0.85rem;
}

.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: var(--glow-cyan);
}

.btn-secondary {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  padding: 0.65rem 1rem;
  color: var(--text-main);
  font-weight: 600;
  font-family: var(--font-body);
  cursor: pointer;
  transition: var(--transition-smooth);
  font-size: 0.85rem;
  width: 100%;
}

.btn-secondary:hover {
  background: rgba(255, 255, 255, 0.08);
}

/* Upload panel */
.upload-card {
  padding: 1.2rem;
}

.upload-zone {
  border: 2px dashed rgba(255, 255, 255, 0.15);
  border-radius: 12px;
  padding: 1.5rem 1rem;
  text-align: center;
  cursor: pointer;
  transition: var(--transition-smooth);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.6rem;
  background: rgba(255, 255, 255, 0.01);
}

.upload-zone:hover, .upload-zone.dragover {
  border-color: var(--accent-cyan);
  background: rgba(0, 242, 254, 0.03);
}

.upload-zone svg {
  color: var(--accent-cyan);
  margin-bottom: 0.2rem;
}

.upload-zone p {
  font-size: 0.85rem;
  color: var(--text-muted);
}

.upload-zone strong {
  color: var(--text-main);
}

/* Dashboard Panel (Right Side) */
.main-dashboard {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

/* Top Stats row */
.stats-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem;
}

.stat-card {
  padding: 1.2rem;
  position: relative;
  overflow: hidden;
}

.stat-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; width: 4px; height: 100%;
}

.stat-card.savings::before { background: var(--accent-green); }
.stat-card.savings { box-shadow: 0 4px 20px rgba(56, 239, 125, 0.05); }

.stat-card.fixed::before { background: var(--accent-purple); }
.stat-card.dynamic::before { background: var(--accent-cyan); }

.stat-header {
  font-size: 0.8rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 1px;
}

.stat-value {
  font-family: var(--font-display);
  font-size: 1.8rem;
  font-weight: 800;
  margin-top: 0.3rem;
  display: flex;
  align-items: baseline;
  gap: 0.2rem;
}

.stat-value span.curr {
  font-size: 1.1rem;
  font-weight: 500;
}

.stat-value span.sub {
  font-size: 0.85rem;
  color: var(--text-muted);
  font-weight: 400;
  margin-left: 0.3rem;
}

.stat-subtext {
  font-size: 0.75rem;
  color: var(--text-muted);
  margin-top: 0.4rem;
  display: flex;
  align-items: center;
  gap: 0.3rem;
}

.stat-subtext .up { color: var(--accent-orange); }
.stat-subtext .down { color: var(--accent-green); }

/* Chart Container */
.chart-card {
  padding: 1.5rem;
}

.chart-header-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.2rem;
}

.chart-legends {
  display: flex;
  gap: 1rem;
  font-size: 0.8rem;
}

.legend-item {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  color: var(--text-muted);
}

.legend-color {
  width: 10px;
  height: 10px;
  border-radius: 50%;
}

.legend-color.import { background: var(--accent-cyan); box-shadow: var(--glow-cyan); }
.legend-color.export { background: var(--accent-green); box-shadow: var(--glow-green); }
.legend-color.price { background: var(--accent-yellow); }

.svg-chart-container {
  width: 100%;
  height: 320px;
  position: relative;
  overflow: visible;
  isolation: isolate;
}

.svg-chart-container svg {
  width: 100%;
  height: 100%;
  overflow: visible;
}

/* Charts must sit above sibling glass-panels */
.chart-card {
  position: relative;
  z-index: 2;
}

.chart-card:hover,
.chart-card:focus-within {
  z-index: 10;
}

/* Tooltip */
.chart-tooltip {
  position: absolute;
  top: 10px;
  left: 10px;
  pointer-events: none;
  background: rgba(6, 9, 19, 0.97);
  border: 1px solid var(--border-focus);
  padding: 0.8rem;
  border-radius: 8px;
  font-size: 0.8rem;
  box-shadow: 0 10px 25px rgba(0,0,0,0.7);
  z-index: 200;
  display: none;
}

.chart-tooltip h4 {
  font-family: var(--font-display);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  padding-bottom: 0.2rem;
  margin-bottom: 0.4rem;
  color: var(--accent-cyan);
}

.tooltip-row {
  display: flex;
  justify-content: space-between;
  gap: 1.5rem;
  margin-bottom: 0.2rem;
}

.tooltip-row span.val {
  font-weight: 600;
  font-family: var(--font-display);
}

/* Detailed Comparison Columns */
.comparison-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}

@media (max-width: 800px) {
  .comparison-grid {
    grid-template-columns: 1fr;
  }
}

.table-panel {
  padding: 1.2rem;
}

.panel-header-badge {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
}

.badge {
  font-family: var(--font-display);
  font-size: 0.75rem;
  font-weight: 700;
  padding: 0.25rem 0.6rem;
  border-radius: 20px;
  text-transform: uppercase;
}

.badge.fixed { background: rgba(102, 126, 234, 0.15); color: var(--accent-blue); border: 1px solid rgba(102, 126, 234, 0.3); }
.badge.dynamic { background: rgba(0, 242, 254, 0.15); color: var(--accent-cyan); border: 1px solid rgba(0, 242, 254, 0.3); }

.detail-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
  text-align: left;
}

.detail-table th {
  color: var(--text-muted);
  font-weight: 500;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  padding: 0.6rem 0.4rem;
}

.detail-table td {
  padding: 0.8rem 0.4rem;
  border-bottom: 1px solid rgba(255,255,255,0.03);
}

.detail-table tr.total-row td {
  font-weight: 700;
  font-size: 0.95rem;
  border-bottom: none;
  border-top: 1px dashed rgba(255,255,255,0.15);
  color: var(--text-main);
  padding-top: 1rem;
}

.detail-table span.num-val {
  font-family: var(--font-display);
  font-weight: 600;
}

/* Pulse / Status effects */
.pulse-light {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent-green);
  box-shadow: 0 0 8px var(--accent-green);
  display: inline-block;
  animation: pulse 2s infinite;
}

@keyframes spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

@keyframes pulse {
  0% { transform: scale(0.95); box-shadow: 0 0 0 0 rgba(56, 239, 125, 0.7); }
  70% { transform: scale(1); box-shadow: 0 0 0 6px rgba(56, 239, 125, 0); }
  100% { transform: scale(0.95); box-shadow: 0 0 0 0 rgba(56, 239, 125, 0); }
}

/* HA Sensor select dropdowns */
.ha-select {
  width: 100%;
  background: rgba(0, 0, 0, 0.35);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  padding: 0.5rem 0.7rem;
  color: var(--text-main);
  font-family: var(--font-body);
  font-size: 0.8rem;
  outline: none;
  cursor: pointer;
  transition: var(--transition-smooth);
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.7rem center;
  padding-right: 2rem;
}
.ha-select:focus {
  border-color: var(--accent-cyan);
  box-shadow: 0 0 8px rgba(0, 242, 254, 0.2);
}
.ha-select option {
  background: #0d1426;
  color: var(--text-main);
}

.download-link {
  color: var(--accent-cyan);
  text-decoration: none;
  font-size: 0.8rem;
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  transition: var(--transition-smooth);
}

.download-link:hover {
  color: #ffffff;
  text-shadow: var(--glow-cyan);
}

/* ============================================================================
   Sidebar UX: stap-clustering, inklapbare kaarten, onafhankelijke scroll
   ============================================================================ */

/* Groep van kaarten die samen één stap vormen (bijv. beide import-methodes = stap 1) */
.config-group {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 0.9rem;
  border: 1px dashed rgba(255, 255, 255, 0.10);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.015);
}
.config-group-label {
  font-family: var(--font-display);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--accent-cyan);
  display: flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.1rem 0.2rem 0.2rem;
}
.config-group-label::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--accent-cyan);
  box-shadow: var(--glow-cyan);
}
/* Genest in een groep: kaarten iets ingetogener zodat de groep als geheel leest */
.config-group .glass-panel { box-shadow: none; background: rgba(10, 15, 30, 0.55); }

/* Inklapbare kaarten (alleen in de config-sidebar) */
.sidebar .section-title {
  cursor: pointer;
  user-select: none;
}
.sidebar .section-title:hover { color: #ffffff; }
.collapse-chevron {
  margin-left: auto;
  display: inline-flex;
  color: var(--text-muted);
  transition: transform 0.25s ease;
  flex-shrink: 0;
}
.glass-panel.collapsed .collapse-chevron { transform: rotate(-90deg); }
/* Verberg alles behalve de titelbalk wanneer ingeklapt.
   !important overrulet inline display-stijlen die JS zet (bijv. de HA-sensorpicker
   die op display:block staat na verbinden) — anders blijft die zichtbaar bij inklappen. */
.glass-panel.collapsed > *:not(.section-title) { display: none !important; }
.glass-panel.collapsed .section-title {
  margin-bottom: 0;
  border-bottom: none;
  padding-bottom: 0;
}

/* Negatieve besparing (dynamisch duurder dan vast) → niet groen maar waarschuwend */
.stat-card.savings.negative::before { background: var(--accent-orange); }
.stat-card.savings.negative { box-shadow: 0 4px 20px rgba(255, 117, 140, 0.06); }

/* Onafhankelijk scrollende kolommen op desktop: links (config) en rechts (resultaten)
   bewegen los van elkaar; de header blijft staan. Op smal scherm: normaal paginascroll. */
@media (min-width: 1101px) {
  .app-container {
    height: 100vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
  }
  header { flex-shrink: 0; margin-bottom: 1.5rem; }
  .dashboard-grid {
    flex: 1 1 auto;
    min-height: 0;
    grid-template-rows: minmax(0, 1fr);
  }
  .sidebar,
  .main-dashboard {
    overflow-y: auto;
    min-height: 0;
    max-height: 100%;
    padding-right: 0.5rem;
    padding-bottom: 1.5rem;
  }
}

/* Progressive Disclosure View Toggle */
.view-toggle-container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.65rem 0.9rem;
  background: rgba(10, 15, 30, 0.55);
  border: 1px solid var(--border-color);
  border-radius: 12px;
  margin-bottom: 0.2rem;
}

.view-toggle-container span {
  font-family: var(--font-display);
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--text-main);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.view-toggle-buttons {
  display: flex;
  background: rgba(0, 0, 0, 0.3);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  padding: 2px;
}

.btn-toggle {
  background: transparent;
  border: none;
  color: var(--text-muted);
  font-family: var(--font-body);
  font-size: 0.74rem;
  font-weight: 600;
  padding: 0.35rem 0.7rem;
  border-radius: 6px;
  cursor: pointer;
  transition: var(--transition-smooth);
}

.btn-toggle:hover {
  color: var(--text-main);
}

.btn-toggle.active {
  background: linear-gradient(135deg, var(--accent-cyan), var(--accent-blue));
  color: #060913;
  font-weight: 700;
}

/* Simple view override logic */
body.mode-simple .advanced-only {
  display: none !important;
}

body.mode-simple #intro-explainer,
body.mode-simple #scope-note,
body.mode-simple #data-quality-banner,
body.mode-simple #prognosis-badge,
body.mode-simple .info-box,
body.mode-simple .warning-note,
body.mode-simple #show-setup-btn,
body.mode-simple #dynprice-explainer {
  display: none !important;
}

/* Table sub-row details styling */
.detail-table tr.sub-row td {
  padding-left: 1.5rem !important;
  font-size: 0.8rem;
  color: var(--text-muted);
}
.toggle-chevron {
  display: inline-block;
  margin-left: 0.35rem;
  font-size: 0.65rem;
  color: var(--accent-cyan);
  transition: transform 0.2s ease;
}

/* ============================================================================
   Mobile Responsive Adjustments (Screens <= 600px)
   ============================================================================ */
@media (max-width: 600px) {
  /* 1. App Container & Header Paddings */
  .app-container {
    padding: 1rem 0.6rem;
  }
  
  header {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.8rem;
    margin-bottom: 1.5rem;
  }

  .logo-section h1 {
    font-size: 1.6rem !important;
  }
  
  .logo-section p {
    font-size: 0.85rem;
  }

  /* Reduce glass panel and container padding to save space */
  .glass-panel,
  .table-panel,
  .chart-card,
  .ha-card,
  .upload-card {
    padding: 1rem !important;
  }

  /* 2. Compact Stats Row (2 columns instead of vertical stack or wide horizontal row) */
  .stats-row {
    grid-template-columns: 1fr 1fr;
    gap: 0.6rem;
  }

  .stat-card {
    padding: 0.8rem !important;
  }

  .stat-value {
    font-size: 1.4rem !important;
  }
  
  .stat-value span.curr {
    font-size: 0.95rem;
  }
  
  .stat-value span.sub {
    font-size: 0.75rem;
    margin-left: 0.15rem;
  }

  /* 3. Larger Slider Touch Targets for Range Inputs */
  input[type="range"] {
    height: 8px;
  }

  input[type="range"]::-webkit-slider-thumb {
    width: 20px !important;
    height: 20px !important;
    box-shadow: 0 0 10px rgba(0, 242, 254, 0.5) !important;
  }

  /* 4. Prevent iOS Safari Auto-Zoom on form fields (must be at least 16px) */
  input[type="text"],
  input[type="password"],
  input[type="number"],
  input[type="email"],
  input:not([type="range"]):not([type="checkbox"]):not([type="radio"]),
  select,
  .ha-select,
  .ha-inputs input {
    font-size: 16px !important;
  }

  /* 5. Chart Height Reduction */
  .svg-chart-container {
    height: 260px !important;
  }

  /* 6. Detailed Table Padding - prevents wrapping of currency values/names */
  .detail-table th,
  .detail-table td {
    padding: 0.6rem 0.25rem !important;
  }

  .detail-table tr.sub-row td {
    padding-left: 0.75rem !important;
  }
}

/* Very Small Mobile Screen Adjustments (Screens <= 400px) */
@media (max-width: 400px) {
  /* Stack the stats-row vertically as 2 columns becomes too narrow */
  .stats-row {
    grid-template-columns: 1fr;
  }
}

