*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --green:#7ED957;--gd:#5ec93a;--gp:#f0fbe8;
  --teal:#79C9CC;--td:#5ab3b6;--tp:#edf8f9;
  --dark:#1a2332;--mid:#1e2b3e;
  --text:#4a5568;--muted:#8a9bb0;
  --border:#e2e8f0;--bg:#fff;--bg2:#f7f9fc;
  --r:10px;--rl:16px;
}
html{scroll-behavior:smooth}
body{font-family:'Nunito',sans-serif;color:var(--text);background:var(--bg2);overflow-x:hidden;line-height:1.65}
.page-hero{background:linear-gradient(135deg,var(--dark) 0%,var(--mid) 100%);padding:3.5rem 5% 3rem;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(121,201,204,.07),transparent 65%);top:-150px;right:-80px;border-radius:50%;pointer-events:none}
.hero-inner{max-width:1100px;margin:0 auto;position:relative;z-index:1}
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:.75rem;color:rgba(255,255,255,.3);margin-bottom:1.25rem;font-weight:600;flex-wrap:wrap}
.breadcrumb a{color:rgba(255,255,255,.38);text-decoration:none;transition:color .15s}
.breadcrumb a:hover{color:rgba(255,255,255,.7)}
.breadcrumb span{color:rgba(255,255,255,.2)}
.hero-eyebrow{font-size:.7rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);margin-bottom:.875rem}
.hero-title{font-family:'Merriweather',serif;font-size:clamp(1.75rem,3vw,2.5rem);color:#fff;line-height:1.2;margin-bottom:.875rem}
.hero-intro{font-size:.9rem;color:rgba(255,255,255,.52);line-height:1.75;max-width:600px;margin-bottom:1.25rem}
.hero-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}
.hero-meta-item{display:flex;align-items:center;gap:5px;font-size:.76rem;color:rgba(255,255,255,.35);font-weight:600}
.hero-meta-dot{width:3px;height:3px;border-radius:50%;background:rgba(255,255,255,.2)}
.page-wrap{max-width:1100px;margin:0 auto;padding:3.5rem 5% 5rem;display:grid;grid-template-columns:220px 1fr;gap:4rem;align-items:start}
.toc{position:sticky;top:84px}
.toc-label{font-size:.68rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.875rem}
.toc-list{list-style:none;display:flex;flex-direction:column;gap:0;border-left:2px solid var(--border)}
.toc-list li a{display:block;padding:.5rem 0 .5rem 1rem;font-size:.8rem;font-weight:700;color:var(--muted);text-decoration:none;transition:color .15s,border-color .15s;border-left:2px solid transparent;margin-left:-2px;line-height:1.4}
.toc-list li a:hover{color:var(--dark)}
.toc-list li a.active{color:var(--td);border-left-color:var(--td)}
.toc-divider{height:1px;background:var(--border);margin:1rem 0}
.toc-updated{padding:.875rem 1rem;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r);margin-top:1.25rem}
.toc-updated-label{font-size:.66rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:3px}
.toc-updated-date{font-size:.84rem;font-weight:800;color:var(--dark)}
.toc-contact{margin-top:.875rem;padding:1rem;background:linear-gradient(135deg,var(--dark),var(--mid));border-radius:var(--r)}
.toc-contact p{font-size:.76rem;color:rgba(255,255,255,.45);line-height:1.6;margin-bottom:.625rem}
.toc-contact a{display:block;background:linear-gradient(135deg,var(--green),var(--gd));color:var(--dark);font-weight:800;font-size:.76rem;padding:8px 0;border-radius:50px;text-align:center;text-decoration:none}
.content-header{margin-bottom:2.5rem;padding-bottom:2rem;border-bottom:2px solid var(--border)}
.content-eyebrow{font-size:.7rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--td);margin-bottom:.75rem}
.content-title{font-family:'Merriweather',serif;font-size:clamp(1.5rem,2.5vw,2rem);color:var(--dark);line-height:1.2;margin-bottom:.875rem}
.content-intro{font-size:.97rem;color:var(--text);line-height:1.8;max-width:640px}
.content-intro strong{color:var(--dark);font-weight:800}
.policy-section{padding:2rem 0;border-bottom:1px solid var(--border)}
.policy-section:last-child{border-bottom:none}
.section-num{font-size:.66rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem}
.section-title{font-family:'Merriweather',serif;font-size:1.15rem;color:var(--dark);margin-bottom:1rem;line-height:1.3}
.section-body{font-size:.95rem;color:var(--text);line-height:1.82}
.section-body p{margin-bottom:.875rem}
.section-body p:last-child{margin-bottom:0}
.section-body ul,.section-body ol{margin:.75rem 0 .875rem 1.5rem;display:flex;flex-direction:column;gap:.5rem}
.section-body li{font-size:.95rem;line-height:1.72}
.section-body strong{color:var(--dark);font-weight:800}
.section-body a{color:var(--td);text-decoration:none;font-weight:700;border-bottom:1px solid rgba(90,179,182,.3);transition:border-color .15s}
.section-body a:hover{border-color:var(--td)}
.section-highlight{background:var(--bg2);border:1.5px solid var(--border);border-left:3px solid var(--teal);border-radius:0 var(--r) var(--r) 0;padding:1rem 1.25rem;margin:1.125rem 0;font-size:.9rem;line-height:1.72}
.foot-inner{max-width:1200px;margin:0 auto}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem;margin-bottom:2.5rem}
.foot-brand p{font-size:.8rem;color:rgba(255,255,255,.38);line-height:1.7;max-width:240px}
.foot-col h4{font-size:.68rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--green);margin-bottom:.875rem}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:6px}
.foot-col ul li a{font-size:.8rem;color:rgba(255,255,255,.38);text-decoration:none;font-weight:600;transition:color .15s}
.foot-col ul li a:hover{color:#fff}
.foot-bottom{padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.07);display:flex;justify-content:space-between;flex-wrap:wrap;gap:.75rem;align-items:center}
.foot-bottom p{font-size:.72rem;color:rgba(255,255,255,.22);font-weight:600}
.foot-legal{display:flex;gap:1rem}
.foot-legal a{font-size:.72rem;color:rgba(255,255,255,.3);text-decoration:none;font-weight:600;transition:color .15s}
.foot-legal a:hover{color:rgba(255,255,255,.65)}
@media(max-width:860px){
  .page-wrap{grid-template-columns:1fr;gap:2rem}
  .toc{position:static;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--rl);padding:1.25rem 1.5rem}
  .toc-list{border-left:none;flex-direction:row;flex-wrap:wrap;gap:.375rem}
  .toc-list li a{border-left:none;border:1.5px solid var(--border);border-radius:50px;padding:5px 13px;margin-left:0;font-size:.76rem}
  .toc-list li a.active{border-color:var(--teal);background:var(--tp);color:var(--td)}
  .toc-divider,.toc-contact,.toc-updated{display:none}
  .foot-grid{grid-template-columns:1fr 1fr;gap:2rem}
}
@media(max-width:640px){
  .page-hero{padding:2rem 4% 1.75rem}
  .hero-title{font-size:1.5rem}
  .page-wrap{padding:2rem 4% 3rem;gap:1.5rem}
  .policy-section{padding:1.5rem 0}
  .section-title{font-size:1rem}
  .section-body,.section-body li{font-size:.9rem}
  .foot-grid{grid-template-columns:1fr;gap:1.25rem}
  .foot-bottom{flex-direction:column;text-align:center}
}

/* ══ LEGAL PAGE ANIMATION UPGRADE ══ */
.hero-orb{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;will-change:transform;z-index:0}
.orb-a{width:400px;height:400px;background:rgba(121,201,204,.06);top:-120px;right:-80px;animation:lg_driftA 24s ease-in-out infinite}
.orb-b{width:260px;height:260px;background:rgba(126,217,87,.04);bottom:-40px;left:5%;animation:lg_driftB 32s ease-in-out infinite}
@keyframes lg_driftA{0%,100%{transform:translate(0,0) scale(1)}35%{transform:translate(-18px,14px) scale(1.03)}70%{transform:translate(12px,-10px) scale(.97)}}
@keyframes lg_driftB{0%,100%{transform:translate(0,0)}50%{transform:translate(26px,-16px) scale(1.04)}}

.hero-grid-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);background-size:68px 68px;transform:perspective(900px) rotateX(20deg) scale(1.3) translateY(-4%);transform-origin:50% 0;opacity:.35;pointer-events:none;z-index:0;mask-image:linear-gradient(to bottom,transparent 0%,black 25%,black 65%,transparent 100%)}

.breadcrumb-anim{opacity:0;animation:lg_fadeUp .4s .05s cubic-bezier(.16,1,.3,1) forwards}
.eyebrow-anim{opacity:0;animation:lg_fadeUp .4s .15s cubic-bezier(.16,1,.3,1) forwards}
.title-anim{opacity:0;animation:lg_fadeUp .55s .25s cubic-bezier(.16,1,.3,1) forwards}
.intro-anim{opacity:0;animation:lg_fadeUp .5s .4s cubic-bezier(.16,1,.3,1) forwards}
.meta-anim{opacity:0;animation:lg_fadeUp .4s .55s cubic-bezier(.16,1,.3,1) forwards}
.content-anim{opacity:0;animation:lg_fadeUp .6s .5s cubic-bezier(.16,1,.3,1) forwards}
@keyframes lg_fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

.read-progress{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--teal),var(--green));width:0%;z-index:300;border-radius:0 2px 2px 0}
