*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}

:root{
  /* フォント設定 */
  --fd:'Holtwood One SC',serif;                                                         /* 英字ディスプレイ（セクション見出し） */
  --fl:'Futura PT','Futura','Century Gothic','Trebuchet MS',sans-serif;                 /* 英字UIフォント */
  --fs:'dnp-shuei-gothic-gin-std','Noto Sans JP','Hiragino Sans',sans-serif;            /* 日本語本文ゴシック */
  --fse:'Noto Serif JP','Hiragino Mincho ProN',serif;                                   /* 日本語明朝 */
  --black:#000;
  --white:#fff;
  --dark:#111;
  --cream:#F5F3EE;
  --gray:#373BC4;
  --border:0.5px solid #ddd;
  --border-dark:0.5px solid #333;
  --blue:#373BC4;
  --dark-green:#1A3D1A;
  --lime:#C4F136;
}

html{scroll-behavior:smooth;}
body{font-family:var(--fs);background:var(--white);color:var(--blue);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased;}
.site-wrap {
  width:100%;
  max-width:1100px;
  transform-origin:top left;
  overflow-x:hidden;
}

img{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;}
button{cursor:pointer;font-family:inherit;}

/* ── HEADER ── */
.site-header {
  position: relative;
  z-index: 100;
  background: transparent;
}

/* 通常時（ロゴのみ・中央） */
.header-top-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 24px;
  height: 240px;
}

.header-logo img {
  width: 1162px;
  height: auto;
  display: block;
}

/* スクロール後（固定・左ロゴ・右ハンバーガー） */
.header-sticky {
  display: none;
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 200;
  background: var(--white);
  border-bottom: var(--border);
  box-shadow: 0 2px 8px rgba(0,0,0,.08);
}
.header-sticky.show { display: block; }
.header-sticky-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 24px;
  height: 72px;
}

.header-logo-small img {
  width: 200px;
  height: auto;
  display: block;
}
.header-ham {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 6px;
  width: 24px;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
}
.header-ham span {
  display: block;
  height: 1px;
  background: var(--black);
  transition: all .3s;
}


/* MAIN NAV（通常時ナビ） */
.main-nav{border-bottom:var(--border);overflow-x:auto;scrollbar-width:none;background:var(--white);}
.main-nav::-webkit-scrollbar{display:none;}
.main-nav-inner{display:flex;white-space:nowrap;justify-content:center;}
.main-nav-item{font-family:var(--fl);font-size:12px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;padding:12px 20px;border:none;border-right:var(--border);background:none;color:var(--blue);flex-shrink:0;transition:background .15s,color .15s;display:block;}
.main-nav-item:first-child{border-left:var(--border);}
.main-nav-item:hover,.main-nav-item.active{background:var(--black);color:var(--white);}


/* ── DRAWER ── */
.nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;}
.nav-overlay.open{display:block;}
.nav-drawer{position:fixed;top:0;right:-300px;width:280px;height:100vh;background:var(--white);z-index:201;transition:right .3s ease;padding:24px;overflow-y:auto;}
.nav-drawer.open{right:0;}
.nav-drawer-close{display:flex;justify-content:flex-end;margin-bottom:24px;background:none;border:none;font-size:20px;width:100%;cursor:pointer;}
.nav-drawer ul{list-style:none;}
.nav-drawer ul li{border-bottom:var(--border);}
.nav-drawer ul li a{display:block;padding:14px 0;font-family:var(--fd);font-size:16px;font-weight:400;letter-spacing:.06em;text-transform:uppercase;transition:color .15s;}
.nav-drawer ul li a:hover{color:var(--gray);}

/* ── HERO ── */
.hero{position:relative;overflow:hidden; height: 800px; /* 追加 */}
.hero-slides{display:flex;transition:transform .6s cubic-bezier(.4,0,.2,1);}
.hero-slide{min-width:100%;position:relative;overflow:hidden;background-color: #aaa;}
.hero-slide img{
  width: 80%;
  height: 600px;
  margin: auto;
  object-fit: cover;
  display: block;
  transition: transform 8s ease;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
}
.hero-slide.active img {
  transform: translateX(-50%) translateY(-50%) scale(1.06);
}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 30%,rgba(0,0,0,.7));}
.hero-caption{position:absolute;bottom:0;left:0;right:0;padding:0 32px 36px;color:var(--white);}
.hero-label{font-family:var(--fl);font-weight: 700;font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:10px;display:block;}
.hero-title{font-family:var(--fs);font-size:22px;font-weight:700;line-height:1.55;}
.hero-nav{position:absolute;bottom:32px;left:32px;display:flex;align-items:center;gap:12px;}
.hero-arrow{width:32px;height:32px;border-radius:50%;border:1px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.2);transition:background .2s;}
.hero-arrow:hover{background:rgba(0,0,0,.5);}
.hero-arrow svg{width:12px;height:12px;stroke:var(--white);fill:none;stroke-width:2;}
.hero-count{font-family:var(--fl);font-size:10px;letter-spacing:.1em;color:rgba(255,255,255,.8);}

/* ── HERO ── */
.hero-caption {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  width: 100%;
  padding: 0 32px;
}

.hero-label {
  font-family: var(--fl);
  font-size: 40px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(255,255,255,.7);
  margin-bottom: 16px;
  display: block;
}

.hero-title {
  font-family: var(--fse);
  font-size: clamp(28px, 8vw, 104px);
  font-weight: 700;
  line-height: 1.4;
}


/* ── ヒーロータイトルアニメーション ── */
.hero-title span {
  display: inline-block;
  opacity: 0;
  transform: translateY(8px);
  animation: charReveal 0.6s ease forwards;
}

@keyframes charReveal {
  0%   { opacity: 0; transform: translateY(8px); }
  100% { opacity: 1; transform: translateY(0); }
}


/* ── HERO 進行バー ── */
.hero-progress {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: rgba(255,255,255,.3);
}
.hero-progress-bar {
  height: 100%;
  width: 0%;
  background: var(--white);
  animation: progressFill 5s linear forwards;
}
@keyframes progressFill {
  0%   { width: 0%; }
  100% { width: 100%; }
}

/* ── SECTION TITLE ── */
.sec-title{text-align:center;padding:80px 0 48px;background:var(--white);}
.sec-title.cream{background:var(--cream);}
.sec-title.dark{background:var(--dark);color:var(--white);}
.sec-title-en{font-family:var(--fd);font-size:clamp(36px,10vw,80px);font-weight:400;letter-spacing:-.01em;text-transform:uppercase;line-height:1;display:block;}
.sec-title-ja{font-family:var(--fs);font-weight:700;14px;color:var(--blue);margin-top:6px;display:block;}
.sec-title.dark .sec-title-ja{color:#aaa;}
.sec-divider{height:0.5px;background:#ddd;margin:16px 32px 0;}
.sec-title.dark .sec-divider{background:#333;}

/* ── 画像の角丸 ── */
.overlay-card,
.interview-img,
.wn-thumb,
.culture-thumb,
.articles-img,
.zine-cover,
.zine-back-img,
.single-hero {
  border-radius: 8px;
}

/* WHAT'S NEW 2列グリッド */
.wn-inner {
  display: grid;
  grid-template-columns: 1fr 260px;
  gap: 32px;
  max-width: 1100px;
  margin: 0 auto;
}
.wn-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}
.wn-item {
  display: flex;
  gap: 12px;
  padding: 24px 16px;
  align-items: flex-start;
}

.wn-section {
  padding: 48px 48px 64px; /* 32px → 48px */
}

.wn-item:hover .wn-item-title{text-decoration:underline;}
.wn-thumb{width:108px;height:108px;flex-shrink:0;overflow:hidden;position:relative;background:#ddd;display:block;}
.wn-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s;}
.wn-item:hover .wn-thumb img{transform:scale(1.05);}
.wn-cat-badge{position:absolute;bottom:5px;left:5px;font-family:var(--fl);font-size:7.5px;letter-spacing:.1em;text-transform:uppercase;background:rgba(255,255,255,.92);padding:2px 6px;color:var(--blue);}
.wn-body{flex:1;}
.wn-item-title{font-family:var(--fs);font-size:14px;line-height:1.65;margin-bottom:6px;display:block;}
.wn-meta{display:flex;align-items:center;gap:6px;}
.wn-date{font-family:var(--fl);font-size:9px;letter-spacing:.06em;color:var(--gray);}
.wn-dot{width:5px;height:5px;border-radius:50%;background:var(--gray);}
.wn-cat{font-family:var(--fl);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--gray);}
.wn-sidebar-inner{background:var(--white);padding:20px;}
.wn-sidebar-badge{display:inline-block;background:var(--black);color:var(--white);font-family:var(--fl);font-size:8px;letter-spacing:.12em;padding:3px 8px;margin-bottom:12px;}
.wn-sidebar-cover{width:100%;aspect-ratio:1/1;background:#1a1a1a;overflow:hidden;margin-bottom:14px;display:block;}
.wn-sidebar-cover img{width:100%;height:100%;object-fit:cover;}
.wn-sidebar-no{font-family:var(--fl);font-size:10px;letter-spacing:.08em;color:var(--gray);margin-bottom:4px;}
.wn-sidebar-title{font-family:var(--fs);font-size:17px;font-weight:700;line-height:1.4;margin-bottom:4px;}
.wn-sidebar-date{font-family:var(--fl);font-size:10px;color:var(--gray);margin-bottom:14px;}
.wn-sidebar-btn{display:block;text-align:center;font-family:var(--fl);font-size:10px;letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--black);border-radius:24px;padding:8px;background:none;width:100%;transition:all .15s;}
.wn-sidebar-btn:hover{background:var(--black);color:var(--white);}

/* ── OVERLAY CARD（正方形 1:1） ── */
.overlay-section{padding:0 48px 64px;background:var(--white);}
.overlay-section.cream{background:var(--cream);}
.overlay-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1100px;margin:0 auto;}
.overlay-card{position:relative;overflow:hidden;aspect-ratio:1/1;background:#222;display:block;}
.overlay-card img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.overlay-card:hover img{transform:scale(1.05);}
.overlay-card-ph{width:100%;height:100%;background:#222;}
.overlay-grad{display:none;}
.overlay-body{position:absolute;bottom:12px;left:12px;display:flex;flex-direction:column;align-items:flex-start;gap:0;pointer-events:none;}
.overlay-cat{display:inline-flex;align-self:flex-start;font-family:var(--fl);font-size:8px;letter-spacing:.14em;text-transform:uppercase;background:var(--white);color:var(--blue);border:0.5px solid var(--black);border-radius:4px;padding:4px 8px;transition:background .2s,color .2s;}
.overlay-title{display:inline-flex;align-self:flex-start;font-family:var(--fs);font-size:13px;line-height:1.45;background:var(--white);color:var(--blue);border:0.5px solid var(--black);border-radius:4px;padding:8px 12px;transition:background .2s,color .2s;}
.overlay-meta{display:inline-flex;align-self:flex-start;font-family:var(--fl);font-size:9px;letter-spacing:.06em;background:var(--white);color:var(--blue);border:0.5px solid var(--black);border-radius:4px;padding:4px 8px;transition:background .2s,color .2s;}
.overlay-card:hover .overlay-cat,
.overlay-card:hover .overlay-title,
.overlay-card:hover .overlay-meta{background:var(--black);color:var(--white);}

/* ── INTERVIEW CARD（人物・横長1:1） ── */
.interview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px;max-width:1100px;margin:0 auto;}
.interview-card{cursor:pointer;display:block;}
.interview-card:hover .interview-title{text-decoration:underline;}
.interview-img{width:100%;aspect-ratio:1/1;overflow:hidden;position:relative;background:#222;margin-bottom:12px;}
.interview-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s;}
.interview-card:hover .interview-img img{transform:scale(1.04);}
.interview-cat{font-family:var(--fl);font-size:8.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--gray);margin-bottom:6px;}
.interview-title{font-family:var(--fs);font-size:15px;line-height:1.6;margin-bottom:4px;}
.interview-date{font-family:var(--fl);font-size:9px;letter-spacing:.06em;color:var(--gray);}

/* ── CULTURE LIST（WHAT'S NEWスタイル） ── */
.culture-list{max-width:1100px;margin:0 auto;padding:0 482px 64px;}
.culture-item{display:flex;gap:28px;padding:28px 0;align-items:flex-start;cursor:pointer;}
.culture-item:hover .culture-title{text-decoration:underline;}
.culture-thumb{width:140px;height:140px;flex-shrink:0;overflow:hidden;position:relative;background:#ddd;}
.culture-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s;}
.culture-item:hover .culture-thumb img{transform:scale(1.05);}
.culture-body{flex:1;}
.culture-cat{font-family:var(--fl);font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--gray);margin-bottom:6px;}
.culture-title{font-family:var(--fse);font-size:16px;line-height:1.6;margin-bottom:6px;}
.culture-excerpt{font-family:var(--fs);font-size:12px;line-height:1.7;color:var(--gray);margin-bottom:8px;}
.culture-date{font-family:var(--fl);font-size:9px;letter-spacing:.06em;color:var(--gray);}

/* ── ARTICLES SECTION（TOP用 小カード） ── */
.articles-section{padding:0 48px 64px;background:var(--cream);}
.articles-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px;max-width:1100px;margin:0 auto;}
.articles-card{cursor:pointer;display:block;}
.articles-card:hover .articles-title{text-decoration:underline;}
.articles-img{width:100%;aspect-ratio:1/1;overflow:hidden;position:relative;background:#ddd;margin-bottom:8px;}
.articles-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s;}
.articles-card:hover .articles-img img{transform:scale(1.05);}
.articles-badge{position:absolute;top:6px;left:6px;font-family:var(--fl);font-size:7.5px;letter-spacing:.1em;text-transform:uppercase;background:var(--white);padding:2px 5px;color:var(--blue);}
.articles-title{font-family:var(--fs);font-size:12px;line-height:1.6;margin-bottom:4px;}
.articles-date{font-family:var(--fl);font-size:9px;letter-spacing:.06em;color:var(--gray);}

/* ── ARTICLES PAGE（フィルタータブ付き） ── */
.articles-filter{display:flex;max-width:1100px;margin:0 auto 24px;border-bottom:0.5px solid #d0ccc5;padding:0 32px;overflow-x:auto;scrollbar-width:none;}
.articles-filter::-webkit-scrollbar{display:none;}
.filter-tab{font-family:var(--fl);font-size:10px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;padding:10px 18px 10px 0;background:none;border:none;border-bottom:2px solid transparent;color:var(--gray);cursor:pointer;flex-shrink:0;transition:all .15s;}
.filter-tab.active{color:var(--blue);border-bottom-color:var(--blue);}
.articles-page-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;max-width:1100px;margin:0 auto;padding:0 32px;}

/* ── MORE BUTTON ── */
.more-wrap{text-align:center;padding-top:36px;}
.more-wrap.right{text-align:right;max-width:1100px;margin:0 auto;}
.more-btn{display:inline-block;font-family:'dnp-shuei-gothic-gin-std',sans-serif;font-size:14px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--blue);border-radius:24px;padding:10px 32px;background:none;transition:all .15s;cursor:pointer;}
.more-btn:hover{background:var(--blue);color:var(--white);}
.more-btn.white{border-color:var(--blue);color:var(--blue);background:var(--white);}
.more-btn.white:hover{background:var(--blue);color:var(--white);}

/* ── ZINE PAGE ── */
.zine-page{background:var(--cream);min-height:60vh;}
.zine-latest{max-width:1100px;margin:0 auto;padding:48px 32px 56px;display:grid;grid-template-columns:380px 1fr;gap:56px;align-items:start;}
.zine-cover-wrap{position:relative;}
.zine-cover{width:100%;aspect-ratio:1/1.414;object-fit:cover;display:block;box-shadow:0 8px 40px rgba(0,0,0,.18);}
.zine-cover-ph{width:100%;aspect-ratio:1/1.414;background:#1a1a1a;display:flex;align-items:center;justify-content:center;}
.zine-cover-ph-text{font-family:var(--fl);font-size:24px;font-weight:700;color:rgba(255,255,255,.15);letter-spacing:.1em;}
.zine-issue-badge{display:inline-block;font-family:var(--fl);font-size:9px;letter-spacing:.16em;text-transform:uppercase;background:var(--black);color:var(--white);padding:4px 10px;margin-bottom:16px;}
.zine-latest-title{font-family:var(--fse);font-size:32px;font-weight:700;line-height:1.3;margin-bottom:8px;}
.zine-theme{font-family:var(--fl);font-size:13px;letter-spacing:.08em;color:var(--gray);margin-bottom:20px;}
.zine-desc{font-family:var(--fse);font-size:15px;line-height:1.85;margin-bottom:28px;}
.zine-contents{margin-bottom:32px;}
.zine-contents-label{font-family:var(--fl);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--gray);margin-bottom:10px;}
.zine-contents-list{list-style:none;border-top:0.5px solid #d8d5cf;}
.zine-contents-list li{font-family:var(--fse);font-size:13px;line-height:1.6;padding:8px 0;border-bottom:0.5px solid #d8d5cf;}
.zine-dl-btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--fl);font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;background:var(--black);color:var(--white);padding:14px 32px;border-radius:2px;transition:background .2s;border:none;cursor:pointer;}
.zine-dl-btn:hover{background:#333;}
.zine-dl-btn svg{width:16px;height:16px;fill:var(--white);}
.zine-dl-btn.disabled{background:var(--gray);pointer-events:none;}

/* バックナンバー */
.zine-back{background:var(--white);padding:0 32px 60px;}
.zine-back-header{max-width:1100px;margin:0 auto;padding:40px 0 20px;border-bottom:0.5px solid #e0e0e0;margin-bottom:28px;}
.zine-back-title{font-family:var(--fd);font-size:18px;font-weight:400;letter-spacing:.04em;text-transform:uppercase;}
.zine-back-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;max-width:1100px;margin:0 auto;}
.zine-back-card{cursor:pointer;display:block;}
.zine-back-card:hover .zine-back-name{text-decoration:underline;}
.zine-back-img{width:100%;aspect-ratio:1/1.414;object-fit:cover;display:block;margin-bottom:10px;box-shadow:0 4px 16px rgba(0,0,0,.12);transition:box-shadow .3s;}
.zine-back-card:hover .zine-back-img{box-shadow:0 8px 28px rgba(0,0,0,.2);}
.zine-back-img-ph{width:100%;aspect-ratio:1/1.414;background:#1a1a1a;display:flex;align-items:center;justify-content:center;margin-bottom:10px;}
.zine-back-no{font-family:var(--fl);font-size:9px;letter-spacing:.1em;color:var(--gray);margin-bottom:3px;}
.zine-back-name{font-family:var(--fse);font-size:13px;line-height:1.5;}

/* ── SINGLE POST ── */
.single-hero{width:100%;max-height:800px;object-fit:cover;display:block;}
.single-header{padding:32px 32px 28px;max-width:800px;margin:0 auto;background:var(--white);border-top:1px solid var(--black);border-bottom:1px solid var(--black);}
.single-cat{display:inline-block;font-family:var(--fl);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--gray);padding:0;border:none;margin-bottom:14px;}
.single-title{font-family:var(--fs);font-size:30px;font-weight:700;line-height:1.4;margin-bottom:14px;}
.single-meta{font-family:var(--fl);font-size:10px;letter-spacing:.08em;color:var(--gray);}
.single-content{max-width:800px;margin:0 auto;padding:0 32px 60px;}
.single-content p{font-family:var(--fs);font-size:16px;line-height:1.9;margin-bottom:1.6em;}
.single-content h2{font-family:var(--fs);font-size:22px;font-weight:700;margin:2em 0 .8em;padding-bottom:.5em;border-bottom:0.5px solid #e0e0e0;}
.single-content h3{font-family:var(--fs);font-size:18px;font-weight:700;margin:1.6em 0 .6em;}
.single-content img{width:100%;margin:2em 0;}
.single-content blockquote{border-left:2px solid var(--black);padding-left:20px;margin:2em 0;font-style:italic;}
.related-section{border-top:0.5px solid #e0e0e0;padding:40px 32px 60px;}
.related-title{font-family:var(--fl);font-size:14px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;max-width:1100px;margin:0 auto 20px;}

/* ── ARCHIVE（カテゴリ一覧共通） ── */
.archive-header{padding:52px 32px 0;text-align:center;border-bottom:var(--border);}
.archive-en{font-family:var(--fd);font-size:clamp(36px,5vw,60px);font-weight:400;text-transform:uppercase;line-height:1;display:block;}
.archive-ja{font-family:var(--fs);font-size:16px;font-weight:700;color:var(--blue);margin-top:6px;display:block;}
.archive-count{font-family:var(--fl);font-size:10px;color:var(--gray);margin-top:10px;letter-spacing:.08em;display:block;padding-bottom:20px;}

/* ── ABOUT PAGE ── */
.about-page{max-width:720px;margin:0 auto;padding:60px 32px;}
.about-lead{font-family:var(--fse);font-size:20px;line-height:1.8;margin-bottom:40px;padding-bottom:40px;border-bottom:0.5px solid #e0e0e0;}
.about-section{margin-bottom:36px;}
.about-section h2{font-family:var(--fl);font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;margin-bottom:14px;color:var(--gray);}
.about-section p{font-family:var(--fse);font-size:15px;line-height:1.85;}

/* ── FOOTER ── */
.site-footer{background:var(--white);border-top:0.5px solid #e0e0e0;padding:48px 48px 32px;}
.footer-logo{margin-bottom:20px;}
.footer-logo svg{width:96px;height:auto;}
.footer-nav{display:flex;flex-wrap:wrap;gap:0;margin-bottom:20px;}
.footer-nav a{font-family:var(--fl);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;padding:6px 16px 6px 0;color:var(--gray);border-right:0.5px solid #e0e0e0;margin-right:16px;transition:color .15s;}
.footer-nav a:hover{color:var(--blue);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;}
.footer-copy{font-family:var(--fl);font-size:9px;letter-spacing:.06em;color:#bbb;}
.footer-sns{display:flex;gap:16px;}
.footer-sns a{font-family:var(--fl);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:#bbb;transition:color .15s;}
.footer-sns a:hover{color:var(--blue);}

/* ── PAGINATION ── */
.pagination{display:flex;justify-content:center;gap:6px;padding:40px 32px;}
.pagination .page-numbers{font-family:var(--fl);font-size:11px;letter-spacing:.06em;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:0.5px solid #ddd;transition:all .15s;}
.pagination .page-numbers:hover,.pagination .page-numbers.current{background:var(--black);color:var(--white);border-color:var(--blue);}

/* ── NO POSTS ── */
.no-posts{padding:60px 32px;text-align:center;font-family:var(--fs);color:var(--gray);}

/* ── RESPONSIVE ── */
@media(max-width:960px){
  .wn-inner{grid-template-columns:1fr;}
  .wn-sidebar-inner{display:none;}
  .overlay-grid{grid-template-columns:repeat(2,1fr);}
  .interview-grid{grid-template-columns:repeat(2,1fr);}
  .articles-grid{grid-template-columns:repeat(3,1fr);}
  .articles-page-grid{grid-template-columns:repeat(2,1fr);}
  .zine-latest{grid-template-columns:1fr;gap:32px;}
  .zine-cover{max-width:320px;}
  .zine-back-grid{grid-template-columns:repeat(3,1fr);}
}
@media(max-width:600px){
  .wn-section,.overlay-section,.articles-section,.culture-list,.zine-page,.zine-back{padding-left:16px;padding-right:16px;}
  .overlay-grid{grid-template-columns:1fr;}
  .interview-grid{grid-template-columns:1fr;}
  .articles-grid{grid-template-columns:repeat(2,1fr);}
  .articles-page-grid{grid-template-columns:1fr;padding:0 16px;}
  .zine-back-grid{grid-template-columns:repeat(2,1fr);}
  .hero-slide img{height:360px;}
  .single-title{font-size:22px;}
}

.ad-block {
  border-top: 0.5px solid #e0e0e0;
  border-bottom: 0.5px solid #e0e0e0;
  padding: 24px 0;
  margin: 40px 0;
  text-align: center;
  background: #fafafa;
}
.ad-block-label {
  font-family: var(--fl);
  font-size: 9px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--gray);
  margin-bottom: 12px;
}

/* ── 動画サムネイル ── */
.video-thumb-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 1/1;
  overflow: hidden;
  border-radius: 8px;
}
.video-thumb-wrap iframe {
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
  border: none;
}

/* ── ヒーロー動画 ── */
.hero-video-wrap {
  width: 100%;
  height: 800px;
  position: relative;
  overflow: hidden;
}
.hero-video-wrap iframe {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  border: none;
  pointer-events: none;
}

/* ── 非対称グリッド ── */
.asymmetric-grid{display:flex;gap:48px;max-width:1100px;margin:0 auto;align-items:flex-start;}
.card-main{flex:0 0 38%;}
.card-main-link{display:block;color:inherit;text-decoration:none;}
.card-main-img{overflow:hidden;}
.card-main-img img{width:100%;aspect-ratio:2/3;object-fit:cover;display:block;transition:transform .5s ease;}
.card-main-link:hover .card-main-img img{transform:scale(1.05);}
.card-main-body{padding:14px 0 0;}
.card-main-title{font-family:var(--fs);font-size:18px;font-weight:700;line-height:1.45;color:var(--blue);margin-bottom:8px;}
.card-main-cat{font-family:var(--fl);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--gray);}
.card-sub{flex:1;display:flex;flex-direction:column;gap:32px;}
.card-sub-item{display:flex;gap:20px;align-items:flex-start;text-decoration:none;color:inherit;}
.card-sub-img{flex:0 0 46%;overflow:hidden;}
.card-sub-img img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;transition:transform .5s ease;}
.card-sub-item:hover .card-sub-img img{transform:scale(1.05);}
.card-sub-body{flex:1;padding-top:4px;}
.card-sub-title{font-family:var(--fs);font-size:15px;font-weight:700;line-height:1.5;color:var(--blue);margin-bottom:8px;display:block;}
.card-sub-cat{font-family:var(--fl);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--gray);}

/* ── RESPONSIVE 960px以下（タブレット） ── */
@media(max-width:960px){
  .wn-inner{grid-template-columns:1fr;}
  .wn-list{grid-template-columns:1fr;}
  .wn-sidebar-inner{display:none;}
  .overlay-grid{grid-template-columns:repeat(2,1fr);}
  .interview-grid{grid-template-columns:repeat(2,1fr);}
  .articles-grid{grid-template-columns:repeat(3,1fr);}
  .articles-page-grid{grid-template-columns:repeat(2,1fr);}
  .zine-latest{grid-template-columns:1fr;gap:32px;}
  .zine-back-grid{grid-template-columns:repeat(3,1fr);}

  /* 非対称グリッド：縦並びに変更 */
  .asymmetric-grid{flex-direction:column;gap:24px;}
  .card-main{flex:none;width:100%;}
  .card-main-img img{aspect-ratio:3/2;}
  .card-sub{gap:20px;}
}

/* ── RESPONSIVE 600px以下（スマホ） ── */
@media(max-width:600px){
  .wn-section,.overlay-section,.articles-section,.culture-list,.zine-page,.zine-back{padding-left:24px;padding-right:24px;}
  .overlay-grid{grid-template-columns:1fr;}
  .interview-grid{grid-template-columns:1fr;}
  .articles-grid{grid-template-columns:repeat(2,1fr);}
  .articles-page-grid{grid-template-columns:1fr;padding:0 16px;}
  .zine-back-grid{grid-template-columns:repeat(2,1fr);}
  .hero-slide img{height:360px;}
  .single-title{font-size:22px;}
  .asymmetric-grid{flex-direction:column;gap:16px;}
  .card-main{flex:none;width:100%;}
  .card-sub{gap:16px;}
  .card-sub-item{gap:12px;}
  .card-sub-img{flex:0 0 40%;}
}


/* ================================================================
   TOP PAGE – REDESIGN 2025
   ================================================================ */

/* フロントページ: 大ロゴヘッダー非表示 */
.home .header-top { display: none !important; }

/* 下層ページ: 大ロゴ非表示・スティッキーヘッダーを常時表示 */
body:not(.home) .header-top { display: none !important; }
body:not(.home) .header-sticky {
  display: block !important;
  position: sticky;
  top: 0;
  box-shadow: 0 2px 8px rgba(0,0,0,.08);
}

/* 下層ページ: テキスト・見出し色を黒に */
body:not(.home) { color: var(--black); }
body:not(.home) .archive-en,
body:not(.home) .archive-ja,
body:not(.home) .archive-count,
body:not(.home) .single-title,
body:not(.home) .single-cat,
body:not(.home) .single-meta { color: var(--black); }
body:not(.home) .sec-hd-en,
body:not(.home) .sec-hd-ja { color: var(--black); }
body:not(.home) .sec-hd-rule { background: var(--black); }

/* ── TOP HERO HEADER ── */
.top-header { padding: 40px 0 0; background: var(--white); }
.top-tagline {
  text-align: center;
  font-family: 'toppan-bunkyu-gothic-pr6n', 'toppan-bunkyu-midashi-gothic-std', sans-serif;
  font-size: 28px;
  font-weight: 700;
  letter-spacing: .1em;
  color:var(--black);
  margin-bottom: 10px;
}
.top-logo-wrap { text-align: center; margin-bottom: -10px; padding: 0 24px; position: relative; z-index: 1; }
.top-logo-img { width: min(88vw, 1162px); height: auto; display: inline-block; }

.top-body {
  display: grid;
  grid-template-columns: 138px 1fr 224px;
  min-height: 480px;
  gap: 30px;
  margin-top: -50px;
  position: relative;
  padding: 0 48px;
}

/* 左：円サムネイル列 */
.top-circles {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 60px;
  padding: 60px 12px;
  background: var(--white);
}
.top-circle {
  display: block;
  width: 138px;
  height: 138px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
}
.top-circle img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.top-circle:hover img { transform: scale(1.1); }

/* 中：メイン画像 */
.top-main-img { display: block; overflow: hidden; border-radius: 30px; position: relative; }
.top-main-img img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .6s ease; }
.top-main-img:hover img { transform: scale(1.03); }

.top-main-info {
  position: absolute; bottom: 14px; left: 14px;
  display: flex; flex-direction: column; align-items: flex-start;
  width: calc(100% - 28px);
}
.top-main-date {
  display: inline-block;
  font-family: var(--fl); font-size: 14px; letter-spacing: .06em;
  color: var(--blue); background: var(--white);
  border: 1px solid var(--blue); border-radius: 8px 8px 0 0;
  padding: 10px 20px; margin: 0; line-height: 1.4;
  transition: background .2s, color .2s;
}
.top-main-title {
  display: block; align-self: stretch;
  font-family: var(--fs); font-size: 21px; font-weight: 700; line-height: 1.45;
  color: var(--blue); background: var(--white);
  border: 1px solid var(--blue); border-radius: 0 8px 8px 0;
  padding: 14px 20px; margin: 0; margin-top: -1px;
  position: relative; z-index: 1;
  transition: background .2s, color .2s;
}
.top-main-cat {
  display: inline-block;
  font-family: var(--fl); font-size: 13px; letter-spacing: .1em; text-transform: uppercase;
  color: var(--blue); background: var(--white);
  border: 1px solid var(--blue); border-radius: 0 0 8px 8px;
  padding: 8px 20px; margin: 0; margin-top: -1px;
  position: relative; z-index: 2;
  transition: background .2s, color .2s;
}
.top-main-img:hover .top-main-date,
.top-main-img:hover .top-main-title,
.top-main-img:hover .top-main-cat {
  background: var(--blue); color: var(--white);
}

/* 右：ダークグリーンパネル */
.top-nav-panel {
  background: transparent;
  display: flex;
  flex-direction: column;
  border-radius: 30px;
  overflow: hidden;
}
.top-nav-links {
  display: flex;
  flex-direction: column;
  gap: 0;
  background: var(--blue);
  border-radius: 30px;
  padding: 36px 30px 28px 28px;
  flex: 1;
  margin-bottom: 6px;
}
.top-nav-links a {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--fl);
  font-size: 13px;
  letter-spacing: .1em;
  color: var(--white);
  text-transform: uppercase;
  padding: 13px 0;
  border-bottom: 0.5px solid rgba(255,255,255,.2);
  transition: opacity .2s;
}
.top-nav-links a:hover { opacity: .65; }
.top-nav-links a span { font-size: 18px; line-height:1; opacity: .6; }
.top-nav-sns {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  padding: 20px 28px 20px;
  background: var(--dark-green);
  border-radius: 30px 30px 0 0;
}
.top-nav-sns-follow {
  font-family: 'Caveat', cursive;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: .05em;
  color: rgba(255,255,255,.75);
}
.top-nav-sns-logo {
  display: block;
  opacity: 0.85;
  transition: opacity .2s;
}
.top-nav-sns-logo:hover { opacity: 1; }
.top-nav-sns-logo img {
  height: 28px;
  width: auto;
  display: block;
  filter: brightness(0) invert(1);
}
.top-nav-sns-icons {
  display: flex;
  gap: 16px;
  align-items: center;
}
.top-nav-sns-icon {
  display: block;
  width: 18px;
  height: 18px;
  opacity: 0.7;
  transition: opacity .2s;
}
.top-nav-sns-icon:hover { opacity: 1; }
.top-nav-sns-icon svg {
  width: 100%;
  height: 100%;
  fill: var(--white);
  display: block;
}
.top-nav-contact {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  text-align: right;
  gap: 12px;
  padding: 20px 28px 32px;
  background: var(--white);
  border: 2px solid var(--dark-green);
  border-top: none;
  border-radius: 0 0 30px 30px;
  overflow: hidden;
}
.contact-svg { width:36px; height:36px; color:var(--dark-green); opacity:.85; flex-shrink:0; animation:planeFly 3s linear infinite; }
@keyframes planeFly {
  0%   { transform: translateX(-160px) rotate(-5deg); opacity:0; }
  10%  { opacity:.85; }
  90%  { opacity:.85; }
  100% { transform: translateX(160px) rotate(-5deg); opacity:0; }
}
.top-nav-contact p { font-family:var(--fs); font-size:10px; line-height:1.75; color:var(--dark-green); }

/* ── SECTION HEADING – 新ブルー明朝スタイル ── */
.sec-hd { text-align:center; padding:72px 48px 36px; }
.sec-hd-en {
  font-family: var(--fd);
  font-size: 40px;
  font-weight: 400;
  font-style: normal;
  color: var(--blue);
  letter-spacing: -.01em;
  line-height: 1;
  display: block;
  margin-bottom: 6px;
}
.sec-hd-ja { font-family:var(--fs); font-size:16px; font-weight:700; color:var(--blue); margin-bottom:14px; display:block; }
.sec-hd-rule { height:1px; background:var(--blue); opacity:1; }
.sec-hd--white .sec-hd-en { color:var(--white); }
.sec-hd--white .sec-hd-ja { color:rgba(255,255,255,.8); }
.sec-hd-rule--white { background:rgba(255,255,255,.4); opacity:1; }

/* ── WHAT'S NEW ── */
.wn2-section { background:var(--white); padding-bottom:64px; }

.wn-marquee-wrap {
  overflow:hidden;
  border-top:2px solid var(--blue);
  border-bottom:2px solid var(--blue);
  padding:9px 0;
  margin-bottom:0;
  width:100%;
}
.wn-marquee-inner {
  display:flex;
  white-space:nowrap;
  gap:0;
  animation: marqueeScroll 22s linear infinite;
}
@keyframes marqueeScroll {
  0%   { transform:translateX(0); }
  100% { transform:translateX(-33.333%); }
}
.wn-marq-item { font-family:var(--fs); font-size:16px; font-weight:700; letter-spacing:.06em; color:var(--blue); padding:0 14px; }
.wn-marq-sep  { font-size:11px; color:#ccc; padding:0 4px; }

.wn2-inner {
  display:flex;
  align-items:flex-start;
  gap:80px;
  max-width:100%;
  margin:0;
  padding:0 48px;
}
.wn2-sidebar { }
.wn2-main {
  display:flex;
  flex-direction:column;
  flex:1;
  min-width:0;
}
.wn2-list { display:grid; grid-template-columns:1fr 1fr; gap:0; width:100%; border-bottom:0.5px solid rgba(55,59,196,.15); }
.wn2-item {
  display:flex;
  gap:12px;
  padding:18px 12px;
  align-items:flex-start;
  border-top:0.5px solid rgba(55,59,196,.15);
}

.wn2-thumb { flex-shrink:0; width:120px; height:120px; overflow:hidden; display:block; background:#ddd; border-radius:16px; }
.wn2-thumb img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.wn2-item:hover .wn2-thumb img { transform:scale(1.06); }

.wn2-body { flex:1; min-width:0; }
.wn2-title { font-family:var(--fs); font-size:16px; font-weight:700; line-height:1.6; display:block; margin-bottom:6px; color:var(--blue); }
.wn2-item:hover .wn2-title { text-decoration:underline; }
.wn2-meta { display:flex; align-items:center; gap:5px; flex-wrap:wrap; }
.wn2-date { font-family:var(--fl); font-size:12px; color:var(--gray); letter-spacing:.06em; }
.wn2-cat-dot { font-size:6px; color:var(--gray); }
.wn2-cat { font-family:var(--fl); font-size:12px; text-transform:uppercase; color:var(--gray); letter-spacing:.08em; }

/* ZINEサイドバー（ライムグリーン） */
.wn2-zine-card {
  background:var(--lime);
  padding:40px 0;
  border-radius:8px;
  position:relative;
  width:280px;
  margin-right:30px;
  margin-left:-30px;
}
.wn2-zine-new {
  position:absolute; top:-16px; right:-46px;
  display:block; line-height:0;
}
.wn2-zine-new svg { width:120px; height:120px; animation:badgeSpin 12s linear infinite; }
.wn2-zine-cover {
  display:flex; justify-content:center; align-items:flex-end; width:100%; height:280px; overflow:hidden;
  margin-bottom:24px; border-radius:4px;
}
.wn2-zine-cover img { width:auto; height:80%; object-fit:contain; display:block; }
.wn2-zine-ph { width:100%; height:100%; background:#111; display:flex; align-items:center; justify-content:center; padding:20px; }
.wn2-zine-ph img { opacity:.35; filter:invert(1); }
.wn2-zine-info { text-align:center; }
.wn2-zine-no { font-family:var(--fl); font-size:10px; color:var(--black); margin-bottom:2px; }
.wn2-zine-title { font-family:var(--fs); font-size:15px; font-weight:700; line-height:1.4; margin-bottom:4px; color:var(--black); }
.wn2-zine-date { font-family:var(--fl); font-size:10px; color:var(--black); margin-bottom:12px; }
.wn2-zine-btn {
  display:inline-block; text-align:center;
  background:var(--white); color:var(--black);
  font-family:'dnp-shuei-gothic-gin-std',sans-serif; font-size:14px; font-weight:700; letter-spacing:.1em;
  padding:10px 32px; border-radius:24px;
  transition:background .2s, color .2s;
}
.wn2-zine-btn:hover { background:var(--black); color:var(--white); }


/* ── GOURMET / CAT SECTION ── */
.cat-section { background:var(--white); padding-bottom:64px; }

.post-card-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:30px;
  max-width:1100px;
  margin:0 auto;
  padding:0 48px;
}
.post-card { position:relative; background:var(--white); border-radius:16px; overflow:hidden; border:none; width:100%; }
.post-card-link { display:block; color:inherit; text-decoration:none; }

.post-card-img { width:100%; aspect-ratio:1/1; overflow:hidden; background:#ddd; border-radius:16px; }
.post-card-img img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .5s ease; }
.post-card-img .video-thumb-wrap { aspect-ratio:4/3; }
.post-card-link:hover .post-card-img img { transform:scale(1.05); }

/* 情報ボックス：画像の上に重ねる absolute 配置 */
.post-card-info {
  position:absolute;
  bottom:10px;
  left:10px;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  padding:0;
  background:transparent;
  width:calc((100% - 20px) / 1.2);
  transform:scale(1.2);
  transform-origin:bottom left;
}

/* 日付：上のみ角丸 */
.post-card-date {
  display:inline-block;
  font-family:var(--fl);
  font-size:9px;
  color:var(--blue);
  letter-spacing:.06em;
  background:var(--white);
  border:1px solid var(--blue);
  border-radius:6px 6px 0 0;
  padding:4px 8px;
  margin:0;
  line-height:1.4;
}

/* 見出しタイトル：右のみ角丸・上下線を共有 */
.post-card-title {
  display:block;
  align-self:stretch;
  font-family:var(--fs);
  font-size:13px;
  font-weight:700;
  line-height:1.45;
  color:var(--blue);
  background:var(--white);
  border:1px solid var(--blue);
  border-radius:0 6px 6px 0;
  padding:6px 10px;
  margin:0;
  margin-top:-1px;
  position:relative;
  z-index:1;
}
.post-card-link:hover .post-card-date,
.post-card-link:hover .post-card-title,
.post-card-link:hover .post-card-cat {
  background:var(--blue);
  color:var(--white);
  transition:background .2s, color .2s;
}
.post-card-date,
.post-card-title,
.post-card-cat { transition:background .2s, color .2s; }

/* カテゴリ：下のみ角丸・上線を共有 */
.post-card-cat {
  display:inline-block;
  font-family:var(--fl);
  font-size:8px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--blue);
  background:var(--white);
  border:1px solid var(--blue);
  border-radius:0 0 6px 6px;
  padding:3px 8px;
  margin:0;
  margin-top:-1px;
  position:relative;
  z-index:2;
}
.post-card-pr-badge {
  position:absolute; top:10px; right:10px; z-index:2;
  background:rgba(255,255,255,.92); border:0.5px solid #ccc;
  font-family:var(--fl); font-size:8px; letter-spacing:.1em;
  padding:2px 6px; border-radius:2px; color:var(--gray);
}

/* ── MOVIE + CULTURE 並列レイアウト ── */
.movie-culture-row {
  display:grid;
  grid-template-columns:2fr 1fr;
  align-items:stretch;
  background:var(--white);
}
.movie-col { padding:0 20px 64px 48px; display:flex; flex-direction:column; min-width:0; }
.culture-col { padding:0 48px 64px 20px; min-width:0; margin-top:-30px; }

.movie-block {
  background:var(--blue);
  border-radius:20px;
  flex:1;
  display:flex;
  flex-direction:column;
}
.movie-block .sec-hd { padding:48px 32px 28px; }

.movie-feat-card {
  display:block; margin:0 20px;
  border-radius:12px; overflow:hidden;
  text-decoration:none; color:inherit;
  background:#111;
  position:relative;
}
.movie-feat-img { width:100%; aspect-ratio:16/9; overflow:hidden; background:#111; }
.movie-feat-img img { width:100%; height:100%; object-fit:cover; display:block; }
.movie-feat-img .video-thumb-wrap { aspect-ratio:16/9; border-radius:0; }

/* Movie カード：画像の上に重ねる absolute 配置 */
.movie-feat-card { position:relative; }

.movie-feat-info {
  position:absolute;
  bottom:10px;
  left:10px;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  padding:0;
  background:transparent;
  max-width:calc(100% - 20px);
}

/* 日付：上のみ角丸 */
.movie-feat-date {
  display:inline-block;
  font-family:var(--fl);
  font-size:9px;
  color:var(--blue);
  letter-spacing:.06em;
  background:var(--white);
  border:1px solid var(--blue);
  border-radius:6px 6px 0 0;
  padding:4px 8px;
  margin:0;
  line-height:1.4;
}

/* 見出しタイトル：右のみ角丸 */
.movie-feat-title {
  display:block;
  align-self:stretch;
  font-family:var(--fs);
  font-size:13px;
  font-weight:700;
  line-height:1.45;
  color:var(--blue);
  background:var(--white);
  border:1px solid var(--blue);
  border-radius:0 6px 6px 0;
  padding:6px 10px;
  margin:0;
  margin-top:-1px;
  position:relative;
  z-index:1;
}

/* カテゴリ：下のみ角丸 */
.movie-feat-cat {
  display:inline-block;
  font-family:var(--fl);
  font-size:8px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--blue);
  background:var(--white);
  border:1px solid var(--blue);
  border-radius:0 0 6px 6px;
  padding:3px 8px;
  margin:0;
  margin-top:-1px;
  position:relative;
  z-index:2;
}

.movie-circles {
  position:relative; flex:1; min-height:180px; margin:20px 2px 0;
  background:var(--white); border:2px solid var(--blue);
  border-bottom:none; border-radius:0;
  overflow:hidden;
}
.movie-circle {
  position:absolute; display:block;
  width:100px; height:100px; border-radius:50%;
  overflow:hidden; border:3px solid var(--blue);
}
.movie-circle img { width:100%; height:100%; object-fit:cover; }

.movie-col .more-wrap {
  padding:20px 20px 32px;
  background:var(--white);
  border-left:2px solid var(--blue);
  border-right:2px solid var(--blue);
  border-bottom:2px solid var(--blue);
  border-top:none;
  border-radius:0 0 16px 16px;
  margin:0 2px 1px;
}

/* Culture列：1カラムカードグリッド */
.post-card-grid--1col { grid-template-columns:1fr; padding:0; justify-items:center; }

/* Culture の画像のみ正円マスク */
.culture-col .post-card-img {
  border-radius:50%;
  aspect-ratio:1/1;
}

/* ── ARTICLES 新デザイン ── */
.articles2-section { background:var(--white); padding-bottom:64px; }

.articles2-intro {
  margin:0 0 28px;
  padding:9px 0;
  border-top:2px solid var(--blue);
  border-bottom:2px solid var(--blue);
  overflow:hidden;
}
.articles2-intro-inner {
  display:flex;
  white-space:nowrap;
  animation:marqueeScroll 22s linear infinite;
}
.articles2-intro-text {
  font-family:var(--fs); font-size:16px; font-weight:700; color:var(--blue); line-height:1.7;
  padding:0 14px;
}
.articles2-intro-sep { font-size:14px; color:#ccc; padding:0 4px; }

.articles2-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:20px; max-width:1100px; margin:0 auto; padding:0 48px;
}
.articles2-link { display:block; color:inherit; text-decoration:none; }
.articles2-img { width:100%; aspect-ratio:1/1; overflow:hidden; background:#ddd; border-radius:16px; margin-bottom:8px; }
.articles2-img img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .4s; }
.articles2-link:hover .articles2-img img { transform:scale(1.05); }
.articles2-body { padding:0 2px; }
.articles2-cat { font-family:var(--fl); font-size:8px; letter-spacing:.1em; text-transform:uppercase; color:var(--blue); display:block; margin-bottom:4px; }
.articles2-title { font-family:var(--fs); font-size:13px; font-weight:700; line-height:1.5; margin-bottom:4px; display:block; }
.articles2-link:hover .articles2-title { text-decoration:underline; }
.articles2-author { font-family:var(--fl); font-size:9px; letter-spacing:.08em; color:var(--gray); display:block; margin-bottom:2px; }
.articles2-date { font-family:var(--fl); font-size:9px; color:var(--gray); letter-spacing:.06em; display:block; }

/* ── FOOTER リデザイン（ブルー） ── */
.site-footer {
  background:var(--blue) !important;
  border-top:none !important;
  padding:56px 48px 48px !important;
}
.footer-inner {
  display:grid; grid-template-columns:1fr auto;
  gap:48px; max-width:1100px; margin:0 auto;
  align-items:start;
}
.footer-left {}
.footer-sns-icons { display:flex; align-items:center; gap:20px; margin-bottom:20px; }
.footer-sns-icon {
  display:flex; align-items:center; gap:6px;
  color:var(--white); text-decoration:none;
  transition:opacity .2s;
}
.footer-sns-icon:hover { opacity:.7; }
.footer-sns-icon svg { width:22px; height:22px; fill:var(--white); display:block; }
.footer-sns-label { font-family:var(--fl); font-size:10px; letter-spacing:.06em; color:var(--white); }
.footer-logo-wrap { margin-bottom:16px; }
.footer-logo-wrap img { width:160px; height:auto; filter:brightness(0) invert(1); }
.footer-nav-links { display:flex; align-items:center; flex-wrap:wrap; gap:0; }
.footer-nav-links a {
  font-family:var(--fl); font-size:10px; letter-spacing:.08em; text-transform:uppercase;
  color:rgba(255,255,255,.8); transition:color .15s;
  padding-right:12px; margin-right:12px;
  border-right:0.5px solid rgba(255,255,255,.3);
}
.footer-nav-links a:last-child { border-right:none; }
.footer-nav-links a:hover { color:var(--white); }

/* フッターZINEカード */
.footer-zine {
  position:relative; background:var(--white); border-radius:12px;
  padding:20px; width:220px;
  box-shadow:0 4px 28px rgba(0,0,0,.25);
}
.footer-zine-new {
  position:absolute; top:-16px; right:-16px;
  display:block; line-height:0;
}
.footer-zine-new svg { width:56px; height:56px; animation:badgeSpin 8s linear infinite; }
.footer-zine-new .new-badge-text { animation-duration:8s; }

@keyframes badgeSpin {
  from { transform:rotate(0deg); }
  to   { transform:rotate(360deg); }
}
/* テキストパスはSVG中心(60,60)を軸に逆回転で打ち消す */
.new-badge-text {
  transform-origin: 60px 60px;
  animation: badgeSpinReverse 12s linear infinite;
}
@keyframes badgeSpinReverse {
  from { transform:rotate(0deg); }
  to   { transform:rotate(-360deg); }
}
.footer-zine-cover {
  display:block; width:100%; aspect-ratio:3/4; overflow:hidden;
  border-radius:4px; background:#111; margin-bottom:10px;
}
.footer-zine-cover img { width:100%; height:100%; object-fit:cover; display:block; }
.footer-zine-no { font-family:var(--fl); font-size:9px; color:var(--gray); margin-bottom:2px; }
.footer-zine-title { font-family:var(--fs); font-size:13px; font-weight:700; line-height:1.4; margin-bottom:4px; color:var(--blue); }
.footer-zine-date { font-family:var(--fl); font-size:10px; color:var(--gray); margin-bottom:12px; }
.footer-zine-btn {
  display:block; text-align:center; border:1px solid var(--black);
  color:var(--blue); font-family:'dnp-shuei-gothic-gin-std',sans-serif; font-size:14px; font-weight:700; letter-spacing:.1em;
  padding:7px; border-radius:24px; transition:all .2s;
}
.footer-zine-btn:hover { background:var(--black); color:var(--white); }

.footer-copy-line {
  font-family:var(--fl); font-size:9px; color:rgba(255,255,255,.45); letter-spacing:.06em;
  max-width:1100px; margin:24px auto 0;
  padding-top:20px; border-top:0.5px solid rgba(255,255,255,.2);
}

/* ================================================================
   RESPONSIVE REDESIGN
   ================================================================ */

/* ── TABLET (〜1099px) ── */
@media(max-width:1099px){
  .top-body { grid-template-columns:100px 1fr 200px; gap:16px; padding:0 24px; }
  .top-circle { width:100px; height:100px; }
  .top-nav-links { padding:24px 16px 16px; }
  .top-nav-links a { font-size:12px; padding:10px 0; }

  .wn2-inner { gap:40px; padding:0 24px; }
  .wn2-zine-card { width:220px; }

  .post-card-grid { padding:0 24px; gap:16px; }
  .sec-hd { padding:48px 24px 28px; }
  .sec-hd-en { font-size:32px; }

  .movie-culture-row { grid-template-columns:2fr 1fr; }
  .movie-col { padding:0 12px 48px 24px; }
  .culture-col { padding:0 24px 48px 12px; margin-top:0; }

  .articles2-grid { grid-template-columns:repeat(3,1fr); padding:0 24px; gap:16px; }

  .footer-inner { grid-template-columns:1fr; }
  .footer-zine { display:none; }

  body:not(.home) .header-sticky { position:sticky; top:0; display:block !important; }
}

/* ── MOBILE (〜767px) ── */
@media(max-width:767px){
  /* TOP */
  .top-header { padding:20px 0 0; }
  .top-tagline { font-size:18px; letter-spacing:.06em; }
  .top-logo-wrap { padding:0 16px; }
  .top-logo-img { width:100%; }

  .top-body {
    grid-template-columns:1fr;
    min-height:auto;
    margin-top:-10px;
    padding:0 16px;
    gap:12px;
  }
  .top-circles {
    display:flex; flex-direction:row;
    justify-content:center; gap:12px;
    padding:8px 0; background:var(--white);
    order:3;
  }
  .top-circle { width:72px; height:72px; }
  .top-main-img { order:1; border-radius:16px; }
  .top-main-title { font-size:15px; padding:10px 14px; }
  .top-main-date { font-size:11px; padding:6px 14px; }
  .top-main-cat { font-size:10px; padding:4px 14px; }

  .top-nav-panel { order:2; border-radius:16px; margin-bottom:4px; }
  .top-nav-links { border-radius:16px; padding:16px 16px 12px; flex:none; margin-bottom:6px; }
  .top-nav-links a { font-size:13px; padding:9px 0; }
  .top-nav-sns { border-radius:16px 16px 0 0; padding:14px 16px; }
  .top-nav-sns-logo img { height:20px; }
  .top-nav-contact { padding:14px 16px 20px; }

  /* What's New */
  .sec-hd { padding:36px 16px 20px; }
  .sec-hd-en { font-size:28px; }
  .sec-hd-ja { font-size:14px; margin-bottom:10px; }

  .wn2-inner { flex-direction:column; padding:0 16px; gap:0; }
  .wn2-sidebar { display:none; }
  .wn2-list { grid-template-columns:1fr; }
  .wn2-item { padding:12px 4px; }
  .wn2-thumb { width:80px; height:80px; border-radius:10px; }
  .wn2-title { font-size:14px; }
  .wn2-date, .wn2-cat { font-size:11px; }

  /* Post cards */
  .post-card-grid { grid-template-columns:1fr 1fr; padding:0 16px; gap:12px; }
  .post-card-title { font-size:12px; padding:5px 8px; }
  .post-card-date { font-size:8px; padding:3px 8px; }
  .post-card-cat { font-size:7px; padding:2px 8px; }
  .post-card-info { width:calc((100% - 16px)/1.1); transform:scale(1.1); }

  /* Movie + Culture */
  .movie-culture-row { grid-template-columns:1fr; }
  .movie-col { padding:0 16px 32px; min-width:0; }
  .culture-col { padding:0 16px 32px; margin-top:0; min-width:0; }
  .post-card-grid--1col { grid-template-columns:1fr 1fr; padding:0; }
  .movie-circles { min-height:120px; }
  .movie-circle { width:72px; height:72px; }

  /* Articles */
  .articles2-grid { grid-template-columns:1fr 1fr; padding:0 16px; gap:12px; }
  .articles2-intro-text { font-size:13px; }
  .articles2-body { padding:0; }
  .articles2-title { font-size:12px; }

  /* More button */
  .more-wrap { padding-top:20px; }
  .more-btn { font-size:12px; padding:9px 24px; }

  /* Footer */
  .site-footer { padding:36px 20px 28px !important; }
  .footer-inner { gap:20px; }
  .footer-sns-icons { gap:14px; margin-bottom:14px; }
  .footer-logo-wrap img { width:120px; }
  .footer-nav-links a { font-size:9px; }
  .footer-copy-line { font-size:8px; margin-top:14px; padding-top:14px; }

  /* Sticky header */
  .header-sticky-inner { height:56px; padding:0 16px; }
  .header-logo-small img { width:140px; }

  /* Archive / 下層 */
  .archive-header { padding:28px 16px 0; }
  .archive-en { font-size:clamp(28px,8vw,48px) !important; }
  .overlay-section { padding:16px 16px 40px !important; }
  .overlay-grid { grid-template-columns:1fr 1fr !important; gap:12px; }
  .overlay-title { font-size:12px !important; padding:6px 8px !important; }
  .overlay-meta, .overlay-cat { font-size:8px !important; padding:3px 6px !important; }

  /* Single */
  .single-header { padding:20px 16px; }
  .single-title { font-size:22px; }
  .single-content { padding:0 16px 40px; }
}

/* ── SMALL MOBILE (〜480px) ── */
@media(max-width:480px){
  .top-body { padding:0 12px; }
  .top-circle { width:60px; height:60px; }
  .top-tagline { font-size:15px; }

  .post-card-grid { grid-template-columns:1fr; }
  .post-card-grid--1col { grid-template-columns:1fr; }
  .articles2-grid { grid-template-columns:1fr; }
  .overlay-grid { grid-template-columns:1fr !important; }

  .wn2-list { grid-template-columns:1fr; }
  .movie-circles { min-height:100px; }
  .movie-circle { width:60px; height:60px; }

  .sec-hd-en { font-size:24px; }
  .top-nav-links a { font-size:12px; }
}