/* =========================================================
   OSSA Contracting Group — Commercial / HOA page
   Page-specific components. Inherits tokens from styles.css
   ========================================================= */

/* ---------- Trust bar / approved vendors ---------- */
.trust { background: var(--brand-deep); color: #fff; position: relative; z-index: 2; padding: clamp(40px, 6vw, 64px) 0; overflow: hidden; }
.trust::before { content: ""; position: absolute; left: -80px; top: -80px; width: 360px; height: 360px; border-radius: 50%; background: radial-gradient(circle, rgba(38,220,208,0.14), transparent 70%); pointer-events: none; }
.trust__inner { position: relative; display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(28px, 5vw, 72px); align-items: center; }
.trust__label { font-size: 11px; font-weight: 800; letter-spacing: 0.24em; text-transform: uppercase; color: var(--brand-accent); }
.trust__title { font-family: var(--font-display); font-size: clamp(22px, 2.6vw, 30px); font-weight: 800; letter-spacing: -0.02em; line-height: 1.2; margin-top: 12px; text-wrap: pretty; }
.trust__vendors { display: flex; flex-wrap: wrap; gap: 12px; }
.trust__vendor { display: flex; flex-direction: column; gap: 2px; padding: 16px 22px; border: 1px solid rgba(255,255,255,0.14); border-radius: var(--radius); background: rgba(255,255,255,0.05); backdrop-filter: blur(6px); min-width: 150px; }
.trust__vendor b { font-size: 15px; font-weight: 800; }
.trust__vendor span { font-size: 11px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--brand-accent); }

/* ---------- Capabilities ---------- */
.caps__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.cap { position: relative; display: flex; flex-direction: column; background: #fff; border: 1px solid #e2eaea; border-radius: var(--radius-lg); padding: clamp(26px, 3vw, 38px); box-shadow: var(--shadow-sm); transition: transform .3s var(--ease), box-shadow .3s var(--ease); }
.cap:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.cap:has(.cap__link):hover { border-color: var(--brand-primary); }
.cap__link { margin-top: auto; padding-top: 20px; display: inline-flex; align-items: center; gap: 7px; font-size: 14.5px; font-weight: 800; color: var(--brand-primary); letter-spacing: -0.01em; }
.cap__link svg { width: 17px; height: 17px; fill: none; stroke: currentColor; stroke-width: 2.2; stroke-linecap: round; stroke-linejoin: round; transition: transform .25s var(--ease); }
.cap__link::after { content: ""; position: absolute; inset: 0; border-radius: var(--radius-lg); }
.cap:hover .cap__link svg { transform: translateX(4px); }
.cap__ic { width: 52px; height: 52px; border-radius: 14px; display: grid; place-items: center; background: var(--primary-12); margin-bottom: 20px; }
.cap__ic svg { width: 26px; height: 26px; fill: none; stroke: var(--brand-primary); stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.cap h3 { font-family: var(--font-display); font-size: clamp(20px, 2vw, 25px); font-weight: 800; letter-spacing: -0.02em; }
.cap p { color: var(--brand-slate); margin-top: 10px; font-size: 15.5px; line-height: 1.6; }
.cap__tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
.cap__tags span { font-size: 12.5px; font-weight: 700; color: var(--brand-deep); background: var(--brand-light); padding: 7px 14px; border-radius: 999px; }

/* ---------- Featured case study ---------- */
.case { background: var(--brand-light); }
.case__grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(32px, 5vw, 64px); align-items: center; }
.case__media { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.case__media img { width: 100%; height: 100%; object-fit: cover; border-radius: var(--radius); box-shadow: var(--shadow-sm); }
.case__media img:first-child { grid-row: span 2; aspect-ratio: 3/4; }
.case__media img:not(:first-child) { aspect-ratio: 4/3; }
.case__lead { font-size: 18px; color: var(--brand-slate); margin: 16px 0 26px; text-wrap: pretty; }
.case__cats { display: grid; gap: 14px; margin-bottom: 30px; }
.case__cat { border-left: 3px solid var(--brand-primary); padding-left: 16px; }
.case__cat b { display: block; font-weight: 800; color: var(--brand-deep); }
.case__cat span { font-size: 14.5px; color: var(--brand-slate); }

/* ---------- Risk mitigation ---------- */
.risk { background: var(--deep-grad); color: #fff; position: relative; z-index: 2; overflow: clip; }
.risk::before { content: ""; position: absolute; right: -6%; bottom: 0; width: 420px; height: 420px; border-radius: 50%; background: radial-gradient(circle, rgba(38,220,208,0.13), transparent 70%); pointer-events: none; }
.risk__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; margin-top: 50px; }
.risk__item { display: flex; gap: 18px; align-items: flex-start; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.12); border-radius: var(--radius-lg); padding: 26px 28px; backdrop-filter: blur(8px); }
.risk__num { font-family: var(--font-display); font-weight: 900; font-size: 20px; color: var(--brand-accent); flex: none; width: 44px; height: 44px; border-radius: 50%; border: 1px solid rgba(38,220,208,0.4); display: grid; place-items: center; }
.risk__item h3 { font-size: 18px; font-weight: 800; }
.risk__item p { color: rgba(255,255,255,0.74); margin-top: 6px; font-size: 14.5px; line-height: 1.55; }

/* ---------- Portfolio masonry gallery ---------- */
.cgallery { columns: 3; column-gap: 16px; }
.cgallery figure { break-inside: avoid; margin: 0 0 16px; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm); position: relative; }
.cgallery img { width: 100%; height: auto; display: block; transition: transform .6s var(--ease); }
.cgallery figure:hover img { transform: scale(1.05); }

/* ---------- Breadcrumb ---------- */
.crumb { position: relative; z-index: 2; background: var(--page-bg); border-bottom: 1px solid #e6edee; }
.crumb ol { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; padding: 14px 0; font-size: 13px; color: var(--brand-slate); }
.crumb a:hover { color: var(--brand-primary); }
.crumb li[aria-current] { color: var(--brand-deep); font-weight: 700; }
.crumb svg { width: 14px; height: 14px; fill: none; stroke: currentColor; stroke-width: 2; }

/* ---------- Process / board timeline ---------- */
.process { background: var(--page-bg); }
.proc { max-width: 880px; margin: 54px auto 0; display: grid; gap: 0; }
.proc__step { position: relative; display: grid; grid-template-columns: auto 1fr; gap: 24px; padding: 0 0 34px 0; }
.proc__step::before { content: ""; position: absolute; left: 27px; top: 8px; bottom: -8px; width: 2px; background: linear-gradient(var(--brand-primary), rgba(38,163,191,0.18)); }
.proc__step:last-child { padding-bottom: 0; }
.proc__step:last-child::before { display: none; }
.proc__num { position: relative; z-index: 1; width: 56px; height: 56px; flex: none; border-radius: 50%; display: grid; place-items: center; background: #fff; border: 2px solid var(--brand-primary); color: var(--brand-deep); font-weight: 900; font-size: 17px; letter-spacing: -0.02em; box-shadow: var(--shadow-sm); }
.proc__step:hover .proc__num { background: var(--brand-primary); color: #fff; }
.proc__body { padding-top: 6px; }
.proc__body h3 { font-family: var(--font-display); font-size: clamp(18px, 1.9vw, 22px); font-weight: 800; letter-spacing: -0.02em; color: var(--brand-deep); }
.proc__body p { color: var(--brand-slate); margin-top: 7px; font-size: 15.5px; line-height: 1.6; max-width: 60ch; }
.process__cta { display: flex; align-items: center; gap: 22px; flex-wrap: wrap; justify-content: center; margin-top: 48px; }
.process__cta span { font-size: 14.5px; color: var(--brand-slate); font-weight: 600; }

/* ---------- FAQ ---------- */
.faq { background: var(--brand-light); }
.faq__grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(32px, 5vw, 72px); align-items: start; }
.faq__intro { position: sticky; top: calc(var(--nav-h) + 24px); }
.faq__intro .btn { margin-top: 24px; }
.faq__list { display: grid; gap: 14px; }
.faq__item { background: #fff; border: 1px solid #e2eaea; border-radius: var(--radius); box-shadow: var(--shadow-sm); overflow: hidden; transition: border-color .25s var(--ease); }
.faq__item[open] { border-color: var(--brand-primary); }
.faq__item summary { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 20px 24px; font-weight: 700; font-size: 16.5px; color: var(--brand-deep); cursor: pointer; list-style: none; }
.faq__item summary::-webkit-details-marker { display: none; }
.faq__ic { position: relative; flex: none; width: 18px; height: 18px; }
.faq__ic::before, .faq__ic::after { content: ""; position: absolute; background: var(--brand-primary); border-radius: 2px; transition: transform .3s var(--ease); }
.faq__ic::before { top: 8px; left: 0; width: 18px; height: 2px; }
.faq__ic::after { left: 8px; top: 0; width: 2px; height: 18px; }
.faq__item[open] .faq__ic::after { transform: scaleY(0); }
.faq__a { padding: 0 24px 22px; }
.faq__a p { color: var(--brand-slate); font-size: 15px; line-height: 1.65; }

/* ---------- Service sub-page extras ---------- */
.subintro__grid { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: clamp(32px, 5vw, 64px); align-items: center; }
.subintro__text .section__sub { font-size: 18px; margin-bottom: 24px; }
.subintro__list { display: grid; gap: 12px; }
.subintro__list li { position: relative; padding-left: 30px; font-weight: 600; color: var(--brand-deep); font-size: 15.5px; }
.subintro__list li::before { content: ""; position: absolute; left: 0; top: 3px; width: 18px; height: 18px; border-radius: 6px; background: var(--primary-12); }
.subintro__list li::after { content: ""; position: absolute; left: 6px; top: 8px; width: 6px; height: 9px; border: solid var(--brand-primary); border-width: 0 2px 2px 0; transform: rotate(45deg); }
.subintro__media img { width: 100%; border-radius: var(--radius-lg); box-shadow: var(--shadow-md); aspect-ratio: 4/5; object-fit: cover; }
.related__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 44px; }
.related__card { position: relative; display: flex; flex-direction: column; gap: 8px; padding: 28px; border-radius: var(--radius-lg); border: 1px solid #e2eaea; background: #fff; box-shadow: var(--shadow-sm); transition: transform .3s var(--ease), box-shadow .3s var(--ease), border-color .25s; }
.related__card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--brand-primary); }
.related__card b { font-size: 18px; font-weight: 800; color: var(--brand-deep); }
.related__card p { font-size: 14.5px; color: var(--brand-slate); line-height: 1.55; }
.related__card .cap__link { margin-top: 6px; padding-top: 0; }
.ctaband { background: var(--deep-grad); color: #fff; text-align: center; position: relative; z-index: 2; overflow: clip; }
.ctaband::before { content: ""; position: absolute; left: 50%; top: -120px; transform: translateX(-50%); width: 520px; height: 520px; border-radius: 50%; background: radial-gradient(circle, rgba(38,220,208,0.12), transparent 70%); pointer-events: none; }
.ctaband__inner { position: relative; display: flex; flex-direction: column; align-items: center; gap: 14px; }
.ctaband h2 { color: #fff; }
.ctaband p { color: rgba(255,255,255,0.78); max-width: 56ch; margin: 0 auto; }
.ctaband .btn { margin-top: 14px; }

/* ---------- Responsive ---------- */
@media (max-width: 1000px) {
  .trust__inner { grid-template-columns: 1fr; }
  .caps__grid { grid-template-columns: 1fr; }
  .case__grid { grid-template-columns: 1fr; }
  .risk__grid { grid-template-columns: 1fr; }
  .cgallery { columns: 2; }
  .faq__grid { grid-template-columns: 1fr; }
  .faq__intro { position: static; }
  .subintro__grid { grid-template-columns: 1fr; }
  .subintro__media { order: -1; }
  .related__grid { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .cgallery { columns: 1; }
  .case__media { grid-template-columns: 1fr 1fr; }
}
