/* ═══════════════════════════════════════════════════
   COSMIC EXPLORER 2055 — MASTER CSS
═══════════════════════════════════════════════════ */
:root {
  --void:#00000a; --deep:#010115; --mid:#020230;
  --glass:rgba(3,3,40,0.65); --glass2:rgba(0,10,50,0.45);
  --cyan:#00f5ff; --cyan2:#00cfff; --purple:#b44fff;
  --gold:#ffd700; --rose:#ff4aaa; --green:#00ffaa;
  --border:rgba(0,245,255,0.18); --border2:rgba(180,79,255,0.2);
  --glow-c:0 0 40px rgba(0,245,255,0.45);
  --glow-p:0 0 40px rgba(180,79,255,0.45);
  --text:#e8f4ff; --dim:#7a9ab8;
  --font-h:'Orbitron',sans-serif;
  --font-b:'Rajdhani',sans-serif;
  --font-s:'Exo 2',sans-serif;
}
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { background:var(--void); color:var(--text); font-family:var(--font-b); overflow-x:hidden; cursor:none; }

/* ── CURSOR ── */
#cursor {
  position:fixed; width:10px; height:10px; border-radius:50%;
  background:var(--cyan); pointer-events:none; z-index:9999;
  transform:translate(-50%,-50%);
  box-shadow:0 0 12px var(--cyan), 0 0 24px rgba(0,245,255,0.4);
  mix-blend-mode:screen; transition:transform 0.05s;
}
#cursor-ring {
  position:fixed; width:34px; height:34px; border-radius:50%;
  border:1px solid rgba(0,245,255,0.5); pointer-events:none; z-index:9998;
  transform:translate(-50%,-50%); transition:all 0.12s ease;
}
body:has(a:hover) #cursor-ring, body:has(button:hover) #cursor-ring {
  width:54px; height:54px; border-color:var(--purple);
}

/* ── GALAXY CANVAS ── */
#galaxy-canvas { position:fixed; inset:0; z-index:0; pointer-events:none; }

/* ── NEBULA ── */
.nebula {
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(ellipse 70% 55% at 15% 25%, rgba(100,0,200,0.1) 0%, transparent 65%),
    radial-gradient(ellipse 60% 70% at 85% 65%, rgba(0,60,180,0.09) 0%, transparent 65%),
    radial-gradient(ellipse 40% 35% at 50% 5%,  rgba(255,50,0,0.04) 0%, transparent 60%);
  animation: nebula-breathe 20s ease-in-out infinite alternate;
}
@keyframes nebula-breathe { 0%{transform:scale(1)}100%{transform:scale(1.05)} }

/* ── SCANLINES ── */
.scanlines {
  position:fixed; inset:0; z-index:1; pointer-events:none;
  background:repeating-linear-gradient(0deg, transparent, transparent 2px,
    rgba(0,0,0,0.025) 2px, rgba(0,0,0,0.025) 4px);
}

/* ── RGB TEXT ── */
.rgb {
  background:linear-gradient(90deg,#ff0080,#ff8c00,#ffd700,#00ff88,#00cfff,#b44fff,#ff0080);
  background-size:400% 100%;
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text; animation:rgb-flow 5s linear infinite;
}
@keyframes rgb-flow { 0%{background-position:0%}100%{background-position:400%} }

/* ── NAVBAR ── */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:200; height:68px;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 3rem;
  background:rgba(0,0,12,0.75);
  backdrop-filter:blur(22px) saturate(160%);
  border-bottom:1px solid var(--border);
}
.nav-logo { display:flex; align-items:center; gap:12px; text-decoration:none; }
.nav-logo-icon {
  width:34px; height:34px; border:1px solid var(--cyan);
  display:flex; align-items:center; justify-content:center; font-size:0.9rem;
  box-shadow:var(--glow-c); animation:logo-pulse 3s ease-in-out infinite;
}
@keyframes logo-pulse { 0%,100%{box-shadow:var(--glow-c)} 50%{box-shadow:0 0 60px rgba(0,245,255,0.7)} }
.nav-logo-text { font-family:var(--font-h); font-size:0.85rem; font-weight:900; letter-spacing:0.25em; }
.nav-links { display:flex; gap:2rem; }
.nav-link {
  font-family:var(--font-h); font-size:0.58rem; letter-spacing:0.2em;
  color:var(--dim); text-decoration:none; transition:all 0.3s;
  padding-bottom:2px; border-bottom:1px solid transparent;
}
.nav-link:hover { color:var(--cyan); border-color:var(--cyan); }
.nav-actions { display:flex; gap:0.8rem; align-items:center; }
.nav-user-info { display:flex; align-items:center; gap:8px; }
.nav-avatar { font-size:1.2rem; }
.nav-username { font-family:var(--font-h); font-size:0.65rem; letter-spacing:0.12em; }
.nav-badge {
  font-family:var(--font-h); font-size:0.5rem; letter-spacing:0.15em;
  background:rgba(180,79,255,0.2); border:1px solid var(--purple);
  color:var(--purple); padding:0.15rem 0.5rem;
}
.btn-outline {
  font-family:var(--font-h); font-size:0.6rem; letter-spacing:0.15em;
  padding:0.45rem 1.2rem; border:1px solid var(--border);
  color:var(--dim); background:transparent; cursor:pointer;
  transition:all 0.3s; text-decoration:none; display:inline-flex; align-items:center; gap:6px;
}
.btn-outline:hover { border-color:var(--cyan); color:var(--cyan); box-shadow:var(--glow-c); }
.btn-primary {
  font-family:var(--font-h); font-size:0.6rem; letter-spacing:0.15em;
  padding:0.45rem 1.3rem; border:1px solid var(--cyan);
  color:var(--void); background:var(--cyan); cursor:pointer; font-weight:700;
  transition:all 0.3s; text-decoration:none; display:inline-flex; align-items:center; gap:6px;
}
.btn-primary:hover { background:transparent; color:var(--cyan); box-shadow:var(--glow-c); }
.btn-small { padding:0.38rem 0.9rem; font-size:0.55rem; }

/* ── HERO ── */
.hero {
  position:relative; min-height:100vh; z-index:2;
  display:flex; align-items:center; padding:68px 5rem 0;
  overflow:hidden;
}
.hero-left { flex:1; max-width:600px; z-index:2; }
.hero-eyebrow {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-h); font-size:0.58rem; letter-spacing:0.4em; color:var(--dim);
  border:1px solid var(--border); padding:0.38rem 1.2rem; margin-bottom:2rem;
}
.eyebrow-dot {
  width:6px; height:6px; border-radius:50%; background:var(--cyan);
  animation:blink 1.5s ease-in-out infinite;
}
@keyframes blink { 0%,100%{opacity:1}50%{opacity:0.2} }
.hero-title {
  font-family:var(--font-h); font-weight:900; line-height:0.95;
  font-size:clamp(2.8rem,7vw,6.5rem); letter-spacing:-0.02em; margin-bottom:1.5rem;
}
.ht1,.ht3 { display:block; }
.ht2 { display:block; color:transparent; -webkit-text-stroke:1.5px rgba(255,255,255,0.22); }
.hero-sub {
  font-family:var(--font-s); font-weight:200; font-size:1.05rem;
  color:var(--dim); line-height:1.8; max-width:460px; margin-bottom:2.5rem;
}
.hero-cta { display:flex; gap:1rem; flex-wrap:wrap; }
.hero-stats {
  display:flex; gap:2.5rem; margin-top:4rem;
  padding-top:2rem; border-top:1px solid var(--border);
}
.stat-num { font-family:var(--font-h); font-size:1.5rem; font-weight:900; color:white; display:block; }
.stat-lbl { font-family:var(--font-h); font-size:0.52rem; letter-spacing:0.12em; color:var(--dim); }
.hero-planet-area {
  position:absolute; right:0; top:0; bottom:0; width:52%;
  display:flex; align-items:center; justify-content:center;
  z-index:1; pointer-events:none;
}
.scroll-hint {
  position:absolute; bottom:3rem; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:6px; z-index:2;
  animation:scroll-bounce 2s ease-in-out infinite;
}
@keyframes scroll-bounce { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(8px)} }
.scroll-line { width:1px; height:48px; background:linear-gradient(to bottom,var(--cyan),transparent); }
.scroll-txt { font-family:var(--font-h); font-size:0.5rem; letter-spacing:0.35em; color:var(--dim); }

/* ── SECTION ── */
.section { position:relative; z-index:2; padding:7rem 5rem; }
.sec-header { text-align:center; margin-bottom:4.5rem; }
.sec-tag {
  display:inline-block; font-family:var(--font-h); font-size:0.55rem;
  letter-spacing:0.4em; color:var(--purple); border:1px solid var(--border2);
  padding:0.3rem 1rem; margin-bottom:1.2rem;
}
.sec-title { font-family:var(--font-h); font-size:clamp(1.8rem,4vw,2.8rem); font-weight:900; letter-spacing:0.1em; margin-bottom:0.8rem; }
.sec-desc { font-family:var(--font-s); color:var(--dim); font-size:1rem; font-weight:300; }

/* ── MENU GRID ── */
.menu-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1.5px; max-width:1300px; margin:0 auto;
  background:var(--border);
}
.menu-card {
  position:relative; background:var(--void); padding:2.5rem 2rem;
  cursor:pointer; text-decoration:none; color:var(--text);
  overflow:hidden; transition:background 0.4s; display:block;
}
.menu-card::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(0,245,255,0.04) 0%,transparent 50%,rgba(180,79,255,0.04) 100%);
  opacity:0; transition:opacity 0.4s;
}
.menu-card:hover::before { opacity:1; }
.menu-card::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,var(--cyan),var(--purple));
  transform:scaleX(0); transform-origin:left; transition:transform 0.4s;
}
.menu-card:hover::after { transform:scaleX(1); }
.menu-card:hover { background:rgba(0,10,40,0.85); }
.card-num { font-family:var(--font-h); font-size:0.52rem; color:rgba(255,255,255,0.12); letter-spacing:0.2em; margin-bottom:1.5rem; display:block; transition:color 0.3s; }
.menu-card:hover .card-num { color:var(--cyan); }
.card-3d { height:148px; display:flex; align-items:center; justify-content:center; margin-bottom:1.5rem; }
.card-title { font-family:var(--font-h); font-size:0.82rem; font-weight:700; letter-spacing:0.12em; margin-bottom:0.5rem; transition:color 0.3s; }
.menu-card:hover .card-title { color:var(--cyan); }
.card-desc { font-family:var(--font-s); font-weight:300; font-size:0.82rem; color:var(--dim); line-height:1.6; }
.card-arrow { position:absolute; bottom:2rem; right:2rem; font-family:var(--font-h); font-size:0.7rem; color:rgba(255,255,255,0.12); transition:all 0.3s; }
.menu-card:hover .card-arrow { color:var(--cyan); transform:translate(4px,-4px); }

/* ── TEAM ── */
.team-section { position:relative; z-index:2; padding:6rem 5rem; border-top:1px solid var(--border); }
.team-grid { display:flex; justify-content:center; gap:2.5rem; flex-wrap:wrap; max-width:860px; margin:4rem auto 0; }
.team-card {
  background:var(--glass); border:1px solid var(--border);
  padding:2.5rem 2rem; text-align:center; width:210px;
  backdrop-filter:blur(20px); transition:all 0.4s;
  position:relative; overflow:hidden;
}
.team-card::before {
  content:''; position:absolute; top:-50%; left:-50%; width:200%; height:200%;
  background:conic-gradient(transparent 0deg,rgba(0,245,255,0.04) 60deg,transparent 120deg);
  animation:card-spin 7s linear infinite;
}
@keyframes card-spin { from{transform:rotate(0deg)}to{transform:rotate(360deg)} }
.team-card:hover { border-color:rgba(0,245,255,0.4); transform:translateY(-8px); box-shadow:0 20px 60px rgba(0,0,0,0.5),var(--glow-c); }
.team-avatar {
  width:88px; height:88px; border-radius:50%;
  background:linear-gradient(135deg,rgba(0,245,255,0.15),rgba(180,79,255,0.15));
  border:2px solid var(--border); display:flex; align-items:center; justify-content:center;
  font-family:var(--font-h); font-size:1.3rem; font-weight:900;
  margin:0 auto 1.2rem; position:relative; z-index:1; transition:all 0.3s;
}
.team-card:hover .team-avatar { border-color:var(--cyan); box-shadow:var(--glow-c); }
.team-name { font-family:var(--font-h); font-size:0.72rem; letter-spacing:0.1em; display:block; margin-bottom:0.4rem; position:relative; z-index:1; }
.team-role { font-size:0.78rem; color:var(--dim); font-family:var(--font-s); font-weight:300; position:relative; z-index:1; }

/* ── PAGE LAYOUTS ── */
.page-wrap { position:relative; z-index:2; padding-top:68px; min-height:100vh; }
.page-hero { text-align:center; padding:5rem 2rem 3rem; position:relative; }
.page-hero::after { content:''; position:absolute; bottom:0; left:50%; transform:translateX(-50%); width:200px; height:1px; background:linear-gradient(90deg,transparent,var(--cyan),transparent); }
.ph-tag { display:inline-block; font-family:var(--font-h); font-size:0.55rem; letter-spacing:0.4em; color:var(--purple); border:1px solid var(--border2); padding:0.3rem 1rem; margin-bottom:1.2rem; }
.ph-title { font-family:var(--font-h); font-size:clamp(2rem,5vw,3.2rem); font-weight:900; letter-spacing:0.1em; margin-bottom:0.6rem; }
.ph-sub { font-family:var(--font-s); color:var(--dim); font-size:1rem; font-weight:300; }

/* ── OBJECTS GRID ── */
.objects-grid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(190px,1fr));
  gap:1.5px; background:var(--border);
  padding:3rem; max-width:1400px; margin:0 auto;
}
.obj-card {
  background:var(--void); padding:1.8rem 1.5rem;
  cursor:pointer; transition:background 0.3s;
  position:relative; overflow:hidden;
}
.obj-card::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,var(--cyan),var(--purple));
  transform:scaleX(0); transform-origin:left; transition:transform 0.4s;
}
.obj-card:hover::after { transform:scaleX(1); }
.obj-card:hover { background:rgba(0,10,40,0.9); }
.obj-3d { height:130px; display:flex; align-items:center; justify-content:center; margin-bottom:1.2rem; }
.obj-name { font-family:var(--font-h); font-size:0.72rem; letter-spacing:0.1em; font-weight:700; display:block; margin-bottom:0.3rem; }
.obj-type { font-size:0.75rem; color:var(--dim); font-family:var(--font-s); font-weight:300; }

/* ── AUTH MODAL ── */
.modal-overlay {
  position:fixed; inset:0; z-index:500;
  background:rgba(0,0,12,0.93); backdrop-filter:blur(16px);
  opacity:0; visibility:hidden; transition:all 0.35s;
  display:flex; align-items:center; justify-content:center; padding:2rem;
}
.modal-overlay.open { opacity:1; visibility:visible; }
.auth-modal {
  background:linear-gradient(135deg,rgba(2,2,28,0.99),rgba(5,0,25,0.99));
  border:1px solid var(--border); max-width:440px; width:100%;
  position:relative; animation:modal-rise 0.4s cubic-bezier(0.34,1.56,0.64,1);
  box-shadow:0 0 100px rgba(0,0,0,0.8), var(--glow-c); padding:3rem;
}
@keyframes modal-rise { from{transform:scale(0.85) translateY(20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1} }
.modal-close-btn {
  position:absolute; top:1.2rem; right:1.2rem; background:transparent;
  border:1px solid var(--border); color:var(--dim); width:32px; height:32px;
  cursor:pointer; font-size:0.85rem; display:flex; align-items:center; justify-content:center; transition:all 0.3s;
}
.modal-close-btn:hover { border-color:#ff4a4a; color:#ff4a4a; }
.auth-header { text-align:center; margin-bottom:2rem; }
.auth-icon { font-size:2.5rem; margin-bottom:0.8rem; }
.auth-title { font-family:var(--font-h); font-size:1rem; letter-spacing:0.25em; margin-bottom:0.4rem; }
.auth-sub { font-size:0.82rem; color:var(--dim); }
.form-grp { margin-bottom:1.2rem; }
.form-grp label { display:block; font-family:var(--font-h); font-size:0.52rem; letter-spacing:0.2em; color:var(--dim); margin-bottom:0.45rem; }
.form-grp label small { font-size:0.65em; color:rgba(122,154,184,0.7); font-family:var(--font-s); letter-spacing:0; font-weight:300; }
.form-grp input {
  width:100%; background:rgba(0,0,0,0.55); border:1px solid var(--border);
  color:white; padding:0.75rem 1rem; font-family:var(--font-s); font-size:0.95rem;
  outline:none; transition:all 0.3s;
}
.form-grp input:focus { border-color:var(--cyan); box-shadow:0 0 20px rgba(0,245,255,0.12); }
.pw-wrap { position:relative; }
.pw-toggle {
  position:absolute; right:10px; top:50%; transform:translateY(-50%);
  background:none; border:none; cursor:pointer; font-size:0.9rem; color:var(--dim); transition:color 0.2s;
}
.pw-toggle:hover { color:var(--cyan); }
.submit-btn {
  width:100%; padding:0.9rem; cursor:pointer;
  background:linear-gradient(90deg,rgba(0,245,255,0.12),rgba(180,79,255,0.12));
  border:1px solid rgba(0,245,255,0.35); color:white; font-family:var(--font-h);
  font-size:0.7rem; letter-spacing:0.2em; transition:all 0.3s; margin-top:0.5rem;
}
.submit-btn:hover { background:linear-gradient(90deg,rgba(0,245,255,0.25),rgba(180,79,255,0.25)); box-shadow:var(--glow-c); }
.submit-btn:disabled { opacity:0.6; cursor:not-allowed; }
.auth-switch { text-align:center; margin-top:1.2rem; font-size:0.85rem; color:var(--dim); }
.link-btn { background:none; border:none; color:var(--cyan); cursor:pointer; font-size:0.85rem; text-decoration:underline; transition:color 0.2s; }
.link-btn:hover { color:var(--cyan2); }
.msg-err { background:rgba(255,50,50,0.07); border:1px solid rgba(255,50,50,0.25); color:#ff9999; padding:0.6rem 1rem; font-size:0.82rem; margin-bottom:1rem; border-radius:0; }
.msg-ok  { background:rgba(0,255,120,0.07); border:1px solid rgba(0,255,120,0.25); color:#99ffcc; padding:0.6rem 1rem; font-size:0.82rem; margin-bottom:1rem; border-radius:0; }

/* ── OBJECT DETAIL MODAL ── */
.obj-modal {
  background:linear-gradient(135deg,rgba(2,2,28,0.99),rgba(5,0,25,0.99));
  border:1px solid var(--border); max-width:960px; width:100%;
  max-height:92vh; overflow-y:auto; position:relative;
  animation:modal-rise 0.4s cubic-bezier(0.34,1.56,0.64,1);
  box-shadow:0 0 100px rgba(0,0,0,0.8),var(--glow-c);
}
.obj-modal-inner { display:grid; grid-template-columns:1fr 1.2fr; min-height:480px; }
.obj-modal-visual {
  background:rgba(0,0,20,0.8); display:flex; align-items:center; justify-content:center;
  border-right:1px solid var(--border); padding:3rem 2rem; position:relative;
}
.obj-modal-visual::before { content:''; position:absolute; inset:0; background:radial-gradient(circle at 50%,rgba(0,245,255,0.04) 0%,transparent 70%); }
.obj-modal-info { padding:3rem 2.5rem; position:relative; }
.obj-modal-tag { font-family:var(--font-h); font-size:0.52rem; letter-spacing:0.3em; color:var(--purple); margin-bottom:0.8rem; display:block; }
.obj-modal-title { font-family:var(--font-h); font-size:2rem; font-weight:900; letter-spacing:0.05em; margin-bottom:0.4rem; line-height:1; }
.obj-modal-desc { font-family:var(--font-s); font-weight:300; font-size:0.9rem; color:var(--text); line-height:1.85; margin-bottom:1.5rem; }
.obj-modal-stats { display:grid; grid-template-columns:1fr 1fr; gap:0.6rem; margin-bottom:1.8rem; }
.mstat { background:rgba(0,245,255,0.03); border:1px solid rgba(0,245,255,0.08); padding:0.6rem 0.8rem; }
.mstat-key { font-family:var(--font-h); font-size:0.48rem; letter-spacing:0.15em; color:var(--dim); display:block; }
.mstat-val { font-size:0.82rem; color:white; margin-top:0.15rem; font-family:var(--font-s); }
.yt-btn {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,30,30,0.08); border:1px solid rgba(255,60,60,0.3);
  color:#ff8888; padding:0.7rem 1.4rem;
  font-family:var(--font-h); font-size:0.58rem; letter-spacing:0.15em;
  cursor:pointer; text-decoration:none; transition:all 0.3s;
}
.yt-btn:hover { background:rgba(255,30,30,0.2); box-shadow:0 0 25px rgba(255,0,0,0.25); color:#ffbbbb; }

/* ── SOLAR SYSTEM PAGE ── */
.ctrl-bar { display:flex; gap:1rem; justify-content:center; padding:1.5rem 2rem; flex-wrap:wrap; border-bottom:1px solid var(--border); }
.ctrl-btn { font-family:var(--font-h); font-size:0.58rem; letter-spacing:0.12em; padding:0.5rem 1.1rem; border:1px solid var(--border); background:rgba(0,245,255,0.04); color:var(--cyan); cursor:pointer; transition:all 0.3s; }
.ctrl-btn:hover,.ctrl-btn.active { background:rgba(0,245,255,0.14); box-shadow:var(--glow-c); }
.speed-info { font-family:var(--font-h); font-size:0.58rem; color:var(--dim); text-align:center; padding:0.6rem; letter-spacing:0.15em; }
.planet-legend { display:flex; flex-wrap:wrap; gap:0.7rem; justify-content:center; padding:1.5rem 2rem; }
.leg-item { display:flex; align-items:center; gap:6px; font-family:var(--font-h); font-size:0.52rem; letter-spacing:0.1em; color:var(--dim); cursor:pointer; padding:0.3rem 0.8rem; border:1px solid rgba(255,255,255,0.06); transition:all 0.3s; }
.leg-item:hover { color:var(--cyan); border-color:rgba(0,245,255,0.3); }
.leg-dot { width:10px; height:10px; border-radius:50%; flex-shrink:0; }
.htip { position:fixed; pointer-events:none; z-index:100; background:rgba(2,2,28,0.96); border:1px solid var(--border); padding:0.5rem 1rem; font-family:var(--font-h); font-size:0.58rem; color:white; display:none; backdrop-filter:blur(10px); letter-spacing:0.1em; }
#solarCanvas { display:block; margin:0 auto; cursor:crosshair; max-width:100%; }

/* ── FOOTER ── */
.site-footer { position:relative; z-index:2; border-top:1px solid var(--border); padding:2.5rem 5rem; }
.footer-inner { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1rem; }
.footer-logo { font-family:var(--font-h); font-size:0.7rem; letter-spacing:0.3em; }
.footer-copy { font-size:0.78rem; color:var(--dim); font-family:var(--font-s); }
.footer-ver { font-family:var(--font-h); font-size:0.55rem; letter-spacing:0.2em; color:rgba(255,255,255,0.1); }

/* ── SCROLLBAR ── */
::-webkit-scrollbar { width:4px; }
::-webkit-scrollbar-track { background:var(--void); }
::-webkit-scrollbar-thumb { background:rgba(0,245,255,0.3); }

/* ── RESPONSIVE ── */
@media(max-width:1100px){
  .menu-grid { grid-template-columns:repeat(2,1fr); }
  .hero-planet-area { display:none; }
  .hero,.section,.team-section { padding-left:2.5rem; padding-right:2.5rem; }
}
@media(max-width:700px){
  .nav { padding:0 1.5rem; }
  .nav-links { display:none; }
  .hero { padding:68px 1.5rem 0; }
  .section,.team-section { padding:4rem 1.5rem; }
  .menu-grid { grid-template-columns:1fr; }
  .obj-modal-inner { grid-template-columns:1fr; }
  .obj-modal-visual { min-height:200px; }
  .footer-inner { flex-direction:column; text-align:center; }
  .objects-grid { padding:1rem; }
}
