/* ========== RESET ========== */
*{margin:0;padding:0;box-sizing:border-box;}

/* ========== DESIGN TOKENS ========== */
:root{
  --bg:#ffffff;
  --bg-elevated:#ffffff;
  --bg-card:#ffffff;
  --bg-card-hover:#fafafa;
  --surface:#f5f5f5;
  --border:#ebebeb;
  --border-hover:#d4d4d4;
  --text:#000000;
  --text-sub:#1a1a1a;
  --text-muted:#333333;
  --accent:#0f172a;
  --accent-light:#1e293b;
  --accent-soft:rgba(15,23,42,0.04);
  --green:#059669;
  --green-soft:rgba(5,150,105,0.07);
  --red:#dc2626;
  --red-soft:rgba(220,38,38,0.06);
  --orange:#ea580c;
  --point:#2563eb;
  --point-soft:rgba(37,99,235,0.06);
  --gradient-hero:none;
  --gradient-accent:none;
  --gradient-card:none;
  --shadow-sm:0 2px 8px rgba(0,0,0,0.04);
  --shadow-md:0 4px 20px rgba(0,0,0,0.06);
  --shadow-lg:0 8px 40px rgba(0,0,0,0.12);
  --shadow-glow:none;
  --radius:16px;
  --radius-sm:12px;
  --radius-xs:6px;
  --mono:'IBM Plex Mono',monospace;
  --max-w:1500px;
}

html{scroll-behavior:smooth;overflow-y:auto;overflow-x:hidden;height:auto;width:100%;max-width:100vw;}

body{
  font-family:'Pretendard Variable','Pretendard',-apple-system,BlinkMacSystemFont,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.8;
  min-height:100vh;
  overflow-x:hidden;max-width:100vw;
  -webkit-font-smoothing:antialiased;
  font-size:17px;
}

/* ========== SCROLL ANIMATIONS ========== */
.reveal{
  opacity:0;
  transform:translateY(24px);
  transition:opacity 0.8s cubic-bezier(0.16,1,0.3,1),transform 0.8s cubic-bezier(0.16,1,0.3,1);
}
.reveal.visible{opacity:1;transform:translateY(0);}
.reveal-delay-1{transition-delay:0.1s;}
.reveal-delay-2{transition-delay:0.2s;}
.reveal-delay-3{transition-delay:0.3s;}

/* ========== HEADER ========== */
header{
  position:sticky;top:0;z-index:100;
  width:100%;max-width:100vw;overflow:hidden;box-sizing:border-box;
  background:rgba(255,255,255,0.85);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid var(--border);
  transition:background 0.3s;
}

.header-inner{
  max-width:var(--max-w);width:100%;margin:0 auto;padding:0 48px;box-sizing:border-box;
  display:flex;justify-content:space-between;align-items:center;min-height:72px;flex-wrap:wrap;
}

.logo{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--text);}

.logo-icon{
  width:40px;height:40px;
  background:var(--point);
  border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:16px;color:#fff;
  transition:transform 0.3s;
}
.logo:hover .logo-icon{transform:scale(1.05);}
.logo-img{height:40px;width:auto;transition:transform 0.3s;}
.logo:hover .logo-img{transform:scale(1.05);}

.logo-text{font-size:26px;font-weight:800;letter-spacing:-0.3px;}
.logo-text span{color:var(--point);}

.header-nav{display:flex;align-items:center;gap:2px;flex-wrap:wrap;max-width:100%;}

.header-nav a{
  text-decoration:none;color:var(--text-muted);
  font-size:18px;font-weight:600;
  padding:10px 18px;border-radius:var(--radius-sm);
  transition:all 0.25s;position:relative;
  background:none !important;
  white-space:nowrap;flex-shrink:0;
}
.header-nav a::after{
  content:'';position:absolute;
  bottom:4px;left:18px;right:18px;height:2px;
  background:var(--point);
  border-radius:2px;
  transform:scaleX(0);
  transform-origin:center;
  transition:transform 0.3s cubic-bezier(0.16,1,0.3,1);
}
.header-nav a:hover{color:var(--text);}
.header-nav a:hover::after{transform:scaleX(1);}
.header-nav a.active{color:var(--point);font-weight:700;}
.header-nav a.active::after{transform:scaleX(1);}

.update-badge{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;color:var(--text-muted);
  background:var(--surface);
  padding:6px 16px;border-radius:24px;
  border:1px solid var(--border);
  margin-left:12px;
  flex-shrink:0;
}

.update-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--green);
  box-shadow:0 0 8px rgba(5,150,105,0.4);
  animation:pulse-glow 2s ease-in-out infinite;
}
@keyframes pulse-glow{0%,100%{opacity:1;box-shadow:0 0 8px rgba(5,150,105,0.4);}50%{opacity:0.4;box-shadow:0 0 3px rgba(5,150,105,0.2);}}

/* ========== HERO ========== */
.hero{
  background:linear-gradient(135deg, #ffffff 0%, #eef2ff 50%, #e0f2fe 100%);
  border-bottom:1px solid var(--border);
  padding:80px 48px 72px;
  text-align:center;
  position:relative;overflow:hidden;
  max-height:700px;
  transition:max-height 0.5s cubic-bezier(0.16,1,0.3,1),padding 0.5s,opacity 0.4s,border-color 0.4s;
}
.hero.hidden{max-height:0;padding:0 48px;opacity:0;pointer-events:none;border-color:transparent;}

/* 기존 그라데이션 블롭 → 심플 배경 */
.hero::before{
  content:'';position:absolute;
  top:-20%;right:-10%;width:600px;height:600px;
  background:radial-gradient(circle,rgba(37,99,235,0.08) 0%,transparent 60%);
  pointer-events:none;
}
.hero::after{
  content:'';position:absolute;
  bottom:-20%;left:-10%;width:500px;height:500px;
  background:radial-gradient(circle,rgba(5,150,105,0.06) 0%,transparent 60%);
  pointer-events:none;
}
@keyframes heroWash{0%{transform:translate(0,0) scale(1);}100%{transform:translate(10px,-8px) scale(1.03);}}

.hero-content::before{content:none;}

.hero-content{position:relative;z-index:1;max-width:640px;margin:0 auto;}

.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(37,99,235,0.08);
  border:1px solid rgba(37,99,235,0.15);
  padding:8px 20px;border-radius:24px;
  font-size:14px;font-weight:600;color:var(--point);
  margin-bottom:28px;
  animation:fadeInDown 0.7s cubic-bezier(0.16,1,0.3,1) both;
}
.hero-badge .badge-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--green);
  box-shadow:0 0 6px rgba(5,150,105,0.4);
  animation:pulse-glow 2s ease-in-out infinite;
}

.hero h1{
  font-size:58px;font-weight:900;
  letter-spacing:-1.5px;line-height:1.2;
  margin-bottom:20px;color:var(--text);
  animation:fadeInUp 0.7s cubic-bezier(0.16,1,0.3,1) 0.1s both;
}
.hero-highlight{
  color:var(--point);
  position:relative;
}
.hero-highlight::after{
  content:'';position:absolute;
  left:-4px;right:-4px;bottom:2px;height:16px;
  background:rgba(37,99,235,0.15);
  border-radius:4px;
  z-index:-1;
  animation:highlightGrow 0.6s cubic-bezier(0.16,1,0.3,1) 0.8s both;
}
@keyframes highlightGrow{from{transform:scaleX(0);transform-origin:left;}to{transform:scaleX(1);transform-origin:left;}}

.hero p{
  font-size:22px;color:var(--text-sub);
  max-width:480px;margin:0 auto 36px;font-weight:400;
  line-height:1.8;letter-spacing:-0.2px;
  animation:fadeInUp 0.7s cubic-bezier(0.16,1,0.3,1) 0.2s both;
}

/* stat pills */
.hero-stats-row{
  display:flex;justify-content:center;gap:16px;
  animation:fadeInUp 0.7s cubic-bezier(0.16,1,0.3,1) 0.3s both;
}
.hero-stat-pill{
  display:flex;align-items:center;gap:12px;
  background:#ffffff;
  border:2px solid #ebebeb;
  padding:22px 36px;border-radius:var(--radius);
  transition:all 0.3s;
  box-shadow:0 2px 16px rgba(0,0,0,0.04);
  backdrop-filter:blur(8px);
}
.hero-stat-pill:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.hs-num{
  font-family:var(--mono);
  font-size:36px;font-weight:700;
}
.hero-stat-pill:nth-child(1) .hs-num{color:var(--point);}
.hero-stat-pill:nth-child(2) .hs-num{color:var(--green);}
.hero-stat-pill:nth-child(3) .hs-num{color:var(--orange);}
.hs-label{font-size:15px;color:var(--text-muted);font-weight:500;}

@keyframes fadeInDown{from{opacity:0;transform:translateY(-16px);}to{opacity:1;transform:translateY(0);}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}

/* ========== CONTENT ========== */
.content-area{max-width:var(--max-w);margin:0 auto;padding:48px 48px 64px;}

/* Top Info — 페이지 타이틀 + 우측 업데이트 뱃지 */
.top-info{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:40px;padding-bottom:32px;
  border-bottom:1px solid var(--border);
  gap:16px;
}
.top-info .update-badge{
  flex-shrink:0;
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 16px !important;
  font-size:13px !important;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:9999px;
  color:var(--text-sub);
}
.top-info .update-badge .upd-sep{color:var(--text-muted);opacity:0.5;}
.top-info .update-badge .upd-next{color:var(--point);font-weight:600;}
.top-info .update-badge #countdown{font-family:var(--mono);font-weight:700;color:var(--point);}
.page-title{
  font-size:34px;font-weight:900;letter-spacing:-1.5px;
  color:var(--text);margin-bottom:4px;
}
.page-desc{font-size:16px;color:var(--text-muted);letter-spacing:-0.2px;}
.top-stats{display:flex;gap:28px;align-items:center;}
.top-stat{display:flex;flex-direction:column;align-items:center;gap:4px;}
.top-stat-num{
  font-family:var(--mono);
  font-size:24px;font-weight:700;color:var(--text);
}
.top-stat-label{font-size:13px;color:var(--text-muted);font-weight:500;}
.top-stat-update{
  flex-direction:row;gap:8px;
  background:var(--surface);
  padding:10px 18px;border-radius:24px;
  font-size:13px;color:var(--text-muted);
}
.update-dot-inline{
  width:6px;height:6px;border-radius:50%;
  background:var(--green);
  box-shadow:0 0 6px rgba(5,150,105,0.4);
  animation:pulse-glow 2s ease-in-out infinite;
  flex-shrink:0;
}

@media(max-width:768px){
  .top-info{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:28px;padding-bottom:20px;}
  .page-title{font-size:24px;}
  .top-stat-update{padding:8px 14px;font-size:12px;}
  .top-stats{gap:14px;flex-wrap:wrap;}
  .top-stat-num{font-size:20px;}
}

/* ========== TABS ========== */
.section-tabs{
  display:flex;gap:0;
  background:transparent;
  padding:0;border-radius:0;
  border:none;border-bottom:2px solid var(--border);
  margin-bottom:40px;width:auto;
}

.section-tab{
  padding:14px 24px;border-radius:0;border:none;
  background:transparent;color:var(--text-muted);
  font-family:inherit;font-size:18px;font-weight:600;
  cursor:pointer;transition:color 0.2s;
  position:relative;
}
.section-tab::after{
  content:'';position:absolute;bottom:-2px;left:0;right:0;height:3px;
  background:var(--point);border-radius:2px;
  transform:scaleX(0);transition:transform 0.25s cubic-bezier(0.16,1,0.3,1);
}
.section-tab:hover{color:var(--text);}
.section-tab.active{color:var(--point);font-weight:700;}
.section-tab.active::after{transform:scaleX(1);}

.section-content{display:none;overflow:visible;}
.rank-type-tabs{width:fit-content;}
.section-content.active{display:block;overflow:visible;animation:sectionFadeIn 0.5s cubic-bezier(0.16,1,0.3,1);}
#ranking-product-panel,#ranking-industry-panel{display:none;}
#ranking-product-panel.active,#ranking-industry-panel.active{display:block;}
@keyframes sectionFadeIn{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);}}

.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;}
.section-header h2{font-size:26px;font-weight:800;letter-spacing:-0.8px;}
.section-header .count{font-size:13px;color:var(--text-muted);}

/* ========== FILTER ========== */
.filter-row{display:flex;gap:10px;margin-bottom:28px;flex-wrap:wrap;}

.filter-chip{
  padding:12px 26px;border-radius:9999px;
  border:2px solid var(--border);
  background:#fff;color:var(--text-sub);
  font-family:inherit;font-size:16px;font-weight:600;
  cursor:pointer;transition:all 0.25s;
}
.filter-chip:hover{border-color:var(--point);color:var(--point);background:rgba(37,99,235,0.06);}
.filter-chip.active{
  background:var(--point);
  color:#fff;
  border-color:var(--point);
  box-shadow:0 4px 14px rgba(37,99,235,0.3);
}

/* ========== PRODUCT CARDS ========== */
.product-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(min(400px,100%),1fr));
  gap:24px;margin-bottom:48px;
}

.product-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  transition:all 0.35s cubic-bezier(0.16,1,0.3,1);
  position:relative;
  box-shadow:var(--shadow-sm);
}
.product-card::before{content:none;}
.product-card:hover{
  border-color:rgba(37,99,235,0.3);
  transform:translateY(-4px) scale(1.01);
  box-shadow:var(--shadow-lg);
}

.card-date-bar{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 22px;
  background:var(--surface);
  border-bottom:1px solid var(--border);
  font-size:13px;color:var(--text-muted);
}
.card-date-bar .datetime{font-family:var(--mono);font-weight:500;color:var(--text-sub);font-size:12px;}
.card-date-bar .buyer{display:inline-flex;align-items:center;gap:6px;font-weight:500;color:var(--text-sub);font-size:13px;}

.card-body{display:flex;gap:20px;padding:22px;}

.card-thumb{
  width:96px;height:96px;border-radius:var(--radius-sm);
  object-fit:cover;background:var(--surface);
  border:1px solid var(--border);flex-shrink:0;
  transition:transform 0.3s;
}
.product-card:hover .card-thumb{transform:scale(1.04);}
.no-img{
  display:flex;align-items:center;justify-content:center;
  font-size:11px;color:var(--text-muted,#aaa);text-align:center;line-height:1.4;
  background:var(--surface);border-style:dashed;flex-shrink:0;
}

.card-info{flex:1;min-width:0;}
.card-info h3{
  font-size:20px;font-weight:700;letter-spacing:-0.3px;
  margin-bottom:12px;line-height:1.5;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}

.sale-detail{display:flex;flex-direction:column;gap:6px;}

.sale-detail-row{display:flex;justify-content:space-between;align-items:center;font-size:15px;}
.sale-detail-row .label{color:var(--text-muted);font-size:13px;}
.sale-detail-row .value{font-weight:600;font-family:var(--mono);}
.sale-detail-row .value.unit-price{color:var(--text-sub);}
.sale-detail-row .value.qty{color:var(--text-muted);}
.sale-detail-row .value.total{font-size:24px;color:var(--point);font-weight:700;}

.sale-divider{height:1px;background:var(--border);margin:8px 0;}

/* Card Comparison */
.card-comparison{
  padding:16px 22px;
  background:var(--surface);
  border-top:1px solid var(--border);
}
.comparison-title{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;}
.comp-list{display:flex;flex-direction:column;gap:6px;}
.comp-item{display:flex;justify-content:space-between;align-items:center;font-size:13px;}
.comp-item .comp-name{color:var(--text-muted);font-weight:500;font-family:var(--mono);font-size:12px;}
.comp-item .comp-price{font-family:var(--mono);font-weight:600;font-size:15px;}
.comp-item .comp-price.higher{color:var(--red);}
.comp-item .comp-diff{font-size:11px;color:var(--green);font-weight:600;margin-left:8px;}

.lowest-banner{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:10px;margin-top:12px;
  background:var(--green-soft);
  border-radius:var(--radius-sm);font-size:12px;font-weight:700;color:var(--green);
}

/* Card Footer */
.card-footer{padding:14px 22px;display:flex;justify-content:flex-end;border-top:1px solid var(--border);}

.card-link{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 20px;border-radius:var(--radius-sm);
  background:var(--point);
  color:#fff;text-decoration:none;
  font-size:14px;font-weight:600;
  border:none;
  transition:all 0.25s;
}
.card-link:hover{background:#1d4ed8;transform:translateY(-2px);box-shadow:0 6px 20px rgba(37,99,235,0.35);}

/* ========== COMPARE TABLE ========== */
.compare-table-wrap{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-sm);
  overflow-x:auto;
}
.compare-table{width:100%;border-collapse:collapse;min-width:750px;}
.compare-table th{
  text-align:left;padding:18px 22px;
  font-size:12px;font-weight:700;color:var(--text-muted);
  background:var(--surface);
  border-bottom:1px solid var(--border);
  text-transform:uppercase;letter-spacing:0.8px;white-space:nowrap;
}
.compare-table td{padding:18px 22px;font-size:15px;border-bottom:1px solid var(--border);vertical-align:middle;}
.compare-table tr:last-child td{border-bottom:none;}
.compare-table tr{transition:background 0.2s;}
.compare-table tr:hover td{background:rgba(0,0,0,0.015);}

.compare-product{display:flex;align-items:center;gap:14px;}
.compare-thumb{width:48px;height:48px;border-radius:var(--radius-sm);object-fit:cover;border:1px solid var(--border);flex-shrink:0;}
.compare-name{font-weight:600;font-size:15px;}

.cp{font-family:var(--mono);font-weight:600;font-size:15px;white-space:nowrap;}
.cp.lowest{color:var(--green);}
.cp.higher{color:var(--text-muted);}
.comp-site{font-family:var(--mono);font-size:11px;color:var(--text-muted);display:block;margin-top:3px;}

.badge-lowest{
  display:inline-flex;align-items:center;gap:4px;
  padding:4px 12px;border-radius:var(--radius-xs);
  font-size:11px;font-weight:700;
  background:var(--green-soft);color:var(--green);
}

.compare-comp-badge{
  display:inline-flex;align-items:center;gap:5px;
  padding:6px 14px;border-radius:var(--radius-sm);
  background:var(--surface);border:1px solid var(--border);
  font-size:13px;
}
.compare-comp-badge .comp-site-name{color:var(--text-muted);font-size:11px;}
.compare-comp-badge .comp-site-price{font-family:var(--mono);}
.compare-comp-badge .comp-site-price.strikethrough{color:var(--text-muted);text-decoration:line-through;}

/* 최저가 표시 */
.lowest-wrap{display:flex;flex-direction:column;gap:4px;align-items:flex-start;}
.lowest-site{font-size:11px;color:var(--text-muted);font-weight:600;}
.delivery-free-badge{
  display:inline-flex;align-items:center;gap:3px;
  padding:3px 10px;border-radius:var(--radius-xs);
  font-size:11px;font-weight:700;
  background:var(--green-soft);color:var(--green);
}

/* 경쟁사 비교 행 */
.comp-list-wrap{display:flex;flex-direction:column;gap:8px;}
.compare-comp-row{
  display:flex;align-items:center;gap:10px;
  padding:6px 12px;border-radius:var(--radius-xs);
  background:var(--surface);border:1px solid var(--border);
  font-size:13px;
}
.comp-site-link{text-decoration:none;color:var(--text-muted);transition:color 0.2s;}
.comp-site-link:hover{color:var(--point);}
.comp-site-link .comp-site-name{font-size:11px;font-weight:600;}
.comp-site-price{font-family:var(--mono);font-weight:600;font-size:13px;}
.comp-delivery{font-family:var(--mono);font-size:11px;color:var(--text-muted);}
.comp-delivery.free{color:var(--green);font-weight:600;}
.comp-diff-plus{font-size:11px;font-weight:600;color:var(--red);margin-left:auto;white-space:nowrap;}
.compare-comp-row.is-lowest{background:var(--green-soft);border-color:rgba(5,150,105,0.15);}

/* ========== RANKING ========== */
.ranking-tabs{display:flex;gap:8px;margin-bottom:28px;flex-wrap:wrap;}

.ranking-tab{
  padding:12px 26px;border-radius:9999px;
  border:2px solid var(--border);
  background:#fff;color:var(--text-sub);
  font-family:inherit;font-size:16px;font-weight:600;
  cursor:pointer;transition:all 0.25s;
}
.ranking-tab:hover{border-color:var(--point);color:var(--point);background:rgba(37,99,235,0.06);}
.ranking-tab.active{background:var(--point);color:#fff;border-color:var(--point);box-shadow:0 4px 14px rgba(37,99,235,0.3);}

.ranking-list{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
}

.ranking-item{
  display:flex;align-items:center;gap:20px;
  padding:20px 28px;
  border-bottom:1px solid var(--border);
  transition:all 0.2s;
}
.ranking-item:last-child{border-bottom:none;}
.ranking-item:hover{background:rgba(37,99,235,0.02);}

.rank-num{
  width:40px;height:40px;border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);
  font-size:17px;font-weight:700;flex-shrink:0;
  background:var(--surface);color:var(--text-muted);
  border:1px solid var(--border);
}
.rank-num.top1{background:rgba(37,99,235,0.08);color:var(--point);border-color:rgba(37,99,235,0.15);font-size:16px;}
.rank-num.top2{background:rgba(5,150,105,0.07);color:var(--green);border-color:rgba(5,150,105,0.12);font-size:16px;}
.rank-num.top3{background:rgba(234,88,12,0.07);color:var(--orange);border-color:rgba(234,88,12,0.12);font-size:16px;}

.rank-thumb{width:56px;height:56px;border-radius:var(--radius-sm);object-fit:cover;border:1px solid var(--border);flex-shrink:0;}

.rank-info{flex:1;min-width:0;}
.rank-info .rank-name{font-size:18px;font-weight:700;margin-bottom:3px;}
.rank-info .rank-meta{font-size:13px;color:var(--text-muted);}

.rank-stats{text-align:right;flex-shrink:0;}
.rank-stats .rank-count{font-family:var(--mono);font-size:22px;font-weight:700;color:var(--point);}
.rank-stats .rank-label{font-size:12px;color:var(--text-muted);}
.rank-stats .rank-price{font-family:var(--mono);font-size:15px;font-weight:600;color:var(--green);margin-top:3px;}

.ranking-sub-panel{display:none;}
.ranking-sub-panel.active{display:block;animation:sectionFadeIn 0.4s ease;}

/* ========== SUB PAGES ========== */
.sub-page{max-width:100%;overflow:visible;}
.sub-page-header{margin-bottom:48px;}
.sub-page-header h2{
  font-size:40px;font-weight:900;letter-spacing:-1.5px;margin-bottom:12px;
  color:var(--text);
}
.sub-page-header p{font-size:16px;color:var(--text-sub);line-height:1.8;}

.sub-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:36px;margin-bottom:20px;
  transition:border-color 0.3s;
  box-shadow:var(--shadow-sm);
}
.sub-card:hover{border-color:var(--border-hover);}

.sub-card h3{font-size:24px;font-weight:700;margin-bottom:16px;color:var(--text);}
.sub-card h4{font-size:20px;font-weight:600;margin-bottom:10px;color:var(--text);}
.sub-card p,.sub-card li{font-size:16px;color:var(--text-sub);line-height:2.0;}
.sub-card ul{padding-left:22px;margin-top:8px;}
.sub-card ul li{margin-bottom:6px;}
.sub-card a{color:var(--point);}

.feature-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(min(280px,100%),1fr));
  gap:24px;margin-top:32px;
}

.feature-item{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);padding:36px;
  text-align:center;
  transition:all 0.35s cubic-bezier(0.16,1,0.3,1);
  position:relative;overflow:hidden;
}
.feature-item::before{
  content:'';position:absolute;top:0;left:50%;
  width:60px;height:3px;
  background:var(--point);
  transform:translateX(-50%);
  border-radius:0 0 4px 4px;
}
.feature-item:hover{
  border-color:var(--border-hover);
  transform:translateY(-6px);
  box-shadow:var(--shadow-lg);
}
.feature-item i{font-size:32px;color:var(--point);margin-bottom:16px;}
.feature-item h4{font-size:16px;font-weight:700;margin-bottom:10px;color:var(--text);}
.feature-item p{font-size:15px;color:var(--text-muted);line-height:1.8;}

/* FAQ */
.faq-item{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  margin-bottom:12px;overflow:hidden;
  transition:border-color 0.3s;
}
.faq-item:hover{border-color:var(--border-hover);}

.faq-q{
  padding:22px 28px;font-size:18px;font-weight:600;
  cursor:pointer;display:flex;justify-content:space-between;align-items:center;
  transition:all 0.2s;
}
.faq-q:hover{background:var(--surface);}
.faq-q i{font-size:12px;color:var(--text-muted);transition:transform 0.3s cubic-bezier(0.16,1,0.3,1);}
.faq-item.open .faq-q i{transform:rotate(180deg);}

.faq-a{
  display:none;padding:0 28px 22px;
  font-size:16px;color:var(--text-sub);line-height:2.0;
  border-top:1px solid var(--border);padding-top:18px;
}
.faq-item.open .faq-a{display:block;animation:faqOpen 0.3s ease;}
@keyframes faqOpen{from{opacity:0;transform:translateY(-8px);}to{opacity:1;transform:translateY(0);}}

.faq-category{font-size:17px;font-weight:700;color:var(--text);margin:36px 0 16px;padding-left:2px;}
.faq-category:first-child{margin-top:0;}

/* INQUIRY */
.inquiry-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(min(220px,100%),1fr));
  gap:16px;margin:24px 0;
}

.inquiry-type{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);padding:28px;text-align:center;
  transition:all 0.25s;
}
.inquiry-type:hover{border-color:var(--point);background:var(--point-soft);transform:translateY(-3px);box-shadow:var(--shadow-md);}
.inquiry-type i{font-size:26px;color:var(--point);margin-bottom:12px;}
.inquiry-type h4{font-size:15px;font-weight:600;margin-bottom:6px;}
.inquiry-type p{font-size:12px;color:var(--text-muted);}

.email-box{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:48px;text-align:center;margin:28px 0;
  position:relative;overflow:hidden;
}
.email-box::before{content:none;}
.email-box .email-addr{font-size:28px;font-weight:800;color:var(--text);margin:14px 0;position:relative;}
.email-box a{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 32px;background:var(--point);
  color:#fff;border-radius:var(--radius-sm);text-decoration:none;
  font-size:18px;font-weight:600;margin-top:16px;
  transition:all 0.25s;position:relative;
}
.email-box a:hover{background:#1d4ed8;transform:translateY(-2px);box-shadow:0 4px 16px rgba(37,99,235,0.25);}

/* LEGAL */
.legal-section{margin-bottom:32px;}
.legal-section h3{
  font-size:16px;font-weight:700;margin-bottom:14px;padding-bottom:12px;
  border-bottom:2px solid var(--text);display:inline-block;
}
.legal-section p,.legal-section li{font-size:16px;color:var(--text-sub);line-height:2.0;}
.legal-section ul{padding-left:20px;}
.legal-section ul li{margin-bottom:6px;}
.legal-section a{color:var(--point);}

.legal-info-bar{
  background:var(--surface);
  border-radius:var(--radius-sm);padding:16px 24px;
  font-size:13px;color:var(--text-sub);font-weight:500;
  margin-bottom:32px;display:flex;gap:28px;
}

/* ========== PAGINATION ========== */
.pagination,#sales-pagination,#sales-pagination nav,#compare-pagination{display:flex;justify-content:center;gap:8px;margin-top:12px;flex-wrap:wrap;}

.pg-btn{
  width:44px;height:44px;border-radius:var(--radius-sm);
  border:1px solid var(--border);background:var(--bg-card);
  color:var(--text-muted);font-family:var(--mono);
  font-size:15px;font-weight:600;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all 0.2s;
}
.pg-btn:hover{border-color:var(--point);color:var(--point);background:var(--point-soft);}
.pg-btn.active{background:var(--point);color:#fff;border-color:var(--point);}
.pg-btn:disabled{opacity:0.35;cursor:not-allowed;}

/* ========== FOOTER ========== */
.new-footer{
  background:#fff;
  border-top:1px solid var(--border);
  padding:64px 48px 32px;margin-top:64px;
  position:relative;
}
.new-footer::before{content:none;}

.footer-inner{
  max-width:var(--max-w);margin:0 auto;
  display:grid;grid-template-columns:2fr 1fr;
  gap:64px;margin-bottom:48px;
}
.footer-links-row{
  display:grid;grid-template-columns:1fr 1fr;gap:32px;
}

.footer-brand h3{font-size:26px;font-weight:800;color:var(--text);margin-bottom:14px;}
.footer-brand p{font-size:15px;color:var(--text-muted);line-height:1.8;margin-bottom:20px;}

.footer-social{display:flex;gap:10px;}
.footer-social a{
  width:40px;height:40px;border-radius:var(--radius-sm);
  background:var(--surface);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);text-decoration:none;font-size:16px;
  transition:all 0.25s;border:1px solid var(--border);
}
.footer-social a:hover{background:var(--point);color:#fff;border-color:var(--point);}

.footer-links h4{font-size:12px;font-weight:700;color:var(--text-sub);margin-bottom:16px;text-transform:uppercase;letter-spacing:0.8px;}
.footer-links a{display:block;font-size:15px;color:var(--text-muted);text-decoration:none;margin-bottom:10px;transition:color 0.2s;}
.footer-links a:hover{color:var(--point);}

.footer-bottom{
  max-width:var(--max-w);margin:0 auto;padding-top:24px;
  border-top:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;font-size:13px;
}
.footer-bottom span{color:var(--text-muted);}
.footer-update{font-size:12px;color:var(--text-muted);}

/* ========== LOADING ========== */
.loading-spinner{
  display:flex;justify-content:center;align-items:center;
  padding:80px 0;
}
.loading-spinner::after{
  content:'';width:36px;height:36px;
  border:3px solid var(--border);
  border-top-color:var(--point);
  border-radius:50%;
  animation:spin 0.8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg);}}

.empty-state{
  text-align:center;padding:80px 20px;
  color:var(--text-muted);font-size:16px;
  grid-column:1 / -1;
}
.loading-spinner{grid-column:1 / -1;}

/* ========== SEARCH ========== */
.search-box{
  display:flex;gap:10px;margin-bottom:28px;
}
.search-input{
  flex:1;padding:14px 20px;
  border:2px solid var(--border);border-radius:9999px;
  font-family:inherit;font-size:16px;
  background:var(--bg-card);color:var(--text);
  transition:border-color 0.2s;
}
.search-input:focus{outline:none;border-color:var(--point);box-shadow:0 0 0 3px rgba(37,99,235,0.1);}
.search-btn{
  padding:14px 28px;border:none;border-radius:var(--radius-sm);
  background:var(--point);color:#fff;
  font-family:inherit;font-size:18px;font-weight:600;
  cursor:pointer;transition:all 0.25s;
}
.search-btn:hover{background:#1d4ed8;box-shadow:0 4px 12px rgba(37,99,235,0.25);}

/* ========== RESPONSIVE ========== */
@media(max-width:1024px){
  .header-nav{gap:2px;}
  .header-nav a{font-size:15px;padding:8px 14px;}
  .content-area{padding:32px 24px;}
  .footer-inner{grid-template-columns:1fr 1fr;gap:32px;}
}

@media(max-width:768px){
  /* 헤더 */
  .header-inner{height:auto;padding:16px 20px;flex-direction:column;align-items:stretch;gap:10px;}
  .logo{justify-content:center;}
  .logo-text{font-size:20px;}
  .logo-icon,.logo-img{width:36px;height:36px;}
  .header-nav{width:100%;justify-content:center;flex-wrap:wrap;gap:2px 0;padding-bottom:2px;overflow:visible;}
  .header-nav a{font-size:13px;white-space:nowrap;flex-shrink:0;padding:8px 12px;font-weight:600;}
  .update-badge{display:flex;width:100%;justify-content:center;margin-left:0;margin-top:6px;font-size:11px;padding:5px 12px;flex-basis:100%;}

  .hero{padding:48px 20px 40px;}
  .hero h1{font-size:32px;letter-spacing:-1px;}
  .hero p{font-size:16px;}
  .hero-stats-row{flex-wrap:wrap;gap:10px;}
  .hero-stat-pill{padding:14px 20px;}
  .hs-num{font-size:20px;}

  .content-area{padding:28px 16px;}
  .section-tabs{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;}
  .section-tabs::-webkit-scrollbar{display:none;}
  .section-tab{white-space:nowrap;flex-shrink:0;font-size:15px;padding:10px 18px;}

  .section-header{flex-direction:column;align-items:flex-start;gap:8px;}
  .section-header h2{font-size:20px;}

  .filter-row{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;scrollbar-width:none;padding-bottom:4px;}
  .filter-row::-webkit-scrollbar{display:none;}
  .filter-chip{white-space:nowrap;flex-shrink:0;}

  .product-grid{grid-template-columns:1fr;gap:16px;}
  .card-body{padding:16px;gap:14px;}
  .card-thumb{width:80px;height:80px;}
  .card-info h3{font-size:16px;}
  .sale-detail-row .value.total{font-size:17px;}

  .compare-table{min-width:650px;}
  .compare-table th,.compare-table td{padding:14px 16px;font-size:13px;}
  .compare-thumb{width:40px;height:40px;}

  .ranking-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;scrollbar-width:none;padding-bottom:4px;}
  .ranking-tabs::-webkit-scrollbar{display:none;}
  .ranking-tab{white-space:nowrap;flex-shrink:0;font-size:13px;padding:8px 16px;}
  .rank-type-tabs{width:fit-content !important;min-width:0;}
  .ranking-item{padding:16px 20px;gap:14px;}
  .rank-num{width:34px;height:34px;font-size:13px;}
  .rank-thumb{width:48px;height:48px;}
  .rank-info .rank-name{font-size:15px;}
  .rank-stats .rank-count{font-size:16px;}

  .sub-page-header h2{font-size:24px;}
  .sub-card{padding:24px;}
  .feature-grid{grid-template-columns:1fr 1fr;gap:14px;}
  .feature-item{padding:24px;}
  .inquiry-grid{grid-template-columns:1fr 1fr;}
  .email-box{padding:32px;}
  .email-box .email-addr{font-size:20px;word-break:break-all;}
  .legal-info-bar{flex-direction:column;gap:6px;}

  /* 푸터 */
  .new-footer{padding:40px 20px 24px;}
  .footer-inner{grid-template-columns:1fr;gap:24px;}
  .footer-brand{text-align:center;}
  .footer-brand p{font-size:13px;}
  .footer-links-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
  .footer-links h4{margin-bottom:12px;font-size:11px;}
  .footer-links a{font-size:13px;margin-bottom:8px;}
  .footer-bottom{flex-direction:column;gap:10px;text-align:center;}
  .pagination{gap:6px;}
  .pg-btn{width:38px;height:38px;font-size:13px;}
}

@media(max-width:400px){
  .header-nav a{font-size:12px;padding:6px 8px;}
  .logo-text{font-size:18px;}
  .hero h1{font-size:28px;}
  .hero-stats-row{flex-direction:column;gap:8px;}
  .hero-stat-pill{width:100%;justify-content:center;}
  .card-body{flex-direction:column;}
  .card-thumb{width:100%;height:180px;}
  .feature-grid{grid-template-columns:1fr;}
  .inquiry-grid{grid-template-columns:1fr;}
  .email-box .email-addr{font-size:17px;}
}

/* ========== COMPARE CARD GRID ========== */
.compare-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(min(400px,100%),1fr));
  gap:24px;margin-bottom:48px;
}

.compare-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  transition:all 0.35s cubic-bezier(0.16,1,0.3,1);
  box-shadow:var(--shadow-sm);
}
.compare-card:hover{
  border-color:rgba(37,99,235,0.3);
  transform:translateY(-4px) scale(1.01);
  box-shadow:var(--shadow-lg);
}

/* ① 사이트 태그 줄 */
.cc-sites{
  display:flex;gap:8px;flex-wrap:wrap;
  padding:14px 20px;
  background:var(--surface);
  border-bottom:1px solid var(--border);
}
.cc-site-tag{
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 12px;border-radius:20px;
  font-size:12px;font-weight:600;
  background:#fff;border:1px solid var(--border);
  color:var(--text-muted);
}
.cc-site-tag.cc-recommended{
  background:var(--point);color:#fff;
  border-color:var(--point);
  font-weight:700;
}
.cc-site-tag.cc-recommended i{font-size:10px;}

/* ② 카드 헤더 */
.cc-header{
  display:flex;align-items:center;gap:16px;
  padding:18px 20px;
  border-bottom:1px solid var(--border);
}
.cc-thumb{
  width:88px;height:88px;border-radius:var(--radius-sm);
  object-fit:cover;border:1px solid var(--border);
  flex-shrink:0;background:var(--surface);
}
.cc-info{flex:1;min-width:0;}
.cc-name{
  font-size:16px;font-weight:700;letter-spacing:-0.2px;
  margin:0 0 6px;line-height:1.5;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.cc-qty{
  font-size:15px;color:var(--text-muted);font-weight:500;
}
.cc-updated{
  display:block;font-size:11px;color:var(--text-muted);
  font-family:var(--mono);margin-top:3px;
}

/* ③ 비교 목록 */
.cc-compare-list{
  padding:12px 20px 16px;
  display:flex;flex-direction:column;gap:12px;
}

.cc-entry{
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  padding:16px 18px;
  background:#fff;
  transition:border-color 0.2s;
}
.cc-entry-lowest{
  border-color:rgba(37,99,235,0.25);
  background:var(--point-soft);
}

.cc-entry-dimmed{
  opacity:0.45;
  border-color:var(--border);
  background:var(--surface);
}
.cc-entry-dimmed:hover{opacity:0.7;}

.cc-note{
  text-align:center;padding:10px 14px;
  font-size:11px;color:var(--text-muted);
}

/* 섹션 면책 문구 */
.section-disclaimer{
  text-align:center;padding:20px 14px 0;
  font-size:12px;color:var(--text-muted);
}

.cc-entry-name{
  font-size:17px;font-weight:700;color:var(--text);
  margin-bottom:10px;
  display:flex;align-items:center;gap:8px;
}

.cc-badge-lowest{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 10px;border-radius:var(--radius-xs);
  font-size:10px;font-weight:700;
  background:var(--point);color:#fff;
}

.cc-entry-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:4px 0;font-size:13px;
}
.cc-entry-label{
  color:var(--text-muted);font-size:12px;font-weight:500;
  flex-shrink:0;
}
.cc-entry-val{
  font-family:var(--mono);font-weight:600;
  color:var(--text-sub);font-size:13px;
  text-align:right;margin-left:auto;
}

.cc-entry-total-row{
  margin-top:8px;padding-top:10px;
  border-top:1px solid var(--border);
  align-items:baseline;justify-content:flex-end;gap:8px;
}
.cc-entry-total-row .cc-entry-label{
  margin-right:auto;
}
.cc-entry-total{
  font-family:var(--mono);font-size:22px;font-weight:800;
  color:var(--text);
}
.cc-entry-lowest .cc-entry-total{
  color:var(--point);
}
.cc-entry-diff{
  font-family:var(--mono);font-size:12px;font-weight:600;
  color:var(--text-muted);margin-left:8px;
}

/* 삭제 요청 박스 */
.cc-optout-box{
  display:flex;align-items:flex-start;gap:16px;
  margin-top:40px;padding:24px 28px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
}
.cc-optout-box > i{
  font-size:22px;color:var(--point);flex-shrink:0;margin-top:2px;
}
.cc-optout-box strong{font-size:15px;color:var(--text);}
.cc-optout-box p{font-size:13px;color:var(--text-muted);margin:6px 0 10px;line-height:1.7;}
.cc-optout-box a{
  display:inline-flex;align-items:center;gap:6px;
  font-size:14px;font-weight:600;color:var(--point);text-decoration:none;
}
.cc-optout-box a:hover{text-decoration:underline;}

.cc-no-data{
  text-align:center;padding:20px;
  font-size:15px;color:var(--text-muted);font-weight:500;
  display:flex;align-items:center;justify-content:center;gap:8px;
}

/* ④ 바로가기 + 삭제요청 */
.cc-footer{
  padding:14px 20px;
  border-top:1px solid var(--border);
  display:flex;gap:10px;align-items:center;
}
.cc-delete-req{
  display:inline-flex;align-items:center;gap:5px;
  padding:12px 16px;border-radius:var(--radius-sm);
  border:1px solid var(--border);
  background:#fff;color:var(--text-muted);
  text-decoration:none;font-size:12px;font-weight:500;
  transition:all 0.2s;white-space:nowrap;flex-shrink:0;
}
.cc-delete-req:hover{border-color:var(--red);color:var(--red);}
.cc-buy-btn{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 24px;border-radius:var(--radius-sm);
  background:var(--point);color:#fff;
  text-decoration:none;
  font-size:16px;font-weight:700;
  transition:all 0.25s;
  width:100%;
}
.cc-buy-btn:hover{
  background:#1d4ed8;
  transform:translateY(-2px);
  box-shadow:0 4px 16px rgba(37,99,235,0.25);
}

/* 반응형 — 비교 카드 */
@media(max-width:768px){
  .compare-grid{grid-template-columns:1fr;gap:16px;}
  .cc-sites{padding:12px 14px;gap:6px;}
  .cc-site-tag{font-size:11px;padding:4px 10px;}
  .cc-header{padding:14px 14px;gap:12px;}
  .cc-thumb{width:72px;height:72px;}
  .cc-name{font-size:15px;}
  .cc-compare-list{padding:8px 14px 12px;gap:10px;}
  .cc-entry{padding:12px 14px;}
  .cc-entry-name{font-size:13px;}
  .cc-entry-row{font-size:12px;}
  .cc-entry-val{font-size:12px;}
  .cc-entry-total{font-size:16px;}
  .cc-buy-btn{font-size:13px;padding:12px 18px;}
}

@media(max-width:400px){
  .cc-entry-val{font-size:11px;}
  .cc-entry-total{font-size:15px;}
}

/* ========== AI CONTEXT BOX ========== */
.ai-context-box{word-break:keep-all;}
@media(max-width:768px){
  .ai-context-box{padding:20px !important;margin-bottom:20px !important;}
  .ai-context-box h3{font-size:15px !important;}
  .ai-context-box ul{font-size:14px !important;padding-left:18px !important;line-height:1.8 !important;}
  .ai-context-box li{margin-bottom:8px !important;}
}
@media(max-width:400px){
  .ai-context-box{padding:16px !important;}
  .ai-context-box h3{font-size:14px !important;}
  .ai-context-box ul{font-size:13px !important;padding-left:16px !important;}
}

/* ========== SCROLLBAR ========== */
::-webkit-scrollbar{width:6px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px;}
::-webkit-scrollbar-thumb:hover{background:#94a3b8;}

/* ========== FLOATING BUTTONS ========== */
.floating-buttons{
  position:fixed;bottom:28px;right:28px;
  display:flex;flex-direction:column;gap:10px;
  z-index:1000;
}
.fab-btn{
  width:52px;height:52px;border-radius:50%;
  border:1px solid var(--border);
  background:#fff;color:var(--text-sub);
  font-size:20px;cursor:pointer;
  box-shadow:var(--shadow-md);
  transition:all 0.25s;
  display:flex;align-items:center;justify-content:center;
}
.fab-btn:hover{
  transform:scale(1.1);
  background:var(--point);color:#fff;
  border-color:var(--point);
  box-shadow:0 4px 20px rgba(37,99,235,0.3);
}

/* ========== BTN TEXT (4중 키워드) ========== */
.btn-text{
  display:inline-block;max-width:200px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  font-size:14px;font-weight:600;
}
.btn-arrow{font-size:12px;flex-shrink:0;}

@media(max-width:768px){
  .floating-buttons{bottom:20px;right:20px;}
  .fab-btn{width:46px;height:46px;font-size:18px;}
  .btn-text{max-width:140px;}
}

footer a{color:var(--point);text-decoration:none;}
footer a:hover{color:#1d4ed8;}

/* ====================================================== */
/* 에누리 스타일 v1 (2026-04-29) — 좌측 사이드바 / 가로 띠 광고 / 강조형 카드 */
/* ====================================================== */

/* 데스크톱: content-area = 좌측 사이드바 + 우측 본문 그리드 (max-w 안 가운데 정렬, gap 0, 라인 끊김 없음) */
@media(min-width:1025px){
  .content-area{
    display:grid;
    grid-template-columns:240px 1fr;
    gap:0;
    padding:0 24px 64px;
    align-items:stretch;
    max-width:var(--max-w);
    margin:0 auto;
    width:100%;
  }
  .content-main{
    min-width:0;
    padding:24px 0 0 24px;
  }
  /* 사이드바가 있을 때 데스크톱은 가로 filter-chip 숨김 (사이드바로 대체) */
  .filter-row{display:none;}
}
/* 헤더 좌우 padding 24px 통일 */
.header-inner{padding:0 24px !important;}

/* 좌측 세로 카테고리 사이드바 — 좌·우 1px 라인 (페이지 끝까지 stretch) */
.sidebar{
  background:#fff;
  border:none !important;
  border-left:1px solid var(--border) !important;
  border-right:1px solid var(--border) !important;
  border-radius:0 !important;
  align-self:stretch;
  position:relative;
}
.sidebar-header{
  padding:14px 18px;
  font-size:14px; font-weight:800;
  color:var(--text);
  border-bottom:1px solid var(--border);
  background:var(--surface);
  display:flex; align-items:center; gap:8px;
}
.sidebar-header i{color:var(--point); font-size:13px;}
.sidebar-list{display:flex; flex-direction:column; padding:0;}
.sidebar-item{
  display:flex; align-items:center; gap:10px;
  padding:14px 18px;
  font-size:13px; font-weight:500;
  color:var(--text-sub);
  cursor:pointer;
  border:none;
  border-bottom:1px solid var(--border);
  background:none;
  text-align:left; width:100%; font-family:inherit;
  transition:background 0.15s, color 0.15s;
}
.sidebar-item:last-child{border-bottom:none;}
.sidebar-item:hover{background:rgba(37,99,235,0.04); color:var(--point);}
.sidebar-item.active{
  background:rgba(37,99,235,0.08);
  color:var(--point); font-weight:700;
}

/* 사이드바 트리 — 부모 카테고리 자식들 펼침 영역 */
.sidebar-children{
  display:flex; flex-direction:column;
  background:#fafafa;
  border-bottom:1px solid var(--border);
}
.sidebar-children[hidden]{display:none;}
.sidebar-child{
  display:block;
  padding:11px 18px 11px 32px;
  font-size:12px; font-weight:500;
  color:var(--text-muted);
  background:none; border:none;
  border-bottom:1px solid #ececec;
  text-align:left; width:100%; font-family:inherit;
  cursor:pointer;
  transition:background 0.15s, color 0.15s;
}
.sidebar-child:last-child{border-bottom:none;}
.sidebar-child:hover{background:rgba(37,99,235,0.06); color:var(--point);}
.sidebar-child.active{background:rgba(37,99,235,0.10); color:var(--point); font-weight:700;}

/* 본문 영역 자식 카테고리 칩 (직사각, 그림자/띠 X — 사장님 룰) */
.section-children-chips{
  display:flex; flex-wrap:wrap; gap:6px;
  margin:-12px 0 18px;
  padding:14px 0 0;
  border-top:1px dashed var(--border);
}
.section-children-chips[hidden]{display:none;}
.child-chip{
  padding:7px 13px;
  border:1px solid var(--border);
  background:#fff;
  color:var(--text-sub);
  font-size:12px; font-weight:500;
  font-family:inherit;
  cursor:pointer;
  border-radius:0;
  transition:background 0.15s, color 0.15s, border-color 0.15s;
}
.child-chip:hover{border-color:var(--point); color:var(--point);}
.child-chip.active{background:var(--point); color:#fff; border-color:var(--point); font-weight:700;}
.sidebar-item i{width:13px; text-align:center; font-size:11px; color:var(--text-muted);}
.sidebar-item.active i{color:var(--point);}
@media(max-width:1024px){.sidebar{display:none;}}

/* hero — 사이드바 옆 가로줄 안에 들어가는 박스 형태 (그림자 X — 1px 테두리) */
.hero{
  background:linear-gradient(135deg,#ffffff 0%,#f5f7fa 50%,#e8ecf5 100%) !important;
  padding:0 !important;
  max-height:none !important;
  border:1px solid var(--border) !important;
  border-radius:12px !important;
  text-align:left !important;
  margin-bottom:20px;
  overflow:hidden;
}
.hero::before, .hero::after{content:none !important;}
.hero-content{
  max-width:none !important;
  margin:0 !important;
  display:grid; grid-template-columns:1fr 280px; gap:24px;
  padding:22px 26px !important;
  align-items:center;
}
.hero-badge{display:none !important;}
.hero-stats-row{display:none !important;}
.hero h1{
  font-size:30px !important;
  letter-spacing:-0.8px;
  line-height:1.3 !important;
  color:var(--text) !important;
  margin-bottom:8px !important;
  animation:none !important;
  font-weight:900 !important;
}
.hero h1 .hero-highlight{color:var(--point) !important;}
.hero h1 .hero-highlight::after{content:none !important;}
.hero p{
  font-size:15px !important;
  color:var(--text-muted) !important;
  margin:0 !important; max-width:none !important;
  animation:none !important; line-height:1.6 !important;
}

/* 우측 작은 추천 카드 (그림자 X — 1px 테두리만) */
.hero-side-card{
  background:#fff; border-radius:8px;
  padding:14px 16px;
  display:flex; flex-direction:column; gap:6px;
  border:1px solid var(--border);
}
.hero-side-card{padding:14px 16px !important;}
.hero-side-card .pitch-num{font-size:34px !important; font-weight:900;}
.hero-side-card .pitch-desc{font-size:11px !important; line-height:1.55; color:var(--text-muted);}
.hero-side-card .pitch-desc .hero-side-divider{color:var(--text-muted); opacity:0.4; margin:0 4px;}
.hero-side-card .pitch-desc .hero-side-next{color:var(--point); font-weight:700; font-family:var(--mono);}
.hero-side-card .small-label{font-size:11px !important;}
.hero-side-card .green-badge{font-size:10px !important; padding:4px 10px !important;}
.hero-side-card .pitch-unit{font-size:14px !important;}
.hero-side-card .badge-row{display:flex; align-items:center; gap:8px; flex-wrap:wrap;}
.hero-side-card .green-badge{
  font-size:11px; font-weight:800; color:#fff; background:#03c75a;
  padding:4px 10px; border-radius:12px; letter-spacing:-0.3px;
}
.hero-side-card .small-label{font-size:11px; color:var(--text-muted);}
.hero-side-card .pitch-row{display:flex; align-items:baseline; gap:6px;}
.hero-side-card .pitch-num{
  font-size:34px; font-weight:900; color:var(--text);
  letter-spacing:-1.5px; line-height:1;
}
.hero-side-card .pitch-unit{font-size:14px; font-weight:700; color:var(--text-sub);}
.hero-side-card .pitch-desc{font-size:12px; color:var(--text-muted); line-height:1.55;}

@media(max-width:1024px){
  .hero-content{grid-template-columns:1fr; padding:28px 20px !important; gap:18px;}
  .hero h1{font-size:22px !important;}
  .hero-side-card{padding:14px 18px;}
}

/* 강조형 상품 카드 — 좌상단 빨간 배지 + 큰 가격 */
.product-card{position:relative;}
.product-card .card-badge-new{
  position:absolute; top:8px; left:8px; z-index:2;
  background:var(--red); color:#fff;
  font-size:11px; font-weight:700;
  padding:4px 9px; border-radius:0;
  letter-spacing:-0.3px;
}

/* 데스크톱 그리드 더 빽빽하게 (작은 카드 다수) */
@media(min-width:1025px){
  .product-grid{
    grid-template-columns:repeat(auto-fill,minmax(220px,1fr)) !important;
    gap:16px !important;
  }
}

/* 카드 내부 — 정보형 → 강조형 */
.product-card .card-body{flex-direction:column !important; align-items:stretch; gap:0 !important; padding:0 !important;}
.product-card .card-thumb{
  width:100% !important; height:180px !important;
  border-radius:0 !important; border:none !important;
}
.product-card .no-img{height:180px !important;}
.product-card .card-info{padding:10px 12px 8px;}
.product-card .card-info h3{
  font-size:13px !important; font-weight:600 !important;
  letter-spacing:-0.2px;
  margin-bottom:6px !important;
  line-height:1.4 !important; color:var(--text-sub);
  -webkit-line-clamp:2; min-height:36px;
}
.product-card .sale-detail{gap:2px !important;}
.product-card .sale-detail-row{font-size:11px !important; padding:0;}
.product-card .sale-detail-row .label{font-size:11px !important;}
.product-card .sale-detail-row .value.unit-price,
.product-card .sale-detail-row .value.qty{
  font-size:11px !important; color:var(--text-muted) !important; font-weight:500 !important;
}
.product-card .sale-divider{display:none !important;}
.product-card .sale-detail-row .value.total{
  font-size:22px !important; color:var(--text) !important;
  font-weight:900 !important; letter-spacing:-0.5px;
}
/* 총 금액 라벨 ("총 금액") 숨김 — 가격만 강조 */
.product-card .sale-detail-row:has(.value.total) .label{display:none !important;}
.product-card .sale-detail-row:has(.value.total){justify-content:flex-end; padding:4px 0 0 !important;}

.product-card .card-date-bar{
  background:#fff !important;
  border-top:1px solid var(--border) !important;
  border-bottom:none !important;
  padding:7px 12px !important;
  font-size:10px !important; color:var(--text-muted);
}
.product-card .card-date-bar .datetime{font-size:10px !important;}
.product-card .card-date-bar .buyer{font-size:10px !important;}

.product-card .card-footer{padding:10px 12px !important;}
.product-card .card-link{
  width:100%; justify-content:center;
  font-size:12px !important; padding:9px 12px !important;
  background:#fff !important; color:var(--point) !important;
  border:1px solid var(--point) !important;
}
.product-card .card-link:hover{background:var(--point) !important; color:#fff !important;}
.product-card .card-link .btn-text{max-width:140px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; font-size:12px;}

/* 태블릿: 사이드바 숨기고 단순 1열, hero 1열, filter-chip(가로 알약) 노출 */
@media(max-width:1024px){
  .content-area{display:block; padding:16px 16px;}
  .filter-row{display:flex;}
  .hero{margin-bottom:16px;}
  .hero-content{display:block !important; padding:18px 18px !important;}
  .hero-side-card{margin-top:14px;}
  .hero h1{font-size:20px !important;}
  .hero p{font-size:13px !important;}
  .header-inner{padding:0 16px !important;}
}
/* 모바일 */
@media(max-width:768px){
  .product-card .card-thumb{height:160px !important;}
  .product-card .sale-detail-row .value.total{font-size:18px !important;}
  .product-grid{grid-template-columns:repeat(2, 1fr) !important;}
  .hero h1{font-size:18px !important;}
  .hero-side-card .pitch-num{font-size:24px !important;}
  .content-area{padding:12px 12px;}
}
/* 작은 모바일 */
@media(max-width:480px){
  .product-grid{grid-template-columns:1fr !important;}
  /* 헤더 메뉴 가로 스크롤로 잘림 방지 */
  .header-inner{padding:10px 12px !important;}
  .header-nav{
    width:100%;
    flex-wrap:nowrap !important;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    justify-content:flex-start !important;
  }
  .header-nav::-webkit-scrollbar{display:none;}
  .header-nav a{font-size:13px !important; padding:8px 10px !important; white-space:nowrap;}
}

/* ====== v2 (2026-04-29) — 직각 박스 / 헤더 검색바 / 로고-사이드바 정렬 ====== */

/* 모든 박스 직각 (헤더 검색바만 라운드 예외) */
.sidebar,
.hero,
.hero-side-card,
.product-card,
.compare-card,
.cc-entry,
.sub-card,
.feature-item,
.email-box,
.cc-optout-box,
.compare-table-wrap,
.fab-btn,
.update-badge,
.legal-info-bar{
  border-radius:0 !important;
}
.product-card .card-thumb{border-radius:0 !important;}
.card-link,
.cc-buy-btn,
.search-btn,
.cc-delete-req,
.section-tabs{border-radius:0 !important;}

/* 데스크톱 헤더: 좌측 로고 240px (사이드바 폭과 정렬) | 가운데 검색바 1fr | 우측 메뉴 auto */
@media(min-width:1025px){
  header{
    background:#fff !important;
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
    border-bottom:1px solid var(--border);
  }
  .header-inner{
    display:grid !important;
    grid-template-columns:240px 1fr auto !important;
    gap:24px !important;
    padding:0 24px !important;
    min-height:88px !important;
    align-items:center;
    flex-wrap:nowrap !important;
  }
  .logo{
    width:240px;
    padding-right:24px;
    box-sizing:border-box;
  }
  /* 우측 메뉴 글자 + 간격 키움 (사장님 지시) */
  .header-nav{gap:6px !important;}
  .header-nav a{
    font-size:17px !important;
    font-weight:600 !important;
    padding:10px 22px !important;
  }
  .update-badge{
    font-size:11px !important;
    padding:5px 12px !important;
  }
  /* 헤더 키운 만큼 검색바도 살짝 키움 + 원형 버튼은 검색바 안쪽에 꽉 차게 */
  .header-search{height:48px !important;}
  .header-search-input{font-size:15px !important;}
  .header-search-input::placeholder{font-size:14px !important;}
  /* 데스크톱: 검색바 height 48 - border 2*2 = 44 → 버튼 44×44 */
  .header-search-btn{
    width:44px !important;
    height:44px !important;
    padding:0 !important; margin:0 !important; border:0 !important;
    font-size:15px !important;
  }
}

/* 헤더 가운데 검색바 (둥근 알약 — 사이트 내 유일한 라운드 요소) */
.header-search{
  display:flex; align-items:stretch;  /* 자식이 검색바 높이 가득 채우도록 */
  background:#fff;
  border:2px solid rgba(37,99,235,0.55);  /* 옅은 파랑 — 본문과 자연스럽게 어울리도록 */
  border-radius:9999px;
  overflow:hidden;
  height:40px;
  max-width:560px;
  width:100%;
  margin:0 auto;
  padding:0;
}
.header-search-input{
  flex:1;
  border:none; outline:none;
  padding:0 16px;
  font-size:14px;
  font-family:inherit;
  background:transparent;
  color:var(--text);
  min-width:0;
  height:100%;
}
.header-search-input::placeholder{color:var(--text-muted); font-size:13px;}
.header-search-btn{
  flex:0 0 auto;
  /* 검색바 외곽 height 40 - border 2*2 = 36 → 버튼 36×36으로 정확 매칭 */
  width:36px;
  height:36px;
  margin:0;
  padding:0;
  background:var(--point);
  color:#fff;
  border:0;
  border-radius:50% !important;
  cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center;
  font-size:14px;
  line-height:1;
  transition:background 0.2s;
  box-sizing:border-box;
}
.header-search-btn:hover{background:#1d4ed8;}

/* 모바일 헤더 검색바 (헤더 아래 새 줄로 떨어짐) */
@media(max-width:1024px){
  .header-inner{display:flex !important; flex-wrap:wrap;}
  .logo{width:auto;}
  .header-search{order:99; max-width:none; height:38px; margin:8px 0 0;}
  .header-search-input{font-size:13px; padding:0 14px;}
  /* 모바일 검색바 안쪽 = 38 - border 2*2 = 34 → 버튼 34×34 */
  .header-search-btn{width:34px !important; height:34px !important; font-size:13px !important;}
}

/* ====== 가격비교 섹션 검색바 — 헤더 검색바와 동일 톤 (일체형 둥근 알약) ====== */
.search-box{
  display:flex !important; align-items:stretch !important;
  background:#fff !important;
  border:2px solid rgba(37,99,235,0.55) !important;  /* 옅은 파랑 — 헤더와 동일 톤 */
  border-radius:9999px !important;
  overflow:hidden;
  height:48px;
  max-width:560px;
  width:100%;
  margin-bottom:24px !important;
  gap:0 !important;
  padding:0 !important;
}
.search-box .search-input{
  flex:1 !important;
  border:none !important; outline:none !important;
  padding:0 20px !important;
  font-size:15px !important;
  font-family:inherit;
  background:transparent !important;
  color:var(--text) !important;
  border-radius:0 !important;
  height:100% !important;
  min-width:0;
}
.search-box .search-input::placeholder{color:var(--text-muted); font-size:14px;}
.search-box .search-input:focus{box-shadow:none !important; outline:none !important;}
.search-box .search-btn{
  flex:0 0 auto !important;
  /* 검색바 height 48 - border 2*2 = 44 → 버튼 44×44 */
  width:44px !important;
  height:44px !important;
  margin:0 !important;
  background:var(--point) !important;
  color:#fff !important;
  border:0 !important;
  border-radius:50% !important;
  padding:0 !important;
  cursor:pointer;
  display:inline-flex !important; align-items:center; justify-content:center;
  font-size:15px !important;
  font-weight:normal !important;
  line-height:1 !important;
  box-sizing:border-box !important;
}
.search-box .search-btn:hover{background:#1d4ed8 !important;}

/* ====== hover/focus 시 그림자 효과 일괄 제거 (사장님 룰: 호버에 그림자 X) ====== */
.product-card:hover,
.product-card:focus-within,
.card-link:hover, .card-link:focus,
.search-btn:hover, .search-btn:focus,
.fab-btn:hover, .fab-btn:focus,
.cc-buy-btn:hover, .cc-buy-btn:focus,
.hero-stat-pill:hover,
.compare-card:hover,
.feature-item:hover,
.inquiry-type:hover,
.cc-entry:hover,
.sidebar-item:hover, .sidebar-item:focus,
.sidebar-item.active,
.filter-chip:hover, .filter-chip:focus, .filter-chip.active,
.ranking-tab:hover, .ranking-tab:focus, .ranking-tab.active,
.pg-btn:hover, .pg-btn:focus, .pg-btn.active,
.section-tab:hover, .section-tab:focus, .section-tab.active,
.header-nav a:hover, .header-nav a:focus,
.header-search-btn:hover, .header-search-btn:focus,
button:hover, button:focus,
a:hover, a:focus,
input:hover, input:focus,
.search-input:focus{
  box-shadow:none !important;
}

/* hover시 transform translate로 띄우는 효과도 같이 제거 (그림자와 짝꿍 패턴) */
.product-card:hover,
.compare-card:hover,
.cc-buy-btn:hover,
.card-link:hover,
.search-btn:hover,
.fab-btn:hover,
.hero-stat-pill:hover,
.feature-item:hover,
.email-box a:hover,
.inquiry-type:hover{
  transform:none !important;
}

/* ===== 모든 미세한 그림자·글로우·필터·backdrop-filter 강제 제거 (사장님 룰: 미세한 그림자도 X) ===== */
*, *::before, *::after{
  box-shadow:none !important;
  -webkit-box-shadow:none !important;
  filter:none !important;
  -webkit-filter:none !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
  text-shadow:none !important;
}
/* 펄스 글로우 애니메이션 = 그림자 효과 대체. 깜빡임 색·투명도만 변화 */
@keyframes pulse-glow{
  0%,100%{opacity:1;}
  50%{opacity:0.4;}
}
