/* =============================================
   地球屋テーマ
   深い木目 × ランプのぬくもり × ステンドグラス
   アンティーク・ゴールド × 苔グリーン × 琥珀
   ============================================= */
:root {
  /* 木材・土・大地 */
  --wood-deep:  #2A1E0F;   /* 古い木の床、最暗部 */
  --wood-dark:  #3D2B1A;   /* 重厚な木目 */
  --wood-mid:   #6B4A28;   /* ウォールナット */
  --wood-warm:  #8B6035;   /* チーク材 */
  --wood-light: #C4924A;   /* 明るい木肌 */
  --wood-pale:  #E8D0A0;   /* 白木・削りたて */
  --wood-cream: #F5EDD8;   /* 古い紙・羊皮紙 */
  --wood-foam:  #FBF6EC;   /* 蜜蝋の白 */

  /* ランプの灯火・琥珀 */
  --amber:      #C4872A;   /* ランプの灯火 */
  --amber-l:    #D4A84A;   /* 揺れる炎 */
  --amber-pale: #EDD898;   /* 蜜色 */
  --amber-mist: #FAF0D0;   /* ランプに照らされた空気 */

  /* 苔・グリーン */
  --moss:       #2A4030;   /* 深い苔 */
  --moss-mid:   #3D5A44;   /* 苔グリーン */
  --moss-light: #587060;   /* 薄い苔 */
  --moss-pale:  #90B898;   /* 若草 */
  --moss-mist:  #D8EAD8;   /* 朝露の葉 */
  --moss-foam:  #EFF6EF;   /* 薄いグリーン */

  /* ステンドグラスアクセント */
  --stained-r:  rgba(184,90,42,0.55);
  --stained-g:  rgba(74,106,68,0.50);
  --stained-b:  rgba(74,102,154,0.50);
  --stained-a:  rgba(196,135,42,0.55);

  /* テキスト */
  --ink:        #1A1208;
  --ink-m:      #3A2A18;
  --ink-s:      #6A5038;
  --ink-p:      #9A8060;

  /* シャドウ */
  --sh-sm:  0 2px 8px rgba(42,30,15,0.15);
  --sh-md:  0 4px 20px rgba(42,30,15,0.22);
  --sh-lg:  0 8px 40px rgba(42,30,15,0.30);
  --sh-glow:0 0 20px rgba(196,135,42,0.20);
  --parchment:      #D4B878;
  --parchment-dark: #C8A858;
  --parchment-aged: #B89840;
  --parchment-pale: #E8D898;
  --parchment-warm: #D4B868;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
img[width]{max-width:100%;height:auto;}
.hdr-logo img[width]{max-width:none;width:auto;height:38px;}
html{scroll-behavior:smooth;}
body{
  font-family:'Noto Serif JP','Hiragino Mincho ProN','Yu Mincho',serif;
  background:var(--parchment);
  color:var(--ink);
  overflow-x:hidden;
  line-height:1.85;
  cursor:url('/wp-content/themes/tempo-rubato/images/svg/cursor-pen.svg') 2 2,crosshair;
}

/* 全体にペーパーテクスチャ */
body::before{
  content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:url('/wp-content/themes/tempo-rubato/images/svg/texture-paper.svg');
  background-repeat:repeat;background-size:300px;
  opacity:0.8;mix-blend-mode:multiply;
}

/* ── HEADER ── */
header{
  position:fixed;top:0;left:0;right:0;z-index:600;
  background:var(--wood-dark);
  background-image:
    repeating-linear-gradient(90deg,
      transparent 0,transparent 3px,
      rgba(255,255,255,0.015) 3px,rgba(255,255,255,0.015) 4px,
      transparent 4px,transparent 18px,
      rgba(0,0,0,0.04) 18px,rgba(0,0,0,0.04) 19px
    );
  border-bottom:3px solid var(--amber);
  box-shadow:var(--sh-md),0 0 30px rgba(196,135,42,0.15);
  height:66px;padding:0 48px;
  display:flex;align-items:center;justify-content:space-between;
  transition:box-shadow 0.3s;
}
/* ステンドグラス帯 */
header::after{
  content:'';position:absolute;bottom:-8px;left:0;right:0;
  height:6px;pointer-events:none;
  background:linear-gradient(90deg,
    var(--stained-r) 0%,var(--stained-r) 8%,
    transparent 8%,transparent 9%,
    var(--stained-g) 9%,var(--stained-g) 17%,
    transparent 17%,transparent 18%,
    var(--stained-b) 18%,var(--stained-b) 26%,
    transparent 26%,transparent 27%,
    var(--stained-a) 27%,var(--stained-a) 36%,
    transparent 36%,transparent 37%,
    var(--stained-g) 37%,var(--stained-g) 45%,
    transparent 45%,transparent 46%,
    var(--stained-r) 46%,var(--stained-r) 55%,
    transparent 55%,transparent 56%,
    var(--stained-b) 56%,var(--stained-b) 65%,
    transparent 65%,transparent 66%,
    var(--stained-a) 66%,var(--stained-a) 75%,
    transparent 75%,transparent 76%,
    var(--stained-g) 76%,var(--stained-g) 85%,
    transparent 85%,transparent 86%,
    var(--stained-r) 86%,var(--stained-r) 100%
  );
}
.hdr-logo{display:flex;align-items:center;gap:12px;}
.hdr-logo img{height:38px;filter:drop-shadow(0 2px 4px rgba(0,0,0,0.5));}
.hdr-logo-text{
  font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;
  font-size:1.11rem;font-weight:700;
  color:var(--wood-cream);line-height:1.3;letter-spacing:0.06em;
  text-shadow:0 1px 4px rgba(0,0,0,0.4);
}
.hdr-logo-text span{
  display:block;font-size:0.72rem;font-weight:300;
  color:rgba(245,237,216,0.75);letter-spacing:0.18em;margin-top:2px;
}
nav[aria-label]{display:flex;align-items:center;gap:26px;}
nav a{
  text-decoration:none;font-size:0.86rem;letter-spacing:0.09em;
  color:rgba(245,237,216,0.82);font-weight:300;
  transition:color 0.2s;position:relative;
}
nav a::after{
  content:'';position:absolute;bottom:-3px;left:0;right:0;
  height:1.5px;
  background:linear-gradient(90deg,var(--amber),var(--amber-l));
  transform:scaleX(0);transition:transform 0.25s;
}
nav a:hover{color:var(--amber-pale);}
nav a:hover::after{transform:scaleX(1);}
.nav-cta{
  background:transparent!important;
  color:var(--amber-pale)!important;
  padding:8px 20px;font-size:0.86rem!important;
  font-weight:600!important;letter-spacing:0.1em;
  border:1.5px solid var(--amber)!important;
  border-radius:2px!important;
  transition:all 0.2s!important;
  box-shadow:0 0 8px rgba(196,135,42,0.2);
}
.nav-cta:hover{
  background:var(--amber)!important;
  color:var(--wood-dark)!important;
  box-shadow:0 0 16px rgba(196,135,42,0.4)!important;
}
.nav-cta::after{display:none!important;}

/* ── ハンバーガーメニュー ── */
.hamburger{
  display:none;background:none;border:none;cursor:pointer;
  width:36px;height:26px;position:relative;z-index:610;padding:0;
}
.hamburger span{
  display:block;width:100%;height:3px;
  background:var(--wood-cream);border-radius:2px;
  position:absolute;left:0;transition:transform 0.3s,opacity 0.2s;
}
.hamburger span:nth-child(1){top:0;}
.hamburger span:nth-child(2){top:50%;transform:translateY(-50%);}
.hamburger span:nth-child(3){bottom:0;}
.hamburger.is-open span:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg);}
.hamburger.is-open span:nth-child(2){opacity:0;}
.hamburger.is-open span:nth-child(3){bottom:auto;top:50%;transform:translateY(-50%) rotate(-45deg);}

.mobile-menu{
  display:none;position:fixed;top:58px;left:0;right:0;z-index:590;
  background:var(--wood-dark);
  border-bottom:3px solid var(--amber);
  box-shadow:0 8px 24px rgba(0,0,0,0.4);
  padding:16px 0;flex-direction:column;
  max-height:calc(100vh - 58px);overflow-y:auto;
  transform:translateY(-100%);opacity:0;
  transition:transform 0.35s ease,opacity 0.3s ease;
}
.mobile-menu.is-open{display:flex;transform:translateY(0);opacity:1;}
.mobile-menu a{
  display:block;padding:14px 28px;
  color:var(--wood-cream);text-decoration:none;
  font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;
  font-size:1.02rem;letter-spacing:0.1em;font-weight:400;
  border-bottom:1px solid rgba(196,135,42,0.15);
  transition:background 0.2s;
}
.mobile-menu a:last-child{border-bottom:none;}
.mobile-menu a:hover,.mobile-menu a:active{background:rgba(196,135,42,0.1);}
.mm-cta{
  color:var(--amber-l)!important;font-weight:700!important;
  text-align:center;margin:8px 20px 0;padding:13px 24px!important;
  border:1px solid var(--amber)!important;border-radius:2px;
  border-bottom:1px solid var(--amber)!important;
}
.menu-overlay{
  display:none;position:fixed;inset:0;z-index:580;
  background:rgba(0,0,0,0.5);
}

/* モバイルCTA */
.mobile-cta{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:550;
  background:var(--wood-dark);
  border-top:2px solid var(--amber);
  box-shadow:0 -4px 20px rgba(42,30,15,0.3);
  padding:12px 24px;text-align:center;
}
.mobile-cta a{
  color:var(--wood-cream);text-decoration:none;
  font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;
  font-size:1.0rem;font-weight:700;letter-spacing:0.1em;
  display:flex;align-items:center;justify-content:center;gap:10px;
}
.mobile-cta a span{font-size:0.88rem;opacity:0.75;}

/* ── HERO ── */
#hero{
  min-height:100vh;position:relative;overflow:hidden;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding-top:66px;
  /* 地球屋の夜の空気感 */
  background:
    linear-gradient(160deg,
      #2A1E0F 0%,
      #3D2A14 25%,
      #2E2210 50%,
      #3A2A18 75%,
      #2A1E0E 100%);
}
/* 木目縦ライン */
.hero-wood{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:
    repeating-linear-gradient(88deg,
      transparent 0,transparent 40px,
      rgba(255,255,255,0.008) 40px,rgba(255,255,255,0.008) 41px,
      transparent 41px,transparent 80px,
      rgba(0,0,0,0.04) 80px,rgba(0,0,0,0.04) 81px
    ),
    repeating-linear-gradient(180deg,
      transparent 0,transparent 8px,
      rgba(255,255,255,0.008) 8px,rgba(255,255,255,0.008) 9px
    );
}
/* ランプの灯火グロー */
.hero-glow{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(ellipse 50% 60% at 20% 30%,rgba(196,135,42,0.18) 0%,transparent 55%),
    radial-gradient(ellipse 40% 50% at 80% 20%,rgba(184,90,42,0.12) 0%,transparent 50%),
    radial-gradient(ellipse 60% 40% at 50% 80%,rgba(42,64,48,0.15) 0%,transparent 55%);
}
/* ステンドグラス上部帯 */
.hero-stained{
  position:absolute;top:66px;left:0;right:0;z-index:2;pointer-events:none;
  height:32px;overflow:hidden;
}
.hero-stained img{width:100%;height:32px;object-fit:cover;display:block;}

/* 葉・蔦 */
.hero-leaves{position:absolute;inset:0;z-index:2;pointer-events:none;}
.hero-score-bottom{
  position:absolute;bottom:0;left:0;right:0;z-index:2;pointer-events:none;overflow:hidden;
}
.hero-score-bottom img{width:100%;height:auto;display:block;}

.hero-inner{
  position:relative;z-index:4;text-align:center;
  padding:40px 24px 80px;max-width:800px;width:100%;
}
/* 地球屋の窓枠・看板風カード */
.hero-card{
  background:rgba(42,30,15,0.75);
  backdrop-filter:blur(12px);
  border-radius:4px;
  padding:48px 52px 42px;
  /* 二重枠線：外＝ゴールド、内＝細め */
  border:2px solid var(--amber);
  outline:1px solid rgba(196,135,42,0.30);
  outline-offset:8px;
  box-shadow:var(--sh-lg),var(--sh-glow),inset 0 1px 0 rgba(255,255,255,0.05);
  position:relative;overflow:visible;
}
/* 四隅の真鍮金具風装飾 */
.hc-corner{
  position:absolute;width:16px;height:16px;
  border-color:var(--amber);border-style:solid;opacity:0.8;
}
.hc-corner.tl{top:-9px;left:-9px;border-width:2px 0 0 2px;}
.hc-corner.tr{top:-9px;right:-9px;border-width:2px 2px 0 0;}
.hc-corner.bl{bottom:-9px;left:-9px;border-width:0 0 2px 2px;}
.hc-corner.br{bottom:-9px;right:-9px;border-width:0 2px 2px 0;}
/* カード上部ラベル（古い看板文字風） */
.hero-card-label{
  position:absolute;top:-11px;left:50%;transform:translateX(-50%);
  font-family:'Crimson Text',serif;font-style:italic;
  font-size:0.72rem;letter-spacing:0.26em;
  color:var(--amber-pale);white-space:nowrap;
  background:rgba(42,30,15,0.9);padding:0 16px;
  opacity:0.85;
}
.hero-logo{width:min(500px,74vw);margin:8px auto 24px;display:block;filter:drop-shadow(0 6px 20px rgba(0,0,0,0.7)) drop-shadow(0 0 30px rgba(196,135,42,0.25));animation:logopulse 5s ease-in-out infinite;}
@keyframes logopulse{
  0%,100%{filter:drop-shadow(0 6px 20px rgba(0,0,0,0.7)) drop-shadow(0 0 30px rgba(196,135,42,0.22));}
  50%{filter:drop-shadow(0 6px 20px rgba(0,0,0,0.6)) drop-shadow(0 0 45px rgba(196,135,42,0.38));}
}
.hero-badge{
  display:inline-block;
  background:transparent;color:var(--moss-pale);
  border:1px solid rgba(144,184,152,0.45);
  font-size:0.8rem;letter-spacing:0.18em;
  padding:5px 18px;border-radius:2px;margin-bottom:16px;font-weight:300;
}
.hero-title{
  font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;margin:0 0 10px;line-height:1.6;
  text-shadow:0 2px 8px rgba(0,0,0,0.5);
}
.hero-title-area{
  display:block;font-size:clamp(0.85rem,1.6vw,1.05rem);
  color:var(--moss-pale);font-weight:400;letter-spacing:0.18em;
}
.hero-title-brand{
  display:block;font-size:clamp(1.3rem,3vw,1.8rem);
  color:var(--wood-cream);font-weight:800;letter-spacing:0.1em;
}
.hero-catch{
  font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;
  font-size:clamp(1.18rem,2.5vw,1.52rem);
  color:var(--wood-cream);line-height:2;margin-bottom:8px;font-weight:700;
  text-shadow:0 2px 8px rgba(0,0,0,0.5);
}
.hero-catch strong{color:var(--amber-l);text-shadow:0 0 12px rgba(196,135,42,0.4);}
.hero-sub{font-size:0.93rem;color:rgba(245,237,216,0.80);letter-spacing:0.07em;margin-bottom:28px;font-weight:300;}
.hero-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
/* ランプスイッチ風ボタン */
.btn-p{
  background:var(--amber);color:var(--wood-dark);
  padding:13px 36px;font-size:0.96rem;font-weight:700;
  letter-spacing:0.12em;text-decoration:none;border-radius:2px;
  font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;
  border:1px solid var(--amber-l);
  box-shadow:0 3px 0 rgba(100,60,10,0.5),var(--sh-sm);
  transition:transform 0.15s,box-shadow 0.15s;
}
.btn-p:hover{transform:translateY(2px);box-shadow:0 1px 0 rgba(100,60,10,0.5),var(--sh-sm);}
.btn-s{
  background:transparent;color:var(--wood-cream);
  padding:13px 36px;font-size:0.96rem;font-weight:400;
  letter-spacing:0.12em;text-decoration:none;border-radius:2px;
  border:1.5px solid rgba(245,237,216,0.35);
  font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;transition:all 0.2s;
}
.btn-s:hover{background:rgba(245,237,216,0.08);border-color:var(--wood-cream);}
.hero-scroll{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:5;
  display:flex;flex-direction:column;align-items:center;gap:6px;
}
.scroll-txt{font-size:0.72rem;letter-spacing:0.3em;color:var(--amber-pale);font-style:italic;font-family:'Crimson Text',serif;}
.scroll-bar{width:1px;height:40px;background:linear-gradient(to bottom,var(--amber),transparent);animation:spulse 2s ease-in-out infinite;}
@keyframes spulse{0%,100%{opacity:0.3;transform:scaleY(0.5);transform-origin:top;}50%{opacity:1;transform:scaleY(1);}}

/* ── 写真ストリップ ── */
.photo-strip{
  display:grid;grid-template-columns:repeat(3,1fr);gap:3px;
  border-top:4px solid var(--wood-dark);
  border-bottom:4px solid var(--wood-dark);
}
.photo-strip img{
  width:100%;height:200px;object-fit:cover;display:block;
  filter:sepia(20%) brightness(0.88) saturate(0.85) contrast(1.05);
  transition:filter 0.4s;
}
.photo-strip img:hover{filter:sepia(5%) brightness(0.98) saturate(1.05);}

/* ── 楽譜区切りバー ── */
.score-bar{width:100%;overflow:hidden;display:flex;align-items:center;}
.score-bar img{width:100%;display:block;object-fit:contain;object-position:left center;}
/* 木材バー */
.sb-wood{
  background:var(--wood-dark);
  background-image:repeating-linear-gradient(90deg,transparent 0,transparent 20px,rgba(255,255,255,0.012) 20px,rgba(255,255,255,0.012) 21px,transparent 21px,transparent 60px,rgba(0,0,0,0.04) 60px,rgba(0,0,0,0.04) 61px);
  border-top:2px solid var(--amber);border-bottom:2px solid var(--amber);
  padding:0;
}
.sb-wood img{width:100%;height:92px;object-fit:cover;object-position:left center;}
/* ステンドグラス帯 */
.sb-stained{
  height:32px;padding:0;overflow:hidden;
  border-top:3px solid var(--wood-dark);border-bottom:3px solid var(--wood-dark);
}
.sb-stained img{width:100%;height:32px;object-fit:cover;opacity:0.9;}
/* 苔グリーンバー */
.sb-moss{
  background:var(--moss);
  border-top:2px solid var(--moss-pale);border-bottom:2px solid var(--moss-pale);
  padding:0;
}
.sb-moss img{width:100%;height:92px;object-fit:cover;object-position:left center;}
/* クリームバー */
.sb-cream{
  background:var(--parchment-warm);
  border-top:1px solid var(--amber-pale);border-bottom:1px solid var(--amber-pale);
  padding:0;
}
.sb-cream img{width:100%;height:92px;object-fit:cover;object-position:left center;}

/* ── セクション共通 ── */
section{padding:80px 24px;position:relative;z-index:1;}
.section-inner{max-width:960px;margin:0 auto;}
.sec-eyebrow{
  display:flex;align-items:center;gap:8px;
  font-family:'Crimson Text',serif;font-style:italic;
  font-size:0.96rem;letter-spacing:0.22em;
  color:#5A3808;font-weight:600;margin-bottom:8px;
}
.sec-eyebrow::before{content:'♪';font-style:normal;}
.sec-eyebrow::after{content:'♩';font-style:normal;}
.sec-title{
  font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;
  font-size:clamp(1.85rem,3.8vw,2.6rem);
  font-weight:800;line-height:1.3;color:var(--wood-dark);margin-bottom:12px;
}
.sec-title .acc{color:var(--amber);}
.sec-title .acc2{color:var(--moss-mid);}
/* 万年筆ライン */
.pen-line{display:flex;align-items:center;gap:10px;margin:10px 0 22px;}
.pls{height:2px;flex:1;max-width:120px;background:linear-gradient(90deg,#5A3808 0%,#5A3808 40%,rgba(90,56,8,0.15) 100%);border-radius:1px;}
.plsr{background:linear-gradient(270deg,#5A3808 0%,#5A3808 40%,rgba(90,56,8,0.15) 100%);}
.pln{font-size:0.96rem;color:var(--amber);font-family:'Noto Serif JP',serif;display:flex;gap:5px;}
.score-deco{width:100%;max-width:520px;margin:6px 0 20px;overflow:hidden;}
.score-deco img{width:100%;height:68px;object-fit:contain;object-position:left center;display:block;}
.sec-lead{font-size:1.0rem;line-height:2;color:#3A2210;max-width:620px;font-weight:300;}
/* カード底部楽譜 */
.csfooter{position:absolute;bottom:0;left:0;right:0;overflow:hidden;height:64px;pointer-events:none;opacity:0.40;}
.csfooter img{width:100%;height:100%;object-fit:contain;object-position:left bottom;display:block;}

/* ── カード共通スタイル ── */
/* 地球屋の棚・引き出し風 */
.shelf-card{
  background:var(--parchment-pale);
  /* 木目調の強弱枠線 */
  border-top:2px solid var(--wood-warm);
  border-left:1px solid rgba(107,74,40,0.3);
  border-right:3px solid var(--wood-warm);
  border-bottom:3px solid var(--wood-mid);
  border-radius:3px;
  box-shadow:var(--sh-md),3px 4px 0 rgba(61,43,26,0.25);
  position:relative;overflow:hidden;
}
/* アンバーアクセントバー */
.shelf-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--wood-warm),var(--amber),var(--wood-light));
}
/* 右下木目ノートライン */
.shelf-card::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:24px;pointer-events:none;
  background:repeating-linear-gradient(0deg,transparent,transparent 6px,rgba(107,74,40,0.06) 6px,rgba(107,74,40,0.06) 7px);
}

/* ── CONCEPT ── */
#concept{background:var(--parchment-pale);}
.concept-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start;margin-top:40px;}
.concept-card{
  background:var(--parchment-pale);
  border-top:2px solid var(--amber);
  border-left:1px solid rgba(196,135,42,0.3);
  border-right:3px solid var(--wood-warm);
  border-bottom:3px solid var(--wood-mid);
  border-radius:3px;
  box-shadow:var(--sh-md),3px 4px 0 rgba(61,43,26,0.22);
  padding:36px 32px 72px;position:relative;overflow:hidden;
}
.concept-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--amber),var(--wood-warm),var(--amber-l));}
.concept-bg-txt{position:absolute;bottom:-28px;right:-8px;font-family:'Crimson Text',serif;font-style:italic;font-size:7.0rem;line-height:1;color:rgba(107,74,40,0.05);pointer-events:none;}
.qm{font-family:'Crimson Text',serif;font-size:4.0rem;line-height:0.8;color:var(--amber);opacity:0.5;display:block;margin-bottom:4px;}
.concept-quote{font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;font-size:clamp(1.1rem,2vw,1.4rem);font-weight:700;line-height:1.85;color:var(--wood-dark);}
.concept-desc{font-size:0.96rem;line-height:2.05;color:var(--ink-m);margin-top:16px;font-weight:300;}
.cbadge{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--parchment-pale);color:#2A4030;
  font-size:0.83rem;letter-spacing:0.1em;
  padding:6px 14px;border-radius:2px;margin-top:16px;
  border:1px solid var(--moss-mist);font-weight:500;
}
.cbadge .dot{width:7px;height:7px;border-radius:50%;background:var(--moss-light);animation:blink 2s infinite;}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:0.2;}}
.concept-text h3{font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;font-size:1.11rem;font-weight:700;color:var(--wood-dark);margin-bottom:12px;display:flex;align-items:center;gap:7px;}
.concept-text h3::before{content:'🌿';font-size:0.96rem;}
.concept-text p{font-size:0.96rem;line-height:2.05;color:#3A2210;margin-bottom:14px;font-weight:300;}
.pgn{display:grid;gap:10px;margin-top:32px;grid-template-columns:1fr 1fr 1fr;}
.pgn img{
  width:100%;object-fit:cover;border-radius:2px;display:block;
  filter:sepia(15%) brightness(0.92) saturate(0.88) contrast(1.04);
  transition:filter 0.35s,transform 0.35s;
  border-top:2px solid rgba(107,74,40,0.22);
  border-right:2px solid rgba(107,74,40,0.22);
  border-bottom:1px solid rgba(107,74,40,0.15);
  border-left:1px solid rgba(107,74,40,0.15);
  box-shadow:2px 3px 8px rgba(42,30,15,0.18);
}
.pgn img:hover{filter:sepia(0%) brightness(1) saturate(1.05);transform:scale(1.02);}
.pgn .pw{grid-column:span 2;aspect-ratio:16/7;}
.pgn .ps{aspect-ratio:4/3;}
.pgn .pt{grid-row:span 2;aspect-ratio:3/4;}

/* ── FEATURES ── */
#features{
  background:var(--moss);
  background-image:repeating-linear-gradient(0deg,transparent,transparent 28px,rgba(255,255,255,0.025) 28px,rgba(255,255,255,0.025) 29px);
}
#features .sec-title{color:var(--wood-cream);}
#features .sec-eyebrow{color:var(--amber-l);}
#features .grimoire-rule{color:var(--amber-pale);opacity:1;font-weight:600;}
#features .sec-stars{color:var(--amber-pale);font-weight:700;}
#features .quill-deco-center{color:var(--amber-pale);font-weight:600;}
#features .sec-lead{color:rgba(245,237,216,0.78);}
#features .pln{color:var(--amber-l);}
#features .pls{background:linear-gradient(90deg,var(--amber-l),rgba(212,168,74,0.2));}
#features .plsr{background:linear-gradient(270deg,var(--amber-l),rgba(212,168,74,0.2));}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px;}
.feat-card{
  background:var(--parchment-pale);
  border-top:2px solid;border-left:1px solid;
  border-right:3px solid;border-bottom:3px solid;
  border-radius:3px;padding:32px 26px 72px;
  position:relative;overflow:hidden;
  transition:transform 0.3s,box-shadow 0.3s;
}
.feat-card:nth-child(1){border-color:var(--wood-warm);box-shadow:var(--sh-sm),3px 4px 0 rgba(107,74,40,0.25);}
.feat-card:nth-child(2){border-color:rgba(196,135,42,0.7);box-shadow:var(--sh-sm),3px 4px 0 rgba(196,135,42,0.25);}
.feat-card:nth-child(3){border-color:rgba(42,64,48,0.6);box-shadow:var(--sh-sm),3px 4px 0 rgba(42,64,48,0.2);}
.feat-card:nth-child(1)::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--wood-warm),var(--amber));}
.feat-card:nth-child(2)::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--amber),var(--amber-l));}
.feat-card:nth-child(3)::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--moss-mid),var(--moss-light));}
.feat-card:hover{transform:translate(-2px,-2px);}
.feat-card:hover:nth-child(1){box-shadow:var(--sh-md),5px 6px 0 rgba(107,74,40,0.28);}
.feat-card:hover:nth-child(2){box-shadow:var(--sh-md),5px 6px 0 rgba(196,135,42,0.30);}
.feat-card:hover:nth-child(3){box-shadow:var(--sh-md),5px 6px 0 rgba(42,64,48,0.25);}
.feat-num{font-family:'Crimson Text',serif;font-style:italic;font-size:4.0rem;font-weight:600;color:rgba(107,74,40,0.07);position:absolute;top:8px;right:14px;line-height:1;}
.feat-icon{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:16px;background:var(--parchment-warm);border:2px solid var(--amber-pale);box-shadow:inset 0 1px 4px rgba(196,135,42,0.1),0 2px 6px rgba(42,30,15,0.1);}
.feat-card h3{font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;font-size:1.08rem;font-weight:700;color:var(--wood-dark);margin-bottom:10px;}
.feat-card p{font-size:0.93rem;line-height:1.95;color:var(--ink-m);font-weight:300;}

/* ── WORK ── */
#work{background:var(--amber-mist);}
.work-layout{display:grid;grid-template-columns:200px 1fr;gap:40px;margin-top:40px;}
/* メニューボード：地球屋の看板 */
.work-board{
  background:var(--wood-dark);
  background-image:repeating-linear-gradient(90deg,transparent 0,transparent 12px,rgba(255,255,255,0.012) 12px,rgba(255,255,255,0.012) 13px,transparent 13px,transparent 35px,rgba(0,0,0,0.04) 35px,rgba(0,0,0,0.04) 36px);
  border:2px solid var(--amber);
  border-radius:3px;padding:16px 0;
  box-shadow:var(--sh-md),3px 4px 0 rgba(61,43,26,0.35),0 0 20px rgba(196,135,42,0.1);
  position:sticky;top:82px;height:fit-content;
}
.wboard-title{
  font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;font-size:0.8rem;letter-spacing:0.26em;
  color:var(--amber-pale);text-align:center;padding:0 14px 10px;
  border-bottom:1px solid rgba(196,135,42,0.30);margin-bottom:6px;
  text-shadow:0 1px 4px rgba(0,0,0,0.4);
}
.wmenu-item{padding:13px 18px;cursor:pointer;transition:background 0.2s;display:flex;align-items:center;gap:10px;border-left:3px solid transparent;}
.wmenu-item.active,.wmenu-item:hover{background:rgba(255,255,255,0.07);border-left-color:var(--amber-l);}
.wm-icon{font-size:1.06rem;}
.wm-title{font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;font-size:0.94rem;font-weight:700;color:var(--wood-cream);display:block;}
.wm-sub{font-size:0.78rem;color:rgba(245,237,216,0.65);margin-top:1px;display:block;}
.work-panel{display:none;}
.work-panel.active{display:block;}
.work-panel h3{font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;font-size:1.55rem;font-weight:800;color:var(--wood-dark);margin-bottom:10px;}
.panel-sub{font-size:0.95rem;color:#3A2210;margin-bottom:20px;line-height:1.95;font-weight:300;}
.wpg{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:20px;}
.wpg img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:2px;display:block;filter:sepia(15%) brightness(0.90) saturate(0.88);transition:filter 0.3s,transform 0.3s;border-top:2px solid rgba(107,74,40,0.2);border-right:2px solid rgba(107,74,40,0.2);border-bottom:1px solid rgba(107,74,40,0.14);border-left:1px solid rgba(107,74,40,0.14);box-shadow:2px 2px 6px rgba(42,30,15,0.15);}
.wpg img:hover{filter:sepia(0%) brightness(1) saturate(1.05);transform:scale(1.02);}
.work-tags{display:flex;flex-wrap:wrap;gap:7px;}
.work-tag{background:var(--parchment-pale);color:#2A4030;border:1px solid rgba(42,64,48,0.35);font-size:0.87rem;letter-spacing:0.05em;padding:5px 13px;border-radius:2px;font-weight:500;transition:background 0.2s;}
.work-tag:hover{background:var(--moss-mist);}

/* ── MEAL ── */
#meal{
  background:var(--wood-dark);
  background-image:repeating-linear-gradient(90deg,transparent 0,transparent 20px,rgba(255,255,255,0.012) 20px,rgba(255,255,255,0.012) 21px,transparent 21px,transparent 60px,rgba(0,0,0,0.04) 60px,rgba(0,0,0,0.04) 61px);
  border-top:3px solid var(--amber);border-bottom:3px solid var(--amber);
}
#meal .sec-title{color:var(--wood-cream);text-shadow:0 2px 6px rgba(0,0,0,0.4);}
#meal .sec-eyebrow{color:var(--amber-l);}
#meal .grimoire-rule{color:var(--amber-pale);opacity:1;font-weight:600;}
#meal .sec-stars{color:var(--amber-pale);font-weight:700;}
#meal .quill-deco-center{color:var(--amber-pale);font-weight:600;}
#meal .sec-lead{color:rgba(245,237,216,0.78);}
#meal .pln{color:var(--amber-l);}
#meal .pls{background:linear-gradient(90deg,var(--amber-l),rgba(212,168,74,0.2));}
#meal .plsr{background:linear-gradient(270deg,var(--amber-l),rgba(212,168,74,0.2));}
.meal-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:40px;}
.meal-card{
  background:var(--parchment-pale);
  border-top:2px solid var(--amber);
  border-left:1px solid rgba(196,135,42,0.28);
  border-right:3px solid var(--wood-warm);
  border-bottom:3px solid var(--wood-mid);
  border-radius:3px;
  box-shadow:var(--sh-md),3px 4px 0 rgba(61,43,26,0.25);
  padding:32px 32px 72px;position:relative;overflow:hidden;
}
.meal-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--amber),var(--wood-warm),var(--amber-l));}
.meal-card h3{font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;font-size:1.11rem;font-weight:700;color:var(--wood-dark);margin-bottom:14px;padding-bottom:12px;border-bottom:2px solid var(--amber-pale);}
.meal-photo{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:2px;margin-bottom:16px;filter:sepia(12%) brightness(0.92) contrast(1.04);border-top:2px solid rgba(107,74,40,0.2);border-right:2px solid rgba(107,74,40,0.2);border-bottom:1px solid rgba(107,74,40,0.14);border-left:1px solid rgba(107,74,40,0.14);}
.mrow{display:flex;justify-content:space-between;align-items:baseline;padding:7px 0;border-bottom:1px dashed rgba(107,74,40,0.18);font-size:0.91rem;color:var(--ink-m);font-weight:300;}
.mrow:last-of-type{border-bottom:none;}
.mprice{color:#8B2010;font-weight:700;font-size:0.96rem;}
.mnote{font-size:0.83rem;color:#5A3808;margin-top:10px;font-style:italic;}
.evitem{margin-bottom:18px;padding-bottom:18px;border-bottom:1px dashed rgba(107,74,40,0.15);}
.evitem:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0;}
.evbadge{display:inline-block;background:#8B2010;color:#fff;font-size:0.77rem;letter-spacing:0.1em;padding:3px 10px;border-radius:2px;margin-bottom:6px;box-shadow:1px 1px 0 rgba(42,64,48,0.4);}
.evitem h4{font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;font-size:1.01rem;font-weight:700;color:var(--wood-dark);margin-bottom:5px;}
.evitem p{font-size:0.91rem;line-height:1.85;color:var(--ink-m);font-weight:300;}

/* ── SCHEDULE ── */
#schedule{background:var(--wood-foam);}
.schedule-grid{display:block;margin-top:40px;}
.tl-item{display:flex;gap:0;position:relative;}
.tl-item::before{content:'';position:absolute;left:64px;top:28px;bottom:-8px;width:1px;background:linear-gradient(to bottom,var(--amber-pale),transparent);border-right:1px dashed rgba(196,135,42,0.2);}
.tl-item:last-child::before{display:none;}
.tl-t{width:58px;flex-shrink:0;text-align:right;font-family:'Crimson Text',serif;font-style:italic;font-size:0.86rem;color:var(--amber);font-weight:600;padding:16px 0;line-height:1.5;}
.tl-nd{width:26px;flex-shrink:0;padding-top:19px;display:flex;justify-content:center;}
.tl-dot{width:11px;height:11px;border-radius:50%;background:var(--wood-warm);border:2px solid var(--parchment-pale);box-shadow:0 0 0 2px var(--amber-pale),0 2px 4px rgba(42,30,15,0.2);}
.tl-b{flex:1;padding:12px 0 24px 14px;}
.tl-b h4{font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;font-size:1.01rem;font-weight:700;color:var(--wood-dark);margin-bottom:3px;}
.tl-b p{font-size:0.88rem;color:var(--ink-s);line-height:1.7;font-weight:300;}
/* 情報ボード：地球屋の古い木製看板 */
.info-board{
  background:var(--wood-dark);
  background-image:repeating-linear-gradient(90deg,transparent 0,transparent 15px,rgba(255,255,255,0.012) 15px,rgba(255,255,255,0.012) 16px);
  border:2px solid var(--amber);
  border-radius:3px;padding:28px;
  box-shadow:var(--sh-md),3px 4px 0 rgba(61,43,26,0.35),0 0 15px rgba(196,135,42,0.08);
}
.ib-title{font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;font-size:1.03rem;font-weight:700;color:var(--amber-l);margin-bottom:18px;padding-bottom:10px;border-bottom:1px solid rgba(196,135,42,0.30);}
.irow{display:flex;gap:14px;margin-bottom:11px;font-size:0.93rem;align-items:baseline;}
.ikey{color:var(--amber-pale);font-size:0.8rem;font-weight:600;letter-spacing:0.07em;min-width:64px;}
.ival{color:rgba(245,237,216,0.88);line-height:1.7;font-weight:300;}

/* ── REMOTE ── */
#remote{background:var(--moss-foam);}
.remote-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:40px;}
.remote-card{
  background:var(--parchment-pale);
  border-top:2px solid var(--moss-mid);
  border-left:1px solid rgba(61,90,68,0.25);
  border-right:3px solid var(--moss-mid);
  border-bottom:3px solid var(--moss);
  border-radius:3px;
  box-shadow:var(--sh-sm),3px 4px 0 rgba(42,64,48,0.18);
  padding:32px 32px 72px;position:relative;overflow:hidden;
  transition:transform 0.3s,box-shadow 0.3s;
}
.remote-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--moss-mid),var(--moss-light),var(--amber-l));}
.remote-card:hover{transform:translate(-2px,-2px);box-shadow:var(--sh-md),5px 6px 0 rgba(42,64,48,0.22);}
.rc-icon{font-size:2.0rem;display:block;margin-bottom:14px;}
.remote-card h3{font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;font-size:1.08rem;font-weight:700;color:var(--wood-dark);margin-bottom:10px;}
.remote-card p{font-size:0.94rem;line-height:2;color:var(--ink-m);font-weight:300;}
.wage-tag{display:inline-block;background:var(--moss-foam);color:var(--moss-mid);border:1px solid var(--moss-mist);font-size:0.86rem;padding:5px 13px;border-radius:2px;margin-top:12px;font-weight:500;}

/* ── FLOW ── */
#flow{background:var(--amber-mist);}
.flow-wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:40px;position:relative;}
.flow-wrap::before{
  content:'';position:absolute;top:30px;
  left:calc(12.5% + 8px);right:calc(12.5% + 8px);
  height:2px;
  background:repeating-linear-gradient(90deg,var(--amber) 0,var(--amber) 6px,transparent 6px,transparent 12px);
  opacity:0.5;
}
.flow-card{
  background:var(--parchment-pale);
  border-top:2px solid var(--amber);
  border-left:1px solid rgba(196,135,42,0.28);
  border-right:3px solid var(--wood-warm);
  border-bottom:3px solid var(--wood-mid);
  border-radius:3px;
  box-shadow:var(--sh-sm),3px 4px 0 rgba(61,43,26,0.20);
  padding:24px 18px 72px;text-align:center;
  position:relative;z-index:1;
  transition:transform 0.3s,box-shadow 0.3s;overflow:hidden;
}
.flow-card:hover{transform:translate(-2px,-2px);box-shadow:var(--sh-md),5px 6px 0 rgba(61,43,26,0.25);}
.flow-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--amber),var(--wood-warm),var(--amber-l));}
/* スタンプ印鑑風ステップ番号 */
.step-ring{
  width:48px;height:48px;border-radius:50%;
  background:var(--parchment-pale);
  border:2px solid var(--wood-dark);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 14px;
  font-family:'Crimson Text',serif;font-style:italic;
  font-size:1.3rem;font-weight:600;color:var(--wood-dark);
  box-shadow:0 0 0 3px var(--wood-foam),0 0 0 4px rgba(107,74,40,0.2),2px 3px 6px rgba(42,30,15,0.2);
}
.flow-card h4{font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;font-size:1.01rem;font-weight:700;color:var(--wood-dark);margin-bottom:7px;}
.flow-card p{font-size:0.88rem;line-height:1.85;color:var(--ink-m);font-weight:300;}

/* ── ACCESS ── */
#access{background:var(--moss-foam);}
.access-layout{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:40px;align-items:start;}
.access-name{font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;font-size:1.32rem;font-weight:700;color:var(--wood-dark);margin-bottom:22px;line-height:1.5;}
.arow{display:flex;gap:11px;margin-bottom:14px;font-size:0.94rem;align-items:flex-start;}
.aicon{color:#2A4030;font-size:1.03rem;flex-shrink:0;margin-top:3px;}
.atext{color:#3A2210;line-height:1.85;font-weight:300;}
.atext strong{color:#8B2010;font-weight:700;}
.hours-tbl{width:100%;font-size:0.91rem;margin-top:20px;padding-top:18px;border-top:2px solid var(--amber-pale);border-collapse:collapse;}
.hours-tbl tr{border-bottom:1px dashed rgba(196,135,42,0.18);}
.hours-tbl tr:last-child{border-bottom:none;}
.hours-tbl td{padding:7px 0;}
.hours-tbl td:first-child{color:#2A4030;width:76px;font-size:0.8rem;font-weight:600;letter-spacing:0.07em;}
.hours-tbl td:last-child{color:var(--ink-m);font-weight:300;}
.hours-tbl a{color:#8B2010;text-decoration:none;font-weight:600;}
.map-wrap{
  border-radius:3px;overflow:hidden;
  border-top:2px solid var(--wood-warm);
  border-right:3px solid var(--wood-warm);
  border-bottom:3px solid var(--wood-mid);
  border-left:1px solid rgba(107,74,40,0.2);
  aspect-ratio:1;
  box-shadow:var(--sh-md),3px 4px 0 rgba(61,43,26,0.22);
}
.map-wrap iframe{width:100%;height:100%;border:none;}

/* ── CTA ── */
#cta{
  background:var(--wood-deep);
  background-image:repeating-linear-gradient(90deg,transparent 0,transparent 25px,rgba(255,255,255,0.01) 25px,rgba(255,255,255,0.01) 26px,transparent 26px,transparent 70px,rgba(0,0,0,0.04) 70px,rgba(0,0,0,0.04) 71px);
  border-top:3px solid var(--amber);
  text-align:center;padding:96px 24px;
  position:relative;overflow:hidden;
}
#cta::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 50% 60% at 20% 30%,rgba(196,135,42,0.10) 0%,transparent 60%),
    radial-gradient(ellipse 50% 50% at 80% 70%,rgba(184,90,42,0.08) 0%,transparent 55%);
}
#cta::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:url('/wp-content/themes/tempo-rubato/images/svg/texture-paper.svg');
  background-repeat:repeat;background-size:300px;
  opacity:0.25;mix-blend-mode:overlay;
}
/* CTAのステンドグラス帯 */
.cta-stained{
  position:absolute;top:0;left:0;right:0;height:32px;overflow:hidden;z-index:1;
}
.cta-stained img{width:100%;height:32px;object-fit:cover;opacity:0.75;}
.cta-score{width:100%;overflow:hidden;margin-bottom:36px;opacity:0.55;position:relative;z-index:1;}
.cta-score img{width:100%;height:92px;display:block;object-fit:contain;object-position:left center;}
.cta-inner{position:relative;z-index:2;max-width:660px;margin:0 auto;}
.cta-eyebrow{font-size:0.75rem;letter-spacing:0.38em;color:var(--amber-pale);margin-bottom:18px;display:block;font-family:'Crimson Text',serif;font-style:italic;opacity:1;font-weight:600;}
#cta h2{font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;font-size:clamp(1.85rem,4.4vw,3.0rem);font-weight:800;line-height:1.55;color:var(--wood-cream);margin-bottom:14px;text-shadow:0 2px 8px rgba(0,0,0,0.4);}
#cta h2 span{color:var(--amber-l);text-shadow:0 0 15px rgba(196,135,42,0.3);}
#cta .cta-sub{font-size:0.98rem;line-height:2;color:rgba(245,237,216,0.68);margin-bottom:36px;font-weight:300;}
.cta-tel{display:block;font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;font-size:clamp(2.1rem,5.2vw,3.6rem);color:var(--wood-cream);letter-spacing:0.06em;text-decoration:none;margin-bottom:4px;transition:color 0.2s;}
.cta-tel:hover{color:var(--amber-l);}
.cta-hours{font-size:0.79rem;letter-spacing:0.14em;color:rgba(245,237,216,0.65);margin-bottom:32px;display:block;font-style:italic;}
.cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
.cta-btn-a{
  background:var(--amber);color:var(--wood-dark);
  padding:14px 38px;font-size:0.96rem;font-weight:700;
  letter-spacing:0.12em;text-decoration:none;border-radius:2px;
  font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;
  border:1px solid var(--amber-l);
  box-shadow:0 3px 0 rgba(100,60,10,0.5),0 0 15px rgba(196,135,42,0.2);
  transition:transform 0.15s,box-shadow 0.15s;
}
.cta-btn-a:hover{transform:translateY(2px);box-shadow:0 1px 0 rgba(100,60,10,0.5),0 0 8px rgba(196,135,42,0.15);}
.cta-btn-o{
  border-top:2px solid rgba(245,237,216,0.38);
  border-right:2px solid rgba(245,237,216,0.38);
  border-bottom:1px solid rgba(245,237,216,0.25);
  border-left:1px solid rgba(245,237,216,0.25);
  color:rgba(245,237,216,0.80);
  padding:14px 38px;font-size:0.96rem;font-weight:300;
  letter-spacing:0.12em;text-decoration:none;border-radius:2px;
  font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;transition:all 0.2s;background:transparent;
}
.cta-btn-o:hover{border-color:var(--amber-pale);color:var(--amber-pale);}

/* ── FOOTER ── */
footer{
  background:var(--wood-deep);
  background-image:repeating-linear-gradient(90deg,transparent 0,transparent 20px,rgba(255,255,255,0.01) 20px,rgba(255,255,255,0.01) 21px);
  padding:0 24px 36px;
  border-top:3px solid var(--amber);
}
.footer-stained{width:100%;height:20px;overflow:hidden;margin-bottom:0;}
.footer-stained img{width:100%;height:20px;object-fit:cover;opacity:0.7;display:block;}
.footer-score{width:100%;overflow:hidden;opacity:0.42;margin-bottom:22px;}
.footer-score img{width:100%;height:92px;display:block;object-fit:contain;object-position:left center;}
.footer-inner{max-width:940px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px;}
.flogo{display:flex;align-items:center;gap:12px;}
.flogo img{height:38px;filter:drop-shadow(0 1px 4px rgba(0,0,0,0.5));}
.flogo-t{font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;font-size:1.03rem;color:rgba(245,237,216,0.92);font-weight:700;}
.flogo-t span{display:block;font-size:0.72rem;font-weight:300;color:rgba(245,237,216,0.65);letter-spacing:0.18em;margin-top:2px;}
.finfo{text-align:right;font-size:0.83rem;color:rgba(245,237,216,0.65);line-height:2;font-weight:300;}
.finfo a{color:var(--amber-pale);text-decoration:none;}


/* ── ランプ装飾 ── */
.hero-lamp {
  position:absolute;z-index:3;pointer-events:none;
  width:60px;opacity:0.82;
  animation:lampflicker 4s ease-in-out infinite;
}
.hero-lamp-l { left:4%; top:30%; }
.hero-lamp-r { right:4%; top:25%; transform:scaleX(-1); }
@keyframes lampflicker {
  0%,100% { opacity:0.82; filter:drop-shadow(0 0 8px rgba(255,216,112,0.5)); }
  33%  { opacity:0.88; filter:drop-shadow(0 0 16px rgba(255,216,112,0.8)); }
  66%  { opacity:0.78; filter:drop-shadow(0 0 6px rgba(255,216,112,0.4)); }
}
.hero-lamp img { width:100%;height:auto;display:block; }

/* ── 星帯 ── */
.hero-stars {
  position:absolute;left:0;right:0;z-index:3;pointer-events:none;
  top:50%;transform:translateY(-50%);
  overflow:hidden;height:60px;
  animation:starsfade 6s ease-in-out infinite;
}
.hero-stars img { width:100%;height:60px;object-fit:cover;display:block; }
@keyframes starsfade {
  0%,100% { opacity:0.65; }
  50% { opacity:0.90; }
}

/* ── セクション星飾り（見出し周辺） ── */
.sec-stars {
  display:flex;align-items:center;gap:8px;
  margin-bottom:8px;
  color:#5A3808;
  font-size:0.98rem;letter-spacing:0.15em;
  font-family:'Crimson Text',serif;
  font-weight:700;
}
.sec-stars .s { color:var(--amber-l);font-size:0.85rem; }

/* ── ランプアイコン（セクション内小ランプ） ── */
.lamp-icon {
  display:inline-flex;align-items:center;gap:6px;
  font-size:0.88rem;color:var(--amber);
  font-family:'Crimson Text',serif;font-style:italic;
  margin-bottom:6px;
}
.lamp-icon::before { content:'🕯️';font-style:normal;font-size:0.98rem; }

/* ── ステンドグラスバーの高さ拡大 ── */
.sb-stained { height:36px; border-top:3px solid var(--wood-dark); border-bottom:3px solid var(--wood-dark); }
.sb-stained img { height:36px; }

/* ── 星のフローティング装飾（各カード右上） ── */
.card-star {
  position:absolute;top:12px;right:16px;
  font-size:0.93rem;color:var(--amber-l);
  opacity:0.55;pointer-events:none;
  font-family:'Crimson Text',serif;
}

/* モバイルでランプを小さく */
@media(max-width:768px) {
  .hero-lamp { width:42px; }
  .hero-lamp-l { left:2%;top:35%; }
  .hero-lamp-r { right:2%;top:30%; }
}



/* =============================================
   魔導書 / ファンタジー古文書テーマ
   ============================================= */

/* 古文書テクスチャ（全セクション共通） */
.ps {
  position:relative;
}
/* 多層テクスチャ合成 */
.ps::before {
  content:"";
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:
    url("/wp-content/themes/tempo-rubato/images/svg/texture-wood-1.svg"),
    url("/wp-content/themes/tempo-rubato/images/svg/texture-wood-2.svg"),
    url("/wp-content/themes/tempo-rubato/images/svg/texture-wood-3.svg"),
    url("/wp-content/themes/tempo-rubato/images/svg/texture-wood-4.svg");
  background-size:512px 512px, 512px 512px, 512px 512px, 256px 256px;
  background-repeat:repeat;
  mix-blend-mode:multiply;
  opacity:0.88;
}
/* 四隅の焦げ・経年ヴィネット */
.ps::after {
  content:"";
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 90% 90% at 50% 50%,
      transparent 35%,
      rgba(80,45,10,0.12) 58%,
      rgba(55,28,5,0.30) 78%,
      rgba(35,15,2,0.55) 100%);
}
.ps .section-inner { position:relative;z-index:1; }

/* ── 魔導書の枠線ルーン装飾 ── */
/* セクション上下にルーン風の区切り線 */
.grimoire-rule {
  text-align:center;
  color:#5A3808;
  font-family:'Crimson Text',serif;
  font-size:0.84rem;
  letter-spacing:0.35em;
  font-weight:600;
  opacity:1;
  margin:8px 0 20px;
  position:relative;
}
.grimoire-rule::before,
.grimoire-rule::after {
  content:'';
  position:absolute;top:50%;
  width:28%;height:1px;
  background:linear-gradient(90deg,transparent,var(--amber),transparent);
}
.grimoire-rule::before { right:55%; }
.grimoire-rule::after  { left:55%; }

/* ── 魔導書ページの「耳折れ」風カード ── */
/* カード右上の折れ耳 */
.dog-ear {
  position:absolute;top:0;right:0;
  width:28px;height:28px;
  background:linear-gradient(225deg,
    var(--amber-pale) 0%,var(--amber-pale) 45%,
    rgba(107,74,40,0.35) 45%,rgba(107,74,40,0.35) 48%,
    var(--parchment-dark) 48%);
  clip-path:polygon(100% 0,0 0,100% 100%);
  pointer-events:none;
}

/* ── 羽ペン・インクの見出し装飾 ── */
.quill-deco {
  display:flex;align-items:center;gap:10px;
  margin:6px 0 18px;
}
.quill-deco-line {
  flex:1;height:1.5px;
  background:linear-gradient(90deg,
    transparent,#5A3808 20%,
    #5A3808 50%,
    rgba(90,56,8,0.3) 80%,transparent);
}
.quill-deco-line.rev {
  background:linear-gradient(270deg,
    transparent,#5A3808 20%,
    #5A3808 50%,
    rgba(90,56,8,0.3) 80%,transparent);
}
.quill-deco-center {
  font-size:1.06rem;color:#5A3808;font-weight:600;
  display:flex;align-items:center;gap:6px;
  font-family:'Crimson Text',serif;
}

/* ── 各カードに古文書の余白線（ノート罫線風） ── */
.shelf-card,
.concept-card,
.feat-card,
.meal-card,
.remote-card,
.flow-card {
  /* 罫線 */
  background-image:
    repeating-linear-gradient(
      0deg,
      transparent,
      transparent 27px,
      rgba(107,74,40,0.07) 27px,
      rgba(107,74,40,0.07) 28px
    ) !important;
}

/* ── 魔法陣風セクションタイトル下装飾 ── */
.magic-circle-sm {
  display:inline-block;
  width:38px;height:38px;
  border:1px solid var(--amber);
  border-radius:50%;
  position:relative;
  margin:0 8px;
  opacity:0.5;
  vertical-align:middle;
}
.magic-circle-sm::before {
  content:'✦';
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  font-size:14px;color:var(--amber-l);
  font-family:'Crimson Text',serif;
}

/* ── 見出し文字：古いインクの滲み感 ── */
.sec-title {
  text-shadow: 1px 1px 0 rgba(101,68,30,0.18),
               2px 2px 4px rgba(42,20,5,0.12);
}

/* ── 情報ボード：魔導書の表紙風 ── */
.info-board {
  background-image:
    repeating-linear-gradient(
      92deg,
      transparent 0,transparent 18px,
      rgba(255,255,255,0.018) 18px,rgba(255,255,255,0.018) 19px
    ),
    repeating-linear-gradient(
      180deg,
      transparent 0,transparent 6px,
      rgba(0,0,0,0.04) 6px,rgba(0,0,0,0.04) 7px
    ) !important;
}

/* ── 作業ボード（木製看板）：古ぼけ木目強化 ── */
.work-board {
  background-image:
    repeating-linear-gradient(91deg,
      transparent 0,transparent 8px,
      rgba(255,255,255,0.022) 8px,rgba(255,255,255,0.022) 9px,
      transparent 9px,transparent 22px,
      rgba(0,0,0,0.055) 22px,rgba(0,0,0,0.055) 23px
    ) !important;
}

/* ── ヴィネット強化（全体の四隅を暗く） ── */
body::after {
  content:"";
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 80% at 50% 50%,
      transparent 40%,
      rgba(42,20,5,0.06) 70%,
      rgba(22,8,2,0.22) 100%);
}

/* ── 羊皮紙セクションのテキスト色調整 ── */
.ps .sec-title       { color:#2A1A08; }
.ps .sec-eyebrow     { color:#5A3808; font-weight:600; }
.ps .concept-quote   { color:#1E1208; }
.ps .concept-desc,
.ps .sec-lead,
.ps .tl-b p,
.ps .feat-card p,
.ps .remote-card p,
.ps .flow-card p,
.ps .panel-sub       { color:#3A2210; }
.ps .tl-b h4,
.ps .feat-card h3,
.ps .remote-card h3,
.ps .flow-card h4,
.ps .work-panel h3   { color:#1E1208; }

/* スマホ */
@media(max-width:768px) {
  .magic-circle-sm { width:28px;height:28px; }
  .magic-circle-sm::before { font-size:10px; }
}


/* ── スケジュール：横型カードリスト ── */
.schedule-grid {
  display:block;
  margin-top:40px;
}
.tl-cards {
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-bottom:32px;
}
.tl-card {
  display:grid;
  grid-template-columns:80px 44px 1fr;
  align-items:center;
  gap:0;
  background:var(--parchment-pale);
  border-top:2px solid var(--amber);
  border-left:1px solid rgba(196,135,42,0.25);
  border-right:3px solid var(--wood-warm);
  border-bottom:3px solid var(--wood-mid);
  border-radius:3px;
  box-shadow:2px 3px 0 rgba(61,43,26,0.18),var(--sh-sm);
  overflow:hidden;
  transition:transform 0.2s, box-shadow 0.2s;
  background-image:
    repeating-linear-gradient(0deg,transparent,transparent 27px,
      rgba(107,74,40,0.06) 27px,rgba(107,74,40,0.06) 28px);
}
.tl-card:hover {
  transform:translate(-2px,-1px);
  box-shadow:4px 5px 0 rgba(61,43,26,0.22),var(--sh-md);
}
/* 時刻列 */
.tl-card-time {
  background:var(--wood-dark);
  background-image:repeating-linear-gradient(
    90deg,transparent 0,transparent 10px,
    rgba(255,255,255,0.015) 10px,rgba(255,255,255,0.015) 11px
  );
  color:var(--amber-pale);
  font-family:'Crimson Text',serif;
  font-style:italic;
  font-size:0.88rem;
  font-weight:600;
  line-height:1.4;
  letter-spacing:0.02em;
  text-align:center;
  padding:14px 8px;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  border-right:2px solid var(--amber);
  min-height:64px;
}
/* アイコン列 */
.tl-card-icon {
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.3rem;
  padding:0 4px;
  height:100%;
  min-height:64px;
  border-right:1px solid rgba(196,135,42,0.18);
  background:rgba(196,135,42,0.05);
}
/* 本文列 */
.tl-card-body {
  padding:12px 16px;
}
.tl-card-body h4 {
  font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;
  font-size:1.03rem;
  font-weight:700;
  color:#1E1208;
  margin-bottom:3px;
}
.tl-card-body p {
  font-size:0.92rem;
  color:#3A2210;
  line-height:1.65;
  font-weight:300;
}
/* 昼休憩カードは特別色 */
.tl-card.lunch .tl-card-time {
  background:var(--amber);
  color:#1E1208;
  font-weight:700;
}
.tl-card.lunch {
  border-top-color:var(--amber-l);
  box-shadow:2px 3px 0 rgba(196,135,42,0.30),var(--sh-sm);
}
/* 情報ボード：横幅フルに */
.info-board-wide {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin-top:0;
}
.info-board-wide .info-board {
  border-radius:3px;
  padding:20px 18px;
}
.info-board-wide .ib-title {
  font-size:0.9rem;
  margin-bottom:12px;
  padding-bottom:8px;
}
.info-board-wide .irow {
  font-size:0.9rem;
  margin-bottom:8px;
  flex-direction:column;
  gap:2px;
}
.info-board-wide .ikey {
  min-width:unset;
}

/* レスポンシブ */
@media(max-width:768px) {
  .tl-card {
    grid-template-columns:68px 38px 1fr;
  }
  .tl-card-time {
    font-size:0.8rem;
    padding:12px 4px;
    min-height:56px;
  }
  .tl-card-icon {
    font-size:1.14rem;
    min-height:56px;
  }
  .tl-card-body { padding:10px 12px; }
  .tl-card-body h4 { font-size:0.96rem; }
  .tl-card-body p  { font-size:0.88rem; }
  .info-board-wide { grid-template-columns:1fr; }
}








/* ── お食事写真レイアウト（上大・下3枚） ── */
.meal-photo-grid-new {
  display:flex;
  flex-direction:column;
  gap:6px;
  margin-bottom:16px;
}
.meal-main-photo {
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  object-position:center center;
  border-radius:3px;
  display:block;
  filter:sepia(10%) brightness(0.93);
  border-top:2px solid rgba(107,74,40,0.2);
  border-right:2px solid rgba(107,74,40,0.2);
  border-bottom:1px solid rgba(107,74,40,0.14);
  border-left:1px solid rgba(107,74,40,0.14);
}
.meal-sub-photos {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:6px;
}
.meal-sub-item {
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  border-radius:3px;
  display:block;
  filter:sepia(10%) brightness(0.93);
  border-top:2px solid rgba(107,74,40,0.2);
  border-right:2px solid rgba(107,74,40,0.2);
  border-bottom:1px solid rgba(107,74,40,0.14);
  border-left:1px solid rgba(107,74,40,0.14);
}
@media(max-width:768px) {
  .meal-sub-photos { grid-template-columns:repeat(3,1fr); }
}



/* ── 雰囲気セクション ── */
.atm-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:40px;}
.atm-card{
  background:var(--parchment-pale);
  border-top:2px solid var(--amber);
  border-left:1px solid rgba(196,135,42,0.25);
  border-right:3px solid var(--wood-warm);
  border-bottom:3px solid var(--wood-mid);
  border-radius:3px;
  padding:28px 24px;
  box-shadow:2px 3px 0 rgba(61,43,26,0.18),var(--sh-sm);
  transition:transform 0.2s,box-shadow 0.2s;
}
.atm-card:hover{transform:translate(-2px,-1px);box-shadow:4px 5px 0 rgba(61,43,26,0.22),var(--sh-md);}
.atm-icon{font-size:1.8rem;margin-bottom:12px;}
.atm-card h3{font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;font-size:1.0rem;font-weight:700;color:#1E1208;margin-bottom:8px;}
.atm-card p{font-size:0.88rem;line-height:1.95;color:#3A2210;font-weight:300;}

/* ── 対象者セクション ── */
.target-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:32px;}
.target-card{
  background:var(--parchment-pale);
  border-top:2px solid var(--wood-warm);
  border-right:2px solid var(--wood-warm);
  border-bottom:1px solid rgba(107,74,40,0.2);
  border-left:1px solid rgba(107,74,40,0.2);
  border-radius:3px;
  padding:20px 16px;
  box-shadow:2px 2px 0 rgba(61,43,26,0.15);
  text-align:center;
}
.target-badge{
  display:inline-block;
  background:var(--moss);color:#fff;
  font-size:0.78rem;font-weight:700;
  letter-spacing:0.08em;
  padding:5px 14px;border-radius:2px;
  margin-bottom:10px;
  box-shadow:1px 1px 0 rgba(42,64,48,0.4);
}
.target-card p{font-size:0.82rem;line-height:1.8;color:#3A2210;font-weight:300;}
.target-note{
  display:flex;align-items:flex-start;gap:12px;
  margin-top:28px;padding:20px 22px;
  background:var(--amber-mist);
  border-left:4px solid var(--amber);
  border-radius:0 3px 3px 0;
}
.target-note span{font-size:1.2rem;flex-shrink:0;margin-top:2px;}
.target-note p{font-size:0.88rem;line-height:1.95;color:#3A2210;font-weight:300;}

/* ── FAQ セクション ── */
.faq-list{display:flex;flex-direction:column;gap:8px;margin-top:36px;}
.faq-item{
  background:var(--parchment-pale);
  border-top:2px solid var(--amber);
  border-left:1px solid rgba(196,135,42,0.22);
  border-right:3px solid var(--wood-warm);
  border-bottom:3px solid var(--wood-mid);
  border-radius:3px;
  overflow:hidden;
  box-shadow:2px 2px 0 rgba(61,43,26,0.15);
}
.faq-q{
  width:100%;display:flex;align-items:center;gap:12px;
  padding:16px 20px;
  background:transparent;border:none;cursor:pointer;
  font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;font-size:0.96rem;font-weight:700;
  color:#1E1208;text-align:left;
  transition:background 0.2s;
}
.faq-q:hover{background:rgba(196,135,42,0.06);}
.faq-icon{
  width:26px;height:26px;border-radius:50%;
  background:var(--amber);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:0.82rem;font-weight:700;flex-shrink:0;
  font-family:'Crimson Text',serif;font-style:italic;
}
.faq-arrow{margin-left:auto;font-size:0.72rem;color:var(--amber);transition:transform 0.25s;flex-shrink:0;}
.faq-q[aria-expanded="true"] .faq-arrow{transform:rotate(180deg);}
.faq-a{padding:0 20px 18px 58px;}
.faq-a p{font-size:0.88rem;line-height:2;color:#3A2210;font-weight:300;}

/* ── Instagram セクション ── */
.insta-wrap{margin-top:36px;}
.insta-btn{
  display:inline-block;
  background:linear-gradient(135deg,#E1306C,#C13584,#833AB4);
  color:#fff;
  padding:13px 32px;
  font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;
  font-size:0.88rem;font-weight:700;letter-spacing:0.1em;
  text-decoration:none;border-radius:28px;
  box-shadow:0 4px 14px rgba(193,53,132,0.35);
  transition:transform 0.2s,box-shadow 0.2s;
}
.insta-btn:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(193,53,132,0.45);}

/* レスポンシブ */
@media(max-width:768px){
  .atm-grid{grid-template-columns:1fr;}
  .target-grid{grid-template-columns:1fr 1fr;}
  .faq-q{font-size:0.88rem;padding:14px 14px;}
  .faq-a{padding:0 14px 14px 46px;}
}
@media(max-width:390px){
  .target-grid{grid-template-columns:1fr 1fr;}
}


/* ── コンセプトタグ ── */
.concept-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px;}
.concept-tag{
  display:inline-block;
  background:var(--parchment-pale);
  color:#2A4030;
  border:1.5px solid rgba(42,64,48,0.28);
  font-size:0.82rem;
  padding:6px 13px;
  border-radius:2px;
  font-weight:500;
  box-shadow:1px 1px 0 rgba(61,43,26,0.12);
}


/* ── お品書きセクションタイトル ── */
.meal-section-title {
  font-family:'Shippori Mincho B1','Hiragino Mincho ProN','Yu Mincho',serif;
  font-size:0.82rem;
  font-weight:700;
  color:#5A3808;
  letter-spacing:0.08em;
  padding:6px 0 4px;
  border-bottom:1px solid rgba(196,135,42,0.25);
  margin-bottom:4px;
}


/* ── 食事説明ノートボックス ── */
.meal-note-box {
  background:var(--amber-mist);
  border-left:4px solid var(--amber);
  border-radius:0 3px 3px 0;
  padding:14px 16px;
  margin-bottom:16px;
}
.meal-note-box p {
  font-size:0.86rem;
  line-height:1.95;
  color:#3A2210;
  font-weight:300;
}

/* reveal */
.reveal{opacity:0;transform:translateY(24px);transition:opacity 0.68s ease,transform 0.68s ease;}
.reveal.in{opacity:1;transform:translateY(0);}

/* ===================== RESPONSIVE ===================== */
@media(max-width:768px){
  html{font-size:16px;} body{padding-bottom:64px;}
  header{padding:0 14px;height:58px;}
  nav[aria-label]{display:none;}
  .hamburger{display:block;}
  .hdr-logo-text{font-size:1.0rem;} .hdr-logo img{height:32px;}
  .mobile-cta{display:block;}
  #hero{padding-top:58px;min-height:100svh;}
  .hero-card{padding:24px 18px 20px;}
  .hero-card-label{display:none;}
  .hero-logo{width:min(300px,80vw);margin-bottom:16px;}
  .hero-badge{font-size:0.77rem;padding:4px 14px;}
  .hero-catch{font-size:1.11rem;line-height:1.85;}
  .hero-sub{font-size:0.9rem;margin-bottom:20px;}
  .hero-btns{flex-direction:column;gap:10px;}
  .btn-p,.btn-s{padding:13px 24px;font-size:0.98rem;width:100%;text-align:center;}
  .hero-score-bottom{display:none;}
  .photo-strip{grid-template-columns:1fr;} .photo-strip img{height:200px;}
  .score-bar{padding:0 12px;}
  .sb-wood img,.sb-moss img,.sb-cream img{height:60px;}
  section{padding:52px 16px;}
  .sec-title{font-size:1.5rem;} .sec-eyebrow{font-size:0.88rem;}
  .sec-lead{font-size:0.98rem;} .score-deco{display:none;}
  .concept-grid{grid-template-columns:1fr;gap:20px;}
  .concept-card{padding:24px 20px 56px;}
  .concept-quote{font-size:1.19rem;} .concept-desc{font-size:0.96rem;} .qm{font-size:3.0rem;}
  .pgn{grid-template-columns:1fr 1fr;gap:6px;}
  .pgn .pw{grid-column:span 2;aspect-ratio:16/7;}
  .pgn .pt{grid-row:auto;aspect-ratio:4/3;} .pgn .ps{aspect-ratio:4/3;}
  .concept-text h3{font-size:1.06rem;}
  .feat-grid{grid-template-columns:1fr;gap:14px;}
  .feat-card{padding:24px 20px 60px;}
  .feat-icon{width:44px;height:44px;font-size:1.3rem;} .csfooter{height:52px;}
  .work-layout{grid-template-columns:1fr;gap:16px;}
  .work-board{position:static;display:grid;grid-template-columns:repeat(2,1fr);gap:6px;padding:12px;border-radius:3px;}
  .wboard-title{display:none;}
  .wmenu-item{padding:10px 12px;border-left:none;border-radius:2px;background:rgba(255,255,255,0.07);justify-content:center;flex-direction:column;align-items:center;text-align:center;gap:4px;}
  .wmenu-item.active{background:rgba(196,135,42,0.2);border-bottom:2px solid var(--amber-l);}
  .wm-icon{font-size:1.24rem;} .wm-title{font-size:0.88rem;} .wm-sub{font-size:0.77rem;}
  .wpg{grid-template-columns:1fr 1fr;gap:6px;}
  .work-tag{font-size:0.88rem;padding:5px 12px;}
  .meal-grid{grid-template-columns:1fr;gap:14px;} .meal-card{padding:24px 20px 60px;}
  
  .info-board{padding:22px 18px;}
  .remote-grid{grid-template-columns:1fr;gap:14px;} .remote-card{padding:24px 20px 60px;}
  .flow-wrap{grid-template-columns:1fr 1fr;gap:10px;} .flow-wrap::before{display:none;}
  .flow-card{padding:20px 14px 60px;}
  .step-ring{width:42px;height:42px;font-size:1.14rem;margin-bottom:10px;}
  .access-layout{grid-template-columns:1fr;gap:20px;} .map-wrap{aspect-ratio:4/3;}
  #cta{padding:60px 16px;} .cta-score img{height:60px;}
  #cta h2{font-size:1.55rem;line-height:1.5;} .cta-tel{font-size:2.2rem;}
  .cta-btns{flex-direction:column;gap:10px;}
  .cta-btn-a,.cta-btn-o{padding:14px 20px;font-size:0.98rem;width:100%;text-align:center;}
  footer{padding:0 16px 28px;} .footer-score img{height:60px;}
  .footer-inner{flex-direction:column;align-items:flex-start;gap:16px;}
  .finfo{text-align:left;font-size:0.85rem;} .flogo-t{font-size:0.98rem;}
}
@media(max-width:390px){
  .hero-logo{width:min(260px,85vw);} .hero-catch{font-size:1.04rem;}
  .sec-title{font-size:1.35rem;} .wpg{grid-template-columns:1fr;}
  .pgn{grid-template-columns:1fr;} .pgn .pw,.pgn .pt{grid-column:auto;aspect-ratio:4/3;}
  .cta-tel{font-size:1.9rem;}
}
