/* practice.css — Shared styles for all 20 practice area pages
   Tokens, nav, header, body content, takeaway, FAQ, subscribe,
   CTA, creative overhaul, enhancements, sticky CTA. */

/* ── Design tokens ── */
:root {
  --navy: #1a2a44;
  --navy-d: #0f1b2e;
  --navy-m: #243354;
  --gold: #9e7b1e;
  --gold-h: #d4aa42;
  --gold-d: #8b6914;
  --cream: #faf6ef;
  --cream2: #f3ece0;
  --text: #111827;
  --text2: #374151;
  --text3: #6b7280;
  --border: #e5e7eb;
  --r: 6px;
  --r2: 12px;
  --r3: 20px;
  --sh: 0 1px 3px rgba(0,0,0,.08);
  --sh2: 0 4px 12px rgba(0,0,0,.1);
}

/* ── Navigation ── */
.pa-nav{background:var(--navy-d);border-bottom:2px solid var(--gold);padding:16px 0}
.pa-nav .wrap{display:flex;align-items:center;justify-content:space-between;max-width:1100px}
.pa-nav__logo{height:40px;width:auto}
.pa-nav__links{display:flex;align-items:center;gap:20px}
.pa-nav__link{font-family:'DM Mono',monospace;font-size:0.72rem;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.8);transition:color 0.2s;padding:8px 0}
.pa-nav__link:hover{color:var(--gold)}

/* ── Header ── */
.pa-header{background:var(--navy);padding:56px 0 48px;color:#fff;text-align:center}
.pa-header .eyebrow{font-family:'DM Mono',monospace;font-size:0.6rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold);font-weight:500;margin-bottom:12px}
.pa-header h1{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.6rem,4vw,2.4rem);font-weight:800;margin-bottom:12px;color:#fff}
.pa-header .statute{font-family:'DM Mono',monospace;font-size:0.78rem;letter-spacing:0.04em;color:rgba(255,255,255,0.65);background:rgba(255,255,255,0.06);display:inline-block;padding:6px 16px;border-radius:var(--r);border:1px solid rgba(255,255,255,0.1)}

/* ── Legacy header (gl- pattern) ── */
.pa-hdr{background:#1a2a44;padding:clamp(40px,6vw,64px) clamp(16px,5vw,32px);text-align:center;color:#fff;border-bottom:3px solid #9e7b1e}
.pa-eyebrow{font-family:'DM Mono',monospace;font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;color:#9e7b1e;margin-bottom:16px;display:block}
.pa-title{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.5rem,3.5vw,2.2rem);font-weight:800;color:#fff;line-height:1.2;margin-bottom:12px}
.pa-title em{font-style:italic;color:#d4aa42}
.pa-meta{font-size:.85rem;font-weight:300;color:rgba(255,255,255,.65);max-width:520px;margin:0 auto;line-height:1.6}
.pa-meta strong{color:#fff;font-weight:500}

/* ── Body content (pa-body pattern) ── */
.pa-body{padding:clamp(32px,5vw,48px) 0}
.pa-body h2{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.15rem,2.5vw,1.4rem);font-weight:700;color:#1a2a44;margin:36px 0 16px;line-height:1.3}
.pa-body h2:first-child{margin-top:0}
.pa-body h3{font-family:'Playfair Display',Georgia,serif;font-size:1.05rem;font-weight:700;color:#1a2a44;margin:24px 0 10px;line-height:1.3}
.pa-body p{font-size:.95rem;font-weight:300;line-height:1.85;color:#374151;margin-bottom:14px}
.pa-body ul,.pa-body ol{margin:0 0 14px 20px}
.pa-body li{font-size:.95rem;font-weight:300;line-height:1.85;color:#374151;margin-bottom:8px}
.pa-body ol{list-style:decimal}
.pa-body ul{list-style:disc}
.pa-body strong{color:#1a2a44;font-weight:500}

/* ── Body content (gl-body pattern — identical rules, different prefix) ── */
.gl-body{padding:clamp(32px,5vw,48px) 0}
.gl-body h2{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.15rem,2.5vw,1.4rem);font-weight:700;color:#1a2a44;margin:36px 0 16px;line-height:1.3}
.gl-body h2:first-child{margin-top:0}
.gl-body h3{font-family:'Playfair Display',Georgia,serif;font-size:1.05rem;font-weight:700;color:#1a2a44;margin:24px 0 10px;line-height:1.3}
.gl-body p{font-size:.95rem;font-weight:300;line-height:1.85;color:#374151;margin-bottom:14px}
.gl-body ul,.gl-body ol{margin:0 0 14px 20px}
.gl-body li{font-size:.95rem;font-weight:300;line-height:1.85;color:#374151;margin-bottom:8px}
.gl-body ol{list-style:decimal}
.gl-body ul{list-style:disc}
.gl-body strong{color:#1a2a44;font-weight:500}

/* ── Takeaway boxes ── */
.pa-takeaway,.gl-takeaway{background:#f5f3f0;border-left:3px solid #9e7b1e;padding:20px 24px;border-radius:0 8px 8px 0;margin:24px 0}
.pa-takeaway strong,.gl-takeaway strong{font-family:'DM Mono',monospace;font-size:.55rem;letter-spacing:.12em;text-transform:uppercase;color:#9e7b1e;display:block;margin-bottom:8px}
.pa-takeaway p,.gl-takeaway p{font-size:.9rem;font-weight:300;line-height:1.8;color:#374151;margin:0 0 8px}
.pa-takeaway p:last-child,.gl-takeaway p:last-child{margin-bottom:0}
.pa-takeaway ul,.gl-takeaway ul{margin:8px 0 0 20px;list-style:disc}
.pa-takeaway li,.gl-takeaway li{font-size:.9rem;font-weight:300;line-height:1.8;color:#374151;margin-bottom:4px}

/* ── Statute references ── */
.pa-statute,.gl-statute{font-family:'DM Mono',monospace;font-size:.75rem;color:#8b6914;background:rgba(196,154,46,.08);padding:2px 8px;border-radius:4px;white-space:nowrap}

/* ── FAQ (details/summary pattern) ── */
.pa-faq{margin:36px 0}
.pa-faq details{border:1px solid #eaeaea;border-radius:8px;margin-bottom:10px;background:#fff}
.pa-faq summary{padding:16px 20px;font-weight:500;font-size:.95rem;cursor:pointer;color:#1a2a44;list-style:none;display:flex;justify-content:space-between;align-items:center}
.pa-faq summary::-webkit-details-marker{display:none}
.pa-faq summary::after{content:'+';font-family:'DM Mono',monospace;font-size:1.1rem;color:#9e7b1e;flex-shrink:0;margin-left:12px}
.pa-faq details[open] summary::after{content:'-'}
.pa-faq .faq-answer{padding:0 20px 16px;font-size:.9rem;font-weight:300;line-height:1.8;color:#374151}

/* ── FAQ (gl- div pattern) ── */
.gl-faq h2{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.15rem,2.5vw,1.4rem);font-weight:700;color:#1a2a44;margin:36px 0 16px;line-height:1.3}
.gl-faq-item{border:1px solid #eaeaea;border-radius:8px;margin-bottom:10px;background:#fff;overflow:hidden}
.gl-faq-q{padding:16px 20px;font-weight:500;font-size:.95rem;color:#1a2a44;cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.gl-faq-q::after{content:'+';font-family:'DM Mono',monospace;font-size:1.1rem;color:#9e7b1e;flex-shrink:0;margin-left:12px}
.gl-faq-item.open .gl-faq-q::after{content:'\2212'}
.gl-faq-a{display:none;padding:0 20px 16px;font-size:.9rem;font-weight:300;line-height:1.8;color:#374151}
.gl-faq-item.open .gl-faq-a{display:block}

/* ── Subscribe ── */
.pa-subscribe,.gl-subscribe{background:#1a2a44;border-radius:12px;padding:clamp(28px,4vw,40px);text-align:center;margin:clamp(32px,5vw,48px) 0}
.pa-subscribe h3,.gl-subscribe h3{font-family:'Playfair Display',Georgia,serif;font-size:1.3rem;font-weight:700;color:#fff;margin-bottom:8px}
.pa-subscribe p,.gl-subscribe p{font-size:.9rem;font-weight:300;color:rgba(255,255,255,.65);margin-bottom:20px;max-width:420px;margin-left:auto;margin-right:auto}
.pa-subscribe-form,.gl-subscribe-form{display:flex;gap:8px;max-width:420px;margin:0 auto}
.pa-subscribe-form input,.gl-subscribe-form input{flex:1;padding:12px 16px;border:1.5px solid rgba(255,255,255,.15);border-radius:6px;background:rgba(255,255,255,.08);color:#fff;font-family:'Outfit',sans-serif;font-size:.9rem;font-weight:300;min-height:48px}
.pa-subscribe-form input::placeholder,.gl-subscribe-form input::placeholder{color:rgba(255,255,255,.6)}
.pa-subscribe-form input:focus,.gl-subscribe-form input:focus{border-color:#9e7b1e;outline:3px solid #9e7b1e;outline-offset:1px;box-shadow:none}
.pa-subscribe-form button,.gl-subscribe-form button{padding:12px 24px;background:#9e7b1e;color:#000;font-family:'DM Mono',monospace;font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;font-weight:500;border:none;border-radius:6px;cursor:pointer;white-space:nowrap;min-height:48px;transition:background .2s}
.pa-subscribe-form button:hover,.gl-subscribe-form button:hover{background:#d4aa42}
.pa-sub-note,.gl-sub-note{font-size:.65rem;color:rgba(255,255,255,.35);margin-top:10px}
@media(max-width:500px){.pa-subscribe-form,.gl-subscribe-form{flex-direction:column}.pa-subscribe-form button,.gl-subscribe-form button{width:100%}}

/* ── CTA ── */
.pa-cta,.gl-cta{background:#1a2a44;color:#fff;padding:32px;border-radius:12px;text-align:center;margin-top:clamp(32px,5vw,48px)}
.pa-cta p,.gl-cta p{font-size:.95rem;font-weight:300;line-height:1.75;color:rgba(255,255,255,.8);margin-bottom:16px}
.pa-cta a.pa-cta-btn,.gl-cta a.gl-cta-btn{display:inline-block;background:#9e7b1e;color:#000;font-weight:600;padding:12px 28px;border-radius:6px;font-size:.85rem;transition:background .2s}
.pa-cta a.pa-cta-btn:hover,.gl-cta a.gl-cta-btn:hover{background:#d4aa42;color:#0f1b2e}

/* ── Footer ── */
.pa-footer,.gl-footer{text-align:center;padding:32px 0;font-size:.7rem;color:#6b7280;line-height:1.7}
.pa-footer a,.gl-footer a{color:#1a2a44}

/* ── Creative overhaul ── */
.section-navy{background:var(--navy,#1a2a44);color:#fff;margin:40px calc(-50vw + 340px);padding:40px calc(50vw - 340px);border-radius:0}
.section-navy h2,.section-navy h3{color:#fff}
.section-navy p,.section-navy li{color:rgba(255,255,255,0.75)}
.section-navy strong{color:#fff}
.section-navy a.inline-link{color:#d4aa42;border-bottom-color:rgba(212,170,66,0.3)}
.section-navy .callout{background:rgba(255,255,255,0.05);border-left-color:#d4aa42;color:rgba(255,255,255,0.85)}
.section-navy .callout strong{color:#d4aa42}
.section-navy .callout-warning{background:rgba(180,147,9,0.12);border-left-color:#d4aa42;color:rgba(255,255,255,0.85)}
.section-navy .callout-warning strong{color:#d4aa42}
.section-navy .damages-table th{background:rgba(255,255,255,0.08);color:rgba(255,255,255,0.5);border-bottom-color:rgba(255,255,255,0.1)}
.section-navy .damages-table td{color:rgba(255,255,255,0.8);border-bottom-color:rgba(255,255,255,0.08)}
.section-navy .damages-table td strong{color:#fff}
.gold-rule{width:48px;height:3px;background:#9e7b1e;border:none;margin:20px auto 24px;border-radius:2px}
.reveal{opacity:0;transform:translateY(24px);transition:opacity 0.6s ease,transform 0.6s ease}
.reveal.vis{opacity:1;transform:translateY(0)}
.faq-section{margin-top:48px;padding-top:40px;border-top:1px solid var(--border,#e5e7eb)}
.cta-section{position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;top:0;right:0;width:35%;height:100%;background:linear-gradient(135deg,transparent,rgba(158,123,30,0.08));pointer-events:none}

/* ── Quick answer box ── */
.quick-answer{background:linear-gradient(135deg,#f8f5f0 0%,#fafaf8 100%);border-left:4px solid #9e7b1e;border-radius:8px;padding:22px 26px;margin:24px 0 36px;box-shadow:0 1px 3px rgba(26,42,68,0.04)}
.quick-answer__label{font-family:'DM Mono',monospace;font-size:0.6rem;letter-spacing:0.16em;text-transform:uppercase;color:#9e7b1e;margin-bottom:10px;font-weight:500}
.quick-answer__body{font-size:0.95rem;line-height:1.65;color:#1a2a44;margin:0!important;max-width:none!important}

/* ── Table of contents ── */
.page-toc{background:#fff;border:1px solid #eaeaea;border-radius:8px;padding:20px 24px;margin:0 0 36px}
.page-toc__label{font-family:'DM Mono',monospace;font-size:0.58rem;letter-spacing:0.16em;text-transform:uppercase;color:#6b7280;margin-bottom:12px;font-weight:500}
.page-toc__list{list-style:decimal;padding-left:22px;margin:0;columns:2;column-gap:32px}
.page-toc__list li{margin-bottom:6px;break-inside:avoid;color:#6b7280;font-size:0.85rem;padding-left:4px}
.page-toc__list a{color:#1a2a44;border-bottom:1px solid transparent;transition:border-color 0.2s,color 0.2s}
.page-toc__list a:hover{color:#9e7b1e;border-bottom-color:#9e7b1e}
@media(max-width:600px){.page-toc__list{columns:1}}

/* ── Sticky CTA ── */
.sticky-cta{position:fixed;bottom:24px;right:24px;z-index:9000;display:inline-flex;align-items:center;gap:8px;background:#9e7b1e;color:#0f1b2e;font-family:'DM Mono',monospace;font-size:0.7rem;letter-spacing:0.08em;text-transform:uppercase;font-weight:600;padding:14px 22px;border-radius:100px;text-decoration:none;box-shadow:0 8px 24px rgba(158,123,30,0.35),0 2px 6px rgba(0,0,0,0.1);transition:transform 0.2s,box-shadow 0.2s,background 0.2s;opacity:0;transform:translateY(20px);pointer-events:none}
.sticky-cta.visible{opacity:1;transform:translateY(0);pointer-events:auto}
.sticky-cta:hover{background:#b8902a;transform:translateY(-2px);box-shadow:0 12px 32px rgba(158,123,30,0.45),0 4px 8px rgba(0,0,0,0.12)}
@media(max-width:600px){.sticky-cta{bottom:16px;right:16px;padding:12px 18px;font-size:0.62rem}}
@media print{.sticky-cta,.page-toc{display:none!important}}
