/* ============================================================
   HILL OF MERCY — SHARED STYLES (shared.css)
   Used by all pages: index, about, services, messages,
   connect, contact, give
   Purple: #7B2D8B  |  Orange: #F5A623  |  Dark: #0D0811
   ============================================================ */

:root {
  --purple:       #7B2D8B;
  --purple-dark:  #5A1F68;
  --purple-mid:   #6B2578;
  --purple-light: #A04DB5;
  --purple-glow:  rgba(123,45,139,0.25);
  --orange:       #F5A623;
  --orange-dark:  #C8851A;
  --orange-light: #FFB84D;
  --orange-glow:  rgba(245,166,35,0.2);
  --deep:         #0D0811;
  --deep2:        #130D1A;
  --card:         #1A1124;
  --card2:        #221633;
  --white:        #FFFFFF;
  --text-light:   #C5B8D4;
  --text-muted:   #7A6E88;
  --border:       rgba(123,45,139,0.18);
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family:'Montserrat',sans-serif;
  background:var(--deep);
  color:var(--white);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img { max-width:100%; display:block; }
a { color:inherit; }

/* ── SKIP LINK ── */
.skip-link {
  position:absolute; top:-50px; left:20px; z-index:9999;
  background:var(--purple); color:#fff; padding:10px 18px;
  font-size:13px; font-weight:600; text-decoration:none; border-radius:0 0 4px 4px;
  transition:top 0.3s;
}
.skip-link:focus { top:0; }

/* ════════════════════════════════
   NAV
════════════════════════════════ */
#navbar {
  position:fixed; top:0; left:0; right:0; z-index:900;
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 56px;
  transition:all 0.4s ease;
}
#navbar.scrolled {
  background:rgba(13,8,17,0.97);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  box-shadow:0 4px 32px rgba(0,0,0,0.5);
  padding:10px 56px;
}
/* On inner pages the nav is always dark */
#navbar.solid {
  background:rgba(13,8,17,0.97);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  padding:14px 56px;
}
.nav-logo { display:flex; align-items:center; text-decoration:none; }
.nav-logo img { height:50px; transition:height 0.4s; }
#navbar.scrolled .nav-logo img { height:40px; }

.nav-links { display:flex; align-items:center; gap:30px; }
.nav-links a {
  text-decoration:none; color:rgba(255,255,255,0.8);
  font-size:11px; font-weight:600; letter-spacing:1.8px; text-transform:uppercase;
  transition:color 0.3s; position:relative; padding-bottom:4px;
}
.nav-links a::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,var(--orange),var(--purple));
  transform:scaleX(0); transform-origin:left; transition:transform 0.3s;
  border-radius:2px;
}
.nav-links a:hover { color:var(--orange); }
.nav-links a:hover::after,
.nav-links a.active::after { transform:scaleX(1); }
.nav-links a.active { color:var(--orange); }
.nav-give {
  background:linear-gradient(135deg,var(--orange),var(--orange-dark)) !important;
  color:var(--white) !important;
  padding:9px 22px !important; border-radius:2px;
  box-shadow:0 4px 16px var(--orange-glow);
}
.nav-give::after { display:none !important; }
.nav-give:hover { transform:translateY(-1px); box-shadow:0 8px 24px var(--orange-glow) !important; }

/* Hamburger */
.nav-toggle {
  display:none; flex-direction:column; gap:5px; cursor:pointer;
  background:none; border:none; padding:4px;
}
.nav-toggle span {
  width:24px; height:2px; background:var(--white);
  border-radius:2px; transition:all 0.3s; display:block;
}
.nav-toggle.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.nav-toggle.open span:nth-child(2) { opacity:0; }
.nav-toggle.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* Mobile nav drawer */
.mobile-nav {
  display:none; position:fixed; top:0; left:0; right:0; bottom:0;
  background:rgba(13,8,17,0.99); z-index:800;
  flex-direction:column; align-items:center; justify-content:center; gap:32px;
}
.mobile-nav.open { display:flex; }
.mobile-nav a {
  font-size:22px; font-weight:300; letter-spacing:3px; text-transform:uppercase;
  text-decoration:none; color:var(--white); transition:color 0.3s;
  font-family:'Cormorant Garamond',serif;
}
.mobile-nav a:hover { color:var(--orange); }
.mobile-nav .mob-give {
  background:var(--orange); color:var(--deep) !important;
  padding:14px 40px; font-size:14px !important; font-weight:700 !important;
  font-family:'Montserrat',sans-serif !important; letter-spacing:2px;
}

/* ════════════════════════════════
   PAGE HERO BANNER (inner pages)
════════════════════════════════ */
.page-hero {
  min-height:380px; position:relative;
  display:flex; align-items:flex-end;
  background:linear-gradient(145deg,#0D0811 0%,#130D1A 55%,#1A1124 100%);
  overflow:hidden;
}
.page-hero-bg {
  position:absolute; inset:0;
  background:linear-gradient(145deg,#0D0811 0%,#130D1A 55%,#1A1124 100%);
}
.ph-arc-1 {
  position:absolute; width:700px; height:700px; border-radius:50%;
  border:1px solid rgba(123,45,139,0.12);
  bottom:-300px; left:-200px; pointer-events:none;
}
.ph-arc-2 {
  position:absolute; width:500px; height:500px; border-radius:50%;
  border:1px solid rgba(245,166,35,0.07);
  top:-200px; right:-180px; pointer-events:none;
}
.ph-glow {
  position:absolute; width:500px; height:500px;
  background:radial-gradient(circle,rgba(123,45,139,0.14) 0%,transparent 65%);
  top:0; right:0; pointer-events:none;
}
.ph-grid {
  position:absolute; inset:0; opacity:0.018;
  background-image:
    linear-gradient(rgba(245,166,35,1) 1px,transparent 1px),
    linear-gradient(90deg,rgba(245,166,35,1) 1px,transparent 1px);
  background-size:65px 65px;
}
.page-hero-inner {
  position:relative; z-index:2;
  max-width:1200px; width:100%; margin:0 auto;
  padding:130px 56px 60px;
}
.ph-breadcrumb {
  font-size:10px; font-weight:700; letter-spacing:3px;
  text-transform:uppercase; color:var(--orange);
  display:flex; align-items:center; gap:10px; margin-bottom:16px;
}
.ph-breadcrumb::before {
  content:''; width:28px; height:2px;
  background:linear-gradient(90deg,var(--orange),var(--purple)); border-radius:2px;
}
.ph-breadcrumb a { text-decoration:none; color:var(--text-muted); transition:color 0.3s; }
.ph-breadcrumb a:hover { color:var(--orange); }
.ph-breadcrumb span { color:var(--text-muted); }
h1.page-title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(42px,6vw,82px);
  font-weight:300; line-height:1.05;
}
.page-title .hl-p { color:var(--purple-light); font-style:italic; }
.page-title .hl-o { color:var(--orange); font-style:italic; }
.ph-sub {
  margin-top:16px; font-size:15px; font-weight:300;
  color:var(--text-muted); max-width:520px; line-height:1.75;
}
.ph-accent-line {
  position:absolute; bottom:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--purple-dark),var(--purple),var(--orange));
}

/* ════════════════════════════════
   BUTTONS
════════════════════════════════ */
.btn {
  display:inline-block; text-decoration:none;
  font-size:11px; font-weight:700; letter-spacing:2px; text-transform:uppercase;
  padding:15px 32px; cursor:pointer; border:none; font-family:'Montserrat',sans-serif;
  transition:all 0.3s;
}
.btn-purple {
  background:linear-gradient(135deg,var(--purple),var(--purple-dark));
  color:#fff; box-shadow:0 6px 20px rgba(123,45,139,0.4);
  clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px));
}
.btn-purple:hover { transform:translateY(-3px); box-shadow:0 12px 30px rgba(123,45,139,0.5); }
.btn-orange {
  background:linear-gradient(135deg,var(--orange),var(--orange-dark));
  color:#fff; box-shadow:0 6px 20px var(--orange-glow);
}
.btn-orange:hover { transform:translateY(-3px); box-shadow:0 12px 30px rgba(245,166,35,0.4); }
.btn-ghost {
  background:transparent; color:var(--white);
  border:1px solid rgba(255,255,255,0.22);
}
.btn-ghost:hover { border-color:var(--purple-light); color:var(--purple-light); }

/* ════════════════════════════════
   SHARED SECTION STYLES
════════════════════════════════ */
section { padding:96px 56px; }
.sec-inner { max-width:1200px; margin:0 auto; }
.sec-label {
  display:inline-flex; align-items:center; gap:12px;
  font-size:10px; font-weight:700; letter-spacing:4px; text-transform:uppercase;
  color:var(--orange); margin-bottom:16px;
}
.sec-label::before {
  content:''; width:34px; height:2px;
  background:linear-gradient(90deg,var(--orange),var(--purple)); border-radius:2px;
}
.sec-title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(32px,4vw,56px); font-weight:300; line-height:1.1; margin-bottom:14px;
}
.hl-p { color:var(--purple-light); font-style:italic; }
.hl-o { color:var(--orange); font-style:italic; }
.sec-sub { color:var(--text-muted); font-size:15px; font-weight:300; line-height:1.8; max-width:520px; margin-top:12px; }

/* ════════════════════════════════
   FOOTER
════════════════════════════════ */
footer {
  background:var(--deep);
  border-top:1px solid rgba(123,45,139,0.18);
  padding:60px 56px 32px;
  position:relative;
}
footer::before {
  content:''; display:block; height:3px;
  background:linear-gradient(90deg,var(--purple-dark),var(--purple),var(--orange),var(--orange-dark));
  position:absolute; top:0; left:0; right:0;
}
.footer-grid {
  max-width:1200px; margin:0 auto;
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:56px;
  padding-bottom:44px; border-bottom:1px solid rgba(255,255,255,0.05);
}
.ft-logo img { height:46px; margin-bottom:16px; filter:brightness(0) invert(1); }
.ft-tagline { color:var(--text-muted); font-size:13px; line-height:1.75; font-weight:300; max-width:260px; }
.ft-soc { display:flex; gap:10px; margin-top:22px; }
.ft-col h5 {
  font-size:10px; font-weight:700; letter-spacing:3px; text-transform:uppercase;
  color:var(--orange); margin-bottom:18px;
}
.ft-col ul { list-style:none; }
.ft-col li { margin-bottom:10px; }
.ft-col a { color:var(--text-muted); text-decoration:none; font-size:13px; font-weight:300; transition:color 0.3s; }
.ft-col a:hover { color:var(--white); }
.footer-btm {
  max-width:1200px; margin:28px auto 0;
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px;
}
.footer-btm p { font-size:12px; color:var(--text-muted); font-weight:300; }
.footer-btm a { color:var(--orange); text-decoration:none; }

/* Social buttons */
.soc-btn {
  width:42px; height:42px; border:1px solid rgba(255,255,255,0.1);
  display:flex; align-items:center; justify-content:center;
  color:var(--text-muted); font-size:12px; font-weight:700; text-decoration:none; transition:all 0.3s;
}
.soc-btn:hover { background:var(--purple); border-color:var(--purple); color:#fff; }

/* Scroll reveal */
.reveal {
  opacity:0; transform:translateY(22px);
  transition:opacity 0.65s ease, transform 0.65s ease;
}
.reveal.visible { opacity:1; transform:translateY(0); }

/* Accent bar */
.accent-bar { display:grid; grid-template-columns:repeat(4,1fr); }
.ab-block { padding:28px 20px; text-align:center; }
.ab-block:nth-child(1){ background:var(--purple-dark); }
.ab-block:nth-child(2){ background:var(--purple); }
.ab-block:nth-child(3){ background:var(--orange-dark); }
.ab-block:nth-child(4){ background:var(--orange); }
.ab-num { font-family:'Cormorant Garamond',serif; font-size:42px; font-weight:700; color:rgba(255,255,255,0.95); line-height:1; }
.ab-lbl { font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,0.72); margin-top:6px; }

/* Form elements (shared across contact/connect/give) */
.fg { margin-bottom:16px; }
.fg label { display:block; font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--text-muted); margin-bottom:7px; }
.fg input, .fg textarea, .fg select {
  width:100%; background:rgba(255,255,255,0.03);
  border:1px solid rgba(123,45,139,0.2); color:var(--white);
  padding:13px 15px; font-size:14px; font-weight:300;
  font-family:'Montserrat',sans-serif; outline:none;
  transition:border-color 0.3s; border-radius:1px;
}
.fg input:focus, .fg textarea:focus, .fg select:focus {
  border-color:var(--purple-light); background:rgba(123,45,139,0.05);
}
.fg select option { background:var(--card2); }
.fg textarea { min-height:116px; resize:vertical; }
.f-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.hp-field { opacity:0; position:absolute; top:0; left:0; height:0; width:0; z-index:-1; }
.form-note { font-size:11px; color:var(--text-muted); margin-top:10px; line-height:1.6; }

/* ════════════════════════════════
   RESPONSIVE
════════════════════════════════ */
@media(max-width:1024px){
  #navbar { padding:14px 28px; }
  #navbar.scrolled, #navbar.solid { padding:10px 28px; }
  section { padding:70px 28px; }
  .page-hero-inner { padding:120px 28px 50px; }
  footer { padding:56px 28px 28px; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:40px; }
}
@media(max-width:820px){
  .nav-links { display:none; }
  .nav-toggle { display:flex; }
  .accent-bar { grid-template-columns:repeat(2,1fr); }
  .f-row { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; gap:36px; }
  .footer-btm { flex-direction:column; text-align:center; }
}
@media(max-width:480px){
  .btn { width:100%; text-align:center; }
  .accent-bar { grid-template-columns:repeat(2,1fr); }
}

/* Print */
@media print {
  #navbar, .mobile-nav { display:none !important; }
  body { background:#fff; color:#000; }
  .sec-title, h1 { color:#000; }
}
