/* =========================================================
   古谷石油（こやせきゆ）公式サイト 共通スタイル
   - index.html および service/*.html で共通利用
   - ブランドカラー：オレンジ #ee7320 厳守
   ========================================================= */

/* Cross-Document View Transitions（Chrome 126+/Safari 18.2+/Edge 126+対応・Firefoxフォールバック無害）*/
@view-transition {
  navigation: auto;
}

:root{
  --orange:#ee7320;
  --orange-d:#d35f12;
  --orange-l:#fff3e8;
  --ink:#20242a;
  --ink2:#3a4048;
  --gray:#64707c;
  --line:#ecebe6;
  --bg:#fbfaf7;
  --navy:#28303a;
  --navy-2:#333c47;
  --navy-3:#424c58;
  --charcoal:var(--navy);
  --jp:"Noto Sans JP","Zen Kaku Gothic New",-apple-system,sans-serif;
  --en:"Oswald","Archivo",sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:var(--jp);color:var(--ink);background:#fff;line-height:1.85;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
.wrap{max-width:1080px;margin:0 auto;padding:0 24px;}
.en{font-family:var(--en);letter-spacing:.04em;}

/* プレースホルダー（画像未配置時のフォールバック） */
.ph{position:relative;background:linear-gradient(135deg,#e4e2db,#f2f0ea);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.ph::after{content:attr(data-label);font-size:12px;color:#9a9488;letter-spacing:.1em;}
.ph.dark{background:linear-gradient(135deg,var(--navy-2),#202832);}
.ph.dark::after{color:rgba(255,255,255,.4);}

/* ========== ヘッダー ========== */
header{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(255,255,255,.55);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border-bottom:1px solid rgba(255,255,255,.3);transition:background .3s,backdrop-filter .3s;}
header.scrolled{background:rgba(255,255,255,.92);border-bottom:1px solid var(--line);}
.hd{display:flex;align-items:center;justify-content:space-between;height:68px;}
.logo{display:flex;align-items:center;gap:10px;font-weight:900;color:var(--ink);}
.logo .mk{width:42px;height:42px;background:url('/icons/icon-192.png') center/cover no-repeat;border-radius:50%;color:transparent;font-size:0;display:inline-block;flex-shrink:0;}
.logo-copy{display:flex;flex-direction:column;justify-content:center;line-height:1.15;min-width:0;}
.logo-main{font-size:21px;font-weight:900;letter-spacing:0;}
.logo-sub{margin-top:3px;font-size:11px;font-weight:800;color:var(--orange-d);letter-spacing:.03em;white-space:nowrap;}
nav ul{display:flex;gap:26px;list-style:none;align-items:center;font-size:14px;font-weight:500;}
nav li{position:relative;}
nav a:hover{color:var(--orange);}
.nav-line{background:#06c755;color:#fff!important;padding:9px 18px;border-radius:8px;font-weight:700;font-size:13px;}
.nav-line:hover{background:#05b34d;}
.nav-service-trigger{display:inline-flex;align-items:center;gap:6px;}
.nav-service-trigger::after{content:"";width:6px;height:6px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translateY(-2px);opacity:.55;transition:.2s;}
.nav-service:hover .nav-service-trigger::after,.nav-service:focus-within .nav-service-trigger::after{transform:rotate(225deg) translateY(-1px);opacity:1;}
.service-menu{position:absolute;top:calc(100% + 16px);left:50%;width:400px;display:grid;grid-template-columns:1fr 1fr;gap:4px;padding:14px;background:rgba(255,255,255,.96);border:1px solid rgba(32,36,42,.1);border-radius:12px;box-shadow:0 22px 55px rgba(32,36,42,.16);backdrop-filter:blur(18px) saturate(180%);-webkit-backdrop-filter:blur(18px) saturate(180%);opacity:0;visibility:hidden;pointer-events:none;transform:translate(-50%,8px);transition:opacity .18s ease,transform .18s ease,visibility .18s ease;z-index:130;}
.service-menu::before{content:"";position:absolute;left:0;right:0;top:-18px;height:18px;}
.service-menu a{display:flex;align-items:center;gap:9px;min-height:42px;padding:10px 12px;border-radius:8px;color:var(--ink);font-size:13px;font-weight:800;line-height:1.35;white-space:normal;}
.service-menu a span{font-family:var(--en);font-size:11px;font-weight:800;color:var(--orange);letter-spacing:.08em;flex:0 0 auto;}
.service-menu a:hover,.service-menu a:focus{background:var(--orange-l);color:var(--orange-d);}
.nav-service:hover .service-menu,.nav-service:focus-within .service-menu{opacity:1;visibility:visible;pointer-events:auto;transform:translate(-50%,0);}
.mobile-menu-toggle,.mobile-menu-panel,.mobile-menu-backdrop{display:none;}

/* ========== ヒーロー ========== */
.hero{position:relative;min-height:90vh;display:flex;align-items:center;color:#fff;overflow:hidden;}
.hero .ph{position:absolute;inset:0;}
.hero .ph picture{width:100%;height:100%;display:block;}
.hero .ph img{width:100%;height:100%;object-fit:cover;display:block;}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(14,18,24,.68) 0%,rgba(14,18,24,.48) 44%,rgba(14,18,24,.16) 76%,rgba(14,18,24,.06) 100%),linear-gradient(180deg,rgba(0,0,0,.08) 0%,rgba(0,0,0,.12) 54%,rgba(0,0,0,.32) 100%);z-index:1;}
.hero-in{position:relative;z-index:2;width:100%;transform:translateY(clamp(150px,20vh,230px));}
.hero .eyebrow{font-family:var(--en);font-size:13px;letter-spacing:.25em;color:var(--orange);font-weight:800;margin-bottom:18px;opacity:0;animation:up .8s .2s forwards;}
.hero h1{font-size:clamp(32px,5.6vw,60px);font-weight:900;line-height:1.28;margin-bottom:14px;opacity:0;animation:up .8s .4s forwards;text-wrap:balance;text-shadow:0 2px 0 rgba(0,0,0,.16),0 10px 30px rgba(0,0,0,.62),0 0 1px rgba(0,0,0,.75);}
.hero h1 .ac{display:inline-block;color:var(--orange);text-shadow:0 2px 0 rgba(0,0,0,.16),0 10px 30px rgba(0,0,0,.7),0 0 1px rgba(0,0,0,.8);}
.hero .catch{font-size:clamp(16px,2.2vw,22px);font-weight:700;margin-bottom:18px;opacity:0;animation:up .8s .55s forwards;}
.hero .catch .q{color:rgba(255,255,255,.78);font-size:.82em;}
.hero p{max-width:1380px;font-size:clamp(16px,1.05vw,17px);font-weight:700;line-height:1.7;color:rgba(255,255,255,.92);margin-bottom:34px;opacity:0;animation:up .8s .7s forwards;}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;opacity:0;animation:up .8s .85s forwards;}
.btn{position:relative;isolation:isolate;overflow:hidden;padding:15px 28px;border-radius:12px;font-weight:900;font-size:15px;transition:transform .22s ease,box-shadow .22s ease,filter .22s ease;display:inline-flex;align-items:center;justify-content:center;gap:10px;border:1px solid rgba(255,255,255,.18);letter-spacing:.02em;box-shadow:0 14px 32px rgba(0,0,0,.18),inset 0 1px 0 rgba(255,255,255,.25);}
.btn::after{content:"";position:absolute;inset:1px;border-radius:inherit;background:linear-gradient(180deg,rgba(255,255,255,.26),rgba(255,255,255,0) 46%);pointer-events:none;z-index:-1;}
.btn:hover{transform:translateY(-2px);filter:saturate(1.04);}
.btn-line{background:linear-gradient(135deg,#05af4d 0%,#06c755 52%,#18df70 100%);color:#fff;border-color:rgba(255,255,255,.22);box-shadow:0 16px 34px rgba(6,199,85,.34),0 6px 16px rgba(0,0,0,.14),inset 0 1px 0 rgba(255,255,255,.34);}
.btn-line::before{content:"LINE";display:inline-flex;align-items:center;justify-content:center;height:24px;min-width:38px;padding:0 8px;border-radius:999px;background:rgba(255,255,255,.92);color:#06a84b;font-family:var(--en);font-size:10px;font-weight:900;letter-spacing:.05em;box-shadow:0 4px 10px rgba(0,0,0,.12);}
.btn-line:hover{background:linear-gradient(135deg,#04a846 0%,#08cc58 52%,#25e978 100%);box-shadow:0 20px 42px rgba(6,199,85,.4),0 8px 18px rgba(0,0,0,.18),inset 0 1px 0 rgba(255,255,255,.36);}
.btn-orange,.btn-tel{background:linear-gradient(135deg,#d96114 0%,#ee7320 50%,#ff9840 100%);color:#fff;border-color:rgba(255,255,255,.2);box-shadow:0 16px 34px rgba(238,115,32,.32),0 6px 16px rgba(0,0,0,.14),inset 0 1px 0 rgba(255,255,255,.32);}
.btn-orange:hover,.btn-tel:hover{background:linear-gradient(135deg,#c95710 0%,#e96d1b 52%,#ff8e32 100%);box-shadow:0 20px 42px rgba(238,115,32,.38),0 8px 18px rgba(0,0,0,.18),inset 0 1px 0 rgba(255,255,255,.34);}
a[href^="tel:"].btn::before{content:"";width:18px;height:18px;flex:0 0 18px;background:currentColor;opacity:.95;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M6.62 10.79c1.44 2.83 3.76 5.15 6.59 6.59l2.2-2.2c.27-.27.67-.36 1.02-.24 1.12.37 2.33.57 3.57.57.55 0 1 .45 1 1V20c0 .55-.45 1-1 1C10.61 21 3 13.39 3 4c0-.55.45-1 1-1h3.5c.55 0 1 .45 1 1 0 1.24.2 2.45.57 3.57.11.35.03.74-.25 1.02l-2.2 2.2z'/%3E%3C/svg%3E") center/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M6.62 10.79c1.44 2.83 3.76 5.15 6.59 6.59l2.2-2.2c.27-.27.67-.36 1.02-.24 1.12.37 2.33.57 3.57.57.55 0 1 .45 1 1V20c0 .55-.45 1-1 1C10.61 21 3 13.39 3 4c0-.55.45-1 1-1h3.5c.55 0 1 .45 1 1 0 1.24.2 2.45.57 3.57.11.35.03.74-.25 1.02l-2.2 2.2z'/%3E%3C/svg%3E") center/contain no-repeat;}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.4);}
.btn-ghost:hover{background:rgba(255,255,255,.22);}
.hero-service-toggle{position:relative;display:inline-flex;}
.hero-service-trigger{padding-right:24px;}
.hero-service-trigger::after{content:"";width:6px;height:6px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translateY(-2px);opacity:.75;transition:.2s;}
.hero-service-toggle:hover .hero-service-trigger::after,.hero-service-toggle:focus-within .hero-service-trigger::after{transform:rotate(225deg) translateY(-1px);opacity:1;}
.hero-service-menu{position:absolute;top:calc(100% + 14px);right:0;width:420px;display:grid;grid-template-columns:1fr 1fr;gap:5px;padding:14px;background:rgba(255,255,255,.96);border:1px solid rgba(255,255,255,.38);border-radius:12px;box-shadow:0 22px 60px rgba(0,0,0,.32);backdrop-filter:blur(18px) saturate(180%);-webkit-backdrop-filter:blur(18px) saturate(180%);opacity:0;visibility:hidden;pointer-events:none;transform:translateY(8px);transition:opacity .18s ease,transform .18s ease,visibility .18s ease;z-index:20;}
.hero-service-menu::before{content:"";position:absolute;left:0;right:0;top:-16px;height:16px;}
.hero-service-menu a{display:flex;align-items:center;gap:9px;min-height:44px;padding:10px 12px;border-radius:8px;color:var(--ink);font-size:13px;font-weight:900;line-height:1.35;}
.hero-service-menu a span{font-family:var(--en);font-size:11px;font-weight:800;color:var(--orange);letter-spacing:.08em;flex:0 0 auto;}
.hero-service-menu a:hover,.hero-service-menu a:focus{background:var(--orange-l);color:var(--orange-d);}
.hero-service-toggle:hover .hero-service-menu,.hero-service-toggle:focus-within .hero-service-menu{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0);}
.hero .eyebrow,.hero h1,.hero .catch,.hero p,.hero-btns{transform:translateY(20px);}
@keyframes up{to{opacity:1;transform:translateY(0);}}
.scroll-cue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;font-family:var(--en);font-size:11px;letter-spacing:.2em;color:rgba(255,255,255,.7);writing-mode:vertical-rl;}
.scroll-cue::after{content:"";display:block;width:1px;height:38px;background:rgba(255,255,255,.5);margin:10px auto 0;animation:cue 1.8s infinite;}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top;}45%{transform:scaleY(1);transform-origin:top;}55%{transform:scaleY(1);transform-origin:bottom;}100%{transform:scaleY(0);transform-origin:bottom;}}

/* ========== セクション共通 ========== */
section{padding:88px 0;}
[id]{scroll-margin-top:88px;}
.sec-head{margin-bottom:46px;}
.sec-head .lbl{font-family:var(--en);font-size:13px;letter-spacing:.25em;color:var(--orange);font-weight:800;display:block;margin-bottom:10px;}
.sec-head h2{font-size:clamp(26px,3.8vw,40px);font-weight:900;color:var(--ink);line-height:1.4;}
.sec-head .sub{color:var(--gray);font-size:15px;margin-top:12px;}
.reveal{opacity:0;transform:translateY(28px);transition:.7s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}

/* STUDIO風：画像部分だけ、明るい黄色の面が右へ抜けるワイプ */
.studio-image-wipe{position:relative;isolation:isolate;overflow:hidden;}
.studio-image-wipe::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;border-radius:inherit;background:linear-gradient(90deg,rgba(255,218,86,.82) 0%,rgba(249,197,61,.72) 62%,rgba(255,238,156,.56) 100%);box-shadow:18px 0 34px rgba(224,159,38,.12);transform:translateX(0);opacity:1;}
.studio-image-wipe.wipe-in::after{animation:studio-image-wipe .95s cubic-bezier(.76,0,.24,1) both;}
@keyframes studio-image-wipe{0%{transform:translateX(0);opacity:1;}58%{transform:translateX(38%);opacity:.96;}100%{transform:translateX(104%);opacity:0;}}
.priority-card.studio-image-wipe::after,.hero .ph.studio-image-wipe::after,.subhero .ph.studio-image-wipe::after{z-index:1;}

/* ========== 相談拠点 3本柱（home） ========== */
.priority-hub{position:relative;background:linear-gradient(180deg,#fff 0%,#fbfaf7 100%);padding:72px 0 78px;overflow:hidden;}
.priority-hub::before{content:"";position:absolute;inset:auto auto -170px -90px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(238,115,32,.11),transparent 68%);pointer-events:none;}
.priority-layout{display:grid;grid-template-columns:.8fr 1.2fr;gap:34px;align-items:stretch;}
.priority-copy{position:relative;padding:34px 32px 32px;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 18px 42px rgba(32,36,42,.07);overflow:hidden;}
.priority-copy::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--orange),#f4b14d);}
.priority-copy .lbl{font-family:var(--en);font-size:12px;letter-spacing:.22em;color:var(--orange);font-weight:900;display:block;margin-bottom:12px;}
.priority-copy h2{font-size:clamp(27px,3.3vw,38px);font-weight:900;line-height:1.38;margin-bottom:16px;color:var(--ink);}
.priority-copy p{color:var(--ink2);font-size:15px;line-height:1.9;margin-bottom:22px;}
.priority-proof{display:flex;gap:8px;flex-wrap:wrap;}
.priority-proof span{display:inline-flex;align-items:center;min-height:34px;padding:7px 12px;border-radius:999px;background:var(--orange-l);color:var(--orange-d);font-size:12.5px;font-weight:900;}
.priority-cards{display:grid;grid-template-columns:1.05fr .95fr;grid-template-rows:1fr 1fr;gap:16px;min-height:430px;}
.priority-card{position:relative;overflow:hidden;border-radius:16px;background:#111;color:#fff;min-height:200px;box-shadow:0 18px 42px rgba(32,36,42,.16);transition:transform .28s ease,box-shadow .28s ease;}
.priority-card:hover{transform:translateY(-4px);box-shadow:0 24px 52px rgba(32,36,42,.2);}
.priority-card.trade{grid-row:1 / 3;}
.priority-card picture,.priority-card img{width:100%;height:100%;display:block;}
.priority-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(1.02) contrast(.98);}
.priority-card::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(12,18,28,.08) 0%,rgba(12,18,28,.36) 48%,rgba(12,18,28,.82) 100%);}
.priority-card.trade::before{background:linear-gradient(180deg,rgba(18,24,36,.08),rgba(18,24,36,.44) 52%,rgba(18,24,36,.88));}
.priority-card.coating::before{background:linear-gradient(180deg,rgba(5,14,24,.05),rgba(5,14,24,.38) 52%,rgba(5,14,24,.86));}
.priority-card.inspection::before{background:linear-gradient(180deg,rgba(8,24,16,.06),rgba(8,24,16,.38) 52%,rgba(8,24,16,.86));}
.priority-body{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:24px;}
.priority-no{display:inline-flex;align-items:center;height:26px;margin-bottom:9px;padding:0 9px;border-radius:999px;background:rgba(255,255,255,.9);color:var(--orange-d);font-family:var(--en);font-size:10px;font-weight:900;letter-spacing:.08em;}
.priority-body h3{font-size:clamp(19px,2.2vw,27px);font-weight:900;line-height:1.35;margin-bottom:7px;text-shadow:0 8px 24px rgba(0,0,0,.38);}
.priority-body p{font-size:13.5px;line-height:1.75;color:rgba(255,255,255,.88);max-width:520px;}
.priority-card.trade .priority-body{padding:30px;}
.priority-card.trade .priority-body h3{font-size:clamp(24px,3vw,34px);}
.priority-card.trade .priority-body p{font-size:14px;}

/* ========== お悩み→解決（home） ========== */
.pain{background:linear-gradient(135deg,#f17b27 0%,#ee7320 48%,#d45f12 100%);color:#fff;}
.pain .sec-head .lbl{color:#fff6e9;}
.pain .sec-head h2{color:#fff;}
.pain .sec-head h2 .ac{color:var(--navy);text-shadow:0 2px 0 rgba(255,255,255,.16);}
.pain-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-bottom:36px;}
.pain-card{background:rgba(39,45,54,.86);border:1px solid rgba(255,255,255,.22);border-radius:16px;overflow:hidden;box-shadow:0 18px 42px rgba(91,36,0,.2);}
.pain-card .ph{height:180px;}
.pain-card .ph picture,.pain-card .ph img{width:100%;height:100%;display:block;}
.pain-card .ph img{object-fit:cover;}
.pain-card .pc-body{padding:20px;}
.pain-card h3{font-size:18px;font-weight:900;margin-bottom:6px;}
.pain-card h3 .em{color:var(--orange);}
.pain-card p{font-size:13px;color:#b9b9c2;line-height:1.7;}
.pain-cta{position:relative;isolation:isolate;overflow:hidden;text-align:center;font-size:clamp(25px,4.4vw,46px);font-weight:900;letter-spacing:.04em;line-height:1.45;min-height:132px;padding:30px 12px 24px;display:flex;align-items:center;justify-content:center;flex-wrap:nowrap;gap:.55em;}
.pain-cta::before,.pain-cta::after{content:"";flex:1 1 120px;max-width:160px;height:2px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.82),rgba(40,48,58,.55),rgba(255,255,255,.82),transparent);align-self:center;filter:drop-shadow(0 0 10px rgba(255,255,255,.32));animation:pain-line-pulse 2.8s ease-in-out infinite;}
.pain-cta::after{animation-delay:.55s;}
.pain-cta .pct-text{position:relative;z-index:1;display:inline-flex;align-items:baseline;gap:.28em;white-space:nowrap;text-shadow:0 10px 32px rgba(88,30,0,.28);animation:pain-cta-float 3.4s ease-in-out infinite;}
.pain-cta .pct-text::before{content:"";position:absolute;left:-.42em;right:-.42em;top:50%;height:1.28em;z-index:-1;border-radius:999px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.2) 34%,rgba(255,246,233,.28) 50%,rgba(255,255,255,.2) 66%,transparent 100%);transform:translateY(-50%) skewX(-12deg);animation:pain-sheen 3.2s cubic-bezier(.45,0,.2,1) infinite;}
.pain-cta .ac{position:relative;display:inline-block;color:var(--navy);font-size:1.22em;letter-spacing:.07em;text-shadow:0 2px 0 rgba(255,255,255,.22),0 12px 30px rgba(70,22,0,.24);padding:0 .17em;transform:translateY(.02em);}
@keyframes pain-line-pulse{0%,100%{opacity:.42;transform:scaleX(.72);}50%{opacity:1;transform:scaleX(1);}}
@keyframes pain-cta-float{0%,100%{transform:translateY(0);}50%{transform:translateY(-4px);}}
@keyframes pain-sheen{0%{opacity:0;clip-path:inset(0 100% 0 0);}18%{opacity:1;}58%{opacity:1;clip-path:inset(0 0 0 0);}100%{opacity:0;clip-path:inset(0 0 0 100%);}}

/* ========== 価格バー（home） ========== */
.price{background:linear-gradient(100deg,var(--orange),var(--orange-d));color:#fff;}
.price-in{display:flex;align-items:center;justify-content:space-between;gap:28px;padding:26px 0;flex-wrap:wrap;}
.price-label{font-family:var(--en);font-size:12px;letter-spacing:.18em;font-weight:800;margin-bottom:10px;opacity:.95;}
.price-list{display:flex;gap:34px;flex-wrap:wrap;}
.price-item .nm{font-size:12px;opacity:.85;margin-bottom:2px;}
.price-item .val{font-family:var(--en);font-size:30px;font-weight:800;line-height:1;}
.price-item .val small{font-size:14px;font-weight:600;}
.price-item.member .val{background:#fff;color:var(--orange-d);padding:2px 8px;border-radius:6px;}
.price-meta{font-size:12px;opacity:.85;margin-top:10px;}
.price-cta{background:#fff;color:var(--orange-d);padding:14px 24px;border-radius:10px;font-weight:800;font-size:14px;white-space:nowrap;transition:.25s;}
.price-cta:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(0,0,0,.18);}

/* ========== アクセス ========== */
.access{background:var(--bg);}
.access .sec-head{margin-bottom:24px;}
.access-grid{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(390px,.92fr);gap:0;align-items:start;}
.access-map{margin-top:34px;border-radius:14px;min-height:420px;overflow:hidden;border:4px solid rgba(238,115,32,.76);box-shadow:0 0 0 1px rgba(32,36,42,.08),0 18px 44px rgba(32,36,42,.10);}
.access-map iframe{width:100%;height:100%;min-height:420px;border:0;display:block;}
.access-info{position:relative;display:flex;flex-direction:column;justify-content:center;background:#fff;border:1px solid rgba(32,36,42,.09);border-radius:12px;margin:34px 0 34px -34px;padding:30px 34px 28px;box-shadow:0 24px 54px rgba(32,36,42,.12);overflow:hidden;}
.access-info::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--orange);}
.access-info-head{padding-bottom:20px;margin-bottom:2px;border-bottom:1px solid var(--line);}
.access-info-head span{display:block;font-family:var(--en);font-size:11px;font-weight:800;letter-spacing:.22em;color:var(--orange);margin-bottom:6px;}
.access-info-head h3{font-size:21px;font-weight:900;line-height:1.45;color:var(--ink);}
.info-row{padding:19px 0;border-bottom:1px solid var(--line);}
.info-row dl{display:grid;grid-template-columns:88px 1fr;gap:18px;align-items:start;}
.info-row dt{font-family:var(--jp);font-size:13px;letter-spacing:0;color:#5f6874;font-weight:900;line-height:1.7;}
.info-row dd{font-size:15.5px;font-weight:800;line-height:1.75;color:var(--ink);}
.info-row .closed{color:var(--orange-d);font-weight:900;}
.info-row .info-small{font-size:12.5px;color:var(--gray);font-weight:700;line-height:1.65;}
.access-btns{display:grid;grid-template-columns:1.08fr 1fr 1fr;gap:10px;margin-top:20px;}
.ab{min-width:0;text-align:center;padding:14px 16px;border-radius:7px;font-weight:800;font-size:14px;transition:.2s;letter-spacing:.02em;}
.ab.fill{background:var(--ink);color:#fff;}
.ab.fill:hover{background:#000;}
.ab.out{background:#fff;border:1px solid #d9d6ce;color:var(--ink);}
.ab.out:hover{border-color:var(--ink);background:#f7f6f2;}
.access-btns .ab{border-radius:999px;padding:13px 15px;font-size:13.5px;}
.access-btns .ab.fill{background:var(--orange);color:#fff;box-shadow:0 10px 22px rgba(238,115,32,.22);}
.access-btns .ab.fill:hover{background:var(--orange-d);transform:translateY(-1px);}
.access-btns .ab.out{border:1px solid #d8d4cb;background:#fff;color:var(--ink);}
.access-btns .ab.out:hover{border-color:var(--ink);background:#fbfaf7;transform:translateY(-1px);}

/* ========== 信頼バンド（home） ========== */
.trust{display:grid;grid-template-columns:.55fr 1.45fr;gap:24px;align-items:stretch;background:linear-gradient(135deg,#f17b27 0%,#ee7320 48%,#d45f12 100%);border:1px solid rgba(255,255,255,.28);border-radius:14px;padding:24px;margin-bottom:42px;box-shadow:0 18px 42px rgba(91,36,0,.18);overflow:hidden;}
.trust-intro{color:#fff;min-width:0;}
.trust-kicker{display:block;font-family:var(--en);font-size:11px;font-weight:800;letter-spacing:.18em;color:#fff6e9;margin-bottom:8px;}
.trust-intro h3{font-size:clamp(20px,2.2vw,27px);font-weight:900;line-height:1.45;}
.trust-list{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.trust-item{position:relative;min-width:0;color:#fff;padding:20px 16px 18px;background:rgba(39,45,54,.86);border:1px solid rgba(255,255,255,.22);border-radius:11px;box-shadow:0 14px 30px rgba(91,36,0,.18),inset 0 1px 0 rgba(255,255,255,.08);}
.trust-visual{width:184px;height:104px;border-radius:18px;background:#18232c;overflow:hidden;margin-bottom:16px;border:2px solid rgba(255,255,255,.24);box-shadow:0 14px 28px rgba(0,0,0,.26),0 0 0 4px rgba(238,115,32,.2);}
.trust-visual picture,.trust-visual img{width:100%;height:100%;display:block;}
.trust-visual img{object-fit:cover;}
.trust-label{font-size:11px;font-weight:900;color:rgba(255,255,255,.58);letter-spacing:.08em;margin-bottom:6px;}
.trust-main{font-size:clamp(16px,1.7vw,20px);font-weight:900;line-height:1.35;color:#fff;margin-bottom:7px;}
.trust-main::after{content:none;}
.trust-note{font-size:12px;line-height:1.7;color:rgba(255,255,255,.72);}

/* ========== サービスカード（home） ========== */
.tier-head{display:flex;align-items:center;gap:12px;margin:0 0 22px;}
.tier-no{font-family:var(--en);font-size:12px;font-weight:800;color:#fff;background:var(--orange);padding:5px 13px;border-radius:6px;}
.tier-head h3{font-size:22px;font-weight:900;}
.tier-head .nt{font-size:13px;color:var(--gray);}
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:48px;align-items:stretch;}
.svc{position:relative;isolation:isolate;min-height:320px;border:0;border-radius:18px;overflow:hidden;background:#141a22;color:#fff;box-shadow:0 20px 44px rgba(32,36,42,.16);transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;display:flex;flex-direction:column;}
.svc:hover{transform:translateY(-6px);box-shadow:0 24px 52px rgba(32,36,42,.2);border-color:transparent;}
.svc .ph{position:absolute;inset:0;height:auto;background:#111;}
.svc .ph::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(12,18,26,.02) 0%,rgba(12,18,26,.24) 45%,rgba(12,18,26,.84) 100%);}
.svc .ph picture,.related-card .rph picture{width:100%;height:100%;display:block;}
.svc .ph img{width:100%;height:100%;object-fit:cover;object-position:center 38%;display:block;filter:brightness(.96) saturate(1.08) contrast(1.02);}
.related-card .rph img{width:100%;height:100%;object-fit:cover;display:block;filter:brightness(1.08) saturate(1.04) contrast(.98);}
.svc-body{position:relative;z-index:2;min-height:320px;padding:152px 18px 18px;color:#fff;flex:1;display:flex;flex-direction:column;}
.svc-no{display:inline-flex;width:max-content;padding:4px 9px;border-radius:999px;background:rgba(255,255,255,.9);font-family:var(--en);font-size:12px;color:var(--orange-d);font-weight:800;}
.svc h4{color:#fff;font-size:18px;font-weight:900;margin:8px 0 8px;text-shadow:0 8px 20px rgba(0,0,0,.28);}
.svc ul{list-style:none;font-size:12.5px;color:rgba(255,255,255,.78);flex:1;}
.svc li{position:relative;padding-left:14px;margin-bottom:3px;line-height:1.55;}
.svc li::before{content:"";position:absolute;left:0;top:8px;width:5px;height:5px;background:var(--orange);border-radius:50%;}
.svc-meta{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px;}
.tag{font-size:11px;font-weight:700;padding:4px 9px;border-radius:6px;}
.tag.price{background:var(--orange-l);color:var(--orange-d);}
.tag.time{background:#f0f0ec;color:var(--gray);}
.tag.rsv{background:#eef4ef;color:#3d8a5a;}
.svc.prem .ph{background:linear-gradient(135deg,var(--navy-2),#202832);}
.svc.prem .ph::after{color:rgba(255,255,255,.4);}
.svc-more{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:38px;margin-top:auto;padding:10px 16px 10px 17px;background:rgba(255,255,255,.94);color:var(--orange-d);border:1px solid rgba(214,97,20,.24);border-bottom-color:rgba(214,97,20,.38);border-radius:999px;font-size:12.5px;font-weight:900;letter-spacing:.01em;align-self:flex-start;box-shadow:0 9px 20px rgba(214,97,20,.13),inset 0 1px 0 rgba(255,255,255,.82);transition:transform .2s ease,box-shadow .2s ease,background .2s ease,color .2s ease;}
.svc-more::after{content:"";width:7px;height:7px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(-45deg);margin-left:1px;}
.svc-more:hover{background:linear-gradient(180deg,#ee7b2d 0%,#d96114 100%);color:#fff;transform:translateY(-1px);box-shadow:0 12px 24px rgba(214,97,20,.22),inset 0 1px 0 rgba(255,255,255,.28);}
.svc.prem .svc-more{background:linear-gradient(180deg,#fff7ef 0%,#ffe6d1 100%);color:var(--orange-d);}
.svc.prem .svc-more:hover{background:linear-gradient(180deg,#ee7b2d 0%,#d96114 100%);color:#fff;}

/* ========== こんな方に（home） ========== */
.reco{background:var(--orange-l);}
.reco-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:980px;margin:0 auto;}
.reco-item{display:grid;grid-template-columns:150px minmax(0,1fr);align-items:stretch;background:#fff;border:1px solid #f4e3d2;border-radius:16px;overflow:hidden;box-shadow:0 12px 30px rgba(142,86,42,.07);font-size:15px;font-weight:700;}
.reco-photo{min-height:126px;background:#eadccc;overflow:hidden;}
.reco-photo img{width:100%;height:100%;display:block;object-fit:cover;transition:transform .45s ease;}
.reco-item:hover .reco-photo img{transform:scale(1.04);}
.reco-copy{display:flex;align-items:center;gap:13px;padding:22px 22px 22px 18px;min-width:0;}
.reco-item .ck{width:30px;height:30px;border-radius:50%;background:var(--orange);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;flex-shrink:0;}
.reco-item p{margin:0;line-height:1.65;color:var(--ink);}

/* ========== LINE（home） ========== */
.line-sec{background:linear-gradient(120deg,#06c755,#05a648);color:#fff;}
.line-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:48px;align-items:center;}
.line-phone{border-radius:20px;min-height:300px;background:linear-gradient(135deg,#04903e,#067a36);}
.line-phone::after{color:rgba(255,255,255,.5);}
.line-sec .lbl{font-family:var(--en);font-size:13px;letter-spacing:.25em;font-weight:800;opacity:.9;}
.line-sec h2{font-size:clamp(26px,3.4vw,36px);font-weight:900;margin:10px 0 8px;}
.line-sec .coupon{display:inline-block;background:rgba(255,255,255,.2);border:1px dashed rgba(255,255,255,.6);padding:6px 16px;border-radius:8px;font-weight:700;font-size:14px;margin-bottom:22px;}
.line-benefits{list-style:none;display:flex;flex-direction:column;gap:13px;margin-bottom:28px;}
.line-benefits li{display:flex;align-items:center;gap:12px;font-size:16px;font-weight:500;}
.line-benefits .chk{width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.25);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;}
.btn-white{background:#fff;color:#05a648;padding:16px 32px;border-radius:10px;font-weight:800;display:inline-flex;align-items:center;gap:8px;transition:.25s;}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(0,0,0,.2);}

/* ========== コヤタス（home） ========== */
.koy{background:var(--bg);}
.koy-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:48px;align-items:center;}
.koy .lbl{color:var(--orange);font-family:var(--en);font-size:13px;letter-spacing:.25em;font-weight:800;}
.koy h2{font-size:clamp(24px,3.2vw,34px);font-weight:900;color:var(--ink);margin:10px 0 0;}
.koy p{color:var(--ink2);font-size:15px;margin:18px 0 24px;}
.koy-img{border-radius:18px;min-height:280px;background:linear-gradient(135deg,#c5d3a8,#e3ead2);}
.koy-img::after{color:#7a8a5e;}
.btn-koy{display:inline-flex;align-items:center;gap:8px;background:#6b8a3d;color:#fff;padding:14px 26px;border-radius:10px;font-weight:700;font-size:14px;transition:.25s;}
.btn-koy:hover{background:#5a7733;transform:translateY(-2px);}
.koy-note{display:inline-flex;align-items:center;width:max-content;max-width:100%;margin:0!important;padding:10px 14px;border-radius:999px;background:#eef4e5;color:#5c7a35!important;font-size:13px!important;font-weight:900!important;line-height:1.4!important;}

/* ========== 会社情報（home） ========== */
.about-grid{display:grid;grid-template-columns:minmax(300px,.78fr) minmax(0,1.12fr);gap:56px;align-items:center;}
.about-img{border-radius:16px;aspect-ratio:4/5;min-height:0;overflow:hidden;background:#edeae4;}
.about-img picture,.about-img img{width:100%;height:100%;display:block;}
.about-img img{object-fit:cover;object-position:center 42%;border-radius:16px;}
.about-txt .lbl{font-family:var(--en);font-size:13px;letter-spacing:.25em;color:var(--orange);font-weight:800;}
.about-txt h2{font-size:clamp(30px,4.2vw,48px);font-weight:900;color:var(--ink);margin:10px 0 18px;line-height:1.28;letter-spacing:0;}
.about-txt p{color:var(--ink2);font-size:15px;margin-bottom:16px;}
.about-lead{max-width:620px;font-size:16px!important;line-height:1.9!important;margin-bottom:22px!important;}
.about-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:0 0 18px;}
.about-step{position:relative;background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 14px 14px;box-shadow:0 10px 24px rgba(32,36,42,.06);}
.about-step span{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:30px;margin-bottom:10px;border-radius:999px;background:var(--orange);color:#fff;font-size:12px;font-weight:900;letter-spacing:.04em;}
.about-step b{display:block;color:var(--ink);font-size:14px;font-weight:900;line-height:1.5;margin-bottom:5px;}
.about-step small{display:block;color:var(--gray);font-size:12px;font-weight:600;line-height:1.65;}
.about-proof{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:0 0 14px;}
.about-proof div{position:relative;padding:16px 15px 15px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 10px 24px rgba(32,36,42,.055);}
.about-proof span{display:inline-flex;align-items:center;min-height:26px;margin-bottom:9px;padding:4px 9px;border-radius:999px;background:var(--orange-l);color:var(--orange-d);font-size:12px;font-weight:900;line-height:1.2;}
.about-proof b{display:block;font-size:14px;font-weight:900;color:var(--ink);line-height:1.45;margin-bottom:5px;}
.about-proof small{display:block;color:var(--gray);font-size:11.5px;font-weight:600;line-height:1.65;}
.about-note{font-size:12.5px!important;color:var(--gray)!important;margin:0!important;line-height:1.7!important;}
.stance{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px;}
.stance span{background:var(--orange-l);color:var(--orange-d);border:1px solid #f4ddc6;font-size:13px;font-weight:700;padding:8px 16px;border-radius:24px;}
.voice{margin-top:24px;padding:18px 22px;background:var(--orange-l);border-left:4px solid var(--orange);border-radius:0 10px 10px 0;}
.voice-ttl{font-size:13px;font-weight:800;color:var(--orange-d);letter-spacing:.08em;margin-bottom:6px;}
.voice p{font-size:14.5px;color:var(--ink2);margin:0;line-height:1.8;}

/* ========== 決済手段（home） ========== */
.payment{background:var(--bg);padding:32px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.payment-in{max-width:1080px;margin:0 auto;padding:0 24px;display:flex;align-items:center;gap:24px;flex-wrap:wrap;}
.payment-title{font-family:var(--en);font-size:12px;letter-spacing:.18em;font-weight:800;color:var(--orange);flex-shrink:0;}
.payment-title .jp{display:block;font-family:var(--jp);font-size:18px;color:var(--ink);letter-spacing:0;margin-top:3px;font-weight:800;}
.payment-list{display:flex;gap:8px;flex-wrap:wrap;flex:1;}
.pay-tag{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);color:var(--ink);font-size:13.5px;font-weight:800;padding:8px 14px;border-radius:9px;box-shadow:0 1px 0 rgba(32,36,42,.04);}
.pay-ic{width:20px;height:20px;border-radius:7px;background:#f1f3f5;color:#72808c;display:inline-flex;align-items:center;justify-content:center;font-family:var(--en);font-size:10px;font-weight:800;letter-spacing:.02em;flex:0 0 20px;}
.payment-note{font-size:12px;color:var(--gray);width:100%;margin-top:4px;}

/* ========== 会社概要ページ ========== */
.about-page{background:#fff;}
.about-page-main{padding-top:68px;}
.company-hero{padding:78px 0 36px;background:#fff;}
.company-wrap{display:grid;grid-template-columns:minmax(320px,.82fr) minmax(420px,1.18fr);gap:68px;align-items:start;}
.company-copy{padding-top:8px;}
.company-en{display:block;font-family:var(--en);font-size:clamp(42px,5.4vw,68px);line-height:1;font-weight:800;letter-spacing:.03em;color:#050608;margin-bottom:20px;}
.company-copy h1{font-size:22px;font-weight:900;color:#050608;margin-bottom:34px;}
.company-copy p{max-width:430px;color:var(--ink2);font-size:15px;line-height:1.95;font-weight:600;}
.company-photo{overflow:hidden;border-radius:8px;background:#ece9e2;box-shadow:0 24px 56px rgba(32,36,42,.13);}
.company-photo picture,.company-photo img{width:100%;height:100%;display:block;}
.company-photo img{aspect-ratio:1.45/1;object-fit:cover;object-position:center 48%;}
.company-profile{padding:12px 0 96px;background:#fff;}
.profile-grid{display:grid;grid-template-columns:minmax(360px,.88fr) minmax(300px,.72fr);gap:72px;align-items:start;}
.profile-table dl{display:grid;gap:0;}
.profile-table dl>div{display:grid;grid-template-columns:112px minmax(0,1fr);gap:24px;padding:0 0 28px;}
.profile-table dt{color:var(--ink);font-size:14px;font-weight:800;line-height:1.7;}
.profile-table dd{color:var(--ink2);font-size:14.5px;font-weight:600;line-height:1.75;}
.profile-table dd span{color:var(--gray);font-size:13px;}
.profile-table dd strong{color:var(--orange-d);font-weight:900;}
.profile-table a{font-weight:900;color:var(--ink);}
.profile-aside{position:sticky;top:104px;padding:34px 34px 36px;border-radius:14px;background:linear-gradient(135deg,#f7f4ef 0%,#fff 70%);border:1px solid var(--line);box-shadow:0 20px 48px rgba(32,36,42,.08);}
.profile-aside .company-en{font-size:13px;letter-spacing:.25em;color:var(--orange);margin-bottom:14px;}
.profile-aside h2{font-size:28px;font-weight:900;line-height:1.35;margin-bottom:14px;}
.profile-aside p{font-size:14px;color:var(--gray);font-weight:600;line-height:1.85;margin-bottom:22px;}
.profile-actions{display:grid;gap:10px;}

/* ========== 相談窓口（home） ========== */
.bottom{background:var(--bg);}
.contact-panel{max-width:860px;margin:0 auto;padding:40px;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:0 18px 44px rgba(32,36,42,.08);}
.contact-panel .lbl{font-family:var(--en);font-size:12px;letter-spacing:.22em;color:var(--orange);font-weight:800;display:block;margin-bottom:8px;}
.contact-panel h2{font-size:clamp(26px,3.6vw,40px);font-weight:900;color:var(--ink);line-height:1.38;margin-bottom:12px;}
.contact-panel p{max-width:620px;color:var(--ink2);font-size:15px;line-height:1.9;margin-bottom:22px;}
.contact-panel .contact-rows{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.contact-rows{display:flex;flex-direction:column;gap:10px;}
.contact-form{margin-top:36px;padding-top:30px;border-top:1px solid var(--line);}
.contact-form-head h3{font-size:18px;font-weight:800;color:var(--ink);margin:0 0 8px;letter-spacing:.02em;}
.contact-form-head p{max-width:620px;font-size:13.5px;line-height:1.8;color:var(--ink2);margin:0 0 18px;}
.contact-form iframe{display:block;width:100%;border:0;background:transparent;}
/* 法務系ページ（プライバシーポリシー・利用規約） */
.legal-main{padding:80px 0 100px;background:linear-gradient(180deg,#fafaf7 0%,#fff 100%);}
.legal-wrap{max-width:780px;margin:0 auto;padding:0 24px;}
.legal-head{margin-bottom:40px;padding-bottom:28px;border-bottom:1px solid var(--line);}
.legal-en{font-family:var(--en);font-size:12px;letter-spacing:.24em;color:var(--orange);font-weight:800;display:block;margin-bottom:10px;}
.legal-head h1{font-size:clamp(28px,4vw,40px);font-weight:900;color:var(--ink);line-height:1.4;margin-bottom:14px;}
.legal-head .legal-meta{font-size:13px;color:var(--ink2);line-height:1.8;}
.legal-toc{background:#fff;border:1px solid var(--line);border-radius:12px;padding:22px 26px;margin-bottom:40px;box-shadow:0 8px 20px rgba(32,36,42,.04);}
.legal-toc h2{font-size:13px;font-weight:800;color:var(--ink);margin:0 0 12px;letter-spacing:.06em;}
.legal-toc ol{margin:0;padding-left:1.4em;color:var(--ink2);}
.legal-toc li{font-size:13.5px;line-height:1.95;}
.legal-toc a{color:var(--ink);text-decoration:none;border-bottom:1px solid transparent;transition:.2s;}
.legal-toc a:hover{border-bottom-color:var(--orange);color:var(--orange);}
.legal-body section{margin-bottom:36px;scroll-margin-top:80px;}
.legal-body h2{font-size:18px;font-weight:800;color:var(--ink);margin:0 0 14px;padding-left:14px;border-left:3px solid var(--orange);letter-spacing:.02em;}
.legal-body p{font-size:14px;line-height:1.95;color:var(--ink2);margin:0 0 12px;}
.legal-body ul,.legal-body ol{margin:0 0 16px;padding-left:1.5em;color:var(--ink2);font-size:14px;line-height:1.95;}
.legal-body li{margin-bottom:4px;}
.legal-body strong{color:var(--ink);font-weight:800;}
.legal-body a{color:var(--orange);text-decoration:underline;text-underline-offset:3px;word-break:break-all;}
.legal-table{width:100%;border-collapse:collapse;margin:14px 0 20px;font-size:13.5px;}
.legal-table th,.legal-table td{padding:10px 12px;border:1px solid var(--line);text-align:left;vertical-align:top;line-height:1.7;}
.legal-table th{background:#fafaf7;font-weight:800;color:var(--ink);}
.legal-table td{color:var(--ink2);}
.legal-contact{background:#fff;border:1px solid var(--line);border-radius:12px;padding:22px 26px;margin-top:24px;}
.legal-contact h3{font-size:15px;font-weight:800;color:var(--ink);margin:0 0 10px;}
.legal-contact p{font-size:13.5px;line-height:1.9;color:var(--ink2);margin:0;}
.legal-foot-nav{display:flex;flex-wrap:wrap;gap:12px;margin-top:48px;padding-top:30px;border-top:1px solid var(--line);}
.legal-foot-nav a{display:inline-flex;align-items:center;padding:10px 18px;border-radius:999px;border:1px solid var(--line);background:#fff;color:var(--ink);text-decoration:none;font-size:13.5px;font-weight:700;transition:.2s;}
.legal-foot-nav a:hover{background:var(--ink);color:#fff;}
.ft-copy a{color:inherit;text-decoration:none;border-bottom:1px solid currentColor;opacity:.8;margin:0 4px;}
.ft-copy a:hover{opacity:1;}
@media (max-width:640px){
  .legal-main{padding:50px 0 70px;}
  .legal-toc{padding:18px 20px;}
  .legal-body h2{font-size:16.5px;}
  .legal-body p,.legal-body li{font-size:13.5px;}
  .legal-table{font-size:12.5px;}
  .legal-table th,.legal-table td{padding:8px 10px;}
}
.crow{position:relative;overflow:hidden;isolation:isolate;display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:12px;border:1px solid var(--line);background:#fff;transition:.22s;box-shadow:0 8px 18px rgba(32,36,42,.04);}
.crow::after{content:"";position:absolute;inset:1px;border-radius:inherit;background:linear-gradient(180deg,rgba(255,255,255,.24),rgba(255,255,255,0) 48%);pointer-events:none;z-index:-1;}
.crow.tel{background:linear-gradient(135deg,#d96114 0%,#ee7320 54%,#ff9840 100%);color:#fff;border-color:rgba(255,255,255,.18);font-weight:900;font-size:17px;box-shadow:0 14px 30px rgba(238,115,32,.25);}
.crow.tel:hover{transform:translateY(-1px);box-shadow:0 18px 36px rgba(238,115,32,.32);}
.crow .crow-ic{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;background:rgba(255,255,255,.2);font-family:var(--en);font-size:10px;font-weight:900;letter-spacing:.04em;flex:0 0 34px;}
.crow.tel .crow-ic{font-size:0;}
.crow.tel .crow-ic::before{content:"";width:17px;height:17px;background:#fff;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M6.62 10.79c1.44 2.83 3.76 5.15 6.59 6.59l2.2-2.2c.27-.27.67-.36 1.02-.24 1.12.37 2.33.57 3.57.57.55 0 1 .45 1 1V20c0 .55-.45 1-1 1C10.61 21 3 13.39 3 4c0-.55.45-1 1-1h3.5c.55 0 1 .45 1 1 0 1.24.2 2.45.57 3.57.11.35.03.74-.25 1.02l-2.2 2.2z'/%3E%3C/svg%3E") center/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M6.62 10.79c1.44 2.83 3.76 5.15 6.59 6.59l2.2-2.2c.27-.27.67-.36 1.02-.24 1.12.37 2.33.57 3.57.57.55 0 1 .45 1 1V20c0 .55-.45 1-1 1C10.61 21 3 13.39 3 4c0-.55.45-1 1-1h3.5c.55 0 1 .45 1 1 0 1.24.2 2.45.57 3.57.11.35.03.74-.25 1.02l-2.2 2.2z'/%3E%3C/svg%3E") center/contain no-repeat;}
.crow.line{background:linear-gradient(135deg,#05af4d 0%,#06c755 54%,#18df70 100%);color:#fff;border-color:rgba(255,255,255,.2);font-weight:900;box-shadow:0 14px 30px rgba(6,199,85,.25);}
.crow.line:hover{transform:translateY(-1px);box-shadow:0 18px 36px rgba(6,199,85,.32);}
.crow-num{font-family:var(--en);letter-spacing:.04em;}
.no-call,.fax-no{color:inherit;text-decoration:none;cursor:default;pointer-events:none;-webkit-touch-callout:none;}
.no-call a,.fax-no a,a[x-apple-data-detectors]{color:inherit!important;text-decoration:none!important;pointer-events:none!important;cursor:default!important;}

/* ========== フッター（共通） ========== */
footer{background:linear-gradient(135deg,#f17b27 0%,#ee7320 48%,#d45f12 100%);color:rgba(255,255,255,.82);padding:60px 0 28px;}
.ft-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.24);}
.ft-logo{font-weight:900;font-size:23px;color:#fff;margin-bottom:12px;}
.ft-logo .o{color:var(--navy);text-shadow:0 2px 0 rgba(255,255,255,.14);}
.ft-info{font-size:14px;line-height:1.95;}
.ft-sns{display:flex;gap:12px;margin-top:16px;}
.ft-sns a{width:44px;height:44px;border-radius:10px;background:rgba(39,45,54,.72);border:1px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:900;color:#fff;transition:.2s;}
.ft-sns a:hover{background:var(--navy);}
.ft-nav{display:flex;gap:50px;flex-wrap:wrap;}
.ft-nav h4{font-family:var(--en);font-size:12px;letter-spacing:.13em;color:#fff6e9;margin-bottom:14px;}
.ft-nav ul{list-style:none;font-size:14px;display:flex;flex-direction:column;gap:10px;}
.ft-nav a{display:inline-flex;align-items:center;min-height:38px;padding:0 3px;}
.ft-nav a:hover{color:var(--navy);}
.ft-copy{padding-top:26px;font-size:12px;color:rgba(255,255,255,.64);font-family:var(--en);}

/* ===================================================================
   サービス詳細ページ用スタイル（service/*.html）
   =================================================================== */

/* パンくず */
.crumbs{padding:90px 0 0;background:#fff;}
.crumbs-in{max-width:1080px;margin:0 auto;padding:18px 24px 0;font-size:13px;color:var(--gray);}
.crumbs-in a:hover{color:var(--orange);}
.crumbs-in .sep{margin:0 8px;color:#c8c8c0;}
.crumbs-in .cur{color:var(--ink);font-weight:700;}

/* サブヒーロー（サービス詳細ページ専用） */
.subhero{position:relative;min-height:52vh;display:flex;align-items:center;color:#fff;overflow:hidden;margin-top:8px;isolation:isolate;}
.subhero .ph{position:absolute;inset:0;}
.subhero .ph picture{width:100%;height:100%;display:block;}
.subhero .ph img{width:100%;height:100%;object-fit:cover;object-position:center center;display:block;transform:none;transform-origin:center;}
.subhero .ph::after{content:"";position:absolute;inset:0;pointer-events:none;z-index:1;opacity:.22;}
.subhero::before{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(20,20,25,.42) 0%,rgba(20,20,25,.22) 48%,rgba(20,20,25,.04) 78%,rgba(20,20,25,0) 100%),linear-gradient(0deg,rgba(20,20,25,.3) 0%,rgba(20,20,25,.08) 42%,transparent 72%);z-index:1;}
.subhero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:36%;z-index:1;pointer-events:none;background:linear-gradient(0deg,rgba(0,0,0,.28),transparent);}
.subhero-in{position:relative;z-index:2;width:100%;padding:48px 0;}
.subhero .eyebrow{font-family:var(--en);font-size:12px;letter-spacing:.25em;color:var(--orange);font-weight:800;margin-bottom:14px;}
.subhero h1{font-size:clamp(28px,4.6vw,46px);font-weight:900;line-height:1.3;margin-bottom:14px;text-shadow:0 2px 0 rgba(0,0,0,.16),0 10px 28px rgba(0,0,0,.62),0 0 1px rgba(0,0,0,.78);}
.subhero h1 .ac{color:var(--orange);text-shadow:0 2px 0 rgba(0,0,0,.16),0 10px 28px rgba(0,0,0,.68),0 0 1px rgba(0,0,0,.82);}
.subhero .lead{font-size:clamp(15px,1.8vw,18px);font-weight:500;color:rgba(255,255,255,.92);max-width:680px;margin-bottom:26px;text-shadow:0 3px 18px rgba(0,0,0,.45);}
@keyframes serviceHeroDrift{
  from{transform:scale(1.006) translate3d(0,0,0);}
  to{transform:scale(1.025) translate3d(-.35%,.2%,0);}
}
@keyframes serviceFuelMeter{to{background-position:92px 0,0 0;}}
@keyframes serviceWashBubbles{to{background-position:60px -90px,-40px -70px,0 0;}}
@keyframes serviceOilFlow{to{background-position:0 120px,0 0;}}
@keyframes serviceScan{to{background-position:0 120px,34px 34px;}}
@keyframes serviceCircuit{to{background-position:90px 0,0 70px,0 0;}}
@keyframes serviceShine{from{transform:translateX(-120%) skewX(-18deg);}to{transform:translateX(120%) skewX(-18deg);}}

.service-page .subhero .ph::after{background:linear-gradient(90deg,rgba(0,0,0,.18),transparent 62%);}
.fuel-page .subhero .ph::after{background:linear-gradient(90deg,rgba(70,40,15,.18),rgba(238,115,32,.02) 64%,transparent);animation:none;}
.wash-page .subhero .ph::after{background:linear-gradient(90deg,rgba(4,33,47,.18),rgba(10,166,192,.02) 64%,transparent);animation:none;}
.oil-page .subhero .ph::after{background:linear-gradient(90deg,rgba(8,8,11,.2),rgba(212,160,23,.02) 64%,transparent);animation:none;}
.tire-page .subhero .ph::after{background:linear-gradient(90deg,rgba(10,10,12,.2),rgba(217,34,49,.02) 64%,transparent);}
.inspection-page .subhero .ph::after{background:linear-gradient(90deg,rgba(8,28,16,.18),rgba(45,94,62,.02) 64%,transparent);animation:none;}
.coating-page .subhero .ph::after{background:linear-gradient(90deg,rgba(2,5,10,.2),rgba(74,144,201,.02) 64%,transparent);}
.coating-page .subhero::after{height:36%;background:linear-gradient(0deg,rgba(0,0,0,.28),transparent);animation:none;mix-blend-mode:normal;opacity:1;}
.trade-page .subhero .ph::after{background:linear-gradient(90deg,rgba(10,18,32,.2),rgba(201,169,110,.02) 64%,transparent);}
.etc-page .subhero .ph::after{background:linear-gradient(90deg,rgba(3,10,22,.2),rgba(0,212,255,.02) 64%,transparent);animation:none;}

/* What we do */
.what{padding:80px 0;background:#fff;}
.what-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.what-card{padding:28px 26px;border:1px solid var(--line);border-radius:14px;background:var(--bg);transition:.3s;}
.what-card:hover{border-color:var(--orange);transform:translateY(-4px);box-shadow:0 12px 28px rgba(32,36,42,.08);}
.what-no{font-family:var(--en);font-size:12px;font-weight:800;color:var(--orange);background:#fff;border:1.5px solid var(--orange);width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:14px;}
.what-card h3{font-size:17px;font-weight:900;margin-bottom:8px;color:var(--ink);}
.what-card p{font-size:14px;color:var(--gray);line-height:1.75;}

/* メニュー・料金 */
.menu{padding:80px 0;background:var(--bg);}
.menu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;}
.menu-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px 28px;display:flex;flex-direction:column;gap:10px;}
.menu-card h3{font-size:18px;font-weight:900;color:var(--ink);}
.menu-card .price-line{display:flex;align-items:baseline;gap:10px;}
.menu-card .price-line .val{font-family:var(--en);font-size:18px;font-weight:800;color:var(--orange);}
.menu-card .price-line .note{font-size:12px;color:var(--gray);}
.menu-card .desc{font-size:14px;color:var(--ink2);line-height:1.7;}
.menu-card .menu-meta{display:flex;gap:6px;flex-wrap:wrap;margin-top:2px;}
.menu-card .menu-cta{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap;}
.menu-card .menu-cta a{position:relative;overflow:hidden;flex:1;min-width:120px;text-align:center;padding:12px 14px;border-radius:10px;font-size:13px;font-weight:900;transition:.22s;box-shadow:0 10px 20px rgba(32,36,42,.08),inset 0 1px 0 rgba(255,255,255,.28);}
.menu-card .menu-cta .cta-line{background:linear-gradient(135deg,#05af4d,#06c755 54%,#18df70);color:#fff;}
.menu-card .menu-cta .cta-line:hover{transform:translateY(-1px);box-shadow:0 14px 26px rgba(6,199,85,.24);}
.menu-card .menu-cta .cta-tel{background:linear-gradient(135deg,var(--orange-d),var(--orange) 54%,#ff9840);color:#fff;}
.menu-card .menu-cta .cta-tel:hover{transform:translateY(-1px);box-shadow:0 14px 26px rgba(238,115,32,.24);}
.price-note{margin-top:20px;padding:14px 18px;background:#fff;border-left:3px solid var(--orange);border-radius:0 8px 8px 0;font-size:13px;color:var(--gray);}

/* サービス詳細：価格未掲載メニューを1つにまとめるパネル */
.service-page{--svc-accent:var(--orange);--svc-accent-d:var(--orange-d);--svc-soft:var(--orange-l);--svc-panel-bg:#fff;--svc-panel-text:var(--ink);--svc-panel-muted:var(--gray);--svc-panel-border:var(--line);--svc-tel-bg:var(--svc-accent);}
.wash-page{--svc-accent:var(--wash-blue);--svc-accent-d:var(--wash-blue-d);--svc-soft:var(--wash-blue-l);--svc-panel-border:var(--wash-blue-l);--svc-tel-bg:var(--wash-blue);}
.oil-page{--svc-accent:var(--oil-gold);--svc-accent-d:var(--oil-gold-l);--svc-soft:rgba(212,160,23,.12);--svc-panel-bg:rgba(255,255,255,.045);--svc-panel-text:#fff;--svc-panel-muted:rgba(255,255,255,.68);--svc-panel-border:#3a3a45;--svc-tel-bg:var(--oil-gold);}
.tire-page{--svc-accent:var(--tire-red);--svc-accent-d:var(--tire-red-d);--svc-soft:#fff1f2;--svc-panel-border:#d8d8de;--svc-tel-bg:var(--tire-charcoal);}
.inspection-page{--svc-accent:var(--insp-green);--svc-accent-d:var(--insp-green-d);--svc-soft:var(--insp-green-l);--svc-panel-border:#d8e2dc;--svc-tel-bg:var(--insp-green);}
.coating-page{--svc-accent:var(--coat-blue);--svc-accent-d:var(--coat-blue-l);--svc-soft:rgba(74,144,201,.12);--svc-panel-bg:linear-gradient(160deg,#1f1f26 0%,#15151a 100%);--svc-panel-text:#fff;--svc-panel-muted:rgba(255,255,255,.7);--svc-panel-border:rgba(192,192,192,.16);--svc-tel-bg:var(--coat-blue);}
.etc-page{--svc-accent:var(--etc-cyan);--svc-accent-d:var(--etc-cyan);--svc-soft:rgba(0,212,255,.1);--svc-panel-bg:linear-gradient(160deg,#15263d 0%,#0c1b2e 100%);--svc-panel-text:#fff;--svc-panel-muted:rgba(255,255,255,.7);--svc-panel-border:var(--etc-grid);--svc-tel-bg:var(--etc-cyan);}
.trade-page{--svc-accent:var(--trade-gold);--svc-accent-d:var(--trade-navy);--svc-soft:var(--trade-ivory);--svc-panel-border:var(--trade-ivory);--svc-tel-bg:var(--trade-navy);}
.service-summary-panel{background:var(--svc-panel-bg);border:1px solid var(--svc-panel-border);border-top:4px solid var(--svc-accent);border-radius:14px;padding:30px 32px 32px;box-shadow:0 18px 42px rgba(32,36,42,.08);color:var(--svc-panel-text);}
.service-summary-top{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:24px;align-items:start;padding-bottom:22px;border-bottom:1px solid var(--svc-panel-border);}
.service-summary-kicker{display:block;font-family:var(--en);font-size:11px;font-weight:800;letter-spacing:.18em;color:var(--svc-accent);margin-bottom:7px;}
.service-summary-top h3{font-size:24px;font-weight:900;line-height:1.45;color:var(--svc-panel-text);}
.service-summary-top p{margin-top:8px;color:var(--svc-panel-muted);font-size:14px;line-height:1.8;}
.service-summary-status{display:flex;align-items:center;justify-content:center;min-width:190px;min-height:72px;padding:14px 18px;background:var(--svc-soft);border:1px solid var(--svc-panel-border);border-radius:10px;color:var(--svc-accent-d);font-weight:900;text-align:center;line-height:1.5;}
.service-summary-list{display:grid;grid-template-columns:repeat(2,1fr);gap:0;margin-top:4px;}
.service-summary-item{padding:24px 24px 22px 0;border-bottom:1px solid var(--svc-panel-border);}
.service-summary-item:nth-child(even){padding-left:24px;border-left:1px solid var(--svc-panel-border);}
.service-summary-item:nth-last-child(-n+2){border-bottom:none;}
.service-summary-item h4{font-size:18px;font-weight:900;color:var(--svc-accent-d);margin-bottom:8px;}
.service-summary-item p{font-size:14px;color:var(--svc-panel-muted);line-height:1.75;}
.service-summary-actions{display:flex;gap:10px;margin-top:24px;}
.service-summary-actions a{position:relative;overflow:hidden;flex:1;text-align:center;padding:14px 18px;border-radius:11px;font-weight:900;transition:.22s;box-shadow:0 12px 24px rgba(32,36,42,.08),inset 0 1px 0 rgba(255,255,255,.28);}
.service-summary-actions .cta-line{background:linear-gradient(135deg,#05af4d,#06c755 54%,#18df70);color:#fff;}
.service-summary-actions .cta-line:hover{transform:translateY(-1px);box-shadow:0 16px 30px rgba(6,199,85,.24);}
.service-summary-actions .cta-tel{background:var(--svc-tel-bg);background:linear-gradient(135deg,var(--svc-accent-d),var(--svc-tel-bg) 54%,color-mix(in srgb,var(--svc-tel-bg),#fff 24%));color:#fff;}
.oil-page .service-summary-actions .cta-tel,.etc-page .service-summary-actions .cta-tel{color:#101820;}
.service-summary-actions .cta-tel:hover{filter:brightness(.92);transform:translateY(-1px);}
.service-summary-note{margin-top:18px;padding:14px 0 0;border-top:1px solid var(--svc-panel-border);font-size:13px;color:var(--svc-panel-muted);line-height:1.75;}

/* ご利用の流れ */
.flow{padding:80px 0;background:#fff;}
.flow-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;position:relative;}
.flow-step{background:var(--bg);border:1px solid var(--line);border-radius:14px;padding:26px 22px;position:relative;}
.flow-no{font-family:var(--en);font-size:11px;letter-spacing:.18em;font-weight:800;color:var(--orange);margin-bottom:10px;}
.flow-step h3{font-size:17px;font-weight:900;color:var(--ink);margin-bottom:8px;}
.flow-step p{font-size:13.5px;color:var(--gray);line-height:1.7;}
.flow-step::after{content:"";position:absolute;right:-18px;top:50%;width:28px;height:2px;transform:translateY(-50%);background:linear-gradient(90deg,rgba(232,124,51,.15),rgba(232,124,51,.7),rgba(232,124,51,.15));border-radius:999px;z-index:1;}
.flow-step:last-child::after{display:none;}

/* FAQ */
.faq{padding:80px 0;background:var(--bg);}
.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:12px;}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;}
.faq-item summary{padding:20px 24px;cursor:pointer;font-weight:700;font-size:15px;color:var(--ink);position:relative;list-style:none;padding-right:50px;}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::before{content:"Q";position:absolute;left:24px;top:50%;transform:translateY(-50%);display:none;}
.faq-item summary{padding-left:54px;}
.faq-item summary::after{content:"+";position:absolute;right:24px;top:50%;transform:translateY(-50%);font-size:22px;color:var(--orange);font-weight:300;transition:transform .2s;}
.faq-item[open] summary::after{content:"−";}
.faq-item summary::before{content:"Q";display:flex;position:absolute;left:20px;top:50%;transform:translateY(-50%);width:28px;height:28px;background:var(--orange);color:#fff;border-radius:50%;align-items:center;justify-content:center;font-family:var(--en);font-size:13px;font-weight:800;}
.faq-item .a{padding:0 24px 22px 54px;font-size:14px;color:var(--ink2);line-height:1.85;}

/* CTA セクション */
.cta-band{padding:80px 0;background:linear-gradient(135deg,var(--ink) 0%,#2a2e35 100%);color:#fff;text-align:center;}
.cta-band h2{font-size:clamp(24px,3.2vw,34px);font-weight:900;margin-bottom:14px;line-height:1.4;}
.cta-band h2 .ac{color:var(--orange);}
.cta-band .lead{font-size:15px;color:rgba(255,255,255,.85);margin-bottom:30px;max-width:560px;margin-left:auto;margin-right:auto;}
.cta-band .cta-tel{display:inline-block;font-family:var(--en);font-size:clamp(30px,4.6vw,42px);font-weight:900;color:#fff;letter-spacing:.04em;margin-bottom:6px;}
.cta-band .cta-tel:hover{color:var(--orange);}
.cta-band .hours{font-size:13px;color:rgba(255,255,255,.7);margin-bottom:24px;line-height:1.8;}
.cta-band .cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:18px;}

/* 関連サービス */
.related{padding:80px 0;background:#fff;border-top:1px solid var(--line);}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.related-card{display:flex;flex-direction:column;background:var(--bg);border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:.3s;}
.related-card:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(32,36,42,.1);border-color:transparent;}
.related-card .rph{height:140px;overflow:hidden;background:#fff7ef;}
.related-card .rph img{width:100%;height:100%;object-fit:cover;}
.related-card .rbody{padding:18px 20px;flex:1;display:flex;flex-direction:column;justify-content:space-between;}
.related-card .rno{font-family:var(--en);font-size:11px;font-weight:800;color:var(--orange);}
.related-card h3{font-size:16px;font-weight:900;color:var(--ink);margin:4px 0 6px;}
.related-card .rmore{font-size:12.5px;color:var(--orange-d);font-weight:700;margin-top:8px;}

/* ========== レスポンシブ ========== */
@media(max-width:860px){
  nav ul{display:none;}
  .hd{position:relative;justify-content:center;}
  .logo{margin-inline:auto;}
  .logo-copy{align-items:center;text-align:center;}
  .mobile-menu-toggle{position:absolute;left:24px;top:50%;transform:translateY(-50%);display:inline-flex;width:46px;height:46px;align-items:center;justify-content:center;flex-direction:column;gap:5px;border:1px solid rgba(32,36,42,.12);border-radius:999px;background:rgba(255,255,255,.86);box-shadow:0 10px 28px rgba(32,36,42,.1),inset 0 1px 0 rgba(255,255,255,.85);appearance:none;color:var(--ink);z-index:142;cursor:pointer;}
  .mobile-menu-toggle span{display:block;width:18px;height:2px;border-radius:999px;background:currentColor;transition:transform .2s ease,opacity .2s ease;}
  .mobile-menu-open .mobile-menu-toggle{background:var(--orange);border-color:rgba(255,255,255,.3);color:#fff;box-shadow:0 14px 30px rgba(238,115,32,.28),inset 0 1px 0 rgba(255,255,255,.3);}
  .mobile-menu-open .mobile-menu-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  .mobile-menu-open .mobile-menu-toggle span:nth-child(2){opacity:0;}
  .mobile-menu-open .mobile-menu-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
  .mobile-menu-backdrop{position:fixed;inset:68px 0 0;z-index:138;background:rgba(18,24,32,.28);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .18s ease,visibility .18s ease;}
  .mobile-menu-panel{position:fixed;top:78px;left:16px;right:16px;z-index:141;display:block;max-height:calc(100svh - 98px);overflow:auto;padding:18px;background:rgba(255,255,255,.96);border:1px solid rgba(32,36,42,.1);border-radius:16px;box-shadow:0 24px 70px rgba(18,24,32,.22);backdrop-filter:blur(18px) saturate(170%);-webkit-backdrop-filter:blur(18px) saturate(170%);opacity:0;visibility:hidden;pointer-events:none;transform:translateY(-8px);transition:opacity .18s ease,transform .18s ease,visibility .18s ease;}
  .mobile-menu-open .mobile-menu-backdrop,.mobile-menu-open .mobile-menu-panel{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0);}
  .mobile-menu-panel[hidden]{display:block;}
  .mobile-menu-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
  .mobile-menu-head span{font-family:var(--en);font-size:12px;letter-spacing:.24em;color:var(--orange);font-weight:900;}
  .mobile-menu-close{border:0;background:#f3f1ec;color:var(--ink);border-radius:999px;padding:8px 12px;font-size:12px;font-weight:900;appearance:none;}
  .mobile-menu-primary{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:14px;}
  .mobile-menu-primary a{display:flex;align-items:center;justify-content:center;min-height:42px;border-radius:10px;background:#f7f4ef;color:var(--ink);font-size:13px;font-weight:900;border:1px solid rgba(32,36,42,.06);}
  .mobile-menu-label{font-family:var(--en);font-size:11px;letter-spacing:.2em;color:var(--gray);font-weight:900;margin:8px 0 9px;}
  .mobile-menu-services{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
  .mobile-menu-services a{display:flex;align-items:center;gap:8px;min-height:44px;padding:9px 10px;border-radius:10px;background:#fff;border:1px solid rgba(32,36,42,.09);box-shadow:0 5px 14px rgba(32,36,42,.05);font-size:12.5px;font-weight:900;line-height:1.28;}
  .mobile-menu-services span{font-family:var(--en);font-size:10px;color:var(--orange);font-weight:900;letter-spacing:.08em;}
  .mobile-menu-actions{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-top:14px;}
  .mobile-menu-actions a{display:flex;align-items:center;justify-content:center;min-height:46px;border-radius:12px;font-size:13px;font-weight:900;color:#fff;}
  .mobile-menu-actions .line{background:linear-gradient(135deg,#05af4d 0%,#06c755 58%,#18df70 100%);}
  .mobile-menu-actions .tel{background:linear-gradient(135deg,#d96114 0%,#ee7320 56%,#ff9840 100%);}
  .hero-service-menu,.hero-service-trigger::after{display:none;}
  .access-grid,.line-grid,.koy-grid,.about-grid{grid-template-columns:1fr;}
  .company-wrap,.profile-grid{grid-template-columns:1fr;gap:34px;}
  .company-hero{padding:58px 0 24px;}
  .company-copy{padding-top:0;}
  .company-photo{max-width:680px;}
  .profile-aside{position:static;}
  .access-grid{gap:0;}
  .access-map{margin-top:0;min-height:320px;border-radius:14px;}
  .access-map iframe{min-height:320px;}
  .access-info{margin:-30px 22px 0;padding:28px 28px 26px;}
  .svc-grid,.pain-grid,.what-grid,.menu-grid,.related-grid{grid-template-columns:1fr 1fr;}
  .trust{grid-template-columns:1fr;gap:18px;padding:22px;margin-bottom:34px;}
  .trust-list{grid-template-columns:1fr;gap:10px;}
  .trust-item{display:grid;grid-template-columns:132px minmax(0,1fr);gap:16px;align-items:center;padding:15px;}
  .trust-visual{width:132px;height:84px;margin-bottom:0;}
  .flow-grid{grid-template-columns:1fr 1fr;gap:24px;}
  .flow-step::after{display:none;}
  .ft-top{flex-direction:column;}
  section{padding:64px 0;}
  .price-in{flex-direction:column;align-items:flex-start;}
  .subhero{min-height:44vh;}
  .subhero-in{padding:36px 0;}
  .crumbs-in{font-size:12px;}
  .what,.menu,.flow,.faq,.cta-band,.related{padding:60px 0;}
  .priority-layout{grid-template-columns:1fr;gap:18px;}
  .priority-cards{grid-template-columns:1fr;grid-template-rows:auto;min-height:0;}
  .priority-card.trade{grid-row:auto;}
  .priority-card{min-height:230px;}
}
@media(max-width:520px){
  .svc-grid,.pain-grid,.reco-grid,.what-grid,.menu-grid,.related-grid,.flow-grid{grid-template-columns:1fr!important;}
  .trust{border-radius:12px;padding:20px 16px;}
  .trust-intro h3{font-size:20px;}
  .trust-list{grid-template-columns:1fr;padding-top:0;gap:10px;}
  .trust-item{display:grid;grid-template-columns:112px minmax(0,1fr);gap:14px;align-items:center;padding:13px;border-radius:10px;}
  .trust-item+.trust-item{border-left:1px solid rgba(255,255,255,.1);border-top:none;}
  .trust-visual{width:112px;height:76px;border-radius:15px;margin-bottom:0;}
  .trust-main{font-size:19px;}
  .trust-main::after{content:none;}
  .service-summary-panel{padding:24px 20px 22px;}
  .service-summary-top{grid-template-columns:1fr;gap:14px;padding-bottom:18px;}
  .service-summary-top h3{font-size:21px;}
  .service-summary-status{min-width:0;min-height:0;justify-content:flex-start;text-align:left;}
  .service-summary-list{grid-template-columns:1fr;}
  .service-summary-item{padding:20px 0;border-bottom:1px solid var(--svc-panel-border);}
  .service-summary-item:nth-child(even){padding-left:0;border-left:none;}
  .service-summary-item:nth-last-child(2){border-bottom:1px solid var(--svc-panel-border);}
  .service-summary-actions{flex-direction:column;}
  .service-summary-note{font-size:12.5px;}
}
@media(max-width:860px){
  .sticky-cta{position:fixed;bottom:12px;left:12px;right:12px;display:flex;gap:8px;z-index:100;padding:7px;background:rgba(255,255,255,.86);border:1px solid rgba(32,36,42,.12);border-radius:18px;box-shadow:0 18px 48px rgba(20,24,30,.24),0 2px 8px rgba(20,24,30,.08);backdrop-filter:blur(18px) saturate(180%);-webkit-backdrop-filter:blur(18px) saturate(180%);}
  .home-page .sticky-cta{transition:opacity .22s ease,transform .22s ease,visibility .22s ease;}
  .home-page:not(.sticky-active) .sticky-cta{opacity:0;visibility:hidden;pointer-events:none;transform:translateY(18px);}
  .sticky-cta a{position:relative;overflow:hidden;isolation:isolate;flex:1;display:flex;align-items:center;justify-content:center;gap:9px;min-height:52px;text-align:center;padding:0 12px;border-radius:14px;font-weight:900;text-decoration:none;font-size:15px;letter-spacing:.02em;box-shadow:inset 0 1px 0 rgba(255,255,255,.32);}
  .sticky-cta a::after{content:"";position:absolute;inset:1px;border-radius:inherit;background:linear-gradient(180deg,rgba(255,255,255,.24),rgba(255,255,255,0) 48%);pointer-events:none;z-index:-1;}
  .sticky-cta .tel{background:linear-gradient(135deg,#d96114 0%,#ee7320 52%,#ff9840 100%);color:#fff;}
  .sticky-cta .tel::before{content:"";width:17px;height:17px;flex:0 0 17px;background:currentColor;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M6.62 10.79c1.44 2.83 3.76 5.15 6.59 6.59l2.2-2.2c.27-.27.67-.36 1.02-.24 1.12.37 2.33.57 3.57.57.55 0 1 .45 1 1V20c0 .55-.45 1-1 1C10.61 21 3 13.39 3 4c0-.55.45-1 1-1h3.5c.55 0 1 .45 1 1 0 1.24.2 2.45.57 3.57.11.35.03.74-.25 1.02l-2.2 2.2z'/%3E%3C/svg%3E") center/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M6.62 10.79c1.44 2.83 3.76 5.15 6.59 6.59l2.2-2.2c.27-.27.67-.36 1.02-.24 1.12.37 2.33.57 3.57.57.55 0 1 .45 1 1V20c0 .55-.45 1-1 1C10.61 21 3 13.39 3 4c0-.55.45-1 1-1h3.5c.55 0 1 .45 1 1 0 1.24.2 2.45.57 3.57.11.35.03.74-.25 1.02l-2.2 2.2z'/%3E%3C/svg%3E") center/contain no-repeat;}
  .sticky-cta .line{background:linear-gradient(135deg,#05af4d 0%,#06c755 52%,#18df70 100%);color:#fff;}
  .sticky-cta .line::before{content:"LINE";display:inline-flex;align-items:center;justify-content:center;height:22px;min-width:36px;padding:0 7px;border-radius:999px;background:rgba(255,255,255,.92);color:#06a84b;font-family:var(--en);font-size:10px;font-weight:900;letter-spacing:.04em;box-shadow:0 4px 10px rgba(0,0,0,.12);}
  body{padding-bottom:84px;}
}
@media(min-width:861px){.sticky-cta{display:none;}}

/* ========== スマホLP最適化 ========== */
@media(max-width:520px){
  body{font-size:15px;line-height:1.75;overflow-x:hidden;}
  .wrap{padding:0 24px;}
  header{background:rgba(255,255,255,.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(32,36,42,.08);}
  .hd{height:66px;}
  .logo{gap:9px;}
  .logo .mk{width:38px;height:38px;}
  .logo-main{font-size:19px;}
  .logo-sub{font-size:10px;margin-top:2px;letter-spacing:0;}

  .hero{min-height:100svh;align-items:flex-end;padding:0 0 86px;}
  .hero-in{transform:none;}
  .hero::before{background:linear-gradient(180deg,rgba(17,24,32,.02) 0%,rgba(17,24,32,.08) 30%,rgba(17,24,32,.46) 58%,rgba(17,24,32,.88) 100%),linear-gradient(90deg,rgba(17,24,32,.44),rgba(17,24,32,.1) 72%);}
  .hero .ph img{height:100%;object-fit:cover;object-position:center center;}
  .hero .eyebrow,.hero .catch,.hero p{text-shadow:0 2px 18px rgba(0,0,0,.46);}
  .hero h1,.hero h1 .ac{text-shadow:0 2px 0 rgba(0,0,0,.2),0 10px 30px rgba(0,0,0,.72),0 0 1px rgba(0,0,0,.85);}
  .hero .eyebrow{font-size:0;line-height:1.9;margin-bottom:12px;}
  .hero .eyebrow::before{content:"KASUMIDAI SS / CHIKUSEI";font-size:10px;letter-spacing:.22em;}
  .hero h1{font-size:34px;line-height:1.22;margin-bottom:18px;}
  .hero .catch{font-size:16px;line-height:1.85;margin-bottom:16px;}
  .hero p{font-size:14px;line-height:1.9;margin-bottom:26px;max-width:330px;}
  .hero-btns{gap:10px;}
  .btn{min-height:54px;border-radius:14px;padding:13px 16px;font-size:14px;justify-content:center;}
  .hero-btns .btn-line{width:100%;}
  .hero-service-toggle{flex:1;min-width:0;}
  .hero-service-trigger{width:100%;padding-right:16px;}
  .hero-btns .btn-tel,.hero-btns .btn-ghost{flex:1;min-width:0;}
  .scroll-cue{display:none;}

  .crumbs{display:none;}
  .service-page .subhero{min-height:430px;align-items:flex-end;margin-top:66px;}
  .service-page .subhero .ph img{animation:none;object-position:center center;}
  .fuel-page .subhero .ph img{object-position:58% center;}
  .wash-page .subhero .ph img{object-position:56% center;}
  .oil-page .subhero .ph img{object-position:62% center;}
  .tire-page .subhero .ph img{object-position:50% center;}
  .trade-page .subhero .ph img{object-position:53% center;}
  .coating-page .subhero .ph img{object-position:55% center;}
  .inspection-page .subhero .ph img{object-position:52% center;}
  .etc-page .subhero .ph img{object-position:58% center;}
  .service-page .subhero::before{background:linear-gradient(180deg,rgba(12,16,22,.04) 0%,rgba(12,16,22,.1) 38%,rgba(12,16,22,.54) 74%,rgba(12,16,22,.76) 100%)!important;}
  .service-page .subhero .ph::after{opacity:.08;}
  .service-page .subhero::after{height:38%;background:linear-gradient(0deg,rgba(0,0,0,.38),transparent);}
  .service-page .subhero-in{padding:54px 24px 34px;}
  .service-page .subhero h1{font-size:28px;line-height:1.36;margin-bottom:13px;letter-spacing:0;max-width:330px;overflow-wrap:anywhere;}
  .service-page .subhero .lead{font-size:14px;line-height:1.78;margin-bottom:20px;}
  section{padding:56px 0;}
  .sec-head{margin-bottom:28px;}
  .sec-head .lbl{font-size:11px;letter-spacing:.2em;margin-bottom:8px;}
  .sec-head h2{font-size:27px;line-height:1.42;}
  .sec-head .sub{font-size:14px;line-height:1.8;margin-top:10px;}

  .pain{padding-top:58px;padding-bottom:56px;}
  .priority-hub{padding:52px 0 54px;}
  .priority-copy{padding:24px 20px;border-radius:12px;}
  .priority-copy h2{font-size:27px;line-height:1.42;margin-bottom:12px;}
  .priority-copy p{font-size:14px;line-height:1.78;margin-bottom:18px;}
  .priority-proof{gap:7px;}
  .priority-proof span{min-height:31px;padding:6px 10px;font-size:12px;}
  .priority-cards{gap:10px;}
  .priority-card{min-height:186px;border-radius:12px;box-shadow:0 12px 28px rgba(32,36,42,.14);}
  .priority-card.trade{min-height:220px;}
  .priority-body{padding:18px;}
  .priority-card.trade .priority-body{padding:20px;}
  .priority-body h3,.priority-card.trade .priority-body h3{font-size:21px;line-height:1.35;}
  .priority-body p,.priority-card.trade .priority-body p{font-size:12.5px;line-height:1.65;}
  .priority-no{height:24px;font-size:9px;margin-bottom:7px;}
  .pain-grid{gap:18px;margin-bottom:26px;}
  .pain-card{border-radius:12px;}
  .pain-card .ph{height:188px;}
  .pain-card .pc-body{padding:20px;}
  .pain-card h3{font-size:19px;line-height:1.55;}
  .pain-card p{font-size:13px;line-height:1.75;}
  .pain-cta{min-height:88px;font-size:clamp(16px,4.6vw,22px);line-height:1.4;padding:12px 4px;gap:.25em;}
  .pain-cta::before,.pain-cta::after{flex:0 0 22px;max-width:22px;}
  .pain-cta .ac{font-size:1.15em;letter-spacing:.03em;}

  .price{background:var(--orange);}
  .price-in{gap:18px;padding:28px 24px;}
  .price-in>div{width:100%;}
  .price-label{font-size:11px;letter-spacing:.16em;margin-bottom:14px;}
  .price-list{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;}
  .price-item{background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:12px 12px 10px;}
  .price-item .nm{font-size:11px;}
  .price-item .val{font-size:25px;}
  .price-item.member{grid-column:1 / -1;}
  .price-item.member .val{display:inline-block;font-size:26px;}
  .price-meta{font-size:11px;line-height:1.7;margin-top:12px;}
  .price-cta{width:100%;text-align:center;justify-content:center;border-radius:8px;padding:13px 18px;white-space:normal;}

  .access{padding-top:54px;padding-bottom:58px;}
  .access .sec-head{margin-bottom:18px;}
  .access-map,.access-map iframe{min-height:240px;}
  .access-map{border-radius:12px;}
  .access-info{margin:-24px 12px 0;padding:24px 18px 20px;border-radius:11px;box-shadow:0 18px 36px rgba(32,36,42,.12);}
  .access-info-head{padding-bottom:16px;margin-bottom:0;}
  .access-info-head span{font-size:10px;letter-spacing:.2em;}
  .access-info-head h3{font-size:18px;}
  .info-row{padding:16px 0;}
  .info-row dl{display:block;}
  .info-row dt{font-size:13px;margin-bottom:5px;line-height:1.5;}
  .info-row dd{font-size:14px;line-height:1.68;}
  .access-btns{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px;}
  .access-btns .ab{min-width:0;padding:12px 10px;border-radius:999px;font-size:13px;}
  .access-btns .ab:nth-child(3){grid-column:1 / -1;}

  #service{padding-top:58px;}
  .trust{margin-bottom:30px;padding:20px 16px;border-radius:12px;box-shadow:0 12px 28px rgba(32,36,42,.12);}
  .trust-kicker{font-size:10px;letter-spacing:.2em;}
  .trust-intro h3{font-size:21px;line-height:1.55;}
  .trust-list{margin-top:0;}
  .trust-item{padding:13px;}
  .trust-label{font-size:11px;}
  .trust-main{font-size:19px;line-height:1.45;}
  .trust-note{font-size:12px;line-height:1.7;}
  .tier-head{align-items:flex-start;flex-wrap:wrap;gap:8px 10px;margin-bottom:16px;}
  .tier-no{font-size:11px;padding:5px 10px;border-radius:5px;}
  .tier-head h3{width:100%;font-size:22px;line-height:1.35;}
  .tier-head .nt{font-size:12px;}
  #service .svc-grid{gap:14px;margin-bottom:30px;}
  #service .svc{display:flex;flex-direction:column;align-items:stretch;border-radius:14px;min-height:0;overflow:hidden;background:#111820;transform:none!important;box-shadow:0 14px 32px rgba(32,36,42,.16);}
  #service .svc.reveal{opacity:1;transform:none!important;transition:border-color .2s ease,box-shadow .2s ease;}
  #service .svc:hover{transform:none!important;}
  #service .svc .ph{position:relative;inset:auto;width:100%;height:196px;min-height:196px;align-self:stretch;overflow:hidden;transform:none!important;}
  #service .svc .ph::before,#service .svc .ph::after{display:none;}
  #service .svc .ph picture{position:absolute;inset:0;width:100%;height:100%;display:block;}
  #service .svc .ph img{width:100%;height:100%;display:block;object-fit:cover;object-position:center 36%;}
  #service .svc-body{min-height:0;padding:16px 16px 15px;min-width:0;align-self:stretch;color:#fff;background:#111820;}
  #service .svc-no{font-size:10px;}
  #service .svc h4{font-size:18px;line-height:1.35;margin:7px 0 7px;}
  #service .svc ul{font-size:13px;line-height:1.55;margin:0;color:rgba(255,255,255,.76);}
  #service .svc li{margin-bottom:1px;}
  #service .svc li:nth-child(n+2){display:block;}
  #service .svc li:nth-child(n+3){display:none;}
  #service .svc-meta{display:none;}
  #service .svc-more{width:100%;min-width:0;min-height:44px;justify-content:center;border-radius:11px;padding:10px 14px;font-size:13px;margin-top:14px;background:linear-gradient(135deg,#d96114 0%,#ee7320 54%,#ff9840 100%);color:#fff;box-shadow:0 12px 26px rgba(238,115,32,.24),inset 0 1px 0 rgba(255,255,255,.28);}

  .reco{padding:54px 0;background:#fff7ef;}
  .reco .sec-head{text-align:left!important;}
  .reco-item{grid-template-columns:106px minmax(0,1fr);border-radius:12px;font-size:13.5px;}
  .reco-photo{min-height:104px;}
  .reco-copy{align-items:center;gap:10px;padding:13px 13px 13px 12px;min-height:100%;}
  .reco-item .ck{width:24px;height:24px;margin-top:0;font-size:13px;}

  .line-sec{padding:54px 0;background:#22b957;}
  .line-grid{gap:0;}
  .line-phone{display:none;}
  .line-sec .lbl{font-size:11px;letter-spacing:.2em;}
  .line-sec h2{font-size:28px;line-height:1.35;}
  .line-sec .coupon{margin:14px 0 20px;border-radius:8px;font-size:13px;}
  .line-benefits{gap:11px;margin-bottom:24px;}
  .line-benefits li{align-items:flex-start;font-size:14px;line-height:1.65;}
  .line-benefits .chk{width:23px;height:23px;margin-top:1px;}
  .btn-white{width:100%;justify-content:center;border-radius:8px;padding:14px 20px;}

  .koy{padding:56px 0;}
  .koy h2{font-size:25px;line-height:1.45;}
  .koy p{font-size:14px;line-height:1.85;margin:16px 0 22px;}
  .koy-note{width:100%;justify-content:center;border-radius:9px;font-size:12.5px!important;}
  .koy-img{display:block;min-height:0;border-radius:12px;background:transparent;}
  .koy-img picture{display:block;width:100%;height:220px;}
  .koy-img img{width:100%!important;height:100%!important;object-fit:cover;border-radius:12px!important;}

  #about{padding:56px 0;}
  .about-grid{gap:24px;}
  .about-img{order:2;width:82%;max-width:280px;margin:0 auto;border-radius:12px;}
  .about-img img{border-radius:12px!important;object-position:center 40%;}
  .about-txt{order:1;}
  .about-txt h2{font-size:28px;line-height:1.38;margin-bottom:14px;}
  .about-txt p{font-size:14px;line-height:1.85;}
  .about-lead{font-size:14px!important;line-height:1.85!important;margin-bottom:18px!important;}
  .about-steps{grid-template-columns:1fr;gap:9px;margin-bottom:18px;}
  .about-step{display:grid;grid-template-columns:52px minmax(0,1fr);gap:4px 12px;align-items:start;padding:13px 14px;border-radius:10px;}
  .about-step span{grid-row:1 / span 2;min-width:42px;height:42px;margin:0;border-radius:12px;font-size:12px;}
  .about-step b{font-size:13.5px;line-height:1.45;margin:0;}
  .about-step small{font-size:11.5px;line-height:1.55;}
  .about-proof{grid-template-columns:1fr;gap:9px;margin-bottom:12px;}
  .about-proof div{padding:13px 14px;border-radius:10px;}
  .about-proof span{min-height:24px;margin-bottom:8px;font-size:11.5px;}
  .about-proof b{font-size:13.5px;line-height:1.45;margin-bottom:4px;}
  .about-proof small{font-size:11.5px;line-height:1.55;}
  .about-note{font-size:12px!important;}
  .company-meta{display:block!important;padding:14px 16px!important;font-size:12px!important;line-height:1.8!important;}
  .company-meta span{display:block;margin-bottom:6px;}
  .voice{padding:16px 18px;margin-top:20px;border-radius:0 8px 8px 0;}
  .voice p{font-size:14px;}
  .stance{gap:8px;margin-top:18px;}
  .stance span{border-radius:999px;padding:7px 12px;font-size:12px;}

  .payment{padding:28px 0;}
  .payment-in{display:block;padding:0 24px;}
  .payment-title{margin-bottom:14px;}
  .payment-list{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
  .pay-tag{justify-content:center;padding:10px 8px;border-radius:8px;font-size:12px;}
  .payment-note{font-size:11px;line-height:1.7;margin-top:12px;}

  .about-page-main{padding-top:66px;}
  .company-hero{padding:42px 0 22px;}
  .company-wrap{gap:28px;}
  .company-en{font-size:44px;margin-bottom:14px;}
  .company-copy h1{font-size:20px;margin-bottom:18px;}
  .company-copy p{font-size:14px;line-height:1.85;}
  .company-photo{border-radius:10px;box-shadow:0 16px 38px rgba(32,36,42,.1);}
  .company-photo img{aspect-ratio:1.38/1;}
  .company-profile{padding:0 0 70px;}
  .profile-grid{gap:28px;}
  .profile-table dl>div{grid-template-columns:1fr;gap:5px;padding:0 0 22px;border-bottom:1px solid var(--line);margin-bottom:18px;}
  .profile-table dl>div:last-child{border-bottom:none;margin-bottom:0;}
  .profile-table dt{font-size:13px;color:var(--gray);}
  .profile-table dd{font-size:14px;line-height:1.75;}
  .profile-aside{padding:26px 22px 24px;border-radius:12px;}
  .profile-aside h2{font-size:23px;}
  .profile-aside p{font-size:13.5px;}

  .bottom{padding:54px 0;}
  .contact-panel{padding:24px 20px 22px;border-radius:12px;}
  .contact-panel .lbl{font-size:11px;letter-spacing:.2em;}
  .contact-panel h2{font-size:25px;line-height:1.42;}
  .contact-panel p{font-size:14px;line-height:1.8;margin-bottom:18px;}
  .contact-panel .contact-rows{grid-template-columns:1fr;gap:9px;}
  .crow{padding:13px 14px;border-radius:8px;}

  footer{padding:44px 0 84px;}
  .ft-top{gap:28px;padding-bottom:28px;}
  .ft-logo{font-size:22px;}
  .ft-info{font-size:13px;line-height:1.9;}
  .ft-nav{gap:30px;}
  .ft-copy{font-size:11px;line-height:1.7;}
}

@media(max-width:520px){
  .what-card{padding:19px 18px;border-radius:11px;}
  .what-card h3{font-size:16px;margin-bottom:5px;}
  .what-card p{font-size:13px;line-height:1.7;}
  .service-summary-panel{border-radius:12px;padding:22px 18px 20px;}
  .service-summary-top p{font-size:13px;line-height:1.7;}
  .service-summary-status{font-size:13px;border-radius:999px;padding:9px 13px;width:max-content;max-width:100%;}
  .service-summary-item{padding:16px 0;}
  .service-summary-item h4{font-size:16px;margin-bottom:4px;}
  .service-summary-item p{font-size:13px;line-height:1.65;}
  .service-summary-actions{flex-direction:row;gap:8px;margin-top:18px;}
  .service-summary-actions a{padding:12px 10px;font-size:13px;border-radius:9px;}
  .flow-grid{gap:10px;}
  .flow-step{padding:16px 16px 15px;border-radius:11px;}
  .flow-no{font-size:10px;margin-bottom:4px;}
  .flow-step h3{font-size:16px;margin-bottom:0;}
  .flow-step p{display:none;}
  .faq-list{gap:10px;}
  .faq-item summary{font-size:14px;line-height:1.55;padding:16px 42px 16px 48px;}
  .faq-item summary::before{left:16px;width:24px;height:24px;font-size:12px;}
  .faq-item summary::after{right:16px;}
  .faq-item .a{padding:0 18px 18px 48px;font-size:13px;line-height:1.75;}
  .cta-band{padding:48px 0;}
  .cta-band h2{font-size:24px;}
  .cta-band .lead{font-size:13px;line-height:1.75;margin-bottom:18px;}
  .cta-band .cta-tel{font-size:30px;}
  .cta-band .hours{font-size:12px;margin-bottom:18px;}
  .related{padding:50px 0;}
  .related-grid{display:flex;flex-direction:column;gap:10px;}
  .related-card{display:grid;grid-template-columns:88px minmax(0,1fr);border-radius:11px;min-height:88px;}
  .related-card .rph{height:100%;}
  .related-card .rbody{padding:12px 14px;min-width:0;}
  .related-card h3{font-size:15px;line-height:1.35;margin:2px 0 2px;}
  .related-card .rmore{font-size:12px;margin-top:4px;}
}

@media(max-width:360px){
  .wrap{padding:0 20px;}
  .hero h1{font-size:31px;}
  .hero .catch,.hero p{font-size:13px;}
  .price-list{grid-template-columns:1fr;}
  .access-btns{grid-template-columns:1fr;}
  .access-btns .ab:nth-child(3){grid-column:auto;}
  .payment-list{grid-template-columns:1fr;}
}

/* ===================================================================
   ローディング・遷移演出・マイクロインタラクション（site.js 連動）
   - 古谷石油の誠実トーン維持・派手すぎない
   - ブランドカラー #ee7320 厳守
   - prefers-reduced-motion: reduce で自動停止
   =================================================================== */

/* ① 初回ローディング オーバーレイ */
#page-loader{position:fixed;inset:0;background:#fbfaf7;z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity .35s ease,visibility .35s ease;}
#page-loader.hidden{opacity:0;visibility:hidden;pointer-events:none;}
.loader-icon{position:relative;width:104px;height:104px;}
.loader-icon::before{content:"";position:absolute;left:50%;top:50%;width:78px;height:78px;transform:translate(-50%,-50%);border-radius:50%;background:#fff;box-shadow:0 8px 22px rgba(32,36,42,.08);}
.loader-icon img{position:absolute;left:50%;top:50%;width:70px;height:70px;transform:translate(-50%,-50%);border-radius:50%;clip-path:circle(50% at 50% 50%);display:block;object-fit:cover;background:#fff;box-shadow:0 2px 8px rgba(32,36,42,.08);}
.loader-ring{position:absolute;inset:0;border:3px solid rgba(238,115,32,.18);border-top-color:#ee7320;border-radius:50%;animation:loader-spin 1s linear infinite;}
@keyframes loader-spin{to{transform:rotate(360deg);}}
/* ローダー安全装置：site.js が動かなくても必ず消える（白画面で固まるのを防止） */
@keyframes loader-failsafe{0%,92%{opacity:1;}100%{opacity:0;visibility:hidden;pointer-events:none;}}
#page-loader{animation:loader-failsafe 6s ease forwards;}
#page-loader.hidden{animation:none;}

/* ② ページ遷移プログレスバー */
#nav-progress{position:fixed;top:0;left:0;width:0;height:3px;background:linear-gradient(90deg,#ee7320,#d35f12);z-index:10000;opacity:1;transition:width .35s ease-out,opacity .25s ease;box-shadow:0 0 8px rgba(238,115,32,.5);pointer-events:none;}
#nav-progress.go{width:80%;}
#nav-progress.done{width:100%;opacity:0;transition:width .15s ease-out,opacity .35s ease .15s;}

/* ③ マイクロインタラクション強化（既存ホバーを土台に追記） */
/* サービスカード：軽くリフトアップ＋シャドウ強化（既存 .svc:hover を上書きせず transition だけ補強） */
.svc{transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;}
/* お悩みカード：枠線がオレンジに変化 */
.pain-card{transition:border-color .3s ease,transform .3s ease,box-shadow .3s ease;}
.pain-card:hover{border-color:rgba(238,115,32,.55);transform:translateY(-3px);box-shadow:0 10px 24px rgba(0,0,0,.15);}
/* お悩みカードの画像も軽くズーム（控えめ） */
.pain-card .ph{transition:transform .5s ease;}
.pain-card:hover .ph{transform:scale(1.03);}
/* 関連サービスカード・what-card は既存 hover に transition だけ補強 */
.related-card,.what-card{transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;}

/* ④ prefers-reduced-motion 対応：動きを止める */
@media (prefers-reduced-motion: reduce){
  #page-loader,#nav-progress,.studio-image-wipe::after,.reveal,.loader-ring,
  .pain-cta::before,.pain-cta::after,.pain-cta .pct-text,.pain-cta .pct-text::before,
  .svc,.pain-card,.pain-card .ph,.related-card,.what-card,
  .hero .eyebrow,.hero h1,.hero .catch,.hero p,.hero-btns,.scroll-cue::after,
  .subhero .ph img,.subhero .ph::after,.subhero::after{
    animation:none !important;
    transition:none !important;
  }
  #page-loader{display:none !important;}
  #nav-progress{display:none !important;}
  .studio-image-wipe::after{display:none !important;}
  .reveal{opacity:1 !important;transform:none !important;}
  .hero .eyebrow,.hero h1,.hero .catch,.hero p,.hero-btns{opacity:1 !important;transform:none !important;}
}
