/* ============================================================================
   JBIT SOLUTIONS — full website styles (site.css)
   Loads after ../colors_and_type.css. Retuned to lead with PERIWINKLE (#5170FF,
   from the product-line marks), cyan kept as a secondary glint, arcade accents
   per product line.
   ============================================================================ */
:root {
  --primary:        #5170FF;
  --primary-bright: #8A9DFF;
  --primary-deep:   #28369e;
  --primary-light:  #B7C2FF;
  --primary-glow:   rgba(81,112,255,.55);
  --text-glow-p:    0 0 9px var(--primary-glow);
  --glow-p-sm:      0 0 10px var(--primary-glow);
  --glow-p-lg:      0 0 26px rgba(81,112,255,.42);
  --shadow-pixel-p: 4px 4px 0 0 var(--primary-deep);

  /* product team colors (kept distinct for the grid, harmonized) */
  --c-ai:      #2EC4FF;
  --c-cloud:   #4F9DE0;
  --c-managed: #34E27A;
  --c-secure:  #5170FF;
  --c-forge:   #FFC24B;
  --c-procure: #B98CFF;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; scroll-behavior: smooth; width: 100%; max-width: 100%; overflow-x: clip; }
body {
  background: var(--black); color: var(--fg);
  font-family: var(--font-term); -webkit-font-smoothing: antialiased;
}
#root { min-height: 100vh; }
img { display: block; max-width: 100%; }
/* nothing escapes the horizontal viewport on small screens */
.crt-page, .nav, footer, section, header { max-width: 100%; }

/* ---------- PAGE / CRT TEXTURE ---------- */
.crt-page { position: relative; min-height: 100vh;
  background: radial-gradient(ellipse at 50% -5%, rgba(81,112,255,.08), transparent 55%), var(--black); }
.crt-page::before { content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image: var(--grid-bg); background-size: var(--grid-size) var(--grid-size); opacity:.5; }
.crt-page::after { content:""; position:fixed; inset:0; z-index:80; pointer-events:none;
  background: var(--scanline); opacity:.32; mix-blend-mode:multiply; }
.crt-page > * { position: relative; z-index: 1; }
.wrap { max-width: 1180px; margin: 0 auto; padding: 0 28px; }
.section { padding: 72px 0; }
.center { text-align: center; }
.blink { animation: blink 1s steps(1) infinite; } @keyframes blink { 50% { opacity:0; } }

/* ---------- NAV ---------- */
.nav { position: sticky; top:0; z-index:70; display:flex; align-items:center; gap:24px;
  padding:13px 28px; background: rgba(5,7,12,.93); border-bottom:2px solid var(--primary);
  box-shadow: 0 2px 18px rgba(81,112,255,.2); }
.nav-logo { display:flex; align-items:center; gap:11px; text-decoration:none; border-bottom:none; white-space:nowrap; }
.nav-logo img { height:34px; width:auto; filter:drop-shadow(0 0 8px rgba(46,196,255,.45)); }
.nav-logo .wm { font-family:var(--font-pixel); font-size:14px; color:var(--primary); text-shadow:var(--text-glow-p); }
.nav-links { display:flex; align-items:center; gap:22px; }
.nav-link { font-family:var(--font-hud); font-size:10px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--fg-dim); background:none; border:none; cursor:pointer; padding:4px 0; text-decoration:none;
  display:inline-flex; align-items:center; gap:6px; }
.nav-link:hover, .nav-link.active { color:var(--primary); text-shadow:var(--text-glow-p); }
.nav-right { margin-left:auto; display:flex; align-items:center; gap:18px; }
.nav-uptime .lbl { font-family:var(--font-hud); font-size:9px; letter-spacing:.12em; color:var(--fg-muted); }
.nav-uptime .val { font-family:var(--font-hud); font-size:11px; letter-spacing:.08em; color:var(--c-managed); }
.nav-burger { display:none; background:none; border:2px solid var(--border); color:var(--primary);
  width:40px; height:38px; cursor:pointer; font-size:18px; }

/* dropdown */
.dd-wrap { position:relative; display:flex; align-items:center; }
.dd-wrap.open .dd-caret { transform: rotate(180deg); }
.dd-caret { transition: transform var(--t-fast); }
.dd-panel { position:absolute; top:calc(100% + 14px); left:0; width:600px; max-width:92vw; background:var(--void);
  border:2px solid var(--primary); box-shadow:0 0 28px rgba(81,112,255,.3); padding:14px;
  display:grid; grid-template-columns:1fr 1fr; gap:6px; animation:ddIn 120ms steps(3,end); }
.dd-panel::before { content:""; position:absolute; top:-9px; left:60px; transform:rotate(45deg); width:14px; height:14px;
  background:var(--void); border-left:2px solid var(--primary); border-top:2px solid var(--primary); }
@keyframes ddIn { from{ transform:translateY(-6px);} to{ transform:translateY(0);} }
.dd-item { display:flex; gap:12px; align-items:flex-start; padding:11px 12px; text-decoration:none; border:2px solid transparent; }
.dd-item:hover { border-color:var(--border-strong); background:rgba(81,112,255,.06); }
.dd-item iconify-icon { font-size:26px; margin-top:2px; }
.dd-ico { width:30px; height:30px; object-fit:contain; margin-top:1px; image-rendering:auto; flex:0 0 auto; }
.dd-item .nm { font-family:var(--font-hud); font-size:11px; letter-spacing:.06em; text-transform:uppercase; }
.dd-item .ds { font-family:var(--font-term); font-size:17px; color:var(--fg-dim); line-height:1.15; margin-top:3px; }
.dd-foot { grid-column:1/-1; margin-top:6px; padding:10px 12px; border-top:2px dashed var(--border);
  font-family:var(--font-term); font-size:17px; color:var(--fg-muted); display:flex; justify-content:space-between; }

/* mobile menu */
.mob { display:none; }

/* ---------- BUTTONS ---------- */
.btn { font-family:var(--font-hud); font-size:11px; letter-spacing:.1em; text-transform:uppercase;
  padding:14px 22px; border:2px solid var(--primary); background:var(--primary); color:#05081f; cursor:pointer;
  text-decoration:none; box-shadow:var(--shadow-pixel-p); display:inline-flex; align-items:center; gap:8px;
  transition: transform var(--t-fast), box-shadow var(--t-fast), background var(--t-fast); }
.btn:hover { background:var(--primary-bright); }
.btn:active { transform:translate(4px,4px); box-shadow:0 0 0 0; }
.btn.outline { background:transparent; color:var(--primary); box-shadow:none; }
.btn.outline:hover { background:rgba(81,112,255,.12); text-shadow:var(--text-glow-p); }
.btn.ghost { background:transparent; border-color:var(--border); color:var(--fg-dim); box-shadow:none; }
.btn.ghost:hover { border-color:var(--primary); color:var(--primary); }
.btn.lg { padding:17px 30px; font-size:12px; }

/* ---------- SECTION HEADER ---------- */
.shead { display:flex; align-items:center; gap:14px; margin-bottom:34px; }
.shead .bar { width:18px; height:18px; background:var(--primary); box-shadow:var(--glow-p-sm); flex:none; }
.shead h2 { font-family:var(--font-pixel); font-size:clamp(15px,2.3vw,21px); color:var(--primary);
  text-shadow:var(--text-glow-p); margin:0; line-height:1.5; }
.shead .meta { margin-left:auto; font-family:var(--font-hud); font-size:9px; letter-spacing:.12em; color:var(--fg-muted); }
.eyebrow { font-family:var(--font-hud); font-size:11px; letter-spacing:.28em; text-transform:uppercase; color:var(--c-managed); }

/* ---------- HERO ---------- */
.hero { padding:64px 0 64px; text-align:center; }
.hero-emblem { display:flex; justify-content:center; margin-bottom:18px; }
.hero-emblem img {
  width:min(280px, 64vw); height:auto;
  filter:drop-shadow(0 0 26px rgba(46,196,255,.45));
  animation:emblemFloat 5s ease-in-out infinite;
}
@keyframes emblemFloat { 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(-9px);} }
@media (prefers-reduced-motion: reduce) { .hero-emblem img { animation:none; } }
.hero h1 { font-family:var(--font-pixel); font-size:clamp(28px,5vw,56px); line-height:1.5; color:var(--fg);
  text-shadow:0 0 16px var(--primary-glow); margin:22px 0; }
.hero h1 .c { color:var(--primary); }
.hero .sub { font-family:var(--font-term); font-size:27px; color:var(--fg-dim); max-width:660px; margin:0 auto 32px; line-height:1.22; }
.hero .cta { display:flex; gap:18px; justify-content:center; flex-wrap:wrap; }
.invader-row { display:flex; gap:30px; justify-content:center; margin-top:54px; }
.invader { display:grid; gap:0; } .invader i { display:block; }
.float { animation: float 2.4s steps(2) infinite alternate; } @keyframes float { to { transform:translateY(-8px);} }

/* ---------- PRODUCT GRID ---------- */
.pgrid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.pcard { background:var(--panel); border:2px solid var(--border); padding:24px; text-decoration:none; display:block;
  box-shadow:4px 4px 0 0 #0a1330; cursor:pointer; transition:transform var(--t-fast), box-shadow var(--t-fast), border-color var(--t-fast); }
.pcard:hover { transform:translate(-2px,-2px); box-shadow:6px 6px 0 0 var(--ac-deep,#0a1330); border-color:var(--ac,var(--primary)); }
.pcard iconify-icon { font-size:40px; color:var(--ac,var(--primary)); }
.pcard-ico { width:52px; height:52px; object-fit:contain; display:block; }
.pcard .nm { font-family:var(--font-hud); font-size:13px; letter-spacing:.06em; text-transform:uppercase; color:var(--fg); margin:16px 0 9px; }
.pcard .ds { font-family:var(--font-term); font-size:20px; color:var(--fg-dim); line-height:1.2; }
.pcard .go { font-family:var(--font-hud); font-size:9px; letter-spacing:.14em; color:var(--ac,var(--primary)); text-transform:uppercase; margin-top:18px; display:inline-flex; gap:6px; }

/* ---------- SCOREBOARD ---------- */
.band { border:2px solid var(--border); border-left-color:var(--primary); border-right-color:var(--primary);
  background:var(--void); display:grid; grid-template-columns:repeat(4,1fr); }
.band .cell { padding:30px 22px; text-align:center; border-right:2px solid var(--border); }
.band .cell:last-child { border-right:none; }
.band .n { font-family:var(--font-pixel); font-size:clamp(18px,2.6vw,28px); color:var(--c-forge); text-shadow:0 0 12px rgba(255,194,75,.45); }
.band .l { font-family:var(--font-hud); font-size:9px; letter-spacing:.12em; color:var(--fg-dim); text-transform:uppercase; margin-top:12px; }

/* ---------- "HOW IT WORKS" STEPS ---------- */
.steps { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.step { border:2px solid var(--border); background:var(--panel); padding:24px; }
.step .num { font-family:var(--font-pixel); font-size:22px; color:var(--primary); text-shadow:var(--text-glow-p); }
.step h3 { font-family:var(--font-hud); font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--fg); margin:16px 0 8px; }
.step p { font-family:var(--font-term); font-size:20px; color:var(--fg-dim); line-height:1.2; margin:0; }

/* ---------- CTA BANNER ---------- */
.cta-band { border:2px solid var(--primary); background:linear-gradient(180deg, rgba(81,112,255,.08), transparent);
  box-shadow:0 0 26px rgba(81,112,255,.2); padding:48px; text-align:center; }
.cta-band h2 { font-family:var(--font-pixel); font-size:clamp(18px,3vw,30px); color:var(--fg); text-shadow:var(--text-glow-p); margin:0 0 14px; line-height:1.5; }
.cta-band p { font-family:var(--font-term); font-size:23px; color:var(--fg-dim); margin:0 auto 26px; max-width:560px; line-height:1.2; }

/* ---------- PRODUCT PAGE ---------- */
.phero { padding:70px 0 50px; display:grid; grid-template-columns:1.3fr 1fr; gap:40px; align-items:center; }
.phero .tag { font-family:var(--font-hud); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--ac,var(--primary)); }
.phero h1 { font-family:var(--font-pixel); font-size:clamp(26px,4vw,46px); line-height:1.5; color:var(--fg); text-shadow:0 0 16px var(--ac-glow,var(--primary-glow)); margin:18px 0; }
.phero .lead { font-family:var(--font-term); font-size:26px; color:var(--fg-dim); line-height:1.25; margin-bottom:28px; }
.phero-art { border:2px solid var(--ac,var(--primary)); background:#000; padding:24px; box-shadow:0 0 26px var(--ac-glow,var(--primary-glow)); }
.phero-art img { width:100%; aspect-ratio:1; object-fit:contain; max-width:260px; margin:0 auto; display:block; }
.feat-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.feat { border:2px solid var(--border); background:var(--panel); padding:24px; border-top:3px solid var(--ac,var(--primary)); }
.feat iconify-icon { font-size:30px; color:var(--ac,var(--primary)); }
.feat h3 { font-family:var(--font-hud); font-size:12px; letter-spacing:.05em; text-transform:uppercase; color:var(--fg); margin:14px 0 8px; }
.feat p { font-family:var(--font-term); font-size:20px; color:var(--fg-dim); line-height:1.2; margin:0; }
.levels { display:flex; flex-direction:column; gap:0; border:2px solid var(--border); }
.level { display:flex; align-items:center; gap:18px; padding:18px 22px; border-bottom:2px solid var(--border); }
.level:last-child { border-bottom:none; }
.level .lv { font-family:var(--font-hud); font-size:10px; letter-spacing:.1em; color:var(--ac,var(--primary)); width:78px; flex:none; text-transform:uppercase; }
.level .lt { font-family:var(--font-term); font-size:23px; color:var(--fg); }
.level iconify-icon { margin-left:auto; color:var(--ac,var(--primary)); font-size:22px; }

/* ---------- ABOUT ---------- */
.about-hero { padding:80px 0 40px; text-align:center; }
.vals { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.vals .val { border:2px solid var(--border); background:var(--panel); padding:24px; }
.vals .val iconify-icon { font-size:30px; color:var(--primary); }
.vals .val h3 { font-family:var(--font-hud); font-size:12px; letter-spacing:.05em; text-transform:uppercase; color:var(--fg); margin:14px 0 8px; }
.vals .val p { font-family:var(--font-term); font-size:20px; color:var(--fg-dim); line-height:1.2; margin:0; }
.about-prose { font-family:var(--font-term); font-size:25px; color:var(--fg-dim); line-height:1.32; max-width:760px; margin:0 auto; }
.about-prose strong { color:var(--primary); }
.crew { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.crew-card { border:2px solid var(--border); background:var(--panel); text-align:center; padding:22px 14px; }
.crew-av { width:78px; height:78px; margin:0 auto 14px; border:2px solid var(--primary); display:flex; align-items:center; justify-content:center;
  font-family:var(--font-pixel); font-size:18px; color:var(--primary); background:var(--void); box-shadow:var(--glow-p-sm); }
.crew-card .cn { font-family:var(--font-hud); font-size:11px; letter-spacing:.05em; color:var(--fg); text-transform:uppercase; }
.crew-card .cr { font-family:var(--font-term); font-size:18px; color:var(--fg-muted); margin-top:5px; }

/* ---------- CONTACT ---------- */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:34px; align-items:start; }
.info-list { display:flex; flex-direction:column; gap:2px; border:2px solid var(--border); }
.info-row { display:flex; align-items:center; gap:16px; padding:20px 22px; border-bottom:2px solid var(--border); text-decoration:none; min-width:0; }
.info-row > div { min-width:0; }
.info-row:last-child { border-bottom:none; }
.info-row:hover { background:rgba(81,112,255,.05); }
.info-row iconify-icon { font-size:26px; color:var(--primary); flex:none; }
.info-row .k { font-family:var(--font-hud); font-size:9px; letter-spacing:.12em; color:var(--fg-muted); text-transform:uppercase; }
.info-row .v { font-family:var(--font-term); font-size:23px; color:var(--fg); overflow-wrap:anywhere; }
.form-box { border:2px solid var(--primary); background:var(--void); box-shadow:0 0 24px rgba(81,112,255,.22); }
.form-head { padding:16px 20px; border-bottom:2px solid var(--border); font-family:var(--font-pixel); font-size:13px; color:var(--primary); text-shadow:var(--text-glow-p); }
.form-body { padding:22px 20px; display:flex; flex-direction:column; gap:16px; }
.field { display:flex; flex-direction:column; gap:6px; }
.field label { font-family:var(--font-hud); font-size:9px; letter-spacing:.12em; color:var(--fg-dim); text-transform:uppercase; }
.field input, .field select, .field textarea { font-family:var(--font-term); font-size:20px; background:var(--panel-3);
  border:2px solid var(--border); color:var(--fg); padding:9px 12px; }
.field textarea { resize:vertical; min-height:90px; }
.field input:focus, .field select:focus, .field textarea:focus { outline:none; border-color:var(--primary); box-shadow:0 0 8px var(--primary-glow); }
.form-done { text-align:center; padding:40px 24px; }
.form-done .big { font-family:var(--font-pixel); font-size:18px; color:var(--c-managed); text-shadow:var(--glow-green); margin-bottom:16px; }
.map-strip { margin-top:18px; border:2px solid var(--border); background:var(--void); position:relative; height:140px; overflow:hidden;
  display:flex; align-items:center; justify-content:center; }
.map-strip::before { content:""; position:absolute; inset:0; background-image:var(--grid-bg); background-size:20px 20px; opacity:.6; }
.map-strip .pin { position:relative; font-family:var(--font-hud); font-size:11px; letter-spacing:.12em; color:var(--primary); text-transform:uppercase; display:flex; align-items:center; gap:8px; }

/* ---------- BLOG ---------- */
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.post { border:2px solid var(--border); background:var(--panel); text-decoration:none; display:flex; flex-direction:column;
  box-shadow:4px 4px 0 0 #0a1330; transition:transform var(--t-fast), box-shadow var(--t-fast), border-color var(--t-fast); }
.post:hover { transform:translate(-2px,-2px); box-shadow:6px 6px 0 0 #0a1330; border-color:var(--primary); }
.post-top { height:120px; background:var(--void); position:relative; display:flex; align-items:center; justify-content:center; overflow:hidden; border-bottom:2px solid var(--border); }
.post-top::before { content:""; position:absolute; inset:0; background-image:var(--grid-bg); background-size:18px 18px; opacity:.5; }
.post-top iconify-icon { position:relative; font-size:38px; }
.post-body { padding:20px; }
.post .cat { font-family:var(--font-hud); font-size:9px; letter-spacing:.12em; text-transform:uppercase; }
.post h3 { font-family:var(--font-term); font-size:25px; color:var(--fg); line-height:1.12; margin:9px 0 10px; }
.post .ex { font-family:var(--font-term); font-size:19px; color:var(--fg-dim); line-height:1.2; }
.post .date { font-family:var(--font-hud); font-size:8px; letter-spacing:.1em; color:var(--fg-muted); text-transform:uppercase; margin-top:14px; }
.blog-feature { display:grid; grid-template-columns:1.1fr 1fr; gap:0; border:2px solid var(--primary); box-shadow:0 0 24px rgba(81,112,255,.2); margin-bottom:34px; }
.blog-feature .bf-art { background:var(--void); position:relative; min-height:240px; display:flex; align-items:center; justify-content:center; overflow:hidden; }
.blog-feature .bf-art::before { content:""; position:absolute; inset:0; background-image:var(--grid-bg); background-size:22px 22px; opacity:.5; }
.blog-feature .bf-art iconify-icon { position:relative; font-size:64px; color:var(--primary); }
.blog-feature .bf-body { padding:34px; }

/* ---------- TICKER + FOOTER ---------- */
.ticker { border-top:2px solid var(--primary); border-bottom:2px solid var(--primary); background:var(--void); overflow:hidden; padding:11px 0; }
.ticker .track { display:inline-flex; gap:48px; white-space:nowrap; animation:marquee 24s linear infinite; }
.ticker span { font-family:var(--font-hud); font-size:10px; letter-spacing:.14em; color:var(--primary); text-transform:uppercase; }
.ticker span b { color:var(--c-procure); }
@keyframes marquee { from{transform:translateX(0);} to{transform:translateX(-50%);} }
.foot { padding:50px 0 60px; }
.foot-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.2fr; gap:28px; }
.foot h4 { font-family:var(--font-hud); font-size:10px; letter-spacing:.12em; color:var(--primary); text-transform:uppercase; margin:0 0 14px; }
.foot a { display:block; font-family:var(--font-term); font-size:19px; color:var(--fg-dim); text-decoration:none; padding:3px 0; overflow-wrap:anywhere; }
.foot a.nav-logo { display:flex; align-items:center; gap:11px; padding:0; }
.foot a:hover { color:var(--primary); }
.foot .blurb { font-family:var(--font-term); font-size:20px; color:var(--fg-muted); line-height:1.25; max-width:280px; }
.foot-social { display:flex; gap:10px; margin-top:18px; }
.foot-social .soc {
  display:flex; align-items:center; justify-content:center;
  width:38px; height:38px; padding:0;
  border:2px solid var(--border); color:var(--fg-dim);
  transition:border-color var(--t-fast), color var(--t-fast), box-shadow var(--t-fast), transform var(--t-fast);
}
.foot-social .soc iconify-icon { font-size:18px; }
.foot-social .soc:hover {
  border-color:var(--primary); color:var(--primary);
  box-shadow:0 0 12px var(--primary-glow); transform:translateY(-2px);
}
.foot-base { border-top:2px dashed var(--border); margin-top:36px; padding-top:20px; display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;
  font-family:var(--font-hud); font-size:9px; letter-spacing:.1em; color:var(--fg-muted); }

@media (max-width: 900px) {
  .nav-links { display:none; }
  .nav-burger { display:block; }
  .nav-right .nav-uptime { display:none; }
  .pgrid, .steps, .vals, .blog-grid { grid-template-columns:1fr 1fr; }
  .band { grid-template-columns:1fr 1fr; }
  .feat-grid { grid-template-columns:1fr; }
  .phero, .contact-grid, .blog-feature { grid-template-columns:1fr; }
  .crew { grid-template-columns:1fr 1fr; }
  .foot-grid { grid-template-columns:1fr 1fr; }
  .phero { padding:48px 0 36px; }
  .blog-feature .bf-art { min-height:160px; }
  .blog-feature .bf-body { padding:26px; }
  .mob.open { display:block; position:fixed; inset:60px 0 0; z-index:65; background:rgba(5,7,12,.98);
    padding:24px 28px; overflow-y:auto; border-top:2px solid var(--primary); }
  .mob.open a { display:block; font-family:var(--font-hud); font-size:13px; letter-spacing:.1em; text-transform:uppercase;
    color:var(--fg-dim); text-decoration:none; padding:16px 0; border-bottom:2px solid var(--border); }
}

/* ---- TABLET / LARGE PHONE ---- */
@media (max-width: 680px) {
  .section { padding:52px 0; }
  .hero { padding:44px 0; }
  .shead { flex-wrap:wrap; gap:10px; margin-bottom:26px; }
  .shead .meta { margin-left:auto; }
  .hero .sub { font-size:23px; }
  .phero .lead { font-size:23px; }
  .about-prose { font-size:22px; }
  .invader-row { gap:clamp(14px,5vw,30px); margin-top:40px; }
}

/* ---- PHONE ---- */
@media (max-width: 560px) {
  .wrap { padding:0 18px; }
  .pgrid, .steps, .vals, .blog-grid, .band, .crew, .foot-grid { grid-template-columns:1fr; }
  .hero h1 { font-size:30px; }
  .section { padding:44px 0; }
  /* nav: keep logo + CTA + burger on one line without clipping */
  .nav { gap:12px; padding:12px 16px; }
  .nav-right { gap:10px; }
  .nav .btn { padding:11px 13px; font-size:10px; letter-spacing:.06em; }
  .nav-logo img { height:30px; }
  /* tighten oversized panels */
  .cta-band { padding:30px 20px; }
  .cta-band p { font-size:21px; }
  .phero-art { padding:18px; }
  .feat, .step, .pcard, .vals .val, .crew-card { padding:20px; }
  .level { gap:12px; padding:16px; }
  .level .lv { width:54px; }
  .form-body { padding:20px 16px; }
  .info-row { padding:16px; gap:12px; }
  .blog-feature .bf-body { padding:22px 18px; }
  /* footer base stacks cleanly */
  .foot-base { flex-direction:column; align-items:flex-start; }
}

/* ---- SMALL PHONE ---- */
@media (max-width: 380px) {
  .wrap { padding:0 14px; }
  .hero .sub { font-size:21px; }
  .nav .btn { padding:10px 11px; }
  .invader-row { gap:12px; }
}
