/* ============================================================
   IGLESIA REY JESUCRISTO INTERNACIONAL
   Sistema de diseño — dorado elegante sobre marfil
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;500;600;700&family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Mulish:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&family=Pinyon+Script&display=swap');

:root{
  /* Tones */
  --ivory:        #FAF5EA;
  --ivory-2:      #F3EAD8;
  --cream-card:   #FFFDF7;
  --espresso:     #281F12;
  --espresso-2:   #1A1409;
  --espresso-3:   #0F0B05;
  --brown:        #6A573A;
  --brown-soft:   #8A7656;

  /* Gold */
  --gold:         #B0843A;
  --gold-deep:    #8A6526;
  --gold-light:   #E6C878;
  --gold-pale:    #EAD9AE;
  --gold-grad:    linear-gradient(135deg, #F0D78F 0%, #C79B45 38%, #9A7129 100%);
  --gold-grad-soft: linear-gradient(135deg, #E9CE86, #B58B3C);

  --line:         rgba(150,110,40,.26);
  --line-strong:  rgba(150,110,40,.5);

  --shadow-sm: 0 2px 10px rgba(60,42,12,.07);
  --shadow-md: 0 14px 40px -18px rgba(60,42,12,.30);
  --shadow-lg: 0 30px 70px -30px rgba(40,28,8,.45);

  --font-display: 'Cinzel', serif;
  --font-head:    'Cormorant Garamond', serif;
  --font-body:    'Mulish', system-ui, sans-serif;
  --font-script:  'Pinyon Script', cursive;

  --maxw: 1200px;
  --nav-h: 78px;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--font-body);
  color:var(--espresso);
  background:var(--ivory);
  line-height:1.65;
  font-size:17px;
  font-weight:400;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
::selection{ background:rgba(176,132,58,.25); }

/* ---------- Typography helpers ---------- */
.eyebrow{
  font-family:var(--font-display);
  text-transform:uppercase;
  letter-spacing:.34em;
  font-size:.72rem;
  font-weight:600;
  color:var(--gold-deep);
  display:inline-flex;
  align-items:center;
  gap:.85em;
}
.eyebrow::before,
.eyebrow.center::after{
  content:"";
  width:34px; height:1px;
  background:linear-gradient(90deg,transparent,var(--gold));
}
.eyebrow.center::before{ background:linear-gradient(90deg,var(--gold),transparent); }

h1,h2,h3,h4{ font-family:var(--font-head); font-weight:600; line-height:1.08; color:var(--espresso); letter-spacing:.005em; }
.display{ font-size:clamp(2.6rem,6vw,5rem); font-weight:600; line-height:1.0; }
h2.section-title{ font-size:clamp(2rem,4vw,3.3rem); }
.lead{ font-size:clamp(1.05rem,1.6vw,1.3rem); color:var(--brown); font-weight:400; }
.script{ font-family:var(--font-script); color:var(--gold-deep); font-weight:400; line-height:.9; }

.text-gold{
  background:var(--gold-grad);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
}

/* ---------- Layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(20px,5vw,48px); }
.section{ padding-block:clamp(64px,9vw,128px); position:relative; }
.section.tight{ padding-block:clamp(48px,6vw,84px); }
.bg-ivory-2{ background:var(--ivory-2); }
.bg-dark{ background:var(--espresso-2); color:#EFE6D4; }
.bg-dark h1,.bg-dark h2,.bg-dark h3,.bg-dark h4{ color:#F6EFDF; }
.bg-dark .lead{ color:#CBB994; }

/* Divider with central lozenge */
.divider{ display:flex; align-items:center; justify-content:center; gap:18px; color:var(--gold); }
.divider::before,.divider::after{ content:""; height:1px; width:min(160px,22vw); background:linear-gradient(90deg,transparent,var(--line-strong)); }
.divider::after{ background:linear-gradient(90deg,var(--line-strong),transparent); }
.divider .dot{ width:9px; height:9px; transform:rotate(45deg); background:var(--gold-grad); box-shadow:0 0 0 4px rgba(176,132,58,.12); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--font-body); font-weight:700; font-size:.92rem;
  letter-spacing:.03em;
  padding:.95em 1.8em; border-radius:999px;
  cursor:pointer; border:1px solid transparent;
  transition:transform .25s cubic-bezier(.2,.7,.3,1), box-shadow .25s, background .25s, color .25s;
  white-space:nowrap;
}
.btn-gold{ background:var(--gold-grad); color:#241a07; box-shadow:0 10px 26px -12px rgba(154,113,41,.8), inset 0 1px 0 rgba(255,255,255,.35); }
.btn-gold:hover{ transform:translateY(-2px); box-shadow:0 16px 34px -12px rgba(154,113,41,.9), inset 0 1px 0 rgba(255,255,255,.45); }
.btn-outline{ border-color:var(--line-strong); color:var(--gold-deep); background:transparent; }
.btn-outline:hover{ background:rgba(176,132,58,.08); border-color:var(--gold); transform:translateY(-2px); }
.btn-ghost-light{ border-color:rgba(230,200,120,.4); color:var(--gold-light); }
.btn-ghost-light:hover{ background:rgba(230,200,120,.1); border-color:var(--gold-light); transform:translateY(-2px); }
.btn-lg{ padding:1.1em 2.2em; font-size:1rem; }

/* ---------- Brand mark (cropped from flyer, clipped to circle) ---------- */
.brand-mark{
  --s:56px;
  width:var(--s); height:var(--s);
  flex:none;
  border-radius:50%;
  background-image:url('flyer-aniversario.png');
  background-repeat:no-repeat;
  background-size: calc(var(--s) * 3.13);
  background-position: calc(var(--s) * -0.375) calc(var(--s) * -0.222);
  box-shadow:0 0 0 1px rgba(176,132,58,.25), var(--shadow-sm);
}
.brand-mark.on-dark{ box-shadow:0 0 0 1px rgba(230,200,120,.3); }
/* For pages in sub-folders, override the url via this modifier if needed */

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:80;
  background:rgba(250,245,234,.82);
  backdrop-filter:blur(14px) saturate(1.2);
  -webkit-backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid var(--line);
  transition:box-shadow .3s, background .3s;
}
.site-header.scrolled{ box-shadow:var(--shadow-sm); background:rgba(250,245,234,.94); }
.nav{
  height:var(--nav-h);
  display:flex; align-items:center; gap:24px;
  max-width:1320px; margin-inline:auto;
  padding-inline:clamp(18px,4vw,40px);
}
.brand{ display:flex; align-items:center; gap:13px; flex:none; }
.brand .brand-mark{ --s:48px; }
.brand-name{ display:flex; flex-direction:column; line-height:1; }
.brand-name b{ font-family:var(--font-display); font-weight:700; font-size:.92rem; letter-spacing:.06em; color:var(--espresso); }
.brand-name span{ font-family:var(--font-display); font-weight:500; font-size:.58rem; letter-spacing:.36em; color:var(--gold-deep); margin-top:3px; }

.nav-links{ display:flex; align-items:center; gap:2px; margin-left:auto; }
.nav-links a{
  font-size:.83rem; font-weight:600; letter-spacing:.01em;
  padding:.55em .82em; border-radius:8px; color:var(--brown);
  position:relative; transition:color .2s; white-space:nowrap;
}
.nav-links a::after{
  content:""; position:absolute; left:.82em; right:.82em; bottom:.34em; height:1.5px;
  background:var(--gold-grad); transform:scaleX(0); transform-origin:left; transition:transform .28s ease;
}
.nav-links a:hover{ color:var(--espresso); }
.nav-links a:hover::after{ transform:scaleX(1); }
.nav-links a.active{ color:var(--espresso); }
.nav-links a.active::after{ transform:scaleX(1); }

.nav-actions{ display:flex; align-items:center; gap:12px; flex:none; }
.lang-toggle{
  display:flex; align-items:center; border:1px solid var(--line-strong); border-radius:999px; overflow:hidden; font-family:var(--font-body);
}
.lang-toggle button{
  border:none; background:transparent; cursor:pointer; font-weight:700; font-size:.72rem; letter-spacing:.05em;
  padding:.42em .7em; color:var(--brown); transition:.2s;
}
.lang-toggle button.active{ background:var(--gold-grad); color:#241a07; }

.nav-toggle{ display:none; background:none; border:none; cursor:pointer; flex-direction:column; gap:5px; padding:8px; }
.nav-toggle span{ width:24px; height:2px; background:var(--espresso); border-radius:2px; transition:.3s; }

/* Mobile nav */
@media (max-width:1080px){
  .nav-links{
    position:fixed; inset:var(--nav-h) 0 auto 0;
    flex-direction:column; align-items:stretch; gap:2px;
    background:var(--ivory); border-bottom:1px solid var(--line);
    padding:14px clamp(18px,4vw,40px) 26px;
    transform:translateY(-130%); transition:transform .4s cubic-bezier(.4,0,.2,1);
    box-shadow:var(--shadow-md); max-height:calc(100vh - var(--nav-h)); overflow:auto;
  }
  .nav-links.open{ transform:translateY(0); }
  .nav-links a{ padding:.85em .4em; font-size:1rem; border-bottom:1px solid var(--line); border-radius:0; }
  .nav-links a::after{ display:none; }
  .nav-toggle{ display:flex; margin-left:auto; }
  .nav-toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  .nav-toggle.open span:nth-child(2){ opacity:0; }
  .nav-toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
  .nav-actions .nav-cta{ display:none; }
}
@media (max-width:520px){
  .brand-name span{ display:none; }
}

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; min-height:clamp(560px,90vh,860px); display:flex; align-items:center; overflow:hidden; }
.hero-bg{ position:absolute; inset:0; z-index:0; }
.hero-bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(105deg, rgba(20,14,6,.82) 0%, rgba(26,18,8,.6) 45%, rgba(26,18,8,.25) 100%); }
.hero .wrap{ position:relative; z-index:2; }
.hero-content{ max-width:720px; color:#F6EFDF; }
.hero-content h1{ color:#FBF4E2; text-shadow:0 2px 30px rgba(0,0,0,.3); }
.hero-content .lead{ color:#E4D6B8; }
.hero .eyebrow{ color:var(--gold-light); }
.hero .eyebrow::before{ background:linear-gradient(90deg,var(--gold-light),transparent); }

/* ============================================================
   PAGE HEADER (interior pages)
   ============================================================ */
.page-hero{ position:relative; padding-block:clamp(72px,11vw,140px); background:var(--espresso-2); color:#EFE6D4; overflow:hidden; }
.page-hero::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(120% 90% at 85% -10%, rgba(176,132,58,.35), transparent 55%),
    radial-gradient(80% 70% at -5% 110%, rgba(176,132,58,.18), transparent 60%);
}
.page-hero .wrap{ position:relative; z-index:2; }
.page-hero h1{ color:#FBF4E2; font-size:clamp(2.4rem,5.5vw,4.4rem); }
.page-hero .lead{ color:#D6C6A2; max-width:680px; }
.page-hero .eyebrow{ color:var(--gold-light); }
.page-hero .eyebrow::before{ background:linear-gradient(90deg,var(--gold-light),transparent); }
.crumb{ font-size:.78rem; letter-spacing:.04em; color:#B8A77F; margin-bottom:18px; }
.crumb a:hover{ color:var(--gold-light); }

/* ============================================================
   CARDS / GRIDS
   ============================================================ */
.grid{ display:grid; gap:clamp(18px,2.4vw,30px); }
.grid-2{ grid-template-columns:repeat(2,1fr); }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-4{ grid-template-columns:repeat(4,1fr); }
@media (max-width:900px){ .grid-3,.grid-4{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:620px){ .grid-2,.grid-3,.grid-4{ grid-template-columns:1fr;} }

.card{
  background:var(--cream-card); border:1px solid var(--line);
  border-radius:16px; padding:30px; box-shadow:var(--shadow-sm);
  transition:transform .3s, box-shadow .3s, border-color .3s;
  position:relative; overflow:hidden;
}
.card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:var(--line-strong); }
.card .num{ font-family:var(--font-display); font-size:.8rem; color:var(--gold); letter-spacing:.1em; }
.card h3{ font-size:1.5rem; margin:.3em 0 .4em; }
.card p{ color:var(--brown); font-size:.96rem; }
.card .ref{ display:inline-block; margin-top:14px; font-size:.74rem; font-family:var(--font-display); letter-spacing:.08em; color:var(--gold-deep); padding:.35em .8em; border:1px solid var(--line); border-radius:999px; }

.icon-badge{
  width:54px; height:54px; border-radius:14px; display:grid; place-items:center;
  background:linear-gradient(135deg, rgba(230,200,120,.28), rgba(176,132,58,.12));
  border:1px solid var(--line); color:var(--gold-deep); margin-bottom:18px;
}
.icon-badge svg{ width:26px; height:26px; }

/* ---------- Placeholder image ---------- */
.ph{
  position:relative; border-radius:16px; overflow:hidden;
  background-color:#EDE2CC;
  background-image:repeating-linear-gradient(45deg, rgba(176,132,58,.12) 0 12px, rgba(176,132,58,.04) 12px 24px);
  border:1px solid var(--line);
  display:grid; place-items:center; min-height:240px; color:var(--gold-deep);
}
.ph span{
  font-family:'Courier New',monospace; font-size:.74rem; letter-spacing:.12em; text-transform:uppercase;
  background:rgba(255,253,247,.85); padding:.5em 1em; border-radius:6px; border:1px dashed var(--line-strong);
  text-align:center;
}
.ph.tall{ min-height:420px; }
.ph.full{ height:100%; }

/* ============================================================
   SCHEDULE / LISTS
   ============================================================ */
.schedule{ display:grid; gap:0; }
.sch-row{ display:grid; grid-template-columns:auto 1fr auto; gap:20px; align-items:center; padding:20px 0; border-bottom:1px solid var(--line); }
.sch-row:first-child{ border-top:1px solid var(--line); }
.sch-day{ font-family:var(--font-display); font-weight:600; letter-spacing:.06em; font-size:.78rem; color:var(--gold-deep); text-transform:uppercase; min-width:118px; }
.sch-name{ font-family:var(--font-head); font-size:1.35rem; font-weight:600; }
.sch-name small{ display:block; font-family:var(--font-body); font-size:.82rem; color:var(--brown); font-weight:400; letter-spacing:0; text-transform:none; }
.sch-time{ font-weight:700; color:var(--espresso); font-variant-numeric:tabular-nums; }
@media (max-width:620px){
  .sch-row{ grid-template-columns:1fr auto; }
  .sch-day{ grid-column:1/-1; }
}

/* info row with icon */
.info-list{ display:grid; gap:22px; }
.info-row{ display:grid; grid-template-columns:auto 1fr; gap:18px; align-items:start; }
.info-row .ic{ width:46px; height:46px; flex:none; border-radius:12px; display:grid; place-items:center; background:var(--gold-grad-soft); color:#241a07; }
.info-row .ic svg{ width:22px; height:22px; }
.info-row b{ display:block; font-family:var(--font-display); font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:3px; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:var(--espresso-3); color:#C8B894; padding-block:64px 30px; position:relative; }
.site-footer::before{ content:""; position:absolute; top:0; left:0; right:0; height:3px; background:var(--gold-grad); }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.3fr; gap:40px; }
@media (max-width:900px){ .footer-grid{ grid-template-columns:1fr 1fr; gap:36px 28px; } }
@media (max-width:560px){ .footer-grid{ grid-template-columns:1fr; } }
.site-footer h4{ font-family:var(--font-display); font-size:.8rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-light); margin-bottom:18px; }
.site-footer a{ color:#C8B894; font-size:.92rem; display:inline-block; padding:4px 0; transition:color .2s; }
.site-footer a:hover{ color:var(--gold-light); }
.foot-links{ display:flex; flex-direction:column; }
.foot-brand .brand{ margin-bottom:16px; }
.foot-brand .brand-name b{ color:#F2E8D2; }
.foot-tagline{ font-family:var(--font-script); font-size:1.7rem; color:var(--gold-light); line-height:1; margin-top:8px; }
.foot-social{ display:flex; gap:10px; margin-top:8px; }
.foot-social a{ width:40px; height:40px; border:1px solid rgba(200,184,148,.3); border-radius:50%; display:grid; place-items:center; padding:0; }
.foot-social a:hover{ border-color:var(--gold-light); background:rgba(230,200,120,.1); }
.foot-social svg{ width:18px; height:18px; }
.foot-bottom{ margin-top:48px; padding-top:24px; border-top:1px solid rgba(200,184,148,.18); display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:.8rem; color:#8E7E5E; }

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
@media (prefers-reduced-motion:no-preference){
  .reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.3,1); }
  .reveal.in{ opacity:1; transform:none; }
  .reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; } .reveal.d3{ transition-delay:.24s; } .reveal.d4{ transition-delay:.32s; }
}

/* utility */
.center{ text-align:center; }
.mx-auto{ margin-inline:auto; }
.mt-s{ margin-top:14px; } .mt-m{ margin-top:26px; } .mt-l{ margin-top:44px; }
.maxw-680{ max-width:680px; } .maxw-760{ max-width:760px; }
.stack{ display:flex; flex-direction:column; }
.row{ display:flex; gap:14px; flex-wrap:wrap; align-items:center; }
.cols-2{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,72px); align-items:center; }
@media (max-width:840px){ .cols-2{ grid-template-columns:1fr; } }
.hide-en[data-lang-hidden]{ display:none; }
