/* Site-specific overrides for HVO.WebSite.v9. Extend the shared theme; never redefine --shell-* at :root. */

/* ─── Power card unique design tokens ───────────────────────────────────────
   These are genuinely v9-specific — no equivalent exists in the shared theme.
   If the palette changes, update these tokens. ──────────────────────────── */
:root {
    /* The power status card has a distinctive teal gradient layer */
    --power-card-teal: rgba(15, 76, 92, 0.75);
    /* Cyan-tinted card borders throughout the power section */
    --power-cyan-border: color-mix(in srgb, var(--shell-card-border) 55%, var(--hvo-accent-cyan) 45%);
    --power-cyan-border-soft: color-mix(in srgb, var(--shell-overlay-panel-border) 60%, var(--hvo-accent-cyan) 40%);
}

/* ─── Power Status Card ──────────────────────────────────────────────────── */
.power-status-card {
    background: linear-gradient(135deg, var(--shell-card-background), var(--power-card-teal));
    border: 1px solid var(--power-cyan-border);
    border-radius: 1.5rem;
    box-shadow: var(--shell-card-shadow);
    color: var(--shell-card-foreground);
    padding: clamp(1.25rem, 3vw, 2rem);
}

.power-status-card--locked {
    text-align: center;
}

.power-status-card__header,
.power-status-card__footer {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: space-between;
}

/* Eyebrow: extend hvo-eyebrow with a cyan accent and wider tracking */
.power-status-card__eyebrow {
    color: var(--hvo-accent-cyan);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    margin-bottom: 0.25rem;
    text-transform: uppercase;
}

/* State chip: use hvo-chip base; colour modifier applied dynamically via C# */
.power-status-card__grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fit, minmax(11rem, 1fr));
    margin: 1.25rem 0;
}

.power-metric {
    background: var(--shell-overlay-panel);
    border-radius: 1.1rem;
    padding: 1rem;
}

.power-metric span,
.power-metric small,
.power-status-card__footer span {
    color: var(--shell-pill-text);
    display: block;
}

.power-metric strong {
    display: block;
    font-size: clamp(1.6rem, 4vw, 2.4rem);
    line-height: 1.05;
}

.power-status-card__footer {
    border-top: 1px solid var(--shell-card-inner-border);
    padding-top: 1rem;
}

/* ─── Power Bank Grid ────────────────────────────────────────────────────── */
.power-bank-grid {
    display: grid;
    gap: 0.85rem;
    grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
    margin-top: 1.25rem;
}

.power-bank {
    background: var(--shell-overlay-panel);
    border: 1px solid var(--power-cyan-border-soft);
    border-radius: 1rem;
    padding: 0.85rem;
}

.power-bank--warning {
    border-color: color-mix(in srgb, var(--hvo-accent-amber) 62%, transparent);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--hvo-accent-amber) 14%, transparent);
}

.power-bank--stale {
    border-color: color-mix(in srgb, var(--hvo-series-5) 75%, transparent);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--hvo-series-5) 20%, transparent);
}

.power-bank--alarm {
    border-color: color-mix(in srgb, var(--hvo-accent-danger) 70%, transparent);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--hvo-accent-danger) 18%, transparent);
}

.power-bank__header {
    align-items: center;
    display: flex;
    gap: 0.75rem;
    justify-content: space-between;
    margin-bottom: 0.75rem;
}

.power-bank__header h3 {
    font-size: 1rem;
    margin: 0;
}

.power-bank__header span {
    color: color-mix(in srgb, var(--shell-card-foreground) 72%, var(--hvo-accent-success) 28%);
    font-size: 0.78rem;
    font-weight: 700;
}

.power-bank--warning .power-bank__header span {
    color: var(--hvo-accent-amber);
}

.power-bank--stale .power-bank__header span {
    color: var(--hvo-series-5);
}

.power-bank--alarm .power-bank__header span {
    color: var(--hvo-accent-danger);
}

.power-bank dl {
    display: grid;
    gap: 0.55rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin: 0;
}

.power-bank dt {
    color: var(--shell-pill-text);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.power-bank dd {
    color: var(--shell-card-foreground);
    font-weight: 700;
    margin: 0;
}

/* ─── Power Inventory ────────────────────────────────────────────────────── */
.power-inventory {
    background: var(--shell-overlay-panel);
    border: 1px solid var(--power-cyan-border-soft);
    border-radius: 1rem;
    margin-top: 1.25rem;
    padding: 0.85rem;
}

.power-inventory dl {
    display: grid;
    gap: 0.65rem;
    margin: 0;
}

.power-inventory dt {
    color: var(--shell-pill-text);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.power-inventory dd,
.power-inventory p {
    color: var(--shell-card-foreground);
    margin: 0;
}

.power-inventory p {
    color: var(--shell-pill-text);
    margin-top: 0.65rem;
}

.power-inventory a {
    color: var(--shell-overlay-link);
    font-weight: 700;
}

/* ─── PV String Grid ─────────────────────────────────────────────────────── */
.power-solarassistant-detail dl,
.power-gateway-status dl {
    grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
}

.power-pv-string-grid {
    display: grid;
    gap: 0.65rem;
    grid-template-columns: repeat(auto-fit, minmax(8rem, 1fr));
    margin-top: 0.75rem;
}

.power-pv-string-grid article {
    background: var(--shell-overlay-panel);
    border: 1px solid var(--power-cyan-border-soft);
    border-radius: 0.85rem;
    padding: 0.65rem;
}

.power-pv-string-grid strong,
.power-pv-string-grid span {
    display: block;
}

.power-pv-string-grid span {
    color: var(--shell-pill-text);
    font-size: 0.88rem;
}

/* ─── Unauthenticated card ───────────────────────────────────────────────── */
.power-unauthenticated-card {
    max-width: 42rem;
    text-align: center;
}
