/*
Theme Name: GVO Dance Pro
Theme URI: https://gvodance.com
Author: OpenAI
Description: Premium lightweight WordPress theme for GVO Dance with easy social linking and simple content updates.
Version: 1.0
Text Domain: gvodance-pro
*/

:root{
  --gvo-black:#111111;
  --gvo-charcoal:#2F2F2F;
  --gvo-gold:#C7A46A;
  --gvo-bg:#F8F8F8;
  --gvo-white:#FFFFFF;
  --gvo-max:1200px;
  --gvo-shadow:0 20px 50px rgba(0,0,0,.12);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Montserrat, Arial, sans-serif;
  background:var(--gvo-bg);
  color:var(--gvo-charcoal);
  line-height:1.65;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
.site-header{
  position:sticky; top:0; z-index:1000;
  background:rgba(17,17,17,.94);
  backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(199,164,106,.18);
}
.wrap{
  width:min(var(--gvo-max), calc(100% - 40px));
  margin-inline:auto;
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:20px; padding:18px 0;
}
.site-branding{display:flex;align-items:center;gap:14px}
.custom-logo{max-height:80px;width:auto}
.logo-wordmark{
  display:flex;flex-direction:column;gap:5px
}
.logo-gvo{
  font-family:"Playfair Display", Georgia, serif;
  font-size:40px; letter-spacing:.16em; line-height:1; color:var(--gvo-white)
}
.logo-line{height:2px;width:110px;background:var(--gvo-gold)}
.logo-dance{
  color:var(--gvo-gold);
  letter-spacing:.55em; font-size:12px; padding-left:2px
}
.primary-nav ul{
  list-style:none; display:flex; gap:28px; margin:0; padding:0; flex-wrap:wrap
}
.primary-nav a{
  color:var(--gvo-white); font-size:14px; letter-spacing:.08em; text-transform:uppercase
}
.primary-nav a:hover,.social-link:hover,.btn-outline:hover{color:var(--gvo-gold)}
.hero{
  min-height:78vh;
  display:flex; align-items:center;
  background:
    linear-gradient(90deg, rgba(0,0,0,.76) 0%, rgba(0,0,0,.52) 46%, rgba(0,0,0,.28) 100%),
    var(--hero-image) center/cover no-repeat,
    var(--gvo-black);
  color:var(--gvo-white);
}
.hero-inner{
  width:min(var(--gvo-max), calc(100% - 40px));
  margin-inline:auto;
  padding:120px 0 100px;
}
.hero-brand{
  max-width:700px;
}
.hero-brand .logo-gvo{font-size:96px}
.hero-brand .logo-line{width:180px;margin:20px 0}
.hero-brand .logo-dance{font-size:24px}
.hero-kicker{
  margin-top:22px; color:rgba(255,255,255,.9);
  font-family:"Playfair Display", Georgia, serif;
  font-size:26px;
}
.hero-subtitle{margin-top:10px;font-size:22px;color:rgba(255,255,255,.84)}
.hero-buttons{display:flex;gap:16px;flex-wrap:wrap;margin-top:30px}
.btn{
  display:inline-block; padding:14px 24px; border-radius:8px;
  font-weight:600; letter-spacing:.04em; transition:.2s ease;
  border:1px solid var(--gvo-gold)
}
.btn-primary{background:var(--gvo-gold);color:var(--gvo-black)}
.btn-primary:hover{opacity:.92}
.btn-outline{background:transparent;color:var(--gvo-white)}
.section{padding:90px 0}
.section-dark{background:var(--gvo-black);color:var(--gvo-white)}
.section-title{
  font-family:"Playfair Display", Georgia, serif;
  font-size:clamp(34px,4vw,54px); line-height:1.15; margin:0 0 20px
}
.section-intro{max-width:760px;color:inherit;opacity:.8}
.gold-divider{
  display:flex; align-items:center; gap:24px; margin-bottom:32px
}
.gold-divider:before,.gold-divider:after{
  content:""; height:1px; flex:1; background:rgba(199,164,106,.55)
}
.gold-divider span{
  color:var(--gvo-gold);
  font-family:"Playfair Display", Georgia, serif;
  font-size:clamp(22px,3vw,42px)
}
.two-col{
  display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:center
}
.card-grid{display:grid; gap:24px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(199,164,106,.16);
  box-shadow:var(--gvo-shadow);
  border-radius:18px;
  overflow:hidden;
}
.section-light .card{background:var(--gvo-white)}
.card-content{padding:28px}
.achievement-year{
  color:var(--gvo-gold);
  font-family:"Playfair Display", Georgia, serif;
  font-size:42px; line-height:1.1; margin:0 0 10px
}
.achievement-title{
  font-family:"Playfair Display", Georgia, serif;
  font-size:28px; line-height:1.25; margin:0 0 8px
}
.muted{opacity:.75}
.media-thumb{
  aspect-ratio:16/10;
  background:#222 center/cover no-repeat;
}
.tag{
  display:inline-block; margin-bottom:10px; color:var(--gvo-gold);
  text-transform:uppercase; letter-spacing:.12em; font-size:12px; font-weight:700
}
.about-portrait{
  min-height:520px;
  background:#ddd center/cover no-repeat;
  border-radius:24px;
  box-shadow:var(--gvo-shadow)
}
.social-row{
  display:flex; flex-wrap:wrap; gap:16px; margin-top:25px
}
.social-link{
  display:inline-flex; align-items:center; gap:10px;
  border:1px solid rgba(199,164,106,.35);
  border-radius:999px; padding:12px 18px;
  color:var(--gvo-white)
}
.social-link.light{color:var(--gvo-charcoal)}
.icon{
  width:18px;height:18px;display:inline-block;flex:0 0 18px
}
.footer{
  background:var(--gvo-black); color:var(--gvo-white);
  border-top:1px solid rgba(199,164,106,.16);
}
.footer-inner{
  padding:36px 0; display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap
}
.footer small{opacity:.7}
.page-content{padding:80px 0}
.entry-content h1,.entry-content h2,.entry-content h3{
  font-family:"Playfair Display", Georgia, serif
}
.cta-panel{
  background:linear-gradient(135deg, rgba(199,164,106,.12), rgba(255,255,255,.03));
  border:1px solid rgba(199,164,106,.2);
  border-radius:24px;
  padding:36px;
}
.notice{
  margin-top:16px; font-size:14px; opacity:.78
}
@media (max-width: 980px){
  .two-col,.grid-3,.grid-4{grid-template-columns:1fr 1fr}
  .hero-brand .logo-gvo{font-size:72px}
  .hero-brand .logo-dance{font-size:18px}
}
@media (max-width: 720px){
  .header-inner{flex-direction:column; align-items:flex-start}
  .primary-nav ul{gap:14px}
  .two-col,.grid-3,.grid-4{grid-template-columns:1fr}
  .hero{min-height:auto}
  .hero-inner{padding:90px 0 70px}
  .hero-brand .logo-gvo{font-size:56px}
  .hero-brand .logo-line{width:130px}
  .hero-kicker{font-size:22px}
  .hero-subtitle{font-size:18px}
}
