/* =======================================================
   Page-level styles (light-only) — CA TAX HUB
   Works with base.css + components.css
   ======================================================= */

/* ---------- HERO (Home / generic) ---------- */
.hero-v2{
  background:
    radial-gradient(1000px 360px at 8% 0%, rgba(10,56,113,.08), transparent 60%),
    radial-gradient(900px 320px at 100% 0%, rgba(244,124,38,.06), transparent 60%);
  padding: clamp(36px, 7vw, 90px) 0 clamp(20px, 5vw, 40px);
  border-bottom: 1px solid var(--line);
}
.hero-v2 .badge{
  display:inline-block;
  padding:.2rem .6rem;
  background: var(--card);
  border:1px solid var(--line);
  border-radius: 999px;
  font-size:.8rem;
  color: var(--muted);
  margin-bottom:.6rem;
}
.ribbon{
  display:flex; gap:.6rem; flex-wrap:wrap; margin:1rem 0 0;
}
.ribbon li{
  background: var(--card);
  border:1px solid var(--line);
  padding:.5rem .7rem;
  border-radius:12px;
  font-size:.9rem;
}

/* ---------- LOGO BAND (trust strip) ---------- */
.logo-band{
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  background:var(--bg);
}
.logo-row{
  display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:.7rem 0;
}
.logo-row ul{
  display:flex; gap: clamp(.9rem, 2.6vw, 1.4rem); align-items:center;
  margin:0; padding:0; list-style:none;
}
.logo-row img{
  height:28px; opacity:.85; filter: grayscale(1);
  transition: opacity .2s, filter .2s, transform .2s;
}
.logo-row img:hover{ opacity:1; filter:none; transform: translateY(-1px); }

/* ---------- PROCESS / TIMELINE (Home / About) ---------- */
.process{
  counter-reset: step; display:grid; gap:.8rem; grid-template-columns:1fr; padding:0; margin:0;
}
.process li{
  list-style:none; padding:1rem 1rem 1rem 3.2rem; background:var(--card);
  border:1px solid var(--line); border-radius:14px; position:relative;
  transition: box-shadow var(--trans-fast), transform var(--trans-fast), border-color var(--trans-fast);
}
.process li::before{
  counter-increment: step;
  content: counter(step);
  position:absolute; left:1rem; top:1rem;
  width:1.6rem; height:1.6rem; display:grid; place-items:center;
  border-radius:50%; background: var(--brand); color:#fff; font-weight:700; font-size:.9rem;
  box-shadow: var(--shadow-sm);
}
.process li:hover{ box-shadow: var(--shadow); transform: translateY(-1px); border-color: rgba(10,56,113,.25); }
@media (min-width: 900px){
  .process{ grid-template-columns: repeat(4, 1fr); }
}

/* ---------- DUE DATES (Resources) ---------- */
.due-list{ display:grid; gap:.7rem; grid-template-columns:1fr; }
.due-date-item{
  display:flex; gap:1rem; align-items:flex-start;
  background:var(--card); border:1px solid var(--line); border-radius:12px; padding:.8rem;
}
.due-date-item .date{ min-width: 150px; }
.due-date-item .title{ font-weight:700; }
.due-date-item .desc{ color:var(--muted); }

/* ---------- SERVICES (index) ---------- */
.services-grid{
  display:grid; grid-template-columns:1fr; gap:1rem;
}
@media (min-width:900px){
  .services-grid{ grid-template-columns:repeat(3, 1fr); }
}
.services-grid .service-card{ min-height: 180px; }

/* ---------- SERVICE DETAIL (problem → solution → deliverables) ---------- */
.service-hero{
  background:
    radial-gradient(900px 300px at 12% -10%, rgba(10,56,113,.08), transparent 60%),
    radial-gradient(700px 220px at 92% -18%, rgba(244,124,38,.08), transparent 60%);
  border-bottom:1px solid var(--line);
  padding: clamp(36px, 7vw, 80px) 0 26px;
}
.service-sections{
  display:grid; grid-template-columns:1fr; gap:1rem;
}
@media (min-width:1000px){
  .service-sections{ grid-template-columns: 1.15fr .85fr; }
}
.deliverables{
  border:1px dashed var(--line);
  border-radius:12px; padding:1rem; background:linear-gradient(180deg, rgba(10,56,113,.03), transparent);
}
.process-steps{ margin-top:.6rem; }
.process-steps li{ margin:.3rem 0; }

/* ---------- TEAM (About) ---------- */
.team{
  text-align:left; overflow:hidden;
}
.team img{
  width:100%; height:auto; border-radius:12px; border:1px solid var(--line);
  aspect-ratio: 3 / 2; object-fit: cover;
}
.team h3{ margin-top:.6rem; }
.team .muted{ margin-bottom:.4rem; display:block; }

/* ---------- BLOG (list + template) ---------- */
.tag-bar{
  justify-content:flex-start;
}
.post-list{
  display:grid; grid-template-columns:1fr; gap:1rem;
}
@media (min-width:900px){
  .post-list{ grid-template-columns:repeat(3,1fr); }
}
.post-head{ text-align:left; }
.post-cover{ max-width:900px; margin:.8rem auto; }

/* ---------- CALCULATORS ---------- */
.calc-grid{
  display:grid; grid-template-columns:1fr; gap:1rem;
}
@media (min-width:900px){
  .calc-grid{ grid-template-columns: repeat(3, 1fr); }
}
.card .result{
  margin-top:.7rem;
  border:1px dashed var(--line);
  border-radius:12px;
  padding:.7rem .8rem;
  background:linear-gradient(180deg, rgba(10,56,113,.04), transparent);
}

/* ---------- CAREERS ---------- */
.jobs{
  list-style:none; padding-left:0; margin:0;
}
.jobs li{
  padding:.55rem .7rem; border:1px solid var(--line); border-radius:12px; margin:.45rem 0;
  background:var(--card);
}

/* ---------- CONTACT ---------- */
.quick-actions .link{
  display:inline-flex; align-items:center; gap:.4rem; font-weight:700;
}

/* ---------- LEGAL PAGES ---------- */
.legal{
  display:block;
}
.legal .toc{
  position:sticky; top:92px;
}
.legal h2{ margin-top:1rem; }

/* ---------- CTA SECTION (shared) ---------- */
.section.cta{
  background: linear-gradient( to right, rgba(10,56,113,.04), rgba(244,124,38,.06) );
}

/* ---------- PAGE HERO (shared simple variation) ---------- */
.page-hero--tight{
  padding: clamp(26px, 5vw, 56px) 0 18px;
  border-bottom:1px solid var(--line);
}

/* ---------- Utilities specific to pages ---------- */
.badge-soft{
  display:inline-block; padding:.2rem .55rem; border-radius:999px;
  background: rgba(10,56,113,.08); color:var(--brand); font-weight:700; font-size:.78rem;
}
.max-800{ max-width:800px; }
.mx-auto{ margin-inline:auto; }

/* End of pages.css */
