@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,600;1,300&family=Montserrat:wght@200;300;400&display=swap');
:root{--text-dark:#2c2c2c;--nude:#fdfaf8;--accent:#d4a373;--soft-grey:#f2f2f2;--transition:all .6s cubic-bezier(.16,1,.3,1);--shadow:0 18px 45px rgba(0,0,0,.08);}*{box-sizing:border-box;margin:0;padding:0;}html{scroll-behavior:smooth;}body{font-family:'Montserrat',sans-serif;background:var(--nude);color:var(--text-dark);line-height:1.75;overflow-x:hidden;padding-top:88px;}img{max-width:100%;display:block;}p{font-weight:200;color:#555;}h1,h2,h3{font-family:'Cormorant Garamond',serif;font-weight:300;text-transform:uppercase;letter-spacing:3px;}header{position:fixed;top:0;left:0;right:0;background:rgba(255,255,255,.98);border-bottom:1px solid rgba(0,0,0,.05);z-index:1000;padding:14px 6%;display:flex;flex-direction:column;align-items:center;gap:10px;transition:var(--transition);backdrop-filter:saturate(180%) blur(10px);} .logo{height:58px;transition:var(--transition);} nav{width:100%;} nav ul{list-style:none;display:flex;gap:18px;justify-content:flex-start;overflow-x:auto;padding:6px 2px 2px;-webkit-overflow-scrolling:touch;scrollbar-width:none;} nav ul::-webkit-scrollbar{display:none;} nav a{text-decoration:none;font-size:.67rem;letter-spacing:2.5px;text-transform:uppercase;opacity:.88;padding-bottom:6px;position:relative;white-space:nowrap;transition:var(--transition);} nav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--accent);transition:var(--transition);} nav a:hover::after{width:100%;} nav a.active{color:var(--accent);opacity:1;} nav a.active::after{width:100%;} header.header--compact{padding:10px 6%;gap:6px;} header.header--compact .logo{height:46px;} header.header--compact nav{max-height:0;opacity:0;overflow:hidden;transition:var(--transition);} header nav{max-height:120px;opacity:1;} section{padding:84px 8%;} .container{max-width:1200px;margin:0 auto;} .kicker{letter-spacing:5px;color:var(--accent);font-size:.75rem;text-transform:uppercase;} .lead{max-width:760px;margin:18px auto 0;} .hero{min-height:72vh;margin-top:-88px;padding-top:88px;background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;position:relative;} .hero::before{content:"";position:absolute;inset:0;background:linear-gradient(rgba(0,0,0,.18),rgba(0,0,0,.28));} .hero>*{position:relative;z-index:1;} .hero-content{max-width:980px;padding:0 18px;} .hero-content h1{font-size:2.7rem;font-style:italic;letter-spacing:4px;margin-bottom:16px;} .hero-content p{color:rgba(255,255,255,.93);font-size:.85rem;letter-spacing:4px;text-transform:uppercase;} .hero--short{min-height:52vh;} .cta-group{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;} .cta{position:relative;display:inline-block;padding:13px 30px;font-size:.68rem;letter-spacing:3px;text-transform:uppercase;text-decoration:none;font-weight:400;transition:var(--transition);overflow:hidden;} .cta-primary{background:var(--accent);color:#fff;} .cta-secondary{background:transparent;border:1px solid var(--accent);color:var(--text-dark);} .cta-light{background:transparent;border:1px solid #fff;color:#fff;} .cta::after{content:"";position:absolute;top:0;left:-120%;width:120%;height:100%;background:rgba(255,255,255,.25);transform:skewX(-20deg);transition:.8s ease;} .cta:hover::after{left:120%;} .cta-primary:hover{background:#c29264;} .cta-secondary:hover{background:var(--accent);color:#fff;} .cta-light:hover{background:#fff;color:var(--text-dark);} .cta-text{font-size:.68rem;letter-spacing:4px;text-transform:uppercase;text-decoration:none;color:var(--text-dark);position:relative;padding-bottom:6px;} .cta-text::after{content:"";position:absolute;bottom:0;left:0;width:30%;height:1px;background:var(--accent);transition:var(--transition);} .cta-text:hover::after{width:100%;} .grid-container{display:grid;grid-template-columns:1fr;gap:16px;margin-top:34px;} .gallery-item{position:relative;overflow:hidden;height:380px;background:var(--soft-grey);} .gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s ease;} .gallery-item:hover img{transform:scale(1.06);} .overlay{position:absolute;left:0;right:0;bottom:0;padding:26px;background:linear-gradient(transparent,rgba(0,0,0,.45));color:#fff;opacity:0;transition:var(--transition);} .gallery-item:hover .overlay{opacity:1;} .card{background:#fff;border:1px solid rgba(0,0,0,.05);padding:46px 8%;box-shadow:var(--shadow);} .pricing{display:grid;grid-template-columns:1fr;gap:16px;margin-top:34px;} .price-card{background:#fff;border:1px solid rgba(0,0,0,.06);padding:36px 28px;box-shadow:var(--shadow);} .price{font-family:'Cormorant Garamond',serif;font-size:2rem;letter-spacing:2px;margin:12px 0 14px;} .price-card ul{list-style:none;margin-top:16px;} .price-card li{padding:10px 0;border-top:1px solid rgba(0,0,0,.05);font-weight:200;color:#555;} footer{padding:64px 8%;text-align:center;background:#fff;border-top:1px solid rgba(0,0,0,.05);} footer img{height:46px;margin:0 auto 16px;} .skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden;} .skip-link:focus{left:16px;top:16px;width:auto;height:auto;padding:10px 14px;background:#fff;border:1px solid rgba(0,0,0,.1);z-index:2000;}
@media (min-width:900px){body{padding-top:120px;}header{flex-direction:row;justify-content:space-between;align-items:center;padding:24px 5%;gap:0;} .logo{height:70px;} nav{width:auto;} nav ul{overflow:visible;justify-content:center;padding:0;gap:28px;} header.header--compact{padding:14px 5%;} header.header--compact nav{max-height:120px;opacity:1;overflow:visible;} section{padding:110px 8%;} .hero{min-height:100vh;margin-top:-120px;padding-top:120px;} .hero-content h1{font-size:4rem;} .hero--short{min-height:60vh;} .grid-container{grid-template-columns:repeat(12,1fr);gap:20px;margin-top:50px;} .gallery-item{grid-column:span 4;height:520px;} .item-large{grid-column:span 8;} .item-tall{grid-row:span 2;height:1060px;} .pricing{grid-template-columns:repeat(3,1fr);gap:20px;}}

/* Encadré tableau packs */
.pack-wrapper{
  margin-top: 40px;
  padding: 28px 24px;
  border: 1px solid #e6e2dc;
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 20px 45px rgba(0,0,0,0.06);
}

.pack-head{
  text-align: left;
  margin-bottom: 18px;
}

.pack-table{
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: 12px;
  outline: none;
}

.pack-table table{
  width: 100%;
  min-width: 760px;
  border-collapse: collapse;
  font-size: 0.95rem;
}

.pack-table th,
.pack-table td{
  padding: 12px 12px;
  border-bottom: 1px solid #eee8e1;
  vertical-align: top;
}

.pack-table thead th{
  background: #fbf8f4;
  font-weight: 700;
  position: sticky;
  top: 0;
  z-index: 1;
}

.pack-table tbody th{
  text-align: left;
  font-weight: 600;
  width: 34%;
}

.pack-table td{
  text-align: center;
  white-space: nowrap;
}

.pack-table tbody tr:hover{
  background: #fcfaf7;
}

.pack-total th,
.pack-total td{
  border-top: 2px solid #e6e2dc;
  background: #fbf8f4;
  font-weight: 800;
}

.pack-note{
  margin-top: 14px;
  font-size: 0.85rem;
  color: #777;
}

/* Mobile : garder le bloc lisible */
@media (max-width: 640px){
  .pack-wrapper{ padding: 22px 16px; }
  .pack-head h3{ font-size: 1.6rem; }
}
/* Encadré infos tarifs — doux & léger */
.pack-info{
  max-width: 980px;
  margin: 34px auto 26px;      /* espace avant l'encadré "pack" */
  padding: 18px 20px;
  background: rgba(255, 255, 255, 0.75);
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 16px;
  box-shadow: 0 10px 26px rgba(0,0,0,0.06);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.pack-info__title{
  margin: 0 0 8px;
  font-weight: 600;
  letter-spacing: 0.2px;
  color: var(--text-dark, #222);
}

.pack-info__list{
  margin: 0;
  padding-left: 18px;
  color: rgba(0,0,0,0.75);
}

.pack-info__list li{
  margin: 6px 0;
  line-height: 1.45;
}

/* Responsive : un peu plus compact sur mobile */
@media (max-width: 640px){
  .pack-info{
    margin: 26px 16px 18px;
    padding: 16px 16px;
    border-radius: 14px;
  }
}
.pack-info {
  text-align: center;
}

.pack-info__list {
  list-style-position: inside;
  padding-left: 0;
}

.price-card--text p {
  font-size: 0.95rem;
  line-height: 1.6;
  opacity: 0.9;
}

.price-card--text h3 {
  margin-bottom: 12px;
}


