/* public/_mobile-public.css
 * Shared mobile responsive rules for every public marketing page.
 * Loaded after each page's inline desktop CSS so these rules win at
 * smaller widths without changing desktop. Mobile-first cascade:
 *   <=768  — phones / small tablets
 *   <=480  — small phones
 */

/* ── Hamburger menu (drives nav collapse on small screens) ────────────── */
.rx-mobile-menu-btn{display:none;background:transparent;border:1px solid rgba(245,247,250,0.18);border-radius:8px;width:40px;height:40px;cursor:pointer;align-items:center;justify-content:center;color:#F5F7FA;flex-shrink:0}
.rx-mobile-menu-btn:hover{background:rgba(245,247,250,0.04)}
.rx-mobile-menu-btn svg{width:22px;height:22px}
.rx-mobile-drawer{display:none;position:fixed;top:0;right:0;bottom:0;width:280px;max-width:80vw;background:#0A0E1A;border-left:1px solid rgba(245,247,250,0.12);padding:80px 24px 24px;z-index:120;transform:translateX(100%);transition:transform .25s ease;box-shadow:-12px 0 32px rgba(0,0,0,0.5)}
.rx-mobile-drawer.open{transform:translateX(0)}
.rx-mobile-drawer a{display:block;padding:14px 0;font-size:16px;color:#E8ECF2;text-decoration:none;border-bottom:1px solid rgba(245,247,250,0.06);font-weight:500}
.rx-mobile-drawer .drawer-cta{margin-top:18px;background:#00E5FF;color:#0A0E1A;padding:14px 18px;border-radius:8px;font-weight:600;text-align:center;border:none;font-size:15px}
.rx-mobile-drawer .drawer-ghost{margin-top:10px;background:transparent;color:#E8ECF2;padding:14px 18px;border-radius:8px;font-weight:600;text-align:center;border:1px solid rgba(245,247,250,0.18);font-size:15px}
.rx-mobile-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:115}
.rx-mobile-overlay.open{display:block}

@media (max-width:768px){
  .rx-mobile-menu-btn{display:inline-flex}
  .rx-mobile-drawer{display:block}
  /* Hide desktop nav middle links + the right-side CTAs in favor of hamburger */
  .nav-links{display:none!important}
  .nav-cta{display:none!important}
  .nav-inner{justify-content:space-between!important;gap:12px!important}
}

/* ── Container + spacing ──────────────────────────────────────────────── */
@media (max-width:768px){
  .wrap, .nav-inner, .footer-inner{padding-left:18px!important;padding-right:18px!important}
  .nav{padding:14px 0!important}
}

/* ── Hero section (every page) ───────────────────────────────────────── */
@media (max-width:768px){
  .hero{padding:40px 0 28px!important}
  .hero h1{font-size:38px!important;line-height:1.05!important;margin-bottom:18px!important;letter-spacing:-0.03em!important}
  .hero p{font-size:15.5px!important;line-height:1.55!important;margin-bottom:22px!important}
  .hero .eyebrow{font-size:10.5px!important;margin-bottom:14px!important}
  .hero-cta{flex-direction:column!important;width:100%!important;align-items:stretch!important}
  .hero-cta .btn, .hero-cta a.btn{text-align:center!important}
}
@media (max-width:480px){
  .hero h1{font-size:30px!important}
  .hero p{font-size:14.5px!important}
}

/* ── Section headers + stage chapters ───────────────────────────────── */
@media (max-width:768px){
  .stage{padding:48px 0!important}
  .stage-head{flex-direction:column!important;align-items:flex-start!important;gap:14px!important;margin-bottom:24px!important}
  .stage-num{font-size:80px!important;opacity:.18!important;line-height:.85!important}
  .stage-meta h2{font-size:28px!important;line-height:1.1!important}
  .stage-meta p{font-size:15px!important}
  .stage-head h2{font-size:28px!important;line-height:1.1!important}
  .stage-head p{font-size:15px!important}
  .spotlight{grid-template-columns:1fr!important;gap:24px!important}
  .stage.mirror .spotlight{grid-template-columns:1fr!important}
  .stage.mirror .spotlight .terminal{order:0!important}
  .spotlight h3{font-size:24px!important}
  .spotlight .desc{font-size:15px!important}
}

/* ── Terminal "demo" cards on Methodology / Features ────────────────── */
@media (max-width:768px){
  .terminal{min-height:260px!important;width:100%!important}
  .terminal-body{padding:16px!important;font-size:11.5px!important;gap:6px!important}
  .terminal-title{display:none!important}
  .tline{flex-direction:column!important;align-items:flex-start!important;gap:2px!important}
  .tline .tval{text-align:left!important}
}

/* ── Feature grids / sub-grids ───────────────────────────────────────── */
@media (max-width:768px){
  .sub-grid, .pillar-grid, .diff-grid{grid-template-columns:1fr!important}
  .sub, .pillar, .diff{padding:24px 22px!important}
}

/* ── Stat band ────────────────────────────────────────────────────────── */
@media (max-width:768px){
  .stats-grid, .statband .stats-grid{grid-template-columns:1fr 1fr!important}
  .stat{padding:20px 16px!important}
  .stat-value{font-size:36px!important}
  .stat-label{font-size:9px!important}
  .stat-sub{font-size:10px!important}
}
@media (max-width:480px){
  .stats-grid, .statband .stats-grid{grid-template-columns:1fr!important}
}

/* ── Compare page matrix table ───────────────────────────────────────── */
@media (max-width:768px){
  .matrix{overflow-x:auto!important}
  .matrix table{min-width:680px!important;font-size:13px!important}
  .matrix th, .matrix td{padding:12px 10px!important}
  .matrix td.feature small{font-size:11px!important}
}

/* ── Compare pricing snippet ─────────────────────────────────────────── */
@media (max-width:768px){
  .price-row{grid-template-columns:1fr!important;gap:14px!important}
  .price-card{padding:20px!important}
  .price-card .pr{font-size:28px!important}
}

/* ── Final CTA ────────────────────────────────────────────────────────── */
@media (max-width:768px){
  .final{padding:60px 18px!important}
  .final h2{font-size:36px!important;line-height:1.05!important}
  .final p{font-size:15px!important}
  .audit-input{flex-direction:column!important;width:100%!important;background:transparent!important;border:none!important;padding:0!important;gap:10px!important}
  .audit-input input{width:100%!important;background:#0A0E1A!important;border:1px solid rgba(245,247,250,0.18)!important;border-radius:8px!important;text-align:left!important}
  .audit-input button{width:100%!important;padding:16px!important;font-size:15px!important}
}

/* ── Footer ───────────────────────────────────────────────────────────── */
@media (max-width:768px){
  .footer{padding:36px 0 24px!important}
  .footer-inner{grid-template-columns:1fr 1fr!important;gap:24px!important}
  .footer h4{margin-bottom:10px!important}
  .footer-bottom{flex-direction:column!important;gap:8px!important;text-align:center!important;padding-top:18px!important}
}
@media (max-width:480px){
  .footer-inner{grid-template-columns:1fr!important;gap:18px!important}
}

/* ── Homepage-specific (index.html) ──────────────────────────────────── */
@media (max-width:768px){
  /* Ticker — already scrolling, just shrink font for narrow screens */
  .ticker .ticker-track{font-size:11px!important}

  /* Hero terminal next to text → stack */
  .hero-grid, .home-hero-grid{grid-template-columns:1fr!important;gap:32px!important}

  /* Brands strip */
  .brands-strip{font-size:11px!important;padding:16px 0!important}

  /* Stats section — already covered by .stats-grid override above */
  .stats-section h2{font-size:28px!important}
  .stats-section .updated{font-size:10px!important}

  /* Final CTA on homepage */
  .start-cta h2{font-size:30px!important}
}

/* ── Pricing page (cards) ─────────────────────────────────────────────── */
@media (max-width:768px){
  .plans-grid{grid-template-columns:1fr!important;gap:18px!important}
  .plan{padding:24px!important}
  .plan h3{font-size:20px!important}
  .plan .price{font-size:32px!important}
}

/* ── Signup / Login pages (often two-pane) ───────────────────────────── */
@media (max-width:768px){
  .signup-grid, .login-grid, .auth-grid{grid-template-columns:1fr!important}
  .signup-left, .login-left, .auth-left{padding:24px 18px!important}
  .signup-right, .login-right, .auth-right{padding:24px 18px!important}
}

/* ── Public audit page (/audit/:id) ──────────────────────────────────── */
@media (max-width:768px){
  .audit-shell{padding:18px!important}
  .audit-shell h1{font-size:26px!important}
  .audit-grid, .audit-cards{grid-template-columns:1fr!important;gap:14px!important}
  .audit-cta{flex-direction:column!important;align-items:stretch!important;gap:10px!important}
  .audit-cta .btn{width:100%!important;text-align:center!important}
}

/* ── Universal: remove giant horizontal padding on small screens ────── */
@media (max-width:768px){
  body{overflow-x:hidden!important}
  *{max-width:100vw}
}


/* ── Homepage hero specific (observed live class names) ─────────────── */
@media (max-width:768px){
  /* The domain capture form on the homepage hero uses .domain-form */
  .domain-form{flex-direction:column!important;width:100%!important;background:transparent!important;border:none!important;padding:0!important;gap:10px!important}
  .domain-form input{width:100%!important;background:#0A0E1A!important;border:1px solid rgba(245,247,250,0.18)!important;border-radius:8px!important;padding:14px 16px!important;font-size:15px!important;color:#fff!important;box-sizing:border-box!important}
  .domain-form button, .domain-form .btn-primary{width:100%!important;padding:14px!important;font-size:15px!important;white-space:nowrap!important}
  .lede{font-size:15.5px!important;line-height:1.55!important}
  .hero-pill{font-size:11px!important}
  .hero-actions{flex-direction:column!important;align-items:flex-start!important;gap:10px!important}
  .domain-error{font-size:12px!important}

  /* Terminal stat card on the homepage hero */
  .terminal .term-stats{grid-template-columns:1fr 1fr 1fr!important;gap:8px!important;padding:14px!important}
  .terminal .term-stat{padding:8px!important}
  .terminal .term-stat .value{font-size:22px!important}
  .terminal .term-stat .label{font-size:9px!important}
  .terminal .term-rows{font-size:12px!important}
  .terminal .term-row{padding:8px 12px!important}

  /* Hide the .live pill in terminal title on small screens to save space */
  .terminal .title{font-size:9px!important}

  /* Brands strip ticker — keep scrolling but smaller */
  .brand-strip, .brands-strip{padding:14px 0!important;font-size:11px!important}
}
@media (max-width:480px){
  .domain-form input{font-size:14px!important;padding:12px 14px!important}
  .terminal .term-stats{gap:4px!important;padding:10px!important}
  .terminal .term-stat .value{font-size:18px!important}
}
