/* ═══════════════════════════════════════
   INTIMATE WEDDING & ELOPEMENT – Page CSS
   Prefisso: .int-
   ═══════════════════════════════════════ */

:root {
  --int-sage: #7a8b6a;
  --int-sage-light: #b5c49a;
  --int-sage-pale: #dde6d0;
  --int-rose: #c4928a;
  --int-rose-light: #d4a99f;
  --int-rose-pale: #f2ddd8;
  --int-linen: #f8f4ef;
  --int-linen-warm: #f0e8dd;
  --int-cream: #fdfaf5;
  --int-taupe: #7a6e63;
  --int-espresso: #3e3530;
  --int-blush: #bb847a;
  --int-white: #ffffff;
}

/* ── HERO SPLIT ── */
.int-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 100vh;
}
.int-hero-left {
  background: linear-gradient(135deg, var(--int-sage-pale), var(--int-linen-warm));
  position: relative; overflow: hidden;
}
.int-hero-img {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
}
.int-placeholder {
  font-family: 'Cormorant Garamond', serif;
  font-size: 16px; color: rgba(122,139,106,.1);
  letter-spacing: 5px; text-transform: uppercase;
}
.int-hero-right {
  display: flex; align-items: center; justify-content: center;
  padding: 80px 60px;
  background: var(--int-cream);
}
.int-hero-content { max-width: 480px; }
.int-hero-badge {
  display: inline-block;
  font-family: 'Karla', sans-serif;
  font-size: 11px; letter-spacing: 4px; text-transform: uppercase;
  color: var(--int-sage);
  border: 1px solid var(--int-sage-light);
  padding: 8px 20px;
  margin-bottom: 30px;
  animation: intFade .8s ease .2s both;
}
h1.int-hero-title {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: clamp(40px, 5vw, 72px) !important;
  font-weight: 300 !important;
  line-height: 1.1 !important;
  color: var(--int-espresso) !important;
  margin-bottom: 25px !important;
  animation: intFade .8s ease .4s both;
}
h1.int-hero-title em { font-style: italic; color: var(--int-rose); font-weight: 400; }
.int-hero-sub {
  font-family: 'Karla', sans-serif;
  font-size: 15px; line-height: 1.9; color: var(--int-taupe);
  font-weight: 300; margin-bottom: 40px;
  animation: intFade .8s ease .6s both;
}
.int-hero-btns { display: flex; gap: 18px; flex-wrap: wrap; animation: intFade .8s ease .8s both; }

/* ── BUTTONS ── */
.int-btn-rose {
  background: var(--int-rose) !important; color: var(--int-white) !important;
  padding: 15px 38px !important; font-family: 'Karla', sans-serif !important;
  font-size: 12px !important; letter-spacing: 2px !important;
  text-transform: uppercase !important; text-decoration: none !important;
  font-weight: 400 !important; transition: all .3s !important;
  border: none !important; display: inline-block; border-radius: 0 !important;
}
.int-btn-rose:hover { background: var(--int-blush) !important; }
.int-btn-outline {
  background: transparent !important; color: var(--int-espresso) !important;
  padding: 15px 38px !important; border: 1.5px solid var(--int-linen-warm) !important;
  font-family: 'Karla', sans-serif !important;
  font-size: 12px !important; letter-spacing: 2px !important;
  text-transform: uppercase !important; text-decoration: none !important;
  font-weight: 300 !important; transition: all .3s !important;
  display: inline-block; border-radius: 0 !important;
}
.int-btn-outline:hover { border-color: var(--int-sage) !important; color: var(--int-sage) !important; }

/* ── SECTION HEADERS ── */
.int-section-header { text-align: center; margin-bottom: 60px; }
.int-section-tag { font-family: 'Karla', sans-serif; font-size: 11px; letter-spacing: 5px; text-transform: uppercase; color: var(--int-sage); margin-bottom: 18px; }
h2.int-section-title { font-family: 'Cormorant Garamond', serif !important; font-size: clamp(28px, 3.5vw, 44px) !important; font-weight: 300 !important; color: var(--int-espresso) !important; }

/* ── PHILOSOPHY ── */
.int-philosophy { padding: 100px 40px; text-align: center; background: var(--int-linen); }
.int-philosophy-inner { max-width: 700px; margin: 0 auto; }
h2.int-philosophy-title { font-family: 'Cormorant Garamond', serif !important; font-size: clamp(30px, 4vw, 50px) !important; font-weight: 300 !important; margin-bottom: 25px !important; color: var(--int-espresso) !important; }
h2.int-philosophy-title em { font-style: italic; color: var(--int-rose); }
.int-philosophy-text { font-family: 'Karla', sans-serif; font-size: 15px; line-height: 2; color: var(--int-taupe); font-weight: 300; }
.int-philosophy-line { width: 1px; height: 60px; background: linear-gradient(to bottom, var(--int-sage-light), transparent); margin: 40px auto 0; }

/* ── EXPERIENCES ── */
.int-experiences { padding: 100px 40px; background: var(--int-cream); }
.int-exp-inner { max-width: 1200px; margin: 0 auto; }
.int-exp-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.int-exp-card {
  background: var(--int-white); padding: 45px 30px; text-align: center;
  border: 1px solid var(--int-linen-warm); transition: all .4s; position: relative;
}
.int-exp-card.featured { border-color: var(--int-rose-light); box-shadow: 0 15px 40px rgba(196,146,138,.1); }
.int-exp-badge {
  position: absolute; top: -12px; left: 50%; transform: translateX(-50%);
  background: var(--int-rose); color: var(--int-white);
  font-family: 'Karla', sans-serif; font-size: 10px; letter-spacing: 1.5px;
  text-transform: uppercase; padding: 5px 16px; white-space: nowrap;
}
.int-exp-card:hover { transform: translateY(-5px); box-shadow: 0 20px 50px rgba(62,53,48,.06); }
.int-exp-icon { font-size: 28px; color: var(--int-sage); margin-bottom: 20px; }
h3.int-exp-name { font-family: 'Bodoni Moda', serif !important; font-size: 28px !important; font-weight: 400 !important; margin-bottom: 8px !important; color: var(--int-espresso) !important; }
.int-exp-guests { font-family: 'Karla', sans-serif; font-size: 12px; letter-spacing: 2px; text-transform: uppercase; color: var(--int-sage); margin-bottom: 15px; }
.int-exp-price { font-family: 'Cormorant Garamond', serif; font-size: 32px; font-weight: 300; color: var(--int-rose); margin-bottom: 18px; }
.int-exp-desc { font-family: 'Karla', sans-serif; font-size: 13px; line-height: 1.8; color: var(--int-taupe); font-weight: 300; margin-bottom: 25px; }
.int-exp-btn {
  display: inline-block; font-family: 'Karla', sans-serif; font-size: 11px;
  letter-spacing: 2px; text-transform: uppercase; color: var(--int-espresso);
  text-decoration: none; border-bottom: 1px solid var(--int-sage-light);
  padding-bottom: 3px; transition: all .3s;
}
.int-exp-btn:hover { color: var(--int-rose); border-color: var(--int-rose); }

/* ── PROCESS ── */
.int-process { padding: 100px 40px; background: var(--int-linen); }
.int-process-inner { max-width: 800px; margin: 0 auto; }
.int-steps { display: flex; flex-direction: column; gap: 0; }
.int-step {
  display: grid; grid-template-columns: 80px 1fr; gap: 25px;
  padding: 35px 0; border-bottom: 1px solid var(--int-linen-warm);
}
.int-step:last-child { border-bottom: none; }
.int-step-num { font-family: 'Cormorant Garamond', serif; font-size: 44px; font-weight: 300; color: var(--int-sage-light); line-height: 1; }
h3.int-step-title { font-family: 'Cormorant Garamond', serif !important; font-size: 24px !important; font-weight: 400 !important; margin-bottom: 8px !important; color: var(--int-espresso) !important; }
.int-step-desc { font-family: 'Karla', sans-serif; font-size: 14px; line-height: 1.8; color: var(--int-taupe); font-weight: 300; }

/* ── TESTIMONIALS ── */
.int-testimonials { padding: 100px 40px; background: var(--int-cream); }
.int-test-inner { max-width: 1100px; margin: 0 auto; }
.int-test-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 30px; }
.int-test-card { background: var(--int-white); padding: 40px; border: 1px solid var(--int-linen-warm); position: relative; }
.int-test-card::before { content: '\201C'; font-family: 'Cormorant Garamond', serif; font-size: 70px; color: var(--int-rose-pale); position: absolute; top: 15px; left: 30px; line-height: 1; }
.int-test-stars { color: var(--int-rose); font-size: 13px; letter-spacing: 3px; margin-bottom: 15px; }
.int-test-text { font-family: 'Cormorant Garamond', serif; font-size: 18px; font-style: italic; line-height: 1.6; color: var(--int-espresso); margin-bottom: 20px; padding-top: 10px; }
.int-test-author { font-family: 'Karla', sans-serif; font-size: 12px; letter-spacing: 2px; text-transform: uppercase; color: var(--int-rose); font-weight: 500; }
.int-test-detail { font-family: 'Karla', sans-serif; font-size: 12px; color: var(--int-taupe); margin-top: 3px; font-weight: 300; }

/* ── FAQ ── */
.int-faq { padding: 100px 40px; background: var(--int-linen); }
.int-faq-inner { max-width: 900px; margin: 0 auto; }
.int-faq-item { border-bottom: 1px solid var(--int-sage-pale); padding: 28px 0; }
.int-faq-item:first-of-type { border-top: 1px solid var(--int-sage-pale); }
h3.int-faq-q { font-family: 'Cormorant Garamond', serif !important; font-size: 21px !important; font-weight: 400 !important; cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 20px; transition: color .3s; color: var(--int-espresso) !important; margin: 0 !important; }
h3.int-faq-q:hover { color: var(--int-sage) !important; }
h3.int-faq-q::after { content: '+'; font-size: 22px; color: var(--int-sage); font-weight: 300; transition: transform .3s; flex-shrink: 0; }
.int-faq-item.open h3.int-faq-q::after { transform: rotate(45deg); }
.int-faq-a { max-height: 0; overflow: hidden; transition: max-height .4s ease, padding .4s ease; font-family: 'Karla', sans-serif; font-size: 14px; line-height: 1.9; color: var(--int-taupe); font-weight: 300; }
.int-faq-item.open .int-faq-a { max-height: 300px; padding-top: 18px; }

/* ── CTA ── */
.int-cta { padding: 100px 40px; background: var(--int-espresso); text-align: center; }
.int-cta-content { max-width: 600px; margin: 0 auto; position: relative; }
h2.int-cta-title { font-family: 'Cormorant Garamond', serif !important; font-size: clamp(30px, 4vw, 48px) !important; font-weight: 300 !important; color: var(--int-linen) !important; margin-bottom: 20px !important; }
h2.int-cta-title em { font-style: italic; color: var(--int-rose-light); }
.int-cta-text { font-family: 'Karla', sans-serif; font-size: 15px; color: var(--int-sage-pale); max-width: 450px; margin: 0 auto 40px; font-weight: 200; line-height: 1.8; }

/* ── ANIMATIONS ── */
@keyframes intFade { from { opacity:0; transform:translateY(20px) } to { opacity:1; transform:translateY(0) } }

/* ── RESPONSIVE ── */
@media(max-width:1024px) {
  .int-hero { grid-template-columns: 1fr; }
  .int-hero-left { min-height: 400px; }
  .int-exp-grid { grid-template-columns: 1fr 1fr; }
  .int-exp-card:last-child { grid-column: span 2; max-width: 400px; margin: 0 auto; }
  .int-test-grid { grid-template-columns: 1fr; }
}
@media(max-width:768px) {
  .int-hero-left { min-height: 300px; }
  .int-hero-right { padding: 60px 25px; }
  h1.int-hero-title { font-size: 38px !important; }
  .int-hero-btns { flex-direction: column; }
  .int-philosophy { padding: 70px 25px; }
  .int-experiences { padding: 70px 25px; }
  .int-exp-grid { grid-template-columns: 1fr; }
  .int-exp-card:last-child { grid-column: span 1; max-width: none; }
  .int-process { padding: 70px 25px; }
  .int-step { grid-template-columns: 55px 1fr; gap: 15px; }
  .int-testimonials { padding: 70px 25px; }
  .int-faq { padding: 70px 25px; }
  .int-cta { padding: 70px 25px; }
}
.int-hero-img img{width:100%;height:100%;object-fit:cover;display:block}
