:root {
  --ce-primary: #c2185b;
  --ce-primary-dark: #8e0038;
  --ce-gold: #b8945f;
  --ce-cream: #faf3ed;
  --ce-rose: #f8d7da;
  --ce-dark: #322430;
  --ce-muted: #706265;
}
body { font-family: 'Quicksand', sans-serif; color: var(--ce-dark); background: var(--ce-cream); font-size: 16px; line-height: 1.7; }
h1, h2, h3, h4 { font-family: 'Lora', serif; font-weight: 600; color: var(--ce-primary-dark); }
h1 { font-size: 2.8rem; }
h2 { font-size: 2rem; }
a { color: var(--ce-primary); text-decoration: none; }
a:hover { color: var(--ce-primary-dark); text-decoration: underline; }
.navbar { background: #fff !important; padding: 18px 0; box-shadow: 0 2px 10px rgba(0,0,0,0.04); }
.navbar-brand img { height: 46px; }
.navbar .nav-link { color: var(--ce-dark) !important; font-weight: 500; padding: 8px 16px !important; font-size: 0.95rem; }
.navbar .nav-link:hover, .navbar .nav-link.active { color: var(--ce-primary) !important; }
.btn-primary { background: var(--ce-primary); border-color: var(--ce-primary); padding: 10px 28px; font-weight: 600; border-radius: 30px; letter-spacing: 0.03em; }
.btn-primary:hover { background: var(--ce-primary-dark); border-color: var(--ce-primary-dark); }
.btn-outline-primary { color: var(--ce-primary); border-color: var(--ce-primary); padding: 10px 28px; font-weight: 600; border-radius: 30px; }
.ce-hero {
  padding: 110px 0;
  background: linear-gradient(135deg, rgba(250, 243, 237, 0.88), rgba(248, 215, 218, 0.72)), url('../images/hero-fete.jpg') center/cover;
  text-align: center;
}
.ce-hero h1 { font-style: italic; font-size: clamp(2.4rem, 5vw, 3.8rem); color: var(--ce-primary-dark); margin-bottom: 20px; }
.ce-hero .lead { max-width: 700px; margin: 0 auto 30px; font-size: 1.15rem; color: var(--ce-dark); }
.ce-page-hero { padding: 80px 0 50px; background: var(--ce-rose); text-align: center; }
.ce-page-hero h1 { font-style: italic; }
.eye { display: inline-block; color: var(--ce-gold); text-transform: uppercase; letter-spacing: 0.3em; font-size: 0.8rem; font-weight: 600; margin-bottom: 12px; font-family: 'Quicksand', sans-serif; }
section { padding: 70px 0; }
.ce-card { background: #fff; border-radius: 12px; overflow: hidden; box-shadow: 0 6px 30px rgba(0,0,0,0.06); transition: transform 0.3s; border: 0; height: 100%; }
.ce-card:hover { transform: translateY(-6px); }
.ce-card img { aspect-ratio: 4/3; object-fit: cover; width: 100%; }
.ce-card .card-body { padding: 28px; }
.ce-card h3 { font-size: 1.35rem; margin-bottom: 10px; }
.ce-card p { color: var(--ce-muted); }
.ce-featured { background: #fff; border-radius: 12px; padding: 50px; border-top: 4px solid var(--ce-gold); box-shadow: 0 8px 40px rgba(0,0,0,0.06); }
.ce-featured h2 { font-style: italic; }
.ce-tips { background: linear-gradient(180deg, #fff, var(--ce-cream)); padding: 70px 0; }
.article { max-width: 780px; margin: 0 auto; }
.article .lead-img { width: 100%; max-height: 440px; object-fit: cover; border-radius: 12px; margin-bottom: 36px; }
.article h2 { margin-top: 40px; font-style: italic; }
.article h3 { color: var(--ce-gold); margin-top: 24px; }
.article blockquote { border-left: 3px solid var(--ce-gold); padding: 10px 24px; margin: 24px 0; font-style: italic; color: var(--ce-muted); font-family: 'Lora', serif; font-size: 1.15rem; }
footer.ce-foot { background: var(--ce-dark); color: rgba(255,255,255,0.8); padding: 50px 0 20px; font-size: 0.92rem; }
footer.ce-foot h4 { color: #fff; font-family: 'Quicksand', sans-serif; font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.15em; margin-bottom: 16px; }
footer.ce-foot a { color: rgba(255,255,255,0.75); }
footer.ce-foot a:hover { color: var(--ce-rose); }
footer.ce-foot ul { list-style: none; padding: 0; }
footer.ce-foot li { margin-bottom: 6px; }
.ce-socials a { display: inline-flex; width: 34px; height: 34px; background: rgba(255,255,255,0.1); border-radius: 50%; align-items: center; justify-content: center; margin-right: 8px; }
.ce-socials a:hover { background: var(--ce-primary); }
.ce-socials svg { width: 15px; height: 15px; fill: #fff; }
.ce-foot-bottom { border-top: 1px solid rgba(255,255,255,0.1); padding-top: 18px; margin-top: 30px; text-align: center; font-size: 0.82rem; opacity: 0.75; }
form label { font-size: 0.88rem; font-weight: 500; color: var(--ce-primary-dark); }
form input, form textarea, form select { border-radius: 8px; padding: 12px 14px; border: 1px solid #e0d0d5; font-family: inherit; }
.info-box { background: #fff; padding: 32px; border-radius: 12px; border-left: 4px solid var(--ce-gold); }
.info-box h3 { font-size: 1rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ce-gold); margin-top: 18px; }
.info-box h3:first-child { margin-top: 0; }
.legal { max-width: 800px; margin: 0 auto; }
.legal h2 { margin-top: 36px; font-style: italic; }
.err-wrap { text-align: center; padding: 100px 24px; }
.err-wrap .big { font-family: 'Lora', serif; font-size: 10rem; color: var(--ce-gold); font-style: italic; line-height: 1; }
@media (max-width: 768px) { section { padding: 50px 0; } .ce-featured { padding: 30px 24px; } .err-wrap .big { font-size: 6rem; } }
