/* =============================================================================
   homepage.css — styles for templates/partials/homepage.html
   ============================================================================= */

/* ─── TOKENS ───────────────────────────────────────────── */
:root {
  --hp-accent:      #ff8400;
  --hp-accent-h:    #e57500;
  --hp-accent-soft: #fff7ed;
  --hp-ink:         #0e0f12;
  --hp-muted:       #6b7280;
  --hp-line:        #e5e7eb;
  --hp-surface:     #ffffff;
  --hp-surface-2:   #f5ede0;
  --hp-dark:        #0e0f12;
}

/* ─── HERO ─────────────────────────────────────────────── */
/* Cancel the .cms-content margin-top (custom.css) — the page wrapper's
   py-10 already provides sufficient top spacing. */
.cms-content:first-child,
.cms-content { margin-top: 0 !important; }

.hp-hero {
  display: grid;
  grid-template-columns: 1fr 400px;
  gap: 52px;
  align-items: start;
  padding: 24px 0 44px;
}

@media (max-width: 1024px) {
  .hp-hero { grid-template-columns: 1fr; gap: 36px; padding: 36px 0 32px; }
}

.hp-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--hp-accent-h);
  margin-bottom: 18px;
}

.hp-hero__eyebrow::before {
  content: '';
  width: 22px;
  height: 2px;
  background: var(--hp-accent);
  display: block;
  flex-shrink: 0;
}

.hp-hero h1 {
  font-size: clamp(2.4rem, 4.2vw, 3.4rem);
  font-weight: 900;
  letter-spacing: -.035em;
  line-height: 1.03;
  margin: 0 0 18px;
  color: var(--hp-ink);
}

.hp-hero h1 em { font-style: normal; color: var(--hp-accent-h); }

.hp-hero__desc {
  font-size: 15px;
  line-height: 1.68;
  color: var(--hp-muted);
  margin: 0 0 28px;
  max-width: 32em;
}

.hp-hero__ctas { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 34px; }

/* Extra specificity to override .cms-content a { color: #cc6a00 } in custom.css */
.cms-content .hp-btn-primary,
.hp-btn-primary {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 13px 22px; border-radius: 10px;
  font-size: 14px; font-weight: 700; color: #fff !important;
  background: var(--hp-accent); border: none; cursor: pointer;
  text-decoration: none; transition: background .14s;
}

.cms-content .hp-btn-primary:hover,
.hp-btn-primary:hover { background: var(--hp-accent-h); color: #fff !important; }

.cms-content .hp-btn-secondary,
.hp-btn-secondary {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 13px 22px; border-radius: 10px;
  font-size: 14px; font-weight: 700; color: var(--hp-ink) !important;
  background: var(--hp-surface); border: 1.5px solid var(--hp-line);
  text-decoration: none; transition: border-color .14s, background .14s;
}

.cms-content .hp-btn-secondary:hover,
.hp-btn-secondary:hover { border-color: var(--hp-accent); background: var(--hp-accent-soft); color: var(--hp-ink) !important; }

.hp-hero__trust {
  display: flex; gap: 32px; flex-wrap: wrap;
  padding-top: 24px; border-top: 1px solid var(--hp-line);
}

.hp-trust__num {
  font-size: 26px; font-weight: 900;
  letter-spacing: -.025em; color: var(--hp-ink); line-height: 1;
}

.hp-trust__label { font-size: 11px; color: var(--hp-muted); line-height: 1.35; margin-top: 3px; }

/* ─── LOGIN CARD ────────────────────────────────────────── */
.hp-login-card {
  background: #fffaf2;
  border: 1px solid #f1e6d3;
  border-radius: 16px;
  padding: 28px;
  box-shadow: 0 12px 40px -16px rgba(255,132,0,.18), 0 2px 8px rgba(14,15,18,.04);
}

/* Scope all cms-content overrides to the login card to avoid conflicts */
.cms-content .hp-login-card p.hp-login-card__eyebrow {
  font-size: 10px !important; font-weight: 800 !important;
  letter-spacing: .18em !important; text-transform: uppercase !important;
  color: var(--hp-accent-h) !important; margin: 0 0 6px !important;
  line-height: 1.2 !important;
}

.cms-content .hp-login-card h2 {
  font-size: 1.2rem !important; font-weight: 800 !important;
  letter-spacing: -.01em !important; line-height: 1.2 !important;
  margin: 0 0 20px !important; color: var(--hp-ink) !important;
}

/* Prevent cms-content p rules from adding bottom margin to non-eyebrow content in the card */
.cms-content .hp-login-card label { color: #374151 !important; }

.hp-login-form { display: flex; flex-direction: column; gap: 13px; }
.hp-login-field { display: flex; flex-direction: column; gap: 5px; }
.hp-login-label { font-size: 11px; font-weight: 700; color: #374151; letter-spacing: .02em; }

.hp-login-input {
  padding: 10px 14px; border: 1.5px solid #f1e6d3;
  border-radius: 9px; font-size: 14px; font-family: inherit;
  background: #ffffff; color: var(--hp-ink); outline: none;
  transition: border-color .13s, background .13s, box-shadow .13s;
}

.hp-login-input::placeholder { color: #c4b89a; }

.hp-login-input:focus {
  border-color: var(--hp-accent); background: #fff;
  box-shadow: 0 0 0 3px rgba(255,132,0,.08);
}

.hp-login-submit {
  margin-top: 2px; padding: 12px 20px;
  border: 0; border-radius: 9px; background: var(--hp-accent);
  color: #fff; font-size: 14px; font-weight: 700;
  font-family: inherit; cursor: pointer; width: 100%;
  transition: background .14s;
}

.hp-login-submit:hover { background: var(--hp-accent-h); }

.hp-login-card__foot {
  display: flex; justify-content: space-between;
  align-items: center; margin-top: 12px;
}

.hp-login-card__foot a { font-size: 11px; color: #a88060; transition: color .13s; text-decoration: none; }
.hp-login-card__foot a:hover { color: var(--hp-accent-h); }

/* Stat tiles inside the dashboard summary card */
.hp-login-stat-tile {
  display: flex; flex-direction: column; gap: 4px;
  padding: 12px 14px; border-radius: 9px;
  border: 1.5px solid #f1e6d3; background: #ffffff;
  text-decoration: none; transition: border-color .15s, background .15s;
}
.hp-login-stat-tile:hover { border-color: var(--hp-accent); background: #fff3e0; }
.hp-login-stat-label {
  font-size: 10px; font-weight: 800; letter-spacing: .15em;
  text-transform: uppercase; color: #a88060;
}
.hp-login-stat-value {
  font-size: 1.6rem; font-weight: 900; line-height: 1;
  color: #0e0f12;
}

/* ─── SERVICES ──────────────────────────────────────────── */
.hp-services { padding: 0 0 52px; }

.hp-section-header {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  align-items: end;
  margin-bottom: 28px;
  padding-bottom: 24px;
  border-bottom: 1px solid #f1e6d3;
}

@media (max-width: 768px) { .hp-section-header { grid-template-columns: 1fr; } }

.hp-section-label {
  font-size: 13px; font-weight: 800; letter-spacing: .14em;
  text-transform: uppercase; color: var(--hp-accent-h);
  margin: 0 0 12px; display: flex; align-items: center; gap: 9px;
}

.hp-section-label::before { content: ''; width: 24px; height: 2px; background: var(--hp-accent); display: block; }

.hp-section-header h2 { font-size: 2.8rem; font-weight: 900; letter-spacing: -.035em; line-height: 1.02; color: var(--hp-ink); margin: 0; }
.hp-section-header p { font-size: 14px; color: var(--hp-muted); line-height: 1.65; margin: 0; align-self: end; }

.hp-svc-top {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 16px; margin-bottom: 16px;
}

.hp-svc-bot {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
}

@media (max-width: 900px) {
  .hp-svc-top { grid-template-columns: 1fr; }
  .hp-svc-bot { grid-template-columns: 1fr; }
}

/* Override .cms-content a color for all service card links */
.cms-content .hp-svc-feat--orange,
.cms-content .hp-svc-feat--orange h3,
.cms-content .hp-svc-feat--orange p { color: #fff !important; }

.cms-content .hp-svc-feat--dark,
.cms-content .hp-svc-feat--dark h3,
.cms-content .hp-svc-feat--dark p { color: #fff !important; }

.cms-content .hp-svc-card--cream,
.cms-content .hp-svc-card--cream h3,
.cms-content .hp-svc-card--cream p { color: var(--hp-ink) !important; }

.cms-content .hp-svc-card--dark,
.cms-content .hp-svc-card--dark h3,
.cms-content .hp-svc-card--dark p { color: #fff !important; }

/* Featured cards */
.hp-svc-feat {
  display: flex; flex-direction: column; gap: 16px;
  border-radius: 20px; padding: 32px; min-height: 200px;
  text-decoration: none; position: relative; overflow: hidden;
  transition: transform .15s;
}

.hp-svc-feat:hover { transform: translateY(-3px); }

.hp-svc-feat::after {
  content: ''; position: absolute; bottom: -28px; right: -28px;
  width: 100px; height: 100px; border-radius: 50%;
  background: rgba(255,255,255,.07); pointer-events: none;
}

.hp-svc-feat--orange { background: var(--hp-accent); color: #fff; }
.hp-svc-feat--dark   { background: var(--hp-dark); color: #fff; }
.hp-svc-feat h3 { font-size: 1.1rem; font-weight: 800; line-height: 1.2; flex: 1; margin: 0; }
.hp-svc-feat p  { font-size: 13px; line-height: 1.6; opacity: .82; margin: 0; }

.hp-svc-icon-feat {
  width: 52px; height: 52px; border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,.2); flex-shrink: 0;
}

.hp-svc-icon-feat--dark {
  width: 52px; height: 52px; border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,.15); color: #fff; flex-shrink: 0;
}

.hp-svc-arrow { margin-top: auto; font-size: 18px; font-weight: 700; }

/* Mini cards */
.hp-svc-card {
  display: flex; flex-direction: row; align-items: flex-start; gap: 18px;
  border-radius: 20px; padding: 26px 28px;
  text-decoration: none; color: inherit;
  transition: border-color .14s, box-shadow .14s, transform .14s;
}

.hp-svc-card:hover { transform: translateY(-2px); }

.hp-svc-card--cream {
  background: #fffaf2; border: 1.5px solid #fce8c8; color: var(--hp-ink);
}

.hp-svc-card--cream:hover { border-color: var(--hp-accent); box-shadow: 0 8px 22px -12px rgba(255,132,0,.25); }
.hp-svc-card--dark { background: var(--hp-dark); color: #fff; }
.hp-svc-card--dark:hover { box-shadow: 0 8px 22px -12px rgba(0,0,0,.35); }
.hp-svc-card__text { flex: 1; }

.hp-svc-icon {
  width: 46px; height: 46px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}

.hp-svc-icon--orange { background: var(--hp-accent-soft); color: var(--hp-accent-h); }
.hp-svc-icon--dark { background: rgba(255,132,0,.18); color: var(--hp-accent); }
.hp-svc-card h3 { font-size: 15px; font-weight: 800; line-height: 1.25; color: inherit; margin: 0 0 6px; }
.hp-svc-card p  { font-size: 13px; color: inherit; opacity: .75; line-height: 1.55; margin: 0; }
.hp-svc-card .hp-svc-arrow { color: var(--hp-accent); font-size: 14px; font-weight: 800; margin-top: 8px; display: block; }

/* ─── ABOUT STRIP ───────────────────────────────────────── */
.hp-about {
  border-radius: 24px; background: var(--hp-dark); color: #fff;
  padding: 48px 52px; margin-bottom: 52px;
}

@media (max-width: 768px) { .hp-about { padding: 32px 28px; } }

.hp-about__eyebrow {
  font-size: 10px; font-weight: 800; letter-spacing: .18em;
  text-transform: uppercase; color: var(--hp-accent); margin: 0 0 12px;
}

.hp-about h2 {
  font-size: clamp(1.5rem, 2.4vw, 2rem); font-weight: 800;
  letter-spacing: -.02em; line-height: 1.1; color: #fff; margin: 0 0 14px;
}

.hp-about h2 span { color: var(--hp-accent); }
.hp-about p { font-size: 14px; line-height: 1.75; color: #9ca3af; max-width: 52em; margin: 0; }
