/* =============================================================================
   GI Vouchers — Styles
   ============================================================================= */

/* ─── Tabs liste bons ────────────────────────────────────────────────────────── */
.gi-vouchers-tabs {
  display: flex;
  gap: 4px;
  background: var(--gi-white);
  padding: 4px;
  margin: var(--gi-space-3);
  border-radius: var(--gi-radius-full);
  border: 1px solid var(--gi-grey-200);
  box-shadow: 0 2px 12px rgba(34, 36, 42, 0.06);
  position: sticky;
  top: var(--gi-topbar-height);
  z-index: 10;
}

.gi-vouchers-tab {
  flex: 1;
  padding: var(--gi-space-2) var(--gi-space-3);
  background: transparent;
  border: 0;
  border-radius: var(--gi-radius-full);
  font-family: var(--gi-font);
  font-size: var(--gi-font-size-sm);
  font-weight: 600;
  color: var(--gi-grey-500);
  cursor: pointer;
  transition: var(--gi-transition-fast);
}

.gi-vouchers-tab.is-active {
  background: var(--gi-dark);
  color: var(--gi-cyan);
  box-shadow: 0 4px 12px rgba(34, 36, 42, 0.18);
}

/* ─── Voucher card (client) ──────────────────────────────────────────────────── */
.gi-voucher-card {
  display: flex;
  align-items: center;
  gap: var(--gi-space-3);
  padding: var(--gi-space-4);
  border-bottom: 1px solid var(--gi-grey-200);
  cursor: pointer;
  transition: var(--gi-transition-fast);
  background: var(--gi-white);
}

.gi-voucher-card:hover {
  background: var(--gi-grey-100);
}

.gi-voucher-card--used {
  opacity: 0.65;
}

.gi-voucher-card__left {
  flex-shrink: 0;
}

.gi-voucher-card__icon {
  width: 52px;
  height: 52px;
  border-radius: var(--gi-radius-md);
  background: var(--gi-grey-100);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.8rem;
  overflow: hidden;
}

.gi-voucher-card__body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.gi-voucher-card__name {
  font-size: var(--gi-font-size-md);
  font-weight: 700;
  color: var(--gi-dark);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.gi-voucher-card__partner {
  font-size: var(--gi-font-size-sm);
  color: var(--gi-grey-500);
}

.gi-voucher-card__adv {
  font-size: var(--gi-font-size-xs);
  color: var(--gi-grey-500);
  font-style: italic;
}

.gi-voucher-card__meta {
  display: flex;
  align-items: center;
  gap: var(--gi-space-2);
  flex-wrap: wrap;
  margin-top: 2px;
}

.gi-voucher-card__check {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(46,204,113,.12);
  color: #2ecc71;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  font-weight: 700;
  flex-shrink: 0;
}

/* Mini QR preview dans la liste */
.gi-voucher-qr-preview {
  width: 48px;
  height: 48px;
  flex-shrink: 0;
}

.gi-voucher-qr-preview canvas,
.gi-voucher-qr-preview img {
  width: 48px !important;
  height: 48px !important;
  border-radius: 4px;
}

/* ─── Modal bon (client) ─────────────────────────────────────────────────────── */
.gi-voucher-modal {
  max-height: 92vh;
  max-height: 92dvh;
}

.gi-voucher-modal-header {
  text-align: center;
  margin-bottom: var(--gi-space-5);
}

.gi-voucher-modal-icon {
  font-size: 3.5rem;
  margin-bottom: var(--gi-space-2);
}

.gi-voucher-modal-title {
  font-size: var(--gi-font-size-2xl);
  font-weight: 700;
  color: var(--gi-dark);
  margin: 0 0 var(--gi-space-1);
}

.gi-voucher-modal-partner {
  font-size: var(--gi-font-size-sm);
  color: var(--gi-grey-500);
  margin: 0;
}

/* QR code dans la modal */
.gi-voucher-qr-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: var(--gi-space-5);
}

.gi-voucher-qr-dark {
  background: var(--gi-dark);
  padding: var(--gi-space-4);
  border-radius: var(--gi-radius-xl);
  box-shadow: var(--gi-shadow-lg);
  display: inline-block;
}

.gi-qr-canvas {
  display: block;
  border-radius: var(--gi-radius-sm);
}

.gi-voucher-code {
  margin-top: var(--gi-space-4);
  font-family: 'Courier New', monospace;
  font-size: var(--gi-font-size-2xl);
  font-weight: 700;
  color: var(--gi-dark);
  letter-spacing: .12em;
  background: var(--gi-grey-100);
  padding: var(--gi-space-2) var(--gi-space-5);
  border-radius: var(--gi-radius-full);
}

.gi-voucher-instruction {
  text-align: center;
  font-size: var(--gi-font-size-sm);
  color: var(--gi-grey-500);
  line-height: 1.6;
  margin-bottom: var(--gi-space-5);
}

.gi-voucher-used-state {
  text-align: center;
  padding: var(--gi-space-8) 0;
}

.gi-voucher-used-icon {
  font-size: 3rem;
  margin-bottom: var(--gi-space-3);
}

/* ─── Scanner partenaire ─────────────────────────────────────────────────────── */
.gi-scanner-tabs {
  display: flex;
  gap: var(--gi-space-2);
  padding-top: var(--gi-space-4);
  padding-bottom: var(--gi-space-3);
  border-bottom: 1px solid var(--gi-grey-200);
}

.gi-scanner-tab {
  flex: 1;
  padding: var(--gi-space-2) var(--gi-space-3);
  background: var(--gi-grey-100);
  border: 2px solid transparent;
  border-radius: var(--gi-radius-full);
  font-family: var(--gi-font);
  font-size: var(--gi-font-size-sm);
  font-weight: 700;
  color: var(--gi-grey-500);
  cursor: pointer;
  transition: var(--gi-transition-fast);
  text-align: center;
}

.gi-scanner-tab.is-active {
  background: var(--gi-cyan-10);
  border-color: var(--gi-cyan);
  color: var(--gi-dark);
}

.gi-scanner-panel { display: none; }
.gi-scanner-panel.is-active { display: block; }

/* ─── Caméra ─────────────────────────────────────────────────────────────────── */
.gi-camera-wrap {
  padding-top: var(--gi-space-4);
  padding-bottom: var(--gi-space-4);
}

.gi-camera-container {
  position: relative;
  background: var(--gi-dark);
  border-radius: var(--gi-radius-xl);
  overflow: hidden;
  aspect-ratio: 1;
  max-width: 360px;
  margin: 0 auto;
}

.gi-camera-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.gi-camera-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

.gi-camera-frame {
  width: 200px;
  height: 200px;
  border: 3px solid var(--gi-cyan);
  border-radius: var(--gi-radius-lg);
  box-shadow:
    0 0 0 2000px rgba(34,36,42,.5),
    inset 0 0 0 2px rgba(87,225,255,.3);
  position: relative;
}

/* Coins du cadre */
.gi-camera-frame::before,
.gi-camera-frame::after {
  content: '';
  position: absolute;
  width: 24px;
  height: 24px;
  border-color: var(--gi-cyan);
  border-style: solid;
}

.gi-camera-frame::before {
  top: -3px; left: -3px;
  border-width: 4px 0 0 4px;
  border-radius: var(--gi-radius-sm) 0 0 0;
}

.gi-camera-frame::after {
  bottom: -3px; right: -3px;
  border-width: 0 4px 4px 0;
  border-radius: 0 0 var(--gi-radius-sm) 0;
}

.gi-camera-hint {
  margin-top: 16px;
  font-size: 12px;
  color: rgba(255,255,255,.7);
  text-align: center;
  font-weight: 600;
}

.gi-camera-result {
  position: absolute;
  inset: 0;
  background: rgba(34,36,42,.9);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--gi-space-4);
}

.gi-scanner-checking {
  color: var(--gi-cyan);
  font-size: var(--gi-font-size-lg);
  font-weight: 700;
  text-align: center;
}

.gi-scanner-error {
  color: var(--gi-danger);
  font-size: var(--gi-font-size-md);
  font-weight: 700;
  text-align: center;
}

/* ─── Confirmation modal ─────────────────────────────────────────────────────── */
.gi-confirm-client-info {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--gi-space-3) 0;
  border-bottom: 1px solid var(--gi-grey-200);
}

.gi-confirm-label {
  font-size: var(--gi-font-size-sm);
  color: var(--gi-grey-500);
  font-weight: 600;
}

.gi-confirm-value {
  font-size: var(--gi-font-size-sm);
  font-weight: 700;
  color: var(--gi-dark);
}

.gi-confirm-status {
  font-size: var(--gi-font-size-lg);
  font-weight: 700;
  margin: var(--gi-space-4) 0;
  text-align: center;
}

/* ─── Liste bons partenaire ──────────────────────────────────────────────────── */
.gi-voucher-list-item {
  display: flex;
  align-items: center;
  gap: var(--gi-space-3);
  padding: var(--gi-space-3) 0;
  border-bottom: 1px solid var(--gi-grey-200);
}

.gi-voucher-list-icon {
  font-size: 1.5rem;
  width: 40px;
  text-align: center;
  flex-shrink: 0;
}

.gi-voucher-list-body {
  flex: 1;
  min-width: 0;
}

.gi-voucher-list-name {
  font-size: var(--gi-font-size-md);
  font-weight: 700;
  color: var(--gi-dark);
}

/* ─── Bouton switch espace (Scanner / Mes bons) ──────────────────────────────── */
.gi-switch-space-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  height: 32px;
  padding: 0 var(--gi-space-3);
  border-radius: var(--gi-radius-full);
  background: #ffffff;
  border: 1px solid rgba(87, 225, 255, 0.40);
  color: var(--gi-cyan) !important;
  font-family: inherit;
  font-size: var(--gi-font-size-xs);
  font-weight: 700;
  line-height: 1;
  text-decoration: none !important;
  white-space: nowrap;
  flex-shrink: 0;
  cursor: pointer;
  letter-spacing: 0.02em;
  transition: background 0.18s ease, border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
  box-shadow: 0 1px 4px rgba(87, 225, 255, 0.15);
}
.gi-switch-space-btn:hover,
.gi-switch-space-btn:visited,
.gi-switch-space-btn:focus {
  background: #ffffff;
  border-color: var(--gi-cyan);
  color: var(--gi-cyan) !important;
  text-decoration: none !important;
  transform: translateY(-1px);
  box-shadow: 0 3px 8px rgba(87, 225, 255, 0.25);
}
.gi-switch-space-btn:active {
  transform: scale(0.96);
}
.gi-switch-space-btn svg {
  flex-shrink: 0;
  opacity: 0.9;
}
