/* ============================================================
   HUDSON VALUATION GROUP — styles.css — Gold & Ink Theme
   ============================================================ */

:root, html { color-scheme: light only; }

:root {
  --accent: #b8965a;
  --accent-light: #f5f0e8;
  --accent-pale: #faf7f2;
  --accent-dark: #8a6e3e;
  --ink: #1c1c1e;
  --charcoal: #3a3a3c;
  --muted: #6e6e73;
  --border: #e8e2d8;
  --bg: #faf8f4;
  --white: #ffffff;
  --shadow: 0 2px 20px rgba(0,0,0,0.06);
  --radius: 10px;
  --font-serif: 'Georgia','Times New Roman',serif;
  --font-sans: 'Helvetica Neue',Arial,sans-serif;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { background:var(--bg); color:var(--ink); font-family:var(--font-sans); font-size:16px; line-height:1.7; }

h1,h2,h3 { font-family:var(--font-serif); font-weight:normal; line-height:1.25; color:var(--ink); }
h1 { font-size:clamp(2.2rem,4vw,3.6rem); margin-bottom:1rem; }
h2 { font-size:clamp(1.4rem,2.5vw,2rem); margin-bottom:0.75rem; }
h3 { font-size:1.1rem; margin-bottom:0.5rem; }
p { color:var(--charcoal); margin-bottom:1rem; }
a { color:var(--accent); text-decoration:none; }
a:hover { text-decoration:underline; }

.container { max-width:1100px; margin:0 auto; padding:0 2rem; }
section { padding:5rem 0; }

/* NAV */
nav {
  background:var(--white);
  border-bottom:1px solid var(--border);
  position:sticky; top:0; z-index:100;
  padding:1.2rem 0;
}
.nav-inner {
  display:flex; align-items:center; justify-content:space-between;
  max-width:1100px; margin:0 auto; padding:0 2rem;
}
.nav-logo {
  font-family:var(--font-serif);
  font-size:1.4rem;
  color:var(--ink);
  text-decoration:none;
  letter-spacing:0.01em;
}
.nav-logo span { color:var(--accent); }
.nav-links { display:flex; gap:2rem; list-style:none; align-items:center; }
.nav-links a { font-size:0.88rem; color:var(--charcoal); text-decoration:none; transition:color 0.2s; }
.nav-links a:hover { color:var(--accent); }
.nav-links .nav-cta {
  background:var(--accent); color:var(--white);
  padding:0.6rem 1.4rem; border-radius:6px;
  font-size:0.85rem; transition:background 0.2s;
}
.nav-links .nav-cta:hover { background:var(--accent-dark); text-decoration:none; }

/* HERO — MBS Capital style */
.hero {
  display:grid; grid-template-columns:1fr 1fr;
  height:580px; align-items:stretch;
}
.hero-photo {
  position:relative; overflow:hidden;
  background:#e8e4dc;
}
.hero-photo img {
  width:100%; height:100%;
  object-fit:cover; object-position:center 10%;
  display:block;
}
.hero-text {
  display:flex; flex-direction:column; justify-content:center;
  padding:5rem 4rem 5rem 5rem;
  background:var(--accent-pale);
}
.hero-brand { font-family:var(--font-serif); font-size:1rem; color:var(--ink); letter-spacing:0.08em; margin-bottom:0.3rem; }
.hero-rule { width:3rem; height:1px; background:var(--accent); margin-bottom:1.5rem; margin-top:0.5rem; }
.hero-tagline { font-family:var(--font-serif); font-style:italic; color:var(--accent); font-size:1rem; margin-bottom:1.5rem; display:block; }
.hero-text h1 { font-size:clamp(2rem,3.5vw,3.5rem); margin-bottom:0.5rem; line-height:1.1; }
.hero-text p { font-size:0.95rem; color:var(--muted); margin-bottom:2rem; max-width:420px; line-height:1.8; }
.hero-actions { display:flex; gap:1rem; flex-wrap:wrap; }

/* BUTTONS */
.btn { display:inline-block; padding:0.8rem 1.8rem; border-radius:7px; font-size:0.9rem; font-weight:500; cursor:pointer; transition:all 0.2s; text-decoration:none; border:none; }
.btn-primary { background:var(--accent); color:var(--white); }
.btn-primary:hover { background:var(--accent-dark); text-decoration:none; }
.btn-outline { background:transparent; color:var(--accent); border:1.5px solid var(--accent); }
.btn-outline:hover { background:var(--accent-light); text-decoration:none; }
.btn-white { background:var(--white); color:var(--accent); }
.btn-white:hover { opacity:0.9; text-decoration:none; }

/* CRED BAR */
.cred-bar { background:var(--white); border-top:1px solid var(--border); border-bottom:1px solid var(--border); padding:1.5rem 0; }
.cred-bar-inner { display:flex; flex-wrap:wrap; gap:2rem; align-items:center; justify-content:center; text-align:center; max-width:1100px; margin:0 auto; padding:0 2rem; }
.cred-item strong { display:block; font-size:0.95rem; color:var(--ink); }
.cred-item span { font-size:0.72rem; color:var(--muted); text-transform:uppercase; letter-spacing:0.1em; }
.cred-sep { color:var(--border); font-size:1.5rem; }

/* SECTION LABELS */
.section-label { font-size:0.72rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--accent); margin-bottom:0.75rem; display:block; }

/* SERVICES GRID */
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:3rem; }
.service-card {
  background:var(--white); border:1px solid var(--border);
  border-top:3px solid var(--accent);
  border-radius:var(--radius); padding:2rem;
  box-shadow:var(--shadow); transition:transform 0.2s,box-shadow 0.2s;
  text-decoration:none; color:inherit; display:block;
}
.service-card:hover { transform:translateY(-3px); box-shadow:0 6px 24px rgba(0,0,0,0.1); text-decoration:none; }
.service-card h3 { color:var(--ink); margin-bottom:0.5rem; }
.service-card p { font-size:0.88rem; color:var(--muted); margin:0; }
.service-icon { font-size:1.3rem; margin-bottom:0.75rem; }

/* WHO GRID */
.who-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; margin-top:2.5rem; }
.who-card { padding:2rem; background:var(--white); border-radius:var(--radius); border-top:3px solid var(--accent); box-shadow:var(--shadow); }
.who-card h3 { color:var(--accent); margin-bottom:0.5rem; }
.who-card p { font-size:0.88rem; color:var(--charcoal); margin:0; }

/* CTA BANNER */
.cta-banner { background:var(--ink); border-radius:var(--radius); padding:4rem; text-align:center; }
.cta-banner h2 { color:var(--white); margin-bottom:0.75rem; }
.cta-banner p { color:rgba(255,255,255,0.65); margin-bottom:2rem; }

/* PAGE HERO */
.page-hero { padding:4rem 0 3rem; border-bottom:1px solid var(--border); background:var(--white); }
.page-hero h1 { margin-bottom:0.75rem; }
.page-hero .lead { font-size:1.05rem; color:var(--muted); max-width:600px; }

/* CONTENT LAYOUT */
.content-layout { display:grid; grid-template-columns:1fr 320px; gap:4rem; padding-top:3rem; }
.content-main h2 { margin-top:2.5rem; }
.content-main ul { padding-left:1.4rem; margin-bottom:1rem; }
.content-main li { margin-bottom:0.4rem; color:var(--charcoal); }

/* SIDEBAR */
.sidebar-card { background:var(--white); border:1px solid var(--border); border-top:3px solid var(--accent); border-radius:var(--radius); padding:1.75rem; box-shadow:var(--shadow); margin-bottom:1.5rem; position:sticky; top:90px; }
.sidebar-card h3 { font-size:1rem; margin-bottom:1rem; color:var(--accent); }
.sidebar-card p { font-size:0.88rem; margin-bottom:0.5rem; color:var(--charcoal); }
.sidebar-card a { color:var(--accent); font-size:0.88rem; }
.related-links { list-style:none; padding:0; }
.related-links li { padding:0.5rem 0; border-bottom:1px solid var(--border); }
.related-links li:last-child { border-bottom:none; }
.related-links a { font-size:0.88rem; color:var(--accent); }

/* CONTACT */
.contact-layout { display:grid; grid-template-columns:1fr 340px; gap:4rem; }
.form-group { margin-bottom:1.4rem; }
.form-group label { display:block; font-size:0.88rem; font-weight:500; margin-bottom:0.4rem; color:var(--charcoal); }
.form-group input,.form-group select,.form-group textarea { width:100%; padding:0.75rem 1rem; border:1.5px solid var(--border); border-radius:7px; font-family:var(--font-sans); font-size:0.92rem; color:var(--ink); background:var(--white); transition:border-color 0.2s; outline:none; }
.form-group input:focus,.form-group select:focus,.form-group textarea:focus { border-color:var(--accent); }
.form-group textarea { min-height:130px; resize:vertical; }
.contact-info-card { background:var(--accent-light); border:1px solid #ddd0b8; border-radius:var(--radius); padding:2rem; }
.contact-info-card h3 { color:var(--accent); margin-bottom:1.2rem; }
.contact-row { display:flex; gap:0.75rem; align-items:flex-start; margin-bottom:1rem; }
.contact-row-icon { font-size:1rem; margin-top:0.15rem; flex-shrink:0; }
.contact-row-text { font-size:0.88rem; color:var(--charcoal); line-height:1.5; }
.contact-row-text a { color:var(--accent); }

/* THANK YOU */
.thankyou-center { text-align:center; padding:8rem 2rem; }
.thankyou-center h1 { margin-bottom:1rem; }
.thankyou-center p { color:var(--muted); margin-bottom:2rem; }

/* FOOTER */
footer { background:var(--ink); color:rgba(255,255,255,0.65); padding:3rem 0; margin-top:4rem; }
.footer-inner { display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:3rem; max-width:1100px; margin:0 auto; padding:0 2rem; }
.footer-brand h3 { color:var(--white); font-family:var(--font-serif); font-size:1.1rem; margin-bottom:0.5rem; }
.footer-brand p { font-size:0.85rem; line-height:1.6; }
.footer-col h4 { color:var(--white); font-size:0.8rem; letter-spacing:0.08em; text-transform:uppercase; margin-bottom:1rem; }
.footer-col ul { list-style:none; }
.footer-col ul li { margin-bottom:0.5rem; }
.footer-col ul li a { color:rgba(255,255,255,0.6); font-size:0.85rem; text-decoration:none; transition:color 0.2s; }
.footer-col ul li a:hover { color:var(--white); }
.footer-col p { font-size:0.85rem; margin-bottom:0.4rem; }
.footer-col a { color:rgba(255,255,255,0.6); font-size:0.85rem; }
.footer-col a:hover { color:var(--white); }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.1); margin-top:2.5rem; padding-top:1.5rem; text-align:center; font-size:0.78rem; color:rgba(255,255,255,0.35); max-width:1100px; margin:2.5rem auto 0; padding:1.5rem 2rem 0; }

/* QUOTE BLOCK */
.quote-block { background:var(--accent-light); border-left:3px solid var(--accent); padding:1.25rem 1.5rem; border-radius:0 8px 8px 0; margin:1.5rem 0; }
.quote-block p { margin:0; font-style:italic; color:var(--charcoal); }

/* TAGS */
.tag { background:var(--white); border:1px solid var(--border); padding:0.35rem 0.85rem; border-radius:20px; font-size:0.78rem; color:var(--muted); display:inline-block; margin:0.25rem; }

/* HIGHLIGHT BOX */
.highlight-box { margin-top:2.5rem; padding:2rem; background:var(--accent-light); border-radius:var(--radius); border:1px solid #ddd0b8; }
.highlight-box h3 { color:var(--accent); margin-bottom:0.75rem; }

/* RESPONSIVE */
@media (max-width:900px) {
  .hero { grid-template-columns:1fr; }
  .hero-photo { min-height:360px; max-height:420px; }
  .hero-text { padding:3rem 2rem; }
  .services-grid { grid-template-columns:1fr 1fr; }
  .who-grid { grid-template-columns:1fr; }
  .content-layout { grid-template-columns:1fr; }
  .contact-layout { grid-template-columns:1fr; }
  .footer-inner { grid-template-columns:1fr; gap:2rem; }
  .nav-links { gap:1rem; }
  .nav-links li:not(:last-child):not(:nth-last-child(2)) { display:none; }
}
@media (max-width:600px) {
  .services-grid { grid-template-columns:1fr; }
  .hero-actions { flex-direction:column; }
  .btn { text-align:center; }
  .cta-banner { padding:2.5rem 1.5rem; }
}

/* ── MOBILE FIXES ── */
@media (max-width: 768px) {
  /* Nav logo — keep on one line */
  .nav-logo {
    font-size: 1rem;
    white-space: nowrap;
  }

  /* Hide all nav links except CTA on mobile */
  .nav-links li:not(:last-child) {
    display: none;
  }

  /* Hero — stack photo on top, text below */
  .hero {
    grid-template-columns: 1fr;
    height: auto;
  }
  .hero-photo {
    height: 320px;
    min-height: unset;
  }
  .hero-text {
    padding: 2.5rem 1.5rem;
  }
  .hero-text h1 {
    font-size: 2.2rem;
  }

  /* Credentials bar — stack vertically, no overlap */
  .cred-bar {
    position: relative;
    z-index: 1;
  }
  .cred-bar-inner {
    flex-direction: column;
    gap: 1rem;
    text-align: center;
  }
  .cred-sep {
    display: none;
  }
  .cred-item {
    width: 100%;
  }

  /* Services grid — single column */
  .services-grid {
    grid-template-columns: 1fr;
  }

  /* About section — stack */
  .content-layout,
  .contact-layout {
    grid-template-columns: 1fr;
  }

  /* Footer */
  .footer-inner {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }

  /* CTA banner */
  .cta-banner {
    padding: 2rem 1.5rem;
  }
  .cta-banner .btn {
    display: block;
    margin: 0.5rem 0 !important;
    width: 100%;
    text-align: center;
  }
}

/* ── MOBILE FIXES — iPhone ── */
@media (max-width: 768px) {
  /* NAV */
  .nav-logo { font-size:1.1rem; }
  .nav-links { gap:0.5rem; }
  .nav-links li { display:none; }
  .nav-links li:last-child { display:block; }

  /* HERO — stack photo on top, text below */
  .hero {
    display:flex;
    flex-direction:column;
    height:auto;
    min-height:auto;
  }
  .hero-photo {
    width:100%;
    height:320px;
    order:1;
  }
  .hero-photo img {
    object-position:center 15%;
  }
  .hero-text {
    order:2;
    padding:2.5rem 1.5rem;
    background:var(--accent-pale);
  }
  .hero-brand { font-size:1.1rem !important; }
  .hero-text h1 { font-size:2rem; }
  .hero-actions {
    flex-direction:column;
    gap:0.75rem;
  }
  .hero-actions .btn {
    width:100%;
    text-align:center;
  }

  /* CRED BAR */
  .cred-bar-inner {
    gap:1rem;
    justify-content:flex-start;
  }
  .cred-sep { display:none; }
  .cred-item { flex:0 0 45%; }

  /* SERVICES */
  .services-grid {
    grid-template-columns:1fr;
    gap:1rem;
  }

  /* WHO GRID */
  .who-grid { grid-template-columns:1fr; gap:1rem; }

  /* ABOUT SECTION */
  .container > div[style*="grid-template-columns:1fr 1fr"] {
    display:flex !important;
    flex-direction:column !important;
    gap:2rem !important;
  }

  /* CTA BANNER */
  .cta-banner { padding:2rem 1.5rem; }
  .cta-banner .btn {
    display:block;
    width:100%;
    margin:0.5rem 0 !important;
    text-align:center;
  }

  /* CONTENT LAYOUT — service pages */
  .content-layout {
    grid-template-columns:1fr;
    gap:2rem;
    padding-top:1.5rem;
  }

  /* CONTACT LAYOUT */
  .contact-layout {
    grid-template-columns:1fr;
    gap:2rem;
  }

  /* FOOTER */
  .footer-inner {
    grid-template-columns:1fr;
    gap:1.5rem;
  }

  /* PAGE HERO */
  .page-hero { padding:2.5rem 0 2rem; }
  .page-hero h1 { font-size:1.8rem; }

  /* GENERAL */
  section { padding:3rem 0; }
  .container { padding:0 1.25rem; }
  h2 { font-size:1.5rem; }

  /* TAGS — wrap nicely */
  .tag { font-size:0.72rem; padding:0.3rem 0.7rem; }
}

@media (max-width: 400px) {
  .hero-photo { height:260px; }
  .hero-text h1 { font-size:1.75rem; }
  .nav-logo { font-size:1rem; }
}

/* ── NAV BUTTON MOBILE FIX ── */
@media (max-width: 768px) {
  .nav-links .nav-cta {
    padding: 0.5rem 0.9rem;
    font-size: 0.75rem;
    white-space: nowrap;
    border-radius: 5px;
  }
  .nav-inner {
    padding: 0 1rem;
    gap: 0.5rem;
  }
  .nav-logo {
    font-size: 1rem;
    white-space: nowrap;
  }
}
