/* =========================================================
   ダスキン大河原 TOPページ案
   松本電工サイト（matsumoto-202606）のデザイン言語を踏襲し、
   配色をダスキン（ティール＋オレンジ）へ最適化した静的サイト。
   ※ビルド不要 / Cloudflare Pages 直デプロイ
   ========================================================= */

:root{
  /* メイン：ティール */
  --teal:#138A86; --teal-d:#13313A; --teal-m:#0F6E6A;
  /* 文字 */
  --ink:#17313B; --ink-2:#2B4A50;
  --muted:#52706E; --muted-2:#9DBEBB; --muted-3:#7C9B98;
  /* 罫線・サポート */
  --line:#EAF4F2; --line-2:#DCEEEB;
  --accent:#4FA39B; --accent-2:#2E8A86; --teal-soft:#C5DCD9;
  --bg:#ffffff; --bg-soft:#F2F9F7;
  /* アクセント：オレンジ */
  --orange:#EE6A12; --orange-d:#D2540A;
  --ease:cubic-bezier(.16,1,.3,1);
  --maxw:1180px;
}

/* ---------- reset / base ---------- */
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; scroll-padding-top:96px; }
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:'Noto Sans JP',sans-serif; line-height:1.75; font-weight:400;
  -webkit-font-smoothing:antialiased; font-feature-settings:'palt';
}
body.is-locked{ overflow:hidden; }
img{ display:block; max-width:100%; }
a{ color:inherit; }
h1,h2,h3,p{ margin:0; }
button{ font-family:inherit; }
.ic{ width:1em; height:1em; flex:none; }

.container{ max-width:var(--maxw); margin:0 auto; padding:0 40px; }
.section{ padding:128px 40px; }
.section--soft{ background:var(--bg-soft); }
.eyebrow{ font-size:12px; letter-spacing:.34em; color:var(--accent); }
.heading{ font-size:30px; font-weight:500; letter-spacing:.1em; color:var(--teal-d); }
.lead-center{ text-align:center; margin-bottom:56px; }
.lead-center .eyebrow{ display:block; margin-bottom:14px; }

@keyframes mdFloatY{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-7px); } }
@keyframes heroUp{ from{ opacity:0; transform:translateY(26px); } to{ opacity:1; transform:translateY(0); } }
@keyframes heroZoom{ from{ transform:scale(1.08); } to{ transform:scale(1); } }

.reveal{ opacity:0; transform:translateY(34px); transition:opacity 1s var(--ease), transform 1s var(--ease); will-change:opacity,transform; }
.reveal.in{ opacity:1; transform:none; }

/* =========================================================
   HEADER
   ========================================================= */
.site-header{ position:sticky; top:0; z-index:60; background:rgba(255,255,255,.92); backdrop-filter:blur(8px); border-bottom:1px solid var(--line); }
.site-header__inner{ max-width:1280px; margin:0 auto; padding:0 32px; height:82px; display:flex; align-items:center; gap:18px; }
.site-header__logo{ display:inline-flex; align-items:center; text-decoration:none; flex:none; }
.site-header__logo img{ height:42px; width:auto; }
.gnav{ margin-left:4px; display:flex; align-items:center; gap:16px; }
.gnav a{ position:relative; font-size:13.5px; font-weight:500; letter-spacing:.04em; color:var(--ink-2); text-decoration:none; white-space:nowrap; transition:color .3s; }
.gnav a::after{ content:""; position:absolute; left:0; bottom:-7px; width:0; height:2px; background:var(--orange); transition:width .4s var(--ease); }
.gnav a:hover{ color:var(--teal); }
.gnav a:hover::after{ width:100%; }
.header-actions{ margin-left:auto; display:flex; align-items:center; gap:14px; flex:none; }
.header-tel{ display:flex; align-items:center; gap:8px; text-decoration:none; color:var(--orange); flex:none; }
.header-tel__num{ display:block; font-size:20px; font-weight:700; color:var(--teal-d); letter-spacing:.02em; white-space:nowrap; }
.header-tel__sub{ display:block; font-size:10px; color:var(--muted-2); letter-spacing:.04em; white-space:nowrap; }
.header-tel .ic{ font-size:22px; }
.header-cta{ display:inline-flex; align-items:center; gap:7px; height:44px; padding:0 18px; border-radius:999px; background:var(--orange); color:#fff; font-weight:500; font-size:13px; letter-spacing:.04em; text-decoration:none; white-space:nowrap; flex:none; transition:transform .3s var(--ease), box-shadow .3s; }
.header-cta .ic{ font-size:17px; }
.header-cta:hover{ transform:translateY(-2px); box-shadow:0 12px 26px -12px rgba(238,106,18,.65); }

/* hamburger (mobile) */
.hamburger{ display:none; place-items:center; position:fixed; top:14px; right:14px; z-index:120; width:60px; height:60px; border:none; border-radius:18px; background:#fff; box-shadow:0 10px 26px -12px rgba(19,138,134,.5); cursor:pointer; padding:0; transition:opacity .45s var(--ease), visibility .45s var(--ease), transform .45s var(--ease), background .35s var(--ease); }
.hamburger:active{ transform:scale(.94); }
.hamburger__bars{ display:grid; gap:5px; transition:opacity .3s ease; }
.hamburger__bars span{ display:block; width:24px; height:2px; border-radius:2px; background:var(--teal-d); }
.hamburger__label{ position:absolute; bottom:7px; font-size:9px; letter-spacing:.08em; color:var(--muted); }
.hamburger__close{ position:absolute; inset:0; display:grid; place-items:center; opacity:0; transform:scale(.5); transition:opacity .3s ease, transform .45s var(--ease); }
.hamburger__close::before, .hamburger__close::after{ content:""; position:absolute; width:24px; height:2px; background:#fff; border-radius:2px; }
.hamburger__close::before{ transform:rotate(45deg); }
.hamburger__close::after{ transform:rotate(-45deg); }
.hamburger.is-open{ background:var(--teal); }
.hamburger.is-open .hamburger__bars, .hamburger.is-open .hamburger__label{ opacity:0; }
.hamburger.is-open .hamburger__close{ opacity:1; transform:scale(1); }

.m-quick{ display:none; }

/* mobile menu overlay */
.mobile-menu{ position:fixed; inset:0; z-index:110; background:linear-gradient(165deg,#138A86 0%,#0F6E6A 55%,#13313A 100%); color:#fff; padding:74px 26px 32px; display:flex; flex-direction:column; overflow-y:auto; -webkit-overflow-scrolling:touch; opacity:0; visibility:hidden; clip-path:circle(0% at calc(100% - 40px) 40px); transition:clip-path .6s var(--ease), opacity .4s ease, visibility .4s; }
.mobile-menu.is-open{ opacity:1; visibility:visible; clip-path:circle(150% at calc(100% - 40px) 40px); }
.mobile-menu__list{ list-style:none; margin:0 0 16px; padding:0; display:flex; flex-direction:column; gap:2px; }
.mobile-menu__list a{ display:flex; align-items:baseline; gap:16px; padding:11px 4px; text-decoration:none; color:#fff; border-bottom:1px solid rgba(197,220,217,.16); opacity:0; transform:translateY(22px); transition:opacity .55s var(--ease), transform .55s var(--ease); }
.mobile-menu.is-open .mobile-menu__list a{ opacity:1; transform:translateY(0); }
.mobile-menu__list li:nth-child(1) a{ transition-delay:.18s; }
.mobile-menu__list li:nth-child(2) a{ transition-delay:.25s; }
.mobile-menu__list li:nth-child(3) a{ transition-delay:.32s; }
.mobile-menu__list li:nth-child(4) a{ transition-delay:.39s; }
.mobile-menu__list li:nth-child(5) a{ transition-delay:.46s; }
.mobile-menu__list li:nth-child(6) a{ transition-delay:.53s; }
.mobile-menu__num{ font-family:'Cormorant Garamond',serif; font-style:italic; font-size:18px; color:var(--teal-soft); min-width:30px; }
.mobile-menu__ja{ font-size:22px; font-weight:500; letter-spacing:.08em; }
.mobile-menu__en{ margin-left:auto; align-self:center; font-size:10.5px; letter-spacing:.22em; color:rgba(197,220,217,.65); }
.mobile-menu__foot{ opacity:0; transform:translateY(22px); transition:opacity .55s var(--ease) .6s, transform .55s var(--ease) .6s; }
.mobile-menu.is-open .mobile-menu__foot{ opacity:1; transform:translateY(0); }
.mm-card{ display:flex; text-decoration:none; color:#fff; border:1px solid rgba(197,220,217,.45); border-radius:18px; background:rgba(255,255,255,.05); transition:transform .3s var(--ease); }
.mm-card:active{ transform:scale(.97); }
.mm-card__ico{ flex:0 0 auto; width:50px; height:50px; border-radius:50%; border:1.5px solid rgba(197,220,217,.55); display:grid; place-items:center; }
.mm-card__ico .ic{ font-size:24px; }
.mm-card--tel{ align-items:center; gap:16px; padding:18px 20px; margin-bottom:12px; }
.mm-card__body{ display:flex; flex-direction:column; gap:2px; }
.mm-card__lead{ font-size:12px; letter-spacing:.08em; color:var(--teal-soft); }
.mm-card__num{ font-size:29px; font-weight:900; line-height:1.1; }
.mm-card__sub{ font-size:11px; color:var(--muted-2); }
.mm-card-row{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.mm-card-row .mm-card{ flex-direction:column; align-items:center; justify-content:center; gap:9px; padding:18px 10px; text-align:center; }
.mm-card__title{ font-size:15px; font-weight:700; letter-spacing:.04em; line-height:1.35; }
.mm-card__en{ font-size:10px; letter-spacing:.2em; color:rgba(197,220,217,.55); }
.mm-card--contact{ border-color:rgba(238,106,18,.7); background:rgba(238,106,18,.16); }
.mm-card--contact .mm-card__ico{ border-color:rgba(245,160,90,.85); }

/* =========================================================
   HERO（モザイク）
   ========================================================= */
.hero{ position:relative; overflow:hidden; }
.hero-mosaic{ display:grid; grid-template-columns:1fr 1fr 1.55fr; grid-template-rows:300px 300px; height:600px; }
.hero-img{ overflow:hidden; }
.hero-img:nth-child(3){ grid-row:1 / 3; }
.hero-img img{ width:100%; height:100%; object-fit:cover; }
.hero-img:nth-child(3) img{ animation:heroZoom 14s ease-out both; }
.hero-overlay{ position:absolute; inset:0; pointer-events:none; background:radial-gradient(62% 62% at 50% 50%, rgba(6,40,44,.5), rgba(6,40,44,.2) 70%, rgba(6,40,44,.05) 100%); }
.hero-copy{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; pointer-events:none; padding:0 24px; }
.hero-eyebrow{ font-size:12px; letter-spacing:.5em; color:#fff; font-weight:600; text-shadow:0 2px 10px rgba(0,22,26,.85),0 1px 3px rgba(0,22,26,.9); animation:heroUp .9s var(--ease) both .2s; }
.hero-title{ margin-top:2px; font-family:'Cormorant Garamond',serif; font-style:italic; font-weight:400; font-size:124px; line-height:1; color:#fff; letter-spacing:.01em; text-shadow:0 8px 28px rgba(0,22,26,.7),0 2px 6px rgba(0,22,26,.8); animation:heroUp 1.1s var(--ease) both .36s; }
.hero-sub{ margin-top:8px; font-size:17px; letter-spacing:.3em; color:#fff; font-weight:600; text-shadow:0 2px 10px rgba(0,22,26,.9),0 1px 3px rgba(0,22,26,.95); animation:heroUp .9s var(--ease) both .54s; }

/* =========================================================
   STATUS RIBBON
   ========================================================= */
.ribbon{ border-bottom:1px solid var(--line); }
.ribbon__inner{ max-width:1280px; margin:0 auto; padding:16px 40px; display:flex; align-items:center; gap:28px; }
.ribbon__status{ display:inline-flex; align-items:center; gap:9px; font-size:13px; letter-spacing:.06em; color:var(--ink-2); white-space:nowrap; }
.ribbon__open{ display:inline-flex; align-items:center; gap:7px; color:var(--orange-d); font-weight:700; }
.ribbon__open.is-off{ color:var(--muted); }
.ribbon__dot{ width:8px; height:8px; border-radius:50%; background:var(--orange); box-shadow:0 0 0 4px rgba(238,106,18,.14); }
.ribbon__open.is-off .ribbon__dot{ background:var(--muted-2); box-shadow:0 0 0 4px rgba(157,190,187,.18); }
.ribbon__muted{ color:var(--muted-2); }
.ribbon__sep{ width:1px; height:18px; background:var(--line); }
.ribbon__news{ display:flex; align-items:center; gap:26px; overflow:hidden; }
.ribbon__news-label{ font-size:12px; letter-spacing:.14em; color:var(--muted-2); flex:0 0 auto; }
.ribbon__news a{ display:flex; align-items:center; gap:12px; text-decoration:none; white-space:nowrap; }
.ribbon__news a span:first-child{ font-size:12.5px; color:var(--muted-2); }
.ribbon__news a span:last-child{ font-size:13.5px; color:var(--ink-2); }
.ribbon__news a:hover span:last-child{ color:var(--orange-d); }

/* =========================================================
   INTRO
   ========================================================= */
.intro{ padding:128px 40px 120px; position:relative; overflow:hidden; }
.intro__deco{ position:absolute; left:0; top:40px; width:60%; height:360px; opacity:.6; pointer-events:none; }
.intro__inner{ max-width:760px; margin:0 auto; text-align:center; position:relative; }
.intro__tag{ display:inline-flex; align-items:center; gap:12px; margin-bottom:30px; }
.intro__tag span:nth-child(odd){ width:28px; height:1px; background:var(--teal-soft); }
.intro__tag span:nth-child(2){ font-size:12px; letter-spacing:.34em; color:var(--accent); }
.intro__title{ font-size:38px; line-height:1.7; font-weight:500; letter-spacing:.06em; color:var(--teal-d); }
.intro__text{ margin:34px auto 0; max-width:640px; font-size:15px; line-height:2.4; letter-spacing:.04em; color:var(--muted); }

/* =========================================================
   STATUS + CALENDAR
   ========================================================= */
.status-card{ background:#fff; border-radius:24px; box-shadow:0 30px 60px -40px rgba(19,138,134,.3); display:grid; grid-template-columns:1fr 1.1fr; overflow:hidden; max-width:1080px; margin:0 auto; }
.status-now{ padding:52px 48px; text-align:center; display:flex; flex-direction:column; justify-content:center; border-right:1px solid var(--line); }
.status-now__label{ font-size:12px; letter-spacing:.26em; color:var(--muted-2); }
.status-now__date{ margin-top:4px; font-size:18px; font-weight:500; color:var(--ink-2); letter-spacing:.04em; }
.status-now__date small{ font-size:14px; }
.status-now__badge{ display:flex; align-items:center; justify-content:center; gap:14px; margin-top:20px; }
.status-now__badge .ic{ font-size:46px; color:var(--orange); }
.status-now__badge.is-off .ic{ color:var(--teal); }
.status-now__badge span{ font-size:44px; font-weight:500; color:var(--orange); letter-spacing:.12em; }
.status-now__badge.is-off span{ color:var(--teal); }
.status-now__hours{ margin-top:18px; font-size:18px; font-weight:500; color:var(--ink-2); letter-spacing:.08em; }
.status-now__note{ margin-top:8px; font-size:13px; color:var(--muted-2); letter-spacing:.06em; }
.status-now__btns{ display:flex; gap:14px; justify-content:center; margin-top:34px; flex-wrap:wrap; }
.btn-pill{ display:inline-flex; align-items:center; gap:9px; min-height:50px; padding:0 26px; border-radius:999px; font-weight:500; font-size:14px; letter-spacing:.06em; text-decoration:none; transition:transform .3s var(--ease), box-shadow .3s; }
.btn-pill .ic{ font-size:17px; }
.btn-pill--orange{ background:var(--orange); color:#fff; }
.btn-pill--orange:hover{ transform:translateY(-2px); box-shadow:0 12px 26px -12px rgba(238,106,18,.65); }
.btn-pill--outline{ border:1px solid var(--teal-soft); color:var(--teal); }
.btn-pill--outline:hover{ transform:translateY(-2px); box-shadow:0 12px 26px -16px rgba(19,138,134,.5); }

.calendar{ padding:48px 52px; }
.calendar__head{ display:flex; align-items:baseline; justify-content:space-between; margin-bottom:22px; }
.calendar__title{ font-size:20px; font-weight:500; color:var(--teal-d); letter-spacing:.06em; }
.calendar__title small{ font-size:14px; color:var(--muted-2); }
.calendar__legend{ display:flex; gap:18px; }
.calendar__legend span{ display:flex; align-items:center; gap:7px; font-size:11.5px; color:var(--muted-3); }
.lg-dot{ width:11px; height:11px; border-radius:50%; }
.lg-dot--today{ background:var(--orange); }
.lg-dot--off{ background:#F0DAD0; }
.calendar__grid{ display:grid; grid-template-columns:repeat(7,1fr); gap:3px; }
.calendar__wd{ text-align:center; font-size:11.5px; font-weight:500; letter-spacing:.04em; color:var(--muted-2); padding:4px 0; }
.calendar__wd.sun{ color:#CC7A66; }
.cal-cell{ display:flex; align-items:center; justify-content:center; height:38px; font-size:14px; border-radius:50%; color:var(--ink-2); }
.cal-cell--today{ background:var(--orange); color:#fff; font-weight:700; }
.cal-cell--off{ color:#C98A6A; }
.calendar__note{ margin-top:20px; font-size:11.5px; color:var(--muted-2); letter-spacing:.04em; line-height:1.9; }

/* =========================================================
   SERVICES
   ========================================================= */
.services__inner{ max-width:1180px; margin:0 auto; display:grid; grid-template-columns:230px 1fr; gap:64px; align-items:start; }
.services__head{ display:flex; gap:22px; }
.services__head-ja{ writing-mode:vertical-rl; text-orientation:mixed; font-size:33px; font-weight:500; letter-spacing:.18em; line-height:1.9; color:var(--teal-d); height:430px; }
.services__head-en{ writing-mode:vertical-rl; padding-top:4px; font-size:11px; letter-spacing:.3em; color:var(--accent); }
.services__grid{ display:grid; grid-template-columns:1fr 1fr; column-gap:52px; row-gap:42px; }
.service{ display:flex; gap:20px; align-items:flex-start; }
.service__icon{ flex:0 0 auto; display:grid; place-items:center; width:68px; height:68px; border-radius:50%; border:1px solid var(--line-2); color:var(--teal); transition:border-color .3s, transform .3s var(--ease); }
.service__icon .ic{ font-size:32px; }
.service:hover .service__icon{ border-color:var(--teal-soft); transform:translateY(-3px); }
.service__title{ margin:6px 0 8px; font-size:17px; font-weight:500; letter-spacing:.06em; color:var(--teal-d); }
.service__desc{ font-size:13px; line-height:2; color:var(--muted); }
.services__more{ display:flex; justify-content:flex-end; margin-top:46px; }
.link-arrow{ display:inline-flex; align-items:center; gap:14px; text-decoration:none; color:var(--teal-d); font-size:14px; letter-spacing:.08em; }
.link-arrow__circle{ display:grid; place-items:center; width:42px; height:42px; border-radius:50%; background:var(--teal); color:#fff; transition:transform .3s var(--ease); }
.link-arrow__circle .ic{ font-size:16px; }
.link-arrow:hover .link-arrow__circle{ transform:translateX(4px); }
.link-arrow--outline .link-arrow__circle{ background:#fff; border:1px solid var(--teal-soft); color:var(--teal); }

/* =========================================================
   REASONS + STAFF
   ========================================================= */
.reasons{ position:relative; overflow:hidden; }
.reasons__deco{ position:absolute; right:0; bottom:60px; width:55%; height:280px; opacity:.6; pointer-events:none; }
.reasons__inner{ max-width:1120px; margin:0 auto; position:relative; }
.reasons__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:40px; }
.reason{ text-align:center; }
.reason__icon{ display:inline-grid; place-items:center; width:88px; height:88px; border-radius:50%; background:#fff; box-shadow:0 18px 40px -28px rgba(19,138,134,.42); margin-bottom:22px; color:var(--teal); transition:transform .35s var(--ease); }
.reason__icon .ic{ font-size:38px; }
.reason__icon .ic.is-orange{ color:var(--orange); }
.reason:hover .reason__icon{ transform:translateY(-4px); }
.reason__title{ margin-bottom:12px; font-size:17px; font-weight:500; letter-spacing:.08em; color:var(--teal-d); }
.reason__desc{ font-size:13px; line-height:2; color:var(--muted); }
.staff{ margin-top:100px; display:grid; grid-template-columns:1.15fr 1fr; gap:62px; align-items:center; }
.staff__photo{ border-radius:6px; overflow:hidden; box-shadow:0 40px 70px -45px rgba(19,138,134,.5); }
.staff__photo img{ width:100%; height:100%; object-fit:cover; max-height:380px; }
.staff__eyebrow{ margin-bottom:16px; font-size:12px; letter-spacing:.3em; color:var(--accent); }
.staff__title{ margin-bottom:26px; font-size:27px; font-weight:500; letter-spacing:.08em; line-height:1.7; color:var(--teal-d); }
.staff__text{ margin-bottom:32px; font-size:14px; line-height:2.4; letter-spacing:.04em; color:var(--muted); }

/* =========================================================
   WORKS
   ========================================================= */
.works__inner{ max-width:1180px; margin:0 auto; }
.works__head{ display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:52px; }
.works__pager{ display:flex; align-items:center; gap:20px; padding-bottom:6px; }
.works__pager > span:nth-child(1){ font-size:15px; letter-spacing:.1em; color:var(--teal); }
.works__pager > span:nth-child(3){ font-size:15px; letter-spacing:.1em; color:var(--muted-2); }
.works__pager-line{ width:64px; height:1px; background:var(--teal-soft); position:relative; }
.works__pager-line::before{ content:""; position:absolute; left:0; top:-1px; width:16px; height:3px; background:var(--orange); }
.works__arrows{ display:flex; gap:10px; margin-left:14px; }
.works__arrows span{ display:grid; place-items:center; width:42px; height:42px; border-radius:50%; color:var(--muted-2); }
.works__arrows span.is-active{ border:1px solid var(--teal); color:var(--teal); }
.works__arrows .ic{ font-size:16px; }
.works__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:28px; }
.work{ display:block; text-decoration:none; }
.work__thumb{ position:relative; border-radius:6px; overflow:hidden; aspect-ratio:4/5; margin-bottom:18px; }
.work__thumb img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease); }
.work:hover .work__thumb img{ transform:scale(1.05); }
.work__tag{ position:absolute; left:14px; bottom:14px; display:inline-flex; align-items:center; height:26px; padding:0 13px; background:rgba(255,255,255,.94); color:var(--teal); font-size:11px; letter-spacing:.06em; border-radius:999px; }
.work__title{ margin-bottom:10px; font-size:14.5px; font-weight:500; letter-spacing:.04em; line-height:1.7; color:var(--ink); }
.work:hover .work__title{ color:var(--orange-d); }
.work__meta{ display:flex; align-items:center; gap:10px; font-size:12px; color:var(--muted-2); letter-spacing:.04em; }
.work__meta i{ width:1px; height:11px; background:var(--line-2); font-style:normal; }
.works__more{ display:flex; justify-content:center; margin-top:58px; }
.btn-outline-lg{ display:inline-flex; align-items:center; gap:14px; min-height:58px; padding:0 40px; border-radius:999px; border:1px solid var(--teal-soft); text-decoration:none; color:var(--teal); font-size:14px; letter-spacing:.1em; transition:background .3s, transform .3s var(--ease); }
.btn-outline-lg .ic{ font-size:17px; }
.btn-outline-lg:hover{ background:var(--bg-soft); transform:translateY(-2px); }

/* =========================================================
   VOICES（お客様の声）
   ========================================================= */
.voices__inner{ max-width:1180px; margin:0 auto; }
.voices__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.voice{ background:#fff; border:1px solid var(--line); border-radius:18px; padding:30px 26px; display:flex; flex-direction:column; gap:16px; box-shadow:0 24px 50px -40px rgba(19,138,134,.4); }
.voice__quote{ font-size:30px; color:var(--teal-soft); }
.voice__quote .ic{ font-size:30px; }
.voice__text{ font-size:13.5px; line-height:2; color:var(--ink-2); flex:1; letter-spacing:.02em; }
.voice__who{ padding-top:14px; border-top:1px solid var(--line); font-size:11.5px; color:var(--muted-2); letter-spacing:.02em; }

/* =========================================================
   SHOWROOM / ACCESS
   ========================================================= */
.showroom__inner{ max-width:1080px; margin:0 auto; }
.showroom__name{ text-align:center; font-size:21px; font-weight:500; letter-spacing:.12em; color:var(--ink); margin-bottom:40px; }
.showroom__top{ display:grid; grid-template-columns:1.5fr 1fr; gap:24px; margin-bottom:48px; }
.showroom__photo{ border-radius:6px; overflow:hidden; box-shadow:0 30px 60px -45px rgba(19,138,134,.5); }
.showroom__photo img{ width:100%; height:100%; object-fit:cover; max-height:340px; }
.showroom__map{ position:relative; border-radius:6px; overflow:hidden; background:#E4F1EF; min-height:300px; border:1px solid var(--line-2); }
.showroom__map svg{ position:absolute; inset:0; width:100%; height:100%; }
.showroom__pin{ position:absolute; left:50%; top:46%; transform:translate(-50%,-100%); text-align:center; }
.showroom__pin .ic{ font-size:32px; color:var(--orange); }
.showroom__pin span{ display:block; margin-top:2px; font-size:11px; font-weight:500; color:var(--teal); background:#fff; padding:3px 10px; border-radius:6px; box-shadow:0 4px 14px rgba(19,138,134,.16); }
.showroom__detail{ display:grid; grid-template-columns:1.25fr 1fr; gap:56px; }
.hours-table{ display:grid; grid-template-columns:84px repeat(7,1fr); align-items:center; row-gap:14px; border-bottom:1px solid var(--line-2); padding-bottom:18px; }
.hours-table > span{ font-size:13px; }
.hours-table .ht-label{ font-size:12px; letter-spacing:.1em; color:var(--muted-2); }
.hours-table .ht-d{ text-align:center; color:var(--ink-2); }
.hours-table .ht-sun{ text-align:center; color:#CC7A66; }
.hours-table .ht-time{ font-size:12px; color:var(--muted-3); }
.hours-table .ht-on{ text-align:center; color:var(--teal); }
.hours-table .ht-off{ text-align:center; color:#D9BCB0; }
.showroom__note{ margin:14px 0 28px; font-size:12px; color:var(--muted-2); letter-spacing:.04em; }
.showroom__sub{ margin-bottom:10px; font-size:12px; letter-spacing:.16em; color:var(--muted-2); }
.showroom__contact{ display:flex; align-items:center; gap:22px; flex-wrap:wrap; }
.showroom__tel{ display:flex; align-items:center; gap:11px; text-decoration:none; color:var(--teal-d); }
.showroom__tel .ic{ font-size:24px; color:var(--orange); }
.showroom__tel span{ font-size:27px; font-weight:700; letter-spacing:.02em; }
.showroom__addr p{ margin-bottom:8px; }
.showroom__addr .a-ttl{ font-size:14.5px; color:var(--ink); letter-spacing:.04em; }
.showroom__addr .a-link{ font-size:13px; color:var(--accent-2); text-decoration:none; letter-spacing:.04em; }
.showroom__addr .a-access{ font-size:13.5px; line-height:2; color:var(--muted); }

/* =========================================================
   INFORMATION（お役立ち情報）
   ========================================================= */
.info{ padding:96px 40px; }
.info__inner{ max-width:1080px; margin:0 auto; text-align:center; }
.info__eyebrow{ margin-bottom:8px; font-size:12px; letter-spacing:.34em; color:var(--accent); }
.info__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:40px; text-align:left; }
.info-card{ display:flex; flex-direction:column; gap:14px; padding:30px 28px; border-radius:18px; border:1px solid var(--line-2); background:var(--bg-soft); text-decoration:none; transition:transform .3s var(--ease), box-shadow .3s; }
.info-card:hover{ transform:translateY(-4px); box-shadow:0 24px 50px -38px rgba(19,138,134,.5); }
.info-card__tag{ align-self:flex-start; display:inline-flex; align-items:center; gap:6px; background:#fff; color:var(--teal); font-size:11px; font-weight:500; letter-spacing:.06em; padding:5px 12px; border-radius:999px; }
.info-card__tag .ic{ font-size:12px; }
.info-card h3{ font-size:17px; font-weight:500; letter-spacing:.04em; color:var(--teal-d); }
.info-card p{ font-size:13px; line-height:1.9; color:var(--muted); }

/* =========================================================
   CTA BAND
   ========================================================= */
.cta-band{ position:relative; overflow:hidden; background:var(--teal); }
.cta-band__bg{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.14; pointer-events:none; }
.cta-band__veil{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(15,110,106,.9), rgba(19,49,58,.95)); }
.cta-band__inner{ position:relative; max-width:1000px; margin:0 auto; padding:110px 40px; text-align:center; }
.cta-band__eyebrow{ margin-bottom:14px; font-size:12px; letter-spacing:.34em; color:var(--teal-soft); }
.cta-band__title{ margin-bottom:54px; font-size:30px; font-weight:500; letter-spacing:.12em; line-height:1.6; color:#fff; }
.cta-band__grid{ display:grid; grid-template-columns:1fr 1fr; max-width:760px; margin:0 auto; border:1px solid rgba(197,220,217,.4); }
.cta-opt{ display:flex; flex-direction:column; align-items:center; gap:14px; padding:46px 24px; text-decoration:none; transition:background .35s; }
.cta-opt:hover{ background:rgba(255,255,255,.06); }
.cta-opt:first-child{ border-right:1px solid rgba(197,220,217,.4); }
.cta-opt__icon{ display:grid; place-items:center; width:58px; height:58px; border-radius:50%; border:1px solid rgba(197,220,217,.6); color:#fff; }
.cta-opt__icon .ic{ font-size:24px; }
.cta-opt__sub{ display:block; font-size:11.5px; letter-spacing:.14em; color:var(--teal-soft); }
.cta-opt__main{ display:block; font-size:18px; font-weight:500; letter-spacing:.08em; color:#fff; }
.cta-opt__num{ display:block; font-size:22px; font-weight:700; letter-spacing:.04em; color:#fff; }
.cta-opt__note{ display:block; font-size:11px; color:var(--teal-soft); margin-top:2px; }

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{ background:var(--teal-d); color:#fff; padding:80px 40px 36px; }
.site-footer__inner{ max-width:1180px; margin:0 auto; display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:40px; }
.site-footer__logo{ display:inline-flex; align-items:center; background:#fff; border-radius:14px; padding:11px 16px; margin-bottom:20px; }
.site-footer__logo img{ height:40px; width:auto; }
.site-footer__addr{ margin-bottom:18px; font-size:12.5px; line-height:2; color:var(--muted-2); letter-spacing:.04em; }
.site-footer__tel{ display:inline-flex; align-items:center; gap:10px; text-decoration:none; color:#fff; }
.site-footer__tel .ic{ font-size:20px; color:var(--orange); }
.site-footer__tel span{ font-size:22px; font-weight:700; letter-spacing:.02em; }
.footer-col h4{ margin:0 0 16px; font-size:11px; font-weight:500; letter-spacing:.2em; color:var(--teal-soft); }
.footer-col div{ display:flex; flex-direction:column; gap:11px; }
.footer-col a{ font-size:12.5px; color:rgba(197,220,217,.85); text-decoration:none; letter-spacing:.04em; transition:color .3s; }
.footer-col a:hover{ color:#fff; }
.site-footer__bottom{ max-width:1180px; margin:48px auto 0; padding-top:24px; border-top:1px solid rgba(157,190,187,.25); display:flex; align-items:center; justify-content:space-between; gap:16px; }
.site-footer__bottom-links{ display:flex; gap:22px; }
.site-footer__bottom-links a{ font-size:11.5px; color:var(--muted-2); text-decoration:none; letter-spacing:.06em; }
.site-footer__copy{ font-size:11px; color:var(--teal-soft); letter-spacing:.06em; }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1024px){
  .section{ padding:72px 22px; }
  .container{ padding:0 22px; }

  .site-header{ position:static; }
  .site-header__inner{ height:62px; padding:0 20px; gap:0; }
  .site-header__logo img{ height:38px; }
  .gnav, .header-actions{ display:none; }
  .hamburger{ display:grid; opacity:0; visibility:hidden; transform:translateY(-16px) scale(.9); pointer-events:none; }
  .hamburger.is-stuck, .hamburger.is-open{ opacity:1; visibility:visible; transform:none; pointer-events:auto; }

  .m-quick{ display:block; padding:22px 20px 8px; }
  .m-quick__lead{ text-align:center; font-size:18px; font-weight:500; letter-spacing:.04em; color:var(--teal-d); margin-bottom:16px; }
  .m-quick__lead small{ display:block; font-size:12px; font-weight:400; letter-spacing:.06em; color:var(--muted); margin-bottom:5px; }
  .m-quick__tel{ display:flex; align-items:center; justify-content:center; gap:12px; min-height:64px; border-radius:16px; background:var(--teal); text-decoration:none; margin-bottom:10px; box-shadow:0 16px 30px -22px rgba(19,138,134,.85); }
  .m-quick__tel .ic{ font-size:26px; color:#fff; }
  .m-quick__tel .mq-label{ display:block; font-size:11px; letter-spacing:.08em; color:var(--teal-soft); }
  .m-quick__tel .mq-num{ display:block; font-size:24px; font-weight:900; letter-spacing:.02em; color:#fff; }
  .m-quick__row{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
  .m-quick__btn{ display:flex; align-items:center; justify-content:center; gap:8px; min-height:54px; border-radius:14px; text-decoration:none; font-size:14px; font-weight:700; letter-spacing:.02em; background:#fff; transition:transform .3s var(--ease); }
  .m-quick__btn .ic{ font-size:18px; }
  .m-quick__btn:active{ transform:scale(.97); }
  .m-quick__btn--access{ border:1.5px solid var(--teal-soft); color:var(--teal); }
  .m-quick__btn--contact{ border:1.5px solid var(--orange); color:var(--orange-d); }

  .heading{ font-size:23px; letter-spacing:.06em; }
  .lead-center{ margin-bottom:38px; }

  .hero-mosaic{ grid-template-columns:1fr 1fr; grid-template-rows:220px 220px; height:440px; }
  .hero-img:nth-child(4), .hero-img:nth-child(5){ display:none; }
  .hero-img:nth-child(1){ grid-column:1; grid-row:1; }
  .hero-img:nth-child(2){ grid-column:1; grid-row:2; }
  .hero-img:nth-child(3){ grid-column:2; grid-row:1 / 3; }
  .hero-title{ font-size:74px; }
  .hero-sub{ font-size:14px; letter-spacing:.2em; }
  .hero-eyebrow{ font-size:10px; letter-spacing:.42em; }

  .ribbon__inner{ padding:13px 22px; gap:14px; }
  .ribbon__sep, .ribbon__news{ display:none; }

  .intro{ padding:72px 22px 64px; }
  .intro__title{ font-size:25px; line-height:1.7; }
  .intro__text{ font-size:14px; line-height:2.2; }
  .intro__deco{ width:90%; }

  .status-card{ grid-template-columns:1fr; border-radius:20px; }
  .status-now{ padding:36px 24px; border-right:none; border-bottom:1px solid var(--line); }
  .status-now__badge .ic, .status-now__badge span{ font-size:38px; }
  .calendar{ padding:30px 24px; }
  .calendar__legend{ gap:12px; }

  .services__inner{ grid-template-columns:1fr; gap:34px; }
  .services__head{ flex-direction:column; gap:10px; align-items:flex-start; }
  .services__head-ja{ writing-mode:horizontal-tb; height:auto; font-size:25px; line-height:1.6; letter-spacing:.08em; }
  .services__head-ja br{ display:none; }
  .services__head-en{ writing-mode:horizontal-tb; padding-top:0; }
  .services__grid{ grid-template-columns:1fr 1fr; column-gap:24px; row-gap:32px; }
  .service{ flex-direction:column; gap:12px; }
  .service__icon{ width:58px; height:58px; }
  .service__icon .ic{ font-size:28px; }
  .service__title{ font-size:15px; }
  .services__more{ justify-content:flex-start; margin-top:34px; }

  .reasons__grid{ grid-template-columns:1fr 1fr; gap:30px 22px; }
  .reason__icon{ width:74px; height:74px; }
  .reason__icon .ic{ font-size:34px; }
  .staff{ margin-top:60px; grid-template-columns:1fr; gap:30px; }
  .staff__title{ font-size:22px; }

  .works__head{ flex-direction:column; align-items:flex-start; gap:18px; margin-bottom:34px; }
  .works__grid{ grid-template-columns:1fr 1fr; gap:18px; }
  .work__title{ font-size:13px; }

  .voices__grid{ grid-template-columns:1fr 1fr; gap:16px; }

  .showroom__top{ grid-template-columns:1fr; gap:16px; }
  .showroom__detail{ grid-template-columns:1fr; gap:34px; }
  .hours-table{ grid-template-columns:72px repeat(7,1fr); }
  .showroom__tel span{ font-size:23px; }

  .info{ padding:64px 22px; }
  .info__grid{ grid-template-columns:1fr; gap:14px; }

  .cta-band__inner{ padding:64px 22px; }
  .cta-band__title{ font-size:23px; margin-bottom:34px; }
  .cta-band__grid{ grid-template-columns:1fr; }
  .cta-opt:first-child{ border-right:none; border-bottom:1px solid rgba(197,220,217,.4); }
  .cta-opt{ padding:34px 24px; }

  .site-footer{ padding:56px 22px 28px; }
  .site-footer__inner{ grid-template-columns:1fr 1fr; gap:34px 24px; }
  .site-footer__col--brand{ grid-column:1 / -1; }
  .site-footer__bottom{ flex-direction:column; align-items:flex-start; gap:14px; margin-top:34px; }
}

@media (max-width:560px){
  .hero-title{ font-size:58px; }
  .services__grid{ grid-template-columns:1fr; }
  .works__grid{ grid-template-columns:1fr 1fr; }
  .reasons__grid{ grid-template-columns:1fr 1fr; }
  .voices__grid{ grid-template-columns:1fr; }
  .status-now__btns{ flex-direction:column; }
  .status-now__btns .btn-pill{ width:100%; justify-content:center; }
  .calendar{ padding:24px 14px; }
  .cal-cell{ height:34px; font-size:13px; }
}

@media (prefers-reduced-motion:reduce){
  html{ scroll-behavior:auto; }
  .reveal{ opacity:1; transform:none; transition:none; }
  .hero-eyebrow,.hero-title,.hero-sub,.hero-img:nth-child(3) img{ animation:none; }
}
