/*
Theme Name: GG Velada
Theme URI: https://invitacionggfirma.lovable.app
Author: Gabriela Granados Abogados & Consultores
Author URI: https://invitacionggfirma.lovable.app
Description: Invitación digital al aniversario de Gabriela Granados Abogados & Consultores. Tema clásico de WordPress con diseño elegante en paleta verde oliva y beige arena.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: gg-velada
Tags: one-page, elegant, invitation, custom-menu, featured-images
*/

/* ============ Tokens / Brand Palette ============ */
:root{
  --background:#48534C;
  --foreground:#E5DED5;
  --card:#3F4A44;
  --primary:#E5DED5;
  --primary-foreground:#2F3931;
  --secondary:#2F3931;
  --muted:#3F4A44;
  --muted-foreground:#C9C0B3;
  --accent:#E2D5B7;
  --accent-foreground:#2F3931;
  --border:rgba(229,222,213,0.22);
  --gold:#E5DED5;
  --gold-soft:#C9C0B3;
  --cream:#E5DED5;
  --gradient-gold:linear-gradient(135deg,#E5DED5,#C9C0B3);
  --gradient-veil:linear-gradient(180deg,rgba(72,83,76,0.15) 0%,rgba(72,83,76,0.75) 65%,#48534C 100%);
  --shadow-gold:0 20px 60px -20px rgba(0,0,0,0.45);
  --font-display:"Playfair Display",serif;
  --font-body:"Inter",sans-serif;
}

*{box-sizing:border-box;border-color:var(--border);}
html{scroll-behavior:smooth;}
body{
  margin:0;background:var(--background);color:var(--foreground);
  font-family:var(--font-body);-webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{font-family:var(--font-display);letter-spacing:-0.01em;margin:0;}
em{font-style:italic;}

.container{max-width:680px;margin:0 auto;padding:0 1.5rem;}

/* ============ Utilities ============ */
.text-gold{
  background:var(--gradient-gold);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.text-cream{color:var(--cream);}
.text-muted{color:var(--muted-foreground);}
.font-display{font-family:var(--font-display);}
.italic{font-style:italic;}
.uppercase{text-transform:uppercase;}
.text-center{text-align:center;}

/* ============ Hairline ornament ============ */
.hairline-divider{
  display:inline-flex;align-items:center;gap:.75rem;color:var(--gold);
  margin:1rem auto;
}
.hairline-divider .line{display:block;height:1px;width:2.5rem;background:rgba(229,222,213,.6);}
.hairline-divider svg{width:16px;height:16px;}

/* ============ Hero ============ */
.hero{position:relative;height:100svh;width:100%;overflow:hidden;}
.hero img.bg{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  animation:heroIn 2.4s ease-out both;
}
.hero .veil{position:absolute;inset:0;background:var(--gradient-veil);}
.hero .inner{
  position:relative;z-index:1;height:100%;display:flex;flex-direction:column;
  align-items:center;justify-content:space-between;padding:0 1.5rem 2.5rem;text-align:center;
}
.hero .logo{
  width:78%;max-width:28rem;margin-top:-2.5rem;
  filter:brightness(0) invert(1);
  animation:fadeDown 1s .4s both;
}
.hero .kicker{font-size:.75rem;letter-spacing:.5em;text-transform:uppercase;color:rgba(229,222,213,.8);animation:fadeIn 1.2s 1s both;}
.hero h1{margin-top:1.5rem;font-size:clamp(3rem,8vw,4.5rem);line-height:.95;color:var(--cream);animation:fadeUp 1.4s 1.2s both;}
.hero .date{margin-top:.5rem;font-family:var(--font-display);font-size:1.125rem;color:rgba(229,222,213,.9);animation:fadeIn 1s 1.8s both;}
.hero .scroll{display:flex;flex-direction:column;align-items:center;gap:.5rem;animation:fadeIn 1s 2.2s both;}
.hero .scroll span{font-size:10px;letter-spacing:.4em;text-transform:uppercase;color:rgba(229,222,213,.7);}
.hero .scroll i{display:block;height:2rem;width:1px;background:var(--gold);animation:bounceLine 1.8s infinite;}

@keyframes heroIn{from{transform:scale(1.15);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes fadeDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes bounceLine{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}

/* ============ Sections ============ */
section{padding:5rem 1.5rem;}
section h2{font-size:clamp(2rem,5vw,2.5rem);color:var(--cream);}
.lead{font-family:var(--font-display);font-style:italic;font-size:1.5rem;line-height:1.3;color:var(--cream);text-align:center;}
.body-sm{font-size:.875rem;line-height:1.7;color:var(--muted-foreground);text-align:center;}

/* ============ Cards ============ */
.card{
  border:1px solid rgba(229,222,213,.2);background:rgba(63,74,68,.4);
  backdrop-filter:blur(6px);border-radius:.5rem;padding:1.25rem;
}
.detail{display:flex;align-items:flex-start;gap:1rem;}
.detail .icon{
  flex-shrink:0;width:2.5rem;height:2.5rem;border-radius:9999px;
  border:1px solid rgba(229,222,213,.4);display:flex;align-items:center;justify-content:center;color:var(--gold);
}
.detail .label{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin:0;}
.detail .title{font-family:var(--font-display);font-size:1.25rem;color:var(--cream);margin:.25rem 0 0;}
.detail .sub{font-size:.875rem;color:var(--muted-foreground);margin:.25rem 0 0;}

.stack{display:grid;gap:1.5rem;max-width:28rem;margin:0 auto;}

.value{display:flex;align-items:flex-start;gap:1rem;text-align:left;}
.value .icon{flex-shrink:0;width:2.5rem;height:2.5rem;border-radius:9999px;border:1px solid rgba(229,222,213,.4);display:flex;align-items:center;justify-content:center;color:var(--gold);}
.value h3{font-family:var(--font-display);font-size:1.125rem;color:var(--cream);}
.value p{font-size:.75rem;line-height:1.7;color:var(--muted-foreground);margin:.25rem 0 0;}

/* ============ Countdown ============ */
.countdown{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;max-width:28rem;margin:2rem auto 0;}
.countdown .cell{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  border:1px solid rgba(229,222,213,.3);background:rgba(63,74,68,.4);
  border-radius:.375rem;padding:1rem .5rem;backdrop-filter:blur(6px);
}
.countdown .num{font-family:var(--font-display);font-size:clamp(1.875rem,5vw,3rem);color:var(--gold);font-variant-numeric:tabular-nums;}
.countdown .lbl{margin-top:.25rem;font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--muted-foreground);}

/* ============ Buttons ============ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  height:2.75rem;padding:0 2rem;border-radius:.375rem;font-weight:500;font-size:.875rem;
  transition:opacity .2s;cursor:pointer;border:0;width:100%;
}
.btn:hover{opacity:.9;}
.btn-maps{background:#E2D5B7;color:#2F3931;}
.btn-waze{background:#2F3931;color:#E5DED5;}
.btn-primary{background:var(--primary);color:var(--primary-foreground);}
.btn-stack{display:flex;flex-direction:column;gap:.75rem;max-width:20rem;margin:2rem auto 0;}
.btn svg{width:18px;height:18px;}

/* ============ Dress code ============ */
.dress-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;max-width:24rem;margin:2rem auto 0;}
.dress{display:flex;flex-direction:column;align-items:center;gap:.75rem;border:1px solid rgba(229,222,213,.2);background:rgba(63,74,68,.4);border-radius:.375rem;padding:1.5rem 1rem;backdrop-filter:blur(6px);}
.dress .icon{color:var(--gold);}
.dress h3{font-family:var(--font-display);font-size:1.125rem;color:var(--cream);}
.dress p{font-size:.75rem;line-height:1.6;color:var(--muted-foreground);text-align:center;margin:0;}

/* ============ RSVP ============ */
.rsvp{
  max-width:28rem;margin:0 auto;border:1px solid rgba(229,222,213,.3);
  background:rgba(63,74,68,.6);padding:2rem;border-radius:.5rem;text-align:center;
  backdrop-filter:blur(6px);box-shadow:var(--shadow-gold);
}

/* ============ Footer ============ */
.site-footer{
  border-top:1px solid rgba(229,222,213,.2);padding:2.5rem 1.5rem;text-align:center;
}
.site-footer img{margin:0 auto;width:36%;max-width:210px;}
.site-footer p{margin-top:1rem;font-size:10px;letter-spacing:.4em;text-transform:uppercase;color:var(--muted-foreground);}

/* ============ Reveal ============ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .9s cubic-bezier(.22,1,.36,1),transform .9s cubic-bezier(.22,1,.36,1);}
.reveal.is-visible{opacity:1;transform:none;}

/* ============ Header (admin/menu) ============ */
.site-header-nav{position:absolute;top:0;left:0;right:0;z-index:50;padding:1rem 1.5rem;}
.site-header-nav ul{list-style:none;margin:0;padding:0;display:flex;gap:1rem;justify-content:flex-end;flex-wrap:wrap;}
.site-header-nav a{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:#E5DED5;}
.site-header-nav a:hover{color:var(--accent);}
