/* ============================================================================
 * ART&SUITES — COMPONENT STYLES
 * Lifted from BMG charte v1.0 — buttons, cards, nav, forms, gallery, FAQ
 * Depends on colors_and_type.css (must be loaded first)
 * ============================================================================ */

/* ── RESET (minimal) ──────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }
img, picture, video, canvas, svg { display: block; max-width: 100%; height: auto; }
input, button, textarea, select { font: inherit; color: inherit; }
button { background: none; border: none; cursor: pointer; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }

/* ── LAYOUT ───────────────────────────────────────────────────────────── */
.container { width: 100%; max-width: var(--max-w-content); margin: 0 auto; padding-inline: var(--gutter); }
@media (min-width: 1024px) { .container { padding-inline: var(--gutter-lg); } }
.section { padding-block: var(--section-py); }
.section--tight { padding-block: var(--section-py-tight); }
.section--bg-warm     { background: var(--c-warm-paper); }
.section--bg-mokaccino { background: var(--c-mokaccino); }
.section--bg-dream    { background: var(--c-dream); color: var(--fg-inverse); }
.section--bg-night    { background: var(--c-night-purple); color: var(--fg-inverse); }

.grid { display: grid; gap: var(--space-lg); }
.grid--2 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.grid--3 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
@media (min-width: 1024px) {
  .grid--3 { grid-template-columns: repeat(3, 1fr); }
  .grid--split { grid-template-columns: 2fr 3fr; gap: var(--space-2xl); align-items: center; }
  .grid--split-reverse { grid-template-columns: 3fr 2fr; gap: var(--space-2xl); align-items: center; }
}

.stack > * + * { margin-top: var(--space-md); }
.stack-lg > * + * { margin-top: var(--space-lg); }
.stack-xl > * + * { margin-top: var(--space-xl); }

.flex { display: flex; gap: var(--space-md); }
.flex--center { align-items: center; justify-content: center; }
.flex--between { justify-content: space-between; align-items: center; }
.flex--wrap { flex-wrap: wrap; }

/* ── BUTTONS ──────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-sm);
  padding: 16px 32px;
  font-family: var(--font-body); font-size: var(--fs-button); font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide); line-height: 1;
  border-radius: var(--radius-sm); border: 1.5px solid transparent;
  cursor: pointer; transition: all var(--t-base); white-space: nowrap;
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }
.btn:focus-visible { outline: 2px solid var(--c-dream); outline-offset: 2px; }

.btn--primary { background: var(--c-lipstikoeur); color: var(--c-warm-paper); box-shadow: var(--shadow-cta); }
.btn--primary:hover { background: var(--c-lipstikoeur-dark); }

.btn--secondary { background: transparent; border-color: var(--c-dream); color: var(--c-dream); }
.btn--secondary:hover { background: var(--c-dream); color: var(--c-warm-paper); }

.btn--ghost { background: transparent; border-color: transparent; color: var(--c-night-purple); padding: 12px 16px; }
.btn--ghost:hover { background: var(--c-night-purple-soft); }

.btn--on-dark { border-color: var(--c-warm-paper); color: var(--c-warm-paper); }
.btn--on-dark:hover { background: var(--c-warm-paper); color: var(--c-night-purple); }

.btn--sm { padding: 10px 20px; font-size: var(--fs-body-sm); }
.btn--lg { padding: 20px 40px; font-size: 1.05rem; }
.btn--block { width: 100%; }

/* ── CARDS ────────────────────────────────────────────────────────────── */
.card {
  background: var(--bg-elevated); border: 1px solid var(--border);
  border-radius: var(--radius-md); overflow: hidden;
  transition: transform var(--t-slow), box-shadow var(--t-slow);
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.card__media { aspect-ratio: 4 / 3; overflow: hidden; background: var(--c-mokaccino-soft); }
.card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--t-slower); }
.card:hover .card__media img { transform: scale(1.05); }
.card__body { padding: var(--space-lg); }
.card__title { font-family: var(--font-display); font-size: var(--fs-h3); font-weight: var(--fw-medium); margin-bottom: var(--space-sm); }
.card__meta { color: var(--fg-soft); font-size: var(--fs-body-sm); margin-bottom: var(--space-md); }
.card__price { font-family: var(--font-display); font-weight: var(--fw-semibold); color: var(--c-dream); font-size: var(--fs-h4); }

/* ── BADGES ───────────────────────────────────────────────────────────── */
.badge {
  display: inline-flex; align-items: center; gap: var(--space-xs);
  padding: 6px 12px; background: var(--c-dream); color: var(--c-warm-paper);
  border-radius: var(--radius-full); font-size: var(--fs-caption);
  font-weight: var(--fw-semibold); letter-spacing: var(--ls-wider); text-transform: uppercase;
}
.badge--accent { background: var(--c-lipstikoeur); }
.badge--soft { background: var(--c-mokaccino-soft); color: var(--c-night-purple); }

/* ── FORMS ────────────────────────────────────────────────────────────── */
.field { display: flex; flex-direction: column; gap: 6px; }
.label { font-size: var(--fs-body-sm); font-weight: var(--fw-semibold); color: var(--c-night-purple); }
.input, .textarea, .select {
  background: var(--c-warm-paper); border: 1px solid var(--c-mokaccino); border-radius: var(--radius-sm);
  padding: 12px 16px; font-family: var(--font-body); font-size: var(--fs-body); color: var(--fg);
  transition: border var(--t-base), box-shadow var(--t-base); width: 100%;
}
.input:focus, .textarea:focus, .select:focus {
  outline: none; border-color: var(--c-dream);
  box-shadow: 0 0 0 3px rgba(68, 155, 170, 0.15);
}
.textarea { min-height: 120px; resize: vertical; line-height: var(--lh-relaxed); }
.input::placeholder, .textarea::placeholder { color: var(--fg-muted); opacity: 1; }

/* ── DIVIDER ──────────────────────────────────────────────────────────── */
.divider { border: none; height: 1px; background: var(--border); margin-block: var(--space-2xl); }
.divider--ornament {
  display: flex; align-items: center; justify-content: center;
  margin-block: var(--space-2xl); background: none; height: auto;
}
.divider--ornament::before, .divider--ornament::after {
  content: ''; flex: 1; height: 1px; background: var(--border);
}
.divider--ornament > * { margin-inline: var(--space-lg); }

/* ── FAQ ──────────────────────────────────────────────────────────────── */
.faq { max-width: var(--max-w-text); margin: 0 auto; }
.faq__item { border-bottom: 1px solid var(--border); padding-block: var(--space-md); }
.faq__question {
  cursor: pointer; font-family: var(--font-body); font-size: var(--fs-body-lg);
  font-weight: var(--fw-semibold); color: var(--c-night-purple);
  padding-block: var(--space-sm); list-style: none;
  display: flex; justify-content: space-between; align-items: center; gap: var(--space-md);
}
.faq__question::-webkit-details-marker { display: none; }
.faq__question::after { content: '+'; font-size: 1.5rem; font-weight: var(--fw-light); transition: transform var(--t-base); }
.faq__item[open] .faq__question::after { transform: rotate(45deg); }
.faq__answer { padding-block: var(--space-md); color: var(--fg-soft); line-height: var(--lh-relaxed); }

/* ── SUITE THEMES ─────────────────────────────────────────────────────── */
.suite-sarah { background: var(--c-mokaccino); color: var(--c-night-purple); }
.suite-sarah .btn--primary { background: var(--c-night-purple); color: var(--c-warm-paper); box-shadow: 0 4px 20px rgba(51, 22, 73, 0.2); }
.suite-sarah .btn--primary:hover { background: var(--c-lipstikoeur); }

.suite-frida { background: var(--c-lipstikoeur); color: var(--c-warm-paper); }
.suite-frida h2, .suite-frida h3 { color: var(--c-warm-paper); }
.suite-frida .btn--primary { background: var(--c-warm-paper); color: var(--c-lipstikoeur); box-shadow: 0 4px 20px rgba(0,0,0,0.15); }
.suite-frida .btn--primary:hover { background: var(--c-night-purple); color: var(--c-warm-paper); }
.suite-frida .btn--secondary { border-color: var(--c-warm-paper); color: var(--c-warm-paper); }

.suite-boheme { background: var(--c-warm-paper); color: var(--c-night-purple); }
