/* ============================================================
   Creeks Bend Golf Club — Shared Stylesheet
   Site by RadSites Co | radsitesco.com

   Common styles for all pages: reset, variables, typography,
   navigation, mobile menu, page heroes, reveal animations,
   footer, responsive breakpoints, skip-link, focus styles,
   back-to-top button, and active nav states.
   ============================================================ */

/* --- Reset & Variables --- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --forest:#0c1525;
  --forest-deep:#081020;
  --forest-card:#12203a;
  --forest-mid:#1a2d4d;
  --gold:#ffffff;
  --gold-light:#e8ecf2;
  --gold-muted:#6b7a94;
  --cream:#f0f2f6;
  --ivory:#fafbfd;
  --text-light:#c5cdd8;
  --text-mid:#8b95a8;
  --text-dim:#5e6a7e;
  --white:#ffffff;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'DM Sans','Helvetica Neue',Arial,sans-serif;
  --mono:'JetBrains Mono','Courier New',monospace;
}

html{scroll-behavior:smooth;overflow-x:hidden;overscroll-behavior-x:none}
body{font-family:var(--sans);background:var(--forest-deep);color:var(--cream);overflow-x:hidden;-webkit-font-smoothing:antialiased;touch-action:manipulation;position:relative}
h1,h2,h3,h4,h5,h6{margin:0;font-weight:inherit}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* --- Skip Navigation --- */
.skip-link{position:absolute;top:-100%;left:1rem;background:var(--gold);color:var(--forest-deep);padding:.75rem 1.5rem;font-size:.85rem;font-weight:600;letter-spacing:1px;text-decoration:none;z-index:9999;border-radius:0 0 4px 4px;transition:top .2s}
.skip-link:focus{top:0}

/* --- Focus Styles --- */
a:focus-visible,
button:focus-visible{outline:2px solid var(--gold);outline-offset:2px}

/* --- Navigation --- */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:.75rem 3rem;display:flex;justify-content:space-between;align-items:center;transition:all .4s;background:transparent}
nav.scrolled{background:rgba(8,16,32,.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:.5rem 3rem;box-shadow:0 2px 30px rgba(0,0,0,.3)}
.nav-logo{display:flex;align-items:center;gap:.75rem}
.nav-logo-img{height:36px;width:auto;transition:opacity .3s}
.nav-logo-text{font-family:var(--serif);font-size:1.8rem;font-weight:600;color:var(--cream);letter-spacing:.5px;line-height:1.1}
.nav-logo-sub{font-size:.7rem;letter-spacing:4px;text-transform:uppercase;color:var(--gold);font-family:var(--sans);font-weight:500}
.nav-links{display:flex;gap:2.25rem;align-items:center}
.nav-links a{font-size:.8rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-light);font-weight:500;transition:color .3s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--gold);transition:width .3s}
.nav-links a:hover{color:var(--cream)}
.nav-links a:hover::after{width:100%}
.nav-links a.active{color:var(--gold)}
.nav-links a.active::after{width:100%}
.nav-cta{background:var(--forest);color:var(--white);padding:.6rem 1.5rem;font-size:.75rem;letter-spacing:2px;text-transform:uppercase;font-weight:600;border:1px solid rgba(255,255,255,.3);cursor:pointer;transition:all .3s;font-family:var(--sans)}
.nav-cta:hover{background:var(--white);color:var(--forest);transform:translateY(-1px)}
.nav-cta::after{display:none !important}

/* --- Hamburger --- */
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;z-index:1001}
.hamburger span{width:24px;height:1.5px;background:var(--cream);transition:all .3s}
.hamburger.open span:first-child{transform:rotate(45deg) translate(5px,4px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:last-child{transform:rotate(-45deg) translate(5px,-4px)}

/* --- Mobile Menu --- */
.mobile-menu{display:none;position:fixed;inset:0;background:rgba(8,16,32,.98);backdrop-filter:blur(20px);z-index:999;flex-direction:column;justify-content:center;align-items:center;gap:2rem;opacity:0;pointer-events:none;transition:opacity .4s;padding-top:100px}
.mobile-menu.open{opacity:1;pointer-events:all}
.mobile-menu a{font-family:var(--serif);font-size:2rem;color:var(--cream);font-weight:400;transition:color .3s;letter-spacing:1px}
.mobile-menu a:hover{color:var(--gold)}
.mobile-menu .mobile-cta{margin-top:1rem;background:var(--white);color:#081020 !important;padding:1rem 2.5rem;font-size:.8rem;letter-spacing:2px;text-transform:uppercase;font-weight:600;font-family:var(--sans);border:2px solid var(--white);box-shadow:0 0 25px rgba(255,255,255,.2);border-radius:2px}

/* --- Page Hero (subpages) --- */
.page-hero{position:relative;height:55vh;min-height:400px;display:flex;align-items:flex-end;overflow:hidden}
.page-hero-placeholder{position:absolute;inset:0;background:linear-gradient(135deg,#12203a 0%,#081020 40%,#0f1a30 70%,#12203a 100%)}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(8,16,32,.95) 0%,rgba(8,16,32,.3) 40%,rgba(8,16,32,.15) 100%)}
.page-hero-content{position:relative;z-index:2;padding:0 5rem 4rem;animation:fadeUp 1s ease-out .2s both}
.page-hero .hero-est{font-size:.7rem;letter-spacing:5px;text-transform:uppercase;color:var(--gold);margin-bottom:.75rem;font-weight:500;display:flex;align-items:center;gap:1rem}
.page-hero .hero-est::before,.page-hero .hero-est::after{content:'';width:25px;height:1px;background:var(--gold-muted)}
.page-hero h1{font-family:var(--serif);font-size:clamp(2.5rem,5vw,4rem);font-weight:600;line-height:1.1;color:var(--white);margin-bottom:.75rem}
.page-hero h1 em{font-style:italic;font-weight:300;color:var(--gold-light)}
.page-hero p{font-size:1rem;font-weight:300;color:var(--text-light);line-height:1.7;max-width:560px}

/* --- Sections Common --- */
.section{padding:5rem 3rem}
.section-inner{max-width:1200px;margin:0 auto}
.section-tag{font-size:.7rem;letter-spacing:4px;text-transform:uppercase;color:var(--gold);font-weight:500;margin-bottom:1rem}
.section-title{font-family:var(--serif);font-size:clamp(2rem,4vw,3rem);font-weight:500;line-height:1.15;color:var(--cream);margin-bottom:1.5rem}
.section-title em{font-style:italic;font-weight:300;color:var(--gold-light)}
.section-desc{font-size:1rem;font-weight:300;color:var(--text-light);line-height:1.75;max-width:600px}

/* --- Buttons --- */
.btn-primary{background:var(--gold);color:var(--forest-deep);padding:.85rem 2.25rem;font-size:.75rem;letter-spacing:2.5px;text-transform:uppercase;font-weight:600;border:none;cursor:pointer;transition:all .3s;font-family:var(--sans);display:inline-block}
.btn-primary:hover{background:var(--gold-light);transform:translateY(-2px);box-shadow:0 8px 25px rgba(255,255,255,.15)}
.btn-outline{border:1px solid rgba(255,255,255,.35);color:var(--cream);padding:.85rem 2.25rem;font-size:.75rem;letter-spacing:2.5px;text-transform:uppercase;font-weight:500;cursor:pointer;transition:all .3s;font-family:var(--sans);display:inline-block;background:rgba(255,255,255,.05)}
.btn-outline:hover{border-color:var(--white);color:var(--white);background:rgba(255,255,255,.12)}

/* --- Scroll Reveal --- */
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* --- Placeholder Label --- */
.placeholder-label{font-size:.65rem;letter-spacing:3px;text-transform:uppercase;color:var(--text-dim);font-weight:500}

/* --- CTA Band --- */
.cta-band{background:var(--forest-card);border-top:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.1);padding:4rem 3rem;text-align:center}
.cta-band .section-title{margin-bottom:1.5rem}

/* --- Footer --- */
footer{background:var(--forest-deep);border-top:1px solid rgba(255,255,255,.1);padding:4rem 3rem 2rem}
.footer-inner{max-width:1200px;margin:0 auto}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-brand{display:flex;flex-direction:column;gap:0}
.footer-logo{width:40px;height:auto;margin-bottom:.75rem;opacity:.7}
.footer-brand p{font-size:.85rem;color:var(--text-mid);line-height:1.7;margin-top:1rem;max-width:300px}
.footer-col h4{font-size:.7rem;letter-spacing:3px;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:1.25rem}
.footer-col a{display:block;font-size:.85rem;color:var(--text-light);margin-bottom:.6rem;transition:color .3s}
.footer-col a:hover{color:var(--gold)}
.footer-col p{font-size:.85rem;color:var(--text-mid);line-height:1.7}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-bottom p{font-size:.75rem;color:var(--text-dim);letter-spacing:.5px}
.footer-bottom a{color:var(--gold-muted);transition:color .3s}
.footer-bottom a:hover{color:var(--gold)}

/* --- Back to Top --- */
.back-top{position:fixed;bottom:2rem;right:2rem;width:44px;height:44px;background:var(--gold);color:var(--forest-deep);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;opacity:0;pointer-events:none;transition:all .3s;z-index:100}
.back-top.visible{opacity:1;pointer-events:all}
.back-top:hover{background:var(--gold-light);transform:translateY(-3px)}

/* --- Coming Soon Page Content --- */
.coming-soon{min-height:40vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:3rem}
.coming-soon p{font-size:1rem;color:var(--text-mid);font-weight:300;margin-top:1rem;max-width:400px;line-height:1.7}

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  nav{padding:.5rem 1rem}
  nav.scrolled{padding:.4rem 1rem}
  nav .nav-logo img{height:40px !important}
  .nav-logo-text{font-size:1.1rem !important}
  .nav-logo-sub{font-size:.5rem !important;letter-spacing:3px !important}
  .nav-links{display:none}
  .hamburger{display:flex;z-index:1002;padding:12px;margin-right:-12px}
  .mobile-menu{display:flex}
  .page-hero-content{padding:0 1.5rem 3rem}
  .section{padding:3.5rem 1.5rem}
  .cta-band{padding:3rem 1.5rem}
  footer{padding:3rem 1.5rem 1.5rem}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .footer-bottom{flex-direction:column;text-align:center}
}
