/* =========================================================
   Fun Coffee — Common Stylesheet (mock)
   ========================================================= */
:root{
  --c-bg:#fdfaf5;
  --c-bg-alt:#f5ece1;
  --c-cream:#faf6f0;
  --c-coffee-50:#f5ece1;
  --c-coffee-100:#e8d5b9;
  --c-coffee-300:#c9a47a;
  --c-coffee-500:#8b5a3c;
  --c-coffee-600:#6b4332;
  --c-coffee-700:#4e3022;
  --c-coffee-900:#2a1f17;
  --c-accent:#c97b3f;
  --c-accent-dark:#a55f2a;
  --c-red:#c84a3a;
  --c-green:#5a7a4a;
  --c-text:#2a1f17;
  --c-muted:#7a6a5c;
  --c-line:#e8dccb;
  --c-white:#ffffff;

  --font-jp:"Hiragino Kaku Gothic ProN","ヒラギノ角ゴ ProN W3","Yu Gothic","游ゴシック","Meiryo",sans-serif;
  --font-serif:"Cormorant Garamond","Times New Roman",serif;
  --font-sans:"Inter","Helvetica Neue",Arial,sans-serif;

  --shadow-sm:0 1px 3px rgba(74,48,34,.06);
  --shadow-md:0 4px 16px rgba(74,48,34,.08);
  --shadow-lg:0 12px 40px rgba(74,48,34,.12);
  --radius:8px;
  --radius-lg:14px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-jp);
  background:var(--c-bg);
  color:var(--c-text);
  line-height:1.7;
  font-size:14px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none;transition:color .15s ease}
a:hover{color:var(--c-accent)}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}

/* ---------- Notice Bar ---------- */
.notice-bar{
  background:var(--c-coffee-900);
  color:#f0e6d6;
  font-size:12px;
  letter-spacing:.05em;
  padding:8px 20px;
  text-align:center;
  overflow:hidden;
}
.notice-bar .scroll{
  display:inline-block;
  white-space:nowrap;
  animation:slide 24s linear infinite;
}
.notice-bar .scroll span{margin:0 30px}
@keyframes slide{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

/* ---------- Header ---------- */
.header{
  background:var(--c-white);
  border-bottom:1px solid var(--c-line);
  position:sticky;
  top:0;
  z-index:100;
}
.header-inner{
  max-width:1280px;
  margin:0 auto;
  padding:16px 24px;
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:24px;
}
.header-left,.header-right{display:flex;align-items:center;gap:18px}
.header-right{justify-content:flex-end}
.logo{
  font-family:var(--font-serif);
  font-size:26px;
  font-weight:600;
  letter-spacing:.04em;
  color:var(--c-coffee-900);
  line-height:1;
  text-align:center;
}
.logo .small{
  display:block;
  font-family:var(--font-sans);
  font-size:9px;
  letter-spacing:.4em;
  color:var(--c-muted);
  margin-top:4px;
  text-transform:uppercase;
}
.nav{
  display:flex;
  gap:24px;
  font-size:13px;
  font-weight:500;
}
.nav a{color:var(--c-coffee-700)}
.nav a:hover{color:var(--c-accent)}
.icon-btn{
  width:36px;height:36px;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:50%;
  color:var(--c-coffee-700);
  position:relative;
  transition:background .15s;
}
.icon-btn:hover{background:var(--c-coffee-50)}
.icon-btn .badge{
  position:absolute;top:0;right:0;
  background:var(--c-accent);color:#fff;
  font-size:10px;font-weight:700;
  width:16px;height:16px;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}
.hamburger{
  display:none;
  width:28px;height:28px;
  flex-direction:column;justify-content:center;align-items:center;gap:5px;
}
.hamburger span{
  display:block;
  width:22px;height:2px;
  background:var(--c-coffee-900);
  transition:all .2s;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 28px;
  font-size:13px;font-weight:600;
  letter-spacing:.05em;
  border-radius:4px;
  transition:all .2s;
  cursor:pointer;
  white-space:nowrap;
}
.btn-primary{background:var(--c-coffee-900);color:#fff}
.btn-primary:hover{background:var(--c-coffee-700);color:#fff}
.btn-accent{background:var(--c-accent);color:#fff}
.btn-accent:hover{background:var(--c-accent-dark);color:#fff}
.btn-outline{background:transparent;color:var(--c-coffee-900);border:1px solid var(--c-coffee-900)}
.btn-outline:hover{background:var(--c-coffee-900);color:#fff}
.btn-outline-white{background:transparent;color:#fff;border:1px solid #fff}
.btn-outline-white:hover{background:#fff;color:var(--c-coffee-900)}
.btn-lg{padding:16px 36px;font-size:14px}
.btn-sm{padding:8px 16px;font-size:12px}
.btn-block{width:100%}

/* ---------- Section ---------- */
.section{padding:80px 0}
.section-sm{padding:48px 0}
.container{max-width:1280px;margin:0 auto;padding:0 24px}
.container-narrow{max-width:880px;margin:0 auto;padding:0 24px}

.section-head{
  text-align:center;
  margin-bottom:48px;
}
.section-tag{
  font-family:var(--font-sans);
  font-size:11px;letter-spacing:.4em;
  color:var(--c-accent);
  text-transform:uppercase;
  margin-bottom:12px;
}
.section-title{
  font-family:var(--font-serif);
  font-size:36px;font-weight:500;
  color:var(--c-coffee-900);
  letter-spacing:.02em;
  line-height:1.3;
}
.section-title-jp{
  font-size:14px;color:var(--c-muted);
  margin-top:8px;
  letter-spacing:.1em;
}

/* ---------- Product Card ---------- */
.product-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:32px 24px;
}
.product-card{
  background:var(--c-white);
  border-radius:var(--radius);
  overflow:hidden;
  transition:transform .2s,box-shadow .2s;
  position:relative;
}
.product-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.product-img{
  aspect-ratio:1/1;
  background:var(--c-coffee-50);
  position:relative;
  overflow:hidden;
}
.product-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .4s ease;
}
.product-card:hover .product-img img{transform:scale(1.05)}
.product-label{
  position:absolute;top:12px;left:12px;
  font-size:10px;font-weight:700;
  padding:4px 10px;
  border-radius:2px;
  letter-spacing:.1em;
  color:#fff;
}
.label-new{background:var(--c-coffee-900)}
.label-sale{background:var(--c-red)}
.label-soldout{background:#6b6b6b}
.label-b{background:var(--c-green)}
.product-info{padding:16px 4px}
.product-cat{
  font-size:10px;
  letter-spacing:.2em;
  color:var(--c-muted);
  text-transform:uppercase;
  margin-bottom:6px;
}
.product-name{
  font-size:14px;font-weight:600;
  color:var(--c-coffee-900);
  margin-bottom:6px;
  line-height:1.5;
  /* 2行で切る */
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.product-price{
  font-size:15px;font-weight:600;
  color:var(--c-coffee-900);
}
.product-price .old{
  font-size:12px;font-weight:400;
  color:var(--c-muted);
  text-decoration:line-through;
  margin-right:6px;
}
.product-price .now{color:var(--c-red)}
.product-tax{font-size:10px;color:var(--c-muted);margin-left:2px;font-weight:400}

/* ---------- Footer ---------- */
.footer{
  background:var(--c-coffee-900);
  color:#cdbfb0;
  padding:64px 0 24px;
  font-size:13px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;
  gap:40px;
  margin-bottom:48px;
}
.footer-logo{
  font-family:var(--font-serif);
  font-size:28px;color:#fff;
  letter-spacing:.04em;
  margin-bottom:16px;
}
.footer-desc{
  color:#a8998a;
  line-height:1.8;
  margin-bottom:20px;
}
.footer-sns{display:flex;gap:12px}
.footer-sns a{
  width:36px;height:36px;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid #4e3022;
  border-radius:50%;
  color:#cdbfb0;
  transition:all .2s;
}
.footer-sns a:hover{background:var(--c-accent);border-color:var(--c-accent);color:#fff}
.footer-title{
  font-size:12px;
  font-weight:700;
  color:#fff;
  letter-spacing:.2em;
  margin-bottom:18px;
  text-transform:uppercase;
}
.footer-list li{margin-bottom:10px}
.footer-list a{color:#cdbfb0}
.footer-list a:hover{color:#fff}
.footer-bottom{
  border-top:1px solid #3a2418;
  padding-top:24px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:16px;
  font-size:11px;
  color:#a8998a;
}
.footer-bottom-links{display:flex;gap:20px}

/* ---------- Utility ---------- */
.text-center{text-align:center}
.mt-0{margin-top:0!important}
.mb-0{margin-bottom:0!important}

/* ---------- SVG icons ---------- */
.icon{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.icon-sm{width:16px;height:16px}

/* ---------- Responsive ---------- */
@media(max-width:1024px){
  .product-grid{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:2fr 1fr 1fr;gap:32px}
  .section-title{font-size:28px}
  .section{padding:64px 0}
}
@media(max-width:768px){
  .header-inner{grid-template-columns:auto 1fr auto;padding:12px 16px}
  .nav{display:none}
  .hamburger{display:flex}
  .logo{font-size:20px}
  .logo .small{font-size:8px}
  .container,.container-narrow{padding:0 16px}
  .product-grid{grid-template-columns:repeat(2,1fr);gap:24px 12px}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .footer-bottom{flex-direction:column;text-align:center}
  .section{padding:48px 0}
  .section-head{margin-bottom:32px}
  .section-title{font-size:24px}
  .btn{padding:11px 22px;font-size:12px}
  .btn-lg{padding:14px 28px}
}
