/* ── SHARED CSS ── Hyam & Rayane RSVP (Thème Floral Royal) */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  /* Nouvelle palette de couleurs */
  --bg-cream: #fdfbf7;
  --bg-warm: #f4ebd8;
  --terracotta: #c1774b;
  --terracotta-dark: #b36c46;
  --terracotta-light: #d9956c;
  --terracotta-pale: #f5dfc0;
  --text-dark: #3e2819;
  --text-mid: #8c7361;
  --text-light: #a88c77;
  --border-color: rgba(140, 115, 97, 0.2);
}

html{scroll-behavior:smooth}
body{background:radial-gradient(circle at 50% 0%, var(--bg-cream) 0%, var(--bg-warm) 100%);font-family:'Jost',sans-serif;color:var(--text-dark);overflow-x:hidden}
#floralCanvas{position:fixed;inset:0;pointer-events:none;z-index:0;opacity:0.3}
.corner-fl{position:absolute;pointer-events:none;z-index:1}
.cfl-tl{top:0;left:0;width:220px;height:220px}
.cfl-tr{top:0;right:0;width:200px;height:200px;transform:scaleX(-1)}
.cfl-bl{bottom:0;left:0;width:180px;height:180px;transform:scaleY(-1)}
.cfl-br{bottom:0;right:0;width:190px;height:190px;transform:scale(-1)}
@media(max-width:600px){.cfl-tl,.cfl-tr{width:130px;height:130px}.cfl-bl,.cfl-br{width:110px;height:110px}}

.hero{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:70px 20px 90px;overflow:hidden}
.hero-glow{position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 80% 55% at 50% 10%,rgba(193,119,75,0.15),transparent 65%)}
.hero-content{position:relative;z-index:2;max-width:580px;width:100%}

.hero-eyebrow{display:inline-flex;align-items:center;gap:12px;font-family:'Jost',sans-serif;font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--text-mid);font-weight:500;margin-bottom:24px;animation:fadeUp 1s ease 0.15s both}
.eb-line{width:36px;height:1px;background:var(--text-light);opacity:0.5}

.hero-names{font-family:'Cormorant Garamond',serif;font-size:clamp(50px,12vw,94px);font-weight:400;color:var(--text-dark);line-height:1;letter-spacing:-1px;animation:fadeUp 1.1s ease 0.25s both}
.amp{font-size:0.55em;font-weight:300;font-style:italic;color:var(--terracotta);display:inline-block;margin:0 8px;vertical-align:middle}

.hero-ornament{display:flex;align-items:center;gap:12px;justify-content:center;margin:22px 0;animation:fadeUp 1s ease 0.45s both}
.ho-line{flex:1;max-width:40px;height:1px;background:var(--text-mid);opacity:0.5}
.ho-line.l{background:linear-gradient(to left,transparent,var(--text-mid))}
.ho-center{display:flex;align-items:center;gap:7px}
.ho-diamond{width:5px;height:5px;border:1px solid var(--text-mid);transform:rotate(45deg)}
.ho-dot{width:4px;height:4px;background:var(--text-mid);border-radius:50%}

.hero-date{font-family:'Cormorant Garamond',serif;font-size:clamp(18px,3vw,24px);font-style:italic;font-weight:400;color:var(--text-dark);margin-bottom:20px;animation:fadeUp 1s ease 0.55s both}
.hero-pill{display:inline-flex;align-items:center;background-color:var(--terracotta-dark);color:white;border-radius:40px;font-size:10px;letter-spacing:2.5px;text-transform:uppercase;padding:12px 30px;font-weight:500;animation:fadeUp 1s ease 0.7s both;box-shadow:0 6px 20px rgba(179,108,70,0.25)}

.scroll-cue{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:7px;opacity:0;animation:fadeUp 1s ease 1.1s forwards}
.scroll-cue span{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--text-light)}
.scroll-line{width:1px;height:34px;background:linear-gradient(to bottom,transparent,var(--text-light));animation:pulse 2s ease infinite}
@keyframes pulse{0%,100%{opacity:0.3;transform:scaleY(0.7)}50%{opacity:1;transform:scaleY(1)}}

.section{padding:72px 20px;position:relative;z-index:1}
.section-inner{max-width:660px;margin:0 auto}
.s-lbl{display:inline-flex;align-items:center;font-size:9px;letter-spacing:3.5px;text-transform:uppercase;color:var(--text-dark);font-weight:600;background:rgba(193,119,75,0.08);border:1px solid rgba(193,119,75,0.18);border-radius:100px;padding:5px 14px;margin-bottom:14px}
.s-lbl-wrap{text-align:center;margin-bottom:0}
.s-ttl{font-family:'Cormorant Garamond',serif;font-size:clamp(26px,4vw,38px);font-weight:400;color:var(--text-dark);text-align:center;margin-bottom:44px;line-height:1.3}

.prog-item{display:grid;grid-template-columns:72px 1fr;gap:0 22px;padding:24px 0;border-bottom:1px solid var(--border-color);opacity:0;transform:translateX(-18px);transition:all 0.6s cubic-bezier(0.4,0,0.2,1)}
.prog-item.visible{opacity:1;transform:none}
.prog-item:last-child{border-bottom:none}
.prog-time{font-family:'Cormorant Garamond',serif;font-size:22px;font-style:italic;color:var(--terracotta-dark);text-align:right;border-right:1px solid var(--text-light);padding-right:18px;padding-top:2px}
.prog-icon{font-size:18px;margin-bottom:4px}
.prog-name{font-family:'Cormorant Garamond',serif;font-size:20px;color:var(--text-dark);margin-bottom:3px}
.prog-desc{font-size:13px;color:var(--text-mid);font-weight:300;line-height:1.7}

.access-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:540px){.access-grid{grid-template-columns:1fr}}
.acard{background:var(--bg-cream);border:1px solid var(--border-color);border-radius:14px;padding:30px 24px;position:relative;overflow:hidden;opacity:0;transform:translateY(16px);transition:all 0.65s cubic-bezier(0.4,0,0.2,1)}
.acard.visible{opacity:1;transform:none}
.acard:hover{transform:translateY(-3px);box-shadow:0 10px 36px rgba(62,40,25,0.06)}
.acard::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--terracotta-light)}
.ac-ic{font-size:22px;margin-bottom:12px}
.ac-ttl{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--text-dark);margin-bottom:7px}
.ac-adr{font-size:13px;color:var(--text-mid);line-height:1.7;font-weight:300;border-bottom:1px solid var(--border-color);padding-bottom:12px;margin-bottom:12px}
.ac-inf{font-size:12px;color:var(--text-mid);line-height:2;font-weight:300}
.ac-inf strong{color:var(--text-dark);font-weight:500}
.map-btn{display:inline-flex;align-items:center;gap:5px;margin-top:16px;font-size:10px;letter-spacing:2px;text-transform:uppercase;color:white;background:var(--terracotta-dark);border-radius:100px;padding:8px 16px;text-decoration:none;font-weight:500;transition:all 0.25s}
.map-btn:hover{background:var(--terracotta)}

.form-section{padding:72px 20px 90px;position:relative;z-index:1}
.form-card{max-width:500px;margin:0 auto;background:var(--bg-cream);border:1px solid var(--border-color);border-radius:20px;padding:44px 40px;box-shadow:0 20px 70px rgba(62,40,25,0.05);position:relative}
@media(max-width:480px){.form-card{padding:32px 22px;border-radius:16px}}
.fc-c{position:absolute;width:26px;height:26px;border-color:var(--text-light);border-style:solid;opacity:0.5}
.fc-tl{top:12px;left:12px;border-width:1px 0 0 1px}.fc-tr{top:12px;right:12px;border-width:1px 1px 0 0}
.fc-bl{bottom:12px;left:12px;border-width:0 0 1px 1px}.fc-br{bottom:12px;right:12px;border-width:0 1px 1px 0}
.fc-ttl{font-family:'Cormorant Garamond',serif;font-size:26px;font-style:italic;font-weight:400;color:var(--text-dark);text-align:center;margin-bottom:5px}
.fc-sub{font-size:11px;color:var(--text-mid);text-align:center;letter-spacing:1px;margin-bottom:34px;font-weight:300}
.field{margin-bottom:24px}
label.lbl{display:block;font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--text-mid);margin-bottom:8px;font-weight:500;transition:color 0.3s}
.field:focus-within label.lbl{color:var(--terracotta-dark)}
input[type=text],textarea{width:100%;border:none;border-bottom:1px solid var(--border-color);padding:8px 0 10px;font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:400;color:var(--text-dark);background:transparent;outline:none;transition:border-color 0.3s;border-radius:0;-webkit-appearance:none}
input[type=text]::placeholder,textarea::placeholder{color:var(--text-light);font-style:italic}
input[type=text]:focus,textarea:focus{border-bottom-color:var(--terracotta-dark)}
textarea{resize:none;min-height:56px;font-size:16px;font-style:italic}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:400px){.two-col{grid-template-columns:1fr}}

.counter{display:flex;align-items:center;gap:14px;padding:6px 0 10px;border-bottom:1px solid var(--border-color)}
.cbtn{width:34px;height:34px;min-width:34px;border-radius:50%;border:1px solid var(--text-light);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--text-dark);transition:all 0.22s}
.cbtn:hover{background:var(--terracotta-dark);border-color:var(--terracotta-dark);color:white}
.cval{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:400;color:var(--text-dark);min-width:32px;text-align:center;transition:all 0.2s cubic-bezier(0.4,0,0.2,1)}
.clbl{font-size:14px;font-style:italic;color:var(--text-mid);font-family:'Cormorant Garamond',serif}

.pres-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.popt{position:relative;cursor:pointer}
.popt input{position:absolute;opacity:0;width:0;height:0}
.pbtn{border:1px solid var(--border-color);border-radius:12px;padding:16px 10px;display:flex;flex-direction:column;align-items:center;gap:7px;transition:all 0.3s;cursor:pointer;background:transparent}
.pbtn .pi{font-size:20px;transition:transform 0.3s}
.pbtn .pt{font-family:'Cormorant Garamond',serif;font-size:14px;font-style:italic;color:var(--text-mid);transition:color 0.3s}
.popt input:checked+.pbtn{border-color:var(--terracotta-dark);background:rgba(179,108,70,0.05)}
.popt input:checked+.pbtn .pi{transform:scale(1.2)}
.popt input:checked+.pbtn .pt{color:var(--terracotta-dark)}

.divider{display:flex;align-items:center;gap:12px;margin:26px 0 22px}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--border-color)}
.dv-ic{font-size:13px;opacity:0.5;color:var(--text-light)}

.sbtn{width:100%;padding:15px;background-color:var(--terracotta-dark);border:none;border-radius:100px;cursor:pointer;font-family:'Jost',sans-serif;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:white;font-weight:500;transition:all 0.32s cubic-bezier(0.4,0,0.2,1);box-shadow:0 5px 20px rgba(179,108,70,0.2);position:relative;overflow:hidden}
.sbtn:hover{background-color:var(--terracotta);transform:translateY(-2px);box-shadow:0 10px 25px rgba(179,108,70,0.3)}
.sbtn:active{transform:none}
.sbtn.loading{opacity:0.6;cursor:not-allowed;transform:none}
.err-msg{display:none;font-size:10px;color:var(--terracotta-dark);margin-top:5px;font-style:italic}
.has-err .err-msg{display:block}
.has-err input[type=text]{border-bottom-color:var(--terracotta-dark)!important}
#presErr{display:none;margin-top:7px;font-size:10px;color:var(--terracotta-dark);font-style:italic}

.success{display:none;text-align:center;padding:14px 0;animation:fadeUp 0.7s ease both}
.s-icon{width:70px;height:70px;border-radius:50%;border:1px solid var(--text-light);display:flex;align-items:center;justify-content:center;margin:0 auto 22px;font-size:24px}
.s-ttl{font-family:'Cormorant Garamond',serif;font-size:28px;font-style:italic;font-weight:400;color:var(--text-dark);margin-bottom:10px;line-height:1.3}
.s-msg{font-size:14px;color:var(--text-mid);line-height:1.9;font-weight:300}

.footer{text-align:center;padding:50px 20px 60px;position:relative;z-index:1}
.footer-names{font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:400;color:var(--text-dark);margin-bottom:10px}
.footer-sub{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--text-mid);font-weight:400}

@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
.reveal{opacity:0;transform:translateY(20px);transition:all 0.7s cubic-bezier(0.4,0,0.2,1)}
.reveal.visible{opacity:1;transform:none}
.ripple{position:absolute;border-radius:50%;background:rgba(255,255,255,0.3);transform:scale(0);animation:rippleA 0.65s linear;pointer-events:none}
@keyframes rippleA{to{transform:scale(4);opacity:0}}