/* =========================================================
   Yun's Mozuku Kimchi — Brand Site
   Colors: #9e2a2b (accent red)  #1c3144 (deep navy)
           #faf9f5 (paper beige) #2b2b2b (charcoal)
   ========================================================= */

:root{
  --c-red:#9e2a2b;
  --c-red-dark:#7f2122;
  --c-navy:#1c3144;
  --c-paper:#faf9f5;
  --c-ink:#2b2b2b;
  --c-mute:#6b6560;
  --c-line:#e6e2d8;
  --f-serif:"Noto Serif JP","Hiragino Mincho ProN",serif;
  --f-sans:"Noto Sans JP","Hiragino Sans","Hiragino Kaku Gothic ProN",Meiryo,sans-serif;
  --f-en:"Cormorant Garamond",serif;
  --wrap:1180px;
  --pad:clamp(20px,4vw,44px);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--f-sans);
  font-weight:400;
  color:var(--c-ink);
  background:var(--c-paper);
  line-height:1.85;
  letter-spacing:.06em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.container{max-width:var(--wrap);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  min-height:52px;padding:0 28px;
  font-family:var(--f-sans);font-weight:500;font-size:15px;letter-spacing:.14em;
  border:1px solid transparent;border-radius:2px;
  transition:.25s ease;cursor:pointer;text-align:center;
}
.btn-primary{background:var(--c-red);color:#fff}
.btn-primary:hover{background:var(--c-red-dark);transform:translateY(-1px);box-shadow:0 8px 24px rgba(158,42,43,.28)}
.btn-outline{background:transparent;color:var(--c-navy);border-color:var(--c-navy)}
.btn-outline:hover{background:var(--c-navy);color:#fff}
.btn-ghost{background:transparent;color:var(--c-ink);border-color:var(--c-line)}
.btn-ghost:hover{background:var(--c-ink);color:#fff;border-color:var(--c-ink)}
.btn-sm{min-height:42px;padding:0 20px;font-size:13px}
.btn-lg{min-height:60px;padding:0 40px;font-size:16px}
.btn-block{width:100%}

/* ===== HEADER ===== */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  background:rgba(250,249,245,.92);backdrop-filter:blur(10px);
  border-bottom:1px solid transparent;transition:.3s ease;
}
.site-header.scrolled{border-bottom-color:var(--c-line);box-shadow:0 4px 24px rgba(0,0,0,.04)}
.header-inner{display:flex;align-items:center;gap:32px;min-height:76px}
.brand{display:flex;flex-direction:column;line-height:1.1;margin-right:auto}
.brand-mark{font-family:var(--f-en);font-style:italic;font-weight:600;color:var(--c-red);font-size:22px;letter-spacing:.02em}
.brand-name{font-family:var(--f-serif);font-weight:500;color:var(--c-navy);font-size:14px;letter-spacing:.14em}
.gnav{display:flex;gap:26px}
.gnav a{font-size:13px;letter-spacing:.14em;color:var(--c-ink);white-space:nowrap;position:relative;padding:6px 0}
.gnav a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--c-red);transform:scaleX(0);transform-origin:right;transition:transform .3s ease}
.gnav a:hover::after{transform:scaleX(1);transform-origin:left}
.gnav-toggle{display:none;background:none;border:0;width:44px;height:44px;padding:10px;cursor:pointer}
.gnav-toggle span{display:block;height:1.5px;background:var(--c-ink);margin:6px 0;transition:.3s}

/* ===== HERO ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;color:#fff;overflow:hidden;padding-top:76px}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-media img{width:100%;height:100%;object-fit:cover}
.hero-scrim{position:absolute;inset:0;background:linear-gradient(120deg,rgba(28,49,68,.72) 0%,rgba(28,49,68,.4) 50%,rgba(0,0,0,.3) 100%)}
.hero-inner{position:relative;z-index:1;padding-top:80px;padding-bottom:120px}
.hero-eyebrow{font-family:var(--f-en);font-style:italic;font-size:18px;letter-spacing:.2em;margin:0 0 22px;opacity:.9}
.hero-eyebrow span{display:inline-block;padding:6px 14px;border:1px solid rgba(255,255,255,.4);border-radius:999px}
.hero-title{
  font-family:var(--f-serif);font-weight:700;font-size:clamp(30px,5.4vw,58px);
  line-height:1.35;letter-spacing:.08em;margin:0 0 24px;
  text-shadow:0 2px 20px rgba(0,0,0,.35);
}
.hero-title-sub{display:block;font-size:.58em;font-weight:500;letter-spacing:.14em;margin-top:14px;opacity:.94}
.hero-lede{font-family:var(--f-serif);font-size:clamp(15px,1.6vw,19px);letter-spacing:.16em;margin:0 0 40px;opacity:.9}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.hero-cta .btn-outline{color:#fff;border-color:rgba(255,255,255,.7)}
.hero-cta .btn-outline:hover{background:#fff;color:var(--c-navy)}
.hero-scroll{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);width:24px;height:44px;border:1px solid rgba(255,255,255,.5);border-radius:12px;display:none}
.hero-scroll span{position:absolute;left:50%;top:8px;transform:translateX(-50%);width:2px;height:8px;background:#fff;border-radius:2px;animation:scrolldot 2s ease-in-out infinite}
@keyframes scrolldot{0%,100%{opacity:0;top:8px}50%{opacity:1;top:24px}}
@media(min-width:900px){.hero-scroll{display:block}}

/* ===== SECTION COMMON ===== */
.section{padding:clamp(70px,10vw,130px) 0;position:relative}
.section-eyebrow{
  font-family:var(--f-en);font-style:italic;font-size:14px;letter-spacing:.24em;
  color:var(--c-red);margin:0 0 18px;
}
.section-eyebrow.center{text-align:center}
.section-eyebrow.on-dark{color:#e8b8b9}
.section-title{
  font-family:var(--f-serif);font-weight:700;color:var(--c-navy);
  font-size:clamp(26px,3.6vw,40px);line-height:1.55;letter-spacing:.1em;
  margin:0 0 36px;
}
.section-title.center{text-align:center}
.section-title.on-dark{color:#fff}

/* ===== JAPAN-1 BAND ===== */
.japan1{
  background:var(--c-navy);color:#fff;padding:56px 0;text-align:center;
  background-image:linear-gradient(180deg, #1c3144 0%, #14232f 100%);
  position:relative;overflow:hidden;
}
.japan1::before{
  content:"";position:absolute;left:50%;top:0;bottom:0;width:1px;
  background:linear-gradient(180deg,transparent 0%,rgba(158,42,43,.6) 50%,transparent 100%);
  transform:translateX(-50%);
}
.japan1-inner{position:relative;z-index:1}
.japan1-mark{
  font-family:var(--f-en);font-style:italic;color:#e8b8b9;
  font-size:16px;letter-spacing:.3em;margin:0 0 10px;
}
.japan1-title{
  font-family:var(--f-serif);font-weight:700;color:#fff;
  font-size:clamp(22px,3vw,32px);letter-spacing:.14em;margin:0 0 18px;line-height:1.6;
}
.japan1-txt{
  font-family:var(--f-serif);font-size:clamp(13px,1.4vw,16px);
  line-height:2;color:rgba(255,255,255,.85);letter-spacing:.12em;margin:0;
}

/* ===== STORY ===== */
.story{background:var(--c-paper)}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,6vw,90px);align-items:center}
.story-media figure{margin:0;position:relative}
.story-media img{width:100%;aspect-ratio:1/1;object-fit:cover;object-position:20% center;border-radius:2px;box-shadow:0 30px 80px rgba(28,49,68,.18)}
.story-media figcaption{
  font-family:var(--f-en);font-style:italic;color:var(--c-mute);
  font-size:14px;letter-spacing:.16em;margin-top:14px;
}
.story-p{font-size:15.5px;line-height:2;margin:0 0 22px;color:#3a3a3a}
.story-signature{font-family:var(--f-serif);font-style:italic;font-size:22px;color:var(--c-red);margin-top:36px;letter-spacing:.1em}
@media(max-width:820px){.story-grid{grid-template-columns:1fr}.story-media{order:-1}}

/* ===== CRAFT ===== */
.craft{background:#fff;border-top:1px solid var(--c-line);border-bottom:1px solid var(--c-line)}
.craft-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;margin-top:40px}
.craft-card{
  background:var(--c-paper);padding:44px 32px 40px;position:relative;
  border:1px solid var(--c-line);border-radius:2px;
  transition:.4s ease;
}
.craft-card:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgba(28,49,68,.12);border-color:var(--c-red)}
.craft-num{
  font-family:var(--f-en);font-style:italic;font-size:64px;font-weight:600;
  color:var(--c-red);opacity:.9;line-height:1;margin-bottom:10px;
}
.craft-media{width:100%;aspect-ratio:4/3;overflow:hidden;margin:16px 0 24px;border-radius:2px;background:#f2ede4}
.craft-media img{width:100%;height:100%;object-fit:cover;transition:.5s ease}
.craft-card:hover .craft-media img{transform:scale(1.05)}
.craft-title{font-family:var(--f-serif);font-weight:700;color:var(--c-navy);font-size:22px;letter-spacing:.14em;margin:0 0 14px;line-height:1.5}
.craft-card p{font-size:14.5px;line-height:1.95;color:#3a3a3a;margin:0}
@media(max-width:820px){.craft-grid{grid-template-columns:1fr}}

/* ===== HEALTH ===== */
.health{color:#fff;position:relative;overflow:hidden}
.health-bg{position:absolute;inset:0;z-index:0}
.health-bg img{width:100%;height:100%;object-fit:cover}
.health-scrim{background:linear-gradient(180deg,rgba(28,49,68,.85),rgba(28,49,68,.9))}
.health-inner{position:relative;z-index:1}
.health-lede{text-align:center;font-family:var(--f-serif);font-size:16px;letter-spacing:.16em;line-height:2;max-width:680px;margin:0 auto 50px;color:rgba(255,255,255,.9)}
.health-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;max-width:960px;margin:0 auto}
.health-card{
  background:rgba(255,255,255,.06);backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,.16);
  padding:32px 22px;text-align:center;border-radius:2px;transition:.3s;
}
.health-card:hover{background:rgba(255,255,255,.1);border-color:var(--c-red)}
.health-key{font-family:var(--f-serif);font-weight:700;font-size:22px;letter-spacing:.14em;color:#fff;margin:0 0 12px}
.health-txt{font-size:13.5px;line-height:1.9;color:rgba(255,255,255,.85);margin:0;letter-spacing:.08em}
.health-note{font-size:11.5px;line-height:1.8;color:rgba(255,255,255,.6);text-align:center;margin:44px auto 0;max-width:640px;letter-spacing:.06em}
@media(max-width:820px){.health-grid{grid-template-columns:repeat(2,1fr)}}

/* ===== PRODUCTS ===== */
.products{background:var(--c-paper)}
.products-lede{text-align:center;font-size:15px;letter-spacing:.14em;color:#4a4a4a;margin:0 auto 50px;max-width:640px;line-height:2}
.products-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.product-card{
  background:#fff;border:1px solid var(--c-line);border-radius:2px;overflow:hidden;
  display:flex;flex-direction:column;position:relative;transition:.4s ease;
}
.product-card:hover{transform:translateY(-4px);box-shadow:0 24px 50px rgba(28,49,68,.13)}
.product-card.featured{border-color:var(--c-red);box-shadow:0 12px 36px rgba(158,42,43,.14)}
.product-ribbon{
  position:absolute;top:14px;left:14px;z-index:2;
  background:var(--c-red);color:#fff;font-family:var(--f-serif);font-weight:500;
  font-size:12px;letter-spacing:.2em;padding:6px 14px;border-radius:2px;
}
.product-media{width:100%;aspect-ratio:4/3;overflow:hidden;background:#efe9df}
.product-media img{width:100%;height:100%;object-fit:cover;transition:.5s ease}
.product-card:hover .product-media img{transform:scale(1.06)}
.product-body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.product-cat{font-family:var(--f-en);font-style:italic;font-size:12px;letter-spacing:.2em;color:var(--c-red);margin:0 0 8px}
.product-name{font-family:var(--f-serif);font-weight:700;color:var(--c-navy);font-size:19px;letter-spacing:.1em;line-height:1.5;margin:0 0 12px}
.product-name-sub{display:block;font-size:12px;font-weight:500;letter-spacing:.14em;color:var(--c-mute);margin-top:4px}
.product-desc{font-size:13.5px;line-height:1.9;color:#4a4a4a;margin:0 0 20px;flex:1}
.products-foot{text-align:center;margin:60px 0 0}
@media(max-width:1080px){.products-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.products-grid{grid-template-columns:1fr}}

/* ===== EVENT ===== */
.event{background:#fff}
.event-inner{max-width:800px;margin:0 auto;text-align:center}
.event-inner .section-eyebrow{text-align:center}
.event-inner .section-title{text-align:center}
.event-lede{font-size:15px;letter-spacing:.12em;line-height:2;color:#3a3a3a;margin:0 0 40px}
.event-cta{display:flex;justify-content:center}

/* ===== VOICE ===== */
.voice{background:var(--c-paper)}
.voice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:40px}
.voice-card{
  background:#fff;border:1px solid var(--c-line);padding:36px 30px;margin:0;
  border-radius:2px;position:relative;
}
.voice-card::before{
  content:"“";position:absolute;top:6px;left:16px;
  font-family:var(--f-serif);color:var(--c-red);font-size:70px;line-height:1;opacity:.28;
}
.voice-card p{font-family:var(--f-serif);font-size:15.5px;line-height:2;color:var(--c-ink);margin:0 0 18px;letter-spacing:.1em}
.voice-card cite{font-family:var(--f-en);font-style:italic;font-size:13px;color:var(--c-mute);letter-spacing:.14em}
.voice-tag{text-align:center;font-family:var(--f-en);font-style:italic;color:var(--c-mute);margin:44px 0 0;letter-spacing:.16em}
@media(max-width:820px){.voice-grid{grid-template-columns:1fr}}

/* ===== CONTACT ===== */
.contact{background:var(--c-navy);color:#fff;text-align:center}
.contact-lede{font-family:var(--f-serif);font-size:16px;letter-spacing:.14em;line-height:2;color:rgba(255,255,255,.88);margin:0 0 40px}
.contact-cta{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}
.contact-cta .btn-outline{color:#fff;border-color:rgba(255,255,255,.7)}
.contact-cta .btn-outline:hover{background:#fff;color:var(--c-navy)}

/* ===== FOOTER ===== */
.site-footer{background:#111820;color:rgba(255,255,255,.78);padding:56px 0 30px}
.footer-inner{display:flex;flex-direction:column;gap:32px;align-items:center;text-align:center}
.footer-mark{font-family:var(--f-en);font-style:italic;color:var(--c-red);font-size:26px;margin:0 0 6px;font-weight:600}
.footer-name{font-family:var(--f-serif);font-weight:500;font-size:14px;letter-spacing:.16em;color:#fff;margin:0 0 6px}
.footer-tag{font-family:var(--f-serif);font-style:italic;font-size:13px;color:rgba(255,255,255,.6);margin:0;letter-spacing:.12em}
.footer-nav{display:flex;gap:22px;flex-wrap:wrap;justify-content:center}
.footer-nav a{font-size:13px;letter-spacing:.14em;color:rgba(255,255,255,.7);transition:.2s}
.footer-nav a:hover{color:var(--c-red)}
.footer-copy{font-family:var(--f-en);font-style:italic;color:rgba(255,255,255,.5);font-size:12.5px;margin:14px 0 0;letter-spacing:.16em}

/* ===== RESPONSIVE ===== */
@media(max-width:960px){
  .gnav{display:none}
  .gnav-toggle{display:block}
  .site-header .btn{display:none}
  .site-header.open .gnav{
    display:flex;flex-direction:column;gap:0;
    position:absolute;top:76px;left:0;right:0;background:#fff;padding:20px;
    border-bottom:1px solid var(--c-line);
  }
  .site-header.open .gnav a{padding:14px 0;border-bottom:1px solid var(--c-line)}
}
