@import url('https://fonts.googleapis.com/css2?family=Kaushan+Script&family=Kaushan Script:wght@300;400;600;700;800&display=swap');

:root{
  --lagoon:#1fb7b0;
  --leaf:#2e7d5b;
  --flower:#e66a9a;
  --wood:#8b5a2b;

  --text:#2b2b2b;
  --muted:#5f5f5f;

  --card:rgba(255,255,255,.92);
  --stroke:rgba(0,0,0,.08);
  --shadow:0 18px 45px rgba(0,0,0,.16);
}

*{box-sizing:border-box}

html,body{
  margin:0;
  padding:0;
  font-family: var(--font-normal);
  color:var(--text);
}

/* Fond global : image 10.png */
body{
  min-height:100vh;
  background:
    linear-gradient(rgba(255,255,255,.86), rgba(255,255,255,.86)),
    url("10.png") center / cover no-repeat fixed;
}

/* motifs floraux discrets */
body::before{
  content:"";
  position:fixed;
  inset:-60px;
  pointer-events:none;
  opacity:.12;
  background:
    radial-gradient(circle at 16% 18%, rgba(230,106,154,.55) 0 7px, transparent 8px),
    radial-gradient(circle at 19% 21%, rgba(212,176,106,.50) 0 5px, transparent 6px),
    radial-gradient(circle at 13% 22%, rgba(31,183,176,.45) 0 4px, transparent 5px),

    radial-gradient(circle at 84% 16%, rgba(230,106,154,.50) 0 7px, transparent 8px),
    radial-gradient(circle at 87% 19%, rgba(212,176,106,.48) 0 5px, transparent 6px),
    radial-gradient(circle at 81% 20%, rgba(31,183,176,.40) 0 4px, transparent 5px),

    radial-gradient(circle at 24% 82%, rgba(230,106,154,.42) 0 6px, transparent 7px),
    radial-gradient(circle at 27% 85%, rgba(212,176,106,.40) 0 4px, transparent 5px),
    radial-gradient(circle at 22% 86%, rgba(31,183,176,.36) 0 3px, transparent 4px),

    radial-gradient(circle at 76% 80%, rgba(230,106,154,.40) 0 6px, transparent 7px),
    radial-gradient(circle at 79% 83%, rgba(212,176,106,.38) 0 4px, transparent 5px),
    radial-gradient(circle at 74% 84%, rgba(31,183,176,.34) 0 3px, transparent 4px);
}

.wrap{max-width:1100px;margin:0 auto;padding:0 18px}

/* ===== HEADER (1 ligne) ===== */
.nav{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:20px;
  padding:14px 18px;
  background:rgba(255,255,255,.86);
  backdrop-filter: blur(6px);
  border-bottom:1px solid var(--stroke);
}

.nav-left{display:flex;flex-direction:column}
.brand-title{
  font-family:"Kaushan Script", cursive;
  font-size:26px;
  line-height:1;
}
.brand-sub{
  font-size:14px;
  color:var(--flower);
  font-style:italic;
}

.nav-center{
  display:flex;
  justify-content:center;
  gap:24px;
}
.nav-center a{
  font-weight:600;
  color:var(--text);
  opacity:.85;
}
.nav-center a:hover{opacity:1;text-decoration:underline}

.nav-right{display:flex;justify-content:flex-end}

/* ===== HERO ===== */
.hero{
  min-height:92vh;
  display:flex;
  flex-direction:column;
}

.hero-content{
  max-width:1100px;
  width:100%;
  margin:0 auto;
  padding:42px 18px 22px;
}

.hero h1{
  font-family:"Kaushan Script", cursive;
  font-size:clamp(36px,4.5vw,56px);
  line-height:1.05;
  margin:0 0 10px;
}
.hero p{
  font-size:16px;
  line-height:1.7;
  color:var(--muted);
  margin:0 0 14px;
}

.bullets{
  list-style:none;
  padding:0;
  margin:18px 0;
  display:grid;
  gap:10px;
}
.bullets li{
  background:var(--card);
  border-radius:16px;
  padding:12px 14px;
  box-shadow:var(--shadow);
  border:1px solid var(--stroke);
}

.btn{
  padding:10px 16px;
  border-radius:18px;
  border:1px solid var(--stroke);
  background:var(--card);
  cursor:pointer;
  transition:.15s;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow)}
.btn.primary{
  background:linear-gradient(135deg,var(--lagoon),var(--leaf));
  color:#fff;
  font-weight:700;
  border:none;
}
.btn.ghost{background:var(--card)}
.cta-row{display:flex;gap:10px;flex-wrap:wrap}

.section{padding:46px 0}
.section h2{
  font-family:"Kaushan Script", cursive;
  font-size:36px;
  margin:0 0 18px;
  color:var(--wood);
}

.cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
.card{
  position:relative;
  background:var(--card);
  border-radius:20px;
  padding:18px;
  box-shadow:var(--shadow);
  border:1px solid var(--stroke);
  overflow:hidden;
}
.card::after{
  content:"";
  position:absolute;
  inset:-30px;
  opacity:.10;
  pointer-events:none;
  background:
    radial-gradient(circle at 85% 20%, rgba(230,106,154,.55) 0 8px, transparent 9px),
    radial-gradient(circle at 88% 23%, rgba(212,176,106,.55) 0 5px, transparent 6px),
    radial-gradient(circle at 82% 25%, rgba(31,183,176,.40) 0 4px, transparent 5px);
}
.price{font-size:30px;color:var(--flower);font-weight:800}

.note{
  margin-top:16px;
  background:var(--card);
  border-radius:16px;
  padding:14px;
  color:var(--muted);
  border:1px solid var(--stroke);
}

/* Booking */
.booking-grid{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:14px;
}
.panel{
  background:var(--card);
  border-radius:20px;
  padding:16px;
  box-shadow:var(--shadow);
  border:1px solid var(--stroke);
}
.small{margin:0;color:var(--muted);font-size:13px}
.tiny{margin:10px 0 0;color:var(--muted);font-size:12px}

.duration{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:10px;
}
.duration label{
  background:rgba(246,232,207,.75);
  padding:4px 8px;
  border-radius:10px;
  cursor:pointer;
  border:1px solid rgba(0,0,0,.06);
  font-size:13px;
  line-height:1.2;
}

.form{margin-top:10px; display:grid; gap:10px}
.form-row{display:grid; gap:6px}

input,textarea{
  width:100%;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--stroke);
  background:#fff;
  font-family: var(--font-normal);
}
.form-msg{color:var(--leaf);font-weight:700}

#calendar{
  background:var(--card);
  border-radius:18px;
  padding:10px;
  box-shadow:var(--shadow);
  border:1px solid var(--stroke);
}

.contact{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
.contact-card{
  background:var(--card);
  border-radius:20px;
  padding:16px;
  box-shadow:var(--shadow);
  border:1px solid var(--stroke);
}

.footer{
  background:rgba(255,255,255,.90);
  border-top:1px solid var(--stroke);
  padding:16px 0;
}
.footer-inner{
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
}
.legal{font-size:12px;color:var(--muted)}
.center{text-align:center}

/* Responsive header */
@media (max-width: 780px){
  .nav{
    grid-template-columns:1fr;
    text-align:center;
    gap:10px;
  }
  .nav-left{align-items:center}
  .nav-center{justify-content:center}
  .nav-right{justify-content:center}
}

@media(max-width:980px){
  .cards{grid-template-columns:1fr;}
  .booking-grid{grid-template-columns:1fr;}
  .contact{grid-template-columns:1fr;}
}

/* ===== CALENDRIER FULLCALENDAR PLUS LISIBLE ===== */
#calendar{
  background: rgba(255,255,255,.95);
  border-radius: 18px;
  padding: 10px;
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 18px 45px rgba(0,0,0,.12);
}

/* Police polynésienne sur le header du calendrier */
#calendar .fc .fc-toolbar-title{
  font-family: var(--font-normal);
  font-size: 26px;
  color: var(--wood);
}

#calendar .fc .fc-button{
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,.12);
  background: rgba(255,255,255,.9);
  color: var(--text);
  font-family: var(--font-normal);
  font-weight: 700;
}
#calendar .fc .fc-button:hover{
  box-shadow: 0 10px 25px rgba(0,0,0,.10);
}
#calendar .fc .fc-button-primary:not(:disabled).fc-button-active{
  background: rgba(31,183,176,.18);
  color: var(--text);
}

/* Grille plus claire */
#calendar .fc .fc-timegrid-slot{
  border-color: rgba(0,0,0,.06);
}
#calendar .fc .fc-timegrid-axis,
#calendar .fc .fc-col-header-cell{
  background: rgba(255,255,255,.85);
}

/* ===== COULEURS PASTEL PAR TYPE ===== */
/* Dispo = vert pâle */
#calendar .fc .evt-available.fc-event{
  background: rgba(46, 125, 91, .18);
  border: 1px solid rgba(46, 125, 91, .25);
  color: #1b3b2c;
  border-radius: 12px;
  font-weight: 700;
}

/* Indispo = orange pâle */
#calendar .fc .evt-unavailable.fc-bg-event{
  background: rgba(255, 165, 0, .18);
  opacity: 1;
}

/* Fermé/Férié = bleu marine pâle */
#calendar .fc .evt-closed.fc-bg-event{
  background: rgba(10, 35, 66, .18);
  opacity: 1;
}

/* En attente = gris */
#calendar .fc .evt-pending.fc-bg-event{
  background: rgba(120, 120, 120, .22);
  opacity: 1;
}
#calendar .evt-pending { pointer-events: none; }

/* Texte events */
#calendar .fc-event-title,
#calendar .fc-event-time{
  font-family: var(--font-normal);
  font-size: 10px;
}

/* Header jours sur 2 lignes */
.fc .fc-col-header-cell-cushion {
  white-space: normal !important;
  display: block;
  padding: 6px 2px;
}

.fc-dayhdr {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  line-height: 1.05;
  gap: 2px;
}

.fc-dayhdr-weekday {
  font-weight: 700;
}

.fc-dayhdr-day {
  font-weight: 700;
  opacity: 0.95;
}

/* ===== AJOUT : AUJOURD’HUI (header) ===== */

/* 1) HEADER: seulement la case d'en-tête du jour */
#calendar .fc-col-header-cell.fc-day-today{
  background-color: #2f5779;
  color:#f7edda;
}

/* 2) GRILLE: annuler la couleur "today" par défaut (sinon toute la colonne est teintée) */
#calendar .fc-daygrid-day.fc-day-today,
#calendar .fc-timegrid-col.fc-day-today{
  background: transparent !important;
}

/* 3) (selon versions) annuler aussi le fond appliqué à l’intérieur de la cellule */
#calendar .fc-daygrid-day.fc-day-today .fc-daygrid-day-frame{
  background: transparent !important;
}

/* ===== Couleurs des créneaux (dispo / indispo / fermeture) ===== */

/* 1) Disponibilités : vert clair */
#calendar .fc-bg-event.evt-available,
#calendar .fc-event.evt-available {
  background-color: #b7e4c7 !important;
  border-color: #b7e4c7 !important;
}

/* 2) Indisponibilités : orange foncé */
#calendar .fc-bg-event.evt-unavailable,
#calendar .fc-event.evt-unavailable {
  background-color: #d97706 !important;
  border-color: #d97706 !important;
}

/* 3) Fermetures : bleu nuit */
#calendar .fc-bg-event.evt-closed,
#calendar .fc-event.evt-closed {
  background-color: #0b132b !important;
  border-color: #0b132b !important;
}

/* 4) Pending : gris */
#calendar .fc-bg-event.evt-pending,
#calendar .fc-event.evt-pending {
  background-color: #9ca3af !important;
  border-color: #9ca3af !important;
}

/* Optionnel : rendu "fond" plus doux si ce sont des background events */
#calendar .fc-bg-event {
  opacity: 0.35;
}

/* Optionnel : rendre les dispos plus visibles (si tu veux) */
#calendar .fc-bg-event.evt-available {
  opacity: 0.45;
}
