/* =========================================================
   Mai Futagami — Official Site
   Editorial / Fairway Diary
   ========================================================= */

:root{
  --c-bg:#F6F3EC;
  --c-ink:#1A1A1A;
  --c-moss:#417153;
  --c-moss-dark:#2E4F3B;
  --c-moss-deep:#1F3A2B;
  --c-blush:#E8C9B8;
  --c-gold:#B8894C;
  --c-line:rgba(26,26,26,.18);
  --c-line-on-dark:rgba(246,243,236,.22);

  --f-brand:"Luckiest Guy","M PLUS Rounded 1c", system-ui, sans-serif;
  --f-display:"Outfit","M PLUS Rounded 1c", system-ui, sans-serif;
  --f-ja-display:"M PLUS Rounded 1c", system-ui, sans-serif;
  --f-ja:"Zen Kaku Gothic New", system-ui, sans-serif;
  --f-en:"Plus Jakarta Sans", system-ui, sans-serif;

  --px:clamp(24px, 6vw, 96px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--c-bg);
  color:var(--c-ink);
  font-family:var(--f-ja);
  font-weight:400;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;width:100%;height:100%;object-fit:cover}
a{color:inherit;text-decoration:none}

/* ---------- Nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--px);
  background:rgba(246,243,236,.82);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid var(--c-line);
}
.logo{display:flex;flex-direction:column;line-height:1}
.logo-en-main{font-family:var(--f-brand);font-weight:400;font-size:26px;letter-spacing:.01em;color:var(--c-ink);line-height:1}
.logo-sub{font-family:var(--f-en);font-weight:500;font-size:11px;letter-spacing:.08em;margin-top:6px;color:#666}
.nav-links{display:flex;gap:28px;font-family:var(--f-en);font-weight:500;font-size:13px;letter-spacing:.08em;text-transform:uppercase}
.nav-links a{position:relative;padding:6px 0}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:var(--c-ink);transition:right .4s ease}
.nav-links a:hover::after{right:0}
.nav-cta{
  font-family:var(--f-display);font-weight:600;font-size:14px;
  border:1px solid var(--c-ink);padding:10px 18px;border-radius:999px;
  transition:background .3s,color .3s;
}
.nav-cta:hover{background:var(--c-ink);color:var(--c-bg)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:32px;height:24px;position:relative}
.nav-toggle span{position:absolute;left:0;right:0;height:1px;background:var(--c-ink);transition:transform .3s,top .3s}
.nav-toggle span:first-child{top:8px}
.nav-toggle span:last-child{top:16px}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  display:grid;grid-template-columns:48% 52%;
  height:100vh;min-height:680px;max-height:980px;
  padding-top:80px;
  background:var(--c-bg);
}
.hero-image{position:relative;background:var(--c-moss-deep);overflow:hidden;min-height:0}
.hero-image img{
  position:absolute;inset:0;
  width:100%;height:100%;object-fit:cover;
  object-position:center 20%;
}
.hero-image::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(31,58,43,0) 55%,rgba(31,58,43,.55) 100%);
  pointer-events:none;
}
.hero-image-placeholder{
  position:absolute;inset:0;display:none;flex-direction:column;align-items:center;justify-content:center;
  color:#eee;letter-spacing:.3em;font-family:var(--f-en);font-size:12px;
  background:linear-gradient(135deg,var(--c-moss-dark) 0%,var(--c-moss-deep) 100%);
  pointer-events:none;
  z-index:1;
}
.hero-image-placeholder small{margin-top:10px;opacity:.55;font-size:10px;letter-spacing:.15em}
.hero-image.no-img .hero-image-placeholder,
.profile-img.no-img .hero-image-placeholder,
.ig-tile.no-img::after,
.yt-thumb.no-img::after{display:flex}

/* placeholder for IG tiles when image missing */
.ig-tile{position:relative;background:var(--c-moss-dark);overflow:hidden}
.ig-tile.no-img::after{
  content:"IG";position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  color:#eee;font-family:var(--f-display);font-size:42px;opacity:.35;
}
.yt-thumb.no-img::after{
  content:"VIDEO";position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  color:#eee;font-family:var(--f-en);letter-spacing:.3em;font-size:12px;opacity:.45;
}

.hero-text{
  position:relative;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:0 var(--px) clamp(48px,8vw,120px) clamp(40px,6vw,96px);
}
.hero-kicker{
  font-family:var(--f-en);font-size:11px;letter-spacing:.4em;text-transform:uppercase;
  color:#666;margin-bottom:24px;
}
.hero-name{
  display:flex;flex-direction:column;gap:18px;
  margin-bottom:28px;
}
.hero-name-en-main{
  font-family:var(--f-brand);font-weight:400;
  font-size:clamp(54px,8vw,124px);
  line-height:1.02;letter-spacing:.01em;color:var(--c-ink);
  white-space:nowrap;
}
.hero-name-tag{
  font-family:var(--f-display);font-weight:500;
  font-size:clamp(16px,1.4vw,22px);letter-spacing:.02em;
  color:var(--c-moss);line-height:1;padding-left:4px;
}
.hero-ja{
  font-family:var(--f-ja-display);font-weight:700;font-size:clamp(15px,1.1vw,20px);
  line-height:2;letter-spacing:.18em;margin-bottom:36px;
}
.hero-caption{
  font-family:var(--f-en);font-size:11px;letter-spacing:.25em;
  color:#888;border-top:1px solid var(--c-line);padding-top:14px;max-width:420px;
}
.hero-scroll{
  position:absolute;right:var(--px);bottom:40px;
  display:flex;align-items:center;gap:14px;
  font-family:var(--f-en);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:#666;
}
.hero-scroll .line{width:64px;height:1px;background:var(--c-ink)}

/* ---------- Section base ---------- */
.section{padding:clamp(96px,12vw,180px) var(--px)}
.section-head{
  display:flex;align-items:baseline;gap:32px;flex-wrap:wrap;
  margin-bottom:clamp(48px,6vw,88px);
  padding-bottom:24px;border-bottom:1px solid var(--c-line);
}

/* Brand logo marks (Instagram / YouTube section markers) */
.section-head--brand{align-items:center}
.brand-logo{
  display:inline-flex;align-items:center;justify-content:center;
  flex-shrink:0;
  line-height:0;
}
.brand-logo svg{display:block;width:auto}
.brand-ig svg{width:56px;height:56px;filter:drop-shadow(0 6px 18px rgba(0,0,0,.25))}
.brand-yt svg{width:72px;height:auto;filter:drop-shadow(0 6px 18px rgba(255,0,0,.25))}
.section-head .num{
  font-family:var(--f-en);font-size:12px;letter-spacing:.3em;color:#888;
}
.section-title{
  font-family:var(--f-display);font-weight:700;font-size:clamp(40px,6.2vw,82px);
  line-height:1.02;letter-spacing:-.015em;
}
.section-title .italic,
.section-title em{font-weight:700;color:var(--c-moss)}
.section-head .section-sub{
  margin-left:auto;font-family:var(--f-en);font-weight:500;font-size:13px;letter-spacing:.12em;color:#666;text-transform:uppercase;
}

/* ---------- Profile ---------- */
.profile-grid{display:grid;grid-template-columns:minmax(280px,40%) 1fr;gap:clamp(40px,6vw,100px);align-items:start}
.profile-img{position:relative;aspect-ratio:3/4;background:var(--c-moss-dark);overflow:hidden}
.profile-img img{width:100%;height:100%;object-fit:cover;object-position:center 25%}
.profile-body .lead{font-size:17px;line-height:2;margin-bottom:40px;max-width:48ch}
.profile-body .lead em{font-family:var(--f-display);font-style:normal;font-weight:700;font-size:19px;color:var(--c-moss-dark)}
.profile-body .lead small{font-family:var(--f-en);font-size:12px;letter-spacing:.15em;color:#888}

.spec{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  border-top:1px solid var(--c-line);
  margin-bottom:56px;
}
.spec > div{
  display:flex;gap:20px;padding:16px 0;
  border-bottom:1px solid var(--c-line);
}
.spec > div:nth-child(odd){padding-right:20px}
.spec > div:nth-child(even){padding-left:20px;border-left:1px solid var(--c-line)}
.spec dt{
  font-family:var(--f-en);font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  color:#999;flex:0 0 80px;padding-top:3px;
}
.spec dd{font-family:var(--f-ja);font-size:14px;letter-spacing:.05em;color:var(--c-ink)}

.pull{
  font-family:var(--f-ja-display);font-weight:700;
  font-size:clamp(22px,2.4vw,34px);line-height:1.55;color:var(--c-moss-dark);
  padding-left:36px;border-left:2px solid var(--c-moss);
  position:relative;letter-spacing:.02em;
}
.pull .mark{
  position:absolute;left:6px;top:-10px;
  font-size:56px;color:var(--c-moss);line-height:1;
}

/* ---------- Instagram ---------- */
.instagram{
  background:var(--c-moss-deep);color:var(--c-bg);
  margin:0 calc(var(--px) * -1);padding-left:var(--px);padding-right:var(--px);
  position:relative;
}
.instagram::before{
  content:"";position:absolute;top:0;left:var(--px);right:var(--px);
  height:1px;background:var(--c-line-on-dark);
}
.instagram .section-head{border-bottom-color:var(--c-line-on-dark)}
.instagram .section-head .num,
.instagram .section-head .section-sub{color:#b6c5bd}
.instagram .section-title a{
  border-bottom:1px solid rgba(255,255,255,.4);padding-bottom:4px;
  transition:border-color .3s;
}
.instagram .section-title a:hover{border-color:var(--c-gold)}

.ig-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  grid-auto-rows:minmax(180px,24vw);
  gap:10px;
}
.ig-tile{display:block;aspect-ratio:auto;transition:transform .5s ease}
.ig-tile img{
  width:100%;height:100%;object-fit:cover;
  object-position:center 30%;
  transition:transform .8s ease,filter .5s ease;
}
.ig-tile.t-wide img,
.ig-tile.t-wide2 img,
.ig-tile.t7 img{object-position:center 38%}
.ig-tile:hover img{transform:scale(1.04);filter:brightness(.85)}
.ig-tile .tile-num{
  position:absolute;left:14px;bottom:12px;
  font-family:var(--f-display);font-size:14px;color:#fff;
  opacity:0;transform:translateY(6px);transition:opacity .4s,transform .4s;
  letter-spacing:.1em;
}
.ig-tile:hover .tile-num{opacity:1;transform:translateY(0)}

/* IG CTA banner */
.ig-cta{overflow:hidden}
.ig-cta .ig-cta-inner{
  display:flex;align-items:center;gap:28px;
  padding:28px clamp(28px,4vw,56px);
  width:100%;height:100%;min-height:140px;
  transition:background .4s ease;
}
.ig-cta:hover .ig-cta-inner{background:var(--c-moss-dark)}
.ig-cta .ig-cta-icon svg{width:56px;height:56px;display:block;filter:drop-shadow(0 4px 14px rgba(0,0,0,.25))}
.ig-cta-text{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}
.ig-cta-kicker{font-family:var(--f-en);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:#c9d8d0}
.ig-cta-handle{font-family:var(--f-display);font-weight:700;font-size:clamp(24px,2.8vw,38px);color:var(--c-bg);line-height:1.1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.01em}
.ig-cta-meta{font-family:var(--f-en);font-size:12px;letter-spacing:.15em;color:#b6c5bd;margin-top:4px}
.ig-cta-arrow{
  font-family:var(--f-display);font-size:32px;color:var(--c-blush);
  transition:transform .4s ease;flex-shrink:0;
}
.ig-cta:hover .ig-cta-arrow{transform:translateX(8px)}
.ig-cta:hover img{transform:none;filter:none}

/* 2-1(wide)-3-1(wide)-2 asymmetric layout on desktop */
.ig-tile.t1{grid-column:span 2;grid-row:span 1}
.ig-tile.t2{grid-column:span 2;grid-row:span 2}
.ig-tile.t-wide{grid-column:span 2;grid-row:span 2}
.ig-tile.t3{grid-column:span 2;grid-row:span 1}
.ig-tile.t4{grid-column:span 2;grid-row:span 1}
.ig-tile.t5{grid-column:span 2;grid-row:span 1}
.ig-tile.t-wide2{grid-column:span 4;grid-row:span 2}
.ig-tile.t6{grid-column:span 2;grid-row:span 2}
.ig-tile.ig-cta{grid-column:span 6;grid-row:span 1;background:var(--c-moss);border:1px solid rgba(246,243,236,.12)}

.ig-footer{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:48px;padding-top:28px;border-top:1px solid var(--c-line-on-dark);
  flex-wrap:wrap;gap:24px;
}
.ig-follow{font-family:var(--f-en);font-size:12px;letter-spacing:.25em;color:#c9d8d0}

/* ---------- Divider quote ---------- */
.divider{
  padding:clamp(96px,12vw,160px) var(--px);
  text-align:center;
  background:var(--c-bg);
  position:relative;
}
.divider::before{
  content:"";position:absolute;left:50%;top:clamp(48px,7vw,96px);
  width:1px;height:clamp(40px,5vw,64px);background:var(--c-moss);
}
.divider p{
  font-family:var(--f-display);font-weight:500;font-size:clamp(22px,2.6vw,36px);line-height:1.55;color:var(--c-moss);
}
.divider p span{font-weight:400}
.divider p em{display:block;margin-top:10px;color:var(--c-ink);font-style:normal;font-weight:700}

/* ---------- YouTube ---------- */
.yt-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:32px;
}
.yt-card{display:block}
.yt-thumb{
  position:relative;aspect-ratio:16/10;background:var(--c-moss-dark);overflow:hidden;
  margin-bottom:18px;
}
.yt-thumb img{
  width:100%;height:100%;object-fit:cover;
  object-position:center 20%;
  transition:transform .8s;
}
.yt-card:hover .yt-thumb img{transform:scale(1.04)}
.yt-thumb .play{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:56px;height:56px;border-radius:50%;
  background:rgba(246,243,236,.9);color:var(--c-ink);
  display:flex;align-items:center;justify-content:center;
  font-size:16px;padding-left:3px;
  transition:transform .4s,background .4s;
}
.yt-card:hover .play{background:var(--c-moss);color:#fff;transform:translate(-50%,-50%) scale(1.08)}
.yt-title{font-family:var(--f-ja);font-weight:500;font-size:18px;margin-bottom:4px}
.yt-meta{font-family:var(--f-en);font-size:11px;letter-spacing:.2em;color:#888;text-transform:uppercase}
.yt-cta{margin-top:56px;text-align:center}

/* ---------- Sponsors ---------- */
.sponsors{background:var(--c-bg)}
.sponsor-list{
  list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:24px;
}
.sp-card{
  position:relative;overflow:hidden;
  background:#fff;border:1px solid var(--c-line);border-radius:20px;
  padding:72px 40px 40px;min-height:280px;
  display:flex;flex-direction:column;justify-content:flex-end;
  transition:border-color .3s,box-shadow .3s,transform .4s;
}
.sp-card:hover{border-color:var(--c-moss);box-shadow:0 20px 60px -30px rgba(31,58,43,.3);transform:translateY(-3px)}

/* Watermark layer */
.sp-watermark{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  pointer-events:none;user-select:none;
  opacity:.08;
}
.sp-wm-main{
  font-family:var(--f-display);font-weight:900;
  font-size:clamp(120px,16vw,220px);line-height:.85;color:var(--c-ink);
  letter-spacing:-.04em;
}
.sp-wm-main em{font-style:normal;color:var(--c-moss);opacity:.9}
.sp-wm-sub{
  font-family:var(--f-en);font-weight:600;font-size:12px;letter-spacing:.4em;
  color:var(--c-ink);text-transform:uppercase;margin-top:8px;
}
.sp-wm-logo{
  width:min(86%,480px);height:auto;
  filter:grayscale(.2);
}

/* Foreground */
.sp-body{position:relative;z-index:1;text-align:left}
.sp-name{
  font-family:var(--f-display);font-weight:800;
  font-size:clamp(22px,2.2vw,30px);color:var(--c-ink);margin-bottom:10px;letter-spacing:-.01em;
  display:flex;align-items:center;gap:14px;
}
.sp-logo-fg{
  width:auto;height:clamp(56px,6vw,88px);display:block;
  margin-left:-18px;transform:scale(1.5);transform-origin:left center;
}
.sp-cgrit .sp-name{margin-bottom:22px;overflow:visible}
.sp-role{
  font-family:var(--f-en);font-weight:600;font-size:11px;letter-spacing:.28em;
  color:var(--c-moss);text-transform:uppercase;
}

/* Specific watermark placements */
.sp-sy32 .sp-watermark{justify-content:center}
.sp-cgrit .sp-watermark{justify-content:center}

/* ---------- Shop ---------- */
.shop{
  background:var(--c-bg);
  padding:clamp(96px,12vw,160px) var(--px) 0;
  position:relative;
  overflow:hidden;
}
.shop-inner{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,96px);
  align-items:center;
  padding-bottom:clamp(72px,10vw,120px);
  border-bottom:1px solid var(--c-line);
}
.shop-text{max-width:560px}
.shop-num{font-family:var(--f-en);font-size:12px;letter-spacing:.3em;color:#888;display:block;margin-bottom:18px}
.shop-kicker{font-family:var(--f-en);font-size:12px;letter-spacing:.3em;color:var(--c-moss);text-transform:uppercase;margin-bottom:16px}
.shop-title{
  font-family:var(--f-display);font-weight:800;
  font-size:clamp(52px,7vw,96px);line-height:.95;color:var(--c-ink);
  margin-bottom:28px;letter-spacing:-.02em;
}
.shop-title .italic{color:var(--c-moss);font-style:normal}
.shop-title-sub{
  display:inline-block;font-weight:700;
  font-size:clamp(34px,4.4vw,64px);
  margin-top:8px;
}
.shop-lead{
  font-family:var(--f-ja);font-size:16px;line-height:2;color:#333;
  margin-bottom:36px;max-width:42ch;
}
.shop-note{font-family:var(--f-en);font-size:11px;letter-spacing:.25em;color:#999;margin-top:18px}

.btn-line-green{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--f-display);font-weight:600;font-size:17px;
  color:var(--c-ink);padding:14px 4px;
  border-top:1px solid var(--c-moss);border-bottom:1px solid var(--c-moss);
  width:fit-content;transition:gap .3s,color .3s;
  letter-spacing:.02em;
}
.btn-line-green:hover{gap:22px;color:var(--c-moss)}

.shop-marquee{
  position:relative;overflow:hidden;
  padding:16px 0;
  mask-image:linear-gradient(90deg,transparent 0,#000 10%,#000 90%,transparent 100%);
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 10%,#000 90%,transparent 100%);
}
.shop-marquee-track{
  display:flex;gap:24px;
  animation:marquee 28s linear infinite;
  white-space:nowrap;
}
.shop-marquee span{
  font-family:var(--f-display);font-weight:600;
  font-size:clamp(38px,4.4vw,62px);letter-spacing:-.01em;
  color:var(--c-moss);
}
.shop-marquee span:nth-child(even){color:var(--c-moss-dark);opacity:.5}
@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ---------- Fan Club ---------- */
.fanclub{
  display:grid;grid-template-columns:38% 62%;gap:0;
  padding:0;
  min-height:72vh;
  position:relative;
}
.fc-empty{
  background:var(--c-bg);
  display:flex;align-items:center;justify-content:center;
  padding:clamp(40px,6vw,80px);
}
.fc-mascot{
  max-width:min(80%,360px);aspect-ratio:1/1;
  background:var(--c-moss);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  box-shadow:0 20px 60px -20px rgba(31,58,43,.45);
}
.fc-mascot img{width:88%;height:auto;display:block}
.fc-block{
  background:var(--c-moss);
  color:var(--c-bg);
  padding:clamp(80px,10vw,140px) clamp(40px,6vw,100px);
  display:flex;flex-direction:column;justify-content:center;
  position:relative;
}
.fc-num{font-family:var(--f-en);font-size:11px;letter-spacing:.35em;color:#c9d8d0;margin-bottom:16px}
.fc-kicker{font-family:var(--f-en);font-size:12px;letter-spacing:.25em;color:#c9d8d0;margin-bottom:8px;text-transform:uppercase}
.fc-title{
  font-family:var(--f-ja-display);font-weight:800;
  font-size:clamp(38px,4.5vw,64px);line-height:1.1;color:var(--c-bg);
  margin-bottom:32px;letter-spacing:0;
}
.fc-title em{
  font-family:var(--f-brand);font-style:normal;font-weight:400;
  font-size:clamp(48px,6.6vw,104px);line-height:1.02;
  display:block;margin-bottom:14px;color:var(--c-bg);letter-spacing:.01em;
}
.fc-title-sub{display:block;font-size:clamp(22px,2.4vw,32px);color:var(--c-blush);letter-spacing:0;font-weight:700;font-family:var(--f-ja-display)}
.fc-lead{
  font-family:var(--f-ja-display);font-weight:700;font-size:clamp(22px,2.4vw,32px);line-height:1.55;
  color:var(--c-blush);margin-bottom:24px;letter-spacing:0;
}
.fc-desc{font-family:var(--f-ja);font-size:14px;line-height:2;color:#d8e3dc;margin-bottom:48px;max-width:34ch}

/* buttons */
.btn-line{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--f-display);font-weight:600;font-size:15px;color:currentColor;
  padding-bottom:6px;border-bottom:1px solid currentColor;
  transition:gap .3s,color .3s;letter-spacing:.01em;
}
.btn-line:hover{gap:18px;color:var(--c-gold)}
.btn-gold{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--f-display);font-weight:600;font-size:16px;
  color:var(--c-bg);padding:14px 4px;
  border-top:1px solid var(--c-blush);border-bottom:1px solid var(--c-blush);
  width:fit-content;transition:gap .3s,color .3s,border-color .3s;
  letter-spacing:.01em;
}
.btn-gold:hover{gap:20px;color:var(--c-blush)}

/* ---------- Footer ---------- */
.footer{
  background:var(--c-ink);color:var(--c-bg);
  padding:clamp(72px,8vw,120px) var(--px) 32px;
}
.foot-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:48px;
  padding-bottom:64px;border-bottom:1px solid rgba(255,255,255,.18);
}
.foot-col .foot-label{
  font-family:var(--f-en);font-size:10px;letter-spacing:.35em;text-transform:uppercase;
  color:#888;margin-bottom:20px;
}
.foot-logo-en-main{font-family:var(--f-brand);font-weight:400;font-size:36px;letter-spacing:.02em;line-height:1;margin-bottom:10px;color:var(--c-bg)}
.foot-logo-sub{font-family:var(--f-en);font-weight:500;font-size:13px;letter-spacing:.08em;color:#aaa;margin-bottom:20px}
.foot-tag{font-family:var(--f-en);font-size:12px;letter-spacing:.1em;color:#999;line-height:1.8;max-width:28ch}

.foot-social{list-style:none;display:flex;flex-direction:column;gap:12px}
.foot-social a{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--f-display);font-weight:600;font-size:16px;
  padding-bottom:3px;border-bottom:1px solid transparent;
  transition:border-color .3s,color .3s,gap .3s;
}
.foot-social a:hover{border-bottom-color:var(--c-blush);color:var(--c-blush);gap:14px}
.sns-ico{
  width:20px;height:20px;flex-shrink:0;
  color:#9aa59e;transition:color .3s;
}
.foot-social a:hover .sns-ico{color:var(--c-blush)}
.foot-link{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--f-display);font-weight:600;font-size:16px;
  border-bottom:1px solid rgba(255,255,255,.4);padding-bottom:3px;
  transition:border-color .3s,color .3s;
}
.foot-link:hover{border-color:var(--c-blush);color:var(--c-blush)}
.foot-text{font-family:var(--f-ja);font-size:13px;line-height:2;color:#bbb;margin-bottom:16px}
.foot-text strong{color:#eee;font-weight:500}

.foot-bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:28px;
  font-family:var(--f-en);font-size:11px;letter-spacing:.2em;color:#777;
  flex-wrap:wrap;gap:12px;
}

/* ---------- Responsive ---------- */
@media (max-width: 960px){
  .nav-links{display:none}
  .nav-cta{display:none}
  .nav-toggle{display:block}
  .nav.open .nav-links{
    display:flex;flex-direction:column;gap:18px;
    position:absolute;top:100%;left:0;right:0;
    background:var(--c-bg);padding:28px var(--px);border-bottom:1px solid var(--c-line);
  }

  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-image{aspect-ratio:4/5}
  .hero-text{padding:48px var(--px) 96px}
  .hero-name{font-size:clamp(80px,28vw,200px)}
  .hero-scroll{display:none}

  .profile-grid{grid-template-columns:1fr}
  .profile-img{aspect-ratio:4/5;max-width:420px}

  .ig-grid{grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(140px,32vw)}
  .ig-tile.t1,.ig-tile.t3,.ig-tile.t4,.ig-tile.t5{grid-column:span 2;grid-row:span 1}
  .ig-tile.t2,.ig-tile.t6{grid-column:span 2;grid-row:span 2}
  .ig-tile.t-wide,.ig-tile.t-wide2{grid-column:span 4;grid-row:span 2}
  .ig-tile.ig-cta{grid-column:span 4;grid-row:span 1}
  .ig-cta .ig-cta-inner{flex-direction:column;align-items:flex-start;gap:16px;padding:24px}
  .ig-cta-handle{font-size:24px;white-space:normal;word-break:break-all}
  .ig-cta-arrow{align-self:flex-end;margin-top:-28px}

  .yt-grid{grid-template-columns:1fr;gap:40px}

  .sponsor-list{grid-template-columns:1fr;gap:18px}
  .sp-card{min-height:220px;padding:56px 28px 28px}
  .sp-wm-main{font-size:clamp(96px,22vw,160px)}
  .sp-logo-fg{height:clamp(30px,6vw,42px)}

  .shop-inner{grid-template-columns:1fr;gap:40px}
  .shop-marquee{margin:0 calc(var(--px) * -1)}
  .shop-marquee span{font-size:clamp(38px,10vw,56px)}

  .fanclub{grid-template-columns:1fr}
  .fc-empty{padding:48px var(--px) 0;background:var(--c-moss)}
  .fc-mascot{background:var(--c-moss-deep);max-width:240px}
  .fc-block{padding-top:24px}

  .spec{grid-template-columns:1fr}
  .spec > div{padding:14px 0!important;border-left:0!important}

  .foot-grid{grid-template-columns:1fr 1fr;gap:40px}
  .foot-brand{grid-column:span 2}
}

@media (max-width: 560px){
  .section-head{flex-direction:column;gap:12px;align-items:flex-start}
  .section-head .section-sub{margin-left:0}
  .ig-grid{grid-template-columns:repeat(2,1fr)}
  .ig-tile.t1,.ig-tile.t2,.ig-tile.t3,.ig-tile.t4,.ig-tile.t5,.ig-tile.t6,
  .ig-tile.t-wide,.ig-tile.t-wide2{grid-column:span 2;grid-row:span 1}
  .ig-tile.ig-cta{grid-column:span 2;grid-row:span 1}
  .foot-grid{grid-template-columns:1fr}
  .foot-brand{grid-column:span 1}
  .foot-bottom{flex-direction:column;align-items:flex-start}
}
