*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg: hsl(20,10%,8%);--fg: hsl(40,30%,92%);
  --card: hsl(20,12%,12%);--card-fg: hsl(40,30%,92%);
  --gold: hsl(38,80%,55%);--gold-glow: hsl(38,90%,65%);
  --secondary: hsl(20,15%,18%);--muted: hsl(30,10%,55%);
  --border: hsl(30,15%,20%);
  --font-display:'Playfair Display',serif;--font-body:'Source Sans 3',sans-serif;
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--fg);font-family:var(--font-body);line-height:1.6}
h1,h2,h3,h4,h5,h6{font-family:var(--font-display)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}
.text-center{text-align:center}

/* Gold text */
.text-gold{background:linear-gradient(135deg,var(--gold),var(--gold-glow),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.text-gold-solid{color:var(--gold)}

/* Header */
#site-header{position:fixed;top:0;left:0;right:0;z-index:50;background:hsla(20,10%,8%,.8);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem}
.logo{font-family:var(--font-display);font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,var(--gold),var(--gold-glow));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.nav-desktop{display:flex;gap:2rem}
.nav-desktop a{font-size:.875rem;font-weight:500;color:hsla(40,30%,92%,.7);transition:color .3s}
.nav-desktop a:hover{color:var(--gold)}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px}
.menu-toggle span{display:block;width:24px;height:2px;background:var(--fg);transition:.3s}
.nav-mobile{display:none;background:var(--card);border-top:1px solid var(--border);padding:0 1.5rem 1rem}
.nav-mobile a{display:block;padding:.75rem 0;color:hsla(40,30%,92%,.7);transition:color .3s}
.nav-mobile a:hover{color:var(--gold)}
@media(max-width:768px){
  .nav-desktop{display:none}
  .menu-toggle{display:flex}
  .nav-mobile.open{display:block}
}

/* Hero */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--bg)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,hsla(20,10%,8%,.6),hsla(20,10%,8%,.8),var(--bg))}
.hero-content{position:relative;z-index:1;text-align:center;padding:8rem 1.5rem 4rem}
.hero-location{color:var(--gold);font-weight:600;letter-spacing:.3em;text-transform:uppercase;font-size:.875rem;margin-bottom:1.5rem}
.hero h1{font-size:clamp(3rem,8vw,6rem);font-weight:700;line-height:1.1;margin-bottom:1rem}
.hero-subtitle{font-family:var(--font-display);font-size:clamp(1.2rem,3vw,1.5rem);color:hsla(40,30%,92%,.8);font-style:italic;margin-bottom:1rem}
.hero-desc{color:var(--muted);max-width:640px;margin:0 auto 2.5rem;font-size:1.125rem}
.hero-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* Buttons */
.btn-gold{display:inline-block;background:linear-gradient(135deg,var(--gold),var(--gold-glow));color:var(--bg);font-weight:600;padding:1rem 2rem;border-radius:.5rem;box-shadow:0 0 40px -10px hsla(38,80%,55%,.3);transition:opacity .3s}
.btn-gold:hover{opacity:.9}
.btn-outline{display:inline-block;border:1px solid hsla(38,80%,55%,.3);color:var(--gold);font-weight:600;padding:1rem 2rem;border-radius:.5rem;transition:background .3s}
.btn-outline:hover{background:hsla(38,80%,55%,.1)}

/* Sections */
.section{padding:6rem 0}
.bg-card{background:var(--card)}
.bg-dark{background:linear-gradient(180deg,var(--bg),hsl(20,12%,6%))}
.section-header{max-width:800px;margin:0 auto 3rem;text-align:center}
.section-header h2{font-size:clamp(2rem,5vw,3rem);font-weight:700;margin-bottom:1.5rem}
.section-header p{color:hsla(40,30%,92%,.8);font-size:1.125rem;line-height:1.7}
.section-header .subtitle{color:var(--muted);max-width:600px;margin:0 auto}

/* Cards */
.cards-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;max-width:1000px;margin:0 auto}
.cards-4{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;max-width:1100px;margin:0 auto}
.card-item,.pillar-card,.step-card,.contact-card{background:var(--secondary);border:1px solid var(--border);border-radius:.75rem;padding:2rem;transition:border-color .3s}
.card-item:hover,.pillar-card:hover{border-color:hsla(38,80%,55%,.3)}
.card-icon{font-size:2rem;margin-bottom:1rem}
.card-item h3,.pillar-card h3{font-size:1.2rem;font-weight:600;margin-bottom:.75rem}
.card-item p,.pillar-card p{color:var(--muted);font-size:.95rem;line-height:1.6}

/* Pillar bar */
.pillar-card{position:relative;overflow:hidden}
.pillar-bar{position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-glow));transform:scaleX(0);transform-origin:left;transition:transform .4s}
.pillar-card:hover .pillar-bar{transform:scaleX(1)}

/* Steps */
.step-num{font-family:var(--font-display);font-size:2rem;font-weight:700;color:hsla(38,80%,55%,.3)}
.step-card p{margin-top:.75rem;font-weight:500}

/* Contact */
.contact-card{text-align:center;background:var(--card);border:1px solid var(--border);border-radius:.75rem;padding:1.5rem}
.contact-label{font-weight:600;margin-top:.25rem}
.contact-sub{color:var(--muted);font-size:.875rem;margin-top:.25rem}
.contact-link{color:var(--gold);font-size:.875rem;margin-top:.25rem;display:inline-block;transition:opacity .3s}
.contact-link:hover{text-decoration:underline;opacity:.85}

/* Footer */
#site-footer{background:var(--bg);border-top:1px solid var(--border);padding:2rem 0}
.footer-inner{text-align:center}
.footer-logo{font-family:var(--font-display);font-size:1.2rem;font-weight:700;background:linear-gradient(135deg,var(--gold),var(--gold-glow));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}
.footer-copy{color:var(--muted);font-size:.875rem}

/* Animations */
.fade-up{opacity:0;transform:translateY(30px);transition:opacity .7s,transform .7s}
.fade-up.visible{opacity:1;transform:translateY(0)}
