/* ============================================================
   LAYOUT.CSS — Mobile First
   Breakpoints:
     sm:  480px  (großes Smartphone)
     md:  768px  (Tablet)
     lg:  900px  (Desktop)
   ============================================================ */

/* ── PAGE WRAPPER ─────────────────────────────────────────── */
.page-wrapper {
  position: relative;
  z-index: 1;
  max-width: 1120px;
  margin: 0 auto;
  padding: var(--space-lg) var(--space-md) var(--space-2xl);
}

@media (min-width: 480px) {
  .page-wrapper {
    padding: var(--space-xl) var(--space-lg) var(--space-2xl);
  }
}

/* ── HEADER ───────────────────────────────────────────────── */
.site-header {
  text-align: center;
  /* Mobile: sehr kompakt – kein Platz verschwenden */
  margin-bottom: var(--space-md);
  padding-top: var(--space-sm);
}

@media (min-width: 480px) {
  .site-header {
    margin-bottom: var(--space-xl);
  }
}

@media (min-width: 768px) {
  .site-header {
    margin-bottom: 56px;
  }
}

.header-badge {
  display: none; /* Mobile: versteckt */
  font-family: var(--font-display);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--accent);
  border: 1px solid rgba(0, 229, 255, 0.3);
  background: rgba(0, 229, 255, 0.05);
  padding: 5px 14px;
  border-radius: var(--radius-full);
  margin-bottom: var(--space-md);
}

@media (min-width: 480px) {
  .header-badge {
    display: inline-block;
    font-size: 11px;
    letter-spacing: 4px;
    padding: 6px 18px;
  }
}

.site-title {
  font-size: clamp(2rem, 8vw, 4.5rem);
  font-weight: 800;
  letter-spacing: clamp(-1px, -0.05em, -2px);
  background: linear-gradient(135deg, #fff 30%, var(--accent) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: var(--space-md);
  line-height: 1.05;
}

.site-subtitle {
  font-size: 12px;
  color: var(--text-muted);
  letter-spacing: 1px;
}

@media (min-width: 480px) {
  .site-subtitle {
    font-size: 13px;
  }
}

/* ── MAIN GRID ────────────────────────────────────────────── */
.main-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-md);
}

@media (min-width: 480px) {
  .main-grid {
    gap: var(--space-lg);
  }
}

@media (min-width: 900px) {
  .main-grid {
    grid-template-columns: 1fr 360px;
    align-items: start;
  }
}

/* ── CONTROLS COLUMN ──────────────────────────────────────── */
.controls-col {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  order: 1;
}

@media (min-width: 480px) {
  .controls-col {
    gap: var(--space-lg);
  }
}

@media (min-width: 900px) {
  .controls-col {
    order: unset;
  }
}

/* ── PREVIEW COLUMN ───────────────────────────────────────── */
.preview-col {
  order: 2;
}

@media (min-width: 900px) {
  .preview-col {
    position: sticky;
    top: var(--space-lg);
    order: unset;
  }
}

.preview-panel .qr-canvas-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border-radius: var(--radius-md);
  /* Mobile: minimales Padding, QR bekommt mehr Platz */
  padding: var(--space-sm);
  margin-bottom: var(--space-md);
  /* Mobile: Höhe nur so groß wie der QR-Code braucht */
  min-height: unset;
  overflow: hidden;
}

@media (min-width: 480px) {
  .preview-panel .qr-canvas-wrapper {
    padding: var(--space-md);
  }
}

/* ── FOOTER ───────────────────────────────────────────────── */
.site-footer {
  margin-top: var(--space-2xl);
  text-align: center;
  font-size: 11px;
  color: var(--text-muted);
  letter-spacing: 2px;
  padding: 0 var(--space-md);
}

.site-footer span {
  color: var(--accent);
}
