/* ============================================================
   RiBiFlex - Components
   Richiede tokens.css
   ============================================================ */

/* ---------- Layout helpers ---------- */
.rb-stack   { display: flex; flex-direction: column; }
.rb-row     { display: flex; align-items: center; }
.rb-wrap    { flex-wrap: wrap; }
.rb-between { justify-content: space-between; }
.rb-center  { align-items: center; justify-content: center; }
.gap-1 { gap: var(--space-1); } .gap-2 { gap: var(--space-2); }
.gap-3 { gap: var(--space-3); } .gap-4 { gap: var(--space-4); }
.gap-6 { gap: var(--space-6); } .gap-8 { gap: var(--space-8); }

/* ============================================================
   BOTTONI
   ============================================================ */
.btn {
  --btn-h: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  height: var(--btn-h);
  padding: 0 var(--space-5);
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: var(--fw-medium);
  line-height: 1;
  letter-spacing: -0.01em;
  border: 1px solid transparent;
  border-radius: var(--r-md);
  cursor: pointer;
  white-space: nowrap;
  user-select: none;
  transition: background 0.22s var(--ease),
              color 0.22s var(--ease),
              border-color 0.22s var(--ease),
              transform 0.16s var(--ease),
              box-shadow 0.16s var(--ease);
}
.btn:active { transform: translateY(1px) !important; box-shadow: none !important; }
.btn svg { width: 16px; height: 16px; }

/* Primary - mint pieno; hover: verde scuro + testo bianco */
.btn-primary {
  background: var(--accent);
  color: var(--brand-ink);
  border-color: var(--accent);
}
.btn-primary:hover {
  background: var(--accent-strong);
  color: #ffffff;
  border-color: var(--accent-strong);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(28,28,26,0.10);
}
[data-theme="dark"] .btn-primary:hover {
  background: #007A5E;
  color: #ffffff;
  border-color: #007A5E;
}

/* Inverted ghost - su sfondi scuri */
.btn-inv {
  background: transparent;
  color: var(--brand-ground);
  border-color: rgba(247,247,245,0.55);
}
.btn-inv:hover {
  background: var(--brand-ground);
  color: var(--brand-ink);
  border-color: var(--brand-ground);
  transform: translateY(-2px);
}

/* Secondary - superficie con bordo */
.btn-secondary {
  background: var(--surface);
  color: var(--text);
  border-color: var(--border-strong);
}
[data-theme="dark"] .btn-secondary { border-color: rgba(247,247,245,0.25); }
.btn-secondary:hover {
  background: var(--text);
  color: var(--bg);
  border-color: var(--text);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

/* Solid ink */
.btn-ink {
  background: var(--text);
  color: var(--bg);
  border-color: var(--text);
}
.btn-ink:hover {
  background: var(--accent);
  color: var(--brand-ink);
  border-color: var(--accent);
  transform: translateY(-2px);
  box-shadow: 0 4px 14px rgba(28,28,26,0.08);
}

/* Ghost */
.btn-ghost {
  background: transparent;
  color: var(--text);
  border-color: transparent;
}
.btn-ghost:hover {
  background: var(--surface-inset);
  transform: translateY(-1px);
}

/* Outline accent */
.btn-outline {
  background: transparent;
  color: var(--accent-strong);
  border-color: var(--accent-line);
}
.btn-outline:hover {
  background: var(--accent);
  color: var(--brand-ink);
  border-color: var(--accent);
  transform: translateY(-2px);
}

/* Danger */
.btn-danger { background: var(--danger); color: #fff; border-color: var(--danger); }
.btn-danger:hover { filter: brightness(0.88); transform: translateY(-1px); }

/* Dimensioni */
.btn-sm { --btn-h: 32px; padding: 0 var(--space-4); font-size: 13px; }
.btn-lg { --btn-h: 48px; padding: 0 var(--space-6); font-size: 15px; }
.btn-icon { width: var(--btn-h); padding: 0; }

.btn:disabled, .btn[disabled] { opacity: 0.45; cursor: not-allowed; }
.btn-block { display: flex; width: 100%; }

/* ============================================================
   BADGE / TAG / STATI
   ============================================================ */
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 4px 10px;
  font-size: 11px;
  font-weight: var(--fw-medium);
  letter-spacing: 0.03em;
  line-height: 1;
  border-radius: var(--r-pill);
  border: var(--hairline) solid transparent;
  white-space: nowrap;
}
.badge-mint    { background: var(--accent-tint); color: var(--accent-strong); border-color: var(--accent-line); }
.badge-neutral { background: var(--surface-inset); color: var(--text-2); border-color: var(--border); }
.badge-success { background: var(--success-tint); color: var(--success); border-color: var(--success-line); }
.badge-warning { background: var(--warning-tint); color: var(--warning); border-color: var(--warning-line); }
.badge-danger  { background: var(--danger-tint);  color: var(--danger);  border-color: var(--danger-line); }
.badge-info    { background: var(--info-tint);    color: var(--info);    border-color: var(--info-line); }
.badge-solid   { background: var(--text); color: var(--bg); }

/* Tag mono (stile annotativo) */
.tag-mono {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-2);
  padding: 4px 8px;
  border: var(--hairline) solid var(--border);
  border-radius: var(--r-xs);
  background: var(--surface);
}

/* Status dot */
.dot {
  width: 7px; height: 7px; border-radius: var(--r-pill);
  background: var(--text-3); flex: none;
}
.dot-live    { background: var(--accent); box-shadow: 0 0 0 0 rgba(0,200,150,0.5); animation: dot-pulse 2s var(--ease) infinite; }
.dot-charge  { background: var(--data-charge); }
.dot-idle    { background: var(--text-3); }
.dot-warn    { background: var(--warning); }
.dot-danger  { background: var(--danger); }
@keyframes dot-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(0,200,150,0.45); }
  70%  { box-shadow: 0 0 0 6px rgba(0,200,150,0); }
  100% { box-shadow: 0 0 0 0 rgba(0,200,150,0); }
}

.status {
  display: inline-flex; align-items: center; gap: var(--space-2);
  font-size: 12px; font-weight: var(--fw-medium); color: var(--text-2);
}

/* ============================================================
   CARD
   ============================================================ */
.card {
  background: var(--surface);
  border: var(--hairline) solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-6);
  transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.card-pad-lg { padding: var(--space-8); }
.card-flush  { padding: 0; overflow: hidden; }
.card-hover:hover { border-color: var(--border-strong); box-shadow: var(--shadow-md); transform: translateY(-2px); }
/* Card "accent" v2 - niente barra verde sopra: bordo menta sottile + glow soffuso all'hover */
.card-accent { border-color: var(--accent-line); }
.card-accent.card-hover:hover { border-color: var(--accent); box-shadow: var(--shadow-md), var(--glow-mint); }
.card-inset  { background: var(--surface-inset); border-color: transparent; }
.card-ink    { background: var(--invert-bg); color: var(--invert-text); border-color: var(--invert-border); }
.card-ink .text-2 { color: var(--invert-text-2); }

.card-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-4);
  padding-bottom: var(--space-4);
  margin-bottom: var(--space-4);
  border-bottom: var(--hairline) solid var(--border);
}

/* ============================================================
   FORM
   ============================================================ */
.field { display: flex; flex-direction: column; gap: var(--space-2); }
.field-label {
  font-size: 12px; font-weight: var(--fw-medium); color: var(--text-2);
}
.field-hint { font-size: 12px; color: var(--text-3); }
.field-error { font-size: 12px; color: var(--danger); }

.input, .select, .textarea {
  width: 100%;
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--text);
  background: var(--surface);
  border: var(--hairline) solid var(--border-strong);
  border-radius: var(--r-md);
  padding: 0 var(--space-4);
  height: 42px;
  transition: border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease), background var(--dur-fast) var(--ease);
}
.textarea { height: auto; padding: var(--space-3) var(--space-4); line-height: 1.5; resize: vertical; min-height: 96px; }
.input::placeholder, .textarea::placeholder { color: var(--text-3); }
.input:hover, .select:hover, .textarea:hover { border-color: var(--text-3); }
.input:focus, .select:focus, .textarea:focus {
  outline: none; border-color: var(--accent); box-shadow: var(--ring); background: var(--surface);
}
.input-error { border-color: var(--danger) !important; }
.input-error:focus { box-shadow: 0 0 0 3px var(--danger-tint) !important; }

.select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M3 4.5L6 7.5L9 4.5' stroke='%23AEADA8' stroke-width='1.4' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-4) center;
  padding-right: var(--space-10);
}

/* Input group con icona */
.input-group { position: relative; display: flex; align-items: center; }
.input-group .input { padding-left: var(--space-10); }
.input-group .ig-icon {
  position: absolute; left: var(--space-4); display: flex;
  color: var(--text-3); pointer-events: none;
}
.input-group .ig-icon svg { width: 16px; height: 16px; }
.input-group .ig-icon .rb-ic { font-size: 16px; }

/* Checkbox / radio */
.check { display: inline-flex; align-items: flex-start; gap: var(--space-3); cursor: pointer; font-size: 14px; }
.check input { position: absolute; opacity: 0; pointer-events: none; }
.check .box {
  width: 18px; height: 18px; flex: none; margin-top: 1px;
  border: 1.5px solid var(--border-strong); border-radius: var(--r-xs);
  background: var(--surface);
  display: flex; align-items: center; justify-content: center;
  transition: all var(--dur-fast) var(--ease);
}
.check .box.round { border-radius: var(--r-pill); }
.check .box svg { width: 12px; height: 12px; color: var(--text-on-accent); opacity: 0; transform: scale(0.6); transition: all var(--dur-fast) var(--ease); }
.check input:checked + .box { background: var(--accent); border-color: var(--accent); }
.check input:checked + .box svg { opacity: 1; transform: scale(1); }
.check input:checked + .box .radio-dot { opacity: 1; transform: scale(1); }
.check .radio-dot { width: 8px; height: 8px; border-radius: var(--r-pill); background: var(--text-on-accent); opacity: 0; transform: scale(0.5); transition: all var(--dur-fast) var(--ease); }
.check input:focus-visible + .box { box-shadow: var(--ring); }

/* Toggle */
.toggle { position: relative; display: inline-flex; align-items: center; cursor: pointer; }
.toggle input { position: absolute; opacity: 0; pointer-events: none; }
.toggle .track {
  width: 40px; height: 23px; border-radius: var(--r-pill);
  background: var(--surface-sunken); border: var(--hairline) solid var(--border-strong);
  transition: all var(--dur) var(--ease); position: relative;
}
.toggle .thumb {
  position: absolute; top: 2px; left: 2px; width: 17px; height: 17px;
  border-radius: var(--r-pill); background: var(--surface);
  box-shadow: var(--shadow-sm); transition: all var(--dur) var(--ease);
}
.toggle input:checked + .track { background: var(--accent); border-color: var(--accent); }
.toggle input:checked + .track .thumb { left: 20px; }
.toggle input:focus-visible + .track { box-shadow: var(--ring); }

/* ============================================================
   TABS
   ============================================================ */
.tabs { display: flex; gap: var(--space-1); border-bottom: var(--hairline) solid var(--border); }
.tab {
  position: relative;
  padding: var(--space-3) var(--space-4);
  font-size: 14px; font-weight: var(--fw-medium); color: var(--text-2);
  cursor: pointer; background: none; border: none; font-family: var(--font-sans);
  transition: color var(--dur-fast) var(--ease);
}
.tab:hover { color: var(--text); }
.tab.active { color: var(--text); }
.tab.active::after {
  content: ""; position: absolute; left: var(--space-4); right: var(--space-4); bottom: -1px;
  height: 2px; background: var(--accent); border-radius: 2px;
}

/* Segmented */
.segment {
  display: inline-flex; padding: 3px; gap: 2px;
  background: var(--surface-inset); border-radius: var(--r-md);
  border: var(--hairline) solid var(--border);
}
.segment button {
  padding: 6px 14px; font-size: 13px; font-weight: var(--fw-medium);
  color: var(--text-2); background: none; border: none; border-radius: var(--r-sm);
  cursor: pointer; font-family: var(--font-sans); transition: all var(--dur-fast) var(--ease);
}
.segment button.active { background: var(--surface); color: var(--text); box-shadow: var(--shadow-xs); }

/* ============================================================
   ALERT
   ============================================================ */
.alert {
  display: flex; gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border-radius: var(--r-md);
  border: var(--hairline) solid var(--border);
  background: var(--surface);
  font-size: 14px;
}
.alert .alert-icon { flex: none; font-size: 19px; margin-top: 1px; }
.alert .alert-body { display: flex; flex-direction: column; gap: 2px; }
.alert .alert-title { font-weight: var(--fw-medium); }
.alert .alert-text { font-size: 13px; color: var(--text-2); }
.alert-success { background: var(--success-tint); border-color: var(--success-line); }
.alert-success .alert-icon { color: var(--success); }
.alert-warning { background: var(--warning-tint); border-color: var(--warning-line); }
.alert-warning .alert-icon { color: var(--warning); }
.alert-danger  { background: var(--danger-tint);  border-color: var(--danger-line); }
.alert-danger .alert-icon { color: var(--danger); }
.alert-info    { background: var(--info-tint);    border-color: var(--info-line); }
.alert-info .alert-icon { color: var(--info); }

/* ============================================================
   TABELLA
   ============================================================ */
.table-wrap { border: var(--hairline) solid var(--border); border-radius: var(--r-lg); overflow: hidden; background: var(--surface); }
.table { width: 100%; border-collapse: collapse; font-size: 14px; }
.table thead th {
  text-align: left; padding: var(--space-3) var(--space-5);
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--text-3); font-weight: var(--fw-regular);
  background: var(--surface-2); border-bottom: var(--hairline) solid var(--border);
}
.table tbody td { padding: var(--space-4) var(--space-5); border-bottom: var(--hairline) solid var(--border); color: var(--text); }
.table tbody tr:last-child td { border-bottom: none; }
.table tbody tr { transition: background var(--dur-fast) var(--ease); }
.table tbody tr:hover { background: var(--surface-2); }
.table .num { font-family: var(--font-mono); font-size: 13px; text-align: right; }

/* ============================================================
   NAVBAR
   ============================================================ */
.nav {
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-6);
  padding: var(--space-4) var(--space-8);
  background: color-mix(in srgb, var(--bg) 86%, transparent);
  backdrop-filter: saturate(140%) blur(12px);
  border-bottom: var(--hairline) solid var(--border);
}
.nav-brand { display: flex; align-items: center; gap: var(--space-3); }
.nav-links { display: flex; align-items: center; gap: var(--space-2); }
.nav-link {
  padding: var(--space-2) var(--space-3); font-size: 14px; font-weight: var(--fw-medium);
  color: var(--text-2); border-radius: var(--r-sm); transition: all var(--dur-fast) var(--ease);
}
.nav-link:hover { color: var(--text); background: var(--surface-inset); }
.nav-link.active { color: var(--text); }
.nav-link.active { position: relative; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer {
  background: var(--invert-bg); color: var(--invert-text);
  padding: var(--space-16) var(--space-8) var(--space-8);
}
.footer a { color: rgba(247,247,245,0.7); }
.footer a:hover { color: var(--accent-hi); }

/* ============================================================
   ICONE - Phosphor Icons (web font). rb-ic = wrapper di dimensione.
   ============================================================ */
.rb-ic { font-size: 22px; line-height: 1; display: inline-block; vertical-align: middle; }
.rb-ic.sm { font-size: 17px; }
.rb-ic.lg { font-size: 30px; }
.btn .rb-ic { font-size: 17px; }
.icon-box {
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px; border-radius: var(--r-md);
  background: var(--accent-tint); color: var(--accent-strong); font-size: 22px;
}

/* ============================================================
   COMPONENTI DATI / V2G
   ============================================================ */

/* KPI / metric card */
.kpi { display: flex; flex-direction: column; gap: var(--space-2); }
.kpi-value {
  font-size: 40px; font-weight: var(--fw-bold); letter-spacing: -0.025em; line-height: 1;
  font-variant-numeric: tabular-nums;
}
.kpi-value .unit { font-size: 18px; font-weight: var(--fw-medium); color: var(--text-2); margin-left: 4px; letter-spacing: 0; }
.kpi-label { font-size: 12px; color: var(--text-2); }
.kpi-delta { display: inline-flex; align-items: center; gap: 4px; font-size: 12px; font-weight: var(--fw-medium); }
.kpi-delta.up { color: var(--success); }
.kpi-delta.down { color: var(--danger); }

/* Charge ring (conic) */
.charge-ring {
  --val: 72;
  width: 120px; height: 120px; border-radius: var(--r-pill);
  background: conic-gradient(var(--accent) calc(var(--val) * 1%), var(--data-track) 0);
  display: flex; align-items: center; justify-content: center;
  position: relative;
}
.charge-ring::before {
  content: ""; position: absolute; inset: 11px; border-radius: var(--r-pill); background: var(--surface);
}
.charge-ring .ring-inner { position: relative; text-align: center; }
.charge-ring .ring-val { font-size: 24px; font-weight: var(--fw-bold); letter-spacing: -0.02em; font-variant-numeric: tabular-nums; }
.charge-ring .ring-cap { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-3); }

/* Power flow - linea con corrente animata (bidirezionale).
   Track sottile basato su currentColor (si adatta a fondo chiaro/scuro);
   pallino sempre mint vivido + glow, visibile in entrambi i temi. */
.flow {
  position: relative; height: 2px; border-radius: 2px;
  background: color-mix(in srgb, currentColor 13%, transparent);
  overflow: visible; margin: var(--space-5) 0;
}
/* Pulse simmetrico: una luce ovale con scia su entrambi i lati e dot brillante al centro.
   Niente flip, niente fade ai bordi: oscilla avanti e indietro in modo perfettamente fluido. */
.flow .pulse {
  position: absolute; top: 50%; left: 0; width: 56px; height: 2px;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(0,200,150,0.55) 35%,
    var(--accent) 50%,
    rgba(0,200,150,0.55) 65%,
    transparent 100%);
  transform: translate(0,-50%);
  animation: flow-current 4.5s ease-in-out infinite alternate;
}
.flow .pulse::after {
  content: ""; position: absolute; left: 50%; top: 50%; width: 6px; height: 6px;
  border-radius: var(--r-pill); background: var(--accent); transform: translate(-50%,-50%);
  box-shadow: 0 0 10px rgba(0,200,150,0.55);
}
.flow.reverse .pulse {
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(233,73,73,0.45) 35%,
    var(--data-discharge) 50%,
    rgba(233,73,73,0.45) 65%,
    transparent 100%);
}
.flow.reverse .pulse::after { background: var(--data-discharge); box-shadow: 0 0 10px var(--data-discharge); opacity: 0.92; }
@keyframes flow-current {
  0%   { left: 0%;   transform: translate(0,-50%); }
  100% { left: 100%; transform: translate(-100%,-50%); }
}
.flow-node {
  display: inline-flex; align-items: center; gap: var(--space-2);
  font-size: 12px; font-weight: var(--fw-medium); color: var(--text-2);
}

/* Mini bar chart (rettangoli, niente SVG) */
.barchart { display: flex; align-items: flex-end; gap: 6px; height: 120px; }
.barchart .bar { flex: 1; background: var(--data-track); border-radius: 3px 3px 0 0; position: relative; transition: background var(--dur) var(--ease); min-height: 4px; }
.barchart .bar.charge { background: var(--data-charge); }
.barchart .bar.discharge { background: var(--data-discharge); }
.barchart .bar.grid { background: var(--data-grid); }

/* Legend */
.legend { display: flex; gap: var(--space-5); flex-wrap: wrap; }
.legend-item { display: inline-flex; align-items: center; gap: var(--space-2); font-size: 12px; color: var(--text-2); }
.legend-swatch { width: 10px; height: 10px; border-radius: 3px; }

/* Placeholder immagine (striato + label mono) */
.img-ph {
  background:
    repeating-linear-gradient(135deg, var(--surface-inset) 0 10px, var(--surface-2) 10px 20px);
  border: var(--hairline) dashed var(--border-strong);
  border-radius: var(--r-lg);
  display: flex; align-items: center; justify-content: center;
  color: var(--text-3); min-height: 160px; position: relative;
}
.img-ph .ph-label {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--text-3); background: var(--surface); padding: 4px 10px; border-radius: var(--r-pill);
  border: var(--hairline) solid var(--border);
}

/* Divider */
.hr { height: var(--hairline); background: var(--border); border: none; width: 100%; }

@media (prefers-reduced-motion: reduce) {
  .flow .pulse, .dot-live { animation: none !important; }
}
