/* ============================================
   三和ペイント LP - Base Styles
   VI Colors:
     BLUE 01: #43ade9
     BLUE 02: #008ad2 (main)
     BLUE 03: #204483 (dark)
     YELLOW 01: #f8e000 (CTA)
     GRAY 02: #595757
   ============================================ */

/* --- Reset & Base --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:62.5%;scroll-behavior:smooth}
body{font-family:"Noto Sans JP","Hiragino Sans",sans-serif;font-size:1.6rem;line-height:1.8;color:#333;background:#fff;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;vertical-align:bottom}
a{color:#008ad2;text-decoration:none;transition:opacity .3s}
a:hover{opacity:.8}
ul,ol{list-style:none}

/* --- Variables --- */
:root{
  --blue01:#43ade9;
  --blue02:#008ad2;
  --blue03:#204483;
  --yellow01:#f8e000;
  --gray02:#595757;
  --white:#fff;
  --bg-light:#f5f8fa;
  --max-width:1100px;
  --header-height:96px;
  --header-top-h:32px;
  --header-main-h:64px;
}

/* --- Utility --- */
.inner{max-width:var(--max-width);margin:0 auto;padding:0 20px}
.section{padding:80px 0}
.section--gray{background:var(--bg-light)}
.section-title{font-size:3.2rem;font-weight:700;text-align:center;color:var(--blue03);margin-bottom:16px;letter-spacing:.05em}
.section-title span{display:block;font-size:1.4rem;font-weight:400;color:var(--blue02);text-transform:uppercase;letter-spacing:.15em;margin-bottom:8px}
.section-lead{text-align:center;color:var(--gray02);margin-bottom:48px;font-size:1.5rem}
.pc-only{display:block}
.sp-only{display:none}

/* --- Header (2-tier) --- */
.l-header{position:fixed;top:0;left:0;width:100%;height:var(--header-height);background:var(--white);box-shadow:0 2px 8px rgba(0,0,0,.08);z-index:1000;display:flex;flex-direction:column}
.l-header__top{height:var(--header-top-h);background:var(--blue03);color:var(--white);font-size:1.2rem;display:flex;align-items:center}
.l-header__top .inner{display:flex;align-items:center;justify-content:space-between;width:100%}
.l-header__branch{font-weight:700;letter-spacing:.05em}
.l-header__top-right{display:flex;align-items:center;gap:18px;color:rgba(255,255,255,.9)}
.l-header__tel-top{display:inline-flex;align-items:center;gap:6px;color:var(--white);font-weight:700}
.l-header__tel-top svg{width:14px;height:14px;fill:var(--yellow01)}
.l-header__tel-top-num{font-size:1.4rem;letter-spacing:.02em}
.l-header__hours{font-size:1.1rem;opacity:.85}
.l-header__corp{font-size:1.1rem;color:rgba(255,255,255,.7);transition:color .2s}
.l-header__corp:hover{color:var(--yellow01);opacity:1}

.l-header__main{height:var(--header-main-h);display:flex;align-items:center;flex:1}
.l-header__main .inner{display:flex;align-items:center;justify-content:space-between;width:100%;gap:24px}
.l-header__logo{display:flex;align-items:center;gap:10px;flex-shrink:0}
.l-header__logo img,.l-header__logo svg{height:34px;width:auto}
.l-header__nav{display:flex;align-items:center;gap:26px}
.l-header__nav a{font-size:1.4rem;color:var(--blue03);font-weight:500;transition:color .3s;position:relative;padding:4px 0}
.l-header__nav a::after{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background:var(--blue02);transition:width .25s,left .25s}
.l-header__nav a:hover{color:var(--blue02);opacity:1}
.l-header__nav a:hover::after{width:100%;left:0}
.btn-header-cta{display:inline-flex;align-items:center;justify-content:center;background:var(--yellow01);color:var(--blue03);font-size:1.3rem;font-weight:700;padding:10px 22px;border-radius:4px;box-shadow:0 2px 4px rgba(0,0,0,.15);transition:transform .2s,box-shadow .2s;flex-shrink:0}
.btn-header-cta:hover{transform:translateY(-1px);box-shadow:0 4px 8px rgba(0,0,0,.2);opacity:1}

/* --- Hamburger (SP) --- */
.l-header__burger{display:none;flex-direction:column;justify-content:center;align-items:center;width:40px;height:40px;background:transparent;border:none;cursor:pointer;padding:0;gap:5px;margin-left:8px}
.l-header__burger span{display:block;width:22px;height:2px;background:var(--blue03);border-radius:1px;transition:transform .3s,opacity .3s}
body.nav-open .l-header__burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.nav-open .l-header__burger span:nth-child(2){opacity:0}
body.nav-open .l-header__burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:998;opacity:0;transition:opacity .3s}
body.nav-open .nav-overlay{opacity:1}

/* --- Hero --- */
.hero{position:relative;margin-top:var(--header-height);height:560px;background:var(--blue03);display:flex;align-items:center;overflow:hidden}
.hero__bg{position:absolute;top:0;left:0;width:100%;height:100%}
.hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero::after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,rgba(32,68,131,.85) 0%,rgba(32,68,131,.55) 50%,rgba(0,138,210,.3) 100%);z-index:1}
.hero .inner{position:relative;z-index:2}
.hero__copy{color:var(--white);text-shadow:0 2px 8px rgba(0,0,0,.3)}
.hero__tagline{font-size:1.6rem;letter-spacing:.2em;margin-bottom:16px;opacity:.9}
.hero__main{font-size:4.8rem;font-weight:900;line-height:1.3;margin-bottom:12px;letter-spacing:.05em}
.hero__main em{font-style:normal;color:var(--yellow01)}
.hero__sub{font-size:2rem;font-weight:500;margin-bottom:32px;opacity:.95}
.hero__area{font-size:1.8rem;font-weight:700;margin-bottom:32px;padding:12px 24px;background:rgba(255,255,255,.12);border-radius:6px;display:inline-block}
.hero__btns{display:flex;gap:16px;flex-wrap:wrap}

/* --- CTA Button (shared) --- */
.btn-cta{display:inline-flex;align-items:center;justify-content:center;font-weight:700;border-radius:6px;transition:transform .2s,box-shadow .2s;cursor:pointer;border:none;text-align:center;line-height:1.4}
.btn-cta:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,.2);opacity:1}
.btn-cta--yellow{background:var(--yellow01);color:var(--blue03);font-size:1.8rem;padding:16px 40px;box-shadow:0 4px 8px rgba(0,0,0,.15)}
.btn-cta--white{background:var(--white);color:var(--blue03);font-size:1.8rem;padding:16px 40px;box-shadow:0 4px 8px rgba(0,0,0,.1)}
.btn-cta--small{font-size:1.4rem;padding:12px 24px}
.btn-cta__icon{margin-right:8px;font-size:2rem}

/* --- Points (3 key points) --- */
.points__list{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.points__item{text-align:center;padding:0 0 32px;background:var(--white);border-radius:12px;box-shadow:0 4px 20px rgba(0,0,0,.06);transition:transform .3s;overflow:hidden}
.points__item:hover{transform:translateY(-4px)}
.points__icon{width:80px;height:80px;margin:20px auto;background:var(--blue02);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--white);font-size:3.2rem}
.points__img{width:100%;height:200px;margin:0 0 30px;overflow:hidden}
.points__img img{width:100%;height:100%;object-fit:cover;object-position:center top}
.points__num{font-size:4.8rem;font-weight:900;color:var(--blue02);line-height:1;margin-bottom:4px;padding:0 24px}
.points__num--text{font-size:4rem;padding-top:5px;padding-bottom:3px}
.points__unit{font-size:1.4rem;color:var(--gray02);padding:0 24px}
.points__label{font-size:1.8rem;font-weight:700;color:var(--blue03);margin-top:12px;padding:0 24px}
.points__desc{font-size:1.4rem;color:var(--gray02);margin-top:8px;line-height:1.6;padding:0 24px}

/* --- CTA Band --- */
.cta-band{background:var(--blue03);padding:48px 0;text-align:center}
.cta-band__text{color:var(--white);font-size:2rem;font-weight:700;margin-bottom:24px}
.cta-band__text em{font-style:normal;color:var(--yellow01)}
.cta-band__btns{display:flex;justify-content:center;gap:20px;flex-wrap:wrap}
.cta-band__tel{color:var(--white);text-align:center;margin-bottom:16px}
.cta-band__tel-num{font-size:2.4rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;gap:8px;margin:0}
.cta-band__tel-num a{color:var(--white);text-decoration:none}
.cta-band__tel small{font-size:1.2rem;font-weight:400;display:block;margin-top:4px}

/* --- Works (施工実績) --- */
.works__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.works__card{background:var(--white);border-radius:8px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.06);transition:transform .3s}
.works__card:hover{transform:translateY(-4px)}
.works__thumb{width:100%;height:200px;background:#ddd;position:relative;overflow:hidden}
.works__thumb-img{width:100%;height:100%;object-fit:cover;object-position:center}
.works__thumb-label{position:absolute;top:12px;left:12px;background:var(--blue02);color:#fff;font-size:1.1rem;font-weight:700;padding:4px 12px;border-radius:3px}
.works__body{padding:20px}
.works__area{font-size:1.2rem;color:var(--blue02);font-weight:700;margin-bottom:4px}
.works__desc{font-size:1.4rem;color:#333;font-weight:500;margin-bottom:8px}
.works__meta{font-size:1.2rem;color:var(--gray02)}
.works__more{text-align:center;margin-top:48px}
.btn-viewmore{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;min-width:320px;padding:18px 40px;background:#fff;border:2px solid var(--blue02);border-radius:999px;color:var(--blue02);font-weight:700;font-size:1.8rem;letter-spacing:.12em;text-decoration:none;transition:all .2s}
.btn-viewmore small{display:block;margin-top:4px;font-size:1.2rem;letter-spacing:.04em;color:#666;font-weight:500}
.btn-viewmore:hover{background:var(--blue02);color:#fff}
.btn-viewmore:hover small{color:rgba(255,255,255,.85)}

/* --- Reviews (お客様の声) --- */
.reviews__list{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.reviews__card{background:var(--white);border-radius:8px;padding:32px 24px;box-shadow:0 2px 12px rgba(0,0,0,.06);position:relative}
.reviews__card::before{content:"\201C";font-size:6rem;color:var(--blue01);opacity:.3;position:absolute;top:8px;left:16px;line-height:1;font-family:Georgia,serif}
.reviews__stars{color:var(--yellow01);font-size:1.8rem;margin-bottom:12px}
.reviews__text{font-size:1.4rem;line-height:1.8;color:#555;margin-bottom:16px;padding-top:8px}
.reviews__author{font-size:1.3rem;color:var(--gray02);font-weight:500;text-align:right}
.reviews__more{text-align:center;margin-top:40px}

/* --- Guarantee (保証・アフターサービス) --- */
.guarantee__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.guarantee__item{text-align:center;padding:32px 20px;background:var(--white);border-radius:8px;border:2px solid #e8edf2;transition:border-color .3s}
.guarantee__item:hover{border-color:var(--blue02)}
.guarantee__icon{margin-bottom:16px;display:flex;align-items:center;justify-content:center}
.guarantee__icon svg{width:48px;height:48px}
.guarantee__title{font-size:1.8rem;font-weight:700;color:var(--blue03);margin-bottom:8px}
.guarantee__text{font-size:1.4rem;color:var(--gray02);line-height:1.6}

/* --- Footer --- */
.l-footer{background:var(--blue03);color:var(--white);padding:48px 0 24px}
.l-footer__top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:40px;flex-wrap:wrap;gap:32px}
.l-footer__info{max-width:400px}
.l-footer__logo{margin-bottom:16px}
.l-footer__logo svg path{fill:#fff}
.l-footer__name{font-size:1.8rem;font-weight:700;margin-bottom:8px}
.l-footer__address{font-size:1.3rem;opacity:.8;line-height:1.8}
.l-footer__nav{display:flex;gap:40px;flex-wrap:wrap}
.l-footer__nav-col h4{font-size:1.3rem;font-weight:700;margin-bottom:12px;opacity:.8}
.l-footer__nav-col a{display:block;font-size:1.3rem;color:var(--white);opacity:.7;margin-bottom:8px;transition:opacity .3s}
.l-footer__nav-col a:hover{opacity:1;color:var(--white)}
.l-footer__bottom{border-top:1px solid rgba(255,255,255,.15);padding-top:20px;text-align:center;font-size:1.2rem;opacity:.6}

/* --- Floating CTA (SP) --- */
.floating-cta{display:none;position:fixed;bottom:0;left:0;width:100%;z-index:999;background:var(--white);box-shadow:0 -4px 12px rgba(0,0,0,.12);padding:8px 8px;gap:6px}
.floating-cta a{flex:1;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;padding:10px 4px;border-radius:6px;gap:4px;text-align:center;white-space:nowrap;line-height:1.2}
.floating-cta a small{font-size:0.85em;font-weight:700;margin-left:2px}
/* 旧tel用クラスは互換のため残す(現状未使用) */
.floating-cta__tel{background:var(--blue03);color:var(--white)}
/* base form(modifier 未指定時のフォールバック)→ modifier より先に書く */
.floating-cta__form{background:var(--yellow01);color:var(--blue03)}
/* primary/secondary バリアント(base form より後に書いて上書き) */
.floating-cta__form--primary{background:var(--yellow01);color:var(--blue03)}
.floating-cta__form--secondary{background:var(--white) !important;color:var(--blue03) !important;border:2px solid var(--blue03)}

/* ============================================
   Area Page (下層ページ)
   ============================================ */

/* --- Breadcrumb --- */
.breadcrumb{background:var(--bg-light);padding:12px 0;margin-top:var(--header-height);font-size:1.2rem;color:var(--gray02)}
.breadcrumb .inner{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.breadcrumb a{color:var(--blue02)}
.breadcrumb span{color:#bbb}
.breadcrumb span:last-child{color:var(--gray02)}

/* --- Page Hero (下層用) --- */
.page-hero{position:relative;height:320px;background:var(--blue03);display:flex;align-items:center;overflow:hidden}
.page-hero__bg{position:absolute;top:0;left:0;width:100%;height:100%}
.page-hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center}
.page-hero::after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,rgba(32,68,131,.85) 0%,rgba(32,68,131,.55) 100%);z-index:1}
.page-hero .inner{position:relative;z-index:2}
.page-hero__copy{color:var(--white);text-shadow:0 2px 8px rgba(0,0,0,.3)}
.page-hero__en{font-size:1.3rem;letter-spacing:.2em;opacity:.9;margin-bottom:12px}
.page-hero__main{font-size:3.2rem;font-weight:900;line-height:1.4;margin-bottom:12px;letter-spacing:.05em}
.page-hero__main em{font-style:normal;color:var(--yellow01)}
.page-hero__sub{font-size:1.5rem;opacity:.95}

/* --- Lead Block --- */
.lead-block{max-width:900px;margin:0 auto;text-align:center;font-size:1.6rem;line-height:2;color:#444}

/* --- Points 2col variant --- */
.points__list--2col{grid-template-columns:repeat(2,1fr);max-width:860px;margin:0 auto}

/* --- Branch Info (access page) --- */

/* --- Service Cards --- */
.service__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.service__card{background:var(--white);border-radius:12px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.06);transition:transform .3s}
.service__card:hover{transform:translateY(-4px)}
.service__thumb{width:100%;height:200px;overflow:hidden}
.service__thumb img{width:100%;height:100%;object-fit:cover}
.service__body{padding:24px}
.service__title{font-size:2rem;font-weight:700;color:var(--blue03);margin-bottom:8px;padding-left:12px;border-left:4px solid var(--blue02)}
.service__desc{font-size:1.4rem;color:#555;line-height:1.8;margin-bottom:16px}
.service__tags{display:flex;flex-wrap:wrap;gap:6px}
.service__tags li{font-size:1.2rem;padding:4px 10px;background:var(--bg-light);color:var(--blue02);border-radius:4px;font-weight:500}

/* --- Area Main (札幌市10区・最重要) --- */
.area-main{background:linear-gradient(135deg,#f0f7fc 0%,#e6f1f9 100%);border-radius:16px;padding:40px;margin-bottom:48px;border:2px solid var(--blue01);position:relative;overflow:hidden}
.area-main::before{content:"";position:absolute;top:-20px;right:-20px;width:160px;height:160px;background:radial-gradient(circle,rgba(67,173,233,.15) 0%,transparent 70%);border-radius:50%}
.area-main__head{text-align:center;margin-bottom:32px;position:relative}
.area-main__badge{display:inline-block;background:var(--blue02);color:var(--white);font-size:1.1rem;font-weight:700;letter-spacing:.15em;padding:4px 14px;border-radius:4px;margin-bottom:12px}
.area-main__title{font-size:2.8rem;font-weight:900;color:var(--blue03);margin-bottom:10px;letter-spacing:.03em}
.area-main__lead{font-size:1.4rem;color:var(--gray02);line-height:1.7}
.area-main__list{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,180px));gap:12px;position:relative;justify-content:center}
.area-main__list li{background:var(--white);border-radius:8px;padding:18px 12px;text-align:center;box-shadow:0 2px 8px rgba(0,0,0,.06);transition:transform .2s,box-shadow .2s;border-top:3px solid var(--blue02);min-width:0}
.area-main__list li:hover{transform:translateY(-3px);box-shadow:0 6px 16px rgba(0,0,0,.1)}
.area-main__name{display:block;font-size:1.8rem;font-weight:700;color:var(--blue03)}

/* --- Area Sub (近郊・道内) --- */
.area-sub{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:28px;margin-bottom:16px}
.area-sub__block{background:var(--white);border-radius:10px;padding:28px;border:1px solid #e8edf2}
.area-sub__head{margin-bottom:20px;padding-bottom:16px;border-bottom:1px dashed #d5dde6}
.area-sub__badge{display:inline-block;background:var(--bg-light);color:var(--blue02);font-size:1rem;font-weight:700;letter-spacing:.1em;padding:3px 10px;border-radius:3px;margin-bottom:8px}
.area-sub__title{font-size:1.8rem;font-weight:700;color:var(--blue03);margin-bottom:6px}
.area-sub__note{font-size:1.2rem;color:var(--gray02);line-height:1.6}
.area-sub__list{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:6px 12px}
.area-sub__list li{font-size:1.4rem;color:#333;padding:8px 0 8px 20px;position:relative}
.area-sub__list li::before{content:"";position:absolute;left:0;top:14px;width:8px;height:8px;background:var(--blue01);border-radius:50%}

/* --- FAQ --- */
.faq-list{max-width:860px;margin:0 auto;display:flex;flex-direction:column;gap:16px}
.faq-item{background:var(--white);border-radius:8px;border:1px solid #e8edf2;padding:20px 24px}
.faq-item__q,.faq-item__a{display:flex;gap:14px;align-items:flex-start;font-size:1.4rem;line-height:1.8}
.faq-item__q{font-weight:700;color:var(--blue03);margin-bottom:10px;padding-bottom:10px;border-bottom:1px dashed #e8edf2}
.faq-item__a{color:#444}
.faq-item__mark{flex-shrink:0;width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:900;font-size:1.3rem}
.faq-item__q .faq-item__mark{background:var(--blue03);color:var(--white)}
.faq-item__a .faq-item__mark{background:var(--yellow01);color:var(--blue03)}

/* --- Related Links --- */
.related-links{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;max-width:900px;margin:0 auto}
.related-links__card{display:flex;gap:20px;align-items:center;background:var(--white);border-radius:10px;padding:24px;box-shadow:0 2px 12px rgba(0,0,0,.06);transition:transform .2s,box-shadow .2s;color:inherit}
.related-links__card:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,0,0,.1);opacity:1}
.related-links__icon{flex-shrink:0;width:64px;height:64px;background:#eef6fb;border-radius:50%;display:flex;align-items:center;justify-content:center}
.related-links__title{font-size:1.6rem;font-weight:700;color:var(--blue03);margin-bottom:4px}
.related-links__desc{font-size:1.3rem;color:var(--gray02);line-height:1.6;margin-bottom:6px}
.related-links__arrow{font-size:1.2rem;color:var(--blue02);font-weight:700}

/* --- Areas Grid (legacy) --- */
.areas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;max-width:900px;margin:0 auto}
.areas-col{background:var(--white);border-radius:8px;padding:24px;border-top:4px solid var(--blue02)}
.areas-col__title{font-size:1.6rem;font-weight:700;color:var(--blue03);margin-bottom:16px;text-align:center}
.areas-col__list{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 12px}
.areas-col__list li{font-size:1.4rem;color:#333;padding:6px 0 6px 18px;position:relative}
.areas-col__list li::before{content:"";position:absolute;left:0;top:12px;width:10px;height:10px;background:var(--blue01);border-radius:50%}
.areas-note{text-align:center;font-size:1.3rem;color:var(--gray02);margin-top:32px}

/* --- Climate Cards --- */
.climate-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;max-width:960px;margin:0 auto}
.climate-card{display:flex;background:var(--white);border-radius:10px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.06)}
.climate-card__thumb{flex:0 0 180px;height:auto}
.climate-card__thumb img{width:100%;height:100%;object-fit:cover}
.climate-card__body{padding:20px;flex:1}
.climate-card__title{font-size:1.6rem;font-weight:700;color:var(--blue03);margin-bottom:8px}
.climate-card__text{font-size:1.3rem;color:#555;line-height:1.7}

/* --- Paint Cards --- */
.paint-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.paint-card{background:var(--white);border-radius:8px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.06);transition:transform .3s}
.paint-card:hover{transform:translateY(-3px)}
.paint-card__thumb{width:100%;height:160px;overflow:hidden}
.paint-card__thumb img{width:100%;height:100%;object-fit:cover}
.paint-card__title{font-size:1.5rem;font-weight:700;color:var(--blue03);margin:16px 16px 4px}
.paint-card__meta{font-size:1.2rem;color:var(--blue02);font-weight:700;margin:0 16px 8px}
.paint-card__desc{font-size:1.3rem;color:#555;line-height:1.7;padding:0 16px 20px}

/* --- Subsidy Table --- */
.subsidy-table-wrap{overflow-x:auto;background:var(--white);border-radius:8px;box-shadow:0 2px 12px rgba(0,0,0,.06)}
.subsidy-table{width:100%;border-collapse:collapse;font-size:1.4rem}
.subsidy-table th{background:var(--blue03);color:var(--white);padding:14px 16px;text-align:left;font-weight:700;white-space:nowrap}
.subsidy-table td{padding:16px;border-bottom:1px solid #e8edf2;color:#333;line-height:1.6;vertical-align:top}
.subsidy-table tr:last-child td{border-bottom:none}
.subsidy-table tr:nth-child(even) td{background:#fafbfc}
.subsidy-note{font-size:1.2rem;color:var(--gray02);line-height:1.8;margin-top:16px}

/* --- Access --- */
.access-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:32px;align-items:stretch}
.access-map{border-radius:8px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.08);min-height:360px;background:#e8edf2}
.access-map iframe{width:100%;height:100%;min-height:360px;border:0;display:block}
.access-map__placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:360px;text-align:center;color:var(--gray02);background:linear-gradient(135deg,#eef4f9 0%,#dce8f2 100%);padding:24px}
.access-map__placeholder p{font-size:1.4rem;margin-top:12px;line-height:1.6}
.access-map__placeholder small{font-size:1.1rem;color:#999}
.access-info{background:var(--white);border-radius:8px;padding:28px;border:1px solid #e8edf2}
.access-info__list dt{font-size:1.5rem;font-weight:700;color:var(--blue03);margin-bottom:6px;display:flex;align-items:center;gap:8px}
.access-info__list dd{font-size:1.4rem;color:#333;line-height:1.7;margin-bottom:20px;padding-left:32px}
.access-info__list dd:last-child{margin-bottom:0}
.access-info__icon{font-size:2rem}
.access-info__note{display:block;font-size:1.2rem;color:var(--gray02);margin-top:4px}

/* ============================================
   Responsive
   ============================================ */
@media screen and (max-width: 768px){
  :root{--header-height:88px;--header-top-h:28px;--header-main-h:60px}
  .pc-only{display:none}
  .sp-only{display:block}

  .l-header__top{height:var(--header-top-h);font-size:1.1rem}
  .l-header__top .inner{justify-content:flex-start}
  .l-header__top-right{display:none}
  .l-header__branch{font-size:1.2rem}
  .l-header__main .btn-header-cta{display:none}
  .l-header__burger{display:flex}
  .nav-overlay{display:block;pointer-events:none}
  body.nav-open .nav-overlay{pointer-events:auto}

  /* Mobile drawer nav */
  .l-header__nav{display:flex;flex-direction:column;align-items:stretch;gap:0;position:fixed;top:var(--header-height);right:0;width:min(85vw,320px);height:calc(100vh - var(--header-height));background:var(--white);box-shadow:-4px 0 20px rgba(0,0,0,.15);padding:20px 0;z-index:999;transform:translateX(100%);transition:transform .3s ease;overflow-y:auto}
  body.nav-open .l-header__nav{transform:translateX(0)}
  .l-header__nav a{font-size:1.5rem;padding:16px 24px;border-bottom:1px solid #eef2f6;color:var(--blue03);font-weight:500}
  .l-header__nav a::after{display:none}
  .l-header__nav a:hover{background:var(--bg-light)}

  /* SP hero: FVエリアを iPhone SE/12 Pro でも一画面に収める高さに圧縮 */
  .hero{height:auto;min-height:auto;padding:32px 0 24px}
  .hero::after{background:linear-gradient(180deg,rgba(32,68,131,.8) 0%,rgba(32,68,131,.6) 60%,rgba(0,138,210,.4) 100%)}
  .hero__tagline{font-size:1.3rem;margin-bottom:8px}
  .hero__main{font-size:2.4rem;margin-bottom:8px}
  .hero__sub{font-size:1.4rem;margin-bottom:12px}
  .hero__area{font-size:1.2rem;padding:6px 12px;margin-bottom:14px}
  .hero__btns{flex-direction:column;align-items:stretch;gap:10px}
  .hero__btns .btn-cta{width:100%;justify-content:center;padding:12px 16px;font-size:1.5rem}

  /* ヌリカエバナー(SP): 絶対配置を解除、CTA下に独立配置 + CTAとの間に余裕(48px) */
  .hero__nurikae{
    position:static !important;
    top:auto !important;
    right:auto !important;
    width:50% !important;
    max-width:160px !important;
    min-width:140px !important;
    margin:28px auto 0 !important;
  }

  .section{padding:56px 0}
  .section-title{font-size:2.4rem}

  .points__list{grid-template-columns:1fr;gap:20px}
  .points__item{padding:28px 20px}

  .works__grid{grid-template-columns:1fr;gap:16px}
  .works__thumb{height:180px}

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

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

  .cta-band__text{font-size:1.6rem}
  .cta-band__btns{flex-direction:column;align-items:stretch;padding:0 20px}
  .cta-band__tel-num{font-size:2rem}

  .l-footer__top{flex-direction:column}
  .l-footer__nav{flex-direction:column;gap:24px}

  .floating-cta{display:flex}
  body{padding-bottom:64px}

  /* Area page - responsive */
  .page-hero{height:auto;min-height:220px;padding:40px 0}
  .page-hero__main{font-size:2rem}
  .page-hero__sub{font-size:1.3rem}
  .lead-block{font-size:1.4rem;text-align:left}
  .points__list--2col{grid-template-columns:1fr}
  .branch-info{grid-template-columns:1fr;gap:24px;padding:20px}
  .branch-info__list{grid-template-columns:90px 1fr;font-size:1.3rem}
  .service__grid{grid-template-columns:1fr;gap:16px}
  .areas-grid{grid-template-columns:1fr;gap:16px}
  .area-main{padding:24px 16px}
  .area-main__title{font-size:2rem}
  .area-main__lead{font-size:1.2rem}
  .area-main__list{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px}
  .area-main__list li{padding:14px 8px}
  .area-main__name{font-size:1.5rem}
  .area-sub{gap:16px}
  .area-sub__block{padding:20px 16px}
  .area-sub__list{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}
  .faq-item{padding:16px}
  .faq-item__q,.faq-item__a{font-size:1.3rem}
  .related-links{grid-template-columns:1fr;gap:12px}
  .related-links__card{padding:16px;gap:14px}
  .related-links__icon{width:48px;height:48px}
  .related-links__icon svg{width:32px;height:32px}
  .climate-grid{grid-template-columns:1fr}
  .climate-card__thumb{flex:0 0 120px}
  .paint-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .paint-card__thumb{height:120px}
  .subsidy-table{font-size:1.2rem}
  .subsidy-table th,.subsidy-table td{padding:10px}
  .access-grid{grid-template-columns:1fr;gap:20px}
  .access-map{min-height:240px}
  .access-map iframe{min-height:240px}
}

@media screen and (max-width: 480px){
  .hero__main{font-size:2.4rem}
  .section-title{font-size:2rem}
}

/* --- Service page --- */
.service-grid{display:grid;grid-template-columns:1fr;gap:32px;max-width:1100px;margin:0 auto}
.service-card{display:grid;grid-template-columns:1fr 1.2fr;gap:0;background:#fff;border:1px solid #e6edf4;border-radius:10px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.05)}
.service-card__thumb{overflow:hidden}
.service-card__thumb img{width:100%;height:100%;object-fit:cover;display:block;min-height:220px}
.service-card__body{padding:28px 32px}
.service-card__en{font-size:1.2rem;letter-spacing:.18em;color:var(--blue02);font-weight:700;margin-bottom:4px}
.service-card__title{font-size:2.2rem;font-weight:700;color:var(--blue03);margin-bottom:12px}
.service-card__desc{font-size:1.45rem;line-height:1.9;color:#333;margin-bottom:14px}
.service-card__list{list-style:disc;padding-left:1.4em;font-size:1.35rem;line-height:1.85;color:#444;margin:0}

.target-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1100px;margin:0 auto}
.target-card{background:#fff;border:1px solid #e6edf4;border-radius:8px;padding:28px 24px;text-align:center}
.target-card__icon{display:flex;justify-content:center;margin-bottom:14px}
.target-card h3{font-size:1.7rem;font-weight:700;color:var(--blue03);margin-bottom:10px}
.target-card p{font-size:1.35rem;line-height:1.85;color:#444}

.flow-list{list-style:none;padding:0;margin:0;max-width:860px;margin:0 auto;counter-reset:flow}
.flow-list__item{display:flex;gap:20px;align-items:flex-start;padding:20px 0;border-bottom:1px dashed #d8e2ed}
.flow-list__item:last-child{border-bottom:0}
.flow-list__num{flex:0 0 56px;height:56px;border-radius:50%;background:var(--blue03);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1.8rem}
.flow-list__body{flex:1}
.flow-list__body h3{font-size:1.6rem;font-weight:700;color:var(--blue03);margin-bottom:6px}
.flow-list__body p{font-size:1.4rem;line-height:1.85;color:#444;margin:0}

@media screen and (max-width: 768px){
  .service-card{grid-template-columns:1fr}
  .service-card__thumb img{min-height:180px;max-height:220px}
  .service-card__body{padding:20px 22px}
  .service-card__title{font-size:1.8rem}
  .target-grid{grid-template-columns:1fr;gap:14px}
  .flow-list__item{gap:14px}
  .flow-list__num{flex-basis:44px;height:44px;font-size:1.5rem}
}

/* --- About page --- */
.partner-box{background:linear-gradient(135deg,#f4f8ff 0%,#eaf3fb 100%);border:1px solid #d7e3f2;border-radius:12px;padding:40px;margin-top:8px}
.partner-box__head{border-bottom:1px solid #c9d7e8;padding-bottom:20px;margin-bottom:24px}
.partner-box__label{font-size:1.2rem;letter-spacing:.12em;color:var(--blue02);font-weight:700;margin-bottom:8px}
.partner-box__title{font-size:2.2rem;font-weight:700;color:var(--blue03);line-height:1.5}
.partner-box__title em{font-style:normal;background:linear-gradient(transparent 60%,#fff2a8 60%);padding:0 2px}
.partner-box__body > p{font-size:1.5rem;line-height:1.85;margin-bottom:24px}
.partner-box__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:20px}
.partner-box__item{background:#fff;border-radius:8px;padding:20px;border:1px solid #e6edf4}
.partner-box__item-label{font-weight:700;color:var(--blue03);font-size:1.4rem;margin-bottom:8px}
.partner-box__item p:last-child{font-size:1.35rem;line-height:1.75;color:#4a5566}
.partner-box__note{font-size:1.2rem;color:#6b7280;margin-top:8px}
.partner-note{background:#f4f8ff;border-left:4px solid var(--blue02);padding:14px 18px;border-radius:4px;font-size:1.4rem;line-height:1.75;margin-top:16px}
.partner-note a{color:var(--blue02);font-weight:700;margin-left:4px}
@media (max-width:768px){
  .partner-box{padding:24px 16px}
  .partner-box__title{font-size:1.8rem}
  .partner-box__grid{grid-template-columns:1fr;gap:12px}
}
.warranty-table{max-width:860px;margin:24px 0 20px}
.warranty-table table{width:100%;border-collapse:collapse;background:#fff;border:1px solid #e6edf4;border-radius:8px;overflow:hidden;font-size:1.45rem}
.warranty-table thead th{background:var(--blue03);color:#fff;padding:14px 16px;text-align:left;font-weight:700;font-size:1.4rem}
.warranty-table tbody td{padding:14px 16px;border-top:1px solid #e6edf4;color:#333}
.warranty-table tbody tr:nth-child(even){background:#f5f8fc}
.warranty-table__note{font-size:1.2rem;color:#888;margin-top:8px}

.timeline{max-width:860px;margin:24px 0 16px;position:relative}
.timeline__item{display:flex;gap:24px;align-items:flex-start;padding:20px 0;border-bottom:1px dashed #d8e2ed}
.timeline__item:last-child{border-bottom:0}
.timeline__mark{flex:0 0 90px;height:90px;border-radius:50%;background:var(--blue02);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:2rem;letter-spacing:0}
.timeline__body{flex:1}
.timeline__body h3{font-size:1.7rem;font-weight:700;color:var(--blue03);margin-bottom:8px}
.timeline__body p{font-size:1.4rem;line-height:1.85;color:#444;margin:0}

@media screen and (max-width: 768px){
  .warranty-table{font-size:1.3rem}
  .warranty-table thead th,.warranty-table tbody td{padding:10px 12px}
  .timeline__item{gap:14px;padding:16px 0}
  .timeline__mark{flex-basis:64px;height:64px;font-size:1.5rem}
  .timeline__body h3{font-size:1.5rem}
}

/* --- Reviews page intro --- */
.intro-block{max-width:860px;margin:0 auto;font-size:1.55rem;line-height:2;color:#333}
.intro-block p{margin-bottom:1.2em}
.intro-block__lead{font-size:2.2rem;font-weight:700;color:var(--blue03);margin-bottom:1em;text-align:center;line-height:1.6}
.intro-block strong{color:var(--blue02);font-weight:700}
@media screen and (max-width: 768px){
  .intro-block{font-size:1.45rem}
  .intro-block__lead{font-size:1.8rem}
}

/* --- Special page --- */
.toc{max-width:780px;margin:0 auto;background:#f5f8fc;border-left:4px solid var(--blue02);border-radius:4px;padding:24px 28px}
.toc__title{font-weight:700;color:var(--blue03);margin-bottom:12px;font-size:1.5rem}
.toc__list{list-style:decimal;padding-left:1.6em;margin:0;color:#333;line-height:1.9;font-size:1.5rem}
.toc__list a{color:var(--blue02);text-decoration:none}
.toc__list a:hover{text-decoration:underline}

.article{max-width:860px;margin:0 auto;font-size:1.55rem;line-height:1.95;color:#222}
.article p{margin-bottom:1.2em}
.article strong{color:var(--blue03);font-weight:700}
.article__cta{text-align:center;margin:32px 0 0}

.callout{background:#fff;border:1px solid #e6edf4;border-left:4px solid var(--yellow01);border-radius:4px;padding:20px 24px;margin:24px 0}
.callout__label{font-weight:700;color:var(--blue03);margin-bottom:10px;font-size:1.4rem}
.callout__list{list-style:disc;padding-left:1.4em;margin:0;font-size:1.4rem;line-height:1.9;color:#333}

.points__list--3col-min{grid-template-columns:repeat(3,1fr);gap:20px;margin:24px 0 28px}
.points__item--plain{background:#fff;border:1px solid #e6edf4;border-radius:8px;padding:24px;text-align:left;box-shadow:none}
.points__item--plain .points__num{font-size:2.8rem;color:var(--blue02);line-height:1;margin-bottom:4px}
.points__item--plain .points__label{font-size:1.7rem;font-weight:700;color:var(--blue03);margin-bottom:10px}
.points__item--plain .points__desc{font-size:1.35rem;line-height:1.8;color:#444}

.reason-list{margin:8px 0;max-width:900px}
.reason-list__row{background:#fff;border:1px solid #e6edf4;border-radius:8px;padding:20px 24px;margin-bottom:14px}
.reason-list__row dt{font-weight:700;color:var(--blue03);font-size:1.6rem;margin-bottom:8px}
.reason-list__row dd{margin:0;font-size:1.45rem;line-height:1.9;color:#333}
.reason-list__row dd strong{color:var(--blue02)}

.stat-list{list-style:none;margin:20px 0 24px;padding:0;display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.stat-list li{background:#fff;border:1px solid #e6edf4;border-radius:8px;padding:18px 22px;display:grid;grid-template-columns:minmax(0,38%) minmax(0,1fr);gap:14px;align-items:center}
.stat-list__num{font-weight:900;color:var(--blue02);font-size:1.6rem;line-height:1.35;word-break:break-word;overflow-wrap:anywhere}
.stat-list__text{font-size:1.35rem;line-height:1.7;color:#333;word-break:break-word}

/* <details>/<summary> adjustment */
.faq-item summary.faq-item__q{list-style:none;cursor:pointer;user-select:none}
.faq-item summary.faq-item__q::-webkit-details-marker{display:none}
.faq-item summary.faq-item__q::after{content:'＋';margin-left:auto;color:var(--blue02);font-weight:900;font-size:1.8rem;flex-shrink:0}
.faq-item[open] summary.faq-item__q::after{content:'−'}

@media screen and (max-width: 768px){
  .toc{padding:18px 20px}
  .article{font-size:1.45rem}
  .points__list--3col-min{grid-template-columns:1fr}
  .stat-list{grid-template-columns:1fr}
  .reason-list__row{padding:16px 18px}
  .reason-list__row dt{font-size:1.5rem}
}

/* --- Access page --- */
.branch-info{max-width:880px;margin:0 auto;background:#fff;border:1px solid #e6edf4;border-radius:8px;overflow:hidden}
.branch-info__list{margin:0}
.branch-info__row{display:grid;grid-template-columns:180px 1fr;border-bottom:1px solid #e6edf4}
.branch-info__row:last-child{border-bottom:0}
.branch-info__row dt{padding:20px 24px;background:#f5f8fc;color:var(--blue03);font-weight:700;font-size:1.4rem}
.branch-info__row dd{padding:20px 24px;font-size:1.5rem;line-height:1.8;color:#222}
.branch-info__row dd small{font-size:1.2rem;color:#666}
.branch-info__row dd a{color:var(--blue02);text-decoration:none;font-weight:700}
.branch-info__row dd a:hover{text-decoration:underline}

.gmap{max-width:1100px;margin:0 auto;border-radius:8px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.06)}
.gmap iframe{display:block;width:100%;height:480px;border:0}
.gmap__link{text-align:center;margin-top:16px;font-size:1.4rem}
.gmap__link a{color:var(--blue02);font-weight:700;text-decoration:none}
.gmap__link a:hover{text-decoration:underline}

.access-list{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1100px;margin:0 auto}
.access-item{background:#fff;border:1px solid #e6edf4;border-radius:8px;padding:28px 24px;text-align:center}
.access-item__icon{display:flex;justify-content:center;margin-bottom:16px}
.access-item__title{font-size:1.7rem;font-weight:700;color:var(--blue03);margin-bottom:12px}
.access-item__text{font-size:1.4rem;line-height:1.8;color:#333}

@media screen and (max-width: 768px){
  .branch-info__row{grid-template-columns:110px 1fr}
  .branch-info__row dt{padding:14px 12px;font-size:1.3rem}
  .branch-info__row dd{padding:14px 16px;font-size:1.4rem}
  .gmap iframe{height:340px}
  .access-list{grid-template-columns:1fr;gap:16px}
}
