/* ==========================================================
   SHIROHATO — Summer 2026 / さらっと、ひんやり。
   Cool Breeze / 涼やかなアクア × マリン × 白
   (Father's Day の構造を継承し、夏の配色へリスキン)
   ========================================================== */

:root{
  --bg:          #eaf6ff;
  --bg-2:        #d3ebfd;
  --paper:       #f4fbff;
  --ink:         #1a6aa0;        /* 明るいオーシャンブルー(濃色セクション) */
  --ink-2:       #3f7fb0;
  --rose:        #2aa6ec;        /* 明るいサマースカイブルー(主役アクセント) */
  --rose-2:      #1b86cf;
  --rose-light:  #cdecff;        /* 明るい水色 */
  --sage:        #f2935f;        /* サンセットコーラル(差し色) */
  --cream:       #f3fbff;
  --cream-2:     #ddeefc;
  --line:        rgba(42, 166, 236, .28);
  --muted:       #86a4c2;
  --blue:        #37a6e0;        /* マリンブルー */
  --blue-light:  #cdecff;        /* 淡い空色 */
  --blue-deep:   #0f4a73;        /* 深いブルー */
  --serif-en:   "Cormorant Garamond", "Noto Serif JP", serif;
  --serif-jp:   "Noto Serif JP", serif;
  --sans-jp:    "Noto Sans JP", system-ui, sans-serif;
  --sans-display: "Montserrat", "Noto Sans JP", system-ui, sans-serif;
  --radius:      2px;
  --shadow:      0 30px 60px -22px rgba(26,106,160,.22);
  --ease:        cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--sans-jp);
  font-weight:300;
  color:var(--ink);
  background:var(--paper);
  line-height:1.95;
  letter-spacing:.04em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%;height:auto;}
a{color:inherit;text-decoration:none;}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;}

.container{
  width:min(1180px, 92vw);
  margin-inline:auto;
}

/* ---------- 共通タイトル ---------- */
.kicker{
  font-family:var(--serif-en);
  letter-spacing:.4em;
  font-size:.78rem;
  color:var(--rose);
  text-transform:uppercase;
  margin-bottom:1.2rem;
}
.kicker.light{color:var(--rose-light);}
.section-title{
  font-family:var(--serif-jp);
  font-weight:500;
  font-size:clamp(1.9rem, 4.2vw, 3rem);
  line-height:1.5;
  letter-spacing:.08em;
  margin-bottom:1.4rem;
  color:var(--ink);
}
.section-title.light{color:var(--cream);}
.section-title em{font-style:italic;color:var(--rose);font-family:var(--serif-en);}
.section-title em.rose{color:var(--rose-light);}
.section-sub{
  font-family:var(--serif-jp);
  color:var(--muted);
  letter-spacing:.18em;
  font-size:.95rem;
}
.section-head{margin-bottom:3.5rem;}
.section-head.center{text-align:center;}
.lead{font-size:1.02rem;margin-bottom:1.2rem;}
.lead.light{color:var(--cream-2);}

/* ---------- ボタン ---------- */
.btn-rose{
  display:inline-flex;align-items:center;gap:.7rem;
  font-family:var(--serif-en);
  letter-spacing:.3em;
  font-size:.85rem;
  padding:1rem 2rem;
  color:#fff;
  background:linear-gradient(110deg, var(--rose) 0%, var(--rose-2) 100%);
  border-radius:99px;
  position:relative;overflow:hidden;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
  box-shadow:0 12px 24px -10px rgba(37,150,224,.55);
}
.btn-rose i{font-style:normal;transition:transform .4s var(--ease);}
.btn-rose:hover{transform:translateY(-2px);box-shadow:0 18px 32px -10px rgba(37,150,224,.7);}
.btn-rose:hover i{transform:translateX(6px);}
.btn-rose::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,transparent 30%, rgba(255,255,255,.4) 50%, transparent 70%);
  transform:translateX(-100%);transition:transform .9s var(--ease);
}
.btn-rose:hover::after{transform:translateX(100%);}
.btn-rose.large{padding:1.2rem 2.6rem;font-size:.95rem;}

.cta-pill{
  font-family:var(--serif-en);
  letter-spacing:.25em;
  font-size:.78rem;
  padding:.7rem 1.4rem;
  border:1px solid var(--rose-light);
  border-radius:99px;
  color:var(--cream);
  transition:.4s var(--ease);
}
.cta-pill:hover{background:var(--rose);border-color:var(--rose);color:#fff;}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:50;
  padding:1.2rem 0;
  transition:.5s var(--ease);
  background:linear-gradient(180deg,rgba(26,106,160,.5),rgba(26,106,160,0));
}
.site-header.scrolled{
  background:rgba(253,250,244,.94);
  backdrop-filter:blur(12px);
  padding:.7rem 0;
  border-bottom:1px solid var(--line);
}
.site-header.scrolled .brand,
.site-header.scrolled .nav a{color:var(--ink);}
.site-header.scrolled .cta-pill{
  color:var(--ink);border-color:var(--ink);
}
.site-header.scrolled .cta-pill:hover{color:#fff;}
.site-header.scrolled .menu-toggle span{background:var(--ink);}

.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;}
.brand{
  display:inline-flex;align-items:center;
  cursor:pointer;
  user-select:none;
  transition:opacity .3s var(--ease);
}
.brand:hover{opacity:.75;}
.brand-logo{
  display:block;
  height:34px;
  width:auto;
  max-width:200px;
  transition:height .35s var(--ease), filter .35s var(--ease);
  filter:drop-shadow(0 2px 8px rgba(0,0,0,.35));
}
.site-header.scrolled .brand-logo{
  height:28px;
  filter:none;
}
.nav{display:flex;gap:2rem;}
.nav a{
  font-family:var(--serif-en);
  letter-spacing:.2em;font-size:.85rem;
  color:var(--cream-2);
  position:relative;
  padding:.3rem 0;
  transition:color .4s var(--ease);
}
.nav a::after{
  content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--rose);
  transition:width .4s var(--ease);
}
.nav a:hover::after{width:100%;}
.site-header.scrolled .nav a{color:var(--ink-2);}

.menu-toggle{display:none;width:34px;height:34px;flex-direction:column;justify-content:center;gap:5px;}
.menu-toggle span{display:block;height:1px;background:var(--cream);transition:.4s var(--ease);}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;align-items:center;
  color:var(--cream);
  overflow:hidden;
  background:var(--ink);
}
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden;}

/* ===== 商品タイル背景(マーキー左右逆方向) ===== */
.hero-tiles{
  position:absolute;
  inset:-8% -10%;
  display:flex;
  flex-direction:column;
  gap:14px;
  padding:14px 0;
  filter:saturate(.55) brightness(.6) contrast(.95);
  opacity:0;
  transition:opacity 1.6s var(--ease);
  will-change:transform;
}
.hero.loaded .hero-tiles{opacity:.85;}
.tile-row{
  display:flex;
  gap:14px;
  flex:1;
  flex-shrink:0;
  min-height:0;
  animation:tile-ltr 60s linear infinite;
  will-change:transform;
}
.tile-row.r-rtl{animation-name:tile-rtl;}
.tile-row:nth-child(1){animation-duration:65s;}
.tile-row:nth-child(2){animation-duration:78s;}
.tile-row:nth-child(3){animation-duration:55s;}
.tile-row:nth-child(4){animation-duration:72s;}
.tile-row img{
  flex-shrink:0;
  width:240px;
  height:100%;
  min-height:180px;
  object-fit:cover;
  border-radius:2px;
  background:#114a72;
}
@keyframes tile-ltr{
  from{transform:translate3d(0,0,0);}
  to{transform:translate3d(-50%,0,0);}
}
@keyframes tile-rtl{
  from{transform:translate3d(-50%,0,0);}
  to{transform:translate3d(0,0,0);}
}

.hero-veil{
  position:absolute;inset:0;
  background:
    radial-gradient(60% 55% at 25% 50%, rgba(35,120,175,.05), rgba(35,120,175,.7) 75%),
    linear-gradient(180deg, rgba(35,120,175,.55) 0%, rgba(22,95,140,.92) 100%);
}
.hero-grain{
  position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='180' height='180' filter='url(%23n)' opacity='0.55'/></svg>");
  opacity:.06;mix-blend-mode:overlay;pointer-events:none;
}

/* ===== 波が打ち寄せるエフェクト（ヒーロー下部） ===== */
.hero-waves{
  position:absolute; left:0; right:0; bottom:0;
  height:46%; min-height:220px;
  pointer-events:none; overflow:hidden; z-index:1;
}
.hero-waves .wv{
  position:absolute; left:0; bottom:0; width:100%;
  background-repeat:repeat-x;
  will-change:transform, background-position;
}
/* 奥の波：ゆっくり、淡く */
.hero-waves .wv-1{
  height:160px;
  background-size:1200px 160px;
  background-position:0 bottom;
  opacity:.45;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 160' preserveAspectRatio='none'><path d='M0,70 C200,120 340,20 600,60 C860,100 1010,20 1200,70 L1200,160 L0,160 Z' fill='%23cdecff'/></svg>");
  animation:wave-drift 26s linear infinite, wave-bob 9s ease-in-out infinite;
}
/* 中間の波 */
.hero-waves .wv-2{
  height:130px;
  background-size:1000px 130px;
  background-position:0 bottom;
  opacity:.5;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1000 130' preserveAspectRatio='none'><path d='M0,60 C180,10 320,100 500,60 C680,20 820,100 1000,55 L1000,130 L0,130 Z' fill='%2337a6e0'/></svg>");
  animation:wave-drift-rev 18s linear infinite, wave-bob 7s ease-in-out infinite;
}
/* 手前の白い波頭（フォーム） */
.hero-waves .wv-3{
  height:96px;
  background-size:780px 96px;
  background-position:0 bottom;
  opacity:.55;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 780 96' preserveAspectRatio='none'><path d='M0,50 C130,20 240,80 390,48 C540,16 650,78 780,46 L780,96 L0,96 Z' fill='%23ffffff'/></svg>");
  animation:wave-drift 12s linear infinite, wave-bob 5.5s ease-in-out infinite;
}
@keyframes wave-drift{
  from{background-position-x:0;}
  to{background-position-x:-1200px;}
}
@keyframes wave-drift-rev{
  from{background-position-x:0;}
  to{background-position-x:1000px;}
}
@keyframes wave-bob{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-10px);}
}
@media (max-width:640px){
  .hero-waves{height:38%; min-height:160px;}
  .hero-waves .wv-1{height:110px; background-size:800px 110px;}
  .hero-waves .wv-2{height:90px; background-size:680px 90px;}
  .hero-waves .wv-3{height:70px; background-size:520px 70px;}
}
@media (prefers-reduced-motion:reduce){
  .hero-waves .wv{animation:none;}
}
.hero-inner{position:relative;z-index:2;padding:9rem 0 6rem;}
.hero-eyebrow{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:.4rem;
  margin-bottom:2.6rem;
  position:relative;
}
.hero-eyebrow .he-line{
  display:block;
  width:80px;height:1px;
  background:linear-gradient(90deg, var(--rose) 0%, transparent 100%);
  margin-bottom:.8rem;
}
.hero-eyebrow .he-tag{
  font-family:var(--sans-display);
  font-style:normal;
  font-weight:600;
  font-size:clamp(1.1rem, 2.2vw, 1.55rem);
  letter-spacing:.22em;
  color:var(--rose-light);
  line-height:1;
  text-transform:uppercase;
}
.hero-eyebrow .he-year{
  font-family:var(--sans-display);
  font-weight:800;
  font-size:clamp(4.8rem, 11vw, 8.5rem);
  letter-spacing:-.01em;
  line-height:.95;
  color:var(--cream);
  background:linear-gradient(180deg, var(--cream) 0%, var(--rose-light) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  position:relative;
}
.hero-eyebrow .he-date{
  font-family:var(--sans-display);
  font-weight:500;
  letter-spacing:.34em;
  font-size:.76rem;
  color:var(--rose-light);
  text-transform:uppercase;
  margin-top:.3rem;
  padding-left:.2em;
}
.hero-title{
  font-family:var(--sans-jp);
  font-weight:700;
  font-size:clamp(2rem, 5.4vw, 4.2rem);
  letter-spacing:.01em;
  line-height:1.22;
  margin-bottom:1.6rem;
  background:linear-gradient(170deg, #d4e2f0 0%, var(--blue-light) 35%, var(--blue) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  filter:drop-shadow(0 4px 16px rgba(35,120,175,.35));
}
.hero-title span{display:block;}
.hero-title em{
  font-style:normal;
  font-family:var(--sans-jp);
  font-weight:900;
  letter-spacing:.01em;
  padding:0 .05em;
}
.hero-lead{
  font-size:1.05rem;
  max-width:36rem;
  color:var(--cream-2);
  margin-bottom:3rem;
  line-height:2.1;
}
.hero-lead small{display:block;margin-top:.8rem;font-size:.78rem;letter-spacing:.18em;color:var(--rose-light);}
.hero-meta{display:flex;align-items:center;gap:2.5rem;flex-wrap:wrap;}

.countdown-wrap{
  display:flex;
  flex-direction:column;
  gap:.85rem;
}
.cd-label{
  font-family:var(--serif-jp);
  font-weight:500;
  letter-spacing:.22em;
  font-size:.9rem;
  color:var(--rose-light);
  padding-left:.15em;
}
.countdown{
  display:flex;gap:1.4rem;
  padding:1.2rem 1.6rem;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:rgba(26,106,160,.35);
  backdrop-filter:blur(6px);
}
.countdown > div{
  text-align:center;min-width:55px;
  position:relative;
}
.countdown > div + div::before{
  content:"";position:absolute;left:-.85rem;top:50%;transform:translateY(-50%);
  width:1px;height:60%;background:var(--line);
}
.countdown .num{
  display:block;
  font-family:var(--serif-en);
  font-weight:500;font-size:1.9rem;
  color:var(--cream);letter-spacing:.05em;
  line-height:1;margin-bottom:.4rem;
}
.countdown small{
  font-family:var(--serif-jp);
  letter-spacing:.2em;font-size:.7rem;
  color:var(--rose-light);
}

.scroll-hint{
  position:absolute;left:50%;bottom:2rem;transform:translateX(-50%);
  font-family:var(--serif-en);letter-spacing:.4em;font-size:.7rem;
  color:var(--cream-2);
  display:flex;flex-direction:column;align-items:center;gap:.6rem;
}
.scroll-hint span{
  width:1px;height:50px;background:var(--rose);position:relative;overflow:hidden;
}
.scroll-hint span::after{
  content:"";position:absolute;top:-100%;left:0;width:100%;height:100%;
  background:var(--cream);
  animation:scroll-line 2.2s var(--ease) infinite;
}
@keyframes scroll-line{
  0%{top:-100%;}50%{top:0;}100%{top:100%;}
}

/* 掲載商品のランダム表示(PC のみ) */
.hero-spot{
  position:absolute;
  right:3.4vw;
  top:50%;
  transform:translateY(-50%);
  z-index:3;
  display:none;
  width:240px;
  pointer-events:auto;
  transition:opacity .55s var(--ease), transform .6s var(--ease);
}
@media (min-width: 981px){
  .hero-spot{display:block;}
}
.hero-spot.swapping{opacity:0;transform:translateY(-50%) translateY(8px);}

.hs-label{
  font-family:var(--serif-en);
  font-style:italic;
  letter-spacing:.32em;
  font-size:.7rem;
  color:var(--rose-light);
  margin-bottom:1rem;
  text-transform:uppercase;
  opacity:.9;
}
.hs-label::before{
  content:"— ";
  color:var(--rose);
  margin-right:.3em;
}

.hs-link{
  display:block;
  color:var(--cream);
  transition:transform .4s var(--ease);
}
.hs-link:hover{transform:translateY(-3px);}

.hs-img{
  position:relative;
  aspect-ratio: 1 / 1;
  overflow:hidden;
  border-radius:2px;
  background:rgba(0,0,0,.25);
  margin-bottom:.9rem;
  box-shadow:0 18px 30px -14px rgba(0,0,0,.45);
}
.hs-img img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.95);
  transition:transform 1.4s var(--ease), filter .5s var(--ease);
}
.hs-link:hover .hs-img img{transform:scale(1.06);filter:saturate(1);}
.hs-code{
  position:absolute;
  top:.55rem;left:.65rem;
  font-family:var(--serif-en);
  font-style:italic;
  font-size:.62rem;
  letter-spacing:.18em;
  color:rgba(255,255,255,.95);
  background:rgba(22,95,140,.5);
  padding:.22rem .55rem;
  border-radius:99px;
  backdrop-filter:blur(6px);
}
.hs-brand{
  font-family:var(--serif-en);
  letter-spacing:.22em;
  font-size:.7rem;
  color:var(--rose-light);
  text-transform:uppercase;
  margin-bottom:.4rem;
}
.hs-name{
  font-family:var(--serif-jp);
  font-size:.82rem;
  line-height:1.6;
  letter-spacing:.04em;
  color:var(--cream);
  margin-bottom:.7rem;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.hs-price{
  font-family:var(--serif-en);
  font-size:1rem;
  letter-spacing:.04em;
  color:var(--blue-light);
  margin-bottom:.7rem;
}
.hs-price small{font-size:.65em;color:var(--cream-2);margin-left:.2em;}
.hs-cta{
  font-family:var(--serif-en);
  letter-spacing:.25em;
  font-size:.7rem;
  color:var(--rose-light);
  text-transform:uppercase;
  padding-top:.7rem;
  border-top:1px solid rgba(184,206,224,.18);
  display:inline-flex;align-items:center;gap:.45rem;
}
.hs-cta i{font-style:normal;transition:transform .35s var(--ease);}
.hs-link:hover .hs-cta i{transform:translateX(5px);}

/* 隠しリボン */
.ee-ribbon{
  position:absolute;right:5%;top:80px;
  z-index:3;
  transform-origin:40px 38px;
  animation:ribbon-sway 5s ease-in-out infinite;
  cursor:grab;
  opacity:.9;
  filter:drop-shadow(0 6px 14px rgba(0,0,0,.3));
}
.ee-ribbon.pulled{animation:ribbon-pull 1.2s var(--ease);}
@keyframes ribbon-sway{
  0%,100%{transform:rotate(-3deg);}
  50%{transform:rotate(3deg);}
}
@keyframes ribbon-pull{
  0%{transform:rotate(0) scale(1);}
  25%{transform:rotate(20deg) scale(1.1);}
  50%{transform:rotate(-12deg) scale(1.05);}
  75%{transform:rotate(8deg) scale(1.02);}
  100%{transform:rotate(0) scale(1);}
}

/* ============================================================
   CONCEPT
   ============================================================ */
.concept{
  padding:9rem 0;
  background:var(--paper);
  position:relative;
}
.concept-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:6rem;
  align-items:center;
}
.concept-text p{margin-bottom:1.4rem;}
.concept-text em{color:var(--rose);font-style:normal;font-family:var(--serif-jp);font-weight:500;}
.concept-pills{list-style:none;display:flex;flex-wrap:wrap;gap:.6rem;margin-top:2rem;}
.concept-pills li{
  font-family:var(--serif-en);
  letter-spacing:.18em;font-size:.78rem;
  padding:.5rem 1.1rem;
  border:1px solid var(--line);
  border-radius:99px;
  color:var(--rose-2);
  background:rgba(191,225,251,.15);
}
.concept-figure{
  position:relative;
  padding:1rem 0 2rem 0;
}
.cf-link{
  display:block;
  position:relative;
}
.cf-img{
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
  aspect-ratio: 1 / 1;
  background:var(--bg-2);
}
.cf-img img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.95);
  transition:transform 1.4s var(--ease), filter .5s var(--ease);
}
.cf-link:hover .cf-img img{transform:scale(1.04);filter:saturate(1);}
.cf-caption{
  position:absolute;
  left:-1.5rem;
  bottom:-1.8rem;
  background:var(--ink);
  color:var(--cream);
  padding:1.1rem 1.5rem 1.2rem;
  max-width:280px;
  box-shadow:0 18px 30px -12px rgba(0,0,0,.35);
}
.cf-brand{
  font-family:var(--serif-en);
  letter-spacing:.28em;
  font-size:.7rem;
  color:var(--rose-light);
  margin-bottom:.45rem;
  text-transform:uppercase;
}
.cf-name{
  font-family:var(--serif-jp);
  font-weight:500;
  font-size:1rem;
  letter-spacing:.06em;
  color:var(--cream);
  margin-bottom:.6rem;
  line-height:1.45;
}
.cf-name em{
  font-style:italic;
  font-family:var(--serif-en);
  font-weight:500;
  color:var(--rose-light);
  margin-left:.15em;
}
.cf-price{
  font-family:var(--serif-en);
  font-size:1.1rem;
  letter-spacing:.04em;
  color:var(--cream);
  margin-bottom:.4rem;
}
.cf-price small{font-size:.65em;color:var(--cream-2);margin-left:.2em;}
.cf-view{
  font-family:var(--serif-en);
  letter-spacing:.25em;
  font-size:.72rem;
  color:var(--rose-light);
  text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.4rem;
  transition:.4s var(--ease);
}
.cf-view i{font-style:normal;transition:transform .4s var(--ease);}
.cf-link:hover .cf-view i{transform:translateX(5px);}

.cf-note{
  position:absolute;
  top:-1rem;right:0;
  font-family:var(--serif-jp);
  font-weight:500;
  font-size:1rem;
  letter-spacing:.25em;
  color:var(--rose);
  font-style:italic;
  background:var(--paper);
  padding:.4rem 1rem;
  z-index:2;
}

/* ============================================================
   FOR YOU (買い手への語りかけ)
   ============================================================ */
.for-you{
  padding:7rem 0;
  background:linear-gradient(180deg, var(--bg-2) 0%, var(--bg) 100%);
  text-align:center;
  position:relative;
  overflow:hidden;
}
.for-you::before{
  content:"☀";
  position:absolute;font-size:22rem;
  color:rgba(242,147,95,.10);
  top:50%;left:50%;transform:translate(-50%,-50%);
  font-family:var(--serif-en);
  pointer-events:none;
  line-height:1;
}
.for-you-inner{position:relative;z-index:2;max-width:680px;margin:0 auto;}
.for-you .kicker{color:var(--rose-2);}
.for-you-title{
  font-family:var(--serif-jp);
  font-weight:400;
  font-size:clamp(1.8rem, 4.2vw, 2.8rem);
  line-height:1.5;letter-spacing:.08em;
  margin-bottom:1.8rem;
  color:var(--ink);
}
.for-you-title em{
  font-style:italic;color:var(--rose);
  font-family:var(--serif-en);font-weight:500;
  padding:0 .15em;
}
.for-you p{margin-bottom:1.2rem;}
.for-you em{color:var(--rose);font-style:normal;font-weight:500;}
.for-you small{font-size:.85rem;color:var(--muted);letter-spacing:.1em;}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{
  background:var(--ink);
  color:var(--cream);
  padding:1.3rem 0;
  overflow:hidden;
  border-block:1px solid var(--line);
}
.marquee-track{
  display:flex;align-items:center;gap:3rem;
  white-space:nowrap;
  animation:marq 28s linear infinite;
  font-family:var(--serif-en);
  letter-spacing:.4em;font-size:.95rem;
}
.marquee-track i{color:var(--rose-light);font-style:normal;font-size:1.2rem;}
@keyframes marq{
  0%{transform:translateX(0);}
  100%{transform:translateX(-50%);}
}

/* ============================================================
   COLLECTION
   ============================================================ */
.collection{padding:9rem 0;background:var(--paper);}
.collection .section-head{text-align:center;}
.card-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:2rem;
}
.card{
  background:#fff;
  border:1px solid rgba(26,106,160,.06);
  border-radius:var(--radius);
  overflow:hidden;
  transition:transform .6s var(--ease), box-shadow .6s var(--ease);
  will-change:transform;
}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow);}
.card-img{overflow:hidden;aspect-ratio:1 / 1;background:var(--bg-2);}
.card-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.4s var(--ease), filter .6s var(--ease);
  filter:saturate(.9);
}
.card:hover .card-img img{transform:scale(1.08);filter:saturate(1);}
.card-body{padding:1.8rem 1.6rem 2rem;}
.card-tag{
  font-family:var(--serif-en);
  letter-spacing:.3em;font-size:.7rem;
  color:var(--rose);margin-bottom:.6rem;
}
.card h3{
  font-family:var(--serif-jp);
  font-weight:500;font-size:1.3rem;
  letter-spacing:.08em;
  margin-bottom:.7rem;
  color:var(--ink);
}
.card p{font-size:.92rem;color:var(--ink-2);line-height:1.85;}
.card .price{
  font-family:var(--serif-en);
  color:var(--ink);
  font-size:1.2rem;letter-spacing:.05em;
  margin:1.1rem 0 1.2rem;
}
.card .price small{font-size:.7em;color:var(--muted);}
.card-link{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--serif-en);letter-spacing:.3em;
  font-size:.78rem;color:var(--ink);
  border-bottom:1px solid var(--ink);
  padding-bottom:.2rem;
  transition:.4s var(--ease);
}
.card-link i{font-style:normal;transition:transform .4s var(--ease);}
.card-link:hover{color:var(--rose);border-color:var(--rose);}
.card-link:hover i{transform:translateX(5px);}

/* ============================================================
   EDITOR'S SELECTION (雑誌風4選)
   ============================================================ */
.editorial{
  padding:9rem 0 7rem;
  background:var(--paper);
  position:relative;
  overflow:hidden;
}
.editorial::before{
  content:"EDITOR'S SELECTION";
  position:absolute;top:3rem;left:50%;transform:translateX(-50%);
  font-family:var(--serif-en);font-style:italic;
  font-size:clamp(4rem, 12vw, 9rem);
  color:rgba(37,150,224,.05);
  letter-spacing:.05em;
  white-space:nowrap;
  pointer-events:none;
  font-weight:400;
}
.editorial .section-head{position:relative;z-index:2;}

.ed-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:5rem 4rem;
  position:relative;
}
.ed-item{
  position:relative;
}
/* 2x2 grid below the feature card — column-2 items dropped for zigzag */
.ed-item:nth-child(3),
.ed-item:nth-child(5){margin-top:4rem;}

/* No.01 feature card — magazine-style spotlight for the new arrival */
.ed-item--feature{
  grid-column:1 / -1;
  display:grid;
  grid-template-columns:minmax(0, 1.05fr) minmax(0, 1fr);
  grid-template-rows:auto auto auto 1fr auto auto;
  column-gap:4rem;
  row-gap:0;
  margin-bottom:2rem;
  padding-bottom:3rem;
  border-bottom:1px solid var(--line);
}
.ed-item--feature > .ed-no{
  grid-column:1 / -1;
  grid-row:1;
}
.ed-item--feature > .ed-link{
  grid-column:1;
  grid-row:2 / span 5;
  margin-bottom:0;
  align-self:stretch;
  display:flex;
}
.ed-item--feature > .ed-link .ed-img{
  aspect-ratio:1 / 1;
  height:100%;
  width:100%;
}
.ed-item--feature > .ed-tag{
  grid-column:2;
  grid-row:2;
  margin-top:1rem;
}
.ed-item--feature > h3{
  grid-column:2;
  grid-row:3;
  font-size:2.2rem;
  align-self:start;
}
.ed-item--feature > .ed-body{
  grid-column:2;
  grid-row:4;
  font-size:1rem;
  align-self:start;
}
.ed-item--feature > .ed-meta{
  grid-column:2;
  grid-row:5;
  align-self:end;
}
.ed-item--feature > .ed-cta{
  grid-column:2;
  grid-row:6;
  justify-self:start;
}

/* NEW chip */
.ed-new{
  display:inline-block;
  font-family:var(--serif-en);
  font-style:italic;
  font-weight:500;
  font-size:.7rem;
  letter-spacing:.2em;
  color:#fff;
  background:var(--rose);
  padding:.25em .8em .3em;
  border-radius:999px;
  margin-right:.8em;
  vertical-align:middle;
  transform:translateY(-1px);
}

.ed-no{
  display:flex;
  align-items:baseline;
  gap:.6rem;
  font-family:var(--serif-en);
  font-size:.95rem;letter-spacing:.3em;
  color:var(--rose-2);
  margin-bottom:1.4rem;
  padding-bottom:.8rem;
  border-bottom:1px solid var(--line);
}
.ed-no em{
  font-style:italic;
  font-weight:500;
  font-size:2.4rem;
  letter-spacing:0;
  color:var(--rose);
  line-height:1;
}
.ed-no::after{
  content:"";
  flex:1;
  height:1px;
  background:linear-gradient(90deg, var(--line) 0%, transparent 100%);
  margin-left:.8rem;
  align-self:center;
  transform:translateY(-.4rem);
}
.ed-link{
  display:block;
  overflow:hidden;
  border-radius:var(--radius);
  background:var(--bg-2);
  margin-bottom:1.6rem;
}
.ed-img{
  aspect-ratio: 1 / 1;
  overflow:hidden;
}
.ed-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.6s var(--ease), filter .6s var(--ease);
  filter:saturate(.92);
}
.ed-item:hover .ed-img img{transform:scale(1.06);filter:saturate(1);}

.ed-tag{
  font-family:var(--serif-en);
  letter-spacing:.25em;
  font-size:.78rem;
  color:var(--muted);
  margin-bottom:.7rem;
}
.ed-tag em{
  font-style:italic;
  color:var(--rose);
  font-weight:500;
  letter-spacing:.05em;
  padding:0 .1em;
}
.ed-item h3{
  font-family:var(--serif-jp);
  font-weight:500;
  font-size:1.6rem;
  letter-spacing:.08em;
  line-height:1.5;
  margin-bottom:1rem;
  color:var(--ink);
}
.ed-body{
  font-size:.95rem;line-height:2;
  color:var(--ink-2);
  margin-bottom:1.5rem;
}
.ed-body em{
  font-style:normal;
  color:var(--rose);
  font-weight:500;
}
.ed-meta{
  display:flex;align-items:baseline;justify-content:space-between;
  gap:1rem;
  padding:1rem 0;
  border-top:1px solid var(--line);
  margin-bottom:1.2rem;
}
.ed-brand{
  font-family:var(--serif-en);
  letter-spacing:.2em;
  font-size:.78rem;
  color:var(--muted);
  text-transform:uppercase;
}
.ed-price{
  font-family:var(--serif-en);
  font-size:1.3rem;letter-spacing:.04em;
  color:var(--ink);
}
.ed-price small{font-size:.6em;color:var(--muted);margin-left:.2em;}
.ed-cta{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--serif-en);
  letter-spacing:.25em;font-size:.85rem;
  color:var(--ink);
  border-bottom:1px solid var(--ink);
  padding-bottom:.25rem;
  transition:.4s var(--ease);
}
.ed-cta i{font-style:normal;transition:transform .4s var(--ease);}
.ed-cta:hover{color:var(--rose);border-color:var(--rose);}
.ed-cta:hover i{transform:translateX(5px);}

/* ============================================================
   PICK UP (旧 Editor's Picks)
   ============================================================ */
.picks{
  padding:9rem 0;
  background:linear-gradient(180deg, var(--ink) 0%, #155f93 100%);
  color:var(--cream);
  position:relative;overflow:hidden;
}
.picks::before{
  content:"";position:absolute;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle, rgba(191,225,251,.16), transparent 70%);
  top:-200px;right:-200px;
}
.picks-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:5rem;
  align-items:center;position:relative;z-index:2;
}
.picks-feature{
  margin:2.5rem 0;
  padding:1.8rem 0;
  border-block:1px solid var(--line);
  display:grid;gap:1.2rem;
}
.picks-feature > div{display:grid;grid-template-columns:120px 1fr;gap:1.5rem;align-items:baseline;}
.picks-label{
  font-family:var(--serif-en);
  letter-spacing:.25em;font-size:.75rem;
  color:var(--rose-light);
}
.picks-feature em{font-style:italic;font-family:var(--serif-en);color:var(--rose-light);}
.picks-figure{position:relative;}
.picks-link{
  display:block;
  overflow:hidden;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  aspect-ratio:1 / 1;
  background:var(--bg-2);
}
.picks-link img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.6s var(--ease), filter .5s var(--ease);
  filter:saturate(.95);
}
.picks-link:hover img{transform:scale(1.05);filter:saturate(1);}
.picks-badge{
  position:absolute;
  top:1.5rem;left:-1.5rem;
  width:120px;height:120px;
  border-radius:50%;
  background:var(--rose);
  color:#fff;
  display:grid;place-items:center;
  text-align:center;
  font-family:var(--serif-jp);
  animation:badge-spin 18s linear infinite;
  box-shadow:0 12px 24px -8px rgba(0,0,0,.4);
  border:2px solid #fff;
}
.picks-badge span{display:block;letter-spacing:.25em;font-size:.65rem;font-family:var(--serif-en);}
.picks-badge strong{display:block;font-size:1.4rem;font-weight:500;line-height:1;margin:.3rem 0;letter-spacing:.1em;}
.picks-badge small{display:block;font-size:.55rem;letter-spacing:.15em;}
@keyframes badge-spin{
  to{transform:rotate(360deg);}
}

/* ============================================================
   ALL PRODUCTS (全60点)
   ============================================================ */
.all-products{
  padding:8rem 0;
  background:var(--paper);
  position:relative;
}
.all-products .section-head{margin-bottom:2.5rem;}

/* カテゴリーナビ */
.cat-nav{
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:.5rem;
  margin-bottom:4rem;
  padding:1.5rem 0;
  border-block:1px solid var(--line);
  position:sticky;
  top:60px;
  background:var(--paper);
  z-index:30;
  backdrop-filter:blur(8px);
}
.cat-nav button{
  font-family:var(--serif-en);
  letter-spacing:.18em;
  font-size:.78rem;
  padding:.55rem 1.2rem;
  border:1px solid var(--line);
  border-radius:99px;
  color:var(--ink-2);
  background:transparent;
  cursor:pointer;
  transition:.3s var(--ease);
  white-space:nowrap;
}
.cat-nav button:hover{color:var(--rose);border-color:var(--rose);}
.cat-nav button.active{
  background:var(--rose);
  color:#fff;
  border-color:var(--rose);
}
.cat-nav button small{
  font-size:.7em;
  margin-left:.4em;
  opacity:.6;
}

/* カテゴリーブロック */
.cat-block{
  margin-bottom:5rem;
  scroll-margin-top:160px;
}
.cat-block:last-child{margin-bottom:0;}
.cat-block.hidden{display:none;}
.cat-head{
  display:flex;align-items:baseline;
  gap:1.5rem;
  margin-bottom:2.5rem;
  padding-bottom:1.5rem;
  border-bottom:1px solid var(--line);
  position:relative;
}
.cat-no{
  font-family:var(--serif-en);
  font-style:italic;
  font-size:clamp(2rem, 4vw, 3rem);
  font-weight:400;
  color:var(--rose);
  line-height:1;
}
.cat-text{flex:1;}
.cat-label{
  font-family:var(--serif-en);
  letter-spacing:.3em;font-size:.85rem;
  color:var(--muted);
  margin-bottom:.4rem;
}
.cat-jp{
  font-family:var(--serif-jp);font-weight:500;
  font-size:clamp(1.3rem, 2.4vw, 1.8rem);
  letter-spacing:.08em;
  color:var(--ink);
  margin-bottom:.3rem;
}
.cat-desc{
  font-size:.9rem;color:var(--muted);
  letter-spacing:.05em;
}
.cat-count{
  font-family:var(--serif-en);font-size:.8rem;
  letter-spacing:.2em;color:var(--rose-2);
  align-self:flex-start;
  padding-top:.5rem;
}

/* 商品グリッド */
.cat-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:2rem 1.5rem;
}
.itm{
  position:relative;
  background:#fff;
  border:1px solid rgba(26,106,160,.05);
  border-radius:var(--radius);
  overflow:hidden;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
.itm:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.itm a{display:block;}
.itm-img{
  aspect-ratio: 1 / 1;
  overflow:hidden;
  background:var(--bg-2);
  position:relative;
}
.itm-img img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.9);
  transition:transform 1s var(--ease), filter .4s var(--ease);
}
.itm:hover .itm-img img{transform:scale(1.06);filter:saturate(1);}
.itm-img.coming::before{
  content:"COMING SOON";
  position:absolute;inset:0;
  display:grid;place-items:center;
  background:linear-gradient(135deg, rgba(26,106,160,.85), rgba(26,106,160,.95));
  color:var(--rose-light);
  font-family:var(--serif-en);letter-spacing:.3em;
  font-size:.85rem;
  z-index:2;
}
.itm-img.coming img{opacity:.3;filter:blur(2px);}

.itm-body{padding:1rem 1.1rem 1.3rem;}
.itm-brand{
  font-family:var(--serif-en);
  letter-spacing:.18em;
  font-size:.65rem;
  color:var(--rose);
  text-transform:uppercase;
  margin-bottom:.4rem;
  display:block;
}
.itm-name{
  font-size:.82rem;line-height:1.55;
  color:var(--ink);
  margin-bottom:.6rem;
  min-height:2.6em;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.itm-price{
  font-family:var(--serif-en);
  font-size:1.05rem;letter-spacing:.04em;
  color:var(--ink);
  font-weight:500;
}
.itm-price small{font-size:.65em;color:var(--muted);margin-left:.2em;font-weight:400;}
.itm-no{
  position:absolute;
  top:.5rem;left:.6rem;
  font-family:var(--serif-en);
  font-style:italic;
  font-size:.75rem;
  color:rgba(26,106,160,.5);
  z-index:1;
  letter-spacing:.05em;
}
.itm-soon{
  position:absolute;
  top:.6rem;right:.6rem;
  font-family:var(--serif-en);
  letter-spacing:.15em;
  font-size:.55rem;
  color:#fff;
  background:var(--rose);
  padding:.2rem .5rem;
  border-radius:99px;
  z-index:3;
}

/* ============================================================
   STAFF VOICE (スタッフのおすすめ)
   ============================================================ */
.message{padding:9rem 0;background:var(--bg-2);}
.voice-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:2rem;
}
.vc-card{
  display:flex;
  flex-direction:column;
  background:#fff;
  border:1px solid rgba(26,106,160,.04);
  padding:2rem 1.8rem 1.8rem;
  position:relative;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
.vc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);}

.vc-staff{
  display:flex;align-items:center;gap:1rem;
  margin-bottom:1.4rem;
  padding-bottom:1.2rem;
  border-bottom:1px dashed var(--line);
}
.vc-avatar{
  width:46px;height:46px;
  display:grid;place-items:center;
  border-radius:50%;
  font-family:var(--serif-en);
  font-style:italic;
  font-size:1.4rem;
  font-weight:500;
  color:#fff;
  flex-shrink:0;
  box-shadow:0 6px 14px -4px rgba(0,0,0,.2);
}
.vc-avatar[data-c="rose"]{background:linear-gradient(135deg, var(--rose), var(--rose-2));}
.vc-avatar[data-c="blue"]{background:linear-gradient(135deg, var(--blue-light), var(--blue));}
.vc-avatar[data-c="sage"]{background:linear-gradient(135deg, #a8b8a0, var(--sage));}

.vc-info{flex:1;}
.vc-name{
  font-family:var(--serif-jp);
  font-weight:500;
  font-size:1rem;
  letter-spacing:.04em;
  color:var(--ink);
  line-height:1.3;
}
.vc-name small{
  font-family:var(--serif-en);
  font-weight:400;
  font-size:.7rem;
  letter-spacing:.15em;
  color:var(--muted);
  margin-left:.3em;
}
.vc-role{
  font-family:var(--serif-en);
  letter-spacing:.2em;
  font-size:.7rem;
  color:var(--rose-2);
  margin-top:.2rem;
}

.vc-msg{
  font-family:var(--serif-jp);
  position:relative;
  padding-left:1.2rem;
  margin-bottom:1.6rem;
  flex:1;
}
.vc-msg::before{
  content:"\201C";
  position:absolute;
  top:-.6rem;left:-.2rem;
  font-family:var(--serif-en);
  font-size:3rem;
  line-height:1;
  color:var(--rose-light);
  opacity:.7;
}
.vc-msg p{
  font-size:.95rem;
  line-height:2;
  color:var(--ink-2);
}

.vc-product{
  display:block;
  background:var(--bg);
  border-top:1px solid var(--line);
  margin:0 -1.8rem -1.8rem;
  padding:1.2rem 1.4rem 1.4rem;
  transition:background .4s var(--ease);
}
.vc-product:hover{background:var(--bg-2);}
.vc-img{
  aspect-ratio: 1 / 1;
  overflow:hidden;
  border-radius:var(--radius);
  margin-bottom:1rem;
  background:#fff;
}
.vc-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.2s var(--ease);
}
.vc-product:hover .vc-img img{transform:scale(1.05);}
.vc-prod-info{
  display:flex;flex-direction:column;gap:.3rem;
}
.vc-brand{
  font-family:var(--serif-en);
  letter-spacing:.18em;
  font-size:.65rem;
  color:var(--rose);
  text-transform:uppercase;
}
.vc-prod-name{
  font-size:.82rem;
  line-height:1.5;
  color:var(--ink);
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.vc-price-line{
  display:flex;align-items:baseline;justify-content:space-between;
  gap:.5rem;
  margin-top:.4rem;
}
.vc-price{
  font-family:var(--serif-en);
  font-size:1.05rem;
  letter-spacing:.04em;
  color:var(--ink);
  font-weight:500;
}
.vc-price small{font-size:.65em;color:var(--muted);margin-left:.2em;font-weight:400;}
.vc-view{
  font-family:var(--serif-en);
  letter-spacing:.22em;
  font-size:.7rem;
  color:var(--rose);
  text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.3rem;
}
.vc-view i{font-style:normal;transition:transform .3s var(--ease);}
.vc-product:hover .vc-view i{transform:translateX(4px);}

.msg-easter{
  text-align:center;
  margin-top:3rem;
  font-size:.85rem;color:var(--muted);
}
.msg-easter code{
  font-family:var(--serif-en);
  background:var(--ink);color:var(--rose-light);
  padding:.2rem .6rem;border-radius:2px;
  letter-spacing:.2em;
}

/* ============================================================
   CTA FINAL (タイルマーキー背景)
   ============================================================ */
.cta-final{
  position:relative;
  padding:8rem 0;
  background:var(--ink);
  color:var(--cream);
  text-align:center;
  overflow:hidden;
}
.cta-final .container{position:relative;z-index:2;}

.cta-tiles{
  position:absolute;
  inset:-8% -10%;
  display:flex;
  flex-direction:column;
  gap:14px;
  padding:14px 0;
  filter:saturate(.55) brightness(.55) contrast(.95);
  opacity:.85;
  z-index:0;
  will-change:transform;
}
.cta-veil{
  position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(60% 60% at 50% 50%, rgba(35,120,175,.1), rgba(35,120,175,.75) 75%),
    linear-gradient(180deg, rgba(35,120,175,.65) 0%, rgba(22,95,140,.88) 100%);
}
.cta-final h2{
  font-family:var(--serif-en);
  font-weight:500;
  font-size:clamp(2.5rem, 6vw, 4.5rem);
  letter-spacing:.1em;
  line-height:1.2;margin-bottom:1.5rem;
}
.cta-final h2 span{
  display:block;
  font-family:var(--serif-jp);
  font-size:.5em;letter-spacing:.15em;
  color:var(--rose-light);margin-top:1rem;
}
.cta-final p{margin-bottom:1.8rem;color:var(--cream-2);}

/* ラッピング無料カード(CTAセクション内) */
.cta-wrap-card{
  display:inline-grid;
  grid-template-columns:auto 1fr;
  align-items:center;
  gap:1.2rem;
  padding:.85rem 1.6rem .85rem .85rem;
  margin:0 auto 2.5rem;
  max-width:460px;
  text-align:left;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(191,225,251,.28);
  border-radius:999px;
  transition:.4s var(--ease);
  backdrop-filter:blur(2px);
}
.cta-wrap-card:hover{
  background:rgba(191,225,251,.12);
  border-color:rgba(191,225,251,.55);
  transform:translateY(-2px);
  box-shadow:0 10px 30px rgba(0,0,0,.25);
}
.cwc-img{
  width:60px;height:60px;
  border-radius:999px;
  overflow:hidden;
  background:#fff;
  flex-shrink:0;
}
.cwc-img img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .6s var(--ease);
}
.cta-wrap-card:hover .cwc-img img{transform:scale(1.08);}
.cwc-eyebrow{
  font-family:var(--serif-en);
  font-size:.65rem;
  letter-spacing:.28em;
  color:var(--rose-light);
  margin:0 0 .25rem;
}
.cwc-title{
  font-family:var(--serif-jp);
  font-weight:500;
  font-size:.95rem;
  color:var(--cream);
  letter-spacing:.06em;
  margin:0 0 .15rem;
  line-height:1.5;
}
.cwc-title em{
  font-style:normal;
  color:#fff;
  border-bottom:1px solid rgba(191,225,251,.5);
  padding-bottom:1px;
}
.cwc-desc{
  font-family:var(--serif-jp);
  display:flex;
  align-items:center;
  gap:.5em;
  font-size:.78rem;
  letter-spacing:.1em;
  color:var(--cream-2);
  margin:0;
}
.cwc-desc i{font-style:normal;transition:transform .4s var(--ease);}
.cta-wrap-card:hover .cwc-desc i{transform:translateX(4px);}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{
  background:var(--ink);
  color:var(--cream-2);
  padding:5rem 0 2rem;
}
.footer-inner{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;gap:2rem;
  text-align:center;
}
.footer-brand{display:flex;align-items:center;gap:1.2rem;justify-self:start;}
.brand-logo--footer{
  height:30px;
  width:auto;
  filter:brightness(1.15);
}
.footer-brand p{font-family:var(--serif-en);letter-spacing:.3em;font-size:.95rem;line-height:1.4;}
.footer-brand small{font-size:.65rem;color:var(--muted);letter-spacing:.15em;}
.footer-nav{display:flex;gap:1.6rem;}
.footer-nav a{
  font-family:var(--serif-en);letter-spacing:.2em;font-size:.8rem;
  color:var(--cream-2);transition:.3s;
}
.footer-nav a:hover{color:var(--rose-light);}
.copy{
  justify-self:end;
  font-family:var(--serif-en);font-size:.72rem;letter-spacing:.25em;
  color:var(--muted);
}

/* ============================================================
   REVEAL
   ============================================================ */
[data-reveal]{
  opacity:0;transform:translateY(28px);
  transition:opacity 1s var(--ease), transform 1s var(--ease);
}
[data-reveal].is-visible{opacity:1;transform:none;}
[data-reveal]:nth-child(2){transition-delay:.08s;}
[data-reveal]:nth-child(3){transition-delay:.16s;}
[data-reveal]:nth-child(4){transition-delay:.24s;}
[data-reveal]:nth-child(5){transition-delay:.32s;}

/* ============================================================
   SPOTLIGHT (カーソル追従)
   ============================================================ */
.spotlight{
  position:fixed;
  width:380px;height:380px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(191,225,251,.18), transparent 70%);
  pointer-events:none;
  z-index:1;
  transform:translate(-50%,-50%);
  transition:opacity .5s ease;
  mix-blend-mode:multiply;
  opacity:0;
}
.spotlight.active{opacity:1;}

.ee-dot{
  position:fixed;width:8px;height:8px;
  bottom:14px;right:14px;
  background:var(--rose);
  border-radius:50%;opacity:.35;z-index:300;
  cursor:pointer;transition:.4s;
  box-shadow:0 0 0 0 rgba(37,150,224,.4);
  animation:dot-pulse 2.4s ease-in-out infinite;
}
.ee-dot::after{
  content:"♡";
  position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%) scale(0);
  color:#fff;font-size:.6rem;
  transition:.3s;
}
.ee-dot:hover{opacity:1;transform:scale(2.4);}
.ee-dot:hover::after{transform:translate(-50%,-50%) scale(1);}
@keyframes dot-pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(37,150,224,.4);}
  50%{box-shadow:0 0 0 10px rgba(37,150,224,0);}
}

@keyframes fade-in{from{opacity:0;}to{opacity:1;}}
@keyframes pop-in{
  from{opacity:0;transform:scale(.92) translateY(20px);}
  to{opacity:1;transform:none;}
}

/* ============================================================
   CONFETTI CANVAS
   ============================================================ */
#confetti{
  position:fixed;inset:0;z-index:150;
  pointer-events:none;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1100px){
  .cat-grid{grid-template-columns:repeat(3, 1fr);}
}
@media (max-width: 980px){
  .nav,.cta-pill{display:none;}
  .menu-toggle{display:flex;color:var(--cream);}
  .site-header.open .nav{
    display:flex;flex-direction:column;
    position:absolute;top:100%;left:0;right:0;
    background:rgba(26,106,160,.96);
    padding:2rem;gap:1.5rem;text-align:center;
    border-bottom:1px solid var(--line);
  }
  .site-header.open .nav a{color:var(--cream);}
  .concept-grid,
  .picks-grid{grid-template-columns:1fr;gap:3rem;}
  .picks-figure{order:-1;max-width:480px;margin-inline:auto;}
  .card-grid,
  .voice-grid{grid-template-columns:repeat(2, 1fr);}
  .footer-inner{grid-template-columns:1fr;gap:2rem;text-align:center;}
  .footer-brand,.copy{justify-self:center;}
  .ee-ribbon{right:1rem;top:60px;}
  .ee-ribbon svg{width:46px;height:64px;}
  .hero-meta{flex-direction:column;align-items:flex-start;gap:1.5rem;}
  .countdown{gap:1rem;padding:1rem 1.2rem;}
  .countdown .num{font-size:1.5rem;}
  .spotlight{display:none;}
  .ed-grid{grid-template-columns:1fr;gap:3rem;}
  .ed-item:nth-child(3),.ed-item:nth-child(5){margin-top:0;}
  .ed-item--feature{
    grid-template-columns:1fr;
    grid-template-rows:auto;
    column-gap:0;
    margin-bottom:1rem;
    padding-bottom:2rem;
  }
  .ed-item--feature > .ed-link{
    grid-column:1;
    grid-row:auto;
    margin-bottom:1.6rem;
  }
  .ed-item--feature > .ed-link .ed-img{aspect-ratio:1 / 1;}
  .ed-item--feature > .ed-tag,
  .ed-item--feature > h3,
  .ed-item--feature > .ed-body,
  .ed-item--feature > .ed-meta,
  .ed-item--feature > .ed-cta{
    grid-column:1;
    grid-row:auto;
    margin-top:0;
  }
  .ed-item--feature > h3{font-size:1.6rem;}
  .ed-item--feature > .ed-body{font-size:.95rem;}
  .tile-row img{width:180px;min-height:150px;}
  .cf-caption{left:-.8rem;bottom:-1.5rem;padding:1rem 1.2rem;max-width:240px;}
  .cat-nav{top:56px;padding:1rem 0;overflow-x:auto;justify-content:flex-start;flex-wrap:nowrap;margin-inline:-4vw;padding-inline:4vw;}
  .cat-nav::-webkit-scrollbar{display:none;}
  .cat-head{flex-wrap:wrap;gap:1rem;}
  .cat-grid{grid-template-columns:repeat(3, 1fr);gap:1.5rem 1rem;}
}
@media (max-width: 640px){
  .container{width:90vw;}
  .hero-inner{padding:2rem 0 5rem;}
  .hero-eyecatch{margin-top:5.5rem;}
  /* スマホでは「2026 / Cool & Dry Collection / メインコピー」を非表示 */
  .hero-eyebrow .he-year,
  .hero-eyebrow .he-date,
  .hero-title{display:none;}
  .hero-title{letter-spacing:.05em;}
  .concept,.collection,.picks,.message,.for-you,.editorial,.all-products{padding:5.5rem 0;}
  .section-head{margin-bottom:2.5rem;}
  .card-grid,.voice-grid{grid-template-columns:1fr;}
  .picks-feature > div{grid-template-columns:1fr;gap:.3rem;}
  .picks-badge{width:96px;height:96px;top:1rem;left:1rem;}
  .picks-badge strong{font-size:1.1rem;}
  .concept-figure figcaption{left:0;bottom:-1rem;font-size:.78rem;padding:.6rem 1rem;}
  .cta-final{background-attachment:scroll;}
  .ed-no em{font-size:1.9rem;}
  .ed-no{font-size:.85rem;margin-bottom:1rem;}
  .ed-item h3{font-size:1.3rem;}
  .tile-row img{width:130px;min-height:110px;}
  .hero-tiles,.cta-tiles{gap:8px;}
  .tile-row{gap:8px;}
  .cf-note{font-size:.85rem;letter-spacing:.18em;padding:.3rem .8rem;}
  .cf-caption{left:0;right:0;max-width:none;bottom:-1.6rem;}
  .cat-grid{grid-template-columns:repeat(2, 1fr);gap:1.2rem .8rem;}
  .itm-body{padding:.8rem .8rem 1rem;}
  .itm-name{font-size:.75rem;}
  .itm-price{font-size:.9rem;}
  .cat-no{font-size:1.8rem;}
  .cat-jp{font-size:1.1rem;}
}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.01s !important;transition-duration:.01s !important;}
  [data-reveal]{opacity:1;transform:none;}
}

/* ============================================================
   SUMMER ADDITIONS — 夏物 本店
   ============================================================ */

/* ヒーローの信頼バッジ */
.hero-badges{
  display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.8rem;
}
.hero-badges span{
  font-family:var(--serif-jp);
  font-size:.74rem;letter-spacing:.12em;
  color:var(--cream);
  padding:.42rem 1rem;
  border:1px solid rgba(191,225,251,.4);
  border-radius:99px;
  background:rgba(37,150,224,.14);
  backdrop-filter:blur(4px);
  display:inline-flex;align-items:center;gap:.4em;
}
.hero-badges span i{font-style:normal;color:var(--rose-light);}

/* NEW/人気チップの色違い */
.ed-new.hot{background:var(--sage);}

/* 機能タグ(冷感/UV/速乾) */
.func-row{display:flex;flex-wrap:wrap;gap:.4rem;margin:.2rem 0 .1rem;}
.func-tag{
  font-family:var(--serif-jp);
  font-size:.62rem;letter-spacing:.08em;
  padding:.16rem .55rem;border-radius:99px;
  border:1px solid var(--line);
  color:var(--rose-2);background:rgba(37,150,224,.08);
  white-space:nowrap;
}
.func-tag[data-f="cool"]{color:#1b86cf;border-color:rgba(37,150,224,.4);background:rgba(37,150,224,.1);}
.func-tag[data-f="uv"]{color:#c97324;border-color:rgba(242,147,95,.45);background:rgba(242,147,95,.12);}
.func-tag[data-f="sweat"]{color:#2f7fb0;border-color:rgba(47,136,196,.4);background:rgba(47,136,196,.1);}

/* ============================================================
   RANKING (社会的証明 / レビュー実績)
   ============================================================ */
.ranking{
  padding:8rem 0;
  background:linear-gradient(180deg, var(--bg-2) 0%, var(--bg) 100%);
  position:relative;overflow:hidden;
}
.ranking::before{
  content:"RANKING";
  position:absolute;top:2.5rem;left:50%;transform:translateX(-50%);
  font-family:var(--serif-en);font-style:italic;
  font-size:clamp(4rem,12vw,9rem);
  color:rgba(37,150,224,.06);letter-spacing:.05em;white-space:nowrap;
  pointer-events:none;
}
.ranking .section-head{position:relative;z-index:2;}
.rank-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem;
}
.rank-card{
  position:relative;background:#fff;border:1px solid rgba(26,106,160,.06);
  border-radius:var(--radius);overflow:hidden;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
.rank-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);}
.rank-card a{display:block;color:inherit;}
.rank-no{
  position:absolute;top:.5rem;left:.6rem;z-index:2;
  font-family:var(--serif-en);font-style:italic;font-weight:500;
  font-size:1.5rem;line-height:1;
  color:#fff;
  width:2.2rem;height:2.2rem;border-radius:50%;
  display:grid;place-items:center;
  background:linear-gradient(135deg,var(--rose),var(--rose-2));
  box-shadow:0 6px 14px -4px rgba(26,106,160,.4);
}
.rank-card:nth-child(1) .rank-no,
.rank-card:nth-child(2) .rank-no,
.rank-card:nth-child(3) .rank-no{background:linear-gradient(135deg,#f6b65a,var(--sage));}
.rank-img{aspect-ratio:1/1;overflow:hidden;background:var(--bg-2);}
.rank-img img{width:100%;height:100%;object-fit:cover;filter:saturate(.95);transition:transform 1.2s var(--ease);}
.rank-card:hover .rank-img img{transform:scale(1.07);}
.rank-body{padding:1rem 1.1rem 1.3rem;}
.rank-brand{font-family:var(--serif-en);letter-spacing:.16em;font-size:.64rem;color:var(--rose);text-transform:uppercase;display:block;margin-bottom:.35rem;}
.rank-name{font-size:.8rem;line-height:1.5;color:var(--ink);min-height:2.4em;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:.5rem;}
.rank-stars{font-size:.78rem;color:#f0a93a;letter-spacing:.05em;margin-bottom:.3rem;}
.rank-stars small{color:var(--muted);font-family:var(--serif-en);letter-spacing:.08em;margin-left:.3em;}
.rank-price{font-family:var(--serif-en);font-size:1.05rem;font-weight:500;color:var(--ink);}
.rank-price small{font-size:.62em;color:var(--muted);margin-left:.2em;}

/* ============================================================
   風鈴 イースターエッグ (ribbon の差し替え)
   ============================================================ */
.ee-furin{
  position:absolute;right:5%;top:78px;z-index:3;
  transform-origin:50% 8px;
  animation:furin-sway 4s ease-in-out infinite;
  cursor:pointer;opacity:.92;
  filter:drop-shadow(0 6px 14px rgba(12,44,74,.35));
}
.ee-furin.ring{animation:furin-ring 1.1s var(--ease);}
@keyframes furin-sway{0%,100%{transform:rotate(-5deg);}50%{transform:rotate(5deg);}}
@keyframes furin-ring{
  0%{transform:rotate(0);}15%{transform:rotate(22deg);}35%{transform:rotate(-16deg);}
  55%{transform:rotate(11deg);}75%{transform:rotate(-7deg);}100%{transform:rotate(0);}
}

/* 太陽ドット(イースターエッグ) */
.ee-dot{background:var(--sage);animation:dot-pulse 2.4s ease-in-out infinite;}
.ee-dot::after{content:"☀";}

@media (max-width:1100px){ .rank-grid{grid-template-columns:repeat(3,1fr);} }
@media (max-width:980px){
  .rank-grid{grid-template-columns:repeat(2,1fr);}
  .ee-furin{right:1rem;top:60px;}
  .ee-furin svg{width:42px;height:auto;}
}
@media (max-width:640px){
  .ranking{padding:5.5rem 0;}
  .rank-name{font-size:.74rem;}
}

/* ============================================================
   SUMMER あしらい（波・太陽・泡・ヤシ / 自作SVG = 著作権フリー）
   ============================================================ */
.has-wave{position:relative;}
.wave{
  position:absolute; left:0; top:0; width:100%; height:62px;
  background-repeat:no-repeat; background-position:center top; background-size:100% 100%;
  z-index:3; pointer-events:none; line-height:0;
}
.wave--ink{background-image:url('../img/wave-ink.svg');}
.wave--light{background-image:url('../img/wave-light.svg');}

.deco{position:absolute; pointer-events:none; z-index:1; background-repeat:no-repeat; background-position:center; background-size:contain;}
.deco-sun{width:230px; height:230px; background-image:url('../img/sun.svg');}
.deco-bubbles{background-image:url('../img/bubbles.svg');}
.deco-palm{background-image:url('../img/palm.svg');}

/* ヒーロー：太陽＋ヤシの葉 */
.hero .deco-sun{ top:14vh; left:3vw; opacity:.42; z-index:1;
  animation:sun-float 9s ease-in-out infinite; filter:drop-shadow(0 0 30px rgba(255,209,102,.35)); }
.hero .deco-palm{ width:300px; height:300px; right:-40px; bottom:-30px; opacity:.5; transform:rotate(8deg); z-index:1; }
@keyframes sun-float{0%,100%{transform:translateY(0);}50%{transform:translateY(-12px);}}

/* 背景ウォーターマークを夏向けに差し替え（父の日流用の名残を上書き） */
#persona.editorial::before{content:"SUMMER 2026";}

/* コンセプト：ヤシの葉のあしらい */
.concept .deco-palm{ width:200px; height:200px; top:-10px; left:-30px; opacity:.5; transform:scaleX(-1) rotate(6deg); }

/* for-you / ranking：泡のあしらい */
.for-you .deco-bubbles{ width:300px; height:300px; right:2%; bottom:4%; opacity:.6; }
.ranking .deco-bubbles{ width:240px; height:240px; left:1%; bottom:6%; opacity:.55; z-index:0; }

@media (max-width:640px){
  .wave{height:40px;}
  .hero .deco-sun{width:150px;height:150px;top:11vh;}
  .hero .deco-palm{width:180px;height:180px;}
  .concept .deco-palm{width:130px;height:130px;}
  .for-you .deco-bubbles,.ranking .deco-bubbles{width:170px;height:170px;}
}

/* ============================================================
   ファーストビュー アイキャッチ（仮メインビジュアル）
   ============================================================ */
.hero-eyecatch{
  position:absolute; right:5.5vw; top:50%; transform:translateY(-50%);
  width:min(500px, 42vw); aspect-ratio:1/1; margin:0; z-index:3;
}
.hero-eyecatch img{
  display:block; width:100%; height:100%; aspect-ratio:1/1;
  object-fit:cover; object-position:center; border-radius:14px;
  box-shadow:0 26px 55px -18px rgba(15,74,115,.55);
  border:3px solid rgba(255,255,255,.55);
}
.hero-eyecatch .ec-badge{
  position:absolute; top:.7rem; left:.7rem; z-index:2;
  font-family:var(--serif-jp); font-size:.66rem; letter-spacing:.18em;
  color:#fff; background:var(--sage);
  padding:.28rem .7rem; border-radius:99px;
  box-shadow:0 6px 14px -4px rgba(0,0,0,.3);
}
/* PCではアイキャッチを右の主役に、Pick Upカードは非表示に */
@media (min-width:981px){
  .hero-spot{display:none !important;}
}
/* スマホ/タブレットでは本文の下に積む */
@media (max-width:980px){
  .hero{flex-direction:column; justify-content:flex-start;}
  .hero-eyecatch{
    order:-1;
    position:static; transform:none; width:90%; max-width:480px;
    aspect-ratio:1/1; margin:6.5rem auto 0;
  }
  .hero-inner{order:0; padding-top:2.5rem;}
}
