/* ═══════════════════════════════════════════════════════════
   The Journal Tapping Method — Shared Styles
   Brand colours: Navy #192e4b · Gold #bda070
   Fonts: Playfair Display (serif) · Nunito (sans)
═══════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;1,400&family=Nunito:wght@300;400;600;700&display=swap');

:root {
  --navy:      #192e4b;
  --navy-deep: #0f1e30;
  --navy-mid:  #1e3a5f;
  --gold:      #bda070;
  --gold-lt:   #d4b98a;
  --gold-pale: #f0e6d3;
  --gold-faint:#faf5ec;
  --sage:      #4a7c63;
  --sage-pale: #e8f3ee;
  --paper:     #faf7f2;
  --white:     #fff;
  --ink:       #1a2535;
  --ink-mid:   #364152;
  --ink-soft:  #5e6e82;
  --ink-ghost: #8e9aaa;
  --border:    rgba(25,46,75,0.10);
  --border-gold: rgba(189,160,112,0.30);
  --danger:    #b94040;
  --success:   #2d7a4f;
  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 20px;
  --radius-xl: 32px;
  --shadow-sm: 0 2px 12px rgba(25,46,75,0.08);
  --shadow-md: 0 6px 28px rgba(25,46,75,0.12);
  --shadow-lg: 0 16px 56px rgba(25,46,75,0.16);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }

html { scroll-behavior: smooth; }

body {
  font-family: Nunito, sans-serif;
  background: var(--paper);
  color: var(--ink);
  line-height: 1.7;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
}

/* ── Typography ── */
.serif   { font-family: 'Playfair Display', serif; }
h1,h2,h3,h4 { font-family: 'Playfair Display', serif; line-height: 1.2; color: var(--navy); }

/* ── Layout ── */
.container { max-width: 1080px; margin: 0 auto; padding: 0 24px; }
.container-sm { max-width: 720px; margin: 0 auto; padding: 0 24px; }

/* ── Nav ── */
.site-nav {
  background: var(--navy-deep);
  padding: 0 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 68px;
  position: sticky;
  top: 0;
  z-index: 1000;
  border-bottom: 1px solid rgba(189,160,112,0.12);
}
.nav-brand { display:flex; align-items:center; gap:12px; text-decoration:none; }
.nav-logo-box {
  width:40px; height:40px; border-radius:10px;
  background:var(--navy); border:1.5px solid var(--border-gold);
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
}
.nav-brand-name { font-family:'Playfair Display',serif; font-size:17px; color:var(--white); line-height:1.2; }
.nav-brand-sub  { font-size:10px; color:rgba(255,255,255,0.35); letter-spacing:.07em; text-transform:uppercase; }
.nav-links { display:flex; align-items:center; gap:4px; }
.nav-link {
  font-size:14px; color:rgba(255,255,255,0.55); text-decoration:none;
  font-weight:600; padding:8px 14px; border-radius:100px;
  transition:color .15s, background .15s;
}
.nav-link:hover { color:var(--gold); }
.nav-link.active { color:var(--gold); }
.nav-cta {
  background:var(--gold); color:var(--white); padding:9px 22px;
  border-radius:100px; font-weight:700; font-size:14px;
  text-decoration:none; transition:opacity .15s; white-space:nowrap;
}
.nav-cta:hover { opacity:.88; }
.nav-menu-btn { display:none; background:none; border:none; color:rgba(255,255,255,.6); font-size:22px; cursor:pointer; }
.mobile-menu { display:none; background:var(--navy-deep); border-top:1px solid rgba(255,255,255,.06); padding:12px 0 20px; }
.mobile-menu a { display:block; padding:12px 28px; color:rgba(255,255,255,.6); text-decoration:none; font-size:15px; font-weight:600; }
.mobile-menu a:hover { color:var(--gold); }
.mobile-menu .mobile-cta { margin:12px 28px 0; background:var(--gold); color:white; padding:12px; border-radius:100px; text-align:center; }

/* ── Buttons ── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  border:none; border-radius:100px; font-family:Nunito,sans-serif;
  font-weight:700; cursor:pointer; transition:opacity .15s, transform .12s;
  text-decoration:none; white-space:nowrap;
}
.btn:hover { opacity:.88; transform:translateY(-1px); }
.btn:active { transform:translateY(0); }
.btn-gold   { background:var(--gold); color:var(--white); padding:14px 32px; font-size:15px; }
.btn-navy   { background:var(--navy); color:var(--white); padding:14px 32px; font-size:15px; }
.btn-sage   { background:var(--sage); color:var(--white); padding:14px 32px; font-size:15px; }
.btn-outline{ background:transparent; border:1.5px solid var(--border-gold); color:var(--gold); padding:12px 28px; font-size:14px; }
.btn-lg     { padding:16px 40px; font-size:16px; }
.btn-sm     { padding:9px 20px; font-size:13px; }

/* ── Cards ── */
.card {
  background:var(--white); border-radius:var(--radius-lg);
  border:1px solid var(--border); overflow:hidden;
  box-shadow:var(--shadow-sm);
}

/* ── Eyebrow label ── */
.eyebrow {
  font-size:11px; letter-spacing:.13em; text-transform:uppercase;
  color:var(--gold); font-weight:700; margin-bottom:12px;
}

/* ── Section divider ── */
.section-divider {
  width:60px; height:2px; background:var(--gold); border-radius:2px;
  margin:0 auto 24px; opacity:.5;
}

/* ── Footer ── */
.site-footer {
  background:var(--navy-deep);
  padding:56px 0 32px;
  border-top:1px solid rgba(189,160,112,0.12);
}
.footer-grid {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr;
  gap:40px; margin-bottom:48px;
}
.footer-brand-name { font-family:'Playfair Display',serif; font-size:19px; color:var(--white); margin-bottom:4px; }
.footer-slogan { font-size:12px; color:var(--gold); letter-spacing:.08em; font-weight:600; text-transform:uppercase; margin-bottom:14px; }
.footer-desc { font-size:13.5px; color:rgba(255,255,255,0.42); line-height:1.75; max-width:280px; }
.footer-col-title { font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,0.3); font-weight:700; margin-bottom:14px; }
.footer-links { display:flex; flex-direction:column; gap:8px; }
.footer-link { font-size:14px; color:rgba(255,255,255,0.5); text-decoration:none; transition:color .15s; }
.footer-link:hover { color:var(--gold); }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.06); padding-top:24px; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; }
.footer-copy { font-size:12.5px; color:rgba(255,255,255,0.25); }
.footer-legal { display:flex; gap:20px; }
.footer-legal a { font-size:12.5px; color:rgba(255,255,255,0.25); text-decoration:none; }
.footer-legal a:hover { color:rgba(255,255,255,0.5); }
.footer-crisis { background:rgba(189,160,112,0.06); border:1px solid rgba(189,160,112,0.15); border-radius:var(--radius-md); padding:14px 18px; margin-bottom:32px; font-size:12.5px; color:rgba(255,255,255,0.4); line-height:1.7; text-align:center; }

/* ── Responsive ── */
@media(max-width:900px) {
  .footer-grid { grid-template-columns:1fr 1fr; gap:28px; }
}
@media(max-width:640px) {
  .site-nav { padding:0 18px; }
  .nav-links,.nav-cta { display:none; }
  .nav-menu-btn { display:block; }
  .footer-grid { grid-template-columns:1fr; gap:24px; }
  .footer-bottom { flex-direction:column; text-align:center; }
}
