/* =====================
   CALDA AFFOGATO CAFE
   Mobile-first / White × Copper / Hotel-like minimal
   ===================== */
:root{
  --bg:#ffffff;
  --ink:#1f1a17;       /* 深いブラウン系（読みやすいボディ色） */
  --muted:#7c7774;
  --line:#ece8e5;
  --copper:#b87333;    /* カッパー */
  --copper-ink:#8a5226;
  --card:#faf9f8;
  --shadow: 0 10px 30px rgba(0,0,0,.06);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);
  font-family: -apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN","Yu Gothic","Noto Sans JP",Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  line-height:1.65}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:min(1040px, calc(100% - 32px)); margin-inline:auto}

/* Buttons */
.btn{display:inline-block;padding:12px 18px;border-radius:999px;
  background:var(--copper);color:#fff;border:1px solid var(--copper);
  transition:transform .15s ease, box-shadow .15s ease; text-align:center}
.btn:hover{transform:translateY(-1px); box-shadow:var(--shadow)}
.btn.ghost{background:#fff;color:var(--copper);border-color:var(--copper)}
.btn.wide{width:100%}
.btn-row{display:flex;gap:10px;flex-wrap:wrap}

/* Type scale */
.h2{font-size:clamp(20px,4.8vw,28px);letter-spacing:.08em}
.h3{font-size:18px;margin:0 0 2px}
.h4{font-size:16px;margin:0 0 6px}
.lead{color:var(--muted)}
.muted{color:var(--muted)}

/* Skip link */
.skip{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip:focus{left:16px;top:16px;width:auto;height:auto;background:#fff;border:1px solid var(--line);padding:.5rem 1rem;z-index:1000}

/* Header */
.header{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.85);
  backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--line)}
.bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0}
.brand{display:flex;align-items:center;gap:10px;font-weight:700}
.mark{width:32px;height:32px;border-radius:50%;
  background:linear-gradient(145deg,var(--copper),var(--copper-ink));
  color:#fff;display:grid;place-items:center;font-weight:800}
.name{letter-spacing:.09em}

/* Nav (mobile-first) */
.hamburger{display:grid;row-gap:4px;background:none;border:0;padding:6px 4px;cursor:pointer}
.hamburger span{display:block;width:22px;height:2px;background:var(--ink)}
.nav{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;
  padding:8px 0 12px;border-top:1px solid var(--line)}
.nav-link{display:block;text-align:center;padding:10px 8px;border:1px solid var(--line);
  border-radius:999px;background:#fff}
.nav-link.is-active, .nav-link:focus{border-color:var(--copper); color:var(--copper)}
/*
  Mobile nav behavior
  - No-JS: show nav normally (so the site remains navigable).
  - JS: collapse nav by default; open via hamburger.
*/
html.js .nav { display: none; }
html.js .nav.is-open { display: grid; }

/* Desktop nav */
@media (min-width: 960px){
  /* 既存の .nav{display:flex...} のままでOKだが、JS有効時も確実に表示させる */
  html.js .nav { display: flex; }
}


/* Desktop nav */
@media (min-width: 960px){
  .hamburger{display:none}
  .nav{display:flex;gap:14px;padding:0;border-top:0}
  .nav-link{padding:10px 14px}
}

/* Hero */
.hero{position:relative;display:grid;gap:20px;padding:34px 0 20px}
.hero-inner{display:grid;gap:12px}
.eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--copper)}
.title{font-size:clamp(22px,6.2vw,40px);line-height:1.2;margin:0}
.cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}
.hero-media{
  height:40vh;
  min-height:220px;
  border:1px solid var(--line);
  border-radius:16px;

  background-image: url("./images/hero.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  box-shadow:var(--shadow);
}

/* Sections */
.section{padding:28px 0}
.section-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.divider{height:1px;background:linear-gradient(90deg,var(--copper) 0%,transparent 60%);flex:1;opacity:.7}
.copy{font-size:15px}
.stack{display:grid;gap:12px}

/* Points */
.points{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.points li{padding:10px 12px;border:1px solid var(--line);border-radius:12px;background:#fff}

/* Cards (Menu) */
.cards{display:grid;grid-template-columns:1fr;gap:10px}
.card{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:var(--shadow)}
.media{
  height:160px;                 /* ← 全メニュー共通サイズ */
  background-size: cover;       /* ← トリミング方法 */
  background-position: center;  /* ← 常に中央 */
  background-repeat: no-repeat;
  background-color:#f1eeec;     /* ← 画像未読込時の保険 */
}

/* Webshop product images: same behavior as .media */
.product-media{
  height:160px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-color:#f1eeec;
}
/* Webshop product cards: same feel as .card */
.products{display:grid;grid-template-columns:1fr;gap:10px}
.product{
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  overflow:hidden;
  box-shadow:var(--shadow);
}
@media (min-width:720px){ .products{grid-template-columns:repeat(2,1fr)} }
@media (min-width:1040px){ .products{grid-template-columns:repeat(4,1fr)} }

.m-espresso{
  background-image: url("./images/espresso.jpg");

}
.m-matcha{
  background-image: url("./images/matcha.jpg");

}

.m-hojicha{
  background-image: url("./images/hojicha.jpg");

}

.m-caramel{
  background-image: url("./images/caramel.jpg");

}

.seasonal{
  margin-top: 28px;
}

.m-seasonal-1{
  background-image: url("./images/seasonal-kasane.jpg");
 
}

.m-seasonal-2{
  background-image: url("./images/seasonal-Ginger.jpg");

}


.card-body{padding:12px}
.note{margin-top:8px;color:var(--muted);font-size:14px}



/* Access */
.access-grid{display:grid;grid-template-columns:1fr;gap:10px}
.access-box{background:#fff;border:1px solid var(--line);border-radius:16px;padding:14px;box-shadow:var(--shadow)}
.list{margin:8px 0 12px 16px}

/* Map */
.map{height:180px;border:1px dashed var(--line);display:grid;place-items:center;border-radius:12px;color:var(--muted)}

/* Footer */
.footer{border-top:1px solid var(--line);padding:16px 0;margin-top:8px}
.foot-inner{display:grid;gap:4px;justify-items:center;text-align:center}
.foot-brand{font-weight:700;letter-spacing:.08em}
.foot-copy{color:var(--muted)}

/* Larger screens */
@media (min-width: 720px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .access-grid{grid-template-columns:1fr 1fr}
  .hero{grid-template-columns:1.1fr .9fr;align-items:center}
  .hero-media{height:54vh;min-height:320px}
}
@media (min-width: 1040px){
  .cards{grid-template-columns:repeat(4,1fr)}
}


/* Sub menus (Drinks / Food) */
.menu-group{margin-top:28px}
.menu-box{
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  padding:14px;
  box-shadow:var(--shadow);
}
.menu-lead{margin:0 0 10px}
.pill-list{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.pill-list li{
  padding:8px 12px;
  border:1px solid var(--line);
  border-radius:999px;
  background:#fff;
  font-size:14px;
}
.menu-list{
  margin:8px 0 0 16px;
}
.menu-cols{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  margin-top:10px;
}
.menu-col .h4{margin:0 0 6px}
.collapse{margin-top:10px}
.collapse-inner{
  border-top:1px solid var(--line);
  padding-top:12px;
}
@media (min-width: 720px){
  .menu-cols{grid-template-columns:repeat(2,1fr)}
}
@media (min-width: 1040px){
  .menu-cols{grid-template-columns:repeat(4,1fr)}
}

/* Workshop details */
.ws{border:1px solid var(--line); border-radius:12px; background:#fff; padding:10px 12px; margin-top:10px}
.ws summary{cursor:pointer; list-style:none}
.ws summary::-webkit-details-marker{display:none}
.ws summary:after{content:"＋"; float:right; color:var(--copper); font-weight:700}
.ws[open] summary:after{content:"－"}
.ws-body{padding-top:8px}
