/*
Theme Name: BUZZ Child
Theme URI: https://buzz-stock.jp
Description: Cocoon子テーマ — BUZZ STOCK 公式テーマ v3
Author: buzz-stock.jp
Template: cocoon-master
Version: 3.0
*/

@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@700;800;900&family=Noto+Sans+JP:wght@400;500;700&display=swap');

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

:root{
  --grad:linear-gradient(135deg,#fd4698 0%,#fd7543 55%,#fd8e25 100%);
  --bg:#ffffff;
  --bg2:#fdf8f8;
  --ink:#1a1a1a;
  --ink2:#666;
  --ink3:#aaa;
  --border:#f0eae8;
  --border2:#e8ddd9;
  --pink-light:#fff0f3;
  --gold:#f5c842;
  --silver:#a8a8a8;
  --bronze:#cd7f32;
  --font-d:'Montserrat','Noto Sans JP',sans-serif;
  --font-b:'Noto Sans JP',sans-serif;
  --r-sm:6px;
  --r:12px;
  --r-lg:18px;
  --r-xl:24px;
}

body{
  font-family:var(--font-b) !important;
  background:var(--bg2) !important;
  color:var(--ink) !important;
  font-size:14px !important;
  line-height:1.6 !important;
  -webkit-font-smoothing:antialiased !important;
}

/* Cocoon リセット */
#container,#contents,#main,.wrap,#content,.content-area{
  max-width:100% !important;
  padding:0 !important;
  margin:0 !important;
  width:100% !important;
  background:transparent !important;
  float:none !important;
}
.entry-content,.site-content{padding:0 !important;background:transparent !important;}
#breadcrumb,.sidebar,#sidebar,.widget-area,#navi,.navi-in{display:none !important;}

/* ========== HEADER ========== */
#header{
  background:var(--bg) !important;
  border-bottom:1px solid var(--border) !important;
  box-shadow:0 1px 12px rgba(253,70,152,.06) !important;
  position:sticky !important;
  top:0 !important;
  z-index:200 !important;
  padding:0 !important;
}

.buzz-hdr{
  max-width:1200px;
  margin:0 auto;
  padding:0 24px;
  height:62px;
  display:flex;
  align-items:center;
  gap:24px;
}

/* ロゴ */
.buzz-logo{
  text-decoration:none !important;
  display:flex;
  align-items:center;
  flex-shrink:0;
  height:36px;
}
.buzz-logo svg{height:36px;width:auto;}

/* 検索 */
.buzz-search{flex:1;max-width:300px;position:relative;}
.buzz-search input[type="search"],
.buzz-search input[type="text"]{
  width:100%;height:35px;
  background:var(--bg2) !important;
  border:1.5px solid var(--border2) !important;
  border-radius:100px !important;
  padding:0 14px 0 36px !important;
  font-size:12px !important;
  color:var(--ink) !important;
  outline:none !important;
  box-shadow:none !important;
  font-family:var(--font-b) !important;
  transition:border-color .15s !important;
}
.buzz-search input:focus{border-color:#fd9ab8 !important;}
.buzz-search input::placeholder{color:var(--ink3) !important;}
.buzz-search-icon{
  position:absolute;left:11px;top:50%;transform:translateY(-50%);
  color:var(--ink3);pointer-events:none;
}

/* ナビ */
.buzz-nav{display:flex;gap:2px;margin-left:auto;flex-shrink:0;}
.buzz-nav a{
  font-family:var(--font-d);
  font-size:11px;font-weight:700;letter-spacing:.04em;
  color:var(--ink2) !important;
  text-decoration:none !important;
  padding:6px 12px;border-radius:100px;
  transition:all .14s;
}
.buzz-nav a:hover{background:var(--pink-light);color:#fd4698 !important;}
.buzz-nav a.active{background:var(--grad);color:#fff !important;}

/* ========== SLIDER ========== */
.buzz-slider{position:relative;overflow:hidden;margin-bottom:20px;}
.buzz-slides{display:flex;transition:transform .65s cubic-bezier(.4,0,.2,1);will-change:transform;}
.buzz-slide{
  min-width:100%;position:relative;
  overflow:hidden;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:#f5f5f5;
}
.buzz-slide img{width:100%;height:auto;display:block;object-fit:cover;max-height:480px;}

/* スライド矢印 */
.buzz-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  z-index:10;width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.9);
  color:var(--ink);font-size:20px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:all .15s;
  box-shadow:0 2px 12px rgba(0,0,0,.12);
}
.buzz-arrow:hover{background:#fff;transform:translateY(-50%) scale(1.08);}
.buzz-arrow.prev{left:16px;}
.buzz-arrow.next{right:16px;}

/* ドット */
.buzz-dots{
  position:absolute;bottom:16px;left:50%;transform:translateX(-50%);
  display:flex;gap:7px;z-index:10;
}
.buzz-dot{
  width:8px;height:8px;border-radius:50%;
  background:rgba(255,255,255,.55);
  cursor:pointer;transition:all .25s;
  border:none;padding:0;
  box-shadow:0 1px 4px rgba(0,0,0,.2);
}
.buzz-dot.active{background:#fff;width:24px;border-radius:4px;}

/* プログレスバー */
.buzz-progress{
  position:absolute;bottom:0;left:0;height:3px;
  background:var(--grad);z-index:10;
}

/* ========== CATEGORY TABS ========== */
.buzz-cats{
  background:var(--bg);
  border-bottom:1px solid var(--border);
  padding:0 24px;
  display:flex;gap:0;
  overflow-x:auto;scrollbar-width:none;
}
.buzz-cats::-webkit-scrollbar{display:none;}
.buzz-cat{
  font-family:var(--font-d);
  font-size:11px;font-weight:700;letter-spacing:.04em;
  color:var(--ink2) !important;
  text-decoration:none !important;
  padding:13px 16px;
  border-bottom:2px solid transparent;
  white-space:nowrap;
  transition:all .14s;
  display:inline-block;
  cursor:pointer;
  background:none;
  border-top:none;border-left:none;border-right:none;
}
.buzz-cat:hover{color:#fd4698 !important;}
.buzz-cat.active{color:#fd4698 !important;border-bottom-color:#fd4698;}

/* ========== MAIN ========== */
.buzz-main{
  max-width:1200px;
  margin:0 auto;
  padding:28px 24px 60px;
}

.buzz-sec-hdr{
  display:flex;align-items:center;
  justify-content:space-between;
  margin-bottom:16px;
}

.buzz-sec-title{
  font-family:var(--font-d);
  font-size:10px;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink3);
  display:flex;align-items:center;gap:8px;
}
.buzz-sec-title::before{
  content:'';display:block;
  width:16px;height:3px;
  background:var(--grad);border-radius:2px;
}

/* ========== GRIDS ========== */
.buzz-featured{
  display:grid;
  grid-template-columns:1.35fr 1fr 1fr;
  gap:1px;
  background:var(--border);
  border:1.5px solid var(--border);
  border-radius:var(--r-lg);
  overflow:hidden;
  margin-bottom:32px;
  box-shadow:0 4px 24px rgba(253,70,152,.06);
}

.buzz-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1px;
  background:var(--border);
  border:1.5px solid var(--border);
  border-radius:var(--r-lg);
  overflow:hidden;
}

/* ========== CARD ========== */
.buzz-card{
  background:var(--bg);
  padding:18px;
  position:relative;
  transition:background .15s;
  display:flex;flex-direction:column;
  cursor:pointer;
}
.buzz-card:hover{background:var(--bg2);}
.buzz-card.feat{padding:24px;}

/* ランクバッジ */
.buzz-rank{
  position:absolute;top:11px;left:11px;
  font-family:var(--font-d);
  font-size:10px;font-weight:800;
  width:24px;height:24px;
  border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  z-index:2;
}
.buzz-rank.r1{background:var(--grad);color:#fff;box-shadow:0 2px 8px rgba(253,70,152,.3);}
.buzz-rank.r2{background:linear-gradient(135deg,#c0c0c0,#e8e8e8);color:#555;}
.buzz-rank.r3{background:linear-gradient(135deg,#cd7f32,#e8a265);color:#fff;}
.buzz-rank.rn{background:var(--bg2);color:var(--ink3);border:1px solid var(--border2);}

/* バッジ */
.buzz-badge{
  position:absolute;top:11px;right:11px;
  font-family:var(--font-d);
  font-size:9px;font-weight:700;
  letter-spacing:.05em;text-transform:uppercase;
  background:var(--grad);color:#fff;
  padding:3px 9px;border-radius:100px;
  z-index:2;
}

/* サムネイル（正方形・角丸） */
.buzz-thumb{
  width:100%;aspect-ratio:1/1;
  background:var(--pink-light);
  border-radius:12px;
  margin-bottom:12px;
  overflow:hidden;flex-shrink:0;
  border:1px solid rgba(253,70,152,.08);
  display:flex;align-items:center;justify-content:center;
  font-size:44px;
}
.buzz-thumb img{
  width:100%;height:100%;
  object-fit:cover;display:block;
  transition:transform .4s;
}
.buzz-card:hover .buzz-thumb img{transform:scale(1.05);}

/* タグ */
.buzz-tags{display:flex;gap:3px;flex-wrap:wrap;margin-bottom:7px;}
.buzz-tag{
  font-family:var(--font-d);
  font-size:9px;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  background:var(--bg2);color:var(--ink3);
  padding:2px 6px;border-radius:3px;
  border:1px solid var(--border2);
}
.buzz-tag.new{background:#edfaed;color:#3a8a3a;border-color:#c8ecc8;}
.buzz-tag.sale{background:var(--pink-light);color:#fd4698;border-color:#ffd5e0;}

/* 商品情報 */
.buzz-name{
  font-family:var(--font-d);
  font-size:12px;font-weight:700;
  color:var(--ink);line-height:1.35;margin-bottom:3px;
}
.feat .buzz-name{font-size:14px;}
.buzz-brand{font-size:10px;color:var(--ink3);letter-spacing:.08em;text-transform:uppercase;margin-bottom:7px;}
.buzz-desc{
  font-size:11px;color:var(--ink2);line-height:1.6;
  margin-bottom:12px;
  display:-webkit-box;-webkit-line-clamp:2;
  -webkit-box-orient:vertical;overflow:hidden;flex:1;
}
.buzz-foot{display:flex;align-items:baseline;margin-bottom:10px;}
.buzz-price{
  font-family:var(--font-d);
  font-size:16px;font-weight:900;
  color:var(--ink);letter-spacing:-.02em;
}
.feat .buzz-price{font-size:20px;}
.buzz-price-old{font-size:10px;color:var(--ink3);text-decoration:line-through;margin-left:5px;}

/* 購入ボタン */
.buzz-btns{display:flex;gap:4px;}
.buzz-btn{
  flex:1;padding:8px 5px;
  border-radius:var(--r-sm);
  font-family:var(--font-d);
  font-size:9px;font-weight:700;
  letter-spacing:.04em;text-transform:uppercase;
  text-decoration:none !important;
  text-align:center;border:none;
  transition:opacity .14s,transform .1s;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;white-space:nowrap;
}
.buzz-btn:hover{opacity:.8;}
.buzz-btn:active{transform:scale(.96);}
.buzz-btn-amz{background:#f0c040;color:#1a0f00 !important;}
.buzz-btn-rak{background:#bf0000;color:#fff !important;}
.buzz-btn-off{background:transparent;color:var(--ink2) !important;border:1px solid var(--border2);}
.buzz-btn-off:hover{background:var(--bg2);opacity:1;}

/* 空状態 */
.buzz-empty{text-align:center;padding:60px 24px;color:var(--ink3);font-size:13px;display:none;}
.buzz-empty.show{display:block;}

/* ========== FOOTER ========== */
#footer{
  background:var(--ink) !important;
  border-top:none !important;
  padding:40px 24px !important;
}
.buzz-footer{
  max-width:1200px;margin:0 auto;
  display:flex;justify-content:space-between;
  align-items:center;flex-wrap:wrap;gap:16px;
}
.buzz-footer-logo{
  display:flex;align-items:center;
  height:28px;
}
.buzz-footer-logo svg{height:28px;width:auto;filter:brightness(0) invert(1);opacity:.85;}
.buzz-footer-links{display:flex;gap:20px;}
.buzz-footer-links a{
  font-size:11px;color:rgba(255,255,255,.45) !important;
  text-decoration:none !important;transition:color .14s;
}
.buzz-footer-links a:hover{color:#fff !important;}
.buzz-footer-copy{font-size:11px;color:rgba(255,255,255,.25);}
