/* Page-level layouts */

/* Generic page hero (inner pages): light, vibrant, animated backdrop */
.pagehero { position: relative; overflow: hidden; background: var(--canvas); color: var(--text); padding-block: clamp(64px, 9vw, 120px); }
/* glows kept to the LEFT (behind copy) so the right stays solid canvas and the
   illustration's baked background blends in invisibly - no dot-grid box */
.pagehero::before { content:""; position:absolute; inset:-30%; z-index:0; pointer-events:none;
  background:
    radial-gradient(28% 36% at 12% 26%, rgba(193,120,23,0.22), transparent 72%),
    radial-gradient(24% 32% at 22% 96%, rgba(36,53,86,0.14), transparent 72%);
  animation: heroDrift 22s ease-in-out infinite alternate; }
.pagehero > .container { position: relative; z-index: 1; }
/* optional two-column page hero with illustration */
.pagehero__grid { display: grid; grid-template-columns: 1.08fr 0.92fr; gap: clamp(24px, 5vw, 56px); align-items: center; }
.pagehero__art { position: relative; }
.pagehero__art::before { content:""; position:absolute; inset:-8% -4%; background: radial-gradient(closest-side, rgba(255,255,255,0.6), transparent 75%); pointer-events:none; }
.pagehero__art img { position: relative; width: 100%; height: auto; animation: floatY 7s ease-in-out infinite; }
@media (prefers-reduced-motion: reduce) { .pagehero__art img { animation: none; } }
.pagehero__copy h1 { max-width: 18ch; }
.pagehero h1 { color: var(--text); max-width: 16ch; }
.pagehero h1 .hl { color: var(--amber); }
.pagehero p { font-family: var(--font-accent); font-weight: 500; color: var(--text-2); font-size: var(--fs-xl); line-height: 1.3; margin-top: 18px; max-width: 60ch; }
@media (prefers-reduced-motion: reduce) { .pagehero::before { animation: none; } }

/* Solutions detail rows */
.soln { display: grid; gap: clamp(40px, 7vw, 88px); }
.soln__row { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 5vw, 56px); align-items: center; scroll-margin-top: 90px; }
.soln__row:nth-child(even) .soln__media { order: -1; }
.soln__media { border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--border-2); box-shadow: var(--shadow-lg); }
.soln__pain { font-size: var(--fs-xs); font-weight: 600; text-transform: uppercase; letter-spacing: .04em; color: var(--amber-dark); margin-bottom: 10px; }
.soln__row h2 { font-size: var(--fs-2xl); margin-bottom: 14px; }

/* Demo page two-column */
.demo-layout { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px, 6vw, 72px); align-items: start; }
.demo-aside ul { list-style: none; padding: 0; margin: 24px 0 0; display: grid; gap: 16px; }
.demo-aside li { display: flex; gap: 12px; align-items: flex-start; font-size: var(--fs-sm); color: var(--text-2); }
.demo-aside li svg { width: 22px; height: 22px; color: var(--amber); flex: 0 0 auto; }

/* Customers */
.cust-grid { display: grid; gap: 24px; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.cust-card { background: var(--bg); border: 1px solid var(--border-2); border-radius: var(--r-lg); padding: 28px; box-shadow: var(--shadow-sm); }
.cust-card__seg { font-family: var(--font-mono); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: .08em; color: var(--amber); }
.cust-card h3 { font-size: var(--fs-lg); margin: 8px 0 14px; }
.cust-card blockquote { margin: 0; font-size: var(--fs-base); color: var(--text); line-height: 1.5; }

/* Resources / blog */
.post-list { display: grid; gap: 20px; }
.post-item { display: flex; flex-direction: column; gap: 6px; padding: 24px; border: 1px solid var(--border-2); border-radius: var(--r-lg); background: var(--bg); transition: var(--transition); }
.post-item:hover { box-shadow: var(--shadow-md); transform: translateY(-1px); }
.post-item time { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--text-3); }
.post-item h2, .post-item h3 { font-size: var(--fs-lg); }
.post-item p { color: var(--text-2); font-size: var(--fs-sm); }

/* Blog article */
.article { max-width: 760px; margin-inline: auto; }
.article__back { display: inline-block; font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: .04em; text-transform: uppercase; color: var(--text-3); margin-bottom: 24px; }
.article__back:hover { color: var(--amber-dark); }
.article__head { padding-bottom: 28px; margin-bottom: 32px; border-bottom: 1px solid var(--border-2); }
.article__tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.article__tag { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: .03em; color: var(--amber-dark); background: var(--amber-tint, rgba(193,120,23,.1)); padding: 4px 10px; border-radius: 999px; }
.article__head h1 { font-size: var(--fs-3xl); line-height: 1.12; margin-bottom: 16px; }
.article__meta { display: flex; gap: 10px; align-items: center; font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--text-3); }
.article__lede { font-family: var(--font-accent); font-weight: 500; margin-top: 18px; font-size: var(--fs-xl); line-height: 1.4; color: var(--text-2); }
.article__body { max-width: none; }
.article__body h2 { font-size: var(--fs-2xl); margin: 40px 0 14px; }
.article__body h3 { font-size: var(--fs-lg); margin: 28px 0 10px; }
.article__body p, .article__body li { color: var(--text-2); font-size: var(--fs-base); line-height: 1.7; }
.article__body ul, .article__body ol { padding-left: 22px; display: grid; gap: 10px; margin: 16px 0; }
.article__body blockquote { border-left: 3px solid var(--amber); padding-left: 20px; margin: 24px 0; font-size: var(--fs-lg); color: var(--text-1); font-style: italic; }
.article__body a { color: var(--amber-dark); font-weight: 600; }
.article__foot { margin-top: 48px; padding-top: 28px; border-top: 1px solid var(--border-2); text-align: center; }
.article__foot p { color: var(--text-2); margin-bottom: 16px; }

/* ROI calculator */
.roi { display: grid; grid-template-columns: 1.45fr 1fr; gap: clamp(24px, 4vw, 48px); align-items: start; }
.roi__inputs { display: grid; gap: 24px; }
.roi__group { border: 1px solid var(--border-2); border-radius: var(--r-lg); padding: 24px; background: #fff; box-shadow: var(--shadow-card); }
.roi__group legend { font-family: var(--font-display); text-transform: uppercase; font-size: var(--fs-lg); font-weight: 600; padding: 0 8px; color: var(--text); }
.roi__note { display: block; font-family: var(--font); text-transform: none; font-size: var(--fs-xs); font-weight: 400; color: var(--text-3); letter-spacing: 0; margin-top: 4px; }
.roi__fields { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 18px; }
.roi__field { position: relative; display: grid; gap: 6px; align-content: start; }
.roi__field > span { font-size: var(--fs-sm); color: var(--text-2); font-weight: 500; line-height: 1.3; }
.roi__field input { width: 100%; padding: 12px 14px; border: 1px solid var(--border); border-radius: var(--r-md); font: inherit; font-size: var(--fs-base); background: var(--bg); color: var(--text); transition: var(--transition); }
.roi__field input:focus { border-color: var(--amber); box-shadow: var(--shadow-focus); }
.roi__field--money input, .roi__field--pct input { padding-right: 46px; }
.roi__field--money::after, .roi__field--pct::after { position: absolute; right: 14px; bottom: 13px; font-size: var(--fs-sm); color: var(--text-3); pointer-events: none; }
.roi__field--money::after { content: "USD"; }
.roi__field--pct::after { content: "%"; }
.roi__results { position: sticky; top: 88px; }
.roi__card { position: relative; overflow: hidden; background: var(--navy); color: #fff; border-radius: var(--r-xl); padding: 32px; box-shadow: var(--shadow-elev); }
.roi__card::before { content:""; position:absolute; inset:0; pointer-events:none; background:
    radial-gradient(60% 50% at 90% 0%, rgba(193,120,23,0.30), transparent 60%),
    radial-gradient(50% 50% at 0% 100%, rgba(36,53,86,0.6), transparent 60%); }
.roi__card > * { position: relative; z-index: 1; }
.roi__card-title { color: #fff; font-size: var(--fs-xl); margin-bottom: 20px; }
.roi__lines { display: grid; gap: 12px; }
.roi__line { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; }
.roi__line span { color: var(--text-on-navy); font-size: var(--fs-sm); }
.roi__line strong { color: #fff; font-family: var(--font-display); font-size: var(--fs-lg); white-space: nowrap; }
.roi__line--total { margin-top: 18px; padding-top: 18px; border-top: 1px solid rgba(255,255,255,0.15); }
.roi__line--total span { color: #fff; font-weight: 600; }
.roi__line--total strong { color: var(--amber-light); font-size: var(--fs-2xl); }
.roi__line--net { margin-top: 10px; }
.roi__line--net strong.is-negative { color: #ff9d8c; }
.roi__kpis { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin: 24px 0; }
.roi__kpi { background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.12); border-radius: var(--r-md); padding: 16px; text-align: center; }
.roi__kpi span { display: block; color: var(--text-on-navy-dim); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 6px; }
.roi__kpi strong { color: #fff; font-family: var(--font-display); font-size: var(--fs-2xl); }
.roi__legal { margin-top: 28px; font-size: var(--fs-xs); color: var(--text-3); max-width: 82ch; line-height: 1.6; }

/* Two-up generic */
.two-up { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }

/* Prose (legal/about) */
.prose { max-width: 70ch; }
.prose h2 { font-size: var(--fs-xl); margin: 36px 0 12px; }
.prose p, .prose li { color: var(--text-2); font-size: var(--fs-base); }
.prose ul { padding-left: 20px; display: grid; gap: 8px; }

@media (max-width: 860px) {
  .soln__row, .demo-layout, .two-up, .roi, .roi__fields { grid-template-columns: 1fr; }
  .soln__row:nth-child(even) .soln__media { order: 0; }
  .roi__results { position: static; }
}
