/* =====================================================
   ANU WEDS TEMI V4 — MAIN STYLESHEET
   Elementor Edition · Yoruba Traditional Wedding
   22 · 10 · 2026 · The City Club, Surulere
   ===================================================== */

/* ── Custom Properties ─────────────────────────────── */
:root {
  --black:      #080604;
  --deep:       #0d0b08;
  --ivory:      #fff8ec;
  --cream:      #f5ead7;
  --parchment:  #ecdec8;
  --gold:       #d7aa52;
  --gold-light: #ead1a0;
  --gold-deep:  #b8892e;
  --wine:       #6f1425;
  --wine-light: #8b1e30;
  --green:      #596b3f;
  --green-dark: #132116;
  --text:       #271b13;
  --muted:      #8b745e;
  --divider:    rgba(215,170,82,0.25);
  --font-serif: Georgia, 'Times New Roman', serif;
  --font-body:  'Jost', 'Inter', system-ui, sans-serif;
  --section-pad: clamp(5rem, 10vw, 9rem);
  --gutter:      clamp(1.25rem, 5vw, 3rem);
  --radius-sm:  6px;
  --radius:     14px;
  --t: 0.3s cubic-bezier(0.25,0.46,0.45,0.94);
  --t-slow: 0.65s cubic-bezier(0.25,0.46,0.45,0.94);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{background:var(--black);color:var(--ivory);font-family:var(--font-body);line-height:1.7;overflow-x:hidden}
a{color:inherit;text-decoration:none;transition:color var(--t)}
img{max-width:100%;display:block}
ul,ol{list-style:none}

.serif{font-family:var(--font-serif)}
h1,h2,h3,h4{font-family:var(--font-serif);font-weight:400;line-height:1.05}
h1{font-size:clamp(2.8rem,7vw,7rem)}
h2{font-size:clamp(2rem,4.5vw,4.5rem)}
h3{font-size:clamp(1.4rem,2.5vw,2rem)}

.kicker{letter-spacing:.42em;text-transform:uppercase;font-size:.72rem;font-family:var(--font-body);font-weight:500;color:var(--gold-light)}
.kicker.gold{color:var(--gold)}
.kicker.dark{color:var(--muted)}
.section-title{font-size:clamp(2.2rem,4vw,4.2rem);font-weight:400;line-height:1;margin:.5rem 0 1.5rem}
.gold{color:var(--gold)}
.wine{color:var(--wine)}
.muted{color:var(--muted)}

.wrap{width:min(1160px,90vw);margin:0 auto}
.wrap--narrow{width:min(780px,90vw)}
.section{padding:var(--section-pad) var(--gutter);background:var(--ivory);color:var(--text)}
.section.dark{background:var(--black);color:var(--ivory)}
.section.deep{background:var(--deep);color:var(--ivory)}
.section.green{background:var(--green-dark);color:var(--ivory)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}

.rule{border:none;border-top:1px solid var(--divider);margin:2.5rem 0}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.7rem;border:1px solid var(--gold);padding:1rem 1.75rem;letter-spacing:.18em;text-transform:uppercase;font-size:.72rem;font-family:var(--font-body);font-weight:500;color:var(--ivory);background:rgba(8,6,4,.35);transition:var(--t);cursor:pointer;position:relative;overflow:hidden}
.btn::before{content:'';position:absolute;inset:0;background:var(--gold);transform:translateX(-101%);transition:transform var(--t);z-index:0}
.btn>*{position:relative;z-index:1}
.btn:hover{color:var(--black)}
.btn:hover::before{transform:translateX(0)}
.btn.dark{background:rgba(12,16,10,.7)}
.btn.filled{background:var(--gold);color:var(--black);border-color:var(--gold)}
.btn.filled:hover{background:var(--gold-deep);border-color:var(--gold-deep)}
.btn.enter{margin-top:2rem}

/* Site header */
.site-head{position:fixed;top:0;left:0;right:0;z-index:200;padding:1.2rem 0;transition:background var(--t-slow),padding var(--t)}
.site-head::before{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(8,6,4,.85),transparent);pointer-events:none;transition:opacity var(--t-slow)}
.site-head.scrolled{background:rgba(8,6,4,.93);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:.85rem 0;border-bottom:1px solid var(--divider)}
.site-head.scrolled::before{opacity:0}
.nav{display:flex;justify-content:space-between;align-items:center;width:min(1200px,92vw);margin:0 auto}
.logo{width:70px;transition:width var(--t)}
.site-head.scrolled .logo{width:58px}

/* Navigation */
.menu{display:flex;gap:2rem;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;font-family:var(--font-body);font-weight:500;align-items:center}
.menu a{opacity:.78;position:relative;padding-bottom:3px;transition:opacity var(--t)}
.menu a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--gold);transition:width var(--t)}
.menu a:hover{opacity:1}
.menu a:hover::after{width:100%}
.menu-list{list-style:none;display:flex;gap:2rem;align-items:center}
.menu-list li{margin:0}

/* Mobile toggle */
.mobile-toggle{appearance:none;border:1px solid rgba(215,170,82,.5);background:rgba(0,0,0,.35);color:var(--ivory);border-radius:999px;padding:.6rem 1rem;display:none;align-items:center;gap:.5rem;cursor:pointer;letter-spacing:.12em;text-transform:uppercase;font-size:.65rem;font-family:var(--font-body);position:relative;z-index:31}
.mobile-toggle .bar{display:flex;flex-direction:column;gap:4px}
.mobile-toggle .bar span{display:block;width:18px;height:1.5px;background:var(--gold);border-radius:99px;transition:all var(--t)}
.mobile-toggle[aria-expanded="true"] .bar span:nth-child(1){transform:translateY(5.5px) rotate(45deg)}
.mobile-toggle[aria-expanded="true"] .bar span:nth-child(2){opacity:0}
.mobile-toggle[aria-expanded="true"] .bar span:nth-child(3){transform:translateY(-5.5px) rotate(-45deg)}

/* Hero */
.hero{min-height:100vh;display:grid;place-items:center;position:relative;background:linear-gradient(135deg,rgba(8,6,4,.88) 0%,rgba(8,6,4,.4) 50%,rgba(8,6,4,.82) 100%),var(--hero,none) center/cover no-repeat;overflow:hidden}
.hero::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 40% 25%,rgba(215,170,82,.22),transparent 40%),linear-gradient(to top,rgba(8,6,4,1) 0%,transparent 28%);pointer-events:none;z-index:1}
.hero-content{position:relative;z-index:2;text-align:center;padding:7rem var(--gutter) 4rem;max-width:860px}
.hero h1{font-size:clamp(3.2rem,9vw,9rem);line-height:.92;margin:1rem 0;color:var(--gold);font-weight:400}
.hero h1 .and{font-style:italic;font-size:.42em;color:var(--gold-light)}
.hero p{font-size:1.05rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,248,236,.75)}
.hero .date{font-size:clamp(1.4rem,3vw,2rem)!important;color:var(--ivory);letter-spacing:.35em;margin:1.5rem 0}
.hero .verse{margin-top:2.5rem;color:var(--gold-light);font-style:italic;font-family:var(--font-serif);font-size:1rem;letter-spacing:.06em;opacity:.85}

.intro-logo{width:120px;margin:0 auto 1.5rem;filter:drop-shadow(0 0 22px rgba(215,170,82,.6));transition:filter var(--t)}
.countdown{font-size:clamp(.85rem,1.5vw,1rem);letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin:1rem 0;min-height:1.4em}
.scroll-cue{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:.5rem;animation:bob 2.5s ease-in-out infinite}
.scroll-cue span{font-size:.58rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,248,236,.35)}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}

body.page-template-page-intro .site-head{display:none}

/* Info cards */
.card-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--divider);border:1px solid var(--divider)}
.info-card{background:var(--ivory);padding:2.5rem 2rem;text-align:center;color:var(--text);transition:background var(--t)}
.info-card:hover{background:var(--cream)}
.info-card.dark-card{background:rgba(255,255,255,.03);color:var(--ivory);border:1px solid var(--divider)}
.info-card.dark-card:hover{background:rgba(215,170,82,.08)}
.info-card b{display:block;letter-spacing:.22em;text-transform:uppercase;color:var(--wine);font-size:.7rem;margin-bottom:.85rem;font-family:var(--font-body)}
.dark-card b{color:var(--gold)}
.info-card p{line-height:1.7;font-size:.95rem}
.info-card .card-date{font-family:var(--font-serif);font-size:clamp(1.6rem,3vw,2.4rem);color:var(--wine)}
.dark-card .card-date{color:var(--gold)}

/* Timeline */
.timeline{display:grid;gap:1.8rem;margin-top:2.5rem;position:relative}
.timeitem{border-left:2px solid var(--gold);padding-left:1.5rem;padding-bottom:1.2rem}
.timeitem h3{font-family:var(--font-serif);font-size:1.2rem;color:var(--wine);font-weight:400;margin-bottom:.4rem}
.section.dark .timeitem h3,.section.green .timeitem h3{color:var(--gold)}
.timeitem p{font-size:.9rem;line-height:1.85;color:var(--muted)}
.section.dark .timeitem p{color:rgba(255,248,236,.65)}

/* Gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:.85rem}
.gallery a{display:block;overflow:hidden;border-radius:var(--radius-sm)}
.gallery img{height:260px;width:100%;object-fit:cover;border-radius:var(--radius-sm);transition:transform var(--t-slow)}
.gallery a:hover img{transform:scale(1.06)}
.awt-gallery a{display:block;cursor:zoom-in}

/* FAQ */
.faq{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--divider)}
.faq details{background:var(--ivory);padding:1.6rem 1.8rem;transition:background var(--t)}
.faq details[open]{background:var(--cream)}
.faq summary{cursor:pointer;font-weight:700;font-size:.9rem;color:var(--wine);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem;letter-spacing:.03em}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';font-size:1.3rem;flex-shrink:0;transition:transform var(--t)}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq p{margin-top:.85rem;line-height:1.8;font-size:.9rem;color:var(--muted)}

/* RSVP form */
.rsvp-form-wrap{background:#fff;padding:2.5rem;border:1px solid var(--parchment);border-radius:var(--radius);box-shadow:0 8px 48px rgba(0,0,0,.06)}
.rsvp-form-wrap label{display:block;font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:.3rem;margin-top:1.1rem}
.rsvp-form-wrap label:first-of-type{margin-top:0}
.rsvp-form-wrap input,.rsvp-form-wrap textarea,.rsvp-form-wrap select{width:100%;padding:.95rem 1rem;border:1px solid var(--parchment);background:#fffaf2;font-family:var(--font-body);font-size:.9rem;color:var(--text);transition:border-color var(--t);border-radius:var(--radius-sm)}
.rsvp-form-wrap input:focus,.rsvp-form-wrap textarea:focus,.rsvp-form-wrap select:focus{outline:none;border-color:var(--gold);background:#fff}
.rsvp-form-wrap textarea{resize:vertical;min-height:100px}

/* Gift cards */
.gift-card{background:var(--ivory);border:1px solid var(--divider);padding:2rem;border-radius:var(--radius);text-align:center;transition:box-shadow var(--t),transform var(--t)}
.gift-card:hover{box-shadow:0 12px 40px rgba(215,170,82,.15);transform:translateY(-3px)}
.gift-icon{font-size:2.5rem;margin-bottom:1rem;display:block}
.gift-card h3{font-family:var(--font-serif);font-size:1.2rem;color:var(--wine);margin-bottom:.75rem}
.gift-card p{font-size:.88rem;color:var(--muted);line-height:1.7}

/* Footer */
.footer{padding:4rem var(--gutter);text-align:center;background:#050403;color:#c9ad75;border-top:1px solid var(--divider)}
.footer .intro-logo{width:80px;margin:0 auto 1.25rem;opacity:.8}
.footer .couple-name{font-family:var(--font-serif);font-size:1.5rem;color:var(--gold-light);margin-bottom:.35rem}
.footer p{font-size:.78rem;letter-spacing:.12em;opacity:.65;line-height:1.9}
.footer .verse{font-style:italic;font-family:var(--font-serif);font-size:.9rem;color:var(--gold-light);margin-top:1.25rem;opacity:.7}
.footer-nav{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;margin:1.5rem 0}
.footer-nav a{font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;opacity:.5;transition:opacity var(--t)}
.footer-nav a:hover{opacity:1}

/* Lightbox */
.awt-lightbox{position:fixed;inset:0;background:rgba(5,4,3,.96);z-index:99999;display:none;align-items:center;justify-content:center;padding:28px;backdrop-filter:blur(8px)}
.awt-lightbox.is-open{display:flex}
.awt-lightbox img{max-width:min(1100px,92vw);max-height:86vh;object-fit:contain;border-radius:var(--radius);box-shadow:0 24px 80px rgba(0,0,0,.75)}
.awt-lightbox button{position:absolute;border:1px solid rgba(215,170,82,.55);background:rgba(0,0,0,.55);color:var(--ivory);border-radius:999px;width:48px;height:48px;font-size:24px;line-height:1;cursor:pointer;transition:all var(--t);display:flex;align-items:center;justify-content:center}
.awt-lightbox button:hover{background:var(--gold);color:var(--black);border-color:var(--gold)}
.awt-lightbox .awt-close{top:20px;right:20px}
.awt-lightbox .awt-prev,.awt-lightbox .awt-next{top:50%;transform:translateY(-50%);width:52px;height:52px;font-size:32px}
.awt-lightbox .awt-prev{left:20px}
.awt-lightbox .awt-next{right:20px}

/* Elementor integration */
.elementor-section-full_width{padding:0}
body.elementor-editor-active .site-head{position:absolute}
.elementor-content:empty{display:none}
.elementor-page .site-main{padding:0}

/* Reveal */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s,transform .7s}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}

/* Story photo */
.story-photo{border-radius:var(--radius);overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.story-photo img{width:100%;height:100%;object-fit:cover}

/* Quote */
.quote-block{border-left:2px solid var(--gold);padding:.5rem 0 .5rem 1.5rem;margin:2rem 0}
.quote-block p{font-family:var(--font-serif);font-size:1.2rem;font-style:italic;color:var(--wine);line-height:1.6}
.section.dark .quote-block p{color:var(--gold-light)}

/* Accessibility */
:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
.skip-link{position:absolute;top:-100%;left:1rem;background:var(--gold);color:var(--black);padding:.5rem 1rem;font-size:.8rem;z-index:9999}
.skip-link:focus{top:.5rem}

/* ── Mobile ─────────────────────────────────────────── */
@media(max-width:900px){
  .menu{display:none}
  .mobile-toggle{display:inline-flex}
  .grid-2,.faq,.grid-3{grid-template-columns:1fr}
  .card-row{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr 1fr}
  .hero h1{font-size:clamp(3rem,12vw,5rem)}
  .section{padding:4rem var(--gutter)}
  .hero-content{padding-top:8rem;padding-inline:1rem}
  .logo{width:58px}
  .site-head{background:rgba(8,6,4,.82);backdrop-filter:blur(14px)}
  .mobile-toggle{display:inline-flex;position:relative;z-index:31}
  .menu{position:fixed;top:0;left:0;right:0;min-height:100svh;background:radial-gradient(circle at 50% 15%,rgba(215,170,82,.14),transparent 35%),rgba(5,4,3,.97);flex-direction:column;align-items:center;justify-content:center;gap:0;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .28s,visibility .28s;z-index:30;display:flex!important}
  .menu.is-open{opacity:1;visibility:visible;pointer-events:auto}
  .menu .menu-list{flex-direction:column!important;gap:0!important;text-align:center}
  .menu .menu-list li{width:100%}
  .menu a{font-family:var(--font-serif);font-size:clamp(2rem,8vw,3.2rem);letter-spacing:.04em;color:var(--gold);opacity:.7;display:block;padding:.6rem 2rem;transition:opacity var(--t),transform var(--t)}
  .menu a:hover{opacity:1;transform:translateX(6px)}
  .menu a::after{display:none}
  body.menu-open{overflow:hidden}
}

@media(max-width:600px){
  .gallery{grid-template-columns:1fr}
  .gallery img{height:280px}
  .faq{grid-template-columns:1fr}
  .rsvp-form-wrap{padding:1.5rem}
  .awt-lightbox .awt-prev,.awt-lightbox .awt-next{display:none}
}


/* ── Aso-Ebi Cards ─────────────────────────────────── */
.asoebi-card {
  border: 1px solid var(--divider);
  border-radius: var(--radius);
  overflow: hidden;
  background: rgba(255,255,255,0.03);
}

.asoebi-header {
  padding: 1.75rem 2rem;
  position: relative;
}

.groom-header { background: linear-gradient(135deg, rgba(111,20,37,0.85), rgba(111,20,37,0.5)); }
.bride-header  { background: linear-gradient(135deg, rgba(89,107,63,0.85), rgba(89,107,63,0.5)); }

.asoebi-tag {
  display: inline-block;
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold-light);
  background: rgba(0,0,0,.3);
  padding: .3rem .85rem;
  border-radius: 999px;
  margin-bottom: .75rem;
}

.asoebi-header h3 {
  font-family: var(--font-serif);
  font-size: clamp(1.4rem,2.5vw,2rem);
  color: var(--ivory);
  font-weight: 400;
  margin-bottom: .4rem;
}

.asoebi-colour-note {
  font-size: .82rem;
  color: rgba(255,248,236,.75);
  line-height: 1.5;
}

.asoebi-colour-note strong { color: var(--gold-light); }

.asoebi-body {
  padding: 1.75rem 2rem;
}

.asoebi-subtitle {
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 1rem;
}

.asoebi-list {
  list-style: none;
  margin-bottom: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: .1rem;
}

.asoebi-list li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: .65rem 0;
  border-bottom: 1px solid rgba(215,170,82,.12);
  gap: 1rem;
}

.asoebi-item {
  font-size: .88rem;
  color: rgba(255,248,236,.8);
}

.asoebi-item em {
  font-size: .78rem;
  color: rgba(255,248,236,.45);
  font-style: italic;
}

.asoebi-price {
  font-family: var(--font-serif);
  font-size: 1rem;
  color: var(--gold);
  white-space: nowrap;
  font-weight: 400;
}

.asoebi-payment {
  background: rgba(215,170,82,.08);
  border: 1px solid rgba(215,170,82,.2);
  border-radius: var(--radius-sm);
  padding: 1rem 1.25rem;
  margin-bottom: 1rem;
}

.asoebi-pay-label {
  font-size: .65rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: .4rem;
}

.asoebi-bank {
  font-size: 1rem;
  font-family: var(--font-serif);
  color: var(--ivory);
}

.asoebi-name {
  font-size: .85rem;
  color: rgba(255,248,236,.65);
  margin-top: .2rem;
}

.asoebi-contact {
  font-size: .82rem;
  color: rgba(255,248,236,.55);
  margin-bottom: 1rem;
  line-height: 1.6;
}

.asoebi-phone {
  display: inline-block;
  color: var(--gold);
  font-size: 1.05rem;
  font-family: var(--font-serif);
  margin-top: .25rem;
  transition: color var(--t);
}

.asoebi-phone:hover { color: var(--gold-light); }

.asoebi-note {
  border-left: 2px solid var(--wine);
  padding: .5rem .85rem;
  font-size: .82rem;
  color: rgba(255,248,236,.65);
  background: rgba(111,20,37,.12);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

.asoebi-note strong { color: var(--ivory); }

@media(max-width:900px){
  .asoebi-card { margin-bottom: 1.5rem; }
}


/* ── FluentForms theme integration ──────────────────── */
.rsvp-form-wrap .ff-el-group { margin-bottom: 1.1rem; }

.rsvp-form-wrap .ff-el-form-control,
.rsvp-form-wrap input[type="text"],
.rsvp-form-wrap input[type="email"],
.rsvp-form-wrap input[type="tel"],
.rsvp-form-wrap input[type="number"],
.rsvp-form-wrap select,
.rsvp-form-wrap textarea {
  width: 100%;
  padding: .95rem 1rem;
  border: 1px solid var(--parchment);
  background: #fffaf2;
  font-family: var(--font-body);
  font-size: .9rem;
  color: var(--text);
  border-radius: var(--radius-sm);
  transition: border-color var(--t);
}

.rsvp-form-wrap .ff-el-form-control:focus,
.rsvp-form-wrap input:focus,
.rsvp-form-wrap select:focus,
.rsvp-form-wrap textarea:focus {
  outline: none;
  border-color: var(--gold);
  background: #fff;
}

.rsvp-form-wrap .ff-el-form-label label,
.rsvp-form-wrap label {
  display: block;
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: .3rem;
}

.rsvp-form-wrap .ff-btn-submit,
.rsvp-form-wrap button[type="submit"] {
  width: 100%;
  padding: 1rem 2rem;
  background: var(--wine) !important;
  color: var(--ivory) !important;
  border: none !important;
  border-radius: 0 !important;
  font-family: var(--font-body) !important;
  font-size: .72rem !important;
  font-weight: 700 !important;
  letter-spacing: .18em !important;
  text-transform: uppercase !important;
  cursor: pointer;
  transition: background var(--t) !important;
  margin-top: .5rem;
}

.rsvp-form-wrap .ff-btn-submit:hover,
.rsvp-form-wrap button[type="submit"]:hover {
  background: var(--wine-light) !important;
}

.rsvp-form-wrap .ff-el-is-error .ff-el-form-control {
  border-color: #c0392b;
}

.rsvp-form-wrap .error { color: #c0392b; font-size: .78rem; margin-top: .25rem; }
