/* ========================================================
   InfoSecPanda — Homepage v2: FUTURISTIC
   ======================================================== */

/* --- HERO --- */
.hero {
  position:relative; min-height:100vh; display:flex; align-items:center;
  padding:100px 0 60px; overflow:hidden; width:100%;
}

.hero-inner {
  position:relative; z-index:3;
  display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center;
}
.hero-text { max-width:580px; }
.hero-h1 { margin-bottom:24px; line-height:1.08; letter-spacing:-0.035em; }
.hero-typed-wrap {
  display:inline; font-size:inherit; font-weight:inherit; letter-spacing:inherit;
  max-width:100%; overflow-wrap:break-word; word-break:break-word;
}
.typed-cursor {
  display:inline-block; color:var(--teal); font-weight:300;
  animation:blink .7s step-end infinite; margin-left:2px;
  font-family:var(--font-body); font-style:normal;
  text-shadow:0 0 10px var(--teal);
}
@keyframes blink { 50% { opacity:0; } }

.hero-sub {
  font-size:clamp(.95rem,1.5vw,1.08rem); color:var(--text-secondary);
  line-height:1.7; margin-bottom:18px; max-width:500px;
}
.hero-audience {
  font-family:var(--font-editorial); font-style:italic;
  font-size:.92rem; color:var(--text-dim); margin-bottom:28px;
}
.hero-actions { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:32px; }

/* Subtle primary button in hero */
.hero .btn-primary {
  box-shadow:0 0 12px rgba(45,212,191,0.1);
}
.hero .btn-primary:hover {
  box-shadow:0 0 18px rgba(45,212,191,0.15);
}

.hero-tags { display:flex; flex-wrap:wrap; gap:8px; }
.hero-tag {
  padding:7px 14px; border-radius:6px;
  font-family:var(--font-mono); font-size:.78rem; font-weight:500;
  color:var(--text-dim); background:rgba(10,16,24,.6);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border:1px solid var(--border); transition:all .3s;
}
.hero-tag:hover {
  border-color:rgba(45,212,191,.3); color:var(--teal);
  box-shadow:0 0 16px rgba(45,212,191,.1);
}

/* Hero product preview */
.hero-preview { position:relative; perspective:1200px; }
.preview-window {
  background:rgba(8,14,24,.5);
  backdrop-filter:blur(36px) saturate(1.5);
  -webkit-backdrop-filter:blur(36px) saturate(1.5);
  border:1px solid rgba(255,255,255,.09);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    inset 0 -1px 0 rgba(0,0,0,.12),
    0 40px 100px rgba(0,0,0,.45),
    0 0 1px rgba(45,212,191,.2);
  transform:rotateY(-4deg) rotateX(2deg);
  transition:transform .5s ease, box-shadow .5s ease;
}
.preview-window:hover {
  transform:rotateY(0) rotateX(0);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    inset 0 -1px 0 rgba(0,0,0,.12),
    0 40px 100px rgba(0,0,0,.45),
    0 0 2px rgba(45,212,191,.3);
}
.preview-titlebar {
  display:flex; align-items:center; gap:12px;
  padding:12px 16px; border-bottom:1px solid rgba(255,255,255,.04);
  background:rgba(5,10,18,.6);
}
.preview-dots { display:flex; gap:6px; }
.preview-dots span {
  width:8px; height:8px; border-radius:50%;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.06);
}
.preview-dots span:first-child { background:rgba(239,68,68,.6); box-shadow:0 0 4px rgba(239,68,68,.3); }
.preview-dots span:nth-child(2) { background:rgba(240,160,48,.6); box-shadow:0 0 4px rgba(240,160,48,.3); }
.preview-dots span:nth-child(3) { background:rgba(52,211,153,.6); box-shadow:0 0 4px rgba(52,211,153,.3); }
.preview-url {
  font-family:var(--font-mono); font-size:.75rem; color:var(--text-dim);
  padding:3px 10px; background:rgba(255,255,255,.03); border-radius:4px;
  flex:1; text-align:center;
}
.preview-label {
  font-family:var(--font-mono); font-size:.75rem; color:var(--violet);
  letter-spacing:.04em;
}
.preview-body { padding:16px; min-height:240px; }
.preview-slide { animation:slideFade .4s ease; }
@keyframes slideFade {
  from { opacity:0; transform:translateX(10px); }
  to { opacity:1; transform:translateX(0); }
}
.preview-dots-nav { display:flex; justify-content:center; gap:6px; padding:10px 0 14px; }
.slide-dot {
  width:10px; height:10px; border-radius:50%;
  background:var(--text-dim); opacity:.3;
  border:none; cursor:pointer; transition:all .25s; padding:0;
  /* Invisible 44px touch target */
  position:relative;
  min-width:44px; min-height:44px;
  background:transparent;
}
.slide-dot::after {
  content:''; position:absolute; top:50%; left:50%;
  transform:translate(-50%,-50%);
  width:8px; height:8px; border-radius:50%;
  background:var(--text-dim); opacity:.3; transition:all .25s;
}
.slide-dot.active {
  opacity:1;
}
.slide-dot.active::after {
  width:22px; height:8px; border-radius:4px;
  background:var(--teal); opacity:1;
  box-shadow:0 0 8px var(--teal);
}

/* Mini dashboard shared */
.mini-kpis { display:grid; grid-template-columns:repeat(4,1fr); gap:6px; margin-bottom:12px; }
.mini-kpi {
  background:rgba(10,16,24,.6); border-radius:8px; padding:10px;
  border:1px solid var(--border); text-align:center;
}
.mini-kpi-val { font-size:1.1rem; font-weight:800; display:block; letter-spacing:-.02em; text-shadow:0 0 12px currentColor; }
.mini-kpi-lbl { font-family:var(--font-mono); font-size:.75rem; color:var(--text-dim); text-transform:uppercase; letter-spacing:.04em; display:block; margin-top:2px; }
.mini-rows { display:flex; flex-direction:column; gap:5px; }
.mini-row {
  display:flex; align-items:center; gap:8px;
  padding:8px 10px; background:rgba(10,16,24,.5);
  border:1px solid var(--border); border-radius:6px;
}
.mini-sev { font-family:var(--font-mono); font-size:.75rem; padding:3px 10px; border-radius:4px; font-weight:600; flex-shrink:0; }
.mini-row-text { font-size:.8rem; color:var(--text-secondary); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.mini-controls { display:flex; flex-direction:column; gap:5px; }
.mini-ctrl {
  display:flex; align-items:center; gap:8px;
  padding:9px 10px; background:rgba(10,16,24,.5);
  border:1px solid var(--border); border-radius:6px;
}
.ctrl-id { font-family:var(--font-mono); font-size:.72rem; font-weight:600; width:40px; flex-shrink:0; }
.ctrl-name { font-size:.8rem; color:var(--text-secondary); flex:1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ctrl-fw { font-family:var(--font-mono); font-size:.6rem; padding:3px 8px; border-radius:3px; flex-shrink:0; }
.mini-foot { font-family:var(--font-mono); font-size:.68rem; color:var(--text-dim); padding:10px 0 0; text-align:center; }
.mini-cia { display:flex; flex-direction:column; gap:12px; }
.cia-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:8px 12px; border-radius:8px;
  background:var(--violet-dim); border:1px solid var(--violet-border);
}
.cia-header span:first-child { font-family:var(--font-mono); font-size:.68rem; font-weight:700; color:var(--violet); text-transform:uppercase; letter-spacing:.04em; }
.cia-score { font-size:.82rem; font-weight:800; color:var(--violet); text-shadow:0 0 10px rgba(167,139,250,.4); }
.cia-bars { display:flex; flex-direction:column; gap:6px; }
.cia-bar { display:flex; align-items:center; gap:6px; }
.cia-letter { font-family:var(--font-mono); font-size:.72rem; font-weight:700; width:16px; }
.cia-track { flex:1; height:4px; background:rgba(255,255,255,.05); border-radius:2px; overflow:hidden; }
.cia-fill { height:100%; border-radius:2px; box-shadow:0 0 8px currentColor; }
.cia-val { font-family:var(--font-mono); font-size:.72rem; font-weight:700; width:16px; text-align:right; }
.cia-composite {
  padding:10px 14px; border-radius:8px;
  background:var(--violet-dim); border:1px solid var(--violet-border);
  display:flex; flex-direction:column; gap:4px;
}
.cia-composite > span:first-child { font-family:var(--font-mono); font-size:.62rem; color:var(--violet); text-transform:uppercase; font-weight:600; }
.cia-composite-val { font-size:.88rem; font-weight:800; color:var(--violet); }
.cia-composite-bar { height:4px; background:rgba(255,255,255,.05); border-radius:3px; overflow:hidden; }
.cia-suggestion { font-size:.72rem; color:var(--text-secondary); }
.cia-suggestion strong { color:var(--violet); font-weight:700; }

/* Floating badges */
.hero-badge {
  position:absolute; display:flex; align-items:center; gap:8px;
  padding:10px 16px; border-radius:12px;
  background:rgba(10,16,26,0.45);
  backdrop-filter:blur(28px) saturate(1.4);
  -webkit-backdrop-filter:blur(28px) saturate(1.4);
  border:1px solid rgba(255,255,255,0.08);
  font-family:var(--font-mono); font-size:.68rem; color:var(--text-secondary);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.05), 0 12px 32px rgba(0,0,0,0.25);
  animation:badgeFloat 8s ease-in-out infinite;
}
.hero-badge svg { width:16px; height:16px; stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round; }
.hero-badge--1 { top:-8px; right:-12px; color:var(--teal); border-color:rgba(45,212,191,.15); }
.hero-badge--1 svg { stroke:var(--teal); filter:drop-shadow(0 0 4px var(--teal)); }
.hero-badge--2 { bottom:30px; left:-20px; animation-delay:-4s; color:var(--amber); border-color:rgba(240,160,48,.15); }
.hero-badge--2 svg { stroke:var(--amber); filter:drop-shadow(0 0 4px var(--amber)); }
@keyframes badgeFloat { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-12px); } }

/* --- PILLARS --- */
.pillars { padding:80px 0; position:relative; }
.pillars-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.pillar-card { padding:36px 28px; display:flex; flex-direction:column; }
.pillar-icon {
  width:52px; height:52px; border-radius:14px;
  display:flex; align-items:center; justify-content:center; margin-bottom:22px;
}
.pillar-icon svg { width:24px; height:24px; fill:none; stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round; }
.pillar-icon--teal { background:var(--teal-dim); border:1px solid rgba(45,212,191,.15); }
.pillar-icon--teal svg { stroke:var(--teal); filter:drop-shadow(0 0 6px rgba(45,212,191,.3)); }
.pillar-icon--amber { background:var(--amber-dim); border:1px solid var(--amber-border); }
.pillar-icon--amber svg { stroke:var(--amber); filter:drop-shadow(0 0 6px rgba(240,160,48,.3)); }
.pillar-icon--violet { background:var(--violet-dim); border:1px solid var(--violet-border); }
.pillar-icon--violet svg { stroke:var(--violet); filter:drop-shadow(0 0 6px rgba(167,139,250,.3)); }
.pillar-card h3 { font-size:1.2rem; margin-bottom:6px; }
.pillar-tagline { font-size:.9rem; color:var(--text-secondary); margin-bottom:12px; }
.pillar-card > p { font-size:.88rem; color:var(--text-secondary); line-height:1.65; flex:1; margin-bottom:20px; }
.pillar-link {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-mono); font-size:.78rem; color:var(--teal);
  transition:all .25s; min-height:44px;
}
.pillar-link svg { stroke:currentColor; fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.pillar-link:hover { gap:14px; text-shadow:0 0 10px rgba(45,212,191,.4); }

/* --- PULLQUOTE --- */
.quote-section { padding:20px 0 80px; }
.pullquote {
  position:relative; max-width:760px;
  padding:32px 0 32px 36px;
  border-left:3px solid var(--teal);
  box-shadow:-6px 0 30px rgba(45,212,191,.06);
}
.pullquote p {
  font-family:var(--font-editorial); font-style:italic;
  font-size:clamp(1.2rem,2.5vw,1.5rem); line-height:1.6; color:var(--text-primary);
}
.pullquote footer { margin-top:20px; }
.pullquote cite {
  font-family:var(--font-mono); font-style:normal;
  font-size:.78rem; color:var(--teal); letter-spacing:.04em;
}

/* --- PROOF --- */
.proof { padding:80px 0; }
.proof-grid { display:flex; flex-direction:column; gap:16px; }
.proof-item { display:flex; gap:20px; align-items:flex-start; padding:28px 28px; }
.proof-icon {
  width:48px; height:48px; border-radius:12px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
}
.proof-icon svg {
  width:22px; height:22px; fill:none; stroke-width:1.5;
  stroke-linecap:round; stroke-linejoin:round;
  filter:drop-shadow(0 0 6px currentColor);
}
.proof-item h3 { font-size:1.05rem; font-weight:600; margin-bottom:6px; }
.proof-item p { font-size:.88rem; color:var(--text-secondary); line-height:1.65; }

/* --- SHOWCASE --- */
.showcase { padding:80px 0; position:relative; }
.showcase-tabs { display:flex; gap:8px; margin-bottom:20px; flex-wrap:wrap; }
.showcase-tab {
  padding:10px 22px; border-radius:var(--radius-sm);
  font-family:var(--font-mono); font-size:.78rem; font-weight:500;
  background:transparent; border:1px solid var(--border); color:var(--text-dim);
  cursor:pointer; transition:all .3s; min-height:44px;
  display:inline-flex; align-items:center;
}
.showcase-tab:hover { color:var(--text-secondary); border-color:var(--border-light); }
.showcase-tab.active {
  background:rgba(45,212,191,.08); color:var(--teal);
  border-color:rgba(45,212,191,.25);
  box-shadow:0 0 16px rgba(45,212,191,.08);
}
.showcase-panel { display:none; }
.showcase-panel.active { display:block; animation:panelFade .4s ease; }
@keyframes panelFade { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:translateY(0); } }
.showcase-panel.glass {
  background:rgba(10,16,26,0.4);
  backdrop-filter:blur(28px) saturate(1.4);
  -webkit-backdrop-filter:blur(28px) saturate(1.4);
  border-color:rgba(255,255,255,0.07);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.05), 0 8px 32px rgba(0,0,0,0.2);
}
.showcase-content { display:grid; grid-template-columns:1fr 1fr; min-height:320px; }
.showcase-info { padding:36px 32px; display:flex; flex-direction:column; justify-content:center; }
.showcase-info h3 { font-size:1.2rem; margin-bottom:6px; }
.showcase-sub { font-size:.9rem; color:var(--text-secondary); margin-bottom:18px; }
.showcase-info ul { list-style:none; display:flex; flex-direction:column; gap:10px; margin-bottom:24px; }
.showcase-info ul li {
  color:var(--text-secondary); font-size:.86rem; padding-left:22px; position:relative; line-height:1.55;
}
.showcase-info ul li::before {
  content:''; position:absolute; left:0; top:7px;
  width:8px; height:8px; border-right:1.5px solid var(--teal);
  border-bottom:1.5px solid var(--teal); transform:rotate(-45deg);
}
.showcase-stats {
  padding:36px 32px; display:flex; flex-direction:column; justify-content:center;
  background:rgba(5,10,18,.5); position:relative;
}
.showcase-stats::before {
  content:''; position:absolute; top:0; right:0;
  width:3px; height:50%; background:var(--teal);
  box-shadow:0 0 12px var(--teal);
}
.showcase-stats::after {
  content:''; position:absolute; top:0; right:0;
  width:35%; height:3px; background:var(--teal);
  box-shadow:0 0 12px var(--teal);
}
.stat-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.stat-item { text-align:center; }
.stat-num {
  font-family:var(--font-mono); font-size:2rem; font-weight:700;
  color:var(--teal); display:block; line-height:1;
  text-shadow:0 0 20px rgba(45,212,191,.3);
}
.stat-lbl { font-size:.76rem; color:var(--text-dim); margin-top:8px; display:block; }

/* --- START HERE --- */
.start-here { padding:80px 0; }
.start-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.start-card { padding:36px 28px; display:flex; flex-direction:column; text-decoration:none; }
.start-icon { width:44px; height:44px; margin-bottom:16px; }
.start-icon svg { width:28px; height:28px; fill:none; stroke:currentColor; stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round; filter:drop-shadow(0 0 8px currentColor); }
.start-card h3 { font-size:1.08rem; margin-bottom:8px; }
.start-card > p { font-size:.86rem; color:var(--text-secondary); line-height:1.6; flex:1; margin-bottom:18px; }
.start-cta {
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--font-mono); font-size:.78rem; color:var(--teal);
  transition:all .25s; min-height:44px;
}
.start-cta svg { stroke:currentColor; fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.future-card:hover .start-cta { gap:12px; text-shadow:0 0 10px rgba(45,212,191,.4); }

/* --- CONTACT --- */
.contact { padding:80px 0; }
.contact-layout { display:grid; grid-template-columns:1fr 1fr; gap:32px; align-items:start; }
.contact-info h2 { font-size:clamp(1.4rem,2.5vw,1.8rem); margin-bottom:14px; }
.contact-info > p { font-size:.92rem; color:var(--text-secondary); line-height:1.65; margin-bottom:24px; }
.contact-checklist { display:flex; flex-direction:column; gap:10px; margin-bottom:28px; }
.contact-checklist li {
  font-size:.86rem; color:var(--text-secondary); padding-left:22px; position:relative; line-height:1.5;
}
.contact-checklist li::before {
  content:''; position:absolute; left:0; top:7px;
  width:8px; height:8px; border-right:1.5px solid var(--teal);
  border-bottom:1.5px solid var(--teal); transform:rotate(-45deg);
}
.contact-email { padding-top:20px; border-top:1px solid var(--border); }
.contact-email .label-mono { display:block; margin-bottom:6px; }
.contact-email a {
  font-family:var(--font-mono); font-size:.9rem; color:var(--teal);
  transition:all .2s; text-shadow:0 0 0 transparent;
  min-height:44px; display:inline-flex; align-items:center;
}
.contact-email a:hover { text-shadow:0 0 12px rgba(45,212,191,.4); }
.contact-form { padding:32px; }

/* ===========================================
   RESPONSIVE - Truly mobile-friendly
   =========================================== */

/* -- Tablet landscape -- */
@media (max-width:1024px) {
  .hero-inner { grid-template-columns:1fr; gap:48px; }
  .hero-text { max-width:100%; }
  .hero-badge { display:none; }
  .preview-window { transform:none; max-width:560px; margin:0 auto; }
  .preview-window:hover { transform:none; }
  .pillars-grid { grid-template-columns:1fr 1fr; }
  .start-grid { grid-template-columns:1fr 1fr; }
}

/* -- Tablet portrait -- */
@media (max-width:900px) {
  .showcase-content { grid-template-columns:1fr; }
  .contact-layout { grid-template-columns:1fr; }
  .hero-orb { display:none; }

  .pillars { padding:80px 0; }
  .proof { padding:60px 0; }
  .showcase { padding:60px 0; }
  .start-here { padding:60px 0; }
  .contact { padding:60px 0; }
  .quote-section { padding:20px 0 60px; }
}

/* -- Mobile -- */
@media (max-width:768px) {
  .hero { padding:92px 0 48px; min-height:auto; }
  .hero-inner { gap:36px; }

  /* Hero text container - no overflow:hidden needed since cursor shadow and gradient-text are killed */
  .hero-text { max-width:100%; }
  .hero-h1 { max-width:100%; margin-bottom:18px; }

  /* Kill gradient-text on mobile - background-clip:text causes iOS Safari layout bugs */
  .hero-typed-wrap.gradient-text {
    background:none; -webkit-background-clip:unset; background-clip:unset;
    -webkit-text-fill-color:var(--teal); color:var(--teal);
  }

  /* Kill cursor text-shadow on mobile - the 10px glow extends past container edge */
  .typed-cursor { text-shadow:none; animation:none; }
  .hero-sub { font-size:.95rem; margin-bottom:10px; }
  .hero-audience { font-size:.88rem; margin-bottom:24px; }

  /* Hero buttons side by side on mobile */
  .hero-actions { flex-direction:column; gap:10px; }
  .hero-actions .btn { width:100%; justify-content:center; }

  /* Hero tags - larger touch targets */
  .hero-tags { gap:8px; }
  .hero-tag {
    font-size:.76rem; padding:8px 16px;
    min-height:40px; display:inline-flex; align-items:center;
  }

  /* Preview window mobile */
  .preview-window { border-radius:var(--radius-md); }
  .mini-kpis { grid-template-columns:repeat(2,1fr); gap:8px; }
  .mini-kpi { padding:12px 10px; }
  .mini-kpi-val { font-size:1.2rem; }
  .mini-kpi-lbl { font-size:.52rem; }
  .mini-row { padding:10px 12px; }
  .mini-row-text { font-size:.78rem; }
  .mini-sev { font-size:.62rem; padding:3px 10px; }

  /* Larger slide dots for touch */
  .preview-dots-nav { gap:10px; padding:14px 0 18px; }

  /* Controls slide mobile */
  .mini-ctrl { padding:10px 12px; gap:10px; }
  .ctrl-id { font-size:.68rem; width:44px; }
  .ctrl-name { font-size:.78rem; }
  .ctrl-fw { font-size:.54rem; padding:3px 8px; }

  /* CIA slide mobile */
  .cia-header { padding:10px 14px; }
  .cia-header span:first-child { font-size:.62rem; }
  .cia-score { font-size:.88rem; }
  .cia-letter { font-size:.68rem; }
  .cia-val { font-size:.68rem; }
  .cia-composite { padding:12px 16px; }
  .cia-composite > span:first-child { font-size:.56rem; }
  .cia-suggestion { font-size:.68rem; }

  /* Pillars */
  .pillars-grid { grid-template-columns:1fr; gap:14px; }
  .pillar-card { padding:28px 24px; }
  .pillar-card h3 { font-size:1.15rem; }
  .pillar-card > p { font-size:.9rem; line-height:1.7; }
  .pillar-link { font-size:.82rem; min-height:44px; display:inline-flex; align-items:center; }

  /* Pullquote */
  .pullquote { padding:28px 0 28px 24px; }
  .pullquote p { font-size:1.1rem; }

  /* Proof */
  .proof-grid { gap:10px; }
  .proof-item { padding:24px 20px; gap:16px; flex-direction:column; }
  .proof-icon { width:44px; height:44px; }
  .proof-item h3 { font-size:1.05rem; }
  .proof-item p { font-size:.9rem; }

  /* Showcase tabs - horizontal scroll */
  .showcase { overflow:hidden; }
  .showcase-tabs {
    flex-wrap:nowrap; overflow-x:auto; -webkit-overflow-scrolling:touch;
    scrollbar-width:none; gap:8px; padding-bottom:4px;
    margin-left:-16px; margin-right:-16px; padding-left:16px; padding-right:16px;
  }
  .showcase-tabs::-webkit-scrollbar { display:none; }
  .showcase-tab {
    flex-shrink:0; padding:12px 20px; font-size:.78rem;
    min-height:44px; display:inline-flex; align-items:center;
  }

  /* Start here */
  .start-grid { grid-template-columns:1fr; gap:12px; }

  /* Contact */
  .contact-info h2 { font-size:1.4rem; }
  .contact-info > p { font-size:.92rem; }
  .contact-checklist li { font-size:.9rem; min-height:32px; display:flex; align-items:center; }
  .contact-form { padding:24px 20px; }
  .contact-email a { font-size:.92rem; }
}

/* -- Small phones -- */
@media (max-width:480px) {
  .hero { padding:88px 0 40px; }
  .hero-label { font-size:.72rem; margin-bottom:14px; }
  .hero-h1 { line-height:1.12; letter-spacing:-0.04em; }
  .hero-sub { font-size:.9rem; }
  .hero-audience { font-size:.84rem; margin-bottom:20px; }

  /* Kill transforms that could cause layout expansion */
  .preview-window, .preview-window:hover { transform:none; }
  .hero-badge { animation:none; }

  .preview-body { padding:12px; }
  .preview-titlebar { padding:10px 12px; }
  .preview-url { font-size:.62rem; }
  .preview-label { font-size:.62rem; }

  .pillar-icon { width:44px; height:44px; }
  .pillar-tagline { font-size:.86rem; }

  .pullquote { padding:20px 0 20px 20px; }
  .pullquote p { font-size:1rem; }

  .showcase-panel { border-radius:var(--radius-sm); }

  .scan-line { display:none; }
}

/* -- Tiny phones (320px) -- */
@media (max-width:360px) {
  .hero-tag { font-size:.7rem; padding:6px 12px; }
  .mini-kpis { gap:6px; }
  .mini-kpi { padding:10px 8px; }
  .mini-kpi-val { font-size:1rem; }
  .showcase-tab { padding:10px 14px; font-size:.72rem; }
}

/* -- Reduced motion: reduce but don't kill -- */
@media (prefers-reduced-motion:reduce) {
  .scan-line { animation:none; opacity:.06; top:0; }
  .hero-orb, .hero-glow { animation:none; }
  .hero-grid { animation:none; }
  .hero-badge { animation:none; }
  .future-card:hover { transform:none; }
  .preview-window, .preview-window:hover { transform:none; }
}
