/* layout.css — header, nav, footer */

/* Header */
.header {
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(154,182,255,0.06), transparent 60%);
}

/* Header bar: brand left, nav right */
.header .wrap,
.header .header-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding-top: var(--space-4);
  padding-bottom: 0;
}

/* Brand lockup (text left, logo right) */
.brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-5);
  text-decoration: none;
  color: var(--text);
}

.brand-text {
  font-weight: 800;
  font-size: 18px;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  line-height: 1;
}

.brand-mark {
  height: 44px;
  width: auto;
  display: block;
  flex: 0 0 auto;
  transform: translateY(0.5px); /* baseline micro-nudge; adjust if needed */
}

/* Nav */
.nav {
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
  padding: var(--space-4) 0;
}
.nav a { color: var(--text-dim); font-weight: 600; }
.nav a.active, .nav a:hover { color: var(--text); }

/* Footer */
.footer {
  border-top: 1px solid var(--line);
  color: var(--text-dim);
  padding: var(--space-6) 0;
  margin-top: var(--space-8);
}


/* Footer lockup (logo + copyright inline) */
.footer .wrap {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}

/* Footer logo sizing */
.footer .logo img {
  height: 20px;
  width: auto;
  display: block;
  opacity: 0.9;
}

/* Responsive */
@media (max-width: 960px) {
  .brand-text { font-size: 16px; }
  .brand-mark { height: 30px; }
}
@media (max-width: 600px) {
  .brand { gap: var(--space-3); }
  .brand-text { font-size: 15px; letter-spacing: 0.4px; }
  .brand-mark { height: 26px; }
  
  .footer .logo img { height: 18px; }
}
