/* ═══════════════════════════════════════════════════════
   Puget Sound Moving — page-sidebar.css
   Standard content page with right sidebar.
═══════════════════════════════════════════════════════ */

/* ── Page Hero ──────────────────────────────────────── */
.page-hero {
  background: var(--navy); padding: 80px 0 60px; position: relative; overflow: hidden;
}
.page-hero::after {
  content: ''; position: absolute; inset: 0;
  background-image: linear-gradient(rgba(201,148,42,.04) 1px,transparent 1px),
                    linear-gradient(90deg,rgba(201,148,42,.04) 1px,transparent 1px);
  background-size: 60px 60px; pointer-events: none;
}
.page-hero-inner { position: relative; z-index: 2; }
.page-hero-title {
  font-family: 'Bebas Neue', sans-serif; font-size: clamp(40px,6vw,72px);
  letter-spacing: 1px; color: var(--white); line-height: 1; margin-bottom: 0;
}
.page-hero-sub { font-size: 17px; color: rgba(255,255,255,.5); margin-top: 14px; max-width: 580px; line-height: 1.7; }

/* ── Layout ─────────────────────────────────────────── */
.page-sidebar-body { padding: 72px 0 96px; background: var(--white); }
.page-sidebar-layout {
  display: grid; grid-template-columns: 1fr 320px; gap: 64px; align-items: start;
}

/* ── Main Content ───────────────────────────────────── */
.page-main-content { min-width: 0; }
.page-main-content h1,
.page-main-content h2,
.page-main-content h3,
.page-main-content h4 {
  font-family: 'Bebas Neue', sans-serif; color: var(--navy); letter-spacing: 1px;
  margin: 32px 0 14px; line-height: 1.05;
}
.page-main-content h2 { font-size: clamp(26px,3.5vw,40px); }
.page-main-content h3 { font-size: clamp(22px,2.8vw,30px); }
.page-main-content h4 { font-size: 22px; }
.page-main-content h2:first-child,
.page-main-content h3:first-child { margin-top: 0; }
.page-main-content p  { font-size: 16px; color: var(--text-mid); line-height: 1.85; margin-bottom: 20px; }
.page-main-content ul,
.page-main-content ol { margin: 0 0 22px 22px; }
.page-main-content li { font-size: 16px; color: var(--text-mid); line-height: 1.75; margin-bottom: 8px; }
.page-main-content a  { color: var(--navy); text-underline-offset: 3px; }
.page-main-content a:hover { color: var(--gold); }
.page-main-content blockquote {
  border-left: 4px solid var(--gold); padding: 18px 26px; margin: 28px 0;
  background: var(--off-white);
}
.page-main-content blockquote p { font-family: 'Playfair Display', serif; font-style: italic; font-size: 19px; color: var(--navy); margin: 0; }
.page-main-content img { max-width: 100%; height: auto; margin: 20px 0; }
.page-main-content table { width: 100%; border-collapse: collapse; font-size: 15px; margin-bottom: 24px; }
.page-main-content table th { background: var(--navy); color: var(--gold); padding: 11px 16px; text-align: left; font-family: 'Bebas Neue', sans-serif; letter-spacing: 1px; }
.page-main-content table td { padding: 10px 16px; border-bottom: 1px solid #ECEAE3; color: var(--text-mid); }
.page-main-content table tr:hover td { background: var(--off-white); }
.page-main-content hr { border: none; border-top: 2px solid var(--gray-bg); margin: 36px 0; }
/* callout shortcode / block */
.page-main-content .wp-block-pullquote { border-top: 4px solid var(--gold); border-bottom: 4px solid var(--gold); padding: 24px 0; }

/* ── Sidebar ────────────────────────────────────────── */
.page-sidebar { position: sticky; top: 96px; }
.page-sidebar .sidebar-widget          { margin-bottom: 36px; }
.page-sidebar .sidebar-widget-title    {
  font-family: 'Bebas Neue', sans-serif; font-size: 20px; letter-spacing: 3px;
  color: var(--navy); margin-bottom: 18px; padding-bottom: 12px;
  border-bottom: 2px solid var(--gold-pale); position: relative;
}
.page-sidebar .sidebar-widget-title::after {
  content: ''; position: absolute; bottom: -2px; left: 0; width: 40px; height: 2px; background: var(--gold);
}

/* Quick contact widget */
.sidebar-contact-widget {
  background: var(--navy); padding: 28px 22px; position: relative; overflow: hidden;
}
.sidebar-contact-widget::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg,var(--gold),var(--gold-light)); }
.sidebar-contact-widget h4 { font-family: 'Bebas Neue', sans-serif; font-size: 24px; letter-spacing: 2px; color: var(--white); margin-bottom: 8px; }
.sidebar-contact-widget p  { font-size: 14px; color: rgba(255,255,255,.5); margin-bottom: 18px; line-height: 1.6; }
.sidebar-contact-line { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; font-size: 14px; color: rgba(255,255,255,.7); }
.sidebar-contact-line a { color: var(--gold-light); text-decoration: none; }
.sidebar-contact-line a:hover { color: var(--white); }
.sidebar-contact-widget .btn-primary { display: block; text-align: center; clip-path: none; margin-top: 18px; }

/* Services list widget */
.sidebar-services-list { list-style: none; display: flex; flex-direction: column; gap: 0; }
.sidebar-services-list li a {
  display: flex; justify-content: space-between; align-items: center;
  padding: 11px 0; border-bottom: 1px solid #ECEAE3; font-size: 14px;
  font-weight: 500; color: var(--text-mid); text-decoration: none;
  transition: color .2s, padding-left .2s;
}
.sidebar-services-list li a:hover { color: var(--gold); padding-left: 6px; }
.sidebar-services-list li a::after { content: '→'; color: var(--gold); opacity: 0; transition: opacity .2s; }
.sidebar-services-list li a:hover::after { opacity: 1; }

/* Trust badges widget */
.sidebar-trust-badges { display: flex; flex-direction: column; gap: 10px; }
.sidebar-badge {
  display: flex; align-items: center; gap: 12px; padding: 12px 14px;
  background: var(--off-white); border-left: 3px solid var(--gold);
  font-size: 13px; font-weight: 600; color: var(--navy);
}
.sidebar-badge-icon { flex-shrink: 0; }

/* ── Responsive ─────────────────────────────────────── */
@media (max-width: 1000px) {
  .page-sidebar-layout { grid-template-columns: 1fr; }
  .page-sidebar { position: static; display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
}
@media (max-width: 600px) {
  .page-sidebar { grid-template-columns: 1fr; }
  .page-sidebar-body { padding: 48px 0 64px; }
}
