/**
 * modals.css
 * Tous les modals : demo-modal, modal-box, form-group, mail-notice, dashboard tabs
 * story-viewer, rating stars
 * Dépend de : variables.css, base.css
 */

  .demo-modal { display: none; position: fixed; inset: 0; background: rgba(42,23,8,0.7); z-index: 200; align-items: center; justify-content: center; backdrop-filter: blur(4px); }
  .demo-modal.open { display: flex; }

  .modal-box { background: var(--white); border-radius: 24px; padding: 48px; max-width: 480px; width: 90%; position: relative; max-height: 90vh; overflow-y: auto; }
  .modal-box-wide { background: var(--white); border-radius: 24px; padding: 40px; max-width: 680px; width: 94%; position: relative; max-height: 90vh; overflow-y: auto; }
  .modal-close { position: absolute; top: 20px; right: 20px; background: var(--cream-dark); border: none; width: 32px; height: 32px; border-radius: 50%; cursor: pointer; font-size: 16px; display: flex; align-items: center; justify-content: center; color: var(--text-mid); }
  .modal-title { font-family: 'Playfair Display', Georgia, serif; font-size: 30px; font-weight: 600; color: var(--text-dark); margin-bottom: 8px; }
  .modal-sub { font-size: 14px; color: var(--text-light); margin-bottom: 28px; }

  .form-group { margin-bottom: 18px; }
  .form-group label { display: block; font-size: 13px; font-weight: 600; color: var(--text-mid); margin-bottom: 6px; }
  .form-group input, .form-group select, .form-group textarea {
    width: 100%; padding: 12px 16px;
    border: 1.5px solid var(--sand); border-radius: 10px;
    font-family: 'Inter', 'DM Sans', sans-serif; font-size: 14px; color: var(--text-dark);
    outline: none; transition: border-color 0.2s; background: var(--cream);
  }
  .form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color: var(--terracotta); }
  .form-group textarea { resize: vertical; min-height: 90px; }
  .form-cgu { font-size: 12px; color: var(--text-light); margin-bottom: 20px; line-height: 1.6; }
  .form-cgu a { color: var(--terracotta); }

  .mail-notice {
    background: linear-gradient(135deg, rgba(196,98,45,0.08), rgba(201,150,60,0.08));
    border: 1.5px solid rgba(196,98,45,0.2);
    border-radius: 12px;
    padding: 14px 16px;
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 20px;
    font-size: 13px;
    color: var(--text-mid);
    line-height: 1.5;
  }
  .mail-notice-icon { font-size: 20px; flex-shrink: 0; margin-top: 1px; }

  /* Dashboard */
  .dashboard-tabs { display: flex; gap: 4px; background: var(--cream-dark); border-radius: 10px; padding: 4px; margin-bottom: 28px; }
  .dash-tab { flex: 1; padding: 8px; border: none; background: transparent; border-radius: 8px; font-family: 'Inter', 'DM Sans', sans-serif; font-size: 13px; font-weight: 500; color: var(--text-light); cursor: pointer; transition: all 0.2s; }
  .dash-tab.active { background: var(--white); color: var(--terracotta); font-weight: 600; box-shadow: 0 2px 8px rgba(42,23,8,0.08); }
  .dash-panel { display: none; }
  .dash-panel.active { display: block; }
  .fav-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
  .fav-card { background: var(--cream); border-radius: 14px; padding: 16px; display: flex; align-items: center; gap: 14px; position: relative; }
  .fav-avatar { width: 48px; height: 48px; border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 24px; flex-shrink: 0; }
  .fav-avatar-1 { background: linear-gradient(135deg, #E8D5B7, #C4622D30); }
  .fav-avatar-2 { background: linear-gradient(135deg, #F0E8DC, #9A4A1F30); }
  .fav-avatar-3 { background: linear-gradient(135deg, #FAF6F0, #C9963C40); }
  .fav-info .fav-name { font-weight: 600; font-size: 14px; color: var(--text-dark); }
  .fav-info .fav-loc { font-size: 12px; color: var(--text-light); margin-top: 2px; }
  .fav-remove { position: absolute; top: 10px; right: 10px; background: none; border: none; font-size: 13px; color: var(--text-light); cursor: pointer; opacity: 0.5; transition: opacity 0.2s; }
  .fav-remove:hover { opacity: 1; color: #c0392b; }
  .dash-order-item { display: flex; align-items: center; justify-content: space-between; padding: 14px 0; border-bottom: 1px solid var(--cream-dark); font-size: 13px; }
  .dash-order-item:last-child { border-bottom: none; }
  .order-status { padding: 3px 10px; border-radius: 50px; font-size: 11px; font-weight: 600; }
  .status-confirmed { background: #e8f5e9; color: #2e7d32; }
  .status-pending   { background: #fff8e1; color: #f57f17; }

