/* ============================================
   ZIGO — Design System (Static Multi-page)
   ============================================ */

/* ---------- Reset & Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  color:#1c1917;
  background:#fafaf9;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none}
ul,ol{list-style:none}

/* ---------- Container ---------- */
.container{width:100%;max-width:72rem;margin:0 auto;padding:0 1.25rem}
@media(min-width:640px){.container{padding:0 1.5rem}}
@media(min-width:1024px){.container{padding:0 2rem}}

/* ---------- Typography ---------- */
.heading-display{font-weight:800;letter-spacing:-.03em;line-height:1.08}
.heading-h1{font-weight:700;letter-spacing:-.02em;line-height:1.15}
.heading-h2{font-weight:700;letter-spacing:-.015em;line-height:1.2}
.heading-h3{font-weight:700;line-height:1.3}
.body-lg{font-size:1.125rem;line-height:1.7}
.body-base{font-size:1rem;line-height:1.7}
.body-sm{font-size:.875rem;line-height:1.6}

/* ---------- Gradients ---------- */
.gradient-primary{background:linear-gradient(135deg,#ef4444,#f97316)}
.gradient-secondary{background:linear-gradient(135deg,#3b82f6,#ef4444)}
.gradient-hero{background:linear-gradient(135deg,#fef2f2,#fff7ed)}

/* ---------- Cards ---------- */
.zigo-card-premium{
  border:1px solid rgba(28,25,23,.06);
  border-radius:1.25rem;
  box-shadow:0 1px 2px rgba(28,25,23,.04),0 4px 16px -4px rgba(28,25,23,.06);
  transition:box-shadow .35s ease,transform .35s ease,border-color .35s ease;
}
.zigo-card-premium:hover{
  box-shadow:0 1px 2px rgba(28,25,23,.04),0 20px 48px -16px rgba(28,25,23,.12);
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.625rem 1.5rem;border-radius:.5rem;
  font-weight:600;font-size:.9375rem;
  transition:all .2s ease;
}
.btn-primary{background:linear-gradient(135deg,#ef4444,#f97316);color:#fff;box-shadow:0 4px 12px rgba(239,68,68,.2)}
.btn-primary:hover{box-shadow:0 6px 20px rgba(239,68,68,.3);transform:translateY(-1px)}
.btn-ghost{color:#57534e;background:transparent}
.btn-ghost:hover{background:#f5f5f4;color:#1c1917}

/* ---------- Navigation ---------- */
.nav-wrap{
  position:sticky;top:0;z-index:50;
  border-bottom:1px solid rgba(214,211,209,.9);
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(16px) saturate(1.5);
  -webkit-backdrop-filter:blur(16px) saturate(1.5);
  transition:box-shadow .3s;
}
.nav-wrap.scrolled{box-shadow:0 1px 0 rgba(28,25,23,.06),0 12px 32px -20px rgba(28,25,23,.1)}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  min-height:4.25rem;gap:1.5rem;padding:.75rem 0;
}
@media(min-width:640px){.nav-inner{min-height:4.5rem;padding:1rem 0;gap:2.5rem}}
.nav-logo{display:flex;align-items:center;gap:.75rem;padding:.25rem .5rem .25rem 0;border-radius:.5rem;transition:opacity .2s}
.nav-logo:hover{opacity:.8}
.nav-logo img{height:2.25rem;width:auto;object-fit:contain}
@media(min-width:640px){.nav-logo img{height:2.5rem}}
.nav-logo-text{display:none}
@media(min-width:400px){.nav-logo-text{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;line-height:1}}
.nav-logo-name{font-size:.9375rem;font-weight:600;letter-spacing:-.02em;color:#1c1917}
.nav-logo-sub{font-size:.6875rem;font-weight:500;color:#78716c;letter-spacing:.05em}
.nav-links{display:none;align-items:center;gap:.125rem}
@media(min-width:768px){.nav-links{display:flex;flex:1;justify-content:center}}
.nav-links a{
  position:relative;padding:.5rem .75rem;font-size:.875rem;font-weight:500;color:#78716c;
  transition:color .2s;
}
@media(min-width:1024px){.nav-links a{padding:.5rem 1rem}}
.nav-links a:hover{color:#1c1917}
.nav-links a::after{
  content:'';position:absolute;left:.75rem;right:.75rem;bottom:.25rem;
  height:1px;background:rgba(28,25,23,.8);transform:scaleX(0);
  transform-origin:center;transition:transform .2s;
}
@media(min-width:1024px){.nav-links a::after{left:1rem;right:1rem}}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-actions{display:flex;align-items:center;gap:.5rem}
@media(min-width:640px){.nav-actions{gap:.75rem}}
.nav-cta{
  display:none;font-size:.8125rem;font-weight:600;letter-spacing:-.01em;
  padding:.375rem .875rem;border-radius:9999px;
  border:1.5px solid rgba(239,68,68,.35);color:#dc2626;
  transition:all .25s ease;
}
@media(min-width:640px){.nav-cta{display:inline-flex;align-items:center}}
.nav-cta:hover{background:rgba(239,68,68,.06);border-color:#ef4444;color:#b91c1c}
.menu-btn{
  display:flex;width:2.5rem;height:2.5rem;align-items:center;justify-content:center;
  border-radius:.5rem;color:#44403c;transition:background .2s;
}
@media(min-width:768px){.menu-btn{display:none}}
.menu-btn:hover{background:#f5f5f4}
.mobile-menu{
  display:none;border-bottom:1px solid rgba(214,211,209,.9);
  background:rgba(255,255,255,.95);backdrop-filter:blur(12px);
  animation:slideDown .2s ease;
}
@media(min-width:768px){.mobile-menu{display:none!important}}
.mobile-menu.open{display:block}
.mobile-menu-inner{padding:.25rem 0 1rem;display:flex;flex-direction:column;gap:.125rem}
.mobile-menu a{
  display:block;padding:.75rem .5rem;font-size:.9375rem;font-weight:500;
  color:#44403c;border-radius:.5rem;transition:all .2s;
}
.mobile-menu a:hover{background:#f5f5f4;color:#1c1917}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;padding:3rem 0 6rem}
@media(min-width:640px){.hero{padding:4rem 0 6rem}}
@media(min-width:1024px){.hero{padding:5rem 0 9rem}}
.hero-grid{display:grid;grid-template-columns:1fr;gap:3.5rem;align-items:center}
@media(min-width:1024px){.hero-grid{grid-template-columns:1fr 1fr;gap:5rem}}
.hero-tag{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.2em;color:rgba(220,38,38,.9)}
.hero-title{font-size:2.25rem;font-weight:800;color:#1c1917;letter-spacing:-.03em;line-height:1.08}
@media(min-width:640px){.hero-title{font-size:3rem}}
@media(min-width:1024px){.hero-title{font-size:3.35rem}}
@media(min-width:1280px){.hero-title{font-size:3.75rem}}
.hero-desc{font-size:1.125rem;color:#57534e;line-height:1.7;max-width:36rem}
@media(min-width:1024px){.hero-desc{font-size:1.25rem}}
.hero-pill{
  display:inline-flex;align-items:center;gap:.625rem;
  padding:.5rem 1rem;border-radius:9999px;
  background:rgba(255,255,255,.8);border:1px solid rgba(214,211,209,.7);
  box-shadow:0 1px 3px rgba(0,0,0,.05);backdrop-filter:blur(4px);
  font-size:.875rem;font-weight:600;color:#44403c;letter-spacing:-.01em;
}
.hero-pill .dot{
  width:8px;height:8px;border-radius:50%;
  background:linear-gradient(135deg,#ef4444,#f97316);
  animation:pulseSoft 2.8s ease-in-out infinite;
}
.hero-image-wrap{position:relative}
@media(min-width:1024px){.hero-image-wrap{min-height:min(32rem,70vh)}}
.hero-image-card{
  position:relative;overflow:hidden;border-radius:1.25rem;
  border:1px solid rgba(28,25,23,.04);
  box-shadow:0 1px 2px rgba(0,0,0,.04),0 8px 32px -8px rgba(0,0,0,.1);
}
.hero-image-card img{
  width:100%;height:100%;min-height:20rem;object-fit:cover;
  transition:transform 1.2s ease;
}
@media(min-width:1024px){.hero-image-card img{min-height:28rem}}
.hero-image-card:hover img{transform:scale(1.02)}
.hero-image-overlay{
  position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(to top,rgba(28,25,23,.25),transparent,rgba(28,25,23,.03));
}
.hero-blob{
  position:absolute;border-radius:50%;pointer-events:none;
  filter:blur(48px);
}
.hero-blob-1{top:-8rem;right:-20%;width:28rem;height:28rem;background:linear-gradient(135deg,rgba(239,68,68,.15),rgba(251,146,60,.1));animation:float 18s ease-in-out infinite}
.hero-blob-2{bottom:-10rem;left:-15%;width:26rem;height:26rem;background:linear-gradient(225deg,rgba(251,146,60,.12),rgba(239,68,68,.08));animation:float 22s ease-in-out infinite reverse}

/* ---------- Sections ---------- */
.section{padding:6rem 0;position:relative;overflow:hidden}
@media(min-width:1024px){.section{padding:8rem 0}}
.section-alt{background:linear-gradient(to bottom,#f5f5f4,#fff,#fafaf9);border-top:1px solid rgba(214,211,209,.5);border-bottom:1px solid rgba(214,211,209,.5)}
.section-header{text-align:center;max-width:48rem;margin:0 auto 3.5rem;padding:0 .5rem}
@media(min-width:1024px){.section-header{margin-bottom:5rem}}
.section-title{font-size:1.875rem;color:#1c1917;letter-spacing:-.02em}
@media(min-width:640px){.section-title{font-size:2.25rem}}
@media(min-width:1024px){.section-title{font-size:3rem}}
.section-desc{margin-top:1.25rem;font-size:1.125rem;color:#57534e;line-height:1.7}

/* ---------- Mode Cards ---------- */
.modes-grid{display:grid;grid-template-columns:1fr;gap:2rem}
@media(min-width:1024px){.modes-grid{grid-template-columns:1fr 1fr;gap:2.5rem}}
.mode-card{
  position:relative;padding:2.25rem;border-radius:1.35rem;
  background:#fff;overflow:hidden;height:100%;
  transition:all .5s ease;
}
@media(min-width:1024px){.mode-card{padding:2.5rem}}
.mode-card:hover{transform:translateY(-4px)}
.mode-card.red:hover{border-color:rgba(254,202,202,.8);box-shadow:0 32px 64px -28px rgba(220,38,38,.18)}
.mode-card.orange:hover{border-color:rgba(254,215,170,.8);box-shadow:0 32px 64px -28px rgba(234,88,12,.15)}
.mode-card-glow{
  position:absolute;width:12rem;height:12rem;border-radius:50%;
  background:rgba(254,226,226,.5);filter:blur(48px);
  opacity:.7;transition:opacity .5s;
}
.mode-card:hover .mode-card-glow{opacity:1}
.red .mode-card-glow{top:0;right:0;background:rgba(254,226,226,.5)}
.orange .mode-card-glow{top:0;left:0;background:rgba(255,237,213,.5)}
.mode-icon{
  width:3.5rem;height:3.5rem;border-radius:1rem;
  display:flex;align-items:center;justify-content:center;
  color:#fff;flex-shrink:0;
  box-shadow:0 4px 12px rgba(0,0,0,.15);
  transition:transform .3s;
}
.mode-card:hover .mode-icon{transform:scale(1.04)}
.mode-icon.red{background:linear-gradient(135deg,#ef4444,#f97316)}
.mode-icon.orange{background:linear-gradient(135deg,#f97316,#ef4444)}
.mode-head{display:flex;align-items:center;gap:1rem;margin-bottom:1.75rem;position:relative}
.mode-title{font-size:1.25rem;font-weight:700;color:#1c1917;letter-spacing:-.01em}
@media(min-width:1024px){.mode-title{font-size:1.5rem}}
.mode-sub{font-size:.875rem;font-weight:600;margin-top:.125rem}
.red .mode-sub{color:#dc2626}
.orange .mode-sub{color:#ea580c}
.mode-body{color:#57534e;line-height:1.7;margin-bottom:1.75rem;position:relative}
.mode-list{display:flex;flex-direction:column;gap:.875rem;margin-bottom:2rem;position:relative}
.mode-list li{display:flex;align-items:center;gap:.75rem;font-weight:500;font-size:.95rem;color:#44403c}
.mode-list li svg{flex-shrink:0;opacity:.9}
.mode-footer{padding-top:1.5rem;border-top:1px solid rgba(214,211,209,.8);position:relative}
.mode-footer p{font-size:.875rem;color:#78716c;line-height:1.6}
.gamification-note{
  border-radius:1.25rem;padding:2rem 2.5rem;text-align:center;
  background:linear-gradient(90deg,rgba(254,242,242,.9),rgba(255,237,213,.8),rgba(254,242,242,.9));
  border:1px solid rgba(254,226,226,.6);font-weight:500;color:#44403c;line-height:1.7;
  max-width:64rem;margin:0 auto;
}

/* ---------- Features ---------- */
.feature-row{
  display:grid;grid-template-columns:1fr;gap:3rem;align-items:center;
}
@media(min-width:1024px){.feature-row{grid-template-columns:1fr 1fr;gap:4rem}}
.feature-row+.feature-row{margin-top:2.5rem;padding-top:2.5rem;border-top:1px solid rgba(214,211,209,.6)}
.feature-row.reverse .feature-text{order:1}
@media(min-width:1024px){.feature-row.reverse .feature-text{order:2}}
.feature-row.reverse .feature-visual{order:2}
@media(min-width:1024px){.feature-row.reverse .feature-visual{order:1}}
.feature-head{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}
.feature-icon{
  width:3rem;height:3rem;border-radius:.75rem;
  background:linear-gradient(135deg,#ef4444,#f97316);
  display:flex;align-items:center;justify-content:center;
  color:#fff;flex-shrink:0;
  box-shadow:0 4px 12px rgba(239,68,68,.15);
  transition:transform .3s;
}
.feature-row:hover .feature-icon{transform:scale(1.05)}
.feature-ftitle{font-weight:700;color:#1c1917;letter-spacing:-.01em}
.feature-fsub{font-size:.875rem;font-weight:600;color:#ea580c;margin-top:.25rem}
.feature-desc{font-size:1.125rem;color:#57534e;line-height:1.7;max-width:36rem}
.feature-line{width:4rem;height:2px;border-radius:9999px;background:linear-gradient(90deg,rgba(239,68,68,.6),rgba(251,146,60,.4));margin-top:.5rem}
.feature-img-card{
  position:relative;overflow:hidden;border-radius:1.25rem;
  background:linear-gradient(135deg,#fef2f2,#fff7ed);
  border:1px solid rgba(28,25,23,.04);
  box-shadow:0 1px 2px rgba(0,0,0,.04),0 12px 40px -12px rgba(0,0,0,.1);
  transition:box-shadow .4s ease;
}
.feature-img-card:hover{
  box-shadow:0 1px 2px rgba(0,0,0,.04),0 20px 56px -16px rgba(239,68,68,.14);
}
.feature-img-card img{width:100%;max-height:22rem;object-fit:contain;padding:1.5rem;transition:transform .6s ease}
.feature-img-card:hover img{transform:scale(1.04)}
@media(min-width:640px){.feature-img-card img{padding:2rem}}
@media(min-width:1024px){.feature-img-card img{padding:2.5rem}}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:768px){.contact-grid{grid-template-columns:1fr 1fr;gap:2rem}}
.contact-card{
  position:relative;padding:2rem;border-radius:1.25rem;
  background:#fff;overflow:hidden;height:100%;
  transition:all .3s ease;
}
.contact-card:hover{transform:translateY(-2px)}
.contact-card .card-glow{
  position:absolute;width:10rem;height:10rem;border-radius:50%;
  filter:blur(32px);opacity:0;transition:opacity .5s;
}
.contact-card:hover .card-glow{opacity:1}
.contact-icon{
  width:3rem;height:3rem;border-radius:.75rem;
  display:flex;align-items:center;justify-content:center;color:#fff;
  flex-shrink:0;box-shadow:0 4px 12px rgba(0,0,0,.1);
}
.contact-link{font-weight:600;display:inline-flex;align-items:center;gap:.5rem;transition:all .2s}
.contact-link:hover{gap:.75rem}
.contact-link svg{transition:transform .2s}
.contact-link:hover svg{transform:translateX(2px)}

/* ---------- Legal / Docs Section ---------- */
.docs-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;max-width:72rem;margin:0 auto}
@media(min-width:640px){.docs-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:2rem}}
.doc-card{
  display:flex;flex-direction:column;padding:2rem;border-radius:1.25rem;
  background:#fff;overflow:hidden;position:relative;height:100%;
  transition:all .3s ease;
}
@media(min-width:1024px){.doc-card{padding:2.25rem}}
.doc-card:hover{transform:translateY(-4px)}
.doc-card .card-glow{
  position:absolute;width:9rem;height:9rem;border-radius:50%;
  filter:blur(32px);opacity:.6;transition:opacity .3s;
}
.doc-card:hover .card-glow{opacity:1}
.doc-icon{
  width:3.5rem;height:3.5rem;border-radius:.75rem;
  display:flex;align-items:center;justify-content:center;color:#fff;
  margin-bottom:1.5rem;box-shadow:0 4px 12px rgba(0,0,0,.1);
  flex-shrink:0;position:relative;z-index:10;
  transition:transform .3s;
}
.doc-card:hover .doc-icon{transform:scale(1.04)}
.doc-card h3{font-size:1.25rem;font-weight:700;color:#1c1917;margin-bottom:.75rem;position:relative;z-index:10;letter-spacing:-.01em}
.doc-card p{font-size:.875rem;color:#57534e;line-height:1.6;flex-grow:1;margin-bottom:2rem;position:relative;z-index:10}
.doc-link{
  display:flex;align-items:center;gap:.5rem;font-weight:600;
  position:relative;z-index:10;transition:gap .3s;
}
.doc-card:hover .doc-link{gap:.75rem}

/* ---------- Footer ---------- */
.footer{background:#0c0a09;color:#fff;padding:4rem 0 2.5rem;position:relative;overflow:hidden}
.footer-blob{position:absolute;top:0;right:0;width:16rem;height:16rem;border-radius:50%;background:rgba(220,38,38,.1);filter:blur(48px);pointer-events:none}
.footer-grid{display:grid;grid-template-columns:1fr;gap:3rem;margin-bottom:3rem;position:relative}
@media(min-width:768px){.footer-grid{grid-template-columns:1fr 1fr 1fr}}
.footer h4{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#d6d3d1;margin-bottom:1rem}
.footer ul{display:flex;flex-direction:column;gap:.75rem}
.footer ul a{font-size:.875rem;color:#78716c;transition:color .2s}
.footer ul a:hover{color:#fff}
.footer-bottom{border-top:1px solid #292524;padding-top:2rem;text-align:center;font-size:.875rem;color:#78716c;position:relative}

/* ---------- Legal Pages (Privacy / Terms) ---------- */
.legal-header{
  background:linear-gradient(90deg,#fef2f2,#eff6ff);
  border-bottom:1px solid #f3f4f6;
  padding:1.5rem 0 1.75rem;
}
.legal-header.terms{background:linear-gradient(90deg,#eff6ff,#fef2f2)}
.legal-header.delete{background:linear-gradient(90deg,#fff7ed,#fef2f2)}
.legal-header .back-btn{
  display:inline-flex;align-items:center;gap:.5rem;
  margin-bottom:.625rem;padding:.375rem .75rem;border-radius:.5rem;
  font-size:.875rem;font-weight:500;color:#57534e;
  transition:all .2s;
}
.legal-header .back-btn:hover{background:#f5f5f4;color:#1c1917}
.legal-header h1{font-size:1.625rem;font-weight:700;color:#1c1917;letter-spacing:-.02em}
@media(min-width:640px){.legal-header h1{font-size:2rem}}
.legal-header .date{font-size:.9375rem;color:#57534e;margin-top:.5rem}
.legal-content{padding:3rem 0}
.legal-inner{max-width:48rem;margin:0 auto}

/* Info box */
.info-box{
  padding:1.5rem;border-radius:.75rem;margin-bottom:3rem;
  display:flex;gap:1rem;
}
.info-box.blue{background:#eff6ff;border:2px solid #bfdbfe}
.info-box.yellow{background:#fefce8;border-left:4px solid #facc15;border-radius:.5rem;padding:1.25rem}
.info-box-icon{flex-shrink:0;margin-top:.125rem}
.info-box-title{font-weight:600;color:#1e293b;margin-bottom:.25rem}
.info-box-text{font-size:.875rem;color:#374151;line-height:1.6}
.yellow .info-box-title{color:#713f12}
.yellow .info-box-text{color:#854d0e}

/* Accordion */
.accordion{display:flex;flex-direction:column;gap:.75rem;margin-bottom:3rem}
.accordion-item{border:1px solid #e5e7eb;border-radius:.5rem;overflow:hidden;transition:border-color .2s}
.accordion-item:hover{border-color:#d1d5db}
.accordion-btn{
  width:100%;padding:1.25rem;display:flex;align-items:center;justify-content:space-between;
  background:#fff;transition:background .2s;text-align:left;
}
.accordion-btn:hover{background:#f9fafb}
.accordion-btn-left{display:flex;align-items:center;gap:1rem;flex:1}
.accordion-icon-wrap{
  width:2.5rem;height:2.5rem;border-radius:.5rem;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.accordion-icon-wrap.red{background:#fef2f2}
.accordion-icon-wrap.blue{background:#eff6ff}
.accordion-icon-wrap.red svg{color:#ef4444}
.accordion-icon-wrap.blue svg{color:#3b82f6}
.accordion-btn h3{font-weight:700;color:#111827}
.accordion-chevron{
  color:#9ca3af;flex-shrink:0;margin-left:1rem;
  transition:transform .3s ease;
}
.accordion-item.open .accordion-chevron{transform:rotate(180deg)}
.accordion-body{
  max-height:0;overflow:hidden;transition:max-height .35s ease;
}
.accordion-body-inner{
  padding:0 1.25rem 1rem;border-top:1px solid #e5e7eb;
  background:#f9fafb;
}
.accordion-body-inner p{padding-top:1rem;color:#374151;line-height:1.7}

/* Extra sections in legal pages */
.legal-extra{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:3rem}
.legal-extra-card{padding:1.5rem;background:#f9fafb;border-radius:.5rem;border:1px solid #e5e7eb}
.legal-extra-card h3{font-weight:700;color:#111827;margin-bottom:.75rem}
.legal-extra-card p{color:#374151;line-height:1.7}

/* CTA box at bottom of legal pages */
.legal-cta{
  padding:2rem;border-radius:.75rem;
  display:flex;align-items:flex-start;gap:1rem;
}
.legal-cta.red{background:linear-gradient(90deg,#fef2f2,#eff6ff);border:2px solid #fecaca}
.legal-cta.blue{background:linear-gradient(90deg,#eff6ff,#fef2f2);border:2px solid #bfdbfe}
.legal-cta-icon{flex-shrink:0}
.legal-cta h3{font-weight:700;color:#111827;margin-bottom:.5rem}
.legal-cta p{color:#374151;line-height:1.7;margin-bottom:1.5rem}
.legal-cta .cta-btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.75rem 1.5rem;border-radius:.5rem;
  color:#fff;font-weight:600;transition:all .2s;
}
.legal-cta .cta-btn:hover{box-shadow:0 6px 20px rgba(0,0,0,.15);transform:translateY(-1px)}

/* ---------- Reveal Animation ---------- */
.reveal{opacity:0;transform:translateY(1.5rem);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ---------- Keyframes ---------- */
@keyframes float{0%,100%{transform:translateY(0) translateX(0)}50%{transform:translateY(14px) translateX(4px)}}
@keyframes pulseSoft{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.75;transform:scale(.96)}}
@keyframes slideDown{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}

@media(prefers-reduced-motion:reduce){
  .reveal,.reveal-left,.reveal-right{opacity:1;transform:none;transition:none}
  .stagger-item{opacity:1;transform:none;transition:none}
  .hero-blob,.hero-pill .dot{animation:none!important}
}

/* ---------- Utility ---------- */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.text-red{color:#dc2626}.text-orange{color:#ea580c}.text-blue{color:#3b82f6}
.bg-red{background:linear-gradient(135deg,#ef4444,#f97316)}.bg-orange{background:linear-gradient(135deg,#f97316,#ef4444)}
.bg-blue{background:linear-gradient(135deg,#3b82f6,#ef4444)}

/* ---------- Reveal — Directional Variants ---------- */
.reveal-left{opacity:0;transform:translateX(-1.5rem);transition:opacity .7s ease,transform .7s ease}
.reveal-right{opacity:0;transform:translateX(1.5rem);transition:opacity .7s ease,transform .7s ease}
.reveal-left.visible,.reveal-right.visible{opacity:1;transform:none}

/* ---------- Stagger Children ---------- */
.stagger-item{
  opacity:0;transform:translateX(-.75rem);
  transition:opacity .45s ease,transform .45s ease;
}
.reveal.visible .stagger-item,
.reveal-left.visible .stagger-item,
.reveal-right.visible .stagger-item{opacity:1;transform:none}
.reveal.visible .stagger-item:nth-child(1),
.reveal-left.visible .stagger-item:nth-child(1),
.reveal-right.visible .stagger-item:nth-child(1){transition-delay:60ms}
.reveal.visible .stagger-item:nth-child(2),
.reveal-left.visible .stagger-item:nth-child(2),
.reveal-right.visible .stagger-item:nth-child(2){transition-delay:130ms}
.reveal.visible .stagger-item:nth-child(3),
.reveal-left.visible .stagger-item:nth-child(3),
.reveal-right.visible .stagger-item:nth-child(3){transition-delay:200ms}
.reveal.visible .stagger-item:nth-child(4),
.reveal-left.visible .stagger-item:nth-child(4),
.reveal-right.visible .stagger-item:nth-child(4){transition-delay:270ms}
.reveal.visible .stagger-item:nth-child(5),
.reveal-left.visible .stagger-item:nth-child(5),
.reveal-right.visible .stagger-item:nth-child(5){transition-delay:340ms}

/* ---------- Active Nav Link ---------- */
.nav-links a.active{color:#dc2626}
.nav-links a.active::after{
  transform:scaleX(1);
  background:linear-gradient(90deg,#ef4444,#f97316);
}

/* ---------- Accordion links ---------- */
.accordion-body-inner a{color:#3b82f6;text-decoration:underline}
.accordion-body-inner a:hover{color:#2563eb}

/* ---------- Reading Progress Bar ---------- */
.reading-progress{
  position:fixed;top:0;left:0;z-index:100;
  height:3px;width:0%;
  background:linear-gradient(90deg,#ef4444,#f97316);
  border-radius:0 9999px 9999px 0;
  pointer-events:none;
}

/* ---------- Back to Top Button ---------- */
.back-to-top{
  position:fixed;bottom:2rem;right:2rem;z-index:40;
  width:2.75rem;height:2.75rem;border-radius:50%;
  background:linear-gradient(135deg,#ef4444,#f97316);
  color:#fff;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 16px rgba(239,68,68,.3);
  opacity:0;transform:translateY(.75rem);pointer-events:none;
  transition:opacity .3s ease,transform .3s ease,box-shadow .3s ease;
}
.back-to-top.show{opacity:1;transform:translateY(0);pointer-events:auto}
.back-to-top:hover{box-shadow:0 6px 24px rgba(239,68,68,.45);transform:translateY(-2px)}
