/* actuary.info — practice-area.css
   Shared template styles for /pc/, /health/, /life-retirement/, /ai-actuarial-science/.

   Inherits IBM Plex Sans + Serif from the site, and the brand blue from base.css.
   Each page sets --pa-area-accent and --pa-area-tint to its own blue shade. */

:root {
  --pa-ink: #0E0E0C;
  --pa-paper: #fbfaf6;
  --pa-paper2: #fff;
  --pa-muted: #5C5A52;
  --pa-sec: #3A3A35;
  --pa-border: #dcd9d2;
  --pa-light: #ebe8e0;
  --pa-hover: #f7f7f9;
  --pa-blue: #1a56c4;
  --pa-blue-hover: #1347a8;
  --pa-blue-light: #5b8def;
  --pa-grad: linear-gradient(90deg, var(--pa-area-accent, #1a56c4) 0%, var(--pa-blue-light) 100%);
  --pa-serif: 'IBM Plex Serif', Georgia, serif;
  --pa-sans: 'IBM Plex Sans', system-ui, sans-serif;
  /* Per-area overrides */
  --pa-area-accent: #1a56c4;
  --pa-area-tint: rgba(26,86,196,0.08);
}

/* === Reset within practice pages === */
.pa-page, .pa-page * { box-sizing: border-box; }
.pa-page { font-family: var(--pa-sans); color: var(--pa-ink); background: var(--pa-paper); margin: 0; }
.pa-page a { color: inherit; text-decoration: none; }
.pa-shell { max-width: 1180px; margin: 0 auto; padding: 0 48px; }

/* === Pulsing dot (re-used) === */
@keyframes pa-pulse-halo { 0% { transform: scale(.5); opacity:.9; } 100% { transform: scale(2.4); opacity: 0; } }
.pa-pdot { position: relative; display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: var(--pa-area-accent); flex-shrink: 0; }
.pa-pdot::before, .pa-pdot::after { content: ""; position: absolute; inset: -1px; border-radius: 50%; background: var(--pa-area-accent); animation: pa-pulse-halo 1.8s ease-out infinite; }
.pa-pdot::before { opacity: .18; }
.pa-pdot::after { opacity: .12; animation-delay: .9s; }

/* === Practice-area masthead === */
.pa-mast { padding: 28px 0 22px; border-bottom: 1px solid var(--pa-ink); position: relative; background: var(--pa-paper); }
.pa-mast::after { content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 3px; background: var(--pa-grad); }
.pa-mast-grid { display: grid; grid-template-columns: 1fr 280px; gap: 36px; align-items: end; }
.pa-mast-kicker { display: inline-flex; align-items: center; gap: 8px; font-size: 10.5px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--pa-area-accent); padding-top: 8px; margin-bottom: 14px; position: relative; }
.pa-mast-kicker::before { content: ""; position: absolute; top: 0; left: 0; width: 56px; height: 3px; background: var(--pa-grad); border-radius: 3px; }
.pa-mast h1 { font-family: var(--pa-serif); font-size: 52px; font-weight: 600; letter-spacing: -0.024em; line-height: 1; color: var(--pa-ink); margin: 0 0 14px; }
.pa-mast h1 em { font-style: normal; color: var(--pa-area-accent); }
.pa-mast-dek { font-family: var(--pa-serif); font-size: 16px; line-height: 1.55; color: var(--pa-sec); max-width: 640px; margin: 0; }
.pa-mast-aside { display: flex; flex-direction: column; gap: 4px; text-align: right; font-family: var(--pa-sans); padding-bottom: 6px; }
.pa-mast-aside .day { font-family: var(--pa-serif); font-size: 14px; font-style: italic; color: var(--pa-sec); }
.pa-mast-aside .date { font-family: var(--pa-serif); font-size: 28px; font-weight: 600; color: var(--pa-ink); letter-spacing: -0.01em; line-height: 1; }
.pa-mast-aside .tag { display: inline-flex; align-items: center; gap: 8px; font-size: 10.5px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--pa-area-accent); margin-top: 6px; justify-content: flex-end; }
.pa-mast-motif { position: absolute; right: 0; top: 28px; width: 220px; height: 100px; pointer-events: none; opacity: 0.85; }

/* === Jump-to nav === */
.pa-jumpto { background: var(--pa-paper); border-bottom: 1px solid var(--pa-border); }
.pa-jumpto .pa-shell { display: flex; align-items: center; gap: 8px; padding-top: 10px; padding-bottom: 10px; overflow-x: auto; }
.pa-jumpto-label { font-size: 10.5px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--pa-muted); margin-right: 8px; white-space: nowrap; }
.pa-jumpto a { font-size: 12.5px; font-weight: 500; color: var(--pa-sec); padding: 6px 12px; border: 1px solid var(--pa-border); border-radius: 999px; white-space: nowrap; background: var(--pa-paper2); transition: all .15s ease; }
.pa-jumpto a:hover { color: var(--pa-area-accent); border-color: var(--pa-area-accent); }

/* === Top grid: From Our Desk + Today in <Area> === */
.pa-top { display: grid; grid-template-columns: 1fr 360px; gap: 48px; padding: 36px 0 8px; }

/* Section primitives */
.pa-sec-head { display: flex; justify-content: space-between; align-items: baseline; padding: 0 0 12px; border-bottom: 2px solid var(--pa-ink); margin-bottom: 18px; }
.pa-sec-title { font-family: var(--pa-sans); font-size: 11px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--pa-ink); display: inline-flex; align-items: center; gap: 10px; }
.pa-sec-title small { font-family: var(--pa-serif); font-style: italic; font-weight: 400; font-size: 12px; color: var(--pa-muted); letter-spacing: 0; text-transform: none; margin-left: 8px; }
.pa-sec-link { font-family: var(--pa-serif); font-style: italic; font-size: 12px; color: var(--pa-area-accent); }
.pa-sec-link:hover { color: var(--pa-blue-hover); }
.pa-sec-link .arrow { display: inline-block; margin-left: 4px; transition: transform .15s; }
.pa-sec-link:hover .arrow { transform: translateX(2px); }
.pa-sec-block { padding: 36px 0; }
.pa-sec-block + .pa-sec-block { border-top: 1px solid var(--pa-light); }

/* From Our Desk — 1 lead spanning + 4 supporting in a 2×2 grid */
.pa-desk-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.pa-desk-grid .pa-desk-lead { grid-column: 1 / -1; padding: 0 0 20px; border-bottom: 1px solid var(--pa-light); margin-bottom: 6px; display: grid; grid-template-columns: 1fr 200px; gap: 28px; align-items: start; }
.pa-desk-cat { display: inline-block; font-size: 10.5px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--pa-area-accent); margin-bottom: 6px; }
.pa-desk-title { font-family: var(--pa-serif); font-size: 24px; font-weight: 600; letter-spacing: -0.012em; line-height: 1.2; color: var(--pa-ink); margin: 0 0 8px; text-wrap: pretty; }
.pa-desk-lead .pa-desk-title { font-size: 32px; line-height: 1.1; letter-spacing: -0.014em; text-wrap: balance; }
.pa-desk:hover .pa-desk-title, .pa-desk-lead:hover .pa-desk-title { color: var(--pa-area-accent); }
.pa-desk-dek { font-family: var(--pa-serif); font-size: 14.5px; line-height: 1.55; color: var(--pa-sec); margin: 0 0 12px; }
.pa-desk-lead .pa-desk-dek { font-size: 16px; }
.pa-desk-byline { display: flex; align-items: center; gap: 8px; font-size: 11.5px; color: var(--pa-muted); }
.pa-desk-byline img { width: 24px; height: 24px; border-radius: 50%; object-fit: cover; }
.pa-desk-byline strong { color: var(--pa-sec); font-weight: 600; }

.pa-desk-stat { background: var(--pa-ink); color: #fff; padding: 16px 18px; position: relative; overflow: hidden; }
.pa-desk-stat::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 3px; background: var(--pa-grad); }
.pa-desk-stat-eye { font-size: 9.5px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,0.55); }
.pa-desk-stat-val { font-family: var(--pa-serif); font-size: 30px; font-weight: 600; line-height: 1; letter-spacing: -0.02em; margin-top: 6px; }
.pa-desk-stat-lbl { font-size: 11.5px; line-height: 1.5; color: rgba(255,255,255,0.72); margin-top: 8px; }

.pa-desk { padding: 6px 0; }

/* Today in <Area> — numbered rundown (right of top grid) */
.pa-rundown { background: var(--pa-paper2); border: 1px solid var(--pa-border); padding: 18px 18px 14px; }
.pa-rundown-head { display: flex; justify-content: space-between; align-items: baseline; padding-bottom: 10px; border-bottom: 1px solid var(--pa-border); margin-bottom: 8px; }
.pa-rundown-title { font-family: var(--pa-serif); font-size: 17px; font-weight: 600; color: var(--pa-ink); letter-spacing: -0.005em; display: inline-flex; align-items: center; gap: 10px; }
.pa-rundown-meta { font-family: var(--pa-sans); font-size: 10.5px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--pa-muted); }
.pa-rundown ol { list-style: none; padding: 0; margin: 0; counter-reset: ru; }
.pa-rundown li { counter-increment: ru; display: grid; grid-template-columns: 28px 1fr; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--pa-light); }
.pa-rundown li:last-child { border-bottom: none; }
.pa-rundown li::before { content: counter(ru, decimal-leading-zero); font-family: var(--pa-serif); font-size: 22px; font-weight: 600; color: var(--pa-area-accent); line-height: 1; font-feature-settings: "tnum"; letter-spacing: -0.02em; }
.pa-rundown li a { display: block; }
.pa-rundown li .h { font-family: var(--pa-serif); font-size: 14px; line-height: 1.3; font-weight: 500; color: var(--pa-ink); }
.pa-rundown li:hover .h { color: var(--pa-area-accent); }
.pa-rundown li .m { font-size: 10.5px; color: var(--pa-muted); margin-top: 3px; }
.pa-rundown li .m b { color: var(--pa-sec); font-weight: 600; }
.pa-page a.pa-rundown-more { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--pa-border); font-family: var(--pa-serif); font-style: italic; font-size: 12.5px; color: var(--pa-area-accent); }
.pa-page a.pa-rundown-more:hover { color: var(--pa-blue-hover); }
.pa-page a.pa-rundown-more .arrow { display: inline-block; transition: transform .15s; }
.pa-page a.pa-rundown-more:hover .arrow { transform: translateX(2px); }

/* === Earnings Pulse (P&C) === */
.pa-earn-recap { display: flex; align-items: center; gap: 22px; padding: 14px 18px; margin-bottom: 16px; background: var(--pa-area-tint); border-left: 3px solid var(--pa-area-accent); }
.pa-earn-recap .lbl { font-family: var(--pa-sans); font-size: 10.5px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--pa-area-accent); }
.pa-earn-recap .txt { font-family: var(--pa-serif); font-size: 14.5px; color: var(--pa-sec); line-height: 1.4; }
.pa-earn-recap .txt b { color: var(--pa-ink); font-weight: 600; }
.pa-earn-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid var(--pa-ink); border-bottom: 1px solid var(--pa-ink); }
.pa-earn-card { padding: 16px 20px; border-right: 1px solid var(--pa-light); }
.pa-earn-card:last-child { border-right: none; }
.pa-earn-name { font-family: var(--pa-sans); font-size: 10.5px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--pa-muted); }
.pa-earn-cr { font-family: var(--pa-serif); font-size: 32px; font-weight: 600; line-height: 1; letter-spacing: -0.02em; color: var(--pa-ink); margin-top: 8px; font-feature-settings: "tnum"; }
.pa-earn-cr-l { font-size: 12px; color: var(--pa-muted); font-family: var(--pa-sans); font-weight: 500; margin-left: 4px; }
.pa-earn-yoy { font-family: var(--pa-sans); font-size: 11.5px; font-weight: 600; margin-top: 6px; font-feature-settings: "tnum"; }
.pa-earn-yoy.up { color: #0d6b3a; }
.pa-earn-yoy.dn { color: #b6312a; }
.pa-earn-yoy::before { content: "▼ "; font-size: 9px; }
.pa-earn-yoy.dn::before { content: "▲ "; }
.pa-earn-quarter { font-size: 10.5px; color: var(--pa-muted); margin-top: 4px; font-family: var(--pa-serif); font-style: italic; }
.pa-earn-foot { font-size: 11.5px; color: var(--pa-muted); margin-top: 14px; font-family: var(--pa-serif); font-style: italic; }
.pa-earn-foot .good { color: #0d6b3a; font-weight: 600; font-style: normal; }

/* === Cat Watch (P&C) === */
.pa-catwatch { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.pa-cw-card { background: var(--pa-paper2); border: 1px solid var(--pa-border); padding: 18px 18px 16px; position: relative; overflow: hidden; }
.pa-cw-card::before { content: ""; position: absolute; inset: 0 auto 0 0; width: 3px; background: var(--pa-area-accent); }
.pa-cw-card.severe::before { background: #b6312a; }
.pa-cw-head { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }
.pa-cw-status { display: inline-flex; align-items: center; gap: 6px; font-size: 10px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--pa-area-accent); }
.pa-cw-card.severe .pa-cw-status { color: #b6312a; }
.pa-cw-name { font-family: var(--pa-serif); font-size: 22px; font-weight: 600; letter-spacing: -0.01em; color: var(--pa-ink); margin: 0 0 4px; }
.pa-cw-meta { font-family: var(--pa-serif); font-style: italic; font-size: 12.5px; color: var(--pa-muted); margin-bottom: 12px; }
.pa-cw-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.pa-cw-stat { font-family: var(--pa-sans); }
.pa-cw-stat-v { font-family: var(--pa-serif); font-size: 18px; font-weight: 600; color: var(--pa-ink); letter-spacing: -0.01em; font-feature-settings: "tnum"; }
.pa-cw-stat-l { font-size: 10px; color: var(--pa-muted); font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; margin-top: 2px; }

/* === CAS Radar / SOA Spotlight === */
.pa-radar { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 28px; }
.pa-radar-item { display: grid; grid-template-columns: 60px 1fr; gap: 14px; padding: 14px 0; border-bottom: 1px solid var(--pa-light); }
.pa-radar-date { font-family: var(--pa-serif); font-size: 11px; color: var(--pa-muted); font-style: italic; padding-top: 4px; }
.pa-radar-tag { display: inline-block; font-size: 9.5px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--pa-area-accent); margin-bottom: 4px; }
.pa-radar-t { font-family: var(--pa-serif); font-size: 14.5px; font-weight: 500; line-height: 1.36; color: var(--pa-ink); }
.pa-radar-item:hover .pa-radar-t { color: var(--pa-area-accent); }
.pa-radar-src { font-size: 11px; color: var(--pa-muted); margin-top: 4px; }
.pa-radar-src b { color: var(--pa-sec); font-weight: 600; }

/* === Newsletter band === */
.pa-newsletter { margin-top: 36px; padding: 32px 0; background: var(--pa-ink); color: #fff; }
.pa-newsletter .pa-shell { display: flex; justify-content: space-between; align-items: center; gap: 32px; }
.pa-newsletter h3 { font-family: var(--pa-serif); font-size: 26px; font-weight: 600; letter-spacing: -0.01em; margin: 0; }
.pa-newsletter h3 em { font-style: normal; color: var(--pa-blue-light); }
.pa-newsletter p { font-size: 13.5px; color: rgba(255,255,255,0.7); margin: 6px 0 0; max-width: 460px; line-height: 1.55; }
.pa-newsletter form { display: flex; gap: 8px; }
.pa-newsletter input { font-family: var(--pa-sans); font-size: 14px; padding: 11px 14px; border: 1px solid rgba(255,255,255,0.25); border-radius: 2px; background: rgba(255,255,255,0.06); color: #fff; width: 240px; }
.pa-newsletter input::placeholder { color: rgba(255,255,255,0.45); }
.pa-newsletter button { font-family: var(--pa-sans); font-size: 13.5px; font-weight: 600; background: #fff; color: var(--pa-ink); border: none; padding: 11px 22px; border-radius: 2px; cursor: pointer; }

/* Responsive */
@media (max-width: 900px) {
  .pa-shell { padding: 0 20px; }
  .pa-mast h1 { font-size: 36px; }
  .pa-mast-grid, .pa-top { grid-template-columns: 1fr; gap: 24px; }
  .pa-mast-aside { flex-direction: row; align-items: baseline; flex-wrap: wrap; gap: 6px 10px; text-align: left; padding-bottom: 0; }
  .pa-mast-aside .day { font-size: 13px; }
  .pa-mast-aside .date { font-size: 15px; font-weight: 600; }
  .pa-mast-aside .tag { font-size: 10px; margin-top: 0; }
  .pa-desk-grid { grid-template-columns: 1fr; }
  .pa-desk-grid .pa-desk-lead { grid-template-columns: 1fr; }
  .pa-earn-strip, .pa-catwatch, .pa-radar { grid-template-columns: 1fr 1fr; }
  .pa-newsletter .pa-shell { flex-direction: column; align-items: flex-start; }
  /* Decorative masthead motif fights the cramped mobile masthead — hide it
     so the headline + dek own the space. */
  .pa-mast-motif { display: none; }
}
@media (max-width: 600px) {
  .pa-earn-strip, .pa-catwatch, .pa-radar { grid-template-columns: 1fr; }
  .pa-mast h1 { font-size: 30px; }
}
