/**
* Digital Hospitality — Dashboard Admin (v10.0.7.32)
* Palette Hello Rodolfo · OPZIONE A (backdrop primary #00584F) · New Atlas.
*
* Selettori INVARIATI (il JS real-time li genera): cambiamo solo i VALORI.
* Allineata alla skin DS Opzione A: backdrop verde brand, card verdi profonde,
* azioni verde brillante con testo scuro.
*/

.dh-dashboard-wrap {
/* ---- Token locali (Opzione A) ---- */
--dh-dash-bg:            #00584F;  /* backdrop pagina = primary pieno */
--dh-dash-card:          #0C2620;  /* card / KPI (staccano sul backdrop) */
--dh-dash-elev:          #123A31;  /* chip, badge tavolo, hover */
--dh-dash-inset:         #081C17;  /* note, blocchi incassati */
--dh-dash-border:        #1C5247;
--dh-dash-border-strong: #2A7062;

--dh-dash-text:          #EEF3EE;
--dh-dash-text-2:        #BFD0C5;
--dh-dash-text-muted:    #8AA093;

--dh-dash-brand:         #29B354;  /* azioni (verde brillante) */
--dh-dash-brand-hover:   #229247;
--dh-dash-on-brand:      #07140F;  /* testo scuro sui bottoni verdi */
--dh-dash-success:       #29B354;  /* conferma / preso in carico */
--dh-dash-success-hover: #229247;
--dh-dash-warning:       #E0B36A;  /* gestione in corso */
--dh-dash-error:         #E0584F;  /* urgenza / rifiuta */

--dh-dash-font: 'New Atlas', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;

background: var(--dh-dash-bg);
color: var(--dh-dash-text);
min-height: calc(100vh - 120px);
padding: 24px;
font-family: var(--dh-dash-font);
margin-left: -20px;
margin-right: -20px;
}

/* ============================================================
  HEADER
  ============================================================ */
.dh-dashboard-header {
display: flex;
justify-content: space-between;
align-items: center;
border-bottom: 1px solid rgba(255, 255, 255, 0.18);
padding-bottom: 20px;
margin-bottom: 24px;
}
.dh-badge-premium {
display: inline-block;
background: #29B354;
color: #07140F;
font-size: 10px;
font-weight: 700;
padding: 4px 10px;
border-radius: 6px;
letter-spacing: 1px;
}
.dh-dashboard-header h1 {
/* titolo direttamente sul backdrop verde → bianco pieno */
color: #FFFFFF;
font-size: 24px;
font-weight: 900;
margin: 8px 0 2px 0;
letter-spacing: -0.01em;
}
.dh-locale-sub {
color: #CFE6DF;
font-size: 14px;
margin: 0;
}
.dh-locale-sub #dh-live-clock {
color: #FFFFFF;
font-variant-numeric: tabular-nums;
}
.dh-header-right {
display: flex;
gap: 12px;
align-items: center;
}

/* ============================================================
  PULSANTI (header)
  ============================================================ */
.dh-btn-primary {
background: var(--dh-dash-brand);
color: var(--dh-dash-on-brand) !important;
text-decoration: none;
padding: 10px 20px;
border-radius: 8px;
font-weight: 700;
font-family: var(--dh-dash-font);
transition: background 0.18s ease-out;
display: inline-flex;
align-items: center;
gap: 6px;
}
.dh-btn-primary:hover {
background: var(--dh-dash-brand-hover);
color: var(--dh-dash-on-brand) !important;
}
.dh-btn-secondary {
background: rgba(255, 255, 255, 0.10);
color: #FFFFFF;
border: 1px solid rgba(255, 255, 255, 0.30);
padding: 10px 20px;
border-radius: 8px;
cursor: pointer;
font-weight: 600;
font-family: var(--dh-dash-font);
transition: background 0.18s ease-out, border-color 0.18s ease-out;
}
.dh-btn-secondary:hover {
background: rgba(255, 255, 255, 0.18);
border-color: #FFFFFF;
}
.dh-sound-disabled {
opacity: 0.55;
}

/* ============================================================
  GRIGLIA KPI
  ============================================================ */
.dh-kpi-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
gap: 20px;
margin-bottom: 24px;
}
.dh-kpi-card {
background: var(--dh-dash-card);
border: 1px solid var(--dh-dash-border);
border-left: 4px solid var(--dh-dash-border-strong);
border-radius: 12px;
padding: 20px;
display: flex;
align-items: center;
gap: 16px;
transition: border-color 0.18s ease-out, transform 0.18s ease-out;
}
.dh-kpi-card:hover {
transform: translateY(-1px);
}
.dh-kpi-card.kpi-urgent  { border-left-color: var(--dh-dash-error); }
.dh-kpi-card.kpi-pending { border-left-color: var(--dh-dash-warning); }
.dh-kpi-card.kpi-success { border-left-color: var(--dh-dash-success); }
.dh-kpi-card.kpi-stats   { border-left-color: #4FC9B8; }

.kpi-icon {
font-size: 30px;
line-height: 1;
}
.kpi-info {
display: flex;
flex-direction: column;
}
.kpi-value {
display: block;
font-size: 28px;
font-weight: 800;
color: var(--dh-dash-text);
line-height: 1.1;
font-variant-numeric: tabular-nums;
}
.kpi-label {
font-size: 12px;
color: var(--dh-dash-text-muted);
font-weight: 600;
letter-spacing: 0.5px;
text-transform: uppercase;
margin-top: 2px;
}

/* ============================================================
  CONTENUTO PRINCIPALE
  ============================================================ */
.dh-dashboard-content {
display: grid;
grid-template-columns: 2fr 1fr;
gap: 24px;
}
@media (max-width: 1024px) {
.dh-dashboard-content { grid-template-columns: 1fr; }
}
.dh-section-title {
display: flex;
align-items: center;
gap: 12px;
margin-bottom: 16px;
}
.dh-section-title h2 {
/* titoli sezione sul backdrop verde → bianco */
color: #FFFFFF;
font-size: 16px;
font-weight: 700;
margin: 0;
letter-spacing: 0.3px;
}
.dh-pulse-indicator {
width: 8px;
height: 8px;
background: var(--dh-dash-error);
border-radius: 50%;
box-shadow: 0 0 0 0 rgba(224, 88, 79, 0.7);
animation: dh-pulse 1.6s infinite;
}
@keyframes dh-pulse {
0%   { transform: scale(0.95); box-shadow: 0 0 0 0 rgba(224, 88, 79, 0.7); }
70%  { transform: scale(1);    box-shadow: 0 0 0 6px rgba(224, 88, 79, 0); }
100% { transform: scale(0.95); box-shadow: 0 0 0 0 rgba(224, 88, 79, 0); }
}

/* ============================================================
  CARD FEED
  ============================================================ */
.dh-cards-feed {
display: flex;
flex-direction: column;
gap: 16px;
}
.dh-card {
background: var(--dh-dash-card);
border: 1px solid var(--dh-dash-border);
border-left: 4px solid var(--dh-dash-border-strong);
border-radius: 10px;
padding: 16px;
transition: transform 0.3s, opacity 0.3s, border-color 0.18s;
}
.dh-card:hover {
border-color: var(--dh-dash-border-strong);
}
.ticket-card.status-nuovo    { border-left-color: var(--dh-dash-error); }
.ticket-card.status-in_corso { border-left-color: var(--dh-dash-warning); }
.booking-card                { border-left-color: var(--dh-dash-brand); }

.dh-card-header {
display: flex;
justify-content: space-between;
align-items: center;
gap: 12px;
margin-bottom: 12px;
}
.dh-card-title {
font-weight: 700;
color: var(--dh-dash-text);
font-size: 16px;
}
.dh-card-table,
.dh-card-pax {
background: var(--dh-dash-elev);
color: var(--dh-dash-text-2);
padding: 4px 12px;
border-radius: 20px;
font-size: 12px;
font-weight: 600;
white-space: nowrap;
}
.dh-card-details p {
margin: 4px 0;
font-size: 13px;
color: var(--dh-dash-text-2);
line-height: 1.5;
}
.dh-booking-notes {
font-style: italic;
background: var(--dh-dash-inset);
padding: 8px 12px;
border-radius: 6px;
border-left: 2px solid var(--dh-dash-brand);
color: var(--dh-dash-text-2) !important;
}
.dh-booking-meta {
font-size: 11px;
color: var(--dh-dash-text-muted) !important;
}

/* ============================================================
  AZIONI CARD
  ============================================================ */
.dh-card-actions {
display: flex;
gap: 8px;
margin-top: 12px;
}
.dh-action-btn {
flex: 1;
border: none;
padding: 9px 16px;
border-radius: 6px;
font-weight: 700;
font-family: var(--dh-dash-font);
cursor: pointer;
font-size: 13px;
transition: background 0.18s ease-out, color 0.18s ease-out;
}
.btn-accept {
background: var(--dh-dash-success);
color: var(--dh-dash-on-brand);
}
.btn-accept:hover { background: var(--dh-dash-success-hover); }

.btn-reject,
.btn-archive {
background: var(--dh-dash-elev);
color: var(--dh-dash-text-2);
}
.btn-reject:hover {
background: var(--dh-dash-error);
color: #fff;
}
.btn-archive:hover {
background: var(--dh-dash-border);
color: var(--dh-dash-text);
}
.dh-action-btn:disabled {
opacity: 0.45;
cursor: not-allowed;
}

/* ============================================================
  EMPTY STATE
  ============================================================ */
.dh-empty-state {
text-align: center;
padding: 40px;
background: var(--dh-dash-card);
border: 1px dashed var(--dh-dash-border);
border-radius: 10px;
color: var(--dh-dash-text-muted);
font-size: 14px;
}