*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --black:   #2b3f3f;
  --white:   #ffffff;
  --ivory:   #f0faf9;
  --gold:    #89dbd5;
  --gold2:   #5cc4bb;
  --muted:   #7a9e99;
  --border:  #cce8e5;
  --bg:      #f0faf9;
  --kaspi:   #ef4b23;
  --radius:  6px;
}

body { font-family: 'Noto Sans','Helvetica Neue',Arial,sans-serif; font-size:14px; color:#222; background:var(--white); line-height:1.6; }
a { text-decoration:none; color:inherit; }
img { max-width:100%; display:block; }
/* 비율 고정 컨테이너 안의 이미지는 height:100% 유지 */
.plist-img img,
.home-card-img img,
.pc-img-wrap img { height:100% !important; object-fit:cover !important; }
.container { max-width:1200px; margin:0 auto; padding:0 24px; }

.top-bar { background:var(--black); color:rgba(255,255,255,.7); font-size:12px; text-align:center; padding:8px 16px; letter-spacing:.5px; }
.top-bar a { color:var(--gold); }

.site-header { position:fixed; top:32px; left:0; right:0; z-index:1000; background:transparent; transition:background .3s,box-shadow .3s,top .3s; }
.site-header.scrolled { top:0; background:rgba(255,255,255,.97); box-shadow:0 1px 12px rgba(0,0,0,.08); }
.header-inner { display:flex; align-items:center; justify-content:space-between; height:70px; gap:24px; }

.site-logo { font-size:20px; font-weight:400; letter-spacing:8px; color:var(--gold); transition:color .3s; text-transform:uppercase; flex-shrink:0; }
.site-header.scrolled .site-logo { color:var(--black); }

.main-nav { display:flex; gap:32px; align-items:center; }
.main-nav > a { font-size:13px; letter-spacing:1px; color:rgba(255,255,255,.85); padding-bottom:2px; border-bottom:1px solid transparent; transition:color .2s,border-color .2s; white-space:nowrap; }
.site-header.scrolled .main-nav > a { color:#222; }
.main-nav > a:hover { border-bottom-color:var(--gold); color:var(--gold); }

.header-icons { display:flex; align-items:center; gap:20px; flex-shrink:0; }
.header-icons a { font-size:12px; letter-spacing:.5px; color:rgba(255,255,255,.85); display:flex; align-items:center; gap:4px; transition:color .2s; }
.site-header.scrolled .header-icons a { color:#222; }
.header-icons a:hover { color:var(--gold); }
.cart-badge { background:var(--kaspi); color:#fff; border-radius:50%; width:18px; height:18px; font-size:10px; display:inline-flex; align-items:center; justify-content:center; font-weight:700; }

.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:4px; background:none; border:none; }
.hamburger span { display:block; width:24px; height:1.5px; background:var(--gold); transition:background .3s,transform .3s,opacity .3s; }
.site-header.scrolled .hamburger span { background:var(--black); }
.hamburger.open span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); }

.mobile-nav { display:none; position:fixed; top:0; right:-100%; width:280px; height:100vh; background:var(--white); z-index:999; padding:80px 32px 32px; transition:right .3s ease; box-shadow:-4px 0 20px rgba(0,0,0,.1); overflow-y:auto; }
.mobile-nav.open { right:0; }
.mobile-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.4); z-index:998; }
.mobile-overlay.open { display:block; }
.mobile-nav a { display:block; padding:14px 0; font-size:15px; letter-spacing:1px; border-bottom:1px solid var(--border); color:#222; }
.mobile-nav a:hover { color:var(--gold); }

.hero { min-height:560px; background:var(--black); display:flex; align-items:center; justify-content:center; text-align:center; position:relative; overflow:hidden; }
.hero-bg { position:absolute; inset:0; background:linear-gradient(135deg,#2b3f3f 0%,#0f2820 100%); }
.hero-content { position:relative; z-index:1; color:#fff; padding:0 24px; width:100%; }
.hero-logo-wrap { width:100%; max-width:900px; margin:0 auto 20px; padding:0 16px; }
.hero-logo-svg { width:100%; height:auto; display:block; }
.hero-sub { font-size:13px; color:rgba(255,255,255,.6); letter-spacing:1.5px; margin-bottom:32px; }
.btn-primary { display:inline-block; padding:14px 44px; background:var(--gold); color:var(--black); font-size:12px; letter-spacing:2px; text-transform:uppercase; font-weight:500; transition:background .2s; }
.btn-primary:hover { background:var(--gold2); }

.feature-strip { background:var(--ivory); padding:40px 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.feature-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:24px; text-align:center; }
.feature-item { padding:8px; }
.feature-icon { font-size:22px; margin-bottom:8px; }
.feature-label { font-size:12px; font-weight:500; letter-spacing:1px; margin-bottom:4px; color:var(--black); }
.feature-desc { font-size:11px; color:var(--muted); }

.section { padding:72px 0; }
.section-header { display:flex; align-items:baseline; justify-content:space-between; margin-bottom:40px; }
.section-title { font-size:11px; letter-spacing:4px; text-transform:uppercase; color:#222; font-weight:500; }
.view-all { font-size:11px; letter-spacing:2px; color:var(--muted); border-bottom:1px solid var(--muted); padding-bottom:1px; text-transform:uppercase; }
.view-all:hover { color:var(--gold); border-color:var(--gold); }

.product-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:32px 24px; }
.product-card { cursor:pointer; }
.product-img-wrap { position:relative; overflow:hidden; background:var(--ivory); aspect-ratio:1; margin-bottom:14px; }
.product-img-wrap img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.product-card:hover .product-img-wrap img { transform:scale(1.04); }
.product-badge { position:absolute; top:10px; left:10px; font-size:10px; letter-spacing:1px; padding:3px 8px; background:var(--black); color:#fff; }
.product-badge.sale { background:var(--gold); color:var(--black); }
.product-badge.soldout { background:#aaa; }
.product-name { font-size:13px; letter-spacing:.3px; margin-bottom:6px; line-height:1.5; color:#222; }
.product-prices { display:flex; gap:8px; align-items:center; }
.price-sale { font-size:15px; font-weight:500; color:var(--black); }
.price-original { font-size:12px; color:#bbb; text-decoration:line-through; }
.price-krw { font-size:11px; color:var(--muted); margin-top:2px; }

.btn-cart { width:100%; margin-top:10px; padding:9px; background:var(--black); color:#fff; border:none; cursor:pointer; font-size:11px; letter-spacing:2px; text-transform:uppercase; transition:background .15s; }
.btn-cart:hover { background:var(--gold); color:var(--black); }
.btn-kaspi { display:block; width:100%; padding:14px; background:var(--kaspi); color:#fff; border:none; font-size:13px; letter-spacing:1px; cursor:pointer; text-align:center; transition:background .15s; }
.btn-kaspi:hover { background:#d43a1a; }
.btn-outline { display:inline-block; padding:12px 40px; border:1px solid var(--black); color:var(--black); font-size:12px; letter-spacing:2px; text-transform:uppercase; transition:background .2s,color .2s; }
.btn-outline:hover { background:var(--black); color:#fff; }

.form-group { margin-bottom:16px; }
.form-label { display:block; font-size:11px; letter-spacing:1px; color:var(--muted); margin-bottom:6px; text-transform:uppercase; }
.form-control { width:100%; padding:11px 14px; border:1px solid var(--border); background:var(--white); font-size:14px; color:#222; outline:none; transition:border-color .15s; border-radius:0; }
.form-control:focus { border-color:var(--black); }
select.form-control { cursor:pointer; }

.cart-table { width:100%; border-collapse:collapse; }
.cart-table th,.cart-table td { padding:14px 8px; border-bottom:1px solid var(--border); font-size:13px; }
.cart-table th { text-align:left; color:var(--muted); font-weight:400; letter-spacing:1px; font-size:11px; text-transform:uppercase; }
.qty-input { width:52px; padding:5px 8px; border:1px solid var(--border); text-align:center; }

.alert { padding:12px 16px; margin-bottom:16px; font-size:13px; }
.alert-success { background:#f0f7f0; color:#2d6a2d; border-left:3px solid var(--gold); }
.alert-error { background:#fdf0f0; color:#8b2020; border-left:3px solid var(--kaspi); }
.alert-info { background:var(--ivory); color:var(--black); border-left:3px solid var(--gold); }
.card { background:var(--white); border:1px solid var(--border); padding:28px; }

.kaspi-wait { text-align:center; padding:56px 24px; }
.kaspi-wait .spinner { width:44px; height:44px; border:3px solid var(--border); border-top-color:var(--kaspi); border-radius:50%; animation:spin 1s linear infinite; margin:0 auto 24px; }
@keyframes spin { to { transform:rotate(360deg); } }
.kaspi-wait h2 { font-size:20px; font-weight:400; letter-spacing:2px; margin-bottom:8px; }
.kaspi-wait p { color:var(--muted); font-size:13px; margin-bottom:24px; }

.site-footer { background:var(--black); color:#6a9e98; padding:56px 0 32px; font-size:12px; }
.footer-inner { display:flex; flex-wrap:wrap; gap:40px; justify-content:space-between; margin-bottom:40px; }
.footer-col h4 { color:#fff; font-size:11px; letter-spacing:3px; text-transform:uppercase; margin-bottom:16px; font-weight:400; }
.footer-col p,.footer-col a { color:#6a9e98; line-height:2.2; font-size:12px; }
.footer-col a:hover { color:var(--gold); }
.footer-bottom { border-top:1px solid rgba(255,255,255,.1); padding-top:24px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px; color:#4a7a74; font-size:11px; }

/* ═══════════════════════════════════════════════════════════
   ADMIN LAYOUT
   ═══════════════════════════════════════════════════════════ */
.admin-layout { display:flex; min-height:100vh; background:#eef6f5; }

/* ── 사이드바 ── */
.admin-sidebar {
  width:240px; background:#1C3D35; flex-shrink:0;
  display:flex; flex-direction:column;
  position:sticky; top:0; height:100vh; overflow-y:auto;
}
.admin-sidebar::-webkit-scrollbar { width:6px; }
.admin-sidebar::-webkit-scrollbar-track { background:transparent; }
.admin-sidebar::-webkit-scrollbar-thumb { background:rgba(255,255,255,.1); border-radius:3px; }

.admin-logo {
  display:flex; align-items:center; gap:10px;
  padding:22px 24px; border-bottom:1px solid rgba(142,218,211,.15);
  text-decoration:none;
}
.admin-logo-mark {
  width:32px; height:32px; border-radius:8px;
  background:#8EDAD3; color:#1C3D35;
  display:flex; align-items:center; justify-content:center;
  font-size:13px; font-weight:700; letter-spacing:.5px;
}
.admin-logo-text {
  color:#fff; font-size:14px; font-weight:600; letter-spacing:2px; text-transform:uppercase;
}

.admin-nav { padding:8px 0 24px; flex:1; }
.admin-nav-group { margin-top:16px; padding:0 12px; }
.admin-nav-group:first-child { margin-top:8px; }
.admin-nav-group-title {
  font-size:10px; letter-spacing:1.5px; text-transform:uppercase;
  color:#5a8580; padding:8px 12px 6px; font-weight:600;
}
.admin-nav-item {
  display:flex; align-items:center; gap:10px;
  padding:9px 12px; border-radius:6px;
  color:#a8c4c0; font-size:13px; text-decoration:none;
  transition:all .15s;
}
.admin-nav-item:hover {
  background:rgba(142,218,211,.08); color:#fff;
}
.admin-nav-item.active {
  background:#8EDAD3; color:#1C3D35; font-weight:600;
}
.admin-nav-icon { font-size:15px; flex-shrink:0; width:18px; text-align:center; }
.admin-nav-label { flex:1; }
.admin-nav-badge {
  background:#ef4b23; color:#fff;
  font-size:10px; font-weight:700;
  padding:2px 7px; border-radius:10px; min-width:18px; text-align:center;
}
.admin-nav-item.active .admin-nav-badge { background:#1C3D35; color:#fff; }

/* ── 메인 콘텐츠 ── */
.admin-content { flex:1; padding:0; min-width:0; }

/* ── 페이지 헤더 ── */
.admin-page-header {
  background:#fff; border-bottom:1px solid #d8eae7;
  padding:24px 36px; display:flex; align-items:center;
  justify-content:space-between; gap:20px; flex-wrap:wrap;
  position:sticky; top:0; z-index:50;
}
.admin-page-header-inner { flex:1; min-width:0; }
.admin-page-title {
  font-size:22px; font-weight:700; color:#1C3D35;
  letter-spacing:-.3px; margin:0; line-height:1.2;
}
.admin-page-subtitle {
  font-size:13px; color:#7a9e99; margin:4px 0 0; font-weight:400;
}
.admin-page-actions { display:flex; gap:8px; align-items:center; flex-wrap:wrap; }

/* 콘텐츠 영역 패딩 */
.admin-content > *:not(.admin-page-header) { padding-left:36px; padding-right:36px; }
.admin-content > *:first-child:not(.admin-page-header) { padding-top:28px; }
.admin-content > *:last-child { padding-bottom:36px; }

/* ── 카드 (섹션 구분) ── */
.admin-card {
  background:#fff; border:1px solid #d8eae7; border-radius:10px;
  padding:24px; margin-bottom:20px;
  box-shadow:0 1px 2px rgba(28,61,53,.03);
}
.admin-card-header {
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding-bottom:16px; margin-bottom:20px;
  border-bottom:1px solid #eef5f3;
}
.admin-card-title {
  font-size:15px; font-weight:700; color:#1C3D35; margin:0;
}
.admin-card-subtitle { font-size:12px; color:#7a9e99; margin:2px 0 0; }
.admin-card-actions { display:flex; gap:8px; }

/* ── 섹션 (카드 내 소제목) ── */
.admin-section { margin-bottom:24px; }
.admin-section:last-child { margin-bottom:0; }
.admin-section-title {
  font-size:11px; letter-spacing:1.5px; text-transform:uppercase;
  color:#7a9e99; font-weight:700; margin-bottom:12px;
  padding-bottom:8px; border-bottom:1px solid #eef5f3;
}

/* 기존 admin-title 호환 (점진적 마이그레이션) */
.admin-title {
  font-size:22px; font-weight:700; color:#1C3D35;
  letter-spacing:-.3px; margin-bottom:20px;
}

/* ── 통계 카드 ── */
.stat-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:14px; margin-bottom:24px;
}
.stat-card {
  background:#fff; border:1px solid #d8eae7; border-radius:10px;
  padding:18px 20px;
  box-shadow:0 1px 2px rgba(28,61,53,.03);
  transition:all .15s;
}
.stat-card:hover { border-color:#8EDAD3; transform:translateY(-1px); }
.stat-card .label {
  font-size:11px; letter-spacing:1px; text-transform:uppercase;
  color:#7a9e99; margin-bottom:6px; font-weight:600;
}
.stat-card .value {
  font-size:26px; font-weight:700; color:#1C3D35; line-height:1.1;
}

/* ── 데이터 테이블 ── */
.data-table {
  width:100%; border-collapse:collapse; background:#fff;
  border-radius:10px; overflow:hidden;
  border:1px solid #d8eae7;
  box-shadow:0 1px 2px rgba(28,61,53,.03);
}
.data-table th {
  background:#f7fbfa; padding:12px 14px; text-align:left;
  font-size:11px; letter-spacing:1px; text-transform:uppercase;
  color:#5a8580; border-bottom:1px solid #d8eae7; font-weight:700;
  position:sticky; top:0; z-index:5;
}
.data-table td {
  padding:13px 14px; border-bottom:1px solid #eef5f3; font-size:13px; color:#2b3f3f;
}
.data-table tr:last-child td { border-bottom:none; }
.data-table tr:hover td { background:#f7fbfa; }
.data-table tbody tr.row-zebra:nth-child(even) td { background:#fafdfc; }

/* ── 버튼 ── */
.btn {
  display:inline-flex; align-items:center; gap:6px;
  padding:9px 16px; border-radius:7px; font-size:13px; font-weight:600;
  border:1px solid transparent; cursor:pointer; text-decoration:none;
  transition:all .15s; line-height:1.2; font-family:inherit;
  white-space:nowrap;
}
.btn-primary { background:#1C3D35; color:#fff; }
.btn-primary:hover { background:#2d5449; }
.btn-secondary { background:#fff; color:#1C3D35; border-color:#cce8e5; }
.btn-secondary:hover { background:#f0faf9; border-color:#8EDAD3; }
.btn-success { background:#27ae60; color:#fff; }
.btn-success:hover { background:#229954; }
.btn-danger { background:#e74c3c; color:#fff; }
.btn-danger:hover { background:#c0392b; }
.btn-warn { background:#f39c12; color:#fff; }
.btn-warn:hover { background:#e67e22; }
.btn-ghost { background:transparent; color:#7a9e99; }
.btn-ghost:hover { background:#f0faf9; color:#1C3D35; }
.btn-sm { padding:6px 12px; font-size:12px; }
.btn-lg { padding:12px 22px; font-size:14px; }
.btn-block { display:flex; width:100%; justify-content:center; }
.btn[disabled] { opacity:.4; cursor:not-allowed; }

/* ── 폼 요소 ── */
.admin-content input[type=text],
.admin-content input[type=email],
.admin-content input[type=number],
.admin-content input[type=password],
.admin-content input[type=date],
.admin-content input[type=search],
.admin-content select,
.admin-content textarea {
  font-family:inherit; font-size:13px;
  padding:9px 12px; border:1px solid #cce8e5; border-radius:6px;
  outline:none; background:#fff; color:#1C3D35;
  transition:border-color .15s;
}
.admin-content input:focus,
.admin-content select:focus,
.admin-content textarea:focus { border-color:#1C3D35; }

/* ── 배지 ── */
.badge {
  display:inline-block; padding:3px 10px; font-size:11px;
  letter-spacing:.3px; border-radius:4px; font-weight:600;
}
.badge-new { background:#fff4e6; color:#8b4500; }
.badge-paid { background:#e8f8ee; color:#1b5e20; }
.badge-ship { background:#f3e8fb; color:#311b92; }
.badge-done { background:#f0f0f0; color:#555; }
.badge-cancel { background:#fdecea; color:#880e4f; }

/* ── 알림 ── */
.admin-flash {
  padding:12px 18px; border-radius:8px; font-size:13px; margin-bottom:18px;
  display:flex; align-items:center; gap:10px;
}
.admin-flash-success { background:#e8f8ee; color:#1b5e20; border-left:4px solid #27ae60; }
.admin-flash-error { background:#fdecea; color:#922b21; border-left:4px solid #e74c3c; }
.admin-flash-warn { background:#fff4e6; color:#8b4500; border-left:4px solid #f39c12; }
.admin-flash-info { background:#e8f4fb; color:#1a4f72; border-left:4px solid #2980b9; }

@media (max-width:768px) {
  .main-nav { display:none; }
  .hamburger { display:flex; }
  .mobile-nav { display:block; }
  .product-grid { grid-template-columns:repeat(2,1fr); gap:20px 14px; }
  .hero h1 { font-size:30px; letter-spacing:5px; }
  .admin-layout { flex-direction:column; }
  .admin-sidebar { width:100%; height:auto; position:static; }
  .admin-content > *:not(.admin-page-header) { padding-left:18px; padding-right:18px; }
  .admin-page-header { padding:16px 18px; }
  .admin-page-title { font-size:18px; }
  .footer-inner { gap:24px; }
  div[style*="grid-template-columns:1fr 320px"],
  div[style*="grid-template-columns:1fr 360px"] { display:block !important; }
  div[style*="grid-template-columns:1fr 320px"] > .card:last-child,
  div[style*="grid-template-columns:1fr 360px"] > .card:last-child { margin-top:20px; }
}
@media (max-width:480px) {
  .product-grid { grid-template-columns:repeat(2,1fr); gap:14px 10px; }
  .section { padding:48px 0; }
}