/*
Theme Name: smilehome
*/
:root{
  --color-primary:#e8854a;--color-primary-dark:#b84c00;--color-primary-hover:#f56500;
  --color-primary-light:#f4a76e;--color-primary-pale:#fdf0e6;
  --color-primary-gradient:linear-gradient(135deg,#f4a76e 0%,#e8854a 50%,#d4703a 100%);
  --color-secondary:#8eb125;--color-secondary-dark:#6a8a10;--color-secondary-light:#a8c94e;
  --color-cta: #3BAD51;
  --color-warm:#f5e6d3;--color-cream:#faf6f1;--color-cream-dark:#f0e8dd;
  --color-dark:#2e2a24;--color-text:#2e2a24;--color-text-medium:#5a5348;--color-text-light:#8a7e72;
  --color-border:#e0d5c8;--color-border-light:#ede6dc;--color-white:#fff;
  --header-height:90px;--container:1200px;--container-wide:1600px;
  --font-ja:'Zen Maru Gothic','Hiragino Maru Gothic Pro',sans-serif;
  --font-en:'Poppins',sans-serif;--font-accent:'Cormorant Garamond',serif;
  --font-serif:'Noto Serif JP',serif;
  --font-logo:'Dancing Script',cursive;
  --shadow-subtle:0 1px 1px hsl(25 30% 40%/.06),0 2px 2px hsl(25 30% 40%/.06),0 4px 4px hsl(25 30% 40%/.06);
  --shadow-elevated:0 1px 2px hsl(25 30% 40%/.05),0 2px 4px hsl(25 30% 40%/.05),0 4px 8px hsl(25 30% 40%/.05),0 8px 16px hsl(25 30% 40%/.05);
  --shadow-floating:0 2px 4px hsl(25 30% 40%/.04),0 4px 8px hsl(25 30% 40%/.04),0 8px 16px hsl(25 30% 40%/.04),0 16px 32px hsl(25 30% 40%/.04),0 32px 64px hsl(25 30% 40%/.04);
  --shadow-mega:0 2px 4px hsl(25 30% 40%/.03),0 4px 8px hsl(25 30% 40%/.03),0 8px 16px hsl(25 30% 40%/.03),0 16px 32px hsl(25 30% 40%/.03),0 32px 64px hsl(25 30% 40%/.03),0 64px 128px hsl(25 30% 40%/.03);
  --border-subtle:1px solid var(--color-border-light);
  --radius-none:0px;--radius-full:9999px;
  --transition-fast:.2s cubic-bezier(.4,0,.2,1);
  --transition-base:.35s cubic-bezier(.4,0,.2,1);
  --transition-slow:.5s cubic-bezier(.25,.46,.45,.94);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-ja);font-size:15px;font-weight:500;line-height:1.9;color:var(--color-text);background:var(--color-cream);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:color var(--transition-fast)}
ul{list-style:none}
h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.4;color:var(--color-dark)}
.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.container-wide{max-width:var(--container-wide);margin:0 auto;padding:0 50px}

/* ============================================
   HEADER
   ============================================ */
.header{
  position:fixed;top:0;left:0;width:100%;height:var(--header-height);
  z-index:1000;background:transparent;
  transition:all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.header.scrolled{
  background:rgba(255, 255, 255, 0.95);
  backdrop-filter:blur(8px);
  height:70px;
  box-shadow:0 2px 15px rgba(0,0,0,0.05);
}
.header-inner{
  max-width:var(--container-wide);margin:0 auto;padding:0 50px;
  display:flex;align-items:center;justify-content:space-between;height:100%;
}
.header-logo text {
  font-family: var(--font-logo);
  font-size: 32px;
  fill: #fff;
  transition: fill var(--transition-base);
}
.header.scrolled .header-logo text {
  fill: var(--color-primary);
}

.header-nav{display:flex;align-items:center;gap:6px}
.header-nav a{
  font-size:12.5px;font-weight:600;letter-spacing:.04em;
  color:rgba(255,255,255,.95);
  padding:8px 16px;
  border-radius:var(--radius-full);
  border:1.5px solid rgba(255,255,255,.35);
  background:rgba(255,255,255,.1);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  transition:all .25s ease;
  position:relative;
}
.header-nav a:hover{
  background:rgba(255,255,255,.25);
  border-color:rgba(255,255,255,.6);
  transform:translateY(-1px);
}
.header-nav a::after{display:none}
.header.scrolled .header-nav a{
  color:var(--color-text-medium);
  border-color:var(--color-border);
  background:var(--color-white);
  box-shadow:0 1px 3px hsl(25 30% 40%/.08);
  backdrop-filter:none;
}
.header.scrolled .header-nav a:hover{
  color:var(--color-primary-dark);
  border-color:var(--color-primary);
  background:var(--color-primary-pale);
  box-shadow:0 2px 6px hsl(25 60% 50%/.15);
}

.header-cta{
  padding:9px 22px!important;font-size:12px!important;font-weight:700!important;
  color:#fff!important;background:var(--color-primary)!important;
  border:1.5px solid var(--color-primary)!important;
  border-bottom:4px solid var(--color-primary-dark)!important;
  box-shadow:0 2px 5px rgba(184,76,0,.3)!important;
  border-radius:var(--radius-full)!important;
  display:inline-flex!important;align-items:center!important;gap:6px!important;
  transition:all .15s ease!important;letter-spacing:.06em!important;
  backdrop-filter:none!important;
}
.header-cta:hover{
  background:var(--color-primary-hover)!important;
  border-bottom:2px solid var(--color-primary-dark)!important;
  margin-top:2px!important;box-shadow:0 1px 2px rgba(184,76,0,.2)!important;
  transform:none!important;
}
.header.scrolled .header-cta{
  color:#fff!important;background:var(--color-primary)!important;
  border-color:var(--color-primary)!important;
  border-bottom-color:var(--color-primary-dark)!important;
}

.header-menu-btn{display:none;background:none;border:none;cursor:pointer;width:32px;height:32px;position:relative}
.header-menu-btn span{display:block;width:24px;height:2px;background:#fff;position:absolute;left:4px;transition:var(--transition-base)}
.header.scrolled .header-menu-btn span{background:var(--color-text)}
.header-menu-btn span:nth-child(1){top:8px}
.header-menu-btn span:nth-child(2){top:15px}
.header-menu-btn span:nth-child(3){top:22px}

.mobile-menu{position:fixed;top:0;right:-100%;width:320px;height:100vh;background:var(--color-white);z-index:1001;transition:right var(--transition-base);padding:100px 40px 40px;box-shadow:var(--shadow-mega)}
.mobile-menu.active{right:0}
.mobile-menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(46,42,36,.5);z-index:1000;opacity:0;visibility:hidden;transition:var(--transition-base)}
.mobile-menu-overlay.active{opacity:1;visibility:visible}
.mobile-menu a{display:block;padding:16px 0;font-size:15px;font-weight:500;color:var(--color-text);border-bottom:var(--border-subtle)}

/* ============================================
   BUTTONS
   ============================================ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 36px;font-family:var(--font-ja);
  font-size:14px;font-weight:700;letter-spacing:.08em;
  border:none;cursor:pointer;border-radius:var(--radius-full);
  transition:all .15s ease;text-align:center;line-height:1.4;
}
.btn::after{
  content:'→';display:inline-flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:400;width:26px;height:26px;border-radius:50%;
  transition:all var(--transition-base);flex-shrink:0;
}
.btn-primary{color:#fff;background:var(--color-primary);border-bottom:5px solid var(--color-primary-dark);box-shadow:0 3px 5px rgba(184,76,0,.3)}
.btn-primary::after{background:rgba(255,255,255,.2);color:#fff}
.btn-primary:hover{margin-top:3px;background:var(--color-primary-hover);border-bottom:2px solid var(--color-primary-dark);box-shadow:0 1px 3px rgba(184,76,0,.2)}
.btn-primary:hover::after{transform:translateX(4px)}
.btn-outline{color:var(--color-primary);background:#fff;border:2px solid var(--color-primary);border-bottom:5px solid var(--color-primary-dark);box-shadow:0 3px 5px rgba(184,76,0,.15);padding:14px 34px}
.btn-outline::after{background:var(--color-primary-pale);color:var(--color-primary)}
.btn-outline:hover{margin-top:3px;background:var(--color-primary-pale);border-bottom:2px solid var(--color-primary-dark);box-shadow:0 1px 3px rgba(184,76,0,.1)}
.btn-outline:hover::after{transform:translateX(4px)}
.btn-white{color:var(--color-primary);background:#fff;border-bottom:5px solid #ccc;box-shadow:0 3px 5px rgba(0,0,0,.15)}
.btn-white::after{background:var(--color-primary-pale);color:var(--color-primary)}
.btn-white:hover{margin-top:3px;background:#f8f8f8;border-bottom:2px solid #ccc;box-shadow:0 1px 3px rgba(0,0,0,.1)}
.btn-white:hover::after{transform:translateX(4px)}
.btn-white-outline{color:#fff;background:transparent;border:2px solid rgba(255,255,255,.7);border-bottom:5px solid rgba(255,255,255,.4);box-shadow:0 3px 5px rgba(0,0,0,.2);padding:14px 34px}
.btn-white-outline::after{background:rgba(255,255,255,.15);color:#fff}
.btn-white-outline:hover{margin-top:3px;background:rgba(255,255,255,.1);border-bottom:2px solid rgba(255,255,255,.4);box-shadow:0 1px 3px rgba(0,0,0,.15)}
.btn-white-outline:hover::after{transform:translateX(4px)}

/* ============================================
   SECTION COMMON
   ============================================ */
.section{padding:110px 0;position:relative}
.section-label{font-family:var(--font-accent);font-style:italic;font-size:clamp(32px,5vw,48px);color:var(--color-primary);letter-spacing:.02em;line-height:1.2;margin-bottom:8px}
.section-title{font-size:clamp(20px,3vw,28px);font-weight:700;color:var(--color-dark);letter-spacing:.06em}
.section-header{text-align:center;margin-bottom:64px}

/* ============================================
   HERO
   ============================================ */
.hero {
  position: relative;
  height: 100vh;
  width: 100%;
  overflow: hidden;
  background: #000;
}

.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 1;
}
.hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.85;
  transform: scale(1.02);
  animation: subtleZoom 30s ease-out forwards;
}
@keyframes subtleZoom {
  to { transform: scale(1.15); }
}

.hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(105deg, rgba(0,0,0,0.65) 0%, rgba(0,0,0,0.2) 50%, transparent 100%);
}

.hero-content {
  position: absolute;
  inset: 0;
  z-index: 10;
  display: flex;
  align-items: center;
  max-width: var(--container-wide);
  margin: 0 auto;
  padding: 0 80px;
}

.message-area {
  max-width: 1200px;
  color: #fff;
  transform: translateY(-5%);
}

.hero-catch {
  font-family: var(--font-serif);
  font-size: clamp(44px, 7.5vw, 96px); /* 1回り小さく */
  line-height: 1.2;
  margin-bottom: 24px;
  font-weight: 900;
  letter-spacing: 0.05em;
  color: #fff; /* 白文字を明示 */
  -webkit-text-stroke: 0; /* 白枠を削除しスマートに */
  text-shadow: 0 4px 20px rgba(0,0,0,0.6); /* シャドウで可読性を担保 */
}

.hero-catch .text-summer {
  color: var(--color-cta);
}

.hero-catch .text-winter {
  color: var(--color-primary);
}

.hero-sub {
  font-size: clamp(16px, 2vw, 24px); /* 1回り小さく */
  font-weight: 700;
  letter-spacing: 0.25em;
  margin-bottom: 40px;
  display: block;
  opacity: 0.95;
  white-space: nowrap; /* スマホでも改行しない */
}

.hero-btn {
  display: inline-flex;
  align-items: center;
  gap: 20px;
  background: var(--color-cta);
  color: #fff;
  padding: 22px 64px; /* 1回り小さく */
  border: 2px solid #fff; /* 枠も少し細く */
  border-radius: 4px;
  text-decoration: none;
  font-weight: 700;
  font-size: 16px;
  letter-spacing: 0.2em;
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  box-shadow: 0 8px 24px rgba(0,0,0,0.3);
}
.hero-btn:hover {
  background: #fff;
  color: var(--color-cta);
  transform: translateY(-5px);
  box-shadow: 0 12px 32px rgba(0,0,0,0.4);
}

/* 波形 */
.hero-wave {
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 100%;
  z-index: 15;
}
.hero-wave svg {
  width: 100%;
  height: 60px;
  display: block;
}

/* ============================================
   FLOATING BANNERS
   ============================================ */
.floating-banners {
  position: fixed;
  right: 40px;
  bottom: 60px;
  z-index: 1100;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.float-banner {
  display: flex;
  align-items: center;
  width: 320px; /* 調整 */
  height: 80px;
  text-decoration: none;
  border-radius: 4px;
  box-shadow: 0 12px 30px rgba(0,0,0,0.25);
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  overflow: hidden;
  box-sizing: border-box;
}
.float-banner:hover {
  transform: translateX(-10px);
}

.float-banner.event {
  background: var(--color-cta);
  border: 2px solid #fff;
}
.float-banner.event span {
  color: #fff;
}

.float-banner.gift {
  background: #fff;
  border: 2px solid var(--color-primary);
}
.float-banner.gift span {
  color: var(--color-primary);
}

.float-banner .banner-thumb {
  width: 100px;
  height: 100%;
  flex-shrink: 0;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 5px;
  border-right: 1px solid rgba(0,0,0,0.05);
}
.float-banner .banner-thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.float-banner .banner-text {
  flex-grow: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0 10px;
}
.float-banner span {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.1em;
  white-space: nowrap;
  text-align: center;
}

/* ============================================
   AWARDS
   ============================================ */
.section-awards{padding:60px 0;background:var(--color-white)}
.awards-grid{display:flex;align-items:center;justify-content:center;gap:40px;flex-wrap:wrap}
.awards-grid a img{height:80px;object-fit:contain;filter:grayscale(20%);transition:filter var(--transition-base),transform var(--transition-base)}
.awards-grid a:hover img{filter:grayscale(0%);transform:scale(1.05)}

/* ============================================
   NEWS (Formerly EVENTS)
   ============================================ */
.section-news{padding:100px 0;background:var(--color-cream)}
.news-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:28px}
.news-card{background:var(--color-white);box-shadow:var(--shadow-subtle);overflow:hidden;transition:all var(--transition-base);display:flex;flex-direction:column;border:1px solid var(--color-border-light)}
.news-card:hover{box-shadow:var(--shadow-elevated);transform:translateY(-4px)}
.news-card-image{position:relative;overflow:hidden;height:200px}
.news-card-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}
.news-card:hover .news-card-image img{transform:scale(1.05)}
.news-card-badge{position:absolute;top:12px;left:12px;padding:4px 14px;font-size:11px;font-weight:700;color:#fff;background:var(--color-primary);border-radius:var(--radius-full)}
.news-card-body{padding:24px;flex:1;display:flex;flex-direction:column}
.news-card-date{font-family:var(--font-en);font-size:12px;font-weight:500;color:var(--color-text-light);margin-bottom:8px;letter-spacing:.06em}
.news-card-title{font-size:16px;font-weight:700;color:var(--color-dark);margin-bottom:12px;line-height:1.6}
.news-card-desc{font-size:13px;color:var(--color-text-medium);line-height:1.8;margin-bottom:16px;flex:1}
.news-card-link{font-size:13px;font-weight:600;color:var(--color-primary);display:inline-flex;align-items:center;gap:6px;transition:gap var(--transition-base)}
.news-card-link:hover{gap:10px}
.news-more{text-align:center;margin-top:48px}

/* ============================================
   FEATURES BANNER
   ============================================ */
.section-features-banner{position:relative;overflow:hidden;height:180px}
.section-features-banner img{width:100%;height:100%;object-fit:cover;display:block}
.features-banner-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(184,76,0,.65) 0%,rgba(232,133,74,.3) 50%,transparent 100%);display:flex;align-items:center;padding:0 60px}
.features-banner-text{color:#fff}
.features-banner-text .section-label{color:rgba(255,255,255,.85);font-size:28px;margin-bottom:4px;font-family:var(--font-logo);font-style:normal}
.features-banner-text h2{font-size:22px;color:#fff;letter-spacing:.06em}

/* ============================================
   FEATURES
   ============================================ */
.section-features{padding:110px 0;background:linear-gradient(180deg,var(--color-cream) 0%,var(--color-warm) 50%,var(--color-cream) 100%);position:relative;overflow:hidden}
.section-features::before{content:'';position:absolute;top:-200px;right:-200px;width:600px;height:600px;background:radial-gradient(circle,hsl(25 80% 60%/.06),transparent 70%);pointer-events:none}
.section-features::after{content:'';position:absolute;bottom:-200px;left:-200px;width:600px;height:600px;background:radial-gradient(circle,hsl(75 60% 50%/.05),transparent 70%);pointer-events:none}

.features-intro{max-width:800px;margin:0 auto 80px;text-align:center;}
.features-intro-text h2{font-size:clamp(24px,3.5vw,36px);color:var(--color-dark);margin-bottom:20px;line-height:1.5}
.features-intro-text p{font-size:15px;line-height:2;color:var(--color-text-medium);text-align:left;}

.feature-row{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;margin-bottom:100px}
.feature-row:last-child{margin-bottom:0}
.feature-row:nth-child(even) .feature-image{order:2}
.feature-row:nth-child(even) .feature-text{order:1}
.feature-image{position:relative;z-index:1}
.feature-image::before{content:'';position:absolute;top:20px;left:20px;width:100%;height:100%;background:var(--color-primary-pale);z-index:-1;transition:all var(--transition-base)}
.feature-image::after{content:'';position:absolute;bottom:-12px;right:-12px;width:80px;height:80px;border:3px solid var(--color-primary-light);z-index:-1;transition:all var(--transition-base)}
.feature-row:nth-child(even) .feature-image::before{left:auto;right:20px}
.feature-row:nth-child(even) .feature-image::after{right:auto;left:-12px}
.feature-image img{width:100%;aspect-ratio:4/3;object-fit:cover;position:relative;z-index:1;box-shadow:var(--shadow-floating);transition:all var(--transition-base)}
.feature-image:hover img{transform:translateY(-8px) translateX(-4px);box-shadow:var(--shadow-mega)}
.feature-image:hover::before{top:28px;left:28px}
.feature-row:nth-child(even) .feature-image:hover::before{left:auto;right:28px}
.feature-image:hover::after{bottom:-18px;right:-18px}
.feature-row:nth-child(even) .feature-image:hover::after{right:auto;left:-18px}
.feature-num{font-family:var(--font-accent);font-style:italic;font-size:72px;line-height:1;color:hsl(25 80% 60%/.12);margin-bottom:-8px}
.feature-title{font-size:clamp(22px,3vw,30px);font-weight:700;color:var(--color-dark);margin-bottom:8px}
.feature-title-en{font-family:var(--font-en);font-size:13px;font-weight:400;color:var(--color-primary);letter-spacing:.08em;text-transform:uppercase;margin-bottom:20px}
.feature-desc{font-size:15px;line-height:2;color:var(--color-text-medium);margin-bottom:24px}
.feature-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 16px;background:var(--color-primary-pale);color:var(--color-primary-dark);font-size:12px;font-weight:600;border-radius:var(--radius-full)}

/* ============================================
   EVENT HIGHLIGHT (Formerly MODEL HOUSE)
   ============================================ */
.section-event-highlight{padding:110px 0;background:var(--color-cream)}
.event-highlight-layout{display:grid;grid-template-columns:1.2fr 1fr;gap:80px;align-items:center}
.event-highlight-image{position:relative}
.event-highlight-image::before{content:'';position:absolute;top:-16px;left:-16px;width:120px;height:120px;border:3px solid var(--color-primary-light);z-index:0;transition:all var(--transition-base);animation:eventFloat1 6s ease-in-out infinite}
.event-highlight-image::after{content:'';position:absolute;bottom:-20px;right:-20px;width:160px;height:160px;background:var(--color-primary-pale);z-index:0;transition:all var(--transition-base);animation:eventFloat2 8s ease-in-out infinite}
@keyframes eventFloat1 {0%,100%{transform:translate(0,0) rotate(0deg)}50%{transform:translate(-8px,-8px) rotate(-2deg)}}
@keyframes eventFloat2 {0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(8px,8px) scale(1.05)}}
.event-highlight-image img{width:100%;position:relative;z-index:1;box-shadow:var(--shadow-floating);transition:all 0.6s cubic-bezier(0.25,1,0.5,1)}
.event-highlight-image:hover img{transform:translateY(-8px) scale(1.02);box-shadow:var(--shadow-mega)}
.event-highlight-text h2{font-size:clamp(22px,3vw,32px);color:var(--color-dark);margin-bottom:20px}
.event-highlight-text p{font-size:15px;line-height:2;color:var(--color-text-medium);margin-bottom:32px}

/* ============================================
   VOICE
   ============================================ */
.section-voice{padding:110px 0;background:var(--color-white)}
.voice-slider{padding-bottom:60px}
.voice-card{background:var(--color-cream);padding:40px;box-shadow:var(--shadow-subtle);transition:all var(--transition-base)}
.voice-card:hover{box-shadow:var(--shadow-elevated);transform:translateY(-4px)}
.voice-card-header{display:flex;align-items:center;gap:20px;margin-bottom:20px}
.voice-avatar{width:56px;height:56px;object-fit:cover;box-shadow:var(--shadow-subtle);border-radius:50%;border:3px solid var(--color-primary-pale)}
.voice-meta{font-size:13px}.voice-name{font-weight:700;color:var(--color-dark)}.voice-area{color:var(--color-text-light)}
.voice-body{font-size:14px;line-height:2;color:var(--color-text-medium)}
.voice-body::before{content:'"';font-family:var(--font-accent);font-size:48px;color:var(--color-primary-light);line-height:.5;display:block;margin-bottom:8px}
.voice-slider .swiper-pagination{bottom:0!important}
.voice-slider .swiper-pagination-bullet{width:10px;height:10px;background:var(--color-border);opacity:1;border-radius:0;transition:var(--transition-base)}
.voice-slider .swiper-pagination-bullet-active{width:32px;background:var(--color-primary)}

/* ============================================
   WORKS (CSS Marquee)
   ============================================ */
.section-works{padding:110px 0;background:var(--color-cream-dark)}
.works-marquee{overflow:hidden;width:100%;padding-bottom:20px}
.works-marquee-track{display:flex;width:max-content}
.works-marquee-list{display:flex;gap:16px;padding-right:16px;animation:marquee 30s linear infinite}
.works-marquee-track:hover .works-marquee-list{animation-play-state:paused}
.work-item{position:relative;overflow:hidden;box-shadow:var(--shadow-subtle);cursor:pointer;display:block;width:280px;height:320px;border-radius:8px;flex-shrink:0}
.work-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.25,.46,.45,.94)}
.work-item:hover img{transform:scale(1.08)}
.work-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(46,42,36,.65) 0%,transparent 60%);display:flex;flex-direction:column;justify-content:flex-end;padding:24px;opacity:0;transition:opacity var(--transition-base)}
.work-item:hover .work-overlay{opacity:1}
.work-tag{display:inline-block;padding:4px 14px;background:var(--color-primary);color:#fff;font-size:11px;font-weight:600;border-radius:var(--radius-full);margin-bottom:8px;width:fit-content}
.work-title{color:#fff;font-size:15px;font-weight:600}
.work-spec{color:rgba(255,255,255,.7);font-size:12px;margin-top:4px}
.works-bottom{text-align:center;margin-top:48px}

@media(min-width:768px){
  .works-marquee-list{gap:24px;padding-right:24px}
  .work-item{width:360px}
}
@media(min-width:1024px){
  .work-item{width:400px}
}
@keyframes marquee{
  0%{transform:translateX(0)}
  100%{transform:translateX(-100%)}
}

/* ============================================
   CTA
   ============================================ */
.section-cta{padding:100px 0;background:var(--color-primary-gradient);text-align:center;position:relative;overflow:hidden}
.section-cta::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.1),transparent 70%)}
.section-cta::after{content:'';position:absolute;bottom:-100px;left:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.08),transparent 70%)}
.cta-title{font-size:clamp(24px,4vw,36px);color:#fff;margin-bottom:16px}
.cta-sub{font-size:15px;color:rgba(255,255,255,.85);margin-bottom:40px}
.cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}

/* ============================================
   FOOTER
   ============================================ */
.footer{background:var(--color-dark);color:rgba(255,255,255,.7);padding:80px 0 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:60px}
.footer-brand-logo{height:32px;margin-bottom:20px}
.footer-brand p{font-size:13px;line-height:1.8}
.footer h4{color:#fff;font-size:14px;font-weight:600;margin-bottom:20px;letter-spacing:.06em}
.footer a{display:block;padding:6px 0;font-size:13px;color:rgba(255,255,255,.6);transition:color var(--transition-fast)}
.footer a:hover{color:var(--color-primary-light)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:24px 0;text-align:center;font-size:12px;color:rgba(255,255,255,.4)}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1024px){
  .header-nav{display:none}.header-menu-btn{display:block}
  .feature-row{grid-template-columns:1fr 1fr;gap:48px}
  .event-highlight-layout{grid-template-columns:1fr 1fr;gap:48px}
  .footer-grid{grid-template-columns:1fr 1fr}

  .hero-content { padding: 0 40px; }
  .float-banner { width: 280px; height: 70px; }
  .float-banner span { font-size: 14px; }
}
@media(max-width:768px){
  .header { height: 70px; }
  .header-inner { padding: 0 20px; }
  .header-logo text { font-size: 24px; }
  
  .hero{height:100svh;min-height:500px}
  .hero-content {
    padding: 0 20px;
    align-items: center;
    text-align: center;
  }
  .message-area { transform: none; width: 100%; }
  
  /* モバイル用のサイズ切り替え・白枠削除 */
  .hero-catch { 
    font-size: clamp(32px, 8vw, 44px); 
    margin-bottom: 16px; 
    letter-spacing: 0.05em;
  }
  .hero-sub { 
    font-size: clamp(12px, 3.5vw, 15px); 
    letter-spacing: 0.1em; 
    margin-bottom: 30px; 
  }
  
  .hero-btn { 
    padding: 16px 30px; 
    width: 100%; 
    max-width: 280px;
    box-sizing: border-box; 
    justify-content: center; 
    font-size: 15px;
    border-width: 2px;
  }
  
  /* スマホ版フローティングバナーを画面下部固定の2分割に変更 */
  .floating-banners {
    bottom: 0;
    right: 0;
    width: 100%;
    flex-direction: row;
    gap: 0;
    background: #fff;
    padding: 0;
  }
  .float-banner { 
    width: 50%; 
    height: 64px; 
    border-radius: 0;
    box-shadow: none;
    border: none;
    border-top: 1px solid #eee;
  }
  .float-banner.event {
    border: none;
    border-top: 2px solid var(--color-cta);
  }
  .float-banner.gift {
    border: none;
    border-top: 2px solid var(--color-border);
  }
  .float-banner:not(:last-child) {
    border-right: 1px solid #f0f0f0;
  }
  .float-banner .banner-thumb { 
    width: 50px;
    padding: 6px;
    border-right: none;
    background: transparent;
  }
  .float-banner .banner-text {
    padding: 0 4px 0 0;
    justify-content: flex-start;
  }
  .float-banner span { 
    font-size: 11px; 
    letter-spacing: 0; 
    white-space: nowrap;
    text-align: left;
  }
  
  .hero-wave svg { height: 40px; }

  .section{padding:80px 0}
  .section-features-banner{height:120px}
  .features-banner-overlay{padding:0 24px}
  .features-banner-text .section-label{font-size:20px}
  .features-banner-text h2{font-size:16px}
  .feature-row{grid-template-columns:1fr;gap:32px}
  .feature-row:nth-child(even) .feature-image{order:0}
  .feature-row:nth-child(even) .feature-text{order:0}
  .feature-image::before{top:12px;left:12px}.feature-image::after{bottom:-8px;right:-8px;width:50px;height:50px}
  .news-grid{grid-template-columns:1fr}
  .event-highlight-layout{grid-template-columns:1fr}
  .event-highlight-image::before{width:80px;height:80px;top:-10px;left:-10px}
  .event-highlight-image::after{width:100px;height:100px;bottom:-12px;right:-12px}
  .work-overlay{opacity:1}
  .footer-grid{grid-template-columns:1fr}
  .cta-btns{flex-direction:column;align-items:center}
}
@media(max-width:480px){
  body{font-size:14px}.container{padding:0 16px}
  .btn{padding:14px 28px;font-size:13px}
  .feature-image::before{top:8px;left:8px}.feature-image::after{display:none}
  .section-features-banner{height:100px}
}
.swiper-pagination-bullet{border-radius:0!important}

:root {
  --color-primary: #e8854a;
  /* ...（以下、すべてのCSSを貼り付け） */
}

/* WordPress特有の微調整 */
.admin-bar .header { top: 32px; }
@media screen and (max-width: 782px) {
  .admin-bar .header { top: 46px; }
}
/* ===== VARIABLES ===== */
:root{
  --color-primary:#e8854a;--color-primary-dark:#b84c00;--color-primary-hover:#f56500;
  --color-primary-light:#f4a76e;--color-primary-pale:#fdf0e6;
  --color-primary-gradient:linear-gradient(135deg,#f4a76e 0%,#e8854a 50%,#d4703a 100%);
  --color-secondary:#8eb125;--color-secondary-dark:#6a8a10;--color-secondary-light:#a8c94e;--color-secondary-pale:#f2f7e4;
  --color-warm:#f5e6d3;--color-cream:#faf6f1;--color-cream-dark:#f0e8dd;
  --color-dark:#2e2a24;--color-text:#2e2a24;--color-text-medium:#5a5348;--color-text-light:#8a7e72;
  --color-border:#e0d5c8;--color-border-light:#ede6dc;--color-white:#fff;
  --color-blue:#5b9bd5;--color-blue-pale:#eaf2fb;
  --color-pink:#e88a9a;--color-pink-pale:#fdf0f2;
  --header-height:72px;--container:1200px;--container-wide:1400px;
  --font-ja:'Zen Maru Gothic','Hiragino Maru Gothic Pro',sans-serif;
  --font-en:'Poppins',sans-serif;--font-accent:'Cormorant Garamond',serif;
  --font-logo:'Dancing Script',cursive;
  --font-handwritten:'Zen Kurenaido','Zen Maru Gothic',sans-serif;
  --shadow-subtle:0 2px 8px rgba(46,42,36,.06);
  --shadow-elevated:0 4px 20px rgba(46,42,36,.1);
  --shadow-floating:0 8px 32px rgba(46,42,36,.1);
  --shadow-mega:0 12px 48px rgba(46,42,36,.12);
  --shadow-card:0 4px 16px rgba(232,133,74,.08);
  --shadow-pop:0 6px 0 rgba(46,42,36,.06);
  --border-subtle:1px solid var(--color-border-light);
  --radius-sm:0;--radius-md:0;--radius-lg:0;--radius-xl:0;--radius-full:9999px;
  --transition-fast:.2s cubic-bezier(.4,0,.2,1);
  --transition-base:.35s cubic-bezier(.4,0,.2,1);
  --transition-slow:.5s cubic-bezier(.25,.46,.45,.94);
  --transition-bounce:.5s cubic-bezier(.34,1.56,.64,1);
}

/* ===== RESET ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-ja);font-size:15px;font-weight:500;line-height:1.9;color:var(--color-text);background:var(--color-cream);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:color var(--transition-fast)}
ul{list-style:none}
h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.4;color:var(--color-dark)}
.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.container-narrow{max-width:900px;margin:0 auto;padding:0 24px}

/* scroll-margin for anchor offset */
[id]{scroll-margin-top:100px}

/* ===== LOGO ===== */
.logo-svg{overflow:visible;display:block}
.logo-svg text{font-family:var(--font-logo);font-size:38px;font-weight:700;fill:none;stroke:#fff;stroke-width:1.2;stroke-dasharray:600;stroke-dashoffset:600;animation:drawLogo 2.5s ease forwards .5s}
.logo-svg .logo-fill{fill:#fff;stroke:none;opacity:0;animation:fillLogo .6s ease forwards 2.4s}
.header.scrolled .logo-svg text{stroke:var(--color-primary)}
.header.scrolled .logo-svg .logo-fill{fill:var(--color-primary)}
@keyframes drawLogo{to{stroke-dashoffset:0}}
@keyframes fillLogo{to{opacity:1}}

/* ===== HEADER ===== */
.header{position:fixed;top:0;left:0;width:100%;height:var(--header-height);z-index:1000;background:transparent;transition:background .4s ease,box-shadow .4s ease}
.header.scrolled{background:rgba(250,246,241,.96);backdrop-filter:blur(16px);box-shadow:var(--shadow-subtle)}
.header-inner{max-width:var(--container-wide);margin:0 auto;padding:0 32px;display:flex;align-items:center;justify-content:space-between;height:100%}
.header-logo{display:flex;align-items:center;gap:8px}
.header-nav{display:flex;align-items:center;gap:6px}
.header-nav a{font-size:12.5px;font-weight:600;letter-spacing:.04em;color:rgba(255,255,255,.95);padding:8px 16px;border-radius:var(--radius-full);border:1.5px solid rgba(255,255,255,.35);background:rgba(255,255,255,.1);backdrop-filter:blur(6px);transition:all .25s ease}
.header-nav a:hover{background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.6);transform:translateY(-1px)}
.header.scrolled .header-nav a{color:var(--color-text-medium);border-color:var(--color-border);background:var(--color-white);box-shadow:0 1px 3px hsl(25 30% 40%/.08);backdrop-filter:none}
.header.scrolled .header-nav a:hover{color:var(--color-primary-dark);border-color:var(--color-primary);background:var(--color-primary-pale)}
.header.scrolled .header-nav a.current{color:var(--color-primary-dark);border-color:var(--color-primary);background:var(--color-primary-pale)}
.header-cta{padding:9px 22px!important;font-size:12px!important;font-weight:700!important;color:#fff!important;background:var(--color-primary)!important;border:1.5px solid var(--color-primary)!important;border-bottom:4px solid var(--color-primary-dark)!important;box-shadow:0 2px 5px rgba(184,76,0,.3)!important;border-radius:var(--radius-full)!important;display:inline-flex!important;align-items:center!important;gap:6px!important;transition:all .15s ease!important;letter-spacing:.06em!important;backdrop-filter:none!important}
.header-cta:hover{background:var(--color-primary-hover)!important;border-bottom:2px solid var(--color-primary-dark)!important;margin-top:2px!important;box-shadow:0 1px 2px rgba(184,76,0,.2)!important;transform:none!important}
.header.scrolled .header-cta{color:#fff!important;background:var(--color-primary)!important;border-color:var(--color-primary)!important;border-bottom-color:var(--color-primary-dark)!important}
.header-menu-btn{display:none;background:none;border:none;cursor:pointer;width:32px;height:32px;position:relative}
.header-menu-btn span{display:block;width:24px;height:2px;background:#fff;position:absolute;left:4px;transition:var(--transition-base)}
.header.scrolled .header-menu-btn span{background:var(--color-text)}
.header-menu-btn span:nth-child(1){top:8px}.header-menu-btn span:nth-child(2){top:15px}.header-menu-btn span:nth-child(3){top:22px}
.mobile-menu{position:fixed;top:0;right:-100%;width:320px;height:100vh;background:var(--color-white);z-index:1001;transition:right var(--transition-base);padding:100px 40px 40px;box-shadow:var(--shadow-mega);overflow-y:auto}
.mobile-menu.active{right:0}
.mobile-menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(46,42,36,.5);z-index:1000;opacity:0;visibility:hidden;transition:var(--transition-base)}
.mobile-menu-overlay.active{opacity:1;visibility:visible}
.mobile-menu a{display:block;padding:16px 0;font-size:15px;font-weight:500;color:var(--color-text);border-bottom:var(--border-subtle)}
.mobile-menu-close{position:absolute;top:24px;right:24px;width:36px;height:36px;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center}
.mobile-menu-close::before,.mobile-menu-close::after{content:'';position:absolute;width:20px;height:2px;background:var(--color-text)}
.mobile-menu-close::before{transform:rotate(45deg)}.mobile-menu-close::after{transform:rotate(-45deg)}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 36px;font-family:var(--font-ja);font-size:14px;font-weight:700;letter-spacing:.08em;border:none;cursor:pointer;border-radius:var(--radius-full);transition:all .15s ease;text-align:center;line-height:1.4;justify-content:center}
.btn::after{content:'\2192';display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:400;width:26px;height:26px;border-radius:50%;transition:all var(--transition-base);flex-shrink:0}
.btn-primary{color:#fff;background:var(--color-primary);border-bottom:5px solid var(--color-primary-dark);box-shadow:0 3px 5px rgba(184,76,0,.3)}
.btn-primary::after{background:rgba(255,255,255,.2);color:#fff}
.btn-primary:hover{margin-top:3px;background:var(--color-primary-hover);border-bottom:2px solid var(--color-primary-dark);box-shadow:0 1px 3px rgba(184,76,0,.2)}
.btn-primary:hover::after{transform:translateX(4px)}
.btn-white{color:var(--color-primary);background:#fff;border-bottom:5px solid #ccc;box-shadow:0 3px 5px rgba(0,0,0,.15)}
.btn-white::after{background:var(--color-primary-pale);color:var(--color-primary)}
.btn-white:hover{margin-top:3px;background:#f8f8f8;border-bottom:2px solid #ccc;box-shadow:0 1px 3px rgba(0,0,0,.1)}
.btn-white:hover::after{transform:translateX(4px)}
.btn-white-outline{color:#fff;background:transparent;border:2px solid rgba(255,255,255,.7);border-bottom:5px solid rgba(255,255,255,.4);box-shadow:0 3px 5px rgba(0,0,0,.2);padding:14px 34px}
.btn-white-outline::after{background:rgba(255,255,255,.15);color:#fff}
.btn-white-outline:hover{margin-top:3px;background:rgba(255,255,255,.1);border-bottom:2px solid rgba(255,255,255,.4);box-shadow:0 1px 3px rgba(0,0,0,.15)}
.btn-white-outline:hover::after{transform:translateX(4px)}
.btn-secondary{color:#fff;background:var(--color-secondary);border-bottom:5px solid var(--color-secondary-dark);box-shadow:0 3px 5px rgba(106,138,16,.3)}
.btn-secondary::after{background:rgba(255,255,255,.2);color:#fff}
.btn-secondary:hover{margin-top:3px;background:var(--color-secondary-light);border-bottom:2px solid var(--color-secondary-dark);box-shadow:0 1px 3px rgba(106,138,16,.2)}
.btn-secondary:hover::after{transform:translateX(4px)}

/* ===== PAGE HERO ===== */
.page-hero{position:relative;height:400px;overflow:hidden}
.page-hero img{width:100%;height:100%;object-fit:cover}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(46,42,36,.55) 0%,rgba(232,133,74,.35) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:0 24px}
.page-hero-label{font-family:var(--font-accent);font-style:italic;font-size:clamp(40px,7vw,64px);color:rgba(255,255,255,.9);margin-bottom:8px}
.page-hero-title{font-size:clamp(20px,3vw,28px);font-weight:700;color:#fff;letter-spacing:.08em}
.page-hero-wave{position:absolute;bottom:-1px;left:0;width:100%;z-index:5;line-height:0}
.page-hero-wave svg{width:100%;height:auto;display:block}

/* ===== BREADCRUMB ===== */
.breadcrumb{padding:20px 0;font-size:12px;color:var(--color-text-light)}
.breadcrumb a{color:var(--color-text-light)}.breadcrumb a:hover{color:var(--color-primary)}
.breadcrumb span{margin:0 8px;opacity:.5}

/* ===== INTRO ===== */
.section-intro{padding:100px 0 60px;background:var(--color-cream);text-align:center;position:relative}
.section-intro::before{content:'';position:absolute;top:40px;left:50%;transform:translateX(-50%);width:120px;height:120px;background:radial-gradient(circle,rgba(232,133,74,.08),transparent 70%);border-radius:50%;pointer-events:none}
.intro-catch{font-family:var(--font-handwritten);font-size:clamp(28px,4.5vw,44px);color:var(--color-dark);line-height:1.6;margin-bottom:32px}
.intro-catch em{font-style:normal;color:var(--color-primary);background:linear-gradient(transparent 60%,rgba(232,133,74,.15) 60%);padding:0 4px}
.intro-desc{max-width:720px;margin:0 auto;font-size:15px;line-height:2.2;color:var(--color-text-medium)}

/* ===== TRUST GRID ===== */
.section-trust{padding:0 0 80px;background:var(--color-cream)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;max-width:var(--container);margin:0 auto;padding:0 24px}
.trust-card{background:#fff;padding:28px 20px;text-align:center;position:relative;overflow:hidden;box-shadow:var(--shadow-card),0 4px 0 var(--color-primary-light);transition:transform var(--transition-bounce),box-shadow var(--transition-base)}
.trust-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-elevated),0 6px 0 var(--color-primary)}
.trust-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--color-primary-gradient)}
.trust-val{font-family:var(--font-en);font-size:clamp(28px,3.5vw,40px);font-weight:700;color:var(--color-primary);line-height:1.2;margin-bottom:4px}
.trust-val span{font-size:14px;color:var(--color-text-medium);font-weight:500;margin-left:4px}
.trust-label{font-size:13px;font-weight:700;color:var(--color-dark);line-height:1.4}
.trust-sub{font-size:11px;color:var(--color-text-light);margin-top:6px;background:var(--color-primary-pale);padding:4px 12px;border-radius:var(--radius-full);display:inline-block}

/* ===== FEATURE NAV ===== */
.feature-nav{padding:0 0 80px;background:var(--color-cream)}
.feature-nav-inner{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;max-width:var(--container);margin:0 auto;padding:0 24px}
.feature-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 12px;background:#fff;border:2px solid var(--color-border-light);box-shadow:var(--shadow-subtle),0 3px 0 var(--color-border);transition:all .2s ease;cursor:pointer}
.feature-nav-item:hover{border-color:var(--color-primary);transform:translateY(-5px);box-shadow:var(--shadow-elevated),0 5px 0 var(--color-primary-light);background:var(--color-primary-pale)}
.feature-nav-num{font-family:var(--font-en);font-size:32px;font-weight:700;color:var(--color-primary);line-height:1;margin-bottom:8px}
.feature-nav-label{font-size:12.5px;font-weight:700;color:var(--color-dark)}

/* ===== FEATURE SECTIONS ===== */
.section-detail{padding:100px 0;position:relative;overflow:hidden}
.bg-white{background:#fff}
.bg-cream{background:var(--color-cream)}
.bg-cream::before{content:'';position:absolute;top:60px;right:40px;width:180px;height:180px;background:radial-gradient(circle,var(--color-primary-pale) 2px,transparent 2px);background-size:20px 20px;opacity:.4;pointer-events:none}
.bg-white::after{content:'';position:absolute;bottom:60px;left:40px;width:160px;height:160px;background:radial-gradient(circle,var(--color-primary-pale) 2px,transparent 2px);background-size:20px 20px;opacity:.3;pointer-events:none}

.detail-header{text-align:center;margin-bottom:60px;position:relative}
.detail-num{font-family:var(--font-en);font-size:100px;font-weight:800;line-height:1;color:transparent;-webkit-text-stroke:2px var(--color-primary-light);margin-bottom:-30px;opacity:.4}
.detail-title{font-size:clamp(26px,4vw,36px);font-weight:700;color:var(--color-dark);position:relative;z-index:1}
.detail-en{font-family:var(--font-en);font-size:13px;color:var(--color-primary);letter-spacing:.1em;text-transform:uppercase;margin-top:8px;font-weight:500}

/* h2 heading animation */
@keyframes h2SlideUp{0%{opacity:0;transform:translateY(30px)}100%{opacity:1;transform:translateY(0)}}
@keyframes h2Underline{0%{width:0}100%{width:60px}}
.detail-title{opacity:0;transform:translateY(30px)}
.detail-header.aos-animate .detail-title{animation:h2SlideUp .8s ease both}
.detail-title::after{content:'';display:block;height:4px;margin:14px auto 0;background:var(--color-primary-gradient);border-radius:2px;width:0;animation:none}
.detail-header.aos-animate .detail-title::after{animation:h2Underline .6s ease .6s both}

/* 2-col grid */
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;margin-bottom:60px}
.detail-grid.reverse .detail-img{order:2}
.detail-grid.reverse .detail-txt{order:1}
.detail-img{position:relative}
.detail-img img{width:100%;aspect-ratio:4/3;object-fit:cover;box-shadow:var(--shadow-floating)}
.detail-img::before{content:'';position:absolute;top:16px;left:16px;width:100%;height:100%;border:3px dashed var(--color-primary-light);z-index:-1;opacity:.6}
.detail-txt h3{font-size:24px;margin-bottom:20px;line-height:1.5}
.detail-txt h3 em{font-style:normal;color:var(--color-primary);background:linear-gradient(transparent 60%,rgba(232,133,74,.15) 60%);padding:0 2px}
.detail-txt p{font-size:15px;line-height:2;color:var(--color-text-medium);margin-bottom:24px}

/* Sub-header */
.sub-header{text-align:center;margin:80px 0 40px;position:relative}
.sub-header h3{font-size:24px;font-weight:700;color:var(--color-dark);display:inline-block;position:relative}
.sub-header h3::after{content:'';position:absolute;bottom:-8px;left:50%;transform:translateX(-50%);width:60px;height:4px;background:var(--color-primary-gradient);border-radius:2px}
.sub-header .detail-en{margin-top:12px}

/* Explainer box */
.explainer-box{background:var(--color-cream);padding:40px 44px;margin-bottom:60px;position:relative;border:2px solid var(--color-primary-light);box-shadow:var(--shadow-card),0 4px 0 var(--color-primary-pale)}
.bg-cream .explainer-box{background:#fff}
.explainer-box::before{content:'';position:absolute;top:-14px;left:32px;width:0;height:0;border-left:14px solid transparent;border-right:14px solid transparent;border-bottom:14px solid var(--color-primary-light)}
.explainer-box::after{content:'';position:absolute;top:-11px;left:34px;width:0;height:0;border-left:12px solid transparent;border-right:12px solid transparent;border-bottom:12px solid var(--color-cream)}
.bg-cream .explainer-box::after{border-bottom-color:#fff}
.explainer-box h4{font-size:20px;color:var(--color-primary-dark);margin-bottom:16px;display:flex;align-items:center;gap:10px}
.explainer-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--color-primary);color:#fff;font-family:var(--font-en);font-size:18px;font-weight:800;flex-shrink:0;box-shadow:0 3px 0 var(--color-primary-dark)}
.explainer-box p{font-size:14px;line-height:2;color:var(--color-text-medium);margin-bottom:16px}
.explainer-box p:last-child{margin-bottom:0}

/* Award banner */
.award-banner{background:var(--color-dark);color:#fff;padding:36px 44px;margin-bottom:60px;display:flex;align-items:center;gap:28px;position:relative;overflow:hidden}
.award-banner::before{content:'';position:absolute;top:-30px;right:-30px;width:120px;height:120px;background:var(--color-primary);border-radius:50%;opacity:.15}
.award-banner::after{content:'';position:absolute;bottom:-20px;left:30%;width:80px;height:80px;background:var(--color-primary);border-radius:50%;opacity:.08}
.award-banner-icon{width:72px;height:72px;border-radius:50%;background:transparent;color:var(--color-primary-light);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;z-index:1;border:3px solid var(--color-primary-light)}
.award-banner-icon .icon-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1}
.award-banner-icon .icon-label{font-family:var(--font-en);font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-primary-light)}
.award-banner-icon .icon-year{font-family:var(--font-en);font-size:22px;font-weight:800;color:#fff;margin-top:2px}
.award-banner-text{position:relative;z-index:1}
.award-banner-text h4{font-size:20px;color:#fff;margin-bottom:6px}
.award-banner-text p{font-size:14px;color:rgba(255,255,255,.75);line-height:1.7}
.award-banner-tag{display:inline-block;background:var(--color-primary);color:#fff;font-size:11px;font-weight:700;padding:4px 14px;border-radius:var(--radius-full);margin-top:8px;letter-spacing:.06em}

/* Merit cards */
.merit-grid-6{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:60px}
.merit-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:60px}
.merit-card{background:var(--color-cream);padding:32px 24px;position:relative;border:1.5px solid var(--color-border-light);box-shadow:var(--shadow-subtle),0 3px 0 var(--color-border);transition:all .2s ease}
.bg-cream .merit-card{background:#fff}
.merit-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-elevated),0 5px 0 var(--color-primary-light);border-color:var(--color-primary-light)}
.merit-icon{width:52px;height:52px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:16px;font-family:var(--font-en);font-weight:800;box-shadow:0 3px 0 rgba(0,0,0,.08)}
.merit-icon.orange{background:var(--color-primary-pale);color:var(--color-primary)}
.merit-icon.green{background:var(--color-secondary-pale);color:var(--color-secondary)}
.merit-icon.blue{background:var(--color-blue-pale);color:var(--color-blue)}
.merit-icon.pink{background:var(--color-pink-pale);color:var(--color-pink)}
.merit-card h4{font-size:16px;margin-bottom:10px;color:var(--color-dark)}
.merit-card p{font-size:13px;line-height:1.8;color:var(--color-text-medium)}

/* Supplement box */
.supplement-box{max-width:840px;margin:0 auto;background:var(--color-cream);padding:40px 44px;position:relative;border:1.5px solid var(--color-border-light);border-top:none;box-shadow:var(--shadow-card),0 4px 0 var(--color-primary-pale)}
.supplement-box::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:var(--color-primary-gradient)}
.bg-cream .supplement-box{background:#fff}
.supplement-box h4{font-size:18px;color:var(--color-primary-dark);margin-bottom:12px;display:flex;align-items:center;gap:12px}
.supplement-box h4::before{content:'Point';font-family:var(--font-en);font-size:11px;font-weight:700;color:#fff;background:var(--color-primary);padding:3px 12px;border-radius:var(--radius-full);letter-spacing:.06em;flex-shrink:0}
.supplement-box p{font-size:14px;line-height:2;color:var(--color-text-medium)}

/* Points grid */
.points-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.point-card{background:var(--color-cream);padding:32px 24px;position:relative;border:1.5px solid var(--color-border-light);box-shadow:var(--shadow-subtle),0 3px 0 var(--color-border);transition:all .2s ease}
.bg-cream .point-card{background:#fff}
.point-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-elevated),0 5px 0 var(--color-primary-light);border-color:var(--color-primary-light)}
.point-num{font-family:var(--font-en);font-size:14px;font-weight:700;color:#fff;background:var(--color-primary);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:16px;box-shadow:0 2px 0 var(--color-primary-dark)}
.point-card h4{font-size:15px;margin-bottom:10px;color:var(--color-dark)}
.point-card p{font-size:13px;line-height:1.8;color:var(--color-text-medium)}

/* Comparison table */
.comp-table-wrap{overflow-x:auto;margin-bottom:60px;-webkit-overflow-scrolling:touch}
.comp-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px;background:#fff;overflow:hidden;box-shadow:var(--shadow-card),0 4px 0 var(--color-primary-pale)}
.comp-table th{background:var(--color-primary-gradient);color:#fff;padding:14px;font-weight:700;font-size:13px;letter-spacing:.04em;white-space:nowrap}
.comp-table td{padding:14px;border-bottom:1px solid var(--color-border-light);text-align:center;font-weight:500}
.comp-table tr:last-child td{border-bottom:none}
.comp-table .highlight{font-weight:700;color:var(--color-primary-dark);background:var(--color-primary-pale)}
.comp-table .highlight td{font-size:15px}

/* Section divider */
.section-divider{display:flex;align-items:center;justify-content:center;gap:12px;margin:80px auto 0;width:200px}
.section-divider::before,.section-divider::after{content:'';flex:1;height:2px;background:var(--color-primary-light);border-radius:1px;opacity:.5}
.section-divider-dot{width:10px;height:10px;border-radius:50%;background:var(--color-primary);box-shadow:0 2px 0 var(--color-primary-dark)}

/* ===== SIDE TOC ===== */
.side-toc{
  position:fixed;top:50%;right:28px;transform:translateY(-50%);
  z-index:900;
  opacity:0;visibility:hidden;
  transition:opacity .4s ease,visibility .4s ease;
}
.side-toc.visible{opacity:1;visibility:visible}
.side-toc-inner{
  background:rgba(255,255,255,.45);
  -webkit-backdrop-filter:none;
  backdrop-filter:none;
  border:1px solid var(--color-border-light);
  box-shadow:var(--shadow-elevated);
  padding:22px 18px 22px 20px;
  max-height:72vh;overflow-y:auto;
  width:200px;
  position:relative;
}
.side-toc-title{
  font-family:var(--font-en);font-size:10px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--color-primary);margin-bottom:16px;
  padding-bottom:10px;border-bottom:2px solid var(--color-primary-pale);
}
.side-toc a{
  display:block;font-size:11.5px;font-weight:500;
  color:var(--color-text-light);
  padding:6px 0 6px 16px;
  position:relative;transition:all .25s ease;
  line-height:1.45;
  border-left:2px solid var(--color-border-light);
  margin-bottom:2px;
}
.side-toc a:hover{color:var(--color-primary)}

/* Active state */
.side-toc a.active{
  color:var(--color-primary-dark);font-weight:700;
  border-left-color:var(--color-primary);
}

.side-toc a.toc-h2{
  font-size:12px;font-weight:600;
  color:var(--color-text-medium);
  padding:8px 0 8px 16px;
  margin-top:6px;
}
.side-toc a.toc-h2:first-of-type{margin-top:0}
.side-toc a.toc-h2.active{color:var(--color-primary-dark);font-weight:700}

.side-toc a.toc-h3{
  font-size:10.5px;
  padding-left:28px;
  color:var(--color-text-light);
  margin-left:0;
}
.side-toc a.toc-h3.active{color:var(--color-primary)}

.side-toc-progress{
  position:absolute;top:0;left:0;width:3px;height:0;
  background:var(--color-primary-gradient);
  transition:height .15s ease;
  z-index:2;
}

@media(max-width:1440px){
  .side-toc{right:12px}
  .side-toc-inner{width:180px;padding:18px 14px 18px 16px}
}
@media(max-width:1280px){
  .side-toc{display:none}
}

/* ===== MESSAGE ===== */
.section-message{padding:100px 0;background:var(--color-cream-dark);position:relative;overflow:hidden}
.section-message::before{content:'';position:absolute;top:-100px;right:-100px;width:300px;height:300px;background:radial-gradient(circle,rgba(232,133,74,.06),transparent 70%);border-radius:50%}
.message-layout{display:grid;grid-template-columns:1fr 1fr;gap:0;max-width:var(--container);margin:0 auto;background:#fff;box-shadow:var(--shadow-floating);overflow:hidden}
.message-text{padding:60px 50px;display:flex;flex-direction:column;justify-content:center}
.message-label{font-family:var(--font-accent);font-style:italic;font-size:24px;color:var(--color-primary);margin-bottom:16px}
.message-title{font-family:var(--font-handwritten);font-size:clamp(20px,2.5vw,26px);color:var(--color-dark);line-height:1.6;margin-bottom:24px}
.message-body{font-size:14px;line-height:2.2;color:var(--color-text-medium)}
.message-body p{margin-bottom:16px}
.message-body p:last-child{margin-bottom:0}
.message-cta{margin-top:32px}
.message-image{position:relative;min-height:400px;overflow:hidden}
.message-image img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.25,1,.5,1)}
.message-layout:hover .message-image img{transform:scale(1.03)}

/* ===== CTA ===== */
.section-cta{padding:100px 0;background:var(--color-primary-gradient);text-align:center;color:#fff;position:relative;overflow:hidden}
.section-cta::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.12),transparent 70%)}
.section-cta::after{content:'';position:absolute;bottom:-100px;left:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.08),transparent 70%)}
.cta-inner{max-width:800px;margin:0 auto;padding:0 24px;position:relative;z-index:1}
.cta-title{font-size:36px;margin-bottom:24px;color:#fff}
.cta-desc{font-size:15px;margin-bottom:40px;opacity:.9;line-height:1.8}
.cta-btns{display:flex;justify-content:center;gap:20px}

/* ===== FOOTER ===== */
.footer{background:var(--color-dark);color:rgba(255,255,255,.7);padding:80px 0 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:60px}
.footer-brand-logo{height:32px;margin-bottom:20px}
.footer-brand p{font-size:13px;line-height:1.8}
.footer h4{color:#fff;font-size:14px;font-weight:600;margin-bottom:20px;letter-spacing:.06em}
.footer a{display:block;padding:6px 0;font-size:13px;color:rgba(255,255,255,.6);transition:color var(--transition-fast)}
.footer a:hover{color:var(--color-primary-light)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:24px 0;text-align:center;font-size:12px;color:rgba(255,255,255,.4)}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .header-nav{display:none}.header-menu-btn{display:block}
  .feature-nav-inner{grid-template-columns:repeat(3,1fr)}
  .trust-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .message-text{padding:48px 36px}
  .merit-grid-6{grid-template-columns:repeat(2,1fr)}
  .award-banner{flex-direction:column;text-align:center}
}
@media(max-width:768px){
  .page-hero{height:260px}
  .page-hero-label{font-size:clamp(32px,8vw,48px)}
  .page-hero-title{font-size:clamp(16px,4vw,22px)}
  .section-intro{padding:72px 0 48px}
  .intro-catch{font-size:clamp(22px,5.5vw,32px);margin-bottom:24px}
  .intro-desc{font-size:14px;line-height:2}
  .section-trust{padding:0 0 60px}
  .trust-grid{gap:12px}
  .trust-card{padding:20px 14px}
  .trust-val{font-size:clamp(22px,5vw,32px)}
  .trust-label{font-size:12px}
  .trust-sub{font-size:10px;padding:3px 10px}
  .feature-nav{padding:0 0 60px}
  .feature-nav-inner{grid-template-columns:repeat(3,1fr);gap:10px}
  .feature-nav-item{padding:18px 8px}
  .feature-nav-num{font-size:26px}
  .feature-nav-label{font-size:11.5px}
  .section-detail{padding:72px 0}
  .detail-num{font-size:64px;margin-bottom:-20px}
  .detail-title{font-size:clamp(22px,5vw,30px)}
  .detail-header{margin-bottom:40px}
  .detail-grid{grid-template-columns:1fr;gap:30px}
  .detail-grid.reverse .detail-img{order:1}.detail-grid.reverse .detail-txt{order:2}
  .detail-txt h3{font-size:20px}
  .detail-txt p{font-size:14px}
  .sub-header{margin:60px 0 32px}
  .sub-header h3{font-size:20px}
  .points-grid,.merit-grid-6,.merit-grid-3{grid-template-columns:1fr;gap:14px}
  .merit-card{padding:24px 20px}
  .point-card{padding:24px 20px}
  .message-layout{grid-template-columns:1fr}
  .message-image{min-height:260px;order:-1}
  .message-text{padding:36px 28px}
  .message-label{font-size:20px}
  .message-title{font-size:clamp(18px,4vw,22px)}
  .footer-grid{grid-template-columns:1fr}
  .cta-btns{flex-direction:column;align-items:center}
  .cta-title{font-size:clamp(24px,5vw,32px)}
  .cta-desc{font-size:14px}
  .explainer-box{padding:28px 24px}
  .award-banner{padding:28px 24px;gap:16px}
  .supplement-box{padding:28px 24px}
  .comp-table{font-size:13px}
  .comp-table th{padding:10px 8px;font-size:12px}
  .comp-table td{padding:10px 8px}
}
@media(max-width:480px){
  body{font-size:14px}
  .container{padding:0 16px}.container-narrow{padding:0 16px}
  .btn{padding:14px 28px;font-size:13px}
  .feature-nav-inner{grid-template-columns:repeat(2,1fr)}
  .detail-img::before{top:8px;left:8px}
  .message-text{padding:28px 20px}
  .message-image{min-height:200px}
  .explainer-box{padding:24px 18px}
  .supplement-box{padding:24px 18px}
  .award-banner{padding:24px 18px}
  .detail-num{font-size:52px;margin-bottom:-16px}
  .trust-grid{grid-template-columns:1fr 1fr;gap:10px}
  .trust-card{padding:16px 12px}
  .trust-val{font-size:clamp(20px,6vw,28px)}
  .section-cta{padding:72px 0}
}
/* ============================================
   CSS VARIABLES
   ============================================ */
:root{
  --color-primary:#e8854a;--color-primary-dark:#b84c00;--color-primary-hover:#f56500;
  --color-primary-light:#f4a76e;--color-primary-pale:#fdf0e6;
  --color-primary-gradient:linear-gradient(135deg,#f4a76e 0%,#e8854a 50%,#d4703a 100%);
  --color-secondary:#8eb125;--color-secondary-dark:#6a8a10;--color-secondary-light:#a8c94e;
  --color-warm:#f5e6d3;--color-cream:#faf6f1;--color-cream-dark:#f0e8dd;
  --color-dark:#2e2a24;--color-text:#2e2a24;--color-text-medium:#5a5348;--color-text-light:#8a7e72;
  --color-border:#e0d5c8;--color-border-light:#ede6dc;--color-white:#fff;
  --header-height:72px;--container:1200px;--container-wide:1400px;
  --font-ja:'Zen Maru Gothic','Hiragino Maru Gothic Pro',sans-serif;
  --font-en:'Poppins',sans-serif;--font-accent:'Cormorant Garamond',serif;
  --font-logo:'Dancing Script',cursive;
  --font-handwritten:'Zen Kurenaido','Zen Maru Gothic',sans-serif;
  --shadow-subtle:0 1px 1px hsl(25 30% 40%/.06),0 2px 2px hsl(25 30% 40%/.06),0 4px 4px hsl(25 30% 40%/.06);
  --shadow-elevated:0 1px 2px hsl(25 30% 40%/.05),0 2px 4px hsl(25 30% 40%/.05),0 4px 8px hsl(25 30% 40%/.05),0 8px 16px hsl(25 30% 40%/.05);
  --shadow-floating:0 2px 4px hsl(25 30% 40%/.04),0 4px 8px hsl(25 30% 40%/.04),0 8px 16px hsl(25 30% 40%/.04),0 16px 32px hsl(25 30% 40%/.04),0 32px 64px hsl(25 30% 40%/.04);
  --shadow-mega:0 2px 4px hsl(25 30% 40%/.03),0 4px 8px hsl(25 30% 40%/.03),0 8px 16px hsl(25 30% 40%/.03),0 16px 32px hsl(25 30% 40%/.03),0 32px 64px hsl(25 30% 40%/.03),0 64px 128px hsl(25 30% 40%/.03);
  --border-subtle:1px solid var(--color-border-light);
  --radius-none:0px;--radius-full:9999px;
  --transition-fast:.2s cubic-bezier(.4,0,.2,1);
  --transition-base:.35s cubic-bezier(.4,0,.2,1);
  --transition-slow:.5s cubic-bezier(.25,.46,.45,.94);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-ja);font-size:15px;font-weight:500;line-height:1.9;color:var(--color-text);background:var(--color-cream);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:color var(--transition-fast)}
ul{list-style:none}
h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.4;color:var(--color-dark)}
.container{max-width:var(--container);margin:0 auto;padding:0 24px}

/* ============================================
   LOGO SVG
   ============================================ */
.logo-svg{overflow:visible;display:block}
.logo-svg text{
  font-family:var(--font-logo);font-size:38px;font-weight:700;
  fill:none;stroke:#fff;stroke-width:1.2;
  stroke-dasharray:600;stroke-dashoffset:600;
  animation:drawLogo 2.5s ease forwards .5s;
}
.logo-svg .logo-fill{fill:#fff;stroke:none;opacity:0;animation:fillLogo .6s ease forwards 2.4s}
.header.scrolled .logo-svg text{stroke:var(--color-primary)}
.header.scrolled .logo-svg .logo-fill{fill:var(--color-primary)}
@keyframes drawLogo{to{stroke-dashoffset:0}}
@keyframes fillLogo{to{opacity:1}}

/* ============================================
   HEADER
   ============================================ */
.header{
  position:fixed;top:0;left:0;width:100%;height:var(--header-height);
  z-index:1000;background:transparent;
  transition:background .4s ease,box-shadow .4s ease;
}
.header.scrolled{
  background:rgba(250,246,241,.96);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  box-shadow:var(--shadow-subtle);
}
.header-inner{
  max-width:var(--container-wide);margin:0 auto;padding:0 32px;
  display:flex;align-items:center;justify-content:space-between;height:100%;
}
.header-logo{display:flex;align-items:center;gap:8px}
.header-nav{display:flex;align-items:center;gap:6px}
.header-nav a{
  font-size:12.5px;font-weight:600;letter-spacing:.04em;
  color:rgba(255,255,255,.95);padding:8px 16px;
  border-radius:var(--radius-full);
  border:1.5px solid rgba(255,255,255,.35);
  background:rgba(255,255,255,.1);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  transition:all .25s ease;
}
.header-nav a:hover{background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.6);transform:translateY(-1px)}
.header.scrolled .header-nav a{
  color:var(--color-text-medium);border-color:var(--color-border);
  background:var(--color-white);box-shadow:0 1px 3px hsl(25 30% 40%/.08);backdrop-filter:none;
}
.header.scrolled .header-nav a:hover{color:var(--color-primary-dark);border-color:var(--color-primary);background:var(--color-primary-pale)}
.header-nav .current{background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.6)}
.header.scrolled .header-nav .current{color:var(--color-primary-dark);border-color:var(--color-primary);background:var(--color-primary-pale)}
.header-cta{
  padding:9px 22px!important;font-size:12px!important;font-weight:700!important;
  color:#fff!important;background:var(--color-primary)!important;
  border:1.5px solid var(--color-primary)!important;
  border-bottom:4px solid var(--color-primary-dark)!important;
  box-shadow:0 2px 5px rgba(184,76,0,.3)!important;
  border-radius:var(--radius-full)!important;
  display:inline-flex!important;align-items:center!important;gap:6px!important;
  transition:all .15s ease!important;letter-spacing:.06em!important;backdrop-filter:none!important;
}
.header-cta:hover{
  background:var(--color-primary-hover)!important;
  border-bottom:2px solid var(--color-primary-dark)!important;
  margin-top:2px!important;box-shadow:0 1px 2px rgba(184,76,0,.2)!important;transform:none!important;
}
.header.scrolled .header-cta{
  color:#fff!important;background:var(--color-primary)!important;
  border-color:var(--color-primary)!important;border-bottom-color:var(--color-primary-dark)!important;
}
.header-menu-btn{display:none;background:none;border:none;cursor:pointer;width:32px;height:32px;position:relative}
.header-menu-btn span{display:block;width:24px;height:2px;background:#fff;position:absolute;left:4px;transition:var(--transition-base)}
.header.scrolled .header-menu-btn span{background:var(--color-text)}
.header-menu-btn span:nth-child(1){top:8px}
.header-menu-btn span:nth-child(2){top:15px}
.header-menu-btn span:nth-child(3){top:22px}
.mobile-menu{position:fixed;top:0;right:-100%;width:320px;height:100vh;background:var(--color-white);z-index:1001;transition:right var(--transition-base);padding:100px 40px 40px;box-shadow:var(--shadow-mega);overflow-y:auto}
.mobile-menu.active{right:0}
.mobile-menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(46,42,36,.5);z-index:1000;opacity:0;visibility:hidden;transition:var(--transition-base)}
.mobile-menu-overlay.active{opacity:1;visibility:visible}
.mobile-menu a{display:block;padding:16px 0;font-size:15px;font-weight:500;color:var(--color-text);border-bottom:var(--border-subtle)}
.mobile-menu-close{
  position:absolute;top:24px;right:24px;width:40px;height:40px;
  background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;
}
.mobile-menu-close::before,.mobile-menu-close::after{content:'';position:absolute;width:24px;height:2px;background:var(--color-text)}
.mobile-menu-close::before{transform:rotate(45deg)}
.mobile-menu-close::after{transform:rotate(-45deg)}

/* ============================================
   BUTTONS
   ============================================ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 36px;font-family:var(--font-ja);
  font-size:14px;font-weight:700;letter-spacing:.08em;
  border:none;cursor:pointer;border-radius:var(--radius-full);
  transition:all .15s ease;text-align:center;line-height:1.4;
}
.btn::after{
  content:'→';display:inline-flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:400;width:26px;height:26px;border-radius:50%;
  transition:all var(--transition-base);flex-shrink:0;
}
.btn-primary{color:#fff;background:var(--color-primary);border-bottom:5px solid var(--color-primary-dark);box-shadow:0 3px 5px rgba(184,76,0,.3)}
.btn-primary::after{background:rgba(255,255,255,.2);color:#fff}
.btn-primary:hover{margin-top:3px;background:var(--color-primary-hover);border-bottom:2px solid var(--color-primary-dark);box-shadow:0 1px 3px rgba(184,76,0,.2)}
.btn-primary:hover::after{transform:translateX(4px)}
.btn-outline{color:var(--color-primary);background:#fff;border:2px solid var(--color-primary);border-bottom:5px solid var(--color-primary-dark);box-shadow:0 3px 5px rgba(184,76,0,.15);padding:14px 34px}
.btn-outline::after{background:var(--color-primary-pale);color:var(--color-primary)}
.btn-outline:hover{margin-top:3px;background:var(--color-primary-pale);border-bottom:2px solid var(--color-primary-dark);box-shadow:0 1px 3px rgba(184,76,0,.1)}
.btn-outline:hover::after{transform:translateX(4px)}
.btn-white{color:var(--color-primary);background:#fff;border-bottom:5px solid #ccc;box-shadow:0 3px 5px rgba(0,0,0,.15)}
.btn-white::after{background:var(--color-primary-pale);color:var(--color-primary)}
.btn-white:hover{margin-top:3px;background:#f8f8f8;border-bottom:2px solid #ccc;box-shadow:0 1px 3px rgba(0,0,0,.1)}
.btn-white:hover::after{transform:translateX(4px)}
.btn-white-outline{color:#fff;background:transparent;border:2px solid rgba(255,255,255,.7);border-bottom:5px solid rgba(255,255,255,.4);box-shadow:0 3px 5px rgba(0,0,0,.2);padding:14px 34px}
.btn-white-outline::after{background:rgba(255,255,255,.15);color:#fff}
.btn-white-outline:hover{margin-top:3px;background:rgba(255,255,255,.1);border-bottom:2px solid rgba(255,255,255,.4);box-shadow:0 1px 3px rgba(0,0,0,.15)}
.btn-white-outline:hover::after{transform:translateX(4px)}

/* ============================================
   PAGE HERO
   ============================================ */
.page-hero{
  position:relative;height:360px;overflow:hidden;
  display:flex;align-items:center;justify-content:center;text-align:center;
}
.page-hero-bg{position:absolute;inset:0;z-index:1}
.page-hero-bg img{width:100%;height:100%;object-fit:cover}
.page-hero-bg::after{
  content:'';position:absolute;inset:0;z-index:2;
  background:linear-gradient(135deg,rgba(184,76,0,.45) 0%,rgba(46,42,36,.35) 100%);
}
.page-hero-content{position:relative;z-index:10;padding-top:var(--header-height)}
.page-hero-label{
  font-family:var(--font-accent);font-style:italic;font-size:clamp(36px,6vw,56px);
  color:rgba(255,255,255,.85);letter-spacing:.02em;line-height:1.2;margin-bottom:8px;
}
.page-hero-title{font-size:clamp(18px,2.5vw,24px);color:#fff;font-weight:700;letter-spacing:.08em}
.page-hero-wave{position:absolute;bottom:-1px;left:0;width:100%;z-index:5;line-height:0}
.page-hero-wave svg{width:100%;height:auto;display:block}

/* ============================================
   BREADCRUMB
   ============================================ */
.breadcrumb{padding:20px 0;font-size:12px;color:var(--color-text-light)}
.breadcrumb a{color:var(--color-text-light);transition:color var(--transition-fast)}
.breadcrumb a:hover{color:var(--color-primary)}
.breadcrumb span{margin:0 8px;opacity:.5}

/* ============================================
   SECTION
   ============================================ */
.section{padding:80px 0;position:relative}
.section-label{font-family:var(--font-accent);font-style:italic;font-size:clamp(32px,5vw,48px);color:var(--color-primary);letter-spacing:.02em;line-height:1.2;margin-bottom:8px}
.section-title{font-size:clamp(20px,3vw,28px);font-weight:700;color:var(--color-dark);letter-spacing:.06em}
.section-header{text-align:center;margin-bottom:56px}
.section-bg-cream{background:var(--color-cream)}
.section-bg-white{background:var(--color-white)}

/* ============================================
   GREETING（代表挨拶）
   ============================================ */
.greeting-layout{
  display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:start;
}
.greeting-image-wrap{position:relative}
.greeting-image{
  width:100%;aspect-ratio:3/4;object-fit:cover;
  box-shadow:var(--shadow-floating);
}
.greeting-image-accent{
  position:absolute;bottom:-20px;right:-20px;width:160px;height:160px;
  background:var(--color-primary-pale);border-radius:50%;z-index:-1;
}
.greeting-name-plate{
  display:inline-flex;align-items:center;gap:12px;
  margin-top:24px;padding:16px 28px;
  background:var(--color-white);border-left:4px solid var(--color-primary);
  box-shadow:var(--shadow-subtle);
}
.greeting-name-plate-title{font-size:12px;color:var(--color-text-light);font-weight:500;letter-spacing:.06em}
.greeting-name-plate-name{font-size:20px;font-weight:700;color:var(--color-dark);letter-spacing:.1em}

.greeting-catch{
  font-family:var(--font-handwritten);
  font-size:clamp(22px,3.5vw,30px);font-weight:400;
  color:var(--color-dark);line-height:1.7;margin-bottom:32px;
  text-shadow:1px 1px 0 rgba(232,133,74,.15);
}
.greeting-body p{
  font-size:15px;line-height:2.1;color:var(--color-text-medium);margin-bottom:20px;
}
.greeting-body p:last-child{margin-bottom:0}
.greeting-profile{
  margin-top:36px;padding:24px 28px;
  background:var(--color-cream);border-radius:4px;
}
.greeting-profile-title{
  font-size:12px;font-weight:700;color:var(--color-primary);
  letter-spacing:.08em;margin-bottom:12px;
}
.greeting-profile p{font-size:13px;line-height:1.9;color:var(--color-text-medium)}

/* ============================================
   WORKS（施工事例 3カラム）
   ============================================ */
.works-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-bottom:48px;
}
.works-card{
  background:var(--color-white);overflow:hidden;display:flex;flex-direction:column;
  border:1.5px solid var(--color-border-light);
  border-bottom:6px solid var(--color-border);
  box-shadow:0 4px 0 var(--color-border),0 6px 12px rgba(46,42,36,.06);
  transition:all .15s ease;cursor:pointer;
}
.works-card:hover{
  border-bottom-width:3px;margin-top:3px;
  box-shadow:0 2px 0 var(--color-border),0 3px 8px rgba(46,42,36,.08);
}
.works-card:active{
  border-bottom-width:1px;margin-top:5px;
  box-shadow:0 0 0 var(--color-border),0 1px 4px rgba(46,42,36,.1);
}
.works-card-image{position:relative;overflow:hidden;height:220px}
.works-card-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}
.works-card:hover .works-card-image img{transform:scale(1.04)}
.works-card-badges{position:absolute;top:12px;left:12px;display:flex;gap:6px;z-index:2}
.works-badge{
  padding:4px 12px;font-size:10px;font-weight:700;color:#fff;
  border-radius:var(--radius-full);line-height:1.4;background:var(--color-dark);
}
.works-card-body{padding:20px 24px;flex:1;display:flex;flex-direction:column}
.works-card-meta{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.works-card-meta-item{
  font-size:11px;font-weight:600;color:var(--color-text-light);
  background:var(--color-cream);padding:3px 10px;border-radius:var(--radius-full);
}
.works-card-title{font-size:16px;font-weight:700;color:var(--color-dark);margin-bottom:8px;line-height:1.6}
.works-card-spec{font-size:12px;color:var(--color-text-light);line-height:1.8;flex:1}
.works-card-footer{
  padding-top:14px;border-top:1px solid var(--color-border-light);margin-top:auto;
}
.works-card-link{
  font-size:13px;font-weight:600;color:var(--color-primary);
  display:inline-flex;align-items:center;gap:6px;
  transition:gap var(--transition-base);
}
.works-card:hover .works-card-link{gap:10px}
.works-more{text-align:center}

/* ============================================
   COMPANY INFO（表 + マップ 横並び）
   ============================================ */
.company-layout{
  display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start;
}
.company-table{width:100%;border-collapse:collapse}
.company-table th,
.company-table td{
  padding:20px 24px;font-size:14px;line-height:1.8;
  text-align:left;vertical-align:top;
  border-bottom:1px solid var(--color-border-light);
}
.company-table th{
  width:140px;font-weight:700;color:var(--color-dark);
  background:var(--color-cream);white-space:nowrap;
  font-size:13px;letter-spacing:.04em;
}
.company-table td{
  color:var(--color-text-medium);background:var(--color-white);
}
.company-table tr:first-child th,
.company-table tr:first-child td{
  border-top:2px solid var(--color-primary);
}
.company-table tr:last-child th,
.company-table tr:last-child td{
  border-bottom:2px solid var(--color-primary);
}
.company-table .tel-link{
  color:var(--color-primary);font-weight:700;font-size:17px;letter-spacing:.04em;
}

.company-map{
  border:1.5px solid var(--color-border-light);overflow:hidden;
  box-shadow:var(--shadow-subtle);height:100%;min-height:420px;
}
.company-map iframe{width:100%;height:100%;min-height:420px;border:none;display:block}

.company-address-note{
  margin-top:16px;display:flex;align-items:center;gap:10px;
  font-size:13px;color:var(--color-text-light);
}
.company-address-note-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:50%;
  background:var(--color-primary-pale);color:var(--color-primary);
  font-size:14px;flex-shrink:0;
}

/* ============================================
   CTA
   ============================================ */
.section-cta{padding:100px 0;background:var(--color-primary-gradient);text-align:center;position:relative;overflow:hidden}
.section-cta::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.1),transparent 70%)}
.section-cta::after{content:'';position:absolute;bottom:-100px;left:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.08),transparent 70%)}
.cta-label{font-family:var(--font-accent);font-style:italic;font-size:clamp(32px,5vw,48px);color:rgba(255,255,255,.7);letter-spacing:.02em;line-height:1.2;margin-bottom:8px}
.cta-title{font-size:clamp(24px,4vw,36px);color:#fff;margin-bottom:16px}
.cta-sub{font-size:15px;color:rgba(255,255,255,.85);margin-bottom:40px}
.cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}

/* ============================================
   FOOTER
   ============================================ */
.footer{background:var(--color-dark);color:rgba(255,255,255,.7);padding:80px 0 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:60px}
.footer-brand-logo{height:32px;margin-bottom:20px}
.footer-brand p{font-size:13px;line-height:1.8}
.footer h4{color:#fff;font-size:14px;font-weight:600;margin-bottom:20px;letter-spacing:.06em}
.footer a{display:block;padding:6px 0;font-size:13px;color:rgba(255,255,255,.6);transition:color var(--transition-fast)}
.footer a:hover{color:var(--color-primary-light)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:24px 0;text-align:center;font-size:12px;color:rgba(255,255,255,.4)}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1024px){
  .header-nav{display:none}.header-menu-btn{display:block}
  .greeting-layout{grid-template-columns:1fr 1fr;gap:40px}
  .works-grid{grid-template-columns:repeat(2,1fr)}
  .company-layout{grid-template-columns:1fr;gap:32px}
  .company-map{min-height:340px}
  .company-map iframe{min-height:340px}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .page-hero{height:280px}
  .section{padding:60px 0}
  .greeting-layout{grid-template-columns:1fr;gap:32px}
  .greeting-image{aspect-ratio:4/3}
  .greeting-image-accent{width:120px;height:120px;bottom:-12px;right:-12px}
  .works-grid{grid-template-columns:1fr}
  .works-card-image{height:200px}
  .company-table th{width:110px;padding:14px;font-size:12px}
  .company-table td{padding:14px;font-size:13px}
  .company-map{min-height:280px}
  .company-map iframe{min-height:280px}
  .cta-btns{flex-direction:column;align-items:center}
  .footer-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  body{font-size:14px}
  .container{padding:0 16px}
  .btn{padding:14px 28px;font-size:13px}
  .page-hero{height:220px}
  .company-table th,
  .company-table td{display:block;width:100%}
  .company-table th{padding:12px 16px 4px;border-bottom:none}
  .company-table td{padding:4px 16px 14px}
  .greeting-name-plate{padding:12px 20px}
  .company-map{min-height:240px}
  .company-map iframe{min-height:240px}
}
:root{
  --color-primary:#e8854a;--color-primary-dark:#b84c00;--color-primary-hover:#f56500;
  --color-primary-light:#f4a76e;--color-primary-pale:#fdf0e6;
  --color-primary-gradient:linear-gradient(135deg,#f4a76e 0%,#e8854a 50%,#d4703a 100%);
  --color-secondary:#8eb125;--color-secondary-dark:#6a8a10;--color-secondary-light:#a8c94e;
  --color-warm:#f5e6d3;--color-cream:#faf6f1;--color-cream-dark:#f0e8dd;
  --color-dark:#2e2a24;--color-text:#2e2a24;--color-text-medium:#5a5348;--color-text-light:#8a7e72;
  --color-border:#e0d5c8;--color-border-light:#ede6dc;--color-white:#fff;
  --color-error:#d44;--color-error-pale:#fef0f0;
  --header-height:72px;--container:1200px;--container-wide:1400px;
  --font-ja:'Zen Maru Gothic','Hiragino Maru Gothic Pro',sans-serif;
  --font-en:'Poppins',sans-serif;--font-accent:'Cormorant Garamond',serif;
  --font-logo:'Dancing Script',cursive;
  --font-handwritten:'Zen Kurenaido','Zen Maru Gothic',sans-serif;
  --shadow-subtle:0 1px 1px hsl(25 30% 40%/.06),0 2px 2px hsl(25 30% 40%/.06),0 4px 4px hsl(25 30% 40%/.06);
  --shadow-elevated:0 1px 2px hsl(25 30% 40%/.05),0 2px 4px hsl(25 30% 40%/.05),0 4px 8px hsl(25 30% 40%/.05),0 8px 16px hsl(25 30% 40%/.05);
  --shadow-floating:0 2px 4px hsl(25 30% 40%/.04),0 4px 8px hsl(25 30% 40%/.04),0 8px 16px hsl(25 30% 40%/.04),0 16px 32px hsl(25 30% 40%/.04),0 32px 64px hsl(25 30% 40%/.04);
  --shadow-mega:0 2px 4px hsl(25 30% 40%/.03),0 4px 8px hsl(25 30% 40%/.03),0 8px 16px hsl(25 30% 40%/.03),0 16px 32px hsl(25 30% 40%/.03),0 32px 64px hsl(25 30% 40%/.03),0 64px 128px hsl(25 30% 40%/.03);
  --border-subtle:1px solid var(--color-border-light);
  --radius-none:0px;--radius-full:9999px;
  --transition-fast:.2s cubic-bezier(.4,0,.2,1);
  --transition-base:.35s cubic-bezier(.4,0,.2,1);
  --transition-slow:.5s cubic-bezier(.25,.46,.45,.94);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-ja);font-size:15px;font-weight:500;line-height:1.9;color:var(--color-text);background:var(--color-cream);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:color var(--transition-fast)}
ul{list-style:none}
h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.4;color:var(--color-dark)}
.container{max-width:var(--container);margin:0 auto;padding:0 24px}

.logo-svg{overflow:visible;display:block}
.logo-svg text{font-family:var(--font-logo);font-size:38px;font-weight:700;fill:none;stroke:#fff;stroke-width:1.2;stroke-dasharray:600;stroke-dashoffset:600;animation:drawLogo 2.5s ease forwards .5s}
.logo-svg .logo-fill{fill:#fff;stroke:none;opacity:0;animation:fillLogo .6s ease forwards 2.4s}
.header.scrolled .logo-svg text{stroke:var(--color-primary)}
.header.scrolled .logo-svg .logo-fill{fill:var(--color-primary)}
@keyframes drawLogo{to{stroke-dashoffset:0}}
@keyframes fillLogo{to{opacity:1}}

.header{position:fixed;top:0;left:0;width:100%;height:var(--header-height);z-index:1000;background:transparent;transition:background .4s ease,box-shadow .4s ease}
.header.scrolled{background:rgba(250,246,241,.96);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:var(--shadow-subtle)}
.header-inner{max-width:var(--container-wide);margin:0 auto;padding:0 32px;display:flex;align-items:center;justify-content:space-between;height:100%}
.header-logo{display:flex;align-items:center;gap:8px}
.header-nav{display:flex;align-items:center;gap:6px}
.header-nav a{font-size:12.5px;font-weight:600;letter-spacing:.04em;color:rgba(255,255,255,.95);padding:8px 16px;border-radius:var(--radius-full);border:1.5px solid rgba(255,255,255,.35);background:rgba(255,255,255,.1);backdrop-filter:blur(6px);transition:all .25s ease}
.header-nav a:hover{background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.6);transform:translateY(-1px)}
.header.scrolled .header-nav a{color:var(--color-text-medium);border-color:var(--color-border);background:var(--color-white);box-shadow:0 1px 3px hsl(25 30% 40%/.08);backdrop-filter:none}
.header.scrolled .header-nav a:hover{color:var(--color-primary-dark);border-color:var(--color-primary);background:var(--color-primary-pale)}
.header-nav .current{background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.6)}
.header.scrolled .header-nav .current{color:var(--color-primary-dark);border-color:var(--color-primary);background:var(--color-primary-pale)}
.header-cta{padding:9px 22px!important;font-size:12px!important;font-weight:700!important;color:#fff!important;background:var(--color-primary)!important;border:1.5px solid var(--color-primary)!important;border-bottom:4px solid var(--color-primary-dark)!important;box-shadow:0 2px 5px rgba(184,76,0,.3)!important;border-radius:var(--radius-full)!important;display:inline-flex!important;align-items:center!important;gap:6px!important;transition:all .15s ease!important;letter-spacing:.06em!important;backdrop-filter:none!important}
.header-cta:hover{background:var(--color-primary-hover)!important;border-bottom:2px solid var(--color-primary-dark)!important;margin-top:2px!important;box-shadow:0 1px 2px rgba(184,76,0,.2)!important;transform:none!important}
.header.scrolled .header-cta{color:#fff!important;background:var(--color-primary)!important;border-color:var(--color-primary)!important;border-bottom-color:var(--color-primary-dark)!important}
.header-menu-btn{display:none;background:none;border:none;cursor:pointer;width:32px;height:32px;position:relative}
.header-menu-btn span{display:block;width:24px;height:2px;background:#fff;position:absolute;left:4px;transition:var(--transition-base)}
.header.scrolled .header-menu-btn span{background:var(--color-text)}
.header-menu-btn span:nth-child(1){top:8px}.header-menu-btn span:nth-child(2){top:15px}.header-menu-btn span:nth-child(3){top:22px}
.mobile-menu{position:fixed;top:0;right:-100%;width:320px;height:100vh;background:var(--color-white);z-index:1001;transition:right var(--transition-base);padding:100px 40px 40px;box-shadow:var(--shadow-mega);overflow-y:auto}
.mobile-menu.active{right:0}
.mobile-menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(46,42,36,.5);z-index:1000;opacity:0;visibility:hidden;transition:var(--transition-base)}
.mobile-menu-overlay.active{opacity:1;visibility:visible}
.mobile-menu a{display:block;padding:16px 0;font-size:15px;font-weight:500;color:var(--color-text);border-bottom:var(--border-subtle)}
.mobile-menu-close{position:absolute;top:24px;right:24px;width:40px;height:40px;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center}
.mobile-menu-close::before,.mobile-menu-close::after{content:'';position:absolute;width:24px;height:2px;background:var(--color-text)}
.mobile-menu-close::before{transform:rotate(45deg)}.mobile-menu-close::after{transform:rotate(-45deg)}

.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 36px;font-family:var(--font-ja);font-size:14px;font-weight:700;letter-spacing:.08em;border:none;cursor:pointer;border-radius:var(--radius-full);transition:all .15s ease;text-align:center;line-height:1.4}
.btn::after{content:'→';display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:400;width:26px;height:26px;border-radius:50%;transition:all var(--transition-base);flex-shrink:0}
.btn-white{color:var(--color-primary);background:#fff;border-bottom:5px solid #ccc;box-shadow:0 3px 5px rgba(0,0,0,.15)}
.btn-white::after{background:var(--color-primary-pale);color:var(--color-primary)}
.btn-white:hover{margin-top:3px;background:#f8f8f8;border-bottom:2px solid #ccc;box-shadow:0 1px 3px rgba(0,0,0,.1)}
.btn-white:hover::after{transform:translateX(4px)}

.page-hero{position:relative;height:360px;overflow:hidden;display:flex;align-items:center;justify-content:center;text-align:center}
.page-hero-bg{position:absolute;inset:0;z-index:1}
.page-hero-bg img{width:100%;height:100%;object-fit:cover}
.page-hero-bg::after{content:'';position:absolute;inset:0;z-index:2;background:linear-gradient(135deg,rgba(184,76,0,.45) 0%,rgba(46,42,36,.35) 100%)}
.page-hero-content{position:relative;z-index:10;padding-top:var(--header-height)}
.page-hero-label{font-family:var(--font-accent);font-style:italic;font-size:clamp(36px,6vw,56px);color:rgba(255,255,255,.85);letter-spacing:.02em;line-height:1.2;margin-bottom:8px}
.page-hero-title{font-size:clamp(18px,2.5vw,24px);color:#fff;font-weight:700;letter-spacing:.08em}
.page-hero-wave{position:absolute;bottom:-1px;left:0;width:100%;z-index:5;line-height:0}
.page-hero-wave svg{width:100%;height:auto;display:block}

.breadcrumb{padding:20px 0;font-size:12px;color:var(--color-text-light)}
.breadcrumb a{color:var(--color-text-light);transition:color var(--transition-fast)}
.breadcrumb a:hover{color:var(--color-primary)}
.breadcrumb span{margin:0 8px;opacity:.5}

.section{padding:80px 0;position:relative}

/* ============================================
   PRESENT SECTION
   ============================================ */
.present-section{padding:60px 0 40px;background:var(--color-white)}
.present-catch{
  text-align:center;font-family:var(--font-handwritten);
  font-size:clamp(20px,3vw,28px);color:var(--color-dark);
  line-height:1.6;margin-bottom:40px;
  text-shadow:1px 1px 0 rgba(232,133,74,.15);
}
.present-catch em{font-style:normal;color:var(--color-primary);font-weight:700}
.present-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;max-width:900px;margin:0 auto}
.present-item{text-align:center}
.present-item-num{font-family:var(--font-en);font-size:40px;font-weight:600;color:var(--color-primary);line-height:1;margin-bottom:12px;opacity:.6}
.present-item-image{width:100%;aspect-ratio:3/4;object-fit:cover;border:1.5px solid var(--color-border-light);box-shadow:var(--shadow-subtle);margin-bottom:16px}
.present-item-text{font-size:14px;font-weight:700;color:var(--color-dark);line-height:1.7}

/* ============================================
   CONTACT 2-COLUMN
   ============================================ */
.contact-layout{display:grid;grid-template-columns:380px 1fr;gap:0;min-height:600px}

/* LEFT SIDEBAR */
.contact-sidebar{
  background:var(--color-dark);color:#fff;
  padding:48px 36px;display:flex;flex-direction:column;
  position:relative;overflow:hidden;
}
.contact-sidebar::before{content:'';position:absolute;top:-60px;right:-60px;width:200px;height:200px;border-radius:50%;background:rgba(232,133,74,.15)}

/* 受賞歴 */
.sidebar-block-label{
  font-family:var(--font-accent);font-style:italic;font-size:24px;
  color:var(--color-primary-light);margin-bottom:4px;
}
.sidebar-block-title{
  font-size:16px;font-weight:700;color:#fff;margin-bottom:20px;letter-spacing:.06em;
}
.sidebar-award-list{margin-bottom:32px}
.sidebar-award-item{
  display:flex;align-items:center;gap:12px;
  padding:14px 0;border-bottom:1px solid rgba(255,255,255,.1);
}
.sidebar-award-item:last-child{border-bottom:none}
.sidebar-award-icon{
  width:36px;height:36px;border-radius:50%;
  background:var(--color-primary);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:15px;font-weight:700;flex-shrink:0;
  box-shadow:0 2px 6px rgba(232,133,74,.4);
}
.sidebar-award-text{font-size:13px;color:rgba(255,255,255,.85);line-height:1.6;font-weight:500}
.sidebar-award-text strong{color:#fff;font-weight:700}

/* 施工実績 */
.sidebar-works{margin-bottom:28px}
.sidebar-works-label{
  font-family:var(--font-accent);font-style:italic;font-size:20px;
  color:var(--color-primary-light);margin-bottom:4px;
}
.sidebar-works-title{
  font-size:14px;font-weight:700;color:#fff;margin-bottom:16px;letter-spacing:.04em;
}
.sidebar-works-images{display:flex;flex-direction:column;gap:12px}
.sidebar-work-item{overflow:hidden}
.sidebar-works-img{
  width:100%;aspect-ratio:16/10;object-fit:cover;
  border:2px solid rgba(255,255,255,.12);
  transition:transform var(--transition-slow);
}
.sidebar-works-img:hover{transform:scale(1.03)}
.sidebar-works-caption{font-size:11px;color:rgba(255,255,255,.45);margin-top:3px;text-align:center}

/* 電話 */
.sidebar-phone{
  margin-top:auto;padding-top:24px;
  border-top:1px solid rgba(255,255,255,.15);text-align:center;
}
.sidebar-phone-label{font-size:11px;color:rgba(255,255,255,.5);margin-bottom:4px}
.sidebar-phone-num{font-family:var(--font-en);font-size:24px;font-weight:600;color:#fff;letter-spacing:.04em}
.sidebar-phone-num a{color:#fff}
.sidebar-phone-note{font-size:10px;color:rgba(255,255,255,.4);margin-top:4px}

/* RIGHT FORM */
.contact-form-area{background:var(--color-white);padding:48px 52px}
.contact-form-header{margin-bottom:36px}
.contact-form-header-label{font-family:var(--font-accent);font-style:italic;font-size:32px;color:var(--color-primary);margin-bottom:4px}
.contact-form-header-title{font-size:20px;font-weight:700;color:var(--color-dark);margin-bottom:8px}
.contact-form-header-desc{font-size:13px;color:var(--color-text-light);line-height:1.8}

/* ============================================
   FORM STYLES
   ============================================ */
.form-group{margin-bottom:24px}
.form-label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--color-dark);margin-bottom:8px}
.form-required{font-size:10px;font-weight:700;color:#fff;background:var(--color-primary);padding:2px 8px;border-radius:var(--radius-full);letter-spacing:.06em;line-height:1.6}
.form-optional{font-size:10px;font-weight:700;color:var(--color-text-light);background:var(--color-cream);padding:2px 8px;border-radius:var(--radius-full);letter-spacing:.06em;line-height:1.6}
.form-input,.form-select,.form-textarea{
  width:100%;padding:14px 18px;font-family:var(--font-ja);font-size:15px;font-weight:500;
  color:var(--color-text);background:var(--color-cream);
  border:1.5px solid var(--color-border);border-radius:4px;
  transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none;
}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(232,133,74,.12);background:var(--color-white)}
.form-input::placeholder,.form-textarea::placeholder{color:var(--color-border);font-weight:400}
.form-input.error,.form-textarea.error{border-color:var(--color-error);background:var(--color-error-pale)}
.form-error-msg{font-size:12px;color:var(--color-error);margin-top:6px;display:none}
.form-error-msg.visible{display:block}
.form-textarea{min-height:140px;resize:vertical}
.form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238a7e72' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-row-3{display:grid;grid-template-columns:140px 1fr 1fr;gap:16px}

.form-check-group{display:flex;flex-wrap:wrap;gap:10px}
.form-check-item{position:relative}
.form-check-item input[type="checkbox"]{position:absolute;opacity:0;width:0;height:0}
.form-check-item label{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;font-size:13px;font-weight:600;color:var(--color-text-medium);background:var(--color-cream);border:1.5px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);user-select:none}
.form-check-item label::before{content:'';width:18px;height:18px;border:2px solid var(--color-border);border-radius:4px;transition:all var(--transition-fast);flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;font-size:11px;color:#fff}
.form-check-item input:checked+label{color:var(--color-primary-dark);background:var(--color-primary-pale);border-color:var(--color-primary)}
.form-check-item input:checked+label::before{background:var(--color-primary);border-color:var(--color-primary);content:'✓'}

.form-radio-group{display:flex;flex-wrap:wrap;gap:10px}
.form-radio-item{position:relative}
.form-radio-item input[type="radio"]{position:absolute;opacity:0;width:0;height:0}
.form-radio-item label{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;font-size:13px;font-weight:600;color:var(--color-text-medium);background:var(--color-cream);border:1.5px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);user-select:none}
.form-radio-item label::before{content:'';width:18px;height:18px;border:2px solid var(--color-border);border-radius:50%;transition:all var(--transition-fast);flex-shrink:0}
.form-radio-item input:checked+label{color:var(--color-primary-dark);background:var(--color-primary-pale);border-color:var(--color-primary)}
.form-radio-item input:checked+label::before{border-color:var(--color-primary);box-shadow:inset 0 0 0 4px var(--color-primary)}

.form-privacy{margin:32px 0 8px;padding:20px 24px;background:var(--color-cream);border-radius:4px;font-size:13px;color:var(--color-text-medium);line-height:1.8}
.form-privacy a{color:var(--color-primary);font-weight:600;text-decoration:underline}
.form-privacy-check{margin-top:12px;display:flex;align-items:center;gap:10px}
.form-privacy-check input[type="checkbox"]{width:20px;height:20px;accent-color:var(--color-primary);cursor:pointer}
.form-privacy-check label{font-size:14px;font-weight:600;color:var(--color-dark);cursor:pointer}

/* 営業お断り確認チェック */
.form-not-sales{
  margin:0 0 24px;padding:16px 24px;
  background:var(--color-cream);border:1.5px solid var(--color-border);
  border-radius:4px;
  display:flex;align-items:center;gap:12px;
}
.form-not-sales input[type="checkbox"]{
  width:20px;height:20px;accent-color:var(--color-primary);cursor:pointer;flex-shrink:0;
}
.form-not-sales label{
  font-size:13px;font-weight:600;color:var(--color-text);cursor:pointer;line-height:1.6;
}

.form-submit{text-align:center;margin-top:16px}
.form-submit-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:18px 64px;font-family:var(--font-ja);font-size:16px;font-weight:700;
  color:#fff;background:var(--color-primary);border:none;
  border-bottom:6px solid var(--color-primary-dark);border-radius:var(--radius-full);
  cursor:pointer;box-shadow:0 4px 8px rgba(184,76,0,.3);
  transition:all .15s ease;letter-spacing:.08em;
}
.form-submit-btn:hover{margin-top:4px;border-bottom-width:2px;background:var(--color-primary-hover);box-shadow:0 2px 4px rgba(184,76,0,.2)}
.form-submit-btn:active{margin-top:6px;border-bottom-width:0;box-shadow:0 0 2px rgba(184,76,0,.15)}
.form-submit-btn:disabled{opacity:.5;cursor:not-allowed}
.form-submit-btn::after{content:'→';font-size:14px;width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.2);display:inline-flex;align-items:center;justify-content:center}

.form-steps{display:flex;justify-content:center;gap:8px;margin-bottom:36px}
.form-step{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--color-text-light)}
.form-step.active{color:var(--color-primary)}
.form-step-num{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;background:var(--color-cream);color:var(--color-text-light);border:2px solid var(--color-border)}
.form-step.active .form-step-num{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}
.form-step-divider{width:32px;height:2px;background:var(--color-border);margin:0 4px}

/* ============================================
   FOOTER
   ============================================ */
.footer{background:var(--color-dark);color:rgba(255,255,255,.7);padding:80px 0 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:60px}
.footer-brand-logo{height:32px;margin-bottom:20px}
.footer-brand p{font-size:13px;line-height:1.8}
.footer h4{color:#fff;font-size:14px;font-weight:600;margin-bottom:20px;letter-spacing:.06em}
.footer a{display:block;padding:6px 0;font-size:13px;color:rgba(255,255,255,.6);transition:color var(--transition-fast)}
.footer a:hover{color:var(--color-primary-light)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:24px 0;text-align:center;font-size:12px;color:rgba(255,255,255,.4)}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1024px){
  .header-nav{display:none}.header-menu-btn{display:block}
  .contact-layout{grid-template-columns:320px 1fr}
  .contact-form-area{padding:40px 36px}
  .contact-sidebar{padding:40px 28px}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .page-hero{height:280px}
  .section{padding:60px 0}
  .present-grid{grid-template-columns:repeat(3,1fr);gap:16px}
  .present-item-num{font-size:28px}
  .contact-layout{grid-template-columns:1fr}
  .contact-sidebar{padding:32px 24px}
  .sidebar-works-images{flex-direction:row;gap:10px}
  .sidebar-works-img{aspect-ratio:1/1;height:120px;width:auto;flex:1}
  .contact-form-area{padding:32px 24px}
  .form-row,.form-row-3{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  body{font-size:14px}
  .container{padding:0 16px}
  .page-hero{height:220px}
  .present-grid{grid-template-columns:1fr;max-width:280px}
  .sidebar-works-images{flex-direction:column}
  .sidebar-works-img{width:100%;height:auto;aspect-ratio:16/9}
  .form-check-item label,.form-radio-item label{padding:8px 14px;font-size:12px}
  .form-submit-btn{padding:16px 40px;font-size:14px}
}
:root{
  --color-primary:#e8854a;--color-primary-dark:#b84c00;--color-primary-hover:#f56500;
  --color-primary-light:#f4a76e;--color-primary-pale:#fdf0e6;
  --color-primary-gradient:linear-gradient(135deg,#f4a76e 0%,#e8854a 50%,#d4703a 100%);
  --color-secondary:#8eb125;--color-secondary-dark:#6a8a10;--color-secondary-light:#a8c94e;
  --color-warm:#f5e6d3;--color-cream:#faf6f1;--color-cream-dark:#f0e8dd;
  --color-dark:#2e2a24;--color-text:#2e2a24;--color-text-medium:#5a5348;--color-text-light:#8a7e72;
  --color-border:#e0d5c8;--color-border-light:#ede6dc;--color-white:#fff;
  --header-height:72px;--container:1200px;--container-wide:1400px;
  --font-ja:'Zen Maru Gothic','Hiragino Maru Gothic Pro',sans-serif;
  --font-en:'Poppins',sans-serif;--font-accent:'Cormorant Garamond',serif;
  --font-logo:'Dancing Script',cursive;
  --font-handwritten:'Zen Kurenaido','Zen Maru Gothic',sans-serif;
  --shadow-subtle:0 1px 1px hsl(25 30% 40%/.06),0 2px 2px hsl(25 30% 40%/.06),0 4px 4px hsl(25 30% 40%/.06);
  --shadow-elevated:0 1px 2px hsl(25 30% 40%/.05),0 2px 4px hsl(25 30% 40%/.05),0 4px 8px hsl(25 30% 40%/.05),0 8px 16px hsl(25 30% 40%/.05);
  --shadow-floating:0 2px 4px hsl(25 30% 40%/.04),0 4px 8px hsl(25 30% 40%/.04),0 8px 16px hsl(25 30% 40%/.04),0 16px 32px hsl(25 30% 40%/.04),0 32px 64px hsl(25 30% 40%/.04);
  --shadow-mega:0 2px 4px hsl(25 30% 40%/.03),0 4px 8px hsl(25 30% 40%/.03),0 8px 16px hsl(25 30% 40%/.03),0 16px 32px hsl(25 30% 40%/.03),0 32px 64px hsl(25 30% 40%/.03),0 64px 128px hsl(25 30% 40%/.03);
  --border-subtle:1px solid var(--color-border-light);
  --radius-none:0px;--radius-full:9999px;
  --transition-fast:.2s cubic-bezier(.4,0,.2,1);
  --transition-base:.35s cubic-bezier(.4,0,.2,1);
  --transition-slow:.5s cubic-bezier(.25,.46,.45,.94);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-ja);font-size:15px;font-weight:500;line-height:1.9;color:var(--color-text);background:var(--color-cream);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:color var(--transition-fast)}
ul{list-style:none}
h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.4;color:var(--color-dark)}
.container{max-width:var(--container);margin:0 auto;padding:0 24px}

/* ============================================
   LOGO SVG
   ============================================ */
.logo-svg{overflow:visible;display:block}
.logo-svg text{
  font-family:var(--font-logo);font-size:38px;font-weight:700;
  fill:none;stroke:#fff;stroke-width:1.2;
  stroke-dasharray:600;stroke-dashoffset:600;
  animation:drawLogo 2.5s ease forwards .5s;
}
.logo-svg .logo-fill{fill:#fff;stroke:none;opacity:0;animation:fillLogo .6s ease forwards 2.4s}
.header.scrolled .logo-svg text{stroke:var(--color-primary)}
.header.scrolled .logo-svg .logo-fill{fill:var(--color-primary)}
@keyframes drawLogo{to{stroke-dashoffset:0}}
@keyframes fillLogo{to{opacity:1}}

/* ============================================
   HEADER
   ============================================ */
.header{
  position:fixed;top:0;left:0;width:100%;height:var(--header-height);
  z-index:1000;background:transparent;
  transition:background .4s ease,box-shadow .4s ease;
}
.header.scrolled{
  background:rgba(250,246,241,.96);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  box-shadow:var(--shadow-subtle);
}
.header-inner{
  max-width:var(--container-wide);margin:0 auto;padding:0 32px;
  display:flex;align-items:center;justify-content:space-between;height:100%;
}
.header-logo{display:flex;align-items:center;gap:8px}
.header-nav{display:flex;align-items:center;gap:6px}
.header-nav a{
  font-size:12.5px;font-weight:600;letter-spacing:.04em;
  color:rgba(255,255,255,.95);padding:8px 16px;
  border-radius:var(--radius-full);
  border:1.5px solid rgba(255,255,255,.35);
  background:rgba(255,255,255,.1);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  transition:all .25s ease;
}
.header-nav a:hover{background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.6);transform:translateY(-1px)}
.header.scrolled .header-nav a{
  color:var(--color-text-medium);border-color:var(--color-border);
  background:var(--color-white);box-shadow:0 1px 3px hsl(25 30% 40%/.08);backdrop-filter:none;
}
.header.scrolled .header-nav a:hover{color:var(--color-primary-dark);border-color:var(--color-primary);background:var(--color-primary-pale)}
.header-nav .current{background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.6)}
.header.scrolled .header-nav .current{color:var(--color-primary-dark);border-color:var(--color-primary);background:var(--color-primary-pale)}
.header-cta{
  padding:9px 22px!important;font-size:12px!important;font-weight:700!important;
  color:#fff!important;background:var(--color-primary)!important;
  border:1.5px solid var(--color-primary)!important;
  border-bottom:4px solid var(--color-primary-dark)!important;
  box-shadow:0 2px 5px rgba(184,76,0,.3)!important;
  border-radius:var(--radius-full)!important;
  display:inline-flex!important;align-items:center!important;gap:6px!important;
  transition:all .15s ease!important;letter-spacing:.06em!important;backdrop-filter:none!important;
}
.header-cta:hover{
  background:var(--color-primary-hover)!important;
  border-bottom:2px solid var(--color-primary-dark)!important;
  margin-top:2px!important;box-shadow:0 1px 2px rgba(184,76,0,.2)!important;transform:none!important;
}
.header.scrolled .header-cta{
  color:#fff!important;background:var(--color-primary)!important;
  border-color:var(--color-primary)!important;border-bottom-color:var(--color-primary-dark)!important;
}
.header-menu-btn{display:none;background:none;border:none;cursor:pointer;width:32px;height:32px;position:relative}
.header-menu-btn span{display:block;width:24px;height:2px;background:#fff;position:absolute;left:4px;transition:var(--transition-base)}
.header.scrolled .header-menu-btn span{background:var(--color-text)}
.header-menu-btn span:nth-child(1){top:8px}
.header-menu-btn span:nth-child(2){top:15px}
.header-menu-btn span:nth-child(3){top:22px}
.mobile-menu{position:fixed;top:0;right:-100%;width:320px;height:100vh;background:var(--color-white);z-index:1001;transition:right var(--transition-base);padding:100px 40px 40px;box-shadow:var(--shadow-mega);overflow-y:auto}
.mobile-menu.active{right:0}
.mobile-menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(46,42,36,.5);z-index:1000;opacity:0;visibility:hidden;transition:var(--transition-base)}
.mobile-menu-overlay.active{opacity:1;visibility:visible}
.mobile-menu a{display:block;padding:16px 0;font-size:15px;font-weight:500;color:var(--color-text);border-bottom:var(--border-subtle)}
.mobile-menu-close{
  position:absolute;top:24px;right:24px;width:40px;height:40px;
  background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;
}
.mobile-menu-close::before,.mobile-menu-close::after{content:'';position:absolute;width:24px;height:2px;background:var(--color-text)}
.mobile-menu-close::before{transform:rotate(45deg)}
.mobile-menu-close::after{transform:rotate(-45deg)}

/* ============================================
   BUTTONS
   ============================================ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 36px;font-family:var(--font-ja);
  font-size:14px;font-weight:700;letter-spacing:.08em;
  border:none;cursor:pointer;border-radius:var(--radius-full);
  transition:all .15s ease;text-align:center;line-height:1.4;
}
.btn::after{
  content:'→';display:inline-flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:400;width:26px;height:26px;border-radius:50%;
  transition:all var(--transition-base);flex-shrink:0;
}
.btn-primary{color:#fff;background:var(--color-primary);border-bottom:5px solid var(--color-primary-dark);box-shadow:0 3px 5px rgba(184,76,0,.3)}
.btn-primary::after{background:rgba(255,255,255,.2);color:#fff}
.btn-primary:hover{margin-top:3px;background:var(--color-primary-hover);border-bottom:2px solid var(--color-primary-dark);box-shadow:0 1px 3px rgba(184,76,0,.2)}
.btn-primary:hover::after{transform:translateX(4px)}
.btn-outline{color:var(--color-primary);background:#fff;border:2px solid var(--color-primary);border-bottom:5px solid var(--color-primary-dark);box-shadow:0 3px 5px rgba(184,76,0,.15);padding:14px 34px}
.btn-outline::after{background:var(--color-primary-pale);color:var(--color-primary)}
.btn-outline:hover{margin-top:3px;background:var(--color-primary-pale);border-bottom:2px solid var(--color-primary-dark);box-shadow:0 1px 3px rgba(184,76,0,.1)}
.btn-outline:hover::after{transform:translateX(4px)}
.btn-white{color:var(--color-primary);background:#fff;border-bottom:5px solid #ccc;box-shadow:0 3px 5px rgba(0,0,0,.15)}
.btn-white::after{background:var(--color-primary-pale);color:var(--color-primary)}
.btn-white:hover{margin-top:3px;background:#f8f8f8;border-bottom:2px solid #ccc;box-shadow:0 1px 3px rgba(0,0,0,.1)}
.btn-white:hover::after{transform:translateX(4px)}
.btn-white-outline{color:#fff;background:transparent;border:2px solid rgba(255,255,255,.7);border-bottom:5px solid rgba(255,255,255,.4);box-shadow:0 3px 5px rgba(0,0,0,.2);padding:14px 34px}
.btn-white-outline::after{background:rgba(255,255,255,.15);color:#fff}
.btn-white-outline:hover{margin-top:3px;background:rgba(255,255,255,.1);border-bottom:2px solid rgba(255,255,255,.4);box-shadow:0 1px 3px rgba(0,0,0,.15)}
.btn-white-outline:hover::after{transform:translateX(4px)}

/* ============================================
   PAGE HERO
   ============================================ */
.page-hero{
  position:relative;height:360px;overflow:hidden;
  display:flex;align-items:center;justify-content:center;text-align:center;
}
.page-hero-bg{position:absolute;inset:0;z-index:1}
.page-hero-bg img{width:100%;height:100%;object-fit:cover}
.page-hero-bg::after{
  content:'';position:absolute;inset:0;z-index:2;
  background:linear-gradient(135deg,rgba(184,76,0,.45) 0%,rgba(46,42,36,.35) 100%);
}
.page-hero-content{position:relative;z-index:10;padding-top:var(--header-height)}
.page-hero-label{
  font-family:var(--font-accent);font-style:italic;font-size:clamp(36px,6vw,56px);
  color:rgba(255,255,255,.85);letter-spacing:.02em;line-height:1.2;margin-bottom:8px;
}
.page-hero-title{font-size:clamp(18px,2.5vw,24px);color:#fff;font-weight:700;letter-spacing:.08em}
.page-hero-wave{position:absolute;bottom:-1px;left:0;width:100%;z-index:5;line-height:0}
.page-hero-wave svg{width:100%;height:auto;display:block}

/* ============================================
   BREADCRUMB
   ============================================ */
.breadcrumb{padding:20px 0;font-size:12px;color:var(--color-text-light)}
.breadcrumb a{color:var(--color-text-light);transition:color var(--transition-fast)}
.breadcrumb a:hover{color:var(--color-primary)}
.breadcrumb span{margin:0 8px;opacity:.5}

/* ============================================
   SECTION COMMON
   ============================================ */
.section{padding:80px 0;position:relative}
.section-label{font-family:var(--font-accent);font-style:italic;font-size:clamp(32px,5vw,48px);color:var(--color-primary);letter-spacing:.02em;line-height:1.2;margin-bottom:8px}
.section-title{font-size:clamp(20px,3vw,28px);font-weight:700;color:var(--color-dark);letter-spacing:.06em}
.section-header{text-align:center;margin-bottom:56px}

/* ============================================
   EVENT INTRO
   ============================================ */
.event-intro{max-width:760px;margin:0 auto 48px;text-align:center}
.event-intro-catch{
  font-family:var(--font-handwritten);
  font-size:clamp(22px,3.5vw,32px);font-weight:400;
  color:var(--color-dark);line-height:1.6;margin-bottom:20px;
  text-shadow:1px 1px 0 rgba(232,133,74,.15);
}
.event-intro-desc{font-size:15px;line-height:2;color:var(--color-text-medium)}

/* ============================================
   EVENT FILTER
   ============================================ */
.event-filter{
  display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-bottom:40px;
}
.event-filter-btn{
  padding:10px 24px;font-family:var(--font-ja);font-size:13px;font-weight:600;
  color:var(--color-text-medium);background:var(--color-white);
  border:1.5px solid var(--color-border);border-radius:var(--radius-full);
  cursor:pointer;transition:all var(--transition-fast);letter-spacing:.04em;
}
.event-filter-btn:hover{border-color:var(--color-primary-light);color:var(--color-primary)}
.event-filter-btn.active{
  color:#fff;background:var(--color-primary);border-color:var(--color-primary);
  box-shadow:0 2px 8px rgba(232,133,74,.25);
}
.event-count{text-align:center;margin-bottom:40px;font-size:14px;color:var(--color-text-light)}
.event-count strong{color:var(--color-primary);font-size:20px;font-weight:700}

/* ============================================
   EVENT CARD (立体ボタン風)
   ============================================ */
.event-card{
  background:var(--color-white);overflow:hidden;display:flex;flex-direction:column;
  border:1.5px solid var(--color-border-light);
  border-bottom:6px solid var(--color-border);
  box-shadow:0 4px 0 var(--color-border),0 6px 12px rgba(46,42,36,.06);
  transition:all .15s ease;position:relative;cursor:pointer;
}
.event-card:hover{
  border-bottom-width:3px;
  margin-top:3px;
  box-shadow:0 2px 0 var(--color-border),0 3px 8px rgba(46,42,36,.08);
}
.event-card:active{
  border-bottom-width:1px;
  margin-top:5px;
  box-shadow:0 0 0 var(--color-border),0 1px 4px rgba(46,42,36,.1);
}
.event-card[data-hidden="true"]{display:none}

/* 終了イベントのスタイル */
.event-card[data-status="ended"]{opacity:.65}
.event-card[data-status="ended"] .event-card-image::after{
  content:'終了しました';
  position:absolute;inset:0;z-index:3;
  background:rgba(46,42,36,.5);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:16px;font-weight:700;letter-spacing:.1em;
}

.event-card-image{position:relative;overflow:hidden;height:220px}
.event-card-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}
.event-card:hover .event-card-image img{transform:scale(1.04)}

/* バッジ */
.event-card-badges{position:absolute;top:12px;left:12px;display:flex;flex-wrap:wrap;gap:6px;z-index:4}
.event-badge{padding:4px 14px;font-size:11px;font-weight:700;color:#fff;border-radius:var(--radius-full);line-height:1.4}
.event-badge-type{background:var(--color-primary)}
.event-badge-status{background:var(--color-secondary)}
.event-badge-permanent{background:var(--color-text-medium)}
.event-badge-ended{background:var(--color-text-light)}
.event-badge-category{background:#5b8c3e;font-size:10px;letter-spacing:.06em}

.event-card-body{padding:24px 28px;flex:1;display:flex;flex-direction:column}
.event-card-category{
  font-size:11px;font-weight:600;color:var(--color-primary);
  letter-spacing:.08em;margin-bottom:6px;
}
.event-card-title{font-size:17px;font-weight:700;color:var(--color-dark);margin-bottom:12px;line-height:1.6}
.event-card-info{font-size:13px;color:var(--color-text-medium);line-height:1.8;margin-bottom:16px;flex:1}
.event-card-info-row{display:flex;align-items:flex-start;gap:8px;margin-bottom:4px}
.event-card-info-label{font-size:11px;font-weight:700;color:var(--color-text-light);min-width:40px;padding-top:2px;flex-shrink:0}
.event-card-info-value{font-size:13px;color:var(--color-text-medium)}
.event-card-footer{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:16px;border-top:1px solid var(--color-border-light);margin-top:auto;
}
.event-card-link{font-size:13px;font-weight:600;color:var(--color-primary);display:inline-flex;align-items:center;gap:6px;transition:gap var(--transition-base)}
.event-card:hover .event-card-link{gap:10px}
.event-card-reserve{
  padding:8px 20px;font-size:12px;font-weight:700;
  color:#fff;background:var(--color-primary);
  border-radius:var(--radius-full);border:none;
  border-bottom:3px solid var(--color-primary-dark);
  transition:all var(--transition-fast);letter-spacing:.04em;
}

/* ============================================
   EVENT LAYOUT: 最新1件=1カラム、残り=2カラム
   ============================================ */
.event-list{display:flex;flex-direction:column;gap:36px}

.event-card-featured{
  display:grid;grid-template-columns:1.2fr 1fr;
  border-bottom:8px solid var(--color-border);
  box-shadow:0 6px 0 var(--color-border),0 8px 16px rgba(46,42,36,.07);
}
.event-card-featured:hover{
  border-bottom-width:4px;margin-top:4px;
  box-shadow:0 3px 0 var(--color-border),0 4px 10px rgba(46,42,36,.09);
}
.event-card-featured:active{
  border-bottom-width:2px;margin-top:6px;
  box-shadow:0 1px 0 var(--color-border),0 2px 6px rgba(46,42,36,.1);
}
.event-card-featured .event-card-image{height:100%;min-height:340px}
.event-card-featured .event-card-body{padding:36px 40px}
.event-card-featured .event-card-title{font-size:22px}
.event-card-featured .event-card-footer{flex-wrap:wrap;gap:12px}

.event-grid-rest{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}

/* ============================================
   CTA
   ============================================ */
.section-cta{padding:100px 0;background:var(--color-primary-gradient);text-align:center;position:relative;overflow:hidden}
.section-cta::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.1),transparent 70%)}
.section-cta::after{content:'';position:absolute;bottom:-100px;left:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.08),transparent 70%)}
.cta-label{font-family:var(--font-accent);font-style:italic;font-size:clamp(32px,5vw,48px);color:rgba(255,255,255,.7);letter-spacing:.02em;line-height:1.2;margin-bottom:8px}
.cta-title{font-size:clamp(24px,4vw,36px);color:#fff;margin-bottom:16px}
.cta-sub{font-size:15px;color:rgba(255,255,255,.85);margin-bottom:40px}
.cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}

/* ============================================
   FOOTER
   ============================================ */
.footer{background:var(--color-dark);color:rgba(255,255,255,.7);padding:80px 0 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:60px}
.footer-brand-logo{height:32px;margin-bottom:20px}
.footer-brand p{font-size:13px;line-height:1.8}
.footer h4{color:#fff;font-size:14px;font-weight:600;margin-bottom:20px;letter-spacing:.06em}
.footer a{display:block;padding:6px 0;font-size:13px;color:rgba(255,255,255,.6);transition:color var(--transition-fast)}
.footer a:hover{color:var(--color-primary-light)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:24px 0;text-align:center;font-size:12px;color:rgba(255,255,255,.4)}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1024px){
  .header-nav{display:none}.header-menu-btn{display:block}
  .event-card-featured{grid-template-columns:1fr 1fr}
  .event-card-featured .event-card-body{padding:28px 32px}
  .event-card-featured .event-card-image{min-height:280px}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .page-hero{height:280px}
  .section{padding:60px 0}
  .event-card-featured{grid-template-columns:1fr}
  .event-card-featured .event-card-image{min-height:220px;height:220px}
  .event-card-featured .event-card-body{padding:24px}
  .event-card-featured .event-card-title{font-size:18px}
  .event-grid-rest{grid-template-columns:1fr}
  .event-card-image{height:200px}
  .cta-btns{flex-direction:column;align-items:center}
  .footer-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  body{font-size:14px}
  .container{padding:0 16px}
  .btn{padding:14px 28px;font-size:13px}
  .page-hero{height:220px}
  .event-filter-btn{padding:8px 16px;font-size:12px}
}
/* ============================================
   CSS VARIABLES
   ============================================ */
:root{
  --color-primary:#e8854a;--color-primary-dark:#b84c00;--color-primary-hover:#f56500;
  --color-primary-light:#f4a76e;--color-primary-pale:#fdf0e6;
  --color-primary-gradient:linear-gradient(135deg,#f4a76e 0%,#e8854a 50%,#d4703a 100%);
  --color-secondary:#8eb125;--color-secondary-dark:#6a8a10;--color-secondary-light:#a8c94e;
  --color-warm:#f5e6d3;--color-cream:#faf6f1;--color-cream-dark:#f0e8dd;
  --color-dark:#2e2a24;--color-text:#2e2a24;--color-text-medium:#5a5348;--color-text-light:#8a7e72;
  --color-border:#e0d5c8;--color-border-light:#ede6dc;--color-white:#fff;
  --header-height:72px;--container:1200px;--container-wide:1400px;
  --font-ja:'Zen Maru Gothic','Hiragino Maru Gothic Pro',sans-serif;
  --font-en:'Poppins',sans-serif;--font-accent:'Cormorant Garamond',serif;
  --font-logo:'Dancing Script',cursive;
  --font-handwritten:'Zen Kurenaido','Zen Maru Gothic',sans-serif;
  --shadow-subtle:0 1px 1px hsl(25 30% 40%/.06),0 2px 2px hsl(25 30% 40%/.06),0 4px 4px hsl(25 30% 40%/.06);
  --shadow-elevated:0 1px 2px hsl(25 30% 40%/.05),0 2px 4px hsl(25 30% 40%/.05),0 4px 8px hsl(25 30% 40%/.05),0 8px 16px hsl(25 30% 40%/.05);
  --shadow-floating:0 2px 4px hsl(25 30% 40%/.04),0 4px 8px hsl(25 30% 40%/.04),0 8px 16px hsl(25 30% 40%/.04),0 16px 32px hsl(25 30% 40%/.04),0 32px 64px hsl(25 30% 40%/.04);
  --shadow-mega:0 2px 4px hsl(25 30% 40%/.03),0 4px 8px hsl(25 30% 40%/.03),0 8px 16px hsl(25 30% 40%/.03),0 16px 32px hsl(25 30% 40%/.03),0 32px 64px hsl(25 30% 40%/.03),0 64px 128px hsl(25 30% 40%/.03);
  --border-subtle:1px solid var(--color-border-light);
  --radius-none:0px;--radius-full:9999px;
  --transition-fast:.2s cubic-bezier(.4,0,.2,1);
  --transition-base:.35s cubic-bezier(.4,0,.2,1);
  --transition-slow:.5s cubic-bezier(.25,.46,.45,.94);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-ja);font-size:15px;font-weight:500;line-height:1.9;color:var(--color-text);background:var(--color-cream);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:color var(--transition-fast)}
ul{list-style:none}
h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.4;color:var(--color-dark)}
.container{max-width:var(--container);margin:0 auto;padding:0 24px}

/* ============================================
   LOGO SVG
   ============================================ */
.logo-svg{overflow:visible;display:block}
.logo-svg text{
  font-family:var(--font-logo);font-size:38px;font-weight:700;
  fill:none;stroke:#fff;stroke-width:1.2;
  stroke-dasharray:600;stroke-dashoffset:600;
  animation:drawLogo 2.5s ease forwards .5s;
}
.logo-svg .logo-fill{fill:#fff;stroke:none;opacity:0;animation:fillLogo .6s ease forwards 2.4s}
.header.scrolled .logo-svg text{stroke:var(--color-primary)}
.header.scrolled .logo-svg .logo-fill{fill:var(--color-primary)}
@keyframes drawLogo{to{stroke-dashoffset:0}}
@keyframes fillLogo{to{opacity:1}}

/* ============================================
   HEADER
   ============================================ */
.header{
  position:fixed;top:0;left:0;width:100%;height:var(--header-height);
  z-index:1000;background:transparent;
  transition:background .4s ease,box-shadow .4s ease;
}
.header.scrolled{
  background:rgba(250,246,241,.96);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  box-shadow:var(--shadow-subtle);
}
.header-inner{
  max-width:var(--container-wide);margin:0 auto;padding:0 32px;
  display:flex;align-items:center;justify-content:space-between;height:100%;
}
.header-logo{display:flex;align-items:center;gap:8px}
.header-nav{display:flex;align-items:center;gap:6px}
.header-nav a{
  font-size:12.5px;font-weight:600;letter-spacing:.04em;
  color:rgba(255,255,255,.95);padding:8px 16px;
  border-radius:var(--radius-full);
  border:1.5px solid rgba(255,255,255,.35);
  background:rgba(255,255,255,.1);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  transition:all .25s ease;
}
.header-nav a:hover{background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.6);transform:translateY(-1px)}
.header.scrolled .header-nav a{
  color:var(--color-text-medium);border-color:var(--color-border);
  background:var(--color-white);box-shadow:0 1px 3px hsl(25 30% 40%/.08);backdrop-filter:none;
}
.header.scrolled .header-nav a:hover{color:var(--color-primary-dark);border-color:var(--color-primary);background:var(--color-primary-pale)}
.header-nav .current{background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.6)}
.header.scrolled .header-nav .current{color:var(--color-primary-dark);border-color:var(--color-primary);background:var(--color-primary-pale)}
.header-cta{
  padding:9px 22px!important;font-size:12px!important;font-weight:700!important;
  color:#fff!important;background:var(--color-primary)!important;
  border:1.5px solid var(--color-primary)!important;
  border-bottom:4px solid var(--color-primary-dark)!important;
  box-shadow:0 2px 5px rgba(184,76,0,.3)!important;
  border-radius:var(--radius-full)!important;
  display:inline-flex!important;align-items:center!important;gap:6px!important;
  transition:all .15s ease!important;letter-spacing:.06em!important;backdrop-filter:none!important;
}
.header-cta:hover{
  background:var(--color-primary-hover)!important;
  border-bottom:2px solid var(--color-primary-dark)!important;
  margin-top:2px!important;box-shadow:0 1px 2px rgba(184,76,0,.2)!important;transform:none!important;
}
.header.scrolled .header-cta{
  color:#fff!important;background:var(--color-primary)!important;
  border-color:var(--color-primary)!important;border-bottom-color:var(--color-primary-dark)!important;
}
.header-menu-btn{display:none;background:none;border:none;cursor:pointer;width:32px;height:32px;position:relative}
.header-menu-btn span{display:block;width:24px;height:2px;background:#fff;position:absolute;left:4px;transition:var(--transition-base)}
.header.scrolled .header-menu-btn span{background:var(--color-text)}
.header-menu-btn span:nth-child(1){top:8px}
.header-menu-btn span:nth-child(2){top:15px}
.header-menu-btn span:nth-child(3){top:22px}
.mobile-menu{position:fixed;top:0;right:-100%;width:320px;height:100vh;background:var(--color-white);z-index:1001;transition:right var(--transition-base);padding:100px 40px 40px;box-shadow:var(--shadow-mega);overflow-y:auto}
.mobile-menu.active{right:0}
.mobile-menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(46,42,36,.5);z-index:1000;opacity:0;visibility:hidden;transition:var(--transition-base)}
.mobile-menu-overlay.active{opacity:1;visibility:visible}
.mobile-menu a{display:block;padding:16px 0;font-size:15px;font-weight:500;color:var(--color-text);border-bottom:var(--border-subtle)}
.mobile-menu-close{
  position:absolute;top:24px;right:24px;width:40px;height:40px;
  background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;
}
.mobile-menu-close::before,.mobile-menu-close::after{content:'';position:absolute;width:24px;height:2px;background:var(--color-text)}
.mobile-menu-close::before{transform:rotate(45deg)}
.mobile-menu-close::after{transform:rotate(-45deg)}

/* ============================================
   BUTTONS
   ============================================ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 36px;font-family:var(--font-ja);
  font-size:14px;font-weight:700;letter-spacing:.08em;
  border:none;cursor:pointer;border-radius:var(--radius-full);
  transition:all .15s ease;text-align:center;line-height:1.4;
}
.btn::after{
  content:'→';display:inline-flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:400;width:26px;height:26px;border-radius:50%;
  transition:all var(--transition-base);flex-shrink:0;
}
.btn-primary{color:#fff;background:var(--color-primary);border-bottom:5px solid var(--color-primary-dark);box-shadow:0 3px 5px rgba(184,76,0,.3)}
.btn-primary::after{background:rgba(255,255,255,.2);color:#fff}
.btn-primary:hover{margin-top:3px;background:var(--color-primary-hover);border-bottom:2px solid var(--color-primary-dark);box-shadow:0 1px 3px rgba(184,76,0,.2)}
.btn-primary:hover::after{transform:translateX(4px)}
.btn-outline{color:var(--color-primary);background:#fff;border:2px solid var(--color-primary);border-bottom:5px solid var(--color-primary-dark);box-shadow:0 3px 5px rgba(184,76,0,.15);padding:14px 34px}
.btn-outline::after{background:var(--color-primary-pale);color:var(--color-primary)}
.btn-outline:hover{margin-top:3px;background:var(--color-primary-pale);border-bottom:2px solid var(--color-primary-dark);box-shadow:0 1px 3px rgba(184,76,0,.1)}
.btn-outline:hover::after{transform:translateX(4px)}
.btn-white{color:var(--color-primary);background:#fff;border-bottom:5px solid #ccc;box-shadow:0 3px 5px rgba(0,0,0,.15)}
.btn-white::after{background:var(--color-primary-pale);color:var(--color-primary)}
.btn-white:hover{margin-top:3px;background:#f8f8f8;border-bottom:2px solid #ccc;box-shadow:0 1px 3px rgba(0,0,0,.1)}
.btn-white:hover::after{transform:translateX(4px)}
.btn-white-outline{color:#fff;background:transparent;border:2px solid rgba(255,255,255,.7);border-bottom:5px solid rgba(255,255,255,.4);box-shadow:0 3px 5px rgba(0,0,0,.2);padding:14px 34px}
.btn-white-outline::after{background:rgba(255,255,255,.15);color:#fff}
.btn-white-outline:hover{margin-top:3px;background:rgba(255,255,255,.1);border-bottom:2px solid rgba(255,255,255,.4);box-shadow:0 1px 3px rgba(0,0,0,.15)}
.btn-white-outline:hover::after{transform:translateX(4px)}

/* ============================================
   PAGE HERO
   ============================================ */
.page-hero{
  position:relative;height:360px;overflow:hidden;
  display:flex;align-items:center;justify-content:center;text-align:center;
}
.page-hero-bg{position:absolute;inset:0;z-index:1}
.page-hero-bg img{width:100%;height:100%;object-fit:cover}
.page-hero-bg::after{
  content:'';position:absolute;inset:0;z-index:2;
  background:linear-gradient(135deg,rgba(184,76,0,.45) 0%,rgba(46,42,36,.35) 100%);
}
.page-hero-content{position:relative;z-index:10;padding-top:var(--header-height)}
.page-hero-label{
  font-family:var(--font-accent);font-style:italic;font-size:clamp(36px,6vw,56px);
  color:rgba(255,255,255,.85);letter-spacing:.02em;line-height:1.2;margin-bottom:8px;
}
.page-hero-title{font-size:clamp(18px,2.5vw,24px);color:#fff;font-weight:700;letter-spacing:.08em}
.page-hero-wave{position:absolute;bottom:-1px;left:0;width:100%;z-index:5;line-height:0}
.page-hero-wave svg{width:100%;height:auto;display:block}

/* ============================================
   BREADCRUMB
   ============================================ */
.breadcrumb{padding:20px 0;font-size:12px;color:var(--color-text-light)}
.breadcrumb a{color:var(--color-text-light);transition:color var(--transition-fast)}
.breadcrumb a:hover{color:var(--color-primary)}
.breadcrumb span{margin:0 8px;opacity:.5}

/* ============================================
   SECTION
   ============================================ */
.section{padding:80px 0;position:relative}
.section-label{font-family:var(--font-accent);font-style:italic;font-size:clamp(32px,5vw,48px);color:var(--color-primary);letter-spacing:.02em;line-height:1.2;margin-bottom:8px}
.section-title{font-size:clamp(20px,3vw,28px);font-weight:700;color:var(--color-dark);letter-spacing:.06em}
.section-header{text-align:center;margin-bottom:56px}

/* ============================================
   GALLERY INTRO
   ============================================ */
.gallery-intro{max-width:760px;margin:0 auto 48px;text-align:center}
.gallery-intro-catch{
  font-family:var(--font-handwritten);
  font-size:clamp(22px,3.5vw,32px);font-weight:400;
  color:var(--color-dark);line-height:1.6;margin-bottom:20px;
  text-shadow:1px 1px 0 rgba(232,133,74,.15);
}
.gallery-intro-desc{font-size:15px;line-height:2;color:var(--color-text-medium)}

/* ============================================
   TYPE TABS (平屋 / 1.5階建て / 2階建て)
   ============================================ */
.type-tabs{
  display:flex;border-bottom:2px solid var(--color-border);margin-bottom:0;
}
.type-tab{
  flex:1;padding:18px 16px;font-family:var(--font-ja);font-size:16px;font-weight:700;
  color:var(--color-text-light);background:none;border:none;cursor:pointer;
  position:relative;letter-spacing:.06em;transition:color var(--transition-fast);
  text-align:center;
}
.type-tab:hover{color:var(--color-text)}
.type-tab.active{color:var(--color-dark)}
.type-tab.active::after{
  content:'';position:absolute;bottom:-2px;left:0;width:100%;height:3px;
  background:var(--color-dark);
}

/* ============================================
   FILTER ACCORDION
   ============================================ */
.filter-section{
  background:var(--color-white);border:1px solid var(--color-border-light);
  margin-bottom:40px;overflow:hidden;
}
.filter-toggle{
  display:flex;align-items:center;gap:12px;
  padding:20px 28px;font-family:var(--font-ja);font-size:15px;font-weight:700;
  color:var(--color-dark);background:none;border:none;cursor:pointer;
  width:100%;text-align:left;transition:background var(--transition-fast);
}
.filter-toggle:hover{background:var(--color-cream)}
.filter-toggle-icon{
  display:flex;align-items:center;justify-content:center;
  width:24px;height:24px;font-size:18px;color:var(--color-text-medium);
  transition:transform var(--transition-base);
}
.filter-toggle.open .filter-toggle-icon{transform:rotate(180deg)}
.filter-toggle-chevron{
  margin-left:auto;font-size:12px;color:var(--color-text-light);
  transition:transform var(--transition-base);
}
.filter-toggle.open .filter-toggle-chevron{transform:rotate(180deg)}

.filter-body{
  max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s ease;
  padding:0 28px;
}
.filter-body.open{
  max-height:600px;padding:0 28px 28px;
}

.filter-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:28px 48px;
}
.filter-group-label{
  font-size:12px;font-weight:600;color:var(--color-primary);
  letter-spacing:.08em;margin-bottom:12px;padding-bottom:8px;
  border-bottom:1px solid var(--color-border-light);
}
.filter-tags{display:flex;flex-wrap:wrap;gap:8px}
.filter-tag{
  padding:8px 18px;font-family:var(--font-ja);font-size:13px;font-weight:500;
  color:var(--color-text-medium);background:var(--color-white);
  border:1.5px solid var(--color-border);border-radius:var(--radius-full);
  cursor:pointer;transition:all var(--transition-fast);user-select:none;
}
.filter-tag:hover{border-color:var(--color-primary-light);color:var(--color-primary)}
.filter-tag.selected{
  color:var(--color-primary-dark);background:var(--color-primary-pale);
  border-color:var(--color-primary);font-weight:700;
}
.filter-search-btn{
  display:flex;align-items:center;justify-content:center;gap:8px;
  margin-top:28px;margin-left:auto;
  padding:14px 40px;font-family:var(--font-ja);font-size:14px;font-weight:700;
  color:#fff;background:var(--color-dark);border:none;
  border-bottom:4px solid #1a1714;
  cursor:pointer;transition:all .15s ease;letter-spacing:.06em;
}
.filter-search-btn:hover{
  margin-top:31px;border-bottom-width:1px;
  box-shadow:0 1px 4px rgba(0,0,0,.2);
}

/* ============================================
   RESULTS COUNT
   ============================================ */
.results-bar{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:32px;padding-bottom:16px;border-bottom:1px solid var(--color-border-light);
}
.results-count{font-size:14px;color:var(--color-text-light)}
.results-count strong{color:var(--color-primary);font-size:20px;font-weight:700}

/* ============================================
   GALLERY CARD
   ============================================ */
.gallery-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:28px;
}
.gallery-card{
  background:var(--color-white);overflow:hidden;display:flex;flex-direction:column;
  border:1.5px solid var(--color-border-light);
  border-bottom:6px solid var(--color-border);
  box-shadow:0 4px 0 var(--color-border),0 6px 12px rgba(46,42,36,.06);
  transition:all .15s ease;cursor:pointer;
}
.gallery-card:hover{
  border-bottom-width:3px;margin-top:3px;
  box-shadow:0 2px 0 var(--color-border),0 3px 8px rgba(46,42,36,.08);
}
.gallery-card:active{
  border-bottom-width:1px;margin-top:5px;
  box-shadow:0 0 0 var(--color-border),0 1px 4px rgba(46,42,36,.1);
}
.gallery-card[data-hidden="true"]{display:none}
.gallery-card-image{position:relative;overflow:hidden;height:240px}
.gallery-card-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}
.gallery-card:hover .gallery-card-image img{transform:scale(1.04)}
.gallery-card-badges{position:absolute;top:12px;left:12px;display:flex;flex-wrap:wrap;gap:6px;z-index:2}
.gallery-badge{
  padding:4px 12px;font-size:10px;font-weight:700;color:#fff;
  border-radius:var(--radius-full);line-height:1.4;letter-spacing:.04em;
}
.gallery-badge-type{background:var(--color-dark)}
.gallery-badge-tag{background:var(--color-primary)}

.gallery-card-body{padding:20px 24px;flex:1;display:flex;flex-direction:column}
.gallery-card-meta{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.gallery-card-meta-item{
  font-size:11px;font-weight:600;color:var(--color-text-light);
  background:var(--color-cream);padding:3px 10px;border-radius:var(--radius-full);
}
.gallery-card-title{
  font-size:16px;font-weight:700;color:var(--color-dark);
  margin-bottom:10px;line-height:1.6;
}
.gallery-card-spec{
  font-size:12px;color:var(--color-text-light);line-height:1.8;margin-bottom:12px;flex:1;
}
.gallery-card-footer{
  padding-top:14px;border-top:1px solid var(--color-border-light);margin-top:auto;
  display:flex;align-items:center;justify-content:space-between;
}
.gallery-card-link{
  font-size:13px;font-weight:600;color:var(--color-primary);
  display:inline-flex;align-items:center;gap:6px;
  transition:gap var(--transition-base);
}
.gallery-card:hover .gallery-card-link{gap:10px}

/* ============================================
   CTA
   ============================================ */
.section-cta{padding:100px 0;background:var(--color-primary-gradient);text-align:center;position:relative;overflow:hidden}
.section-cta::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.1),transparent 70%)}
.section-cta::after{content:'';position:absolute;bottom:-100px;left:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.08),transparent 70%)}
.cta-label{font-family:var(--font-accent);font-style:italic;font-size:clamp(32px,5vw,48px);color:rgba(255,255,255,.7);letter-spacing:.02em;line-height:1.2;margin-bottom:8px}
.cta-title{font-size:clamp(24px,4vw,36px);color:#fff;margin-bottom:16px}
.cta-sub{font-size:15px;color:rgba(255,255,255,.85);margin-bottom:40px}
.cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}

/* ============================================
   FOOTER
   ============================================ */
.footer{background:var(--color-dark);color:rgba(255,255,255,.7);padding:80px 0 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:60px}
.footer-brand-logo{height:32px;margin-bottom:20px}
.footer-brand p{font-size:13px;line-height:1.8}
.footer h4{color:#fff;font-size:14px;font-weight:600;margin-bottom:20px;letter-spacing:.06em}
.footer a{display:block;padding:6px 0;font-size:13px;color:rgba(255,255,255,.6);transition:color var(--transition-fast)}
.footer a:hover{color:var(--color-primary-light)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:24px 0;text-align:center;font-size:12px;color:rgba(255,255,255,.4)}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1024px){
  .header-nav{display:none}.header-menu-btn{display:block}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .page-hero{height:280px}
  .section{padding:60px 0}
  .type-tab{font-size:14px;padding:14px 12px}
  .filter-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr}
  .gallery-card-image{height:220px}
  .cta-btns{flex-direction:column;align-items:center}
  .footer-grid{grid-template-columns:1fr}
  .results-bar{flex-direction:column;gap:12px;align-items:flex-start}
}
@media(max-width:480px){
  body{font-size:14px}
  .container{padding:0 16px}
  .btn{padding:14px 28px;font-size:13px}
  .page-hero{height:220px}
  .type-tab{font-size:13px;padding:12px 8px}
  .filter-toggle{padding:16px 20px;font-size:14px}
  .filter-body.open{padding:0 20px 20px}
  .filter-tag{padding:6px 14px;font-size:12px}
}
/* 検索結果なし時のスタイル */
.no-results-container {
    grid-column: 1 / -1; /* グリッド全体を占有 */
    text-align: center;
    padding: 60px 0;
}

.no-results-message {
    margin-bottom: 80px;
}

.no-results-message p {
    font-size: 18px;
    font-weight: 700;
    color: #2e2a24;
    margin-bottom: 10px;
}

.no-results-message .sub-msg {
    font-size: 14px;
    font-weight: 400;
    color: #8a7e72;
}

/* おすすめタイトル */
.recommend-title {
    font-family: 'Cormorant Garamond', serif;
    font-style: italic;
    font-size: 32px;
    color: #e8854a;
    margin-bottom: 40px;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.recommend-title span {
    font-family: sans-serif;
    font-style: normal;
    font-size: 14px;
    color: #2e2a24;
    letter-spacing: 0.1em;
    margin-top: 5px;
}
/* 予約フォーム全体のコンテナ */
.section-reserve-form {
    padding: 80px 0;
    background-color: #fff;
}

/* 各入力行の余白調整 */
.form-row {
    margin-bottom: 30px;
}

.form-group label {
    display: block;
    font-weight: 700;
    margin-bottom: 10px;
    color: #2e2a24;
}

.form-group label span {
    color: #e8854a;
    font-size: 12px;
    margin-left: 8px;
}

/* 入力フィールドの共通スタイル */
.wpcf7-form-control {
    width: 100% !important;
    padding: 15px !important;
    border: 1px solid #e0d5c8 !important;
    border-radius: 4px !important;
    background-color: #faf6f1 !important;
    font-size: 15px !important;
    transition: border-color 0.3s ease;
}

.wpcf7-form-control:focus {
    border-color: #e8854a !important;
    outline: none !important;
    background-color: #fff !important;
}

/* 日付と時間のセレクトボックスを横並びに */
input[type="date"],
select.wpcf7-form-control {
    display: inline-block;
    width: auto !important;
    margin-right: 10px;
}

/* ラジオボタンの装飾 */
.wpcf7-list-item {
    margin: 0 20px 0 0 !important;
}

/* 送信ボタンの装飾 */
.form-submit {
    text-align: center;
    margin-top: 50px;
}

.btn-primary {
    background-color: #e8854a;
    color: #fff;
    padding: 20px 80px;
    border: none;
    border-radius: 99px;
    font-weight: 700;
    cursor: pointer;
    transition: 0.3s;
    box-shadow: 0 4px 15px rgba(232, 133, 74, 0.3);
}

.btn-primary:hover {
    background-color: #b84c00;
    transform: translateY(-2px);
}