/* inline.css — Styles personnalisés Cocoon® (CSS variables, classes utilitaires propres au site).
   Extrait des index*.php pour mutualisation entre les 3 langues. */

:root {
      --c-text: #3A4148;
      --c-cream: #F4F1EE;
      --c-primary: #6B2E6B;
      --c-secondary: #4BA8D4;
      --c-tertiary: #2E6C87;
      --c-soft: #B862B8;
    }
    html { scroll-behavior: smooth; }
    body {
      font-family: 'Inter', system-ui, -apple-system, sans-serif;
      color: var(--c-text);
      -webkit-font-smoothing: antialiased;
    }
    .font-script { font-family: 'Pinyon Script', cursive; }
    .font-editorial { font-family: 'Cormorant Garamond', Georgia, serif; }
    .bg-cream { background-color: var(--c-cream); }
    .bg-dark { background-color: var(--c-text); }
    .bg-primary { background-color: var(--c-primary); }
    .text-primary { color: var(--c-primary); }
    .text-tertiary { color: var(--c-tertiary); }
    .border-primary { border-color: var(--c-primary); }
    a, button { transition: all 0.25s ease; }
    .btn-primary { background: var(--c-primary); color: #fff; }
    .btn-primary:hover { background: #5A2659; transform: translateY(-1px); box-shadow: 0 10px 25px -5px rgba(107, 46, 107, 0.35); }
    .btn-outline { border: 2px solid var(--c-primary); color: var(--c-primary); }
    .btn-outline:hover { background: var(--c-primary); color: #fff; }
    .link-primary { color: var(--c-primary); }
    .link-primary:hover { color: var(--c-soft); }
    .hero-decoration {
      background:
        radial-gradient(circle at 70% 30%, rgba(107, 46, 107, 0.08) 0%, transparent 50%),
        radial-gradient(circle at 20% 80%, rgba(75, 168, 212, 0.08) 0%, transparent 50%);
    }
    .section-title em { font-style: italic; color: var(--c-primary); }
    .cta-gradient { background: linear-gradient(135deg, #2E6C87 0%, #6B2E6B 100%); }

    /* ─── Tarifs : grille avec image Paris à droite en desktop ─── */
    .tarifs-grid {
      display: grid;
      grid-template-columns: 1fr;
      gap: 2.5rem;
      align-items: start;
    }
    @media (min-width: 768px) {
      .tarifs-grid {
        grid-template-columns: minmax(0, 1.4fr) minmax(260px, 1fr);
        gap: 3rem;
      }
    }
    @media (min-width: 1024px) {
      .tarifs-grid { gap: 3.5rem; }
    }

    /* Logo intégré : nautilus + "Cocoon" en SVG unifié */
    .logo-cocoon { display: inline-block; vertical-align: middle; height: 48px; }
    .logo-cocoon-lg { height: 72px; }
    .logo-cocoon-sm { height: 36px; }

    /* ─── Formulaire moderne : floating labels, bordures souples ─── */
    .field {
      position: relative;
    }
    .field-input {
      width: 100%;
      padding: 1.5rem 1rem 0.6rem 1rem;
      background: #FAFAF8;
      border: 1px solid #E5E2DD;
      border-radius: 14px;
      color: var(--c-text);
      font-size: 0.975rem;
      outline: none;
      transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
      appearance: none;
    }
    .field-input:hover { background: #F6F3EF; }
    .field-input:focus {
      border-color: var(--c-primary);
      background: #ffffff;
      box-shadow: 0 0 0 4px rgba(107,46,107,0.10);
    }
    .field-input::placeholder { color: transparent; }
    .field-label {
      position: absolute;
      left: 1rem;
      top: 1.1rem;
      color: #98928A;
      font-size: 0.975rem;
      pointer-events: none;
      transition: all 0.2s ease;
      background: transparent;
    }
    .field-input:focus + .field-label,
    .field-input:not(:placeholder-shown) + .field-label {
      top: 0.45rem;
      font-size: 0.72rem;
      font-weight: 600;
      color: var(--c-primary);
      letter-spacing: 0.02em;
      text-transform: uppercase;
    }
    textarea.field-input { min-height: 140px; resize: vertical; }

    /* ─── Carrousel des lieux ─── */
    .carousel { position: relative; overflow: hidden; }
    .carousel-track {
      display: flex;
      transition: transform 0.5s ease;
      will-change: transform;
    }
    .carousel-slide {
      flex: 0 0 100%;
      min-width: 0;
    }
    .carousel-slide figure {
      background: #fff;
      padding: 0.75rem;
      box-shadow: 0 4px 18px -4px rgba(0,0,0,0.08);
    }
    .carousel-slide img {
      width: 100%;
      height: 380px;
      object-fit: cover;
      display: block;
    }
    .carousel-slide figcaption {
      font-family: 'Cormorant Garamond', serif;
      font-style: italic;
      text-align: center;
      color: #6B7280;
      font-size: 0.95rem;
      padding: 0.6rem 0 0.2rem;
    }
    .carousel-btn {
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      width: 44px; height: 44px;
      border-radius: 9999px;
      background: rgba(255,255,255,0.95);
      color: var(--c-primary);
      box-shadow: 0 4px 12px rgba(0,0,0,0.15);
      display: flex; align-items: center; justify-content: center;
      cursor: pointer;
      border: none;
      transition: all 0.2s ease;
      z-index: 2;
    }
    .carousel-btn:hover { background: var(--c-primary); color: #fff; transform: translateY(-50%) scale(1.05); }
    .carousel-btn.prev { left: -0.5rem; }
    .carousel-btn.next { right: -0.5rem; }
    .carousel-dots {
      display: flex;
      justify-content: center;
      gap: 0.5rem;
      margin-top: 1rem;
    }
    .carousel-dot {
      width: 8px; height: 8px;
      border-radius: 9999px;
      background: #D9D3CC;
      border: none;
      cursor: pointer;
      transition: all 0.25s ease;
    }
    .carousel-dot.active { background: var(--c-primary); width: 24px; }
    .carousel-playpause {
      display: inline-flex;
      align-items: center;
      gap: 0.4rem;
      margin-top: 0.75rem;
      padding: 0.4rem 0.9rem;
      border-radius: 999px;
      border: 1px solid #E5E2DD;
      background: #ffffff;
      color: var(--c-tertiary);
      font-size: 0.78rem;
      font-weight: 600;
      letter-spacing: 0.04em;
      cursor: pointer;
      transition: all 0.2s ease;
    }
    .carousel-playpause:hover { border-color: var(--c-primary); color: var(--c-primary); }
    .carousel-playpause svg { width: 12px; height: 12px; fill: currentColor; }

    /* ─── Tableaux cliquables (lien vers site d'exposition) ─── */
    .painting-link {
      display: block;
      position: relative;
      overflow: hidden;
    }
    .painting-link img { transition: transform 0.4s ease; }
    .painting-link:hover img { transform: scale(1.03); }
    .painting-link::after {
      content: "Voir l'œuvre ↗";
      position: absolute;
      bottom: 10px; right: 10px;
      background: rgba(255,255,255,0.95);
      color: var(--c-primary);
      font-family: 'Inter', sans-serif;
      font-size: 0.72rem;
      font-weight: 600;
      letter-spacing: 0.04em;
      padding: 0.35rem 0.7rem;
      border-radius: 999px;
      opacity: 0;
      transform: translateY(6px);
      transition: all 0.25s ease;
      box-shadow: 0 4px 12px rgba(0,0,0,0.12);
    }
    .painting-link:hover::after { opacity: 1; transform: translateY(0); }

    select.field-input {
      background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 20 20' fill='%236B2E6B'><path d='M5 7l5 6 5-6z'/></svg>");
      background-repeat: no-repeat;
      background-position: right 1rem center;
      padding-right: 2.5rem;
    }
    /* Pour les select, le label reste toujours en position haute */
    select.field-input ~ .field-label,
    select.field-input:focus ~ .field-label {
      top: 0.45rem;
      font-size: 0.72rem;
      font-weight: 600;
      color: var(--c-primary);
      letter-spacing: 0.02em;
      text-transform: uppercase;
    }
