/* static/styles/generic-view.css */
:root{
  --bg:#0b0f14; --fg:#e8eef5; --muted:#a6b3c2;
  --card:#121a22; --line:#213040; --accent:#3ba0ff; --ok:#10b981; --err:#ef4444;
  --radius:12px;
  --font: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, "Helvetica Neue", Arial, "Noto Sans", sans-serif;
}
*{box-sizing:border-box}
html,body{height:100%}
body{ margin:0; font-family:var(--font); background:var(--bg); color:var(--fg); }

.site-header{ padding:16px; border-bottom:1px solid var(--line); background:#0d141c; }
.site-header .brand{display:flex; align-items:center; gap:12px}
.site-header .brand .logo{height:40px}
.site-header h1{margin:0; font-size:20px; font-weight:700}

.page{ display:grid; gap:16px; padding:16px; align-items:start; grid-template-columns: 1fr 1fr; }
/* Mode auto (par défaut) quand aucun verrou n’est posé via data-layout */
@media (max-aspect-ratio: 1/1) { .page:not([data-layout]){ grid-template-columns: 1fr; } }
@media (min-aspect-ratio: 1/1) { .page:not([data-layout]){ grid-template-columns: 1fr 1fr; } }
/* Verrous utilisateur (prioritaires) */
.page[data-layout="row"]{ grid-template-columns: 1fr 1fr; }
.page[data-layout="col"]{ grid-template-columns: 1fr; }

.col{ min-width:0; }
.panel{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:16px; box-shadow: 0 8px 20px rgba(0,0,0,.25); }

#plan .panel-title{ margin:0; font-size:18px }
.panel-head{
  display:flex; align-items:center; gap:12px; margin-bottom:8px;
}
.panel-head .plan-actions{ margin-left:auto; display:flex; gap:6px; }

.panel-head{
  display:flex; align-items:center; gap:12px; margin-bottom:8px;
}
.panel-head .plan-actions{ margin-left:auto; display:flex; gap:6px; }
.plan-wrap{ position:relative; background:#0b131a; border:1px solid var(--line); border-radius:10px; overflow:hidden; }
.plan-object{ width:100%; height:60vh; display:block; background:#0a1118; }
#venuePlan.grabbing{ cursor:grabbing; }
.plan-status{ position:absolute; left:8px; bottom:8px; font-size:12px; color:var(--muted); }

/* Toolbar : désormais dans l’entête du panel, plus dans le plan */
.plan-actions{ display:flex; gap:6px; }
.tool-btn{
  display:inline-flex; align-items:center; justify-content:center;
  width:34px; height:34px; border-radius:8px;
  border:1px solid var(--line); background:#0d141c; color:#cbd5e1; cursor:pointer;
}
.tool-btn:hover{ border-color:#36506b; color:#e2e8f0; background:#0f1720; }
 .tool-btn .icon{ display:block; }
 /* s’assurer que [hidden] l’emporte sur display:block ci-dessus */
 .tool-btn .icon[hidden]{ display:none !important; }

/* Respecter l’attribut [hidden] malgré la règle ci-dessus */
.tool-btn .icon[hidden]{ display:none !important; }

/* Plein écran du container du plan */
.plan-wrap:fullscreen{ border-radius:0; }
.plan-wrap:fullscreen .plan-object{ height:100vh; }


/* ORDER */
#order .block{ margin-bottom:16px; }
#order .block h2{ margin:0 0 8px 0; font-size:18px }

/* LIGNES — master */
.lines-head, .cart-row{
  display:grid; grid-template-columns: 44px 1.2fr 1fr 1fr 1.2fr; gap:8px;
  align-items:center; border-bottom:1px dashed var(--line); padding:8px 4px;
}
.lines-head{ color:var(--muted); font-size:12px; text-transform:uppercase; letter-spacing:.04em; }

.cart-row .trash{
  width:34px; height:34px; border-radius:8px; border:1px solid var(--line);
  background:#0d141c; color:#90a4b8; cursor:pointer; display:flex; align-items:center; justify-content:center;
}
.cart-row .trash:hover{ border-color:#36506b; color:#c7d5e4; background:#0f1720; }
.cart-row input[type="text"], .cart-row select{
  width:100%; padding:8px 10px; background:#0f1720; color:var(--fg);
  border:1px solid var(--line); border-radius:8px; outline:none;
}
.cart-row select{ cursor:pointer; }

/* LIGNES — sous-ligne compacte (une seule ligne, masquée par défaut) */
.line-extra-inline{
  grid-column: 2 / span 4;
  display:flex; align-items:center; gap:10px;
  justify-content: flex-end;     /* ⬅️ aligne toute la sous-ligne à droite */
  padding:8px 4px 12px;
}
.line-extra-inline .extra-info{ text-align:right; }
.line-extra-inline .extra-justif{ display:flex; align-items:center; gap:8px; min-width: 45%; }
.line-extra-inline .extra-label{ color:var(--muted); font-size:12px; }
.line-extra-inline .extra-input{
  flex:1; min-width: 220px; padding:8px 10px; background:#0f1720; color:var(--fg);
  border:1px solid var(--line); border-radius:8px; outline:none;
}
.line-extra-inline .extra-sep{ color:#5f748c; }
.line-extra-inline .extra-info{ color:var(--muted); }

/* Paiement — 2 lignes : headers puis valeurs parfaitement alignées */
.pay-grid{
  display:grid; grid-template-columns: 1fr 1fr 1fr; gap:8px; margin-top:8px;
}
.pay-hdr{ color:var(--muted); font-size:12px; text-transform:uppercase; letter-spacing:.04em; }
.total-box{
  background:#0f1720; border:1px solid var(--line); border-radius:8px; padding:10px 12px; min-height: 42px; display:flex; align-items:center;
}
#paySchedule{
  width:100%; padding:10px 12px; background:#0f1720; color:var(--fg); border:1px solid var(--line); border-radius:8px; outline:none;
}
.actions{ display:flex; justify-content:flex-end; margin-top:12px; }
button.pay-btn{ background:linear-gradient(180deg, #3ba0ff, #2a7bd1); color:white; border:none; border-radius:10px; padding:12px 18px; font-weight:700; cursor:pointer; }
button.pay-btn:disabled{ opacity:.6; cursor:not-allowed; }

.feedback{
  margin-top: .5rem;
  display: flex;
  align-items: flex-start;
  gap: .5rem;
  line-height: 1.3;
}
.feedback.err { color: #b91c1c; }
.feedback.ok  { color: #166534; }
.feedback .fb-icon {
  flex: 0 0 auto;
  display: inline-flex;
  margin-top: 2px;
}
.feedback .fb-text {
  display: inline-block;
}
.feedback .fb-list {
  margin: .25rem 0 0 .75rem;
  padding: 0;
}
.feedback .fb-list li {
  margin: 0;
}


/* Highlights seats (au cas où CSS inline du SVG soit agressif) */
.seat.is-allowed, .token-seat{ outline: 2px solid #fbbf24 !important; outline-offset: 1px; }
.seat.is-selected{ outline: 2px solid #3ba0ff !important; outline-offset: 1px; }

.help{ margin-top:8px; color:var(--muted); font-size:12px }


/* --- Contacts: grille et style des inputs (retour à l'ancien rendu) --- */
.form-grid{
  display:grid; grid-template-columns: 1fr 1fr 1fr; gap:8px;
}
.form-grid .form-group{
  display:flex; flex-direction:column; gap:6px;
}
.form-grid input, .form-grid select{
  width:100%;
  padding:10px 12px;
  background:#0f1720; color:var(--fg);
  border:1px solid var(--line); border-radius:8px; outline:none;
}

/* --- Paiement: sélecteur d'échéancier SOUS le libellé, aligné avec les 2 autres colonnes --- */
.pay-bottom{
  display:grid; grid-template-columns: 1fr 1fr 1fr; gap:8px; margin-top:8px;
}
.pay-bottom .form-group{
  display:flex; flex-direction:column; gap:6px;
}
.pay-bottom select, .pay-bottom input{
  width:100%;
  padding:10px 12px;
  background:#0f1720; color:var(--fg);
  border:1px solid var(--line); border-radius:8px; outline:none;
}


/* Icônes blanches (fond sombre) */
.plan-actions .tool-btn{ color:#fff; }
.plan-actions .tool-btn svg *{
  fill:#fff !important;
  stroke:#fff !important;
}

/* respecter l’attribut [hidden] malgré .tool-btn .icon{display:block} */
.tool-btn .icon[hidden]{ display:none !important; }
