/*
Theme Name: Capital Governance & Allocation Authority
Theme URI: https://thecountrybankofneedham.com/
Author: Pro Plans & Black Ice Security
Author URI: https://thecountrybankofneedham.com/
Description: Institutional governance theme implementing the CGAA landing design (nav + hero + pillars + services + audience + value proposition), with seeded landing pages and working navigation.
Version: 1.1.0
Requires at least: 5.9
Tested up to: 6.5
Requires PHP: 7.4
License: GPLv2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: capital-governance-authority
Tags: custom-logo, custom-menu, featured-images, block-styles, wide-blocks
*/


:root{
  --deep-indigo:#1a1a2e;
  --cosmic-purple:#16213e;
  --sacred-gold:#d4af37;
  --divine-light:#f4f1de;
  --ethereal-blue:#0f4c75;
  --celestial-silver:#e8e8e8;
  --mystic-teal:#1b4965;
  --phi:1.618;
  --space-1:13px;
  --space-2:21px;
  --space-3:34px;
  --space-4:55px;
  --space-5:89px;
}

*{margin:0;padding:0;box-sizing:border-box}
body{
  font-family:'Montserrat',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--deep-indigo);
  color:var(--divine-light);
  overflow-x:hidden;
  position:relative;
}

/* Sacred geometry ambient background */
body::before{
  content:'';
  position:fixed; inset:0;
  background:
    radial-gradient(circle at 20% 30%, rgba(212,175,55,.03) 0%, transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(15,76,117,.05) 0%, transparent 50%),
    radial-gradient(circle at 50% 50%, rgba(212,175,55,.02) 0%, transparent 70%);
  pointer-events:none;
  z-index:0;
}

/* Typography */
h1,h2,h3{font-family:'Cormorant Garamond',serif; font-weight:700; line-height:1.2}
a{color:inherit}

/* Nav */
nav.cgaa-nav{
  position:fixed; top:0; width:100%;
  background:rgba(26,26,46,.95);
  backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(212,175,55,.2);
  z-index:1000;
  transition:all .3s ease;
}
nav.cgaa-nav.scrolled{
  background:rgba(26,26,46,.98);
  box-shadow:0 4px 30px rgba(0,0,0,.3);
}
.cgaa-nav .nav-container{
  max-width:1600px; margin:0 auto;
  padding:1.5rem 3rem;
  display:flex; justify-content:space-between; align-items:center;
}
.logo-container{display:flex; align-items:center; gap:1rem}
.logo-symbol{width:40px;height:40px; position:relative}
.golden-circle{position:absolute;border:2px solid var(--sacred-gold); border-radius:50%; animation:cgaa_pulse 3s ease-in-out infinite}
.golden-circle:nth-child(1){width:40px;height:40px}
.golden-circle:nth-child(2){width:30px;height:30px; top:5px; left:5px; animation-delay:1s}
@keyframes cgaa_pulse{0%,100%{opacity:.3; transform:scale(1)}50%{opacity:1; transform:scale(1.05)}}
.logo-text{font-family:'Cormorant Garamond',serif; font-size:1.3rem; font-weight:600; color:var(--sacred-gold); letter-spacing:1px}
.nav-links{display:flex; gap:2.5rem; list-style:none; align-items:center}
.nav-links a{
  text-decoration:none; font-size:.95rem; font-weight:400; letter-spacing:.5px;
  position:relative; transition:all .3s ease;
}
.nav-links a::before{
  content:''; position:absolute; bottom:-5px; left:50%; transform:translateX(-50%);
  width:0; height:2px; background:linear-gradient(90deg, transparent, var(--sacred-gold), transparent);
  transition:width .3s ease;
}
.nav-links a:hover{color:var(--sacred-gold)}
.nav-links a:hover::before{width:100%}

/* CTA */
.cgaa-cta{
  padding:1.0rem 2.4rem;
  background:linear-gradient(135deg,var(--sacred-gold), #b8960f);
  color:var(--deep-indigo);
  text-decoration:none;
  font-weight:600;
  letter-spacing:1px;
  border:none;
  position:relative;
  overflow:hidden;
  transition:all .35s ease;
  box-shadow:0 0 30px rgba(212,175,55,.25);
}
.cgaa-cta:hover{transform:translateY(-2px); box-shadow:0 10px 40px rgba(212,175,55,.45)}

/* Sacred geometry svg */
.sacred-geometry{
  position:fixed; top:50%; left:50%;
  transform:translate(-50%,-50%);
  width:100vw; height:100vh;
  opacity:.03; pointer-events:none; z-index:0;
}

/* Hero */
.hero{
  min-height:100vh;
  display:flex; align-items:center; justify-content:center;
  position:relative;
  margin-top:80px;
  overflow:hidden;
}
.hero::before{
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(135deg,var(--cosmic-purple) 0%, var(--deep-indigo) 50%, var(--mystic-teal) 100%);
  z-index:-1;
}
.particles{position:absolute; inset:0; overflow:hidden}
.particle{position:absolute; width:2px; height:2px; background:var(--sacred-gold); border-radius:50%; opacity:0; animation:cgaa_float 10s infinite}
@keyframes cgaa_float{
  0%{opacity:0; transform:translateY(100vh) translateX(0)}
  10%{opacity:1}
  90%{opacity:1}
  100%{opacity:0; transform:translateY(-100vh) translateX(100px)}
}
.hero-content{
  max-width:1400px; margin:0 auto; padding:4rem 3rem;
  text-align:center; position:relative; z-index:2;
}
.hero h1{
  font-size:4.1rem; margin-bottom:2rem;
  text-shadow:0 0 30px rgba(212,175,55,.25);
}
.divine-tagline{
  font-family:'Cormorant Garamond',serif;
  font-size:2rem; color:var(--sacred-gold); font-style:italic;
  margin-bottom:2.5rem; font-weight:300;
}
.hero-description{
  font-size:1.2rem; color:rgba(244,241,222,.9);
  max-width:900px; margin:0 auto 3rem;
  line-height:1.9;
}
.cta-row{display:flex; gap:2rem; justify-content:center; flex-wrap:wrap}
.cta-secondary{
  padding:1.0rem 2.4rem;
  background:transparent;
  color:var(--sacred-gold);
  text-decoration:none;
  font-weight:600;
  letter-spacing:1px;
  border:2px solid var(--sacred-gold);
  transition:all .35s ease;
}
.cta-secondary:hover{background:var(--sacred-gold); color:var(--deep-indigo); transform:translateY(-2px)}

.scroll-indicator{
  position:absolute; bottom:3rem; left:50%;
  transform:translateX(-50%);
  animation:cgaa_bounce 2s infinite;
}
.scroll-indicator::before{content:'↓'; font-size:2rem; color:var(--sacred-gold)}
@keyframes cgaa_bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(10px)}}

/* Sections */
.section{
  padding:8rem 3rem;
  position:relative;
  z-index:1;
}
.section-inner{max-width:1200px; margin:0 auto; text-align:center}
.section-title{
  font-size:3rem; color:var(--sacred-gold);
  margin-bottom:2rem; position:relative; display:inline-block;
}
.section-title::after{
  content:''; position:absolute; bottom:-10px; left:50%;
  transform:translateX(-50%); width:60px; height:2px; background:var(--sacred-gold);
}
.essence{background:linear-gradient(180deg,var(--deep-indigo), var(--cosmic-purple))}
.essence-text{font-size:1.25rem; line-height:2; color:rgba(244,241,222,.9); max-width:900px; margin:3rem auto 0}

.pillars{background:var(--cosmic-purple)}
.pillars-grid{
  max-width:1600px; margin:4rem auto 0;
  display:grid; grid-template-columns:repeat(auto-fit, minmax(350px, 1fr));
  gap:2.5rem;
}
.pillar-card{
  background:linear-gradient(135deg, rgba(22,33,62,.8), rgba(26,26,46,.8));
  border:1px solid rgba(212,175,55,.2);
  padding:3rem;
  position:relative;
  overflow:hidden;
  transition:all .5s ease;
  backdrop-filter:blur(10px);
  text-align:center;
}
.pillar-card:hover{transform:translateY(-10px) scale(1.02); border-color:var(--sacred-gold); box-shadow:0 20px 60px rgba(212,175,55,.18)}
.pillar-icon{width:80px;height:80px;margin:0 auto 2rem;position:relative}
.pillar-symbol{width:100%;height:100%;border:3px solid var(--sacred-gold);border-radius:50%;position:relative;animation:cgaa_rotate 20s linear infinite}
.pillar-symbol::before,.pillar-symbol::after{
  content:''; position:absolute; top:50%; left:50%;
  width:60%; height:60%; border:2px solid var(--sacred-gold); border-radius:50%;
  transform:translate(-50%,-50%); opacity:.5;
}
.pillar-symbol::after{width:40%;height:40%; animation:cgaa_rotate 15s linear infinite reverse}
@keyframes cgaa_rotate{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

.pillar-card h3{font-size:1.8rem; color:var(--sacred-gold); margin-bottom:1.5rem}
.pillar-card p{color:rgba(244,241,222,.85); margin-bottom:2rem; line-height:1.8}
.pillar-link{
  display:block;
  color:var(--sacred-gold);
  text-decoration:none;
  font-weight:600;
  letter-spacing:1px;
  padding:1rem;
  border:2px solid var(--sacred-gold);
  transition:all .3s ease;
}
.pillar-link:hover{background:var(--sacred-gold); color:var(--deep-indigo); transform:translateY(-2px)}

.divine-purpose{
  background:linear-gradient(135deg, var(--deep-indigo), var(--ethereal-blue));
  text-align:center;
}
.divine-purpose::before{
  content:'';
  position:absolute; inset:0;
  background:url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M50 0 L61.8 38.2 L100 50 L61.8 61.8 L50 100 L38.2 61.8 L0 50 L38.2 38.2 Z' fill='%23d4af37' opacity='0.03'/%3E%3C/svg%3E");
  background-size:100px 100px;
  opacity:.25;
  pointer-events:none;
}
.divine-quote{
  font-family:'Cormorant Garamond',serif;
  font-size:2.2rem;
  font-style:italic;
  line-height:1.6;
  margin:2rem auto 2rem;
  max-width:1000px;
  text-shadow:0 0 20px rgba(212,175,55,.25);
}
.footer{
  background:var(--deep-indigo);
  padding:5rem 3rem 2rem;
  border-top:1px solid rgba(212,175,55,.2);
  position:relative;
  z-index:1;
}
.footer-content{
  max-width:1600px; margin:0 auto;
  display:grid; grid-template-columns:repeat(auto-fit, minmax(250px,1fr));
  gap:3rem; margin-bottom:3rem;
}
.footer h3{font-family:'Cormorant Garamond',serif; color:var(--sacred-gold); font-size:1.3rem; margin-bottom:1.5rem}
.footer p,.footer a{color:rgba(244,241,222,.7); text-decoration:none; line-height:2; transition:color .3s ease}
.footer a:hover{color:var(--sacred-gold)}
.footer-bottom{
  max-width:1600px; margin:0 auto;
  padding-top:2rem; border-top:1px solid rgba(212,175,55,.2);
  text-align:center; color:rgba(244,241,222,.5);
}

/* Responsive */
@media (max-width: 900px){
  .cgaa-nav .nav-container{flex-direction:column; gap:1rem; padding:1.2rem 1.5rem}
  .nav-links{flex-direction:column; gap:1rem; text-align:center}
  .hero h1{font-size:2.6rem}
  .divine-tagline{font-size:1.4rem}
  .section-title{font-size:2rem}
  .pillars-grid{grid-template-columns:1fr}
}


/* Sacred landing template (pillar + ethos pages) */
.cgaa-landing-hero{min-height:70vh}
.landing-cta-row{display:flex; gap:1.25rem; justify-content:center; flex-wrap:wrap; margin-top:1.5rem}
.cgaa-landing-body .section-inner{max-width:1100px}
.cgaa-landing-body h2, .cgaa-landing-body h3{color:var(--sacred-gold)}
.cgaa-landing-body p{color:rgba(244,241,222,.88)}
.cgaa-landing-body ul{margin:1rem auto; max-width:900px; text-align:left}
.cgaa-landing-body li{margin:.5rem 0; line-height:1.9; color:rgba(244,241,222,.85)}
.cgaa-landing-body strong{color:var(--divine-light)}
.cgaa-landing-body .wp-block-separator{border-color:rgba(212,175,55,.25)}

/* Professional “what this includes” callout */
.cgaa-callout{
  border:1px solid rgba(212,175,55,.22);
  background:linear-gradient(135deg, rgba(22,33,62,.65), rgba(26,26,46,.65));
  padding:2rem;
  margin:2.5rem auto;
  max-width:950px;
}

/* Next cards */
.landing-next{margin-top:3rem}
.landing-next-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:1.25rem;
  max-width:1100px;
  margin:0 auto;
}
.landing-next-card{
  display:block;
  padding:1.5rem 1.5rem;
  border:1px solid rgba(212,175,55,.18);
  background:rgba(22,33,62,.35);
  text-decoration:none;
  transition:all .3s ease;
}
.landing-next-card:hover{transform:translateY(-4px); border-color:rgba(212,175,55,.45); box-shadow:0 18px 50px rgba(0,0,0,.25)}
.landing-next-card h3{margin:0 0 .5rem 0; font-size:1.35rem}
.landing-next-card p{margin:0; color:rgba(244,241,222,.78); line-height:1.7}


/* Institutional nav dropdown + mobile toggle */
.logo-text{font-family:'Cormorant Garamond',serif; font-size:1.3rem; font-weight:600; color:var(--sacred-gold); letter-spacing:1px; text-decoration:none}
.cgaa-nav-toggle{
  display:none;
  background:transparent;
  border:1px solid rgba(212,175,55,.35);
  color:var(--divine-light);
  padding:.6rem 1rem;
  letter-spacing:.6px;
}
.has-submenu{position:relative}
.submenu{
  position:absolute;
  top:calc(100% + 10px);
  left:0;
  min-width:260px;
  background:rgba(26,26,46,.98);
  border:1px solid rgba(212,175,55,.22);
  padding:.6rem;
  list-style:none;
  display:none;
  z-index:1200;
}
.has-submenu:hover .submenu,
.has-submenu:focus-within .submenu{display:block}
.submenu a{
  display:block;
  padding:.75rem .9rem;
  border:1px solid transparent;
}
.submenu a:hover{
  border-color:rgba(212,175,55,.25);
  background:rgba(22,33,62,.55);
}

/* Hide legacy widget blocks if inserted accidentally */
.widget, .wp-block-latest-posts, .wp-block-archives, .wp-block-categories{display:none !important}

@media (max-width: 900px){
  .cgaa-nav-toggle{display:block}
  #cgaaNavMenu{
    display:none;
    width:100%;
    flex-direction:column;
    align-items:stretch;
    gap:.75rem;
    padding:1rem 0 0;
  }
  nav.cgaa-nav .nav-container{align-items:stretch}
  .has-submenu .submenu{
    position:static;
    display:block;
    background:transparent;
    border:none;
    padding:0;
  }
  .has-submenu > a{display:none}
}
