/* =========================================================
   松本電工 TOPページ  ―  スタイルシート
   元: ClaudeDesign プロトタイプ（余白版 / モバイル版）を
   静的サイト用にクラスベースで再構築
   ========================================================= */

:root{
  --navy:#003072; --navy-d:#001B45; --navy-m:#00245A;
  --ink:#1B3C5E; --ink-2:#2A4A73;
  --muted:#56738F; --muted-2:#9DB4CE; --muted-3:#7A93B2;
  --line:#ECF2F8; --line-2:#E3EDF7;
  --blue:#5B8FD4; --blue-2:#3E6BA0; --blue-soft:#C7DDF6;
  --bg:#ffffff; --bg-soft:#F6FAFD;
  --orange:#F86600; --orange-d:#E25600;
  --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; }

.container{ max-width:var(--maxw); margin:0 auto; padding:0 40px; }
.section{ padding:130px 40px; }
.section--soft{ background:var(--bg-soft); }
.eyebrow{ font-size:12px; letter-spacing:.34em; color:var(--blue); }
.heading{ font-size:30px; font-weight:500; letter-spacing:.1em; color:var(--navy); }
.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); } }

/* ---------- scroll reveal ---------- */
.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 40px; height:84px; display:flex; align-items:center; gap:36px; }
.site-header__logo{ display:inline-flex; align-items:center; text-decoration:none; }
.site-header__logo img{ height:50px; width:auto; }

.gnav{ margin-left:14px; display:flex; align-items:center; gap:30px; }
.gnav a{ position:relative; font-size:14px; font-weight:500; letter-spacing:.06em; 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(--navy); }
.gnav a:hover::after{ width:100%; }

.header-actions{ margin-left:auto; display:flex; align-items:center; gap:26px; }
.header-ico{ display:flex; flex-direction:column; align-items:center; gap:5px; text-decoration:none; transition:transform .3s var(--ease); }
.header-ico:hover{ transform:translateY(-2px); }
.header-ico span{ font-size:10.5px; letter-spacing:.1em; color:var(--blue-2); }
.header-tel{ display:flex; align-items:center; gap:9px; text-decoration:none; padding-left:24px; border-left:1px solid var(--line); }
.header-tel__num{ display:block; font-size:21px; font-weight:700; color:var(--navy); letter-spacing:.02em; }
.header-tel__sub{ display:block; font-size:10px; color:var(--muted-2); letter-spacing:.04em; }
.header-cta{ display:inline-flex; align-items:center; height:46px; padding:0 22px; border-radius:999px; background:var(--orange); color:#fff; font-weight:500; font-size:13.5px; letter-spacing:.06em; text-decoration:none; transition:transform .3s var(--ease), box-shadow .3s; }
.header-cta:hover{ transform:translateY(-2px); box-shadow:0 12px 26px -12px rgba(248,102,0,.65); }

/* hamburger (mobile only) ― うさぎMENUアイコン */
.hamburger{ display:none; place-items:center; position:fixed; top:14px; right:14px; z-index:120; width:62px; height:62px; border:none; border-radius:18px; background:#ffffff; box-shadow:0 10px 26px -12px rgba(0,48,114,.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__icon{ width:48px; height:48px; object-fit:contain; transition:opacity .3s ease, transform .45s var(--ease); }
.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(--navy); }
.hamburger.is-open .hamburger__icon{ opacity:0; transform:scale(.5) rotate(-20deg); }
.hamburger.is-open .hamburger__close{ opacity:1; transform:scale(1); }

/* mobile quick contact（ヒーロー直下の電話・アクセス・問い合わせ導線） */
.m-quick{ display:none; }

/* mobile menu overlay */
.mobile-menu{ position:fixed; inset:0; z-index:110; background:linear-gradient(165deg,#00306f 0%,#00245A 55%,#001B45 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; flex:0 0 auto; display:flex; flex-direction:column; justify-content:flex-start; 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(199,221,246,.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(--blue); min-width:30px; }
.mobile-menu__ja{ font-size:23px; font-weight:500; letter-spacing:.08em; }
.mobile-menu__en{ margin-left:auto; align-self:center; font-size:10.5px; letter-spacing:.22em; color:rgba(199,221,246,.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); }
.mobile-menu__foot-h{ margin:0 0 14px; font-size:12px; font-weight:600; letter-spacing:.22em; color:var(--blue-soft); }
.mm-card{ display:flex; text-decoration:none; color:#fff; border:1px solid rgba(199,221,246,.45); border-radius:18px; background:rgba(255,255,255,.04); transition:transform .3s var(--ease), background .3s, border-color .3s; }
.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(199,221,246,.55); display:grid; place-items:center; }
/* 電話: 横並びで番号を大きく */
.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(--blue-soft); }
.mm-card__num{ font-size:30px; font-weight:900; letter-spacing:.01em; 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:15.5px; font-weight:700; letter-spacing:.04em; line-height:1.35; }
.mm-card__en{ font-size:10px; letter-spacing:.2em; color:rgba(199,221,246,.55); }
.mm-card--contact{ border-color:rgba(248,102,0,.7); background:rgba(248,102,0,.14); }
.mm-card--contact .mm-card__ico{ border-color:rgba(248,150,80,.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; }
@keyframes heroZoom{ from{ transform:scale(1.08); } to{ transform:scale(1); } }
.hero-overlay{ position:absolute; inset:0; pointer-events:none; background:radial-gradient(60% 60% at 50% 50%, rgba(0,24,58,.42), rgba(0,24,58,.12) 70%, rgba(0,24,58,0) 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,54,.85),0 1px 3px rgba(0,22,54,.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:128px; line-height:1; color:#fff; letter-spacing:.01em; text-shadow:0 8px 28px rgba(0,22,54,.7),0 2px 6px rgba(0,22,54,.8); animation:heroUp 1.1s var(--ease) both .36s; }
.hero-sub{ margin-top:6px; font-size:17px; letter-spacing:.32em; color:#fff; font-weight:600; text-shadow:0 2px 10px rgba(0,22,54,.9),0 1px 3px rgba(0,22,54,.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__dot{ width:8px; height:8px; border-radius:50%; background:var(--orange); box-shadow:0 0 0 4px rgba(248,102,0,.14); }
.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); }

/* =========================================================
   INTRO
   ========================================================= */
.intro{ padding:128px 40px 120px; position:relative; overflow:hidden; }
.intro__deco{ position:absolute; left:0; top:40px; width:60%; height:360px; opacity:.5; 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(--blue-soft); }
.intro__tag span:nth-child(2){ font-size:12px; letter-spacing:.34em; color:var(--blue); }
.intro__title{ font-size:38px; line-height:1.7; font-weight:500; letter-spacing:.06em; color:var(--navy); }
.intro__text{ margin:34px auto 0; max-width:640px; font-size:15px; line-height:2.4; letter-spacing:.04em; color:var(--muted); }
.intro__float{ position:absolute; right:8%; bottom:40px; width:78px; height:auto; opacity:.95; animation:mdFloatY 4.5s ease-in-out infinite; pointer-events:none; }

/* =========================================================
   STATUS + CALENDAR
   ========================================================= */
.status-card{ background:#fff; border-radius:24px; box-shadow:0 30px 60px -40px rgba(0,48,114,.25); 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:16px; margin-top:20px; }
.status-now__badge span{ font-size:46px; font-weight:500; color:var(--orange); letter-spacing:.14em; }
.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--orange{ background:var(--orange); color:#fff; }
.btn-pill--orange:hover{ transform:translateY(-2px); box-shadow:0 12px 26px -12px rgba(248,102,0,.65); }
.btn-pill--outline{ border:1px solid var(--blue-soft); color:var(--navy); }
.btn-pill--outline:hover{ transform:translateY(-2px); box-shadow:0 12px 26px -16px rgba(0,48,114,.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(--navy); 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--am{ box-shadow:inset 0 0 0 1.5px var(--blue-soft); }
.lg-dot--off{ background:#F3E3DB; }
.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; }
.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--am{ color:var(--blue-2); box-shadow:inset 0 0 0 1.5px var(--blue-soft); }
.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:34px; font-weight:500; letter-spacing:.18em; line-height:1.9; color:var(--navy); height:420px; }
.services__head-en{ writing-mode:vertical-rl; padding-top:4px; font-size:11px; letter-spacing:.3em; color:var(--blue); }
.services__grid{ display:grid; grid-template-columns:1fr 1fr; column-gap:56px; row-gap:46px; }
.service{ display:flex; gap:22px; 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); transition:border-color .3s, transform .3s var(--ease); }
.service:hover .service__icon{ border-color:var(--blue-soft); transform:translateY(-3px); }
.service__title{ margin:6px 0 8px; font-size:17px; font-weight:500; letter-spacing:.06em; color:var(--navy); }
.service__desc{ font-size:13px; line-height:2; color:var(--muted); }
.services__more{ display:flex; justify-content:flex-end; margin-top:48px; }
.link-arrow{ display:inline-flex; align-items:center; gap:14px; text-decoration:none; color:var(--navy); font-size:14px; letter-spacing:.08em; }
.link-arrow__circle{ display:grid; place-items:center; width:42px; height:42px; border-radius:50%; background:var(--navy); transition:transform .3s var(--ease); }
.link-arrow:hover .link-arrow__circle{ transform:translateX(4px); }
.link-arrow--outline .link-arrow__circle{ background:#fff; border:1px solid var(--blue-soft); }

/* =========================================================
   REASONS + STAFF
   ========================================================= */
.reasons{ position:relative; overflow:hidden; }
.reasons__deco{ position:absolute; right:0; bottom:60px; width:55%; height:280px; opacity:.55; 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(0,48,114,.4); margin-bottom:22px; transition:transform .35s var(--ease); }
.reason:hover .reason__icon{ transform:translateY(-4px); }
.reason__title{ margin-bottom:12px; font-size:17px; font-weight:500; letter-spacing:.08em; color:var(--navy); }
.reason__desc{ font-size:13px; line-height:2; color:var(--muted); }
.staff{ margin-top:104px; display:grid; grid-template-columns:1.15fr 1fr; gap:64px; align-items:center; }
.staff__photo{ border-radius:6px; overflow:hidden; box-shadow:0 40px 70px -45px rgba(0,48,114,.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(--blue); }
.staff__title{ margin-bottom:26px; font-size:27px; font-weight:500; letter-spacing:.08em; line-height:1.7; color:var(--navy); }
.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:54px; }
.works__pager{ display:flex; align-items:center; gap:22px; padding-bottom:6px; }
.works__pager > span:nth-child(1){ font-size:15px; letter-spacing:.1em; color:var(--navy); }
.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(--blue-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%; }
.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(--navy); font-size:11px; letter-spacing:.08em; 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__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:60px; }
.btn-outline-lg{ display:inline-flex; align-items:center; gap:16px; min-height:58px; padding:0 40px; border-radius:999px; border:1px solid var(--blue-soft); text-decoration:none; color:var(--navy); font-size:14px; letter-spacing:.1em; transition:background .3s, transform .3s var(--ease); }
.btn-outline-lg:hover{ background:var(--bg-soft); transform:translateY(-2px); }

/* =========================================================
   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(0,48,114,.5); }
.showroom__photo img{ width:100%; height:100%; object-fit:cover; max-height:340px; }
.showroom__map{ position:relative; border-radius:6px; overflow:hidden; background:#E8F1FB; min-height:300px; border:1px solid #DCEBFB; }
.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 span{ display:block; margin-top:2px; font-size:11px; font-weight:500; color:var(--navy); background:#fff; padding:3px 10px; border-radius:6px; box-shadow:0 4px 14px rgba(0,48,114,.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:#C98A6A; }
.hours-table .ht-time{ font-size:12px; color:var(--muted-3); }
.hours-table .ht-on{ text-align:center; color:var(--blue-2); }
.hours-table .ht-off{ text-align:center; color:#D6C0B4; }
.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(--navy); }
.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(--blue-2); text-decoration:none; letter-spacing:.04em; }
.showroom__addr .a-access{ font-size:13.5px; line-height:2; color:var(--muted); }

/* =========================================================
   CERTIFICATION
   ========================================================= */
.cert{ padding:96px 40px; }
.cert__inner{ max-width:980px; margin:0 auto; text-align:center; }
.cert__eyebrow{ margin-bottom:38px; font-size:12px; letter-spacing:.34em; color:var(--blue); }
.cert__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.cert__item{ padding:0 14px; }
.cert__item + .cert__item{ border-left:1px solid var(--line); }
.cert__item svg{ margin-bottom:16px; }
.cert__item .c-ttl{ font-size:14px; font-weight:500; color:var(--navy); letter-spacing:.04em; }
.cert__item .c-sub{ margin-top:6px; font-size:11px; color:var(--muted-2); line-height:1.7; }

/* =========================================================
   CTA BAND
   ========================================================= */
.cta-band{ position:relative; overflow:hidden; background:var(--navy); }
.cta-band__bg{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.12; pointer-events:none; }
.cta-band__veil{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,36,90,.92), rgba(0,27,69,.96)); }
.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(--muted-2); }
.cta-band__title{ margin-bottom:56px; 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(157,180,206,.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,.05); }
.cta-opt:first-child{ border-right:1px solid rgba(157,180,206,.4); }
.cta-opt__icon{ display:grid; place-items:center; width:58px; height:58px; border-radius:50%; border:1px solid rgba(157,180,206,.6); }
.cta-opt__sub{ display:block; font-size:11.5px; letter-spacing:.14em; color:var(--muted-2); }
.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(--muted-2); margin-top:2px; }

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{ background:var(--navy-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:12px 18px; margin-bottom:20px; }
.site-footer__logo img{ height:44px; 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 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(--blue); }
.footer-col div{ display:flex; flex-direction:column; gap:11px; }
.footer-col a{ font-size:12.5px; color:var(--blue-soft); 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(91,143,212,.25); display:flex; align-items:center; justify-content:space-between; gap:16px; }
.site-footer__bottom-links{ display:flex; gap:24px; }
.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(--blue); letter-spacing:.06em; }

/* =========================================================
   下部固定CTA（電話・問い合わせ）
   ※ 現在は非表示。復活させる場合は body から
      class を付けず、HTML側のコメントを解除してください。
   ========================================================= */
.bottom-cta{ position:fixed; bottom:0; left:50%; transform:translateX(-50%); width:100%; max-width:430px; z-index:90; display:grid; grid-template-columns:1fr 1fr; box-shadow:0 -8px 24px -10px rgba(0,30,72,.3); }
.bottom-cta a{ display:flex; align-items:center; justify-content:center; gap:9px; min-height:64px; text-decoration:none; }
.bottom-cta__tel{ background:var(--navy); }
.bottom-cta__form{ background:var(--orange); }
.bottom-cta span{ line-height:1.15; color:#fff; text-align:left; }
.bottom-cta .l-sub{ display:block; font-size:10px; }
.bottom-cta .l-main{ display:block; font-size:16px; font-weight:900; }

/* =========================================================
   RESPONSIVE  ―  タブレット / モバイル
   ========================================================= */
@media (max-width:900px){
  .section{ padding:72px 22px; }
  .container{ padding:0 22px; }

  /* header: ロゴは固定しない（一緒にスクロールして消える） */
  .site-header{ position:static; }
  .site-header__inner{ height:64px; padding:0 20px; gap:0; }
  .site-header__logo img{ height:40px; }
  .gnav, .header-actions{ display:none; }
  /* うさぎMENUボタン: 最上部では非表示、スクロールで固定表示 */
  .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(--navy); 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(--navy); text-decoration:none; margin-bottom:10px; box-shadow:0 16px 30px -22px rgba(0,48,114,.8); }
  .m-quick__tel .mq-label{ display:block; font-size:11px; letter-spacing:.08em; color:var(--blue-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), box-shadow .3s; }
  .m-quick__btn:active{ transform:scale(.97); }
  .m-quick__btn--access{ border:1.5px solid var(--blue-soft); color:var(--navy); }
  .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 → モバイル: 写真3枚 */
  .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:.22em; }
  .hero-eyebrow{ font-size:10px; letter-spacing:.42em; }

  /* ribbon: ニュースは隠してステータスのみ */
  .ribbon__inner{ padding:13px 22px; gap:14px; }
  .ribbon__sep, .ribbon__news{ display:none; }

  /* intro */
  .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%; }
  .intro__float{ width:58px; right:5%; bottom:14px; }

  /* status + calendar → 縦積み */
  .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 span{ font-size:38px; }
  .calendar{ padding:30px 24px; }
  .calendar__legend{ gap:12px; }

  /* services → 見出しを横組みに */
  .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__title{ font-size:15px; }
  .services__more{ justify-content:flex-start; margin-top:34px; }

  /* reasons → 2列 / staff 縦積み */
  .reasons__grid{ grid-template-columns:1fr 1fr; gap:30px 22px; }
  .reason__icon{ width:74px; height:74px; }
  .staff{ margin-top:60px; grid-template-columns:1fr; gap:30px; }
  .staff__title{ font-size:22px; }

  /* works → 2列 */
  .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; }

  /* showroom → 縦積み */
  .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; }

  /* certification → 2列 */
  .cert{ padding:64px 22px; }
  .cert__grid{ grid-template-columns:1fr 1fr; gap:32px 20px; }
  .cert__item + .cert__item{ border-left:none; }
  .cert__item:nth-child(2n){ border-left:1px solid var(--line); }

  /* cta band */
  .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(157,180,206,.4); }
  .cta-opt{ padding:34px 24px; }

  /* footer → 縦積み */
  .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:60px; }
  .services__grid{ grid-template-columns:1fr; }
  .works__grid{ grid-template-columns:1fr 1fr; }
  .reasons__grid{ grid-template-columns:1fr 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,.intro__float{ animation:none; }
}
