/* ==========================================================
   SHIROHATO — Father's Day 2026
   Soft Luxury / 女性が手に取りたくなる柔らかなシック
   ========================================================== */

:root{
  --bg:          #faf6ef;
  --bg-2:        #f4ece1;
  --paper:       #fdfaf4;
  --ink:         #4a3c30;        /* ウォームブラウン(深) */
  --ink-2:       #6b5947;
  --rose:        #c89084;        /* ダスティローズ */
  --rose-2:      #a87267;
  --rose-light:  #e8c8c0;
  --sage:        #8a9a7b;        /* セージグリーン(差し色) */
  --cream:       #fdfaf4;
  --cream-2:     #ede1cf;
  --line:        rgba(200, 144, 132, .28);
  --muted:       #9a8a7a;
  --blue:        #6b89a8;        /* 父の日 ダスティブルー */
  --blue-light:  #b8cee0;        /* 淡い空色 */
  --blue-deep:   #2d3b52;        /* 深いネイビー */
  --serif-en:   "Cormorant Garamond", "Noto Serif JP", serif;
  --serif-jp:   "Noto Serif JP", serif;
  --sans-jp:    "Noto Sans JP", system-ui, sans-serif;
  --radius:      2px;
  --shadow:      0 30px 60px -22px rgba(74,60,48,.25);
  --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(200,144,132,.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(200,144,132,.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(74,60,48,.5),rgba(74,60,48,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:#1a1812;
}
@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(45,59,82,.05), rgba(45,59,82,.7) 75%),
    linear-gradient(180deg, rgba(45,59,82,.55) 0%, rgba(20,28,42,.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-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(--serif-en);
  font-style:italic;
  font-weight:400;
  font-size:clamp(1.2rem, 2.4vw, 1.7rem);
  letter-spacing:.18em;
  color:var(--rose-light);
  line-height:1;
  text-transform:capitalize;
}
.hero-eyebrow .he-year{
  font-family:var(--serif-en);
  font-weight:500;
  font-size:clamp(4.8rem, 11vw, 8.5rem);
  letter-spacing:.04em;
  line-height:.95;
  color:var(--cream);
  text-shadow:0 6px 30px rgba(0,0,0,.4);
  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-year::after{
  content:"";
  position:absolute;left:0;right:-12%;bottom:.12em;
  height:1px;
  background:linear-gradient(90deg, var(--rose) 0%, transparent 100%);
}
.hero-eyebrow .he-date{
  font-family:var(--serif-en);
  letter-spacing:.4em;
  font-size:.78rem;
  color:var(--rose-light);
  text-transform:uppercase;
  margin-top:.3rem;
  padding-left:.2em;
}
.hero-title{
  font-family:var(--serif-jp);
  font-weight:500;
  font-size:clamp(2rem, 5.4vw, 4.2rem);
  letter-spacing:-.01em;
  line-height:1.18;
  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(45,59,82,.35));
}
.hero-title span{display:block;}
.hero-title em{
  font-style:italic;
  font-family:var(--serif-en);
  font-weight:500;
  letter-spacing:.02em;
  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(74,60,48,.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(20,28,42,.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(232,200,192,.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(200,144,132,.06);
  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(74,60,48,.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(200,144,132,.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:4 / 5;
  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%, #382c22 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(232,200,192,.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:4 / 5;
  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(74,60,48,.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(74,60,48,.85), rgba(74,60,48,.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(74,60,48,.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(74,60,48,.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(45,59,82,.1), rgba(45,59,82,.75) 75%),
    linear-gradient(180deg, rgba(45,59,82,.65) 0%, rgba(20,28,42,.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(232,193,184,.28);
  border-radius:999px;
  transition:.4s var(--ease);
  backdrop-filter:blur(2px);
}
.cta-wrap-card:hover{
  background:rgba(232,193,184,.12);
  border-color:rgba(232,193,184,.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(232,193,184,.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(232,200,192,.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 MODAL
   ============================================================ */
.ee-modal{
  position:fixed;inset:0;z-index:200;
  background:rgba(74,60,48,.78);
  backdrop-filter:blur(8px);
  display:grid;place-items:center;
  padding:2rem;
  animation:fade-in .5s var(--ease);
}
.ee-modal[hidden]{display:none;}
.ee-modal-inner{
  max-width:480px;
  background:linear-gradient(180deg, #fff 0%, var(--bg) 100%);
  color:var(--ink);
  padding:3rem 2.5rem;
  border:1px solid var(--rose);
  border-radius:8px;
  text-align:center;
  box-shadow:0 30px 80px rgba(0,0,0,.4);
  animation:pop-in .7s var(--ease);
}
.ee-eyebrow{
  font-family:var(--serif-en);letter-spacing:.3em;
  font-size:.75rem;color:var(--rose);margin-bottom:1.5rem;
}
.ee-modal-inner h3{
  font-family:var(--serif-jp);font-weight:500;
  font-size:1.5rem;letter-spacing:.1em;
  margin-bottom:1.8rem;color:var(--ink);
}
.ee-code{
  font-family:var(--serif-en);
  font-size:1.6rem;letter-spacing:.3em;
  padding:1.2rem 0;
  border-block:1px solid var(--line);
  margin-bottom:1.5rem;
  color:var(--rose);
}
.ee-desc{color:var(--ink-2);margin-bottom:2rem;font-size:.95rem;}
.ee-desc strong{color:var(--rose);}

.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(200,144,132,.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(200,144,132,.4);}
  50%{box-shadow:0 0 0 10px rgba(200,144,132,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(74,60,48,.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:8rem 0 5rem;}
  .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;}
}
