@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700&family=Cormorant+Garamond:ital,wght@0,300;0,500;1,300&family=Quicksand:wght@400;600;700&display=swap');
@import url('styles/boots-bones.css');
/*
Theme Name: girl's bar GO!!! original theme
Author: hachi  Version: 1.0
*/

/* ============================================================
   RESET
============================================================ */
html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,
blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,
img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,
center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,
tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,
figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,
summary,time,mark,audio,video {
  margin:0; padding:0; border:0; vertical-align:baseline;
  font:inherit; font-size:100%;
}
article,aside,details,figcaption,figure,footer,header,
hgroup,menu,nav,section { display:block; }
html { font-size:62.5%; -webkit-text-size-adjust:100%; -ms-text-size-adjust:100%; }
ol,ul { list-style:none; }
blockquote,q { quotes:none; }
blockquote:before,blockquote:after,q:before,q:after { content:''; content:none; }
table { border-spacing:0; border-collapse:collapse; }
sup,sub { font-size:75%; height:0; line-height:0; position:relative; vertical-align:baseline; }
sup { bottom:1ex; } sub { top:.5ex; }
small { font-size:75%; } big { font-size:125%; } figure { margin:0; }
table { margin:0 0 1.5em; width:100%; } th { font-weight:bold; }
button,input,select,textarea { font-size:100%; margin:0; vertical-align:middle; }
button,input { line-height:normal; overflow:visible; }
button,html input[type="button"],input[type="reset"],input[type="submit"] {
  border:none; border-radius:10px; background:#ccc; color:rgba(0,0,0,.8);
  cursor:pointer; -webkit-appearance:button; appearance:button;
  font-size:1.4rem; line-height:1; padding:1.12em 1.5em 1em;
}
input[type="checkbox"],input[type="radio"] { box-sizing:border-box; padding:0; }
input[type=text],input[type=email],textarea { color:#888; border:1px solid #ddd; border-radius:5px; }
input[type=text],input[type=email] { padding:3px; }
textarea { overflow:auto; padding:10px; vertical-align:top; width:98%; }
b,strong { font-weight:bold; } dfn,cite,em,i { font-style:italic; }

/* ============================================================
   CSS VARIABLES
============================================================ */
:root {
  /* Brand colours */
  --pink:       #ff4fa3;
  --pink-light: #ffd4ef;
  --pink-mid:   #ff88c6;
  --pink-dark:  #b4237a;
  --lavender-1: #d9cbff;
  --lavender-2: #bca7ff;
  --sky-1:      #d3f2ff;
  --sky-2:      #8ed8ff;
  --gold-1:     #f4b3ff;
  --gold-2:     #98dfff;
  --deep:       #2a0f4c;

  /* Gradients */
  --g-crimson:  linear-gradient(135deg, #ff5db2 0%, #c443ff 52%, #73d0ff 100%);
  --g-gold:     linear-gradient(135deg, #ffc4ee 0%, #d3c6ff 52%, #9fddff 100%);
  --g-hero:     linear-gradient(to top, rgba(42,15,76,.84) 0%, rgba(77,33,134,.46) 54%, transparent 100%);
  --g-section:  linear-gradient(160deg, rgba(255,239,250,.95) 0%, rgba(236,245,255,.96) 52%, rgba(245,239,255,.98) 100%);

  /* Surfaces */
  --bg:         #fbe8f7;
  --card:       rgba(255,255,255,.92);
  --card-b:     rgba(196,67,255,.18);

  /* Shadows */
  --s0: 0 2px 10px  rgba(111,43,168,.12);
  --s1: 0 8px 26px rgba(111,43,168,.16);
  --s2: 0 14px 42px rgba(111,43,168,.24);
  --s3: 0 18px 56px rgba(111,43,168,.30);
  --glow-pink: 0 0 22px rgba(255,93,178,.42);
  --glow-gold: 0 0 24px rgba(115,208,255,.45);

  /* Misc */
  --r:    18px;
  --r-sm: 10px;
  --r-xs: 6px;
  --mw:   1080px;
  --tx:   #32184f;
  --tx2:  #6b4e95;
}

/* ============================================================
   ANIMATIONS
============================================================ */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(24px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes shimmer {
  0%,100% { opacity:1; }
  50%      { opacity:.65; }
}
@keyframes glow-pulse {
  0%,100% { box-shadow: var(--s1); }
  50%      { box-shadow: var(--glow-pink), var(--s2); }
}
@keyframes float {
  0%,100% { transform:translateY(0); }
  50%      { transform:translateY(-6px); }
}

/* ============================================================
   BASE
============================================================ */
html { scroll-behavior:smooth; }
body {
  margin:0; padding:0;
  background-color: var(--bg);
  background-image:
    radial-gradient(circle at 16% 20%, rgba(255,164,228,.36) 0%, rgba(255,164,228,0) 36%),
    radial-gradient(circle at 84% 18%, rgba(149,219,255,.32) 0%, rgba(149,219,255,0) 34%),
    radial-gradient(circle at 50% 82%, rgba(203,171,255,.28) 0%, rgba(203,171,255,0) 40%),
    url("img/background.jpg");
  background-attachment: fixed;
  background-size: cover;
  background-position: center top;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 1.6rem; line-height: 1.9;
  color: var(--tx);
}
*,*::before,*::after { box-sizing:border-box; }
img { max-width:100%; height:auto; display:block; }
a { color:var(--pink-dark); text-decoration:none; transition:color .2s; }
a:hover { color:var(--pink); }
h1,h2,h3,h4,h5,h6 { font-family:'Quicksand','Noto Sans JP',sans-serif; }
p { margin-bottom:1.4em; }
.alignleft  { float:left;  margin-right:1.5em; display:inline; }
.alignright { float:right; margin-left:1.5em;  display:inline; }
.aligncenter { display:block; margin:0 auto; clear:both; }
.clear { clear:both; }
.clearfix::after { content:"."; display:block; clear:both; visibility:hidden; line-height:0; height:0; }
.clearfix { display:inline-block; }
html[xmlns] .clearfix { display:block; }
* html .clearfix { height:1%; }

/* ============================================================
   HEADER  —  white sticky bar
============================================================ */
header#masthead {
  background: rgba(255,255,255,.97);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 2px 18px rgba(111,43,168,.16);
  position: sticky; top:0; z-index:100;
  border-bottom: 1px solid rgba(196,67,255,.20);
}
.header-inner {
  display: flex; align-items: center; justify-content: space-between;
  max-width: 1240px; margin: 0 auto;
  padding: 0 28px; height: 66px;
  position: relative;
}

/* Logo */
.header-logo .site-title { margin:0; line-height:1; font-size:1rem; }
.header-logo img { height:50px; width:auto; transition:opacity .2s; }
.header-logo img:hover { opacity:.8; }

/* Main nav */
.site-navigation { flex:1; margin:0 12px; }
.site-navigation ul {
  list-style:none; margin:0; padding:0;
  display:flex; justify-content:center; gap:0;
}
.site-navigation ul li a {
  display:block; color:#4d2e75; font-size:1.2rem; font-weight:600;
  letter-spacing:.10em; padding:8px 16px;
  position:relative; transition:color .2s;
}
.site-navigation ul li a::after {
  content:''; position:absolute; bottom:0; left:16px; right:16px;
  height:2px; background:var(--g-crimson);
  border-radius:2px; transform:scaleX(0);
  transition:transform .25s ease;
}
.site-navigation ul li a:hover { color:var(--pink); }
.site-navigation ul li a:hover::after { transform:scaleX(1); }

/* CTA pill */
.header-cta-btn {
  display:inline-flex; align-items:center;
  background: var(--g-crimson);
  color:#fff !important; font-size:1.2rem; font-weight:700;
  padding:9px 22px; border-radius:50px;
  box-shadow:0 5px 20px rgba(196,67,255,.30);
  letter-spacing:.05em; white-space:nowrap;
  transition:transform .2s, box-shadow .2s, opacity .2s;
}
.header-cta-btn:hover { transform:translateY(-2px); box-shadow:var(--glow-pink); opacity:.9; color:#fff !important; }

/* Hamburger */
.hamburger {
  display:none; cursor:pointer; flex-shrink:0; z-index:10;
  width:28px; height:22px; position:relative;
}
.hamburger span {
  position:absolute; width:100%; height:2px;
  background:#7b3ec6; transition:all .3s;
}
.hamburger span:nth-child(1) { top:2px; }
.hamburger span:nth-child(2) { top:10px; }
.hamburger span:nth-child(3) { top:18px; }
.hamburger.open span:nth-child(1) { top:10px; transform:rotate(-45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { top:10px; transform:rotate(45deg); }

/* ============================================================
   MAIN / HOME WRAPPER
============================================================ */
.main-fluid { min-height:60vh; }
.home-wrapper { width:100%; }

/* ============================================================
   SECTION COMMON  —  heading with sub-title line
============================================================ */
.sec-head {
  display:flex; align-items:center; justify-content:center;
  gap:18px; margin-bottom:44px; text-align:center;
}
.sec-head-inner { text-align:center; min-width:0; }
.sec-sub {
  display:block; font-size:1.15rem; font-weight:700;
  letter-spacing:.22em; color:var(--pink);
  text-transform:uppercase; margin:0 0 2px;
}
.sec-title {
  display:block; font-size:2.2rem; font-weight:700;
  letter-spacing:.22em; color:var(--pink-dark);
  font-family:'Cormorant Garamond','Quicksand',serif;
  margin:0; line-height:1.1;
}
.sec-deco {
  color:rgba(196,67,255,.55); font-size:1.1rem;
  white-space:nowrap; flex-shrink:0;
  animation: shimmer 3s ease-in-out infinite;
  text-shadow:0 0 12px rgba(115,208,255,.4);
}

/* Shared section sizing */
.features-section,
.gallery-section,
.news-section {
  max-width: var(--mw);
  margin: 0 auto;
  padding: 72px 28px;
  position: relative;
}
.system-section,
.access-section,
.recruit-section {
  max-width: var(--mw);
  margin: 24px auto;
  padding: 72px 40px;
  background: var(--g-section);
  backdrop-filter: blur(8px);
  border-radius: var(--r);
  border: 1px solid rgba(196,67,255,.18);
  box-shadow: var(--s1);
  position: relative;
  overflow: hidden;
}

.system-section::before,
.access-section::before,
.recruit-section::before {
  content:'';
  position:absolute;
  top:-180px;
  right:-120px;
  width:360px;
  height:360px;
  background:radial-gradient(circle, rgba(255,152,225,.26) 0%, rgba(255,152,225,0) 68%);
  pointer-events:none;
}
.system-section::after,
.access-section::after,
.recruit-section::after {
  content:'';
  position:absolute;
  left:-110px;
  bottom:-180px;
  width:320px;
  height:320px;
  background:radial-gradient(circle, rgba(143,220,255,.24) 0%, rgba(143,220,255,0) 66%);
  pointer-events:none;
}

/* ============================================================
   HERO  —  full-width + overlay
============================================================ */
.hero-section { width:100%; background:var(--bg); }

.hero-img-wrap { position:relative; width:100%; overflow:hidden; line-height:0; }
.hero-img {
  display:block; width:100%;
  height:260px; /* mobile */
  object-fit:cover; object-position:center top;
}

/* Desktop gradient overlay */
.hero-overlay { display:none; }

/* Mobile block */
.hero-mobile-content {
  background: linear-gradient(180deg, rgba(255,241,252,.88) 0%, rgba(232,245,255,.85) 100%);
  text-align:center; padding:36px 24px 0;
}

/* Text */
.hero-eyecatch {
  font-size:1.4rem; letter-spacing:.14em;
  color:var(--tx2); margin-bottom:5px;
}
.hero-title {
  font-size:2.9rem; font-weight:900;
  letter-spacing:.05em; line-height:1.16;
  margin:0 0 14px; color:var(--pink-dark);
  font-family:'Cormorant Garamond','Quicksand',serif;
}
.hero-subcatch { font-size:1.3rem; color:var(--tx2); margin-bottom:22px; }
.hero-hours-note {
  font-size:1.2rem; color:var(--tx2);
  margin:8px 0 20px; display:flex; align-items:center; justify-content:center; gap:8px;
}
.hours-dot { color:var(--pink); font-size:.8rem; }

/* Time badge */
.hero-time-badge {
  display:inline-block;
  background: var(--g-crimson);
  color:#fff; font-size:1.55rem; font-weight:700; letter-spacing:.18em;
  padding:14px 56px; border-radius:50px;
  margin:12px 0 34px;
  box-shadow:var(--s1), var(--glow-pink);
}

/* Prices */
.price-row {
  display:flex; justify-content:center; gap:12px;
  flex-wrap:wrap; margin-bottom:20px;
}
.price-box {
  background: var(--g-crimson);
  color:#fff; border-radius:var(--r-sm);
  padding:24px 26px; min-width:146px; text-align:center;
  box-shadow:var(--s1);
  transition:transform .25s, box-shadow .25s;
}
.price-box:hover { transform:translateY(-4px); box-shadow:var(--s2), var(--glow-pink); }
.price-gender { display:block; font-size:1.25rem; font-weight:500; opacity:.88; margin-bottom:10px; }
.price-val { font-size:1.35rem; line-height:1.6; }
.price-val strong { display:block; font-size:2.4rem; font-weight:900; line-height:1.15; margin-top:8px; }

.tax-note { font-size:1.2rem; color:var(--tx2); margin:4px 0 8px; }
.extend-note {
  font-size:1.7rem; font-weight:700;
  color:var(--tx); letter-spacing:.05em; margin:12px 0 26px;
}

/* CTA buttons row */
.hero-cta-row {
  display:flex; justify-content:center; gap:16px; flex-wrap:wrap;
  background:var(--bg); padding:24px 22px 40px;
}
.cta-btn {
  display:inline-flex; align-items:center; justify-content:center;
  min-height:52px;
  padding:15px 40px; border-radius:50px;
  font-size:1.6rem; font-weight:700; letter-spacing:.06em;
  color:#fff !important; text-decoration:none;
  position:relative;
  overflow:hidden;
  transition:transform .25s, box-shadow .25s;
}
.cta-btn::before {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(120deg, rgba(255,255,255,.28) 0%, rgba(255,255,255,0) 44%, rgba(255,255,255,.25) 100%);
  pointer-events:none;
}
.cta-btn:hover { transform:translateY(-4px); color:#fff !important; }
.cta-gold {
  background: var(--g-gold);
  box-shadow: 0 6px 24px rgba(115,208,255,.32);
  text-shadow: 0 1px 3px rgba(77,33,134,.28);
}
.cta-gold:hover { box-shadow: var(--glow-gold), var(--s2); }
.cta-pink {
  background: var(--g-crimson);
  box-shadow: 0 6px 24px rgba(196,67,255,.32);
}
.cta-pink:hover { box-shadow: var(--glow-pink), var(--s2); }

/* ============================================================
   FEATURE CARDS  (ABOUT)
============================================================ */
.features-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:22px;
}
.feature-card {
  background: var(--card);
  border: 1px solid var(--card-b);
  border-radius: var(--r);
  padding: 40px 22px 32px;
  text-align: center;
  box-shadow: var(--s1);
  position: relative;
  overflow: hidden;
  backdrop-filter: blur(8px);
  transition: transform .25s, box-shadow .25s;
}
.feature-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:4px;
  background: var(--g-crimson);
}
.feature-card::after {
  content:'';
  position:absolute;
  right:-24px;
  bottom:-24px;
  width:120px;
  height:120px;
  background:radial-gradient(circle, rgba(142,219,255,.28) 0%, rgba(142,219,255,0) 72%);
  pointer-events:none;
}
.feature-card:hover { transform:translateY(-7px); box-shadow:var(--s3); }
.feature-icon-wrap {
  font-size:3.2rem; margin-bottom:16px; line-height:1;
  animation: float 4s ease-in-out infinite;
}
.feature-card:nth-child(2) .feature-icon-wrap { animation-delay:.8s; }
.feature-card:nth-child(3) .feature-icon-wrap { animation-delay:1.6s; }
.feature-title {
  font-size:1.5rem; font-weight:700;
  color:var(--pink-dark); margin:0 0 10px;
}
.feature-desc { font-size:1.3rem; color:var(--tx2); line-height:1.8; margin:0; }

/* ============================================================
   SYSTEM  —  price table + drink menu
============================================================ */

/* Price table */
.sys-price-area { text-align:center; margin-bottom:52px; }

.sys-price-label-bar {
  display:inline-block;
  background: var(--g-crimson);
  color:#fff; font-size:1.45rem; font-weight:700; letter-spacing:.14em;
  padding:8px 40px; border-radius:50px; margin-bottom:28px;
  box-shadow:0 4px 16px rgba(196,67,255,.32);
}

.sys-price-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:20px; max-width:700px; margin:0 auto 16px;
}
.sys-price-card {
  background: var(--g-crimson);
  color:#fff; border-radius:var(--r);
  padding:32px 20px; text-align:center;
  box-shadow:var(--s2);
  transition:transform .3s, box-shadow .3s;
  position:relative; overflow:hidden;
}
.sys-price-card::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg, rgba(255,255,255,.12) 0%, transparent 60%);
  pointer-events:none;
}
.sys-price-card:hover { transform:translateY(-8px); box-shadow:var(--s3), var(--glow-pink); }
.sys-price-card.featured {
  background:linear-gradient(135deg, #ff8ecf, #be63ff 58%, #79d6ff 100%);
  box-shadow:0 10px 36px rgba(111,43,168,.34);
}
.sys-price-card.extend {
  background: var(--g-gold);
  box-shadow:0 10px 36px rgba(115,208,255,.35);
}

.sys-pg   { display:block; font-size:1.4rem; font-weight:500; opacity:.85; margin-bottom:8px; }
.sys-amount { font-size:1.5rem; line-height:1; margin:4px 0 10px; }
.sys-amount strong { display:block; font-size:3.6rem; font-weight:900; line-height:1; }
.sys-pnote { font-size:1.2rem; opacity:.80; }
.sys-tax-note { font-size:1.25rem; color:var(--tx2); margin:0; }

/* Drink menu 3-column grid */
.drink-menu-wrap {
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
}
.drink-cat-card {
  background: var(--card);
  border:1px solid var(--card-b);
  border-radius:var(--r);
  padding:28px 24px;
  box-shadow:var(--s1);
  transition:transform .2s, box-shadow .2s;
}
.drink-cat-card:hover { transform:translateY(-5px); box-shadow:var(--s2); }
.drink-cat-head {
  display:flex; align-items:center; gap:10px;
  margin-bottom:18px; padding-bottom:14px;
  border-bottom:2px solid rgba(196,67,255,.16);
}
.drink-cat-icon { font-size:2.2rem; flex-shrink:0; }
.drink-cat-name {
  font-size:1.4rem; font-weight:700;
  color:var(--pink-dark); margin:0; line-height:1.3;
}
.order-card .drink-cat-name { color:#8c2fc8; }

.drink-item-list { list-style:none; margin:0; padding:0; }
.drink-item-list li {
  display:flex; align-items:center; justify-content:space-between;
  font-size:1.3rem; color:var(--tx);
  padding:8px 0; border-bottom:1px solid rgba(196,67,255,.10);
}
.drink-item-list li:last-child { border-bottom:none; }
.drink-plus {
  font-size:1.15rem; font-weight:600; color:var(--pink);
  background:rgba(196,67,255,.12); padding:2px 10px; border-radius:20px;
}
.order-price { font-size:1.35rem; font-weight:700; color:#7d31cb; }

/* ============================================================
   GALLERY
============================================================ */
.gallery-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:12px; margin-bottom:20px;
  border-radius:var(--r); overflow:hidden;
}
.gallery-grid img {
  width:100%; height:230px;
  object-fit:cover; display:block;
  transition:transform .4s, filter .4s;
  filter:brightness(.95) saturate(1.1);
}
.gallery-grid img:hover { transform:scale(1.05); filter:brightness(1.05) saturate(1.25); }
.gallery-caption {
  text-align:center; font-size:1.35rem; color:var(--tx2); line-height:1.85;
}

/* ============================================================
   NEWS
============================================================ */
.news-list { display:flex; flex-direction:column; gap:12px; }
.news-item {
  display:flex; align-items:center; gap:14px;
  background:var(--card); border-radius:50px;
  padding:14px 28px;
  border:1px solid rgba(196,67,255,.16);
  box-shadow:var(--s0);
  transition:box-shadow .2s, transform .2s;
  min-width:0;
}
.news-item:hover { box-shadow:var(--s2); transform:translateX(4px); }
.news-badge {
  background:var(--g-crimson); color:#fff;
  padding:4px 16px; border-radius:50px;
  font-size:1.15rem; font-weight:600;
  white-space:nowrap; flex-shrink:0;
}
.news-date { font-size:1.2rem; color:var(--tx2); white-space:nowrap; flex-shrink:0; }
.news-link { flex:1; font-size:1.35rem; color:var(--tx); transition:color .2s; }
.news-link:hover { color:var(--pink); }
.news-arrow { font-size:1.8rem; color:var(--pink-dark); flex-shrink:0; }

/* ============================================================
   ACCESS  —  2-column: cards + map
============================================================ */
.access-layout {
  display:grid; grid-template-columns:1fr 1.5fr;
  gap:28px; align-items:start;
}
.access-info-col { display:flex; flex-direction:column; gap:14px; }
.access-card {
  display:flex; align-items:flex-start; gap:14px;
  background:var(--card);
  border:1px solid var(--card-b);
  border-radius:var(--r-sm);
  padding:18px 20px;
  box-shadow:var(--s0);
  transition:box-shadow .2s, transform .2s;
}
.access-card:hover { box-shadow:var(--s1); transform:translateX(3px); }
.access-icon { font-size:2.2rem; flex-shrink:0; line-height:1; margin-top:2px; }
.access-text h4 {
  font-size:1.35rem; font-weight:700; color:var(--pink-dark); margin:0 0 4px;
}
.access-text p { font-size:1.35rem; color:var(--tx); margin:0; line-height:1.85; }
.access-text p small { font-size:1.15rem; color:var(--tx2); }
.access-text a { color:var(--pink-dark); font-weight:600; }
.access-text a:hover { color:var(--pink); }
.access-map-wrap {
  border-radius:var(--r); overflow:hidden;
  box-shadow:var(--s2), 0 0 0 4px rgba(196,67,255,.18);
}
.access-map-wrap iframe { width:100%; height:380px; border:none; display:block; }

/* ============================================================
   RECRUIT
============================================================ */
.recruit-section {
  background: linear-gradient(150deg, rgba(255,235,251,.96) 0%, rgba(235,245,255,.98) 52%, rgba(245,239,255,.98) 100%);
}

.recruit-headline { text-align:center; margin-bottom:44px; }
.recruit-catch {
  font-size:2.7rem; font-weight:900;
  color:var(--pink-dark); line-height:1.45;
  margin-bottom:10px;
}
.recruit-sub-catch { font-size:1.5rem; color:var(--tx2); letter-spacing:.06em; margin:0; }

.recruit-benefits-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:18px; margin-bottom:44px;
}
.benefit-card {
  display:flex; align-items:flex-start; gap:14px;
  background:var(--card);
  border:1px solid var(--card-b);
  border-radius:var(--r-sm);
  padding:22px 18px;
  box-shadow:var(--s0);
  transition:transform .25s, box-shadow .25s;
}
.benefit-card:hover { transform:translateY(-5px); box-shadow:var(--s2); }
.benefit-icon { font-size:2.6rem; flex-shrink:0; line-height:1; }
.benefit-body { flex:1; }
.benefit-title { font-size:1.45rem; font-weight:700; color:var(--tx); margin:0 0 4px; }
.benefit-sub   { font-size:1.2rem; color:var(--tx2); margin:0; }

.recruit-cta-area { text-align:center; margin-bottom:40px; }
.recruit-cta-btn { font-size:1.75rem !important; padding:16px 56px !important; }

.bottom-link-row {
  display:flex; justify-content:center; gap:12px; flex-wrap:wrap;
}
.bottom-link-btn {
  display:flex; flex-direction:column; align-items:center; gap:6px;
  background:var(--card); border:1px solid var(--card-b);
  border-radius:var(--r-sm); padding:14px 24px;
  font-size:1.3rem; color:var(--tx); text-decoration:none; min-width:96px;
  transition:background .2s, transform .2s, box-shadow .2s;
  box-shadow:var(--s0);
}
.bottom-link-btn:hover { background:rgba(196,67,255,.10); transform:translateY(-3px); box-shadow:var(--s1); }
.bottom-link-btn span:first-child { font-size:1.9rem; }

/* WP content fallback */
.wp-content-inner {
  background:var(--card); border-radius:var(--r);
  padding:32px 36px; box-shadow:var(--s1);
  border:1px solid var(--card-b);
  font-size:1.45rem; line-height:1.9; color:var(--tx);
}
.wp-content-inner p  { margin-bottom:1.2em; }
.wp-content-inner a  { color:var(--pink-dark); font-weight:600; }
.wp-content-inner img { max-width:100%; border-radius:var(--r-sm); }

/* ============================================================
   FOOTER
============================================================ */
.footer-wave { display:block; width:100%; line-height:0; overflow:hidden; }
.footer-wave svg { display:block; width:100%; }

footer.site-footer {
  background: linear-gradient(160deg, #2a0f4c 0%, #572597 55%, #45a8df 100%);
  color:rgba(255,255,255,.85);
  text-align:center; padding:52px 20px 96px;
  position:relative;
}
footer.site-footer::before {
  content:''; display:block; position:absolute;
  top:0; left:0; right:0; height:3px;
  background: var(--g-gold);
}
.site-footer .site-info { max-width:700px; margin:0 auto; }
.footer-logo { margin-bottom:18px; }
.footer-logo img {
  max-width:110px; margin:0 auto;
  filter:brightness(0) invert(1) drop-shadow(0 0 10px rgba(255,150,200,.5));
  opacity:.9;
}
.footer-shop-name {
  font-size:1.6rem; font-weight:700; letter-spacing:.2em;
  color:rgba(255,255,255,.9); margin-bottom:8px;
  font-family:'Cormorant Garamond',serif;
}
.site-footer p { font-size:1.3rem; color:rgba(255,255,255,.65); margin-bottom:.6em; line-height:1.85; }
.footer-sep { opacity:.5; margin:0 6px; }
.site-footer a { color:var(--pink-light); }
.site-footer a:hover { color:#fff; }

.footer-sns { display:flex; justify-content:center; gap:12px; margin:18px 0; }
.footer-sns-btn {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.12);
  color:rgba(255,255,255,.88) !important;
  padding:8px 20px; border-radius:50px; font-size:1.3rem; font-weight:600;
  border:1px solid rgba(255,255,255,.2);
  transition:background .2s, transform .2s;
}
.footer-sns-btn:hover { background:rgba(255,255,255,.2); transform:translateY(-2px); }
.footer-copy { font-size:1.2rem !important; color:rgba(255,255,255,.45) !important; margin-top:20px; }

/* ============================================================
   MOBILE FIXED BOTTOM NAV
============================================================ */
.mobile-bottom-nav {
  display:none;
  position:fixed; bottom:0; left:0; right:0;
  background:rgba(255,246,255,.96);
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
  border-top:1px solid rgba(196,67,255,.20);
  z-index:200; box-shadow:0 -4px 20px rgba(0,0,0,.10);
}
.mob-nav-item {
  flex:1; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:2px;
  padding:10px 6px; color:var(--pink-dark);
  text-decoration:none;
  border-right:1px solid rgba(196,67,255,.14);
  transition:background .2s;
}
.mob-nav-item:last-child { border-right:none; }
.mob-nav-item:hover { background:rgba(196,67,255,.12); color:var(--pink-dark); }
.mob-nav-icon  { font-size:2rem; line-height:1; }
.mob-nav-label { font-size:1.1rem; font-weight:700; }

/* ============================================================
   OTHER PAGES
============================================================ */
#primary.row-fluid { max-width:1100px; margin:0 auto; padding:0 24px 72px; }
#content { padding:0 !important; margin:40px 0 0 !important; width:100% !important; }
article {
  background:var(--card); border-radius:var(--r);
  padding:32px; margin-bottom:28px;
  border:1px solid var(--card-b); box-shadow:var(--s1);
}
article .title   { color:var(--tx); font-size:2.4rem; font-weight:700; text-align:center; }
article .the-content a   { font-weight:700; color:var(--pink-dark); }
article .the-content p   { color:var(--tx); }
article .the-content img { width:100%; height:auto; border-radius:var(--r-sm); }

/* ============================================================
   MEDIA QUERIES  —  Desktop first transitions
============================================================ */

/* ─── Desktop ≥ 768px ─── */
@media (min-width: 768px) {
  .hamburger   { display:none; }
  .header-cta-wrap { display:flex; align-items:center; }

  /* Hero */
  .hero-img { height:500px; }
  .hero-overlay {
    display:block;
    position:absolute; bottom:0; left:0; right:0;
    background: var(--g-hero);
    padding:86px 78px 56px;
    text-align:center; color:#fff;
  }
  .hero-overlay .hero-eyecatch  { color:rgba(255,255,255,.85); font-size:1.55rem; }
  .hero-overlay .hero-title     {
    color:#fff;
    font-size:4.8rem;
    text-shadow:0 2px 30px rgba(202,126,255,.55);
    margin-bottom:18px;
  }
  .hero-overlay .hero-subcatch  { color:rgba(255,255,255,.82); font-size:1.45rem; margin-bottom:24px; }
  .hero-overlay .hero-time-badge { margin:12px 0 36px; padding:14px 62px; }
  .hero-overlay .price-row { gap:16px; margin-bottom:24px; }
  .hero-overlay .price-box { padding:26px 30px; min-width:166px; }
  .hero-overlay .tax-note       { color:rgba(255,255,255,.70); }
  .hero-overlay .hero-time-badge {
    box-shadow:var(--glow-pink), var(--s2);
  }
  .hero-mobile-content { display:none; }
  .hero-cta-row { background:linear-gradient(180deg, rgba(255,241,252,.92) 0%, rgba(235,245,255,.9) 100%); padding:28px 40px 48px; }
}

/* ─── Mobile < 768px ─── */
@media (max-width: 767px) {
  body {
    background-attachment: scroll;
    background-position: center top;
  }

  .sec-head {
    gap:10px;
    margin-bottom:30px;
  }
  .sec-title {
    font-size:1.95rem;
    letter-spacing:.12em;
  }
  .sec-deco {
    display:none;
  }

  .hamburger { display:block; }
  .header-cta-wrap { display:none; }
  .header-logo {
    position:absolute; left:50%; transform:translateX(-50%);
  }
  .header-logo img { height:40px; }
  .header-inner { padding:0 16px; }

  #header-menu {
    display:none; position:absolute; top:100%; left:0; right:0;
    background:rgba(255,246,255,.96);
    backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
    box-shadow:0 8px 24px rgba(0,0,0,.12); z-index:99;
    border-bottom:2px solid rgba(196,67,255,.20);
    max-height:72vh;
    overflow-y:auto;
  }
  #header-menu ul { flex-direction:column; display:block; }
  #header-menu ul li { display:block; text-align:center; border-top:1px solid rgba(196,67,255,.14); }
  #header-menu ul li a { padding:14px 0; font-size:1.4rem; }
  #header-menu ul li a::after { display:none; }
  .menu-main-nav-container,.menu-main-container { float:none; width:100%; display:block; }

  .hero-overlay { display:none !important; }
  .hero-mobile-content { display:block; }
  .hero-img { height:auto; max-height:270px; object-fit:cover; }
  .hero-title { font-size:2.7rem; }

  .price-row { gap:10px; }
  .price-box {
    min-width:0;
    width:calc(50% - 6px);
    padding:20px 14px;
  }
  .price-val strong { font-size:2.1rem; }

  .hero-cta-row {
    gap:10px;
    padding:20px 16px 28px;
  }
  .cta-btn {
    width:100%;
    max-width:420px;
    font-size:1.45rem;
    padding:14px 18px;
  }

  .features-section,.gallery-section,.news-section { padding:44px 16px; }
  .system-section,.access-section,.recruit-section  { padding:44px 18px; margin:12px 0; border-radius:0; }

  .features-grid { grid-template-columns:1fr; gap:12px; }
  .feature-card  { padding:28px 14px 22px; }

  .sys-price-grid { grid-template-columns:1fr; max-width:280px; }
  .drink-menu-wrap { grid-template-columns:1fr; gap:14px; }

  .gallery-grid { grid-template-columns:1fr 1fr; gap:8px; }
  .gallery-grid img { height:120px; }

  .news-item { padding:12px 16px; border-radius:12px; flex-wrap:wrap; gap:8px; }
  .news-link {
    flex-basis:100%;
    overflow-wrap:anywhere;
  }
  .news-arrow {
    margin-left:auto;
  }

  .access-layout { grid-template-columns:1fr; }
  .access-map-wrap iframe { height:270px; }

  .recruit-catch { font-size:2.3rem; }
  .recruit-benefits-grid { grid-template-columns:1fr; gap:12px; }
  .benefit-card { padding:16px 14px; }
  .recruit-cta-btn { font-size:1.5rem !important; padding:14px 32px !important; }

  .mobile-bottom-nav { display:flex; padding-bottom:env(safe-area-inset-bottom, 0px); }
  body { padding-bottom:66px; }
  footer.site-footer { padding-bottom:90px; }

  #primary.row-fluid { padding:0 12px 48px; }
}

/* ─── Tablet 768–1024px ─── */
@media (min-width:768px) and (max-width:1024px) {
  .hero-img { height:390px; }
  .features-section,.gallery-section,.news-section { padding:52px 22px; }
  .system-section,.access-section,.recruit-section  { padding:52px 28px; }
  .features-grid { grid-template-columns:repeat(2,1fr); }
  .drink-menu-wrap   { grid-template-columns:1fr 1fr; }
  .gallery-grid { grid-template-columns:repeat(2,1fr); }
  .recruit-benefits-grid { grid-template-columns:repeat(2,1fr); }
  .access-layout { grid-template-columns:1fr; }
  .access-map-wrap iframe { height:320px; }
}

/* ─── Large ≥ 1280px ─── */
@media (min-width:1280px) {
  .hero-img { height:560px; }
  .gallery-grid img { height:260px; }
  .hero-overlay { padding:104px 96px 62px; }
  .hero-overlay .hero-title { font-size:5.4rem; }
}

/* ============================================================
   BLOG — 共通ラッパー
============================================================ */
.blog-index-wrapper,
.single-post-wrapper {
  max-width: var(--mw);
  margin: 0 auto;
  padding: 60px 28px 100px;
}
.blog-index-inner { width: 100%; }
.blog-sec-head { margin-bottom: 32px; }

/* ============================================================
   BLOG — カテゴリーナビ
============================================================ */
.blog-cat-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  margin-bottom: 44px;
}
.blog-cat-btn {
  display: inline-block;
  padding: 7px 20px;
  border-radius: 50px;
  font-size: 1.3rem;
  font-weight: 600;
  color: var(--tx2);
  background: var(--card);
  border: 1.5px solid rgba(196,67,255,.22);
  box-shadow: var(--s0);
  transition: background .2s, color .2s, box-shadow .2s, transform .2s;
  text-decoration: none;
}
.blog-cat-btn:hover,
.blog-cat-btn.active {
  background: var(--g-crimson);
  color: #fff;
  border-color: transparent;
  box-shadow: var(--glow-pink);
  transform: translateY(-2px);
}

/* ============================================================
   BLOG — カード グリッド
============================================================ */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.related-grid { margin-top: 0; }

.blog-post-card {
  background: var(--card);
  border: 1px solid var(--card-b);
  border-radius: var(--r);
  overflow: hidden;
  box-shadow: var(--s1);
  display: flex;
  flex-direction: column;
  transition: transform .25s, box-shadow .25s;
}
.blog-post-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--s3);
}

/* サムネイル */
.blog-card-img-link { display: block; text-decoration: none; }
.blog-card-img-wrap {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16 / 9;
  background: linear-gradient(135deg, var(--lavender-1), var(--sky-1));
}
.blog-card-img-wrap img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .4s ease;
}
.blog-post-card:hover .blog-card-img-wrap img { transform: scale(1.05); }

/* サムネイルなし */
.blog-card-noimg {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  background: var(--g-crimson);
}
.blog-card-noimg span {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2.8rem; font-weight: 700;
  color: rgba(255,255,255,.75);
  letter-spacing: .1em;
}

/* カテゴリーバッジ */
.blog-card-cat {
  position: absolute;
  top: 10px; left: 10px;
  background: var(--g-crimson);
  color: #fff;
  font-size: 1.1rem; font-weight: 700;
  padding: 3px 12px;
  border-radius: 50px;
  letter-spacing: .06em;
  pointer-events: none;
}

/* テキストエリア */
.blog-card-text {
  padding: 20px 22px 24px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}
.blog-card-date {
  font-size: 1.2rem;
  font-family: 'Quicksand', sans-serif;
  font-weight: 600;
  color: var(--pink);
}
.blog-card-title {
  font-size: 1.55rem;
  font-weight: 700;
  line-height: 1.55;
  color: var(--tx);
  margin: 0;
}
.blog-card-title a {
  color: var(--tx);
  text-decoration: none;
  transition: color .2s;
}
.blog-card-title a:hover { color: var(--pink); }

.blog-card-excerpt {
  font-size: 1.35rem;
  color: var(--tx2);
  line-height: 1.75;
  flex: 1;
}
.blog-card-more {
  display: inline-block;
  margin-top: 6px;
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--pink-dark);
  text-decoration: none;
  transition: color .2s, gap .2s;
}
.blog-card-more:hover { color: var(--pink); }

/* ページネーション */
.blog-pagination { margin-top: 56px; text-align: center; }
.blog-pagination .nav-links {
  display: flex; justify-content: center; gap: 8px; flex-wrap: wrap;
}
.blog-pagination .page-numbers {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 42px; height: 42px; padding: 0 12px;
  border-radius: var(--r-sm);
  background: var(--card);
  border: 1.5px solid rgba(196,67,255,.20);
  color: var(--tx2);
  font-size: 1.4rem; font-weight: 600;
  text-decoration: none;
  box-shadow: var(--s0);
  transition: background .2s, color .2s, box-shadow .2s;
}
.blog-pagination .page-numbers.current,
.blog-pagination .page-numbers:hover {
  background: var(--g-crimson);
  color: #fff;
  border-color: transparent;
  box-shadow: var(--glow-pink);
}
.blog-no-posts {
  text-align: center;
  font-size: 1.6rem;
  color: var(--tx2);
  padding: 60px 0;
}

/* ============================================================
   SINGLE POST — レイアウト
============================================================ */
.post-article {
  max-width: 780px;
  margin: 0 auto;
}

/* パンくず */
.post-breadcrumb {
  max-width: 780px;
  margin: 0 auto 28px;
}
.breadcrumb-list {
  display: flex; flex-wrap: wrap; align-items: center; gap: 4px;
  list-style: none; margin: 0; padding: 0;
  font-size: 1.25rem; color: var(--tx2);
}
.bc-item a { color: var(--tx2); text-decoration: none; transition: color .2s; }
.bc-item a:hover { color: var(--pink); }
.bc-current { color: var(--tx); font-weight: 600; }
.bc-sep { color: rgba(107,78,149,.45); font-size: 1.1rem; }

/* 記事ヘッダー */
.post-header {
  background: var(--g-section);
  border: 1px solid rgba(196,67,255,.18);
  border-radius: var(--r);
  padding: 36px 40px 30px;
  margin-bottom: 28px;
  box-shadow: var(--s0);
  position: relative;
  overflow: hidden;
}
.post-header::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 4px;
  background: var(--g-crimson);
}
.post-header-meta {
  display: flex; flex-wrap: wrap; align-items: center; gap: 10px;
  margin-bottom: 16px;
}
.post-cat-badge {
  display: inline-block;
  background: var(--g-crimson);
  color: #fff;
  font-size: 1.15rem; font-weight: 700;
  padding: 4px 14px; border-radius: 50px;
  text-decoration: none;
  transition: opacity .2s;
}
.post-cat-badge:hover { opacity: .82; color: #fff; }
.post-header-date {
  font-size: 1.25rem; font-family: 'Quicksand', sans-serif;
  font-weight: 600; color: var(--tx2);
}
.post-header-updated {
  font-size: 1.2rem; color: var(--tx2); opacity: .75;
}
.post-title {
  font-size: 2.6rem; font-weight: 900;
  line-height: 1.45; color: var(--tx);
  margin: 0 0 14px;
  font-family: 'Quicksand', 'Noto Sans JP', sans-serif;
}
.post-read-time {
  font-size: 1.2rem; color: var(--tx2);
  display: inline-flex; align-items: center; gap: 6px;
  margin: 0;
  opacity: .8;
}

/* アイキャッチ */
.post-thumbnail {
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 32px;
  box-shadow: var(--s2);
}
.post-thumbnail img { width: 100%; height: auto; }

/* ============================================================
   目次 (TOC)
============================================================ */
.post-toc {
  background: linear-gradient(135deg, rgba(255,213,244,.55) 0%, rgba(220,235,255,.55) 100%);
  border: 1.5px solid rgba(196,67,255,.22);
  border-radius: var(--r);
  padding: 24px 28px 28px;
  margin-bottom: 40px;
  box-shadow: var(--s0);
}
.post-toc-head {
  font-size: 1.5rem; font-weight: 800;
  color: var(--pink-dark);
  margin-bottom: 14px;
  display: flex; align-items: center; gap: 8px;
  letter-spacing: .05em;
}
.post-toc-list {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: 4px;
  counter-reset: toc-counter;
}
.post-toc-item {
  counter-increment: toc-counter;
}
.post-toc-item a {
  display: flex; align-items: baseline; gap: 10px;
  font-size: 1.4rem; color: var(--tx2);
  text-decoration: none; padding: 5px 0;
  border-bottom: 1px dashed rgba(196,67,255,.18);
  transition: color .2s;
}
.post-toc-item a::before {
  content: counter(toc-counter) ".";
  flex-shrink: 0;
  font-family: 'Quicksand', sans-serif;
  font-weight: 700; font-size: 1.2rem;
  color: var(--pink);
  min-width: 22px;
}
.post-toc-item a:hover { color: var(--pink); }
.post-toc-h3 { padding-left: 20px; }
.post-toc-h3 a { font-size: 1.3rem; }

/* ============================================================
   本文スタイル
============================================================ */
.post-content {
  font-size: 1.65rem;
  line-height: 1.95;
  color: var(--tx);
}
.post-content p { margin-bottom: 1.6em; }

.post-content h2 {
  font-size: 2.1rem; font-weight: 800;
  color: var(--tx); line-height: 1.4;
  margin: 56px 0 20px;
  padding: 16px 20px 16px 24px;
  background: var(--g-section);
  border-left: 5px solid;
  border-image: var(--g-crimson) 1;
  border-radius: 0 var(--r-xs) var(--r-xs) 0;
  box-shadow: var(--s0);
}
.post-content h3 {
  font-size: 1.8rem; font-weight: 700;
  color: var(--pink-dark); line-height: 1.45;
  margin: 40px 0 14px;
  padding-bottom: 8px;
  border-bottom: 2px solid rgba(196,67,255,.25);
}
.post-content h4 {
  font-size: 1.6rem; font-weight: 700;
  color: var(--tx); margin: 28px 0 10px;
}
.post-content ul,
.post-content ol {
  padding-left: 1.8em;
  margin-bottom: 1.6em;
}
.post-content li { margin-bottom: .5em; }
.post-content ul li::marker { color: var(--pink); }
.post-content blockquote {
  margin: 28px 0;
  padding: 18px 24px;
  background: rgba(196,67,255,.06);
  border-left: 4px solid var(--pink);
  border-radius: 0 var(--r-xs) var(--r-xs) 0;
  color: var(--tx2);
  font-size: 1.55rem;
}
.post-content blockquote p { margin: 0; }
.post-content strong { color: var(--pink-dark); font-weight: 700; }
.post-content a {
  color: var(--pink-dark);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color .2s;
}
.post-content a:hover { color: var(--pink); }
.post-content img {
  border-radius: var(--r-sm);
  box-shadow: var(--s1);
  margin: 16px auto;
}
.post-content table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 2em;
  font-size: 1.5rem;
}
.post-content th {
  background: var(--g-crimson);
  color: #fff; padding: 10px 14px;
  text-align: left;
}
.post-content td {
  padding: 10px 14px;
  border-bottom: 1px solid rgba(196,67,255,.15);
}
.post-content tr:nth-child(even) td { background: rgba(196,67,255,.04); }

/* ============================================================
   タグ / シェア / 前後ナビ
============================================================ */
.post-tags {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin: 40px 0 32px;
}
.post-tag {
  display: inline-block;
  padding: 5px 14px;
  background: var(--card);
  border: 1.5px solid rgba(196,67,255,.25);
  border-radius: 50px;
  font-size: 1.25rem; color: var(--tx2);
  text-decoration: none;
  transition: background .2s, color .2s;
}
.post-tag:hover { background: var(--g-crimson); color: #fff; border-color: transparent; }

/* シェアボタン */
.post-share {
  background: var(--g-section);
  border: 1px solid rgba(196,67,255,.18);
  border-radius: var(--r);
  padding: 24px 28px;
  margin-bottom: 36px;
  box-shadow: var(--s0);
  text-align: center;
}
.post-share-label {
  font-size: 1.3rem; font-weight: 700; color: var(--tx2);
  margin-bottom: 14px; letter-spacing: .08em;
}
.post-share-btns { display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; }
.share-btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 10px 24px; border-radius: 50px;
  font-size: 1.35rem; font-weight: 700;
  color: #fff; text-decoration: none;
  transition: transform .2s, box-shadow .2s;
}
.share-btn:hover { transform: translateY(-2px); color: #fff; }
.share-x    { background: #000; }
.share-fb   { background: #1877f2; }
.share-line { background: #06c755; }

/* 前後ナビ */
.post-nav {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 14px; margin-bottom: 48px;
}
.post-nav-prev a,
.post-nav-next a {
  display: flex; flex-direction: column; gap: 6px;
  padding: 18px 20px;
  background: var(--card);
  border: 1px solid var(--card-b);
  border-radius: var(--r-sm);
  box-shadow: var(--s0);
  text-decoration: none;
  transition: transform .2s, box-shadow .2s;
}
.post-nav-prev a:hover,
.post-nav-next a:hover { transform: translateY(-3px); box-shadow: var(--s1); }
.post-nav-next a { text-align: right; }
.post-nav-label { font-size: 1.15rem; color: var(--pink); font-weight: 700; }
.post-nav-title { font-size: 1.4rem; color: var(--tx); font-weight: 600; line-height: 1.5; }

/* 関連記事 */
.related-posts {
  margin-top: 56px;
  padding-top: 56px;
  border-top: 2px solid rgba(196,67,255,.14);
}

/* ブログ一覧へ戻るボタン */
.post-back-btn-wrap {
  text-align: center;
  margin: 48px 0 0;
}
.post-back-btn {
  font-size: 1.5rem !important;
  padding: 14px 44px !important;
}

/* コメント */
.post-comments-wrap {
  margin-top: 56px;
  padding-top: 48px;
  border-top: 2px solid rgba(196,67,255,.14);
}

/* ============================================================
   BLOG — レスポンシブ
============================================================ */
@media (max-width: 768px) {
  .blog-index-wrapper,
  .single-post-wrapper { padding: 40px 16px 80px; }

  .blog-grid { grid-template-columns: 1fr; }

  .post-header { padding: 24px 20px 20px; }
  .post-title  { font-size: 2rem; }

  .post-nav { grid-template-columns: 1fr; }
  .post-nav-next a { text-align: left; }

  .post-toc { padding: 18px 18px 22px; }

  .post-content h2 { font-size: 1.8rem; padding: 12px 16px 12px 18px; }
  .post-content h3 { font-size: 1.6rem; }
}
@media (min-width: 769px) and (max-width: 1024px) {
  .blog-grid { grid-template-columns: repeat(2, 1fr); }
}
