/* HomePage animations & responsive overrides */
@keyframes mg-glitch-reveal {
  0% { opacity: 0; transform: translateY(8px) skewX(-2deg); filter: blur(4px); }
  40% { opacity: 0.7; transform: translateY(-2px) skewX(1deg); filter: blur(1px); }
  60% { opacity: 0.9; transform: translateY(1px) skewX(-0.5deg); filter: blur(0px); }
  100% { opacity: 1; transform: translateY(0) skewX(0); filter: blur(0); }
}
@keyframes mg-fade-up {
  0% { opacity: 0; transform: translateY(16px); }
  100% { opacity: 1; transform: translateY(0); }
}
.mg-glitch-word { display: inline-block; opacity: 0; animation: mg-glitch-reveal 0.6s ease-out forwards; }
.mg-hero-fade { opacity: 0; animation: mg-fade-up 0.8s ease-out forwards; }
.mg-check-row { display: flex; align-items: center; justify-content: space-between; padding: 0.5rem 0; font-size: 0.8rem; border-bottom: 1px solid rgba(255,255,255,0.04); }
.mg-check-row:last-of-type { border-bottom: none; }
.mg-check-label { color: #CBD5E1; display: flex; align-items: center; gap: 0.4rem; }
.mg-check-pass { color: #22C55E; font-weight: 600; }
.mg-check-fail { color: #EF4444; font-weight: 600; }
.mg-check-warn { color: #FBBF24; font-weight: 600; }
.mg-check-group { font-size: 0.65rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: #94A3B8; padding: 0.6rem 0 0.25rem; border-bottom: 1px solid rgba(255,255,255,0.06); margin-bottom: 0.15rem; }
.mg-info-tip { position: relative; display: inline-flex; align-items: center; justify-content: center; width: 14px; height: 14px; border-radius: 50%; background: rgba(239,68,68,0.15); color: #EF4444; font-size: 9px; font-weight: 700; cursor: help; flex-shrink: 0; }
.mg-info-tip .mg-tip-text { visibility: hidden; opacity: 0; position: absolute; bottom: calc(100% + 6px); left: 50%; transform: translateX(-50%); width: 240px; padding: 0.5rem 0.65rem; background: #1E293B; border: 1px solid rgba(255,255,255,0.1); border-radius: 6px; color: #94A3B8; font-size: 0.68rem; font-weight: 400; line-height: 1.45; text-align: left; z-index: 50; pointer-events: none; transition: opacity 0.15s, visibility 0.15s; box-shadow: 0 4px 12px rgba(0,0,0,0.3); }
.mg-info-tip .mg-tip-text::after { content: ''; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); border: 5px solid transparent; border-top-color: #1E293B; }
.mg-info-tip:hover .mg-tip-text, .mg-info-tip.mg-tip-active .mg-tip-text { visibility: visible; opacity: 1; }
.mg-meta-grid { display: grid; grid-template-columns: auto 1fr; gap: 0.15rem 0.75rem; align-items: baseline; }
.mg-meta-key { color: #94A3B8; font-size: 0.6rem; text-transform: uppercase; letter-spacing: 0.05em; white-space: nowrap; }
.mg-meta-val { color: #94A3B8; font-size: 0.7rem; font-family: var(--font-mono, monospace); }
@keyframes mg-grid-pulse{0%,100%{opacity:.03}50%{opacity:.08}}
@keyframes mg-scanline{0%{transform:translateY(-100%)}100%{transform:translateY(200vh)}}
@keyframes mg-crt-flicker{0%,100%{opacity:1}92%{opacity:1}93%{opacity:.85}94%{opacity:1}97%{opacity:.92}98%{opacity:1}}
@keyframes mg-float-up{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes mg-float-down{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}
@keyframes mg-rotate-slow{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
@keyframes mg-dash-draw{0%{stroke-dashoffset:300}100%{stroke-dashoffset:0}}
@keyframes mg-glow-pulse{0%,100%{box-shadow:0 0 20px rgba(30,64,175,.1),0 0 60px rgba(30,64,175,.03)}50%{box-shadow:0 0 30px rgba(30,64,175,.18),0 0 80px rgba(30,64,175,.06)}}

.mg-terminal{position:relative;animation:mg-crt-flicker 4s ease-in-out infinite;box-shadow:0 0 40px rgba(30,64,175,.15),0 0 80px rgba(30,64,175,.05),inset 0 0 60px rgba(0,0,0,.1)}
.mg-terminal::after{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,rgba(0,0,0,.06) 0px,rgba(0,0,0,.06) 1px,transparent 1px,transparent 3px);pointer-events:none;border-radius:inherit}
.mg-terminal::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 50%,rgba(0,0,0,.25) 100%);pointer-events:none;border-radius:inherit;z-index:2}

.mg-stat-card:hover{border-color:#1E40AF!important;transform:translateY(-2px)}
.mg-service-card:hover{border-color:#1E40AF!important;transform:translateY(-4px)}
.mg-service-card-red:hover{border-color:#DC2626!important;transform:translateY(-4px)}
.mg-service-card-blue:hover{border-color:#2563EB!important;transform:translateY(-4px)}

/* Animation fallback: ensure hero content is visible even if JS animations fail */
@media (prefers-reduced-motion: reduce) {
  .mg-glitch-word, .mg-hero-fade { opacity: 1 !important; transform: none !important; animation: none !important; }
}

/* Grid defaults (mobile-first) */
.mg-trust-bar-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:center}
.mg-trust-divider-v{display:none}
.mg-redblue-grid{display:grid;grid-template-columns:1fr;gap:0;border-radius:var(--radius,12px);overflow:hidden}
.mg-hero-section{min-height:auto}

/* Founder quote responsive */
.mg-founder-quote{flex-direction:row}

@media(max-width:768px){
  .mg-hero-heading{font-size:1.65rem!important;line-height:1.18!important;overflow-wrap:break-word;hyphens:auto}
  .mg-hero-sub{font-size:.95rem!important}
  .mg-hero-cta-row{flex-direction:column!important}
  .mg-hero-cta-row a{width:100%!important;justify-content:center!important}
  .mg-hero-terminal{display:none!important}
  .mg-hero-badge{font-size:.75rem!important}
  .mg-trust-bar-grid{grid-template-columns:1fr 1fr;gap:.25rem}
  .mg-trust-bar-grid p{font-size:.7rem!important;letter-spacing:0!important}
  .mg-redblue-panel{padding:1.5rem 1.25rem!important}
  .mg-founder-quote{flex-direction:column!important;text-align:center;gap:1rem!important;padding:1.5rem 1.25rem!important}
}
@media(min-width:769px) and (max-width:1279px){
  .mg-hero-heading{font-size:2.2rem!important}
  .mg-hero-sub{font-size:.95rem!important}
  .mg-hero-terminal{display:block!important}
  .mg-trust-bar-grid{grid-template-columns:1fr 1fr}
}
@media(min-width:1280px){
  .mg-trust-bar-grid{grid-template-columns:1fr auto 1fr auto 1fr auto 1fr}
  .mg-trust-divider-v{display:block}
  .mg-redblue-grid{grid-template-columns:1fr 1fr}
}
