/* ============================================================
   Layout
   ============================================================ */

/* ── 컨테이너 ─────────────────────────────── */
.container {
  width: 100%;
  max-width: var(--max-width);
  margin-inline: auto;
  padding-inline: var(--space-6);
}

/* ── 네비게이션 ───────────────────────────── */
.navbar {
  position: sticky;
  top: 0;
  z-index: 100;
  height: var(--nav-height);
  background: rgba(15,15,15,0.85);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--color-border);
}

.navbar__inner {
  display: flex;
  align-items: center;
  gap: var(--space-6);
  height: 100%;
}

.navbar__logo {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xl);
  font-weight: var(--font-extrabold);
  color: var(--color-primary);
  flex-shrink: 0;
}

.navbar__logo span {
  color: var(--color-text);
  font-weight: var(--font-normal);
}

.navbar__search {
  flex: 1;
  max-width: 480px;
}

.navbar__links {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  margin-left: auto;
}

.navbar__links a {
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--color-text-muted);
  transition: color var(--transition-fast), background var(--transition-fast);
}

.navbar__links a:hover,
.navbar__links a.active {
  color: var(--color-text);
  background: var(--color-bg-glass);
}

.navbar__mobile-toggle {
  display: none;
  padding: var(--space-2);
  border-radius: var(--radius-md);
  color: var(--color-text);
  font-size: var(--text-xl);
}

/* ── 푸터 ─────────────────────────────────── */
.footer {
  margin-top: var(--space-24);
  padding: var(--space-12) 0;
  border-top: 1px solid var(--color-border);
  text-align: center;
}

.footer__text {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}

/* ── 메인 콘텐츠 ──────────────────────────── */
.main-content {
  padding-top: var(--space-10);
  padding-bottom: var(--space-16);
  min-height: calc(100vh - var(--nav-height));
}

/* ── 섹션 ─────────────────────────────────── */
.section {
  margin-bottom: var(--space-16);
}

.section__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-8);
}

.section__title {
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
}

.section__title-accent {
  color: var(--color-primary);
}

.section__link {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  transition: color var(--transition-fast);
}

.section__link:hover { color: var(--color-primary); }

/* ── 그리드 ───────────────────────────────── */
.recipe-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
}

.recipe-grid--3 {
  grid-template-columns: repeat(3, 1fr);
}

/* ── 관리자 레이아웃 ──────────────────────── */
.admin-layout {
  display: flex;
  min-height: 100vh;
}

.admin-sidebar {
  width: var(--sidebar-width);
  flex-shrink: 0;
  background: var(--color-bg-card);
  border-right: 1px solid var(--color-border);
  padding: var(--space-6) 0;
  position: sticky;
  top: 0;
  height: 100vh;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}

.admin-main {
  flex: 1;
  padding: var(--space-8);
  overflow-x: hidden;
}

/* ── 반응형 ───────────────────────────────── */
@media (max-width: 1199px) {
  .recipe-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 767px) {
  .container { padding-inline: var(--space-4); }
  .recipe-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-3); }
  .recipe-grid--3 { grid-template-columns: repeat(2, 1fr); }
  .navbar__search { display: none; }
  .navbar__links { display: none; }
  .navbar__mobile-toggle { display: flex; }
  .admin-layout { flex-direction: column; }
  .admin-sidebar { width: 100%; height: auto; position: static; }
}
@media (max-width: 479px) {
  .recipe-grid { grid-template-columns: 1fr; }
  .recipe-grid--3 { grid-template-columns: 1fr; }
}
