/* ============================================
   THE WEST COAST GENTLEMAN — Global Styles
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Inter:wght@300;400;500;600&display=swap');

/* ── Tokens ── */
:root {
  --bg:       #F8F7F4;
  --bg-alt:   #F0EFE9;
  --surface:  #FFFFFF;
  --border:   rgba(0,0,0,0.09);
  --text:     #111111;
  --muted:    #727272;
  --subtle:   #AAAAAA;
  --gold:     #B8973E;
  --gold-dim: rgba(184,151,62,0.12);
  --nav-bg:   rgba(248,247,244,0.92);
  --nav-h:    64px;
  --radius:   0px;
  --ease:     cubic-bezier(.4,0,.2,1);
  --t:        .28s;
  --shadow:   0 8px 32px rgba(0,0,0,0.07);
  --shadow-lg:0 20px 56px rgba(0,0,0,0.1);
}
[data-theme="dark"] {
  --bg:       #0E0E0E;
  --bg-alt:   #161616;
  --surface:  #1A1A1A;
  --border:   rgba(255,255,255,0.08);
  --text:     #EFEFEF;
  --muted:    #888888;
  --subtle:   #444444;
  --gold:     #C9A84C;
  --gold-dim: rgba(201,168,76,0.1);
  --nav-bg:   rgba(14,14,14,0.93);
  --shadow:   0 8px 32px rgba(0,0,0,0.35);
  --shadow-lg:0 20px 56px rgba(0,0,0,0.5);
}

/* ── Reset ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0 }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100% }
body {
  font-family:'Inter',system-ui,sans-serif;
  background:var(--bg); color:var(--text);
  line-height:1.65; font-size:16px;
  overflow-x:hidden;
  transition:background var(--t) var(--ease), color var(--t) var(--ease);
}
img { display:block; width:100%; height:auto }
a   { color:inherit; text-decoration:none }
ul  { list-style:none }
button { cursor:pointer; border:none; background:none; font-family:inherit; color:inherit }

/* ── Typography ── */
h1,h2,h3,h4 {
  font-family:'Playfair Display',Georgia,serif;
  line-height:1.15; letter-spacing:-.015em;
}
h1 { font-size:clamp(2.5rem,5vw,4.8rem); font-weight:700 }
h2 { font-size:clamp(1.8rem,3.2vw,3rem); font-weight:600 }
h3 { font-size:clamp(1.15rem,1.8vw,1.5rem); font-weight:600 }
h4 { font-size:.68rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; font-family:'Inter',sans-serif }

p   { font-size:.97rem; line-height:1.78; color:var(--muted) }
p+p { margin-top:.85rem }

/* Eyebrow label */
.eyebrow {
  display:inline-block;
  font-family:'Inter',sans-serif;
  font-size:.65rem; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold);
}

/* Gold rule */
.divider-gold {
  width:32px; height:1px;
  background:var(--gold);
  display:block; margin:1rem 0 1.5rem;
}

/* ── Layout ── */
.container       { max-width:1180px; margin:0 auto; padding:0 clamp(1.25rem,4vw,3rem) }
.container--wide { max-width:1440px; margin:0 auto; padding:0 clamp(1.25rem,4vw,4rem) }
.section         { padding:clamp(4rem,8vw,7rem) 0 }

/* ── Section header ── */
.section-header { margin-bottom:2.5rem }
.section-header--center { text-align:center }
.section-header--center .divider-gold { margin-left:auto; margin-right:auto }
.section-header h2 { margin:.35rem 0 .75rem }
.section-header p  { max-width:460px }
.section-header--center p { margin-left:auto; margin-right:auto }

/* ── Buttons ── */
.btn {
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:'Inter',sans-serif;
  font-size:.7rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase;
  padding:.72rem 1.9rem;
  border:1px solid transparent;
  transition:all var(--t) var(--ease);
  white-space:nowrap;
}
.btn--primary {
  background:var(--text); color:var(--bg); border-color:var(--text);
}
.btn--primary:hover {
  background:var(--gold); border-color:var(--gold); color:#fff;
  transform:translateY(-1px); box-shadow:0 6px 20px rgba(184,151,62,.3);
}
.btn--outline {
  background:transparent; color:var(--text); border-color:var(--border);
}
.btn--outline:hover { border-color:var(--text) }
.btn--ghost {
  background:transparent; color:var(--gold); border-color:var(--gold);
  padding:.65rem 1.6rem;
}
.btn--ghost:hover { background:var(--gold); color:#fff }

/* ── Navigation ── */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:900;
  height:var(--nav-h);
  background:var(--nav-bg);
  backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid var(--border);
  transition:background var(--t),border-color var(--t);
}
.nav__inner {
  max-width:1440px; margin:0 auto;
  padding:0 clamp(1.25rem,4vw,4rem);
  height:100%;
  display:flex; align-items:center; justify-content:space-between; gap:2rem;
}
.nav__logo {
  font-family:'Playfair Display',serif;
  font-size:1rem; font-weight:600; letter-spacing:.01em;
  color:var(--text); flex-shrink:0;
}
.nav__logo span { color:var(--gold) }

.nav__links {
  display:flex; align-items:center; gap:2.5rem;
}
.nav__links a {
  font-size:.68rem; font-weight:500; letter-spacing:.14em; text-transform:uppercase;
  color:var(--muted); transition:color var(--t);
  position:relative;
}
.nav__links a::after {
  content:''; position:absolute; bottom:-3px; left:0; right:100%;
  height:1px; background:var(--gold);
  transition:right var(--t) var(--ease);
}
.nav__links a:hover,
.nav__links a.active { color:var(--text) }
.nav__links a:hover::after,
.nav__links a.active::after { right:0 }

.nav__actions { display:flex; align-items:center; gap:.6rem }

/* Theme toggle — SVG icon, no emoji */
.theme-toggle {
  width:34px; height:34px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--border); color:var(--muted);
  transition:all var(--t);
  font-size:.9rem; line-height:1;
}
.theme-toggle:hover { border-color:var(--text); color:var(--text) }

/* Hamburger */
.nav__hamburger {
  display:none; flex-direction:column; gap:5px;
  width:24px; padding:3px 0;
}
.nav__hamburger span {
  display:block; height:1.5px; background:var(--text);
  transition:all var(--t) var(--ease); transform-origin:center;
}
.nav__hamburger.open span:nth-child(1) { transform:translateY(6.5px) rotate(45deg) }
.nav__hamburger.open span:nth-child(2) { opacity:0; transform:scaleX(0) }
.nav__hamburger.open span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg) }

/* Mobile drawer */
.nav__mobile {
  display:none; position:fixed; inset:0; top:var(--nav-h); z-index:850;
  background:var(--bg);
  flex-direction:column; align-items:center; justify-content:center; gap:2rem;
}
.nav__mobile.open { display:flex }
.nav__mobile a {
  font-family:'Playfair Display',serif;
  font-size:2rem; font-weight:600; color:var(--muted);
  transition:color var(--t);
}
.nav__mobile a:hover { color:var(--gold) }

/* ── Page hero (inner pages) ── */
.page-hero {
  min-height:50vh; display:flex; align-items:flex-end;
  position:relative; overflow:hidden;
  padding:calc(var(--nav-h) + 4rem) 0 4rem;
}
.page-hero__bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  filter:brightness(.35);
}
.page-hero__content { position:relative; z-index:1; color:#fff }
.page-hero__content .eyebrow { color:rgba(201,168,76,.85) }
.page-hero__content h1 { color:#fff; margin:.6rem 0 .4rem }
.page-hero__content p { color:rgba(255,255,255,.6); font-size:.95rem; max-width:480px }

/* ── Cards ── */
.card {
  background:var(--surface); border:1px solid var(--border);
  overflow:hidden;
  transition:border-color var(--t), transform var(--t), box-shadow var(--t);
}
.card:hover { border-color:rgba(0,0,0,.18); transform:translateY(-4px); box-shadow:var(--shadow-lg) }
[data-theme="dark"] .card:hover { border-color:rgba(255,255,255,.14) }
.card__image { overflow:hidden; aspect-ratio:4/3 }
.card__image img { width:100%; height:100%; object-fit:cover; transition:transform .65s var(--ease) }
.card:hover .card__image img { transform:scale(1.05) }
.card__body { padding:1.4rem }
.card__body .eyebrow { margin-bottom:.4rem }
.card__body h3 { margin:.2rem 0 .5rem }
.card__body p { font-size:.88rem }

/* ── Forms ── */
.form-group { margin-bottom:1.1rem }
.form-group label {
  display:block; font-size:.65rem; font-weight:600;
  letter-spacing:.16em; text-transform:uppercase;
  color:var(--muted); margin-bottom:.4rem;
}
.form-group input,
.form-group select,
.form-group textarea {
  width:100%; padding:.72rem .95rem;
  background:var(--surface); border:1px solid var(--border);
  color:var(--text); font-family:'Inter',sans-serif; font-size:.95rem;
  outline:none; transition:border-color var(--t);
  -webkit-appearance:none; border-radius:0;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { border-color:var(--gold) }
.form-group textarea { resize:vertical; min-height:130px }
.form-group select {
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6' fill='none' stroke='%23888' stroke-width='1.5'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right .9rem center;
  padding-right:2.5rem;
}

/* ── Footer ── */
footer {
  background:var(--bg-alt);
  border-top:1px solid var(--border);
  padding:4rem 0 2rem;
}
.footer__grid {
  display:grid; grid-template-columns:1.6fr repeat(3,1fr);
  gap:3rem; margin-bottom:2.5rem;
  padding-bottom:2.5rem; border-bottom:1px solid var(--border);
}
.footer__brand .nav__logo { margin-bottom:.75rem }
.footer__brand p { font-size:.87rem; max-width:260px }
.footer__col h4 { margin-bottom:1rem }
.footer__col li+li { margin-top:.55rem }
.footer__col a { font-size:.87rem; color:var(--muted); transition:color var(--t) }
.footer__col a:hover { color:var(--gold) }
.footer__bottom {
  display:flex; justify-content:space-between; align-items:center;
  font-size:.77rem; color:var(--muted);
}
.footer__social { display:flex; gap:.5rem }
.footer__social a {
  width:30px; height:30px; border:1px solid var(--border); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:.6rem; font-weight:700;
  color:var(--muted); transition:all var(--t);
}
.footer__social a:hover { border-color:var(--gold); color:var(--gold) }

/* ── Scroll-to-top ── */
.scroll-top {
  position:fixed; bottom:1.75rem; right:1.75rem; z-index:800;
  width:38px; height:38px; border-radius:50%;
  background:var(--text); color:var(--bg);
  display:flex; align-items:center; justify-content:center;
  font-size:.85rem; font-weight:600;
  opacity:0; pointer-events:none;
  transition:opacity var(--t), transform var(--t), background var(--t);
  transform:translateY(8px);
}
.scroll-top.visible { opacity:1; pointer-events:auto; transform:translateY(0) }
.scroll-top:hover { background:var(--gold); color:#fff }

/* ── Scroll reveal ── */
[data-reveal] {
  opacity:0; transform:translateY(18px);
  transition:opacity .6s var(--ease), transform .6s var(--ease);
}
[data-reveal].revealed { opacity:1; transform:none }

/* ── Fade-up animation ── */
@keyframes fadeUp { from { opacity:0; transform:translateY(20px) } to { opacity:1; transform:none } }
.animate-up { animation:fadeUp .65s var(--ease) both }
.delay-1 { animation-delay:.12s }
.delay-2 { animation-delay:.24s }
.delay-3 { animation-delay:.36s }
.delay-4 { animation-delay:.48s }

/* ── Responsive ── */
@media (max-width:900px) {
  .footer__grid { grid-template-columns:1fr 1fr; gap:2rem }
}
@media (max-width:700px) {
  .nav__links { display:none }
  .nav__hamburger { display:flex }
  .footer__grid { grid-template-columns:1fr }
  .footer__bottom { flex-direction:column; gap:.75rem; text-align:center }
}
@media (max-width:480px) {
  :root { --nav-h:58px }
}
