/*
Theme Name: 宮原窯業 リフォームLP
Theme URI: https://reformyasan.net/
Author: LP Creator Athena
Description: reformyasan.net トップページ用のリフォーム相談LPテーマ。既存投稿を残しながら、トップページをLP化します。
Version: 1.6.0
Text Domain: miyahara-reform
*/

:root{
  --mr-blue:#0d4f8b;
  --mr-blue-deep:#083b68;
  --mr-blue-soft:#eaf4fb;
  --mr-sky:#f5fbff;
  --mr-green:#2f7d5c;
  --mr-orange:#f49a2a;
  --mr-red:#bf3131;
  --mr-text:#1f2933;
  --mr-muted:#64748b;
  --mr-line:#dbe7f0;
  --mr-bg:#ffffff;
  --mr-card:#ffffff;
  --mr-cream:#fff8ec;
  --mr-radius:18px;
  --mr-shadow:0 18px 45px rgba(12,50,84,.12);
  --mr-max:1120px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  color:var(--mr-text);
  background:#fff;
  font-family:-apple-system,BlinkMacSystemFont,"Hiragino Sans","Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,sans-serif;
  line-height:1.8;
  letter-spacing:.02em;
}
body.admin-bar .mr-header{top:32px;}
a{color:inherit;}
img{max-width:100%;height:auto;display:block;}
button,input,textarea,select{font:inherit;}
.mr-page{overflow:hidden;background:#fff;}
.mr-container{width:min(100% - 32px,var(--mr-max));margin-inline:auto;}
.mr-narrow{width:min(100% - 32px,860px);margin-inline:auto;}
.mr-section{padding:78px 0;}
.mr-section--soft{background:linear-gradient(180deg,#f7fbff 0%,#fff 100%);}
.mr-section--cream{background:linear-gradient(180deg,#fff8ec 0%,#fff 100%);}
.mr-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:13px;
  font-weight:800;
  color:var(--mr-blue);
  letter-spacing:.08em;
  background:var(--mr-blue-soft);
  border-radius:999px;
  padding:6px 13px;
  margin-bottom:14px;
}
.mr-eyebrow::before{
  content:"";
  width:8px;height:8px;border-radius:99px;background:var(--mr-orange);
}
.mr-section-title{
  margin:0 0 18px;
  font-size:clamp(27px,4vw,42px);
  line-height:1.35;
  letter-spacing:.02em;
  color:var(--mr-blue-deep);
}
.mr-section-lead{
  margin:0;
  color:#435466;
  font-size:clamp(16px,2vw,18px);
}
.mr-center{text-align:center;}
.mr-note{font-size:13px;color:var(--mr-muted);line-height:1.7;}
.mr-br-sp{display:none;}

/* Header */
.mr-header{
  position:sticky;
  top:0;
  z-index:80;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(219,231,240,.86);
}
.mr-header__inner{
  width:min(100% - 24px,var(--mr-max));
  height:72px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-inline:auto;
}
.mr-brand{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  min-width:0;
}
.mr-brand__mark{
  width:42px;height:42px;
  border-radius:12px;
  background:linear-gradient(135deg,var(--mr-blue),var(--mr-green));
  color:#fff;
  display:grid;
  place-items:center;
  font-weight:900;
  box-shadow:0 10px 24px rgba(13,79,139,.22);
}
.mr-brand__text{line-height:1.25;min-width:0;}
.mr-brand__name{
  display:block;
  font-size:17px;
  font-weight:900;
  color:var(--mr-blue-deep);
}
.mr-brand__sub{
  display:block;
  font-size:12px;
  color:var(--mr-muted);
  white-space:nowrap;
}
.mr-header__nav{
  display:flex;
  align-items:center;
  gap:18px;
  font-size:14px;
  font-weight:700;
}
.mr-header__nav a{
  text-decoration:none;
  color:#334155;
}
.mr-header__nav a:hover{color:var(--mr-blue);}
.mr-header__cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 16px;
  border-radius:999px;
  background:var(--mr-orange);
  color:#fff!important;
  text-decoration:none;
  font-weight:900;
  box-shadow:0 10px 24px rgba(244,154,42,.28);
}

/* Hero */
.mr-hero{
  position:relative;
  background:
    radial-gradient(circle at 12% 15%,rgba(47,125,92,.16),transparent 30%),
    radial-gradient(circle at 85% 20%,rgba(244,154,42,.20),transparent 28%),
    linear-gradient(180deg,#f4fbff 0%,#ffffff 78%);
  padding:74px 0 56px;
}
.mr-hero::after{
  content:"";
  position:absolute;
  inset:auto -80px -160px auto;
  width:360px;height:360px;
  border-radius:50%;
  background:rgba(13,79,139,.06);
}
.mr-hero__grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(320px,.95fr);
  gap:42px;
  align-items:center;
}
.mr-hero__label{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 14px;
  border-radius:999px;
  background:#fff;
  border:1px solid var(--mr-line);
  color:var(--mr-blue);
  font-weight:900;
  font-size:14px;
  box-shadow:0 8px 20px rgba(12,50,84,.08);
}
.mr-hero__title{
  margin:18px 0 18px;
  font-size:clamp(34px,5.4vw,58px);
  line-height:1.18;
  letter-spacing:.015em;
  color:var(--mr-blue-deep);
}
.mr-hero__subtitle{
  margin:0 0 18px;
  font-size:clamp(20px,3vw,30px);
  line-height:1.5;
  font-weight:900;
  color:#143c5c;
}
.mr-hero__lead{
  margin:0 0 26px;
  font-size:18px;
  color:#42576b;
}
.mr-cta-row{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  align-items:center;
}
.mr-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:54px;
  padding:0 22px;
  border:0;
  border-radius:999px;
  background:var(--mr-orange);
  color:#fff;
  text-decoration:none;
  font-weight:900;
  box-shadow:0 14px 28px rgba(244,154,42,.28);
  cursor:pointer;
}
.mr-btn:hover{filter:brightness(.98);transform:translateY(-1px);}
.mr-btn--sub{
  background:#fff;
  color:var(--mr-blue);
  border:1px solid var(--mr-line);
  box-shadow:0 10px 22px rgba(12,50,84,.08);
}
.mr-hero__note{
  margin-top:12px;
  color:var(--mr-muted);
  font-size:14px;
}
.mr-hero-card{
  background:#fff;
  border:1px solid var(--mr-line);
  border-radius:28px;
  padding:24px;
  box-shadow:var(--mr-shadow);
}
.mr-hero-card__image{
  min-height:300px;
  border-radius:22px;
  background:
    linear-gradient(135deg,rgba(13,79,139,.95),rgba(47,125,92,.78)),
    repeating-linear-gradient(135deg,rgba(255,255,255,.18) 0,rgba(255,255,255,.18) 2px,transparent 2px,transparent 18px);
  color:#fff;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:24px;
  position:relative;
  overflow:hidden;
}
.mr-hero-card__image::before{
  content:"";
  position:absolute;
  top:24px;right:24px;
  width:92px;height:92px;
  border:16px solid rgba(255,255,255,.22);
  border-radius:50%;
}
.mr-hero-card__image strong{
  position:relative;
  z-index:1;
  display:block;
  font-size:27px;
  line-height:1.35;
}
.mr-hero-card__image span{
  position:relative;
  z-index:1;
  margin-top:8px;
  font-weight:700;
  opacity:.94;
}
.mr-trust-list{
  list-style:none;
  padding:0;
  margin:16px 0 0;
  display:grid;
  gap:10px;
}
.mr-trust-list li{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-weight:800;
  color:#334155;
}
.mr-trust-list li::before{
  content:"✓";
  width:22px;height:22px;
  flex:0 0 22px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:#eaf7f1;
  color:var(--mr-green);
  font-size:13px;
  margin-top:2px;
}

/* Pain */
.mr-pain-grid{
  margin-top:34px;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.mr-pain-item{
  background:#fff;
  border:1px solid var(--mr-line);
  border-radius:16px;
  padding:16px 16px 16px 44px;
  position:relative;
  box-shadow:0 10px 20px rgba(12,50,84,.05);
}
.mr-pain-item::before{
  content:"";
  position:absolute;
  left:16px;top:23px;
  width:12px;height:12px;
  border-radius:50%;
  background:var(--mr-orange);
  box-shadow:0 0 0 5px rgba(244,154,42,.14);
}
.mr-message-box{
  margin-top:28px;
  background:var(--mr-blue-deep);
  color:#fff;
  padding:22px;
  border-radius:20px;
  text-align:center;
  font-weight:800;
}

/* Split */
.mr-split{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);
  gap:42px;
  align-items:center;
}
.mr-quote-stack{
  display:grid;
  gap:14px;
}
.mr-quote-bubble{
  background:#fff;
  border:1px solid var(--mr-line);
  border-radius:18px;
  padding:17px 18px;
  box-shadow:0 10px 22px rgba(12,50,84,.07);
  color:#334155;
  font-weight:800;
}
.mr-text-card{
  background:#fff;
  border:1px solid var(--mr-line);
  border-radius:24px;
  padding:30px;
  box-shadow:var(--mr-shadow);
}

/* Reasons */
.mr-reasons{
  margin-top:36px;
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:14px;
}
.mr-reason{
  background:#fff;
  border:1px solid var(--mr-line);
  border-radius:20px;
  padding:22px 18px;
  box-shadow:0 12px 28px rgba(12,50,84,.08);
}
.mr-reason__num{
  display:inline-grid;
  place-items:center;
  width:38px;height:38px;
  border-radius:12px;
  background:var(--mr-blue-soft);
  color:var(--mr-blue);
  font-weight:900;
  margin-bottom:12px;
}
.mr-reason h3{
  margin:0 0 10px;
  font-size:18px;
  line-height:1.5;
  color:var(--mr-blue-deep);
}
.mr-reason p{margin:0;color:#475569;font-size:15px;}

/* Services */
.mr-service-grid{
  margin-top:36px;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.mr-service{
  background:#fff;
  border:1px solid var(--mr-line);
  border-radius:20px;
  padding:24px;
  box-shadow:0 12px 26px rgba(12,50,84,.07);
}
.mr-service__icon{
  width:46px;height:46px;
  border-radius:14px;
  background:linear-gradient(135deg,var(--mr-blue),var(--mr-green));
  color:#fff;
  display:grid;
  place-items:center;
  font-size:23px;
  margin-bottom:14px;
}
.mr-service h3{margin:0 0 10px;color:var(--mr-blue-deep);font-size:20px;}
.mr-service p{margin:0;color:#475569;}

/* Voices */
.mr-voice-grid{
  margin-top:36px;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.mr-voice{
  background:#fff;
  border:1px solid var(--mr-line);
  border-radius:22px;
  padding:24px;
  box-shadow:var(--mr-shadow);
}
.mr-voice__quote{
  margin:0 0 14px;
  color:var(--mr-blue-deep);
  font-size:19px;
  line-height:1.6;
  font-weight:900;
}
.mr-voice p{margin:0;color:#475569;}

/* Flow */
.mr-flow{
  margin-top:38px;
  display:grid;
  gap:16px;
  counter-reset:flow;
}
.mr-flow-item{
  counter-increment:flow;
  display:grid;
  grid-template-columns:82px minmax(0,1fr);
  gap:18px;
  align-items:flex-start;
  background:#fff;
  border:1px solid var(--mr-line);
  border-radius:20px;
  padding:22px;
  box-shadow:0 10px 22px rgba(12,50,84,.06);
}
.mr-flow-item__step{
  display:grid;
  place-items:center;
  min-height:66px;
  border-radius:16px;
  background:var(--mr-blue-soft);
  color:var(--mr-blue);
  font-weight:900;
  text-align:center;
  line-height:1.2;
}
.mr-flow-item__step span{font-size:12px;display:block;}
.mr-flow-item h3{margin:0 0 6px;color:var(--mr-blue-deep);}
.mr-flow-item p{margin:0;color:#475569;}

/* Areas */
.mr-area-box{
  margin-top:34px;
  background:#fff;
  border:1px solid var(--mr-line);
  border-radius:24px;
  padding:26px;
  box-shadow:var(--mr-shadow);
}
.mr-area-box h3{margin:0 0 8px;color:var(--mr-blue-deep);}
.mr-area-box p{margin:0 0 20px;color:#475569;}
.mr-area-list{
  display:grid;
  grid-template-columns:120px 1fr;
  gap:12px 18px;
  padding:16px 0;
  border-top:1px solid var(--mr-line);
}
.mr-area-list strong{color:var(--mr-blue);}
.mr-area-list span{color:#475569;}

/* FAQ */
.mr-faq{
  margin-top:34px;
  display:grid;
  gap:12px;
}
.mr-faq details{
  background:#fff;
  border:1px solid var(--mr-line);
  border-radius:16px;
  padding:0;
  overflow:hidden;
  box-shadow:0 8px 18px rgba(12,50,84,.05);
}
.mr-faq summary{
  cursor:pointer;
  padding:18px 20px;
  font-weight:900;
  color:var(--mr-blue-deep);
  list-style:none;
  display:flex;
  justify-content:space-between;
  gap:18px;
}
.mr-faq summary::-webkit-details-marker{display:none;}
.mr-faq summary::after{
  content:"+";
  flex:0 0 auto;
  color:var(--mr-orange);
  font-size:24px;
  line-height:1;
}
.mr-faq details[open] summary::after{content:"−";}
.mr-faq__answer{
  padding:0 20px 20px;
  color:#475569;
}

/* Posts */
.mr-post-grid{
  margin-top:34px;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.mr-post-card{
  background:#fff;
  border:1px solid var(--mr-line);
  border-radius:20px;
  overflow:hidden;
  box-shadow:0 12px 26px rgba(12,50,84,.07);
}
.mr-post-card__thumb{
  aspect-ratio:16/10;
  background:linear-gradient(135deg,var(--mr-blue-soft),#fff);
}
.mr-post-card__thumb img{width:100%;height:100%;object-fit:cover;}
.mr-post-card__body{padding:18px;}
.mr-post-card__date{font-size:13px;color:var(--mr-muted);}
.mr-post-card h3{font-size:17px;line-height:1.55;margin:5px 0 0;color:var(--mr-blue-deep);}
.mr-post-card a{text-decoration:none;}

/* Contact */
.mr-contact{
  background:
    radial-gradient(circle at 15% 15%,rgba(255,255,255,.16),transparent 26%),
    linear-gradient(135deg,var(--mr-blue-deep),var(--mr-blue));
  color:#fff;
}
.mr-contact .mr-section-title,
.mr-contact .mr-section-lead{color:#fff;}
.mr-contact-card{
  margin-top:32px;
  background:#fff;
  color:var(--mr-text);
  border-radius:26px;
  padding:30px;
  box-shadow:0 20px 60px rgba(0,0,0,.2);
}
.mr-form-message{
  margin-bottom:18px;
  padding:14px 16px;
  border-radius:14px;
  font-weight:800;
}
.mr-form-message--success{background:#eaf7f1;color:#116342;}
.mr-form-message--error{background:#fff0f0;color:#a52424;}
.mr-form-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}
.mr-field{display:grid;gap:6px;}
.mr-field--full{grid-column:1/-1;}
.mr-field label,
.mr-field legend{
  font-weight:900;
  color:#334155;
}
.mr-required{
  display:inline-block;
  margin-left:6px;
  padding:1px 7px;
  border-radius:999px;
  background:var(--mr-red);
  color:#fff;
  font-size:11px;
  vertical-align:middle;
}
.mr-field input,
.mr-field textarea,
.mr-field select{
  width:100%;
  border:1px solid #cbd5e1;
  border-radius:12px;
  padding:12px 13px;
  background:#fff;
  color:var(--mr-text);
}
.mr-field textarea{min-height:128px;resize:vertical;}
.mr-radio-group{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.mr-radio{
  display:flex;
  align-items:center;
  gap:8px;
  padding:10px 13px;
  border:1px solid #cbd5e1;
  border-radius:999px;
  background:#fff;
  cursor:pointer;
  font-weight:800;
}
.mr-radio input{width:auto;}
.mr-hidden{display:none!important;}
.mr-privacy{
  background:#f8fafc;
  border:1px solid var(--mr-line);
  border-radius:14px;
  padding:14px;
  font-size:14px;
}
.mr-privacy label{display:flex;gap:10px;align-items:flex-start;font-weight:700;color:#334155;}
.mr-privacy input{margin-top:6px;}
.mr-form-submit{margin-top:20px;text-align:center;}

/* Footer/Subpages */
.mr-footer{
  background:#0b2034;
  color:#dbeafe;
  padding:34px 0 82px;
}
.mr-footer a{color:#fff;}
.mr-footer__inner{
  width:min(100% - 32px,var(--mr-max));
  margin:auto;
  display:flex;
  justify-content:space-between;
  gap:24px;
  flex-wrap:wrap;
}
.mr-footer__brand{font-weight:900;color:#fff;font-size:18px;}
.mr-footer__meta{font-size:13px;color:#bdd4e8;}
.mr-sticky-cta{
  position:fixed;
  left:0;right:0;bottom:0;
  z-index:90;
  display:none;
  background:rgba(255,255,255,.96);
  border-top:1px solid var(--mr-line);
  padding:10px 14px calc(10px + env(safe-area-inset-bottom));
  box-shadow:0 -10px 26px rgba(12,50,84,.12);
}
.mr-sticky-cta .mr-btn{width:100%;min-height:50px;}

.mr-subpage{
  min-height:100vh;
  background:#f8fafc;
}
.mr-subpage-main{
  width:min(100% - 32px,900px);
  margin:0 auto;
  padding:42px 0 82px;
}
.mr-entry{
  background:#fff;
  border:1px solid var(--mr-line);
  border-radius:22px;
  padding:34px;
  box-shadow:var(--mr-shadow);
}
.mr-entry h1{
  margin:0 0 14px;
  line-height:1.35;
  color:var(--mr-blue-deep);
}
.mr-entry-meta{
  color:var(--mr-muted);
  font-size:14px;
  margin-bottom:20px;
}
.mr-entry-content h2,
.mr-entry-content h3{color:var(--mr-blue-deep);line-height:1.45;}
.mr-entry-content img{border-radius:14px;}
.mr-archive-list{display:grid;gap:16px;}
.mr-archive-item{
  background:#fff;
  border:1px solid var(--mr-line);
  border-radius:18px;
  padding:18px;
  box-shadow:0 10px 22px rgba(12,50,84,.06);
}
.mr-archive-item a{text-decoration:none;color:var(--mr-blue-deep);}
.nav-links{display:flex;justify-content:center;gap:8px;margin-top:24px;}
.nav-links a,.nav-links span{
  padding:8px 12px;
  border-radius:10px;
  background:#fff;
  border:1px solid var(--mr-line);
  text-decoration:none;
}
.nav-links .current{background:var(--mr-blue);color:#fff;}

@media (max-width: 980px){
  .mr-header__nav{display:none;}
  .mr-hero{padding-top:46px;}
  .mr-hero__grid,
  .mr-split{grid-template-columns:1fr;}
  .mr-reasons{grid-template-columns:repeat(2,minmax(0,1fr));}
  .mr-service-grid,
  .mr-voice-grid,
  .mr-post-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}

@media (max-width: 640px){
  body{font-size:15px;line-height:1.75;}
  body.admin-bar .mr-header{top:0;}
  .mr-container,
  .mr-narrow,
  .mr-subpage-main{width:min(100% - 24px,var(--mr-max));}
  .mr-section{padding:56px 0;}
  .mr-header__inner{height:62px;}
  .mr-brand__mark{width:38px;height:38px;}
  .mr-brand__name{font-size:15px;}
  .mr-brand__sub{font-size:10px;}
  .mr-header__cta{display:none;}
  .mr-hero{padding:34px 0 44px;}
  .mr-hero__title{font-size:34px;}
  .mr-hero__subtitle{font-size:19px;}
  .mr-hero__lead{font-size:16px;}
  .mr-hero-card{padding:16px;border-radius:22px;}
  .mr-hero-card__image{min-height:220px;padding:20px;}
  .mr-hero-card__image strong{font-size:22px;}
  .mr-cta-row .mr-btn{width:100%;}
  .mr-pain-grid,
  .mr-reasons,
  .mr-service-grid,
  .mr-voice-grid,
  .mr-post-grid,
  .mr-form-grid{grid-template-columns:1fr;}
  .mr-flow-item{grid-template-columns:1fr;gap:12px;}
  .mr-flow-item__step{width:74px;min-height:56px;}
  .mr-area-list{grid-template-columns:1fr;gap:4px;}
  .mr-contact-card{padding:20px;border-radius:20px;}
  .mr-entry{padding:22px;border-radius:18px;}
  .mr-sticky-cta{display:block;}
  .mr-br-sp{display:block;}
  .mr-section-title{font-size:28px;}
}


/* v1.1 text-light adjustment */
.mr-mini-list{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  list-style:none;
  padding:0;
  margin:18px 0 0;
}
.mr-mini-list li{
  background:var(--mr-blue-soft);
  color:var(--mr-blue-deep);
  border-radius:999px;
  padding:9px 12px;
  text-align:center;
  font-weight:900;
  font-size:14px;
}
.mr-area-box--compact{
  max-width:820px;
  margin-left:auto;
  margin-right:auto;
}
.mr-area-summary{
  text-align:center;
  font-size:17px;
}
.mr-area-details{
  margin-top:16px;
  border-top:1px solid var(--mr-line);
}
.mr-area-details summary{
  cursor:pointer;
  list-style:none;
  padding:16px 0 0;
  font-weight:900;
  color:var(--mr-blue);
  text-align:center;
}
.mr-area-details summary::-webkit-details-marker{display:none;}
.mr-area-details summary::after{
  content:"＋";
  margin-left:8px;
  font-weight:900;
}
.mr-area-details[open] summary::after{content:"−";}
.mr-reason p,
.mr-service p,
.mr-voice p,
.mr-flow-item p{
  line-height:1.7;
}
.mr-reason,
.mr-service,
.mr-voice{
  display:flex;
  flex-direction:column;
}
.mr-reason h3,
.mr-service h3{
  min-height:0;
}
@media (max-width: 640px){
  .mr-mini-list{grid-template-columns:1fr;gap:8px;}
  .mr-section{padding:48px 0;}
  .mr-pain-grid{gap:10px;}
  .mr-pain-item{padding:14px 14px 14px 38px;font-size:14px;}
  .mr-pain-item::before{left:14px;top:22px;width:10px;height:10px;}
  .mr-reasons,
  .mr-service-grid,
  .mr-voice-grid{gap:12px;}
  .mr-reason,
  .mr-service,
  .mr-voice,
  .mr-flow-item,
  .mr-area-box{padding:18px;}
  .mr-service__icon{width:40px;height:40px;font-size:20px;margin-bottom:10px;}
  .mr-flow-item{grid-template-columns:56px minmax(0,1fr);gap:12px;}
  .mr-flow-item__step{min-height:52px;border-radius:14px;font-size:15px;}
  .mr-flow-item__step span{font-size:10px;}
  .mr-area-list{grid-template-columns:1fr;gap:6px;}
}


/* v1.2 form privacy and pain-message refinement */
.mr-message-box{
  max-width:720px;
  margin:22px auto 0;
  padding:16px 18px;
  text-align:center;
  line-height:1.75;
}
.mr-privacy label{
  display:grid;
  grid-template-columns:22px minmax(0,1fr);
  align-items:start;
  gap:9px;
  width:100%;
}
.mr-privacy input[type="checkbox"]{
  width:18px!important;
  min-width:18px;
  height:18px;
  margin:4px 0 0!important;
  padding:0;
  flex:0 0 auto;
}
.mr-privacy span{
  display:block;
  min-width:0;
  overflow-wrap:anywhere;
  word-break:normal;
  line-height:1.65;
}
@media (max-width: 640px){
  .mr-message-box{
    margin-top:18px;
    padding:14px 15px;
    text-align:left;
    font-size:14px;
  }
  .mr-privacy{
    padding:13px;
  }
  .mr-privacy label{
    grid-template-columns:20px minmax(0,1fr);
    gap:8px;
    font-size:13px;
  }
  .mr-privacy input[type="checkbox"]{
    width:17px!important;
    min-width:17px;
    height:17px;
  }
}


/* v1.3 entrance split CTA */
.mr-entry-cta{
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(210px,.85fr);
  gap:12px;
  margin-top:22px;
  max-width:720px;
}
.mr-entry-cta--center{
  margin:24px auto 0;
}
.mr-entry-cta a{
  text-decoration:none;
}
.mr-entry-cta__main,
.mr-entry-cta__phone{
  position:relative;
  display:flex;
  flex-direction:column;
  justify-content:center;
  min-height:92px;
  border-radius:20px;
  padding:18px 20px;
  box-shadow:0 14px 30px rgba(12,50,84,.15);
  overflow:hidden;
}
.mr-entry-cta__main{
  background:linear-gradient(135deg,#119dd2,var(--mr-blue));
  color:#fff;
  border:3px solid rgba(255,255,255,.9);
}
.mr-entry-cta__phone{
  background:#fff;
  color:var(--mr-blue-deep);
  border:1px solid var(--mr-line);
}
.mr-entry-cta__main::after,
.mr-entry-cta__phone::after{
  content:"›";
  position:absolute;
  right:18px;
  top:50%;
  transform:translateY(-50%);
  width:32px;
  height:32px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.9);
  color:var(--mr-blue);
  font-size:32px;
  line-height:1;
  font-weight:900;
}
.mr-entry-cta__phone::after{
  background:var(--mr-blue-soft);
}
.mr-entry-cta__badge{
  display:inline-flex;
  align-self:flex-start;
  padding:3px 9px;
  margin-bottom:8px;
  border-radius:999px;
  background:#ffe830;
  color:#15425f;
  font-size:12px;
  font-weight:900;
  line-height:1.4;
}
.mr-entry-cta strong{
  font-size:clamp(21px,3.6vw,30px);
  line-height:1.25;
  font-weight:900;
  letter-spacing:.02em;
}
.mr-entry-cta small{
  margin-top:5px;
  font-size:13px;
  font-weight:800;
  opacity:.9;
}
.mr-form-purpose{
  display:grid;
  gap:4px;
  padding:15px 16px;
  border-radius:16px;
  background:linear-gradient(135deg,var(--mr-blue-soft),#fff);
  border:1px solid var(--mr-line);
}
.mr-form-purpose strong{
  color:var(--mr-blue-deep);
  font-size:18px;
}
.mr-form-purpose span{
  color:#526579;
  font-size:14px;
  line-height:1.65;
}

.mr-sticky-cta{
  gap:8px;
}
.mr-sticky-cta__phone{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  flex:0 0 38%;
  border-radius:999px;
  background:#fff;
  color:var(--mr-blue);
  border:1px solid var(--mr-line);
  text-decoration:none;
  font-weight:900;
}
.mr-sticky-cta .mr-btn{
  flex:1 1 auto;
}

@media (max-width: 640px){
  .mr-entry-cta{
    grid-template-columns:1fr;
    gap:10px;
    margin-top:18px;
  }
  .mr-entry-cta__main,
  .mr-entry-cta__phone{
    min-height:78px;
    border-radius:18px;
    padding:15px 48px 15px 16px;
  }
  .mr-entry-cta strong{
    font-size:22px;
  }
  .mr-entry-cta small{
    font-size:12px;
  }
  .mr-entry-cta__badge{
    font-size:11px;
    margin-bottom:6px;
  }
}
/* v1.4 natural green reference design adjustment */
:root{
  --mr-blue:#2f8f4e;
  --mr-blue-deep:#244229;
  --mr-blue-soft:#eef8d8;
  --mr-sky:#fbfff0;
  --mr-green:#69b941;
  --mr-green-deep:#2f7a32;
  --mr-lime:#dff3a6;
  --mr-orange:#f5b93f;
  --mr-red:#c2412d;
  --mr-text:#263126;
  --mr-muted:#64715f;
  --mr-line:#d7e6c4;
  --mr-bg:#fffdf1;
  --mr-card:#ffffff;
  --mr-cream:#fbf7df;
  --mr-wood:#b98750;
  --mr-radius:22px;
  --mr-shadow:0 16px 34px rgba(59,96,43,.12);
}

body{
  background:var(--mr-cream);
  color:var(--mr-text);
}
.mr-page{
  background:
    radial-gradient(circle at 8% 6%,rgba(130,190,78,.18),transparent 18%),
    radial-gradient(circle at 92% 2%,rgba(223,243,166,.55),transparent 18%),
    var(--mr-cream);
}
.mr-header{
  background:rgba(255,253,241,.94);
  border-bottom:2px solid rgba(111,166,64,.16);
}
.mr-brand__mark{
  border-radius:50% 50% 44% 44%;
  background:linear-gradient(135deg,var(--mr-green),#8bcf51);
  color:#fff;
  box-shadow:0 10px 22px rgba(61,126,49,.18);
}
.mr-header__cta{
  background:var(--mr-green);
  box-shadow:0 10px 20px rgba(70,151,54,.22);
}
.mr-header__nav a:hover{color:var(--mr-green-deep);}

.mr-hero{
  padding:72px 0 64px;
  background:
    radial-gradient(circle at 8% 18%,rgba(107,180,66,.25) 0 8%,transparent 9%),
    radial-gradient(circle at 90% 16%,rgba(107,180,66,.2) 0 10%,transparent 11%),
    linear-gradient(180deg,#fbf7df 0%,#fffdf1 72%,#f0f7d6 100%);
  overflow:hidden;
}
.mr-hero::before{
  content:"";
  position:absolute;
  right:-40px;
  top:38px;
  width:180px;
  height:210px;
  background:
    radial-gradient(circle at 50% 26%,#67b640 0 32px,transparent 33px),
    radial-gradient(circle at 32% 46%,#5da83a 0 38px,transparent 39px),
    radial-gradient(circle at 70% 48%,#76c34c 0 36px,transparent 37px),
    linear-gradient(#8c5f33,#8c5f33) 50% 100%/24px 92px no-repeat;
  opacity:.9;
  transform:rotate(7deg);
}
.mr-hero::after{
  content:"";
  position:absolute;
  left:-62px;
  bottom:-28px;
  width:190px;
  height:190px;
  background:
    radial-gradient(circle at 50% 30%,#7cc24c 0 38px,transparent 39px),
    radial-gradient(circle at 28% 52%,#67ad3e 0 44px,transparent 45px),
    radial-gradient(circle at 72% 55%,#5fa43a 0 42px,transparent 43px),
    linear-gradient(#98683c,#98683c) 50% 100%/26px 84px no-repeat;
  opacity:.85;
}
.mr-hero__grid{gap:36px;}
.mr-hero__label,
.mr-eyebrow{
  background:#fff;
  border:2px solid var(--mr-line);
  color:var(--mr-green-deep);
  box-shadow:0 8px 18px rgba(83,126,53,.08);
}
.mr-eyebrow::before{background:var(--mr-green);}
.mr-hero__title,
.mr-section-title,
.mr-service h3,
.mr-reason h3,
.mr-flow-item h3,
.mr-entry h1,
.mr-entry-content h2,
.mr-entry-content h3{
  color:var(--mr-blue-deep);
}
.mr-hero__title{
  letter-spacing:.01em;
}
.mr-hero__subtitle{
  color:#32583c;
}
.mr-hero__lead{
  color:#55624d;
  max-width:650px;
}
.mr-section{
  position:relative;
  padding:74px 0;
}
.mr-section--soft{
  background:linear-gradient(180deg,#f0f7d6 0%,#fffdf1 100%);
}
.mr-section--cream{
  background:
    linear-gradient(180deg,rgba(255,253,241,.96),rgba(255,253,241,.96)),
    repeating-linear-gradient(90deg,rgba(151,103,54,.06) 0 12px,transparent 12px 24px);
}
.mr-section--soft::before,
.mr-section--cream::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:-1px;
  height:36px;
  background:inherit;
  clip-path:polygon(0 0,100% 0,50% 100%);
  opacity:.75;
  pointer-events:none;
}
.mr-hero-card,
.mr-text-card,
.mr-reason,
.mr-service,
.mr-voice,
.mr-flow-item,
.mr-area-box,
.mr-faq details,
.mr-post-card,
.mr-contact-card,
.mr-entry{
  border:2px solid rgba(129,176,88,.28);
  border-radius:26px;
  box-shadow:var(--mr-shadow);
}
.mr-hero-card{
  background:#fffef7;
  position:relative;
}
.mr-hero-card::before{
  content:"";
  position:absolute;
  inset:12px;
  border:2px dashed rgba(105,185,65,.22);
  border-radius:20px;
  pointer-events:none;
}
.mr-hero-card__image{
  background:
    linear-gradient(135deg,rgba(91,171,59,.9),rgba(40,118,58,.82)),
    repeating-linear-gradient(135deg,rgba(255,255,255,.16) 0,rgba(255,255,255,.16) 2px,transparent 2px,transparent 18px);
  border-radius:24px;
}
.mr-hero-card__image::before{
  background:rgba(255,255,255,.18);
}
.mr-trust-list li{
  border-color:rgba(105,185,65,.3);
}
.mr-entry-cta{
  background:#fff;
  padding:12px;
  border-radius:28px;
  box-shadow:0 18px 45px rgba(53,91,39,.13);
  border:2px solid rgba(105,185,65,.22);
}
.mr-entry-cta__main{
  background:linear-gradient(135deg,#2fa847,#6bc342);
  color:#fff;
  border:3px solid rgba(255,255,255,.96);
}
.mr-entry-cta__phone{
  background:#243126;
  color:#fff;
  border:3px solid rgba(255,255,255,.96);
}
.mr-entry-cta__main::after{
  color:#2f8f4e;
}
.mr-entry-cta__phone::after{
  background:#fff;
  color:#243126;
}
.mr-entry-cta__badge{
  background:#ffe533;
  color:#25452b;
  border-radius:4px;
}
.mr-entry-cta small{
  line-height:1.55;
}
.mr-btn{
  background:var(--mr-green);
  color:#fff;
  box-shadow:0 14px 28px rgba(80,153,47,.24);
}
.mr-btn--sub{
  background:#fff;
  color:var(--mr-green-deep);
  border:2px solid var(--mr-line);
}
.mr-phone-panel,
.mr-contact-phone{
  display:grid;
  gap:2px;
  text-decoration:none;
  margin-top:16px;
  padding:16px 18px;
  border-radius:20px;
  background:#fff;
  border:3px solid #35a8d6;
  color:#1f2933;
  box-shadow:0 12px 24px rgba(56,95,38,.12);
}
.mr-phone-panel span,
.mr-contact-phone span{
  display:inline-block;
  justify-self:start;
  padding:3px 10px;
  background:#ffe533;
  color:#253327;
  font-weight:900;
  font-size:13px;
}
.mr-phone-panel strong,
.mr-contact-phone strong{
  font-size:clamp(30px,5vw,46px);
  line-height:1.12;
  letter-spacing:.02em;
  color:#1f1f1f;
}
.mr-phone-panel small,
.mr-contact-phone small{
  color:#445044;
  font-weight:900;
}
.mr-contact-phone{
  max-width:680px;
  margin:26px auto 0;
  text-align:center;
  justify-items:center;
}
.mr-pain-item{
  background:#fffef7;
  border-color:rgba(129,176,88,.28);
}
.mr-pain-item::before{
  background:var(--mr-green);
  box-shadow:0 0 0 5px rgba(105,185,65,.15);
}
.mr-message-box{
  background:#fff;
  color:#2f5132;
  border:2px dashed rgba(105,185,65,.35);
  border-radius:22px;
}
.mr-reason{
  background:#fffdf1;
  position:relative;
}
.mr-reason__num{
  background:#dff3a6;
  color:#6aae3d;
  font-size:24px;
  width:48px;
  height:48px;
  border-radius:50%;
}
.mr-service{
  background:#fff;
}
.mr-service__icon{
  background:linear-gradient(135deg,#6bc342,#2f8f4e);
  border-radius:50%;
}
.mr-voice{
  background:#fffdf1;
}
.mr-voice__quote{
  color:#2f5132;
}
.mr-flow-item__step{
  background:#dff3a6;
  color:#4a9d35;
}
.mr-area-details summary,
.mr-area-list strong,
.mr-faq summary,
.mr-post-card h3{
  color:var(--mr-green-deep);
}
.mr-faq summary::after{
  color:var(--mr-green);
}
.mr-contact{
  background:
    radial-gradient(circle at 12% 14%,rgba(255,255,255,.18),transparent 25%),
    linear-gradient(135deg,#6fbf44,#2f8f4e);
}
.mr-contact .mr-eyebrow{
  color:#2f5132;
}
.mr-form-purpose{
  background:linear-gradient(135deg,#eef8d8,#fff);
  border:2px solid rgba(105,185,65,.24);
}
.mr-form-purpose strong{
  color:#2f5132;
}
.mr-footer{
  background:#314125;
  color:#eef8d8;
}
.mr-footer__meta{color:#dbeec3;}

.mr-sticky-cta{
  display:none;
}
.mr-sticky-cta__phone{
  flex:0 0 42%;
  flex-direction:column;
  gap:1px;
  line-height:1.2;
  color:#243126;
  border:2px solid var(--mr-line);
}
.mr-sticky-cta__phone span{
  font-size:12px;
}
.mr-sticky-cta__phone strong{
  font-size:13px;
}

@media (max-width: 980px){
  .mr-hero::before{right:-90px;top:20px;opacity:.55;}
  .mr-hero::after{left:-100px;opacity:.5;}
  .mr-reasons{grid-template-columns:repeat(2,minmax(0,1fr));}
}

@media (max-width: 640px){
  .mr-page{
    background:#fffdf1;
  }
  .mr-hero{
    padding:34px 0 42px;
  }
  .mr-hero::before{
    width:120px;
    height:140px;
    right:-46px;
    top:64px;
    opacity:.45;
    transform:rotate(10deg) scale(.82);
  }
  .mr-hero::after{
    width:132px;
    height:132px;
    left:-68px;
    bottom:-20px;
    opacity:.42;
    transform:scale(.8);
  }
  .mr-hero__title{
    font-size:31px;
  }
  .mr-hero__subtitle{
    font-size:18px;
  }
  .mr-entry-cta{
    padding:9px;
    border-radius:22px;
  }
  .mr-entry-cta__main,
  .mr-entry-cta__phone{
    padding:14px 48px 14px 15px;
  }
  .mr-entry-cta strong{
    font-size:21px;
  }
  .mr-entry-cta small{
    font-size:11px;
  }
  .mr-phone-panel,
  .mr-contact-phone{
    padding:14px;
    border-radius:18px;
  }
  .mr-phone-panel strong,
  .mr-contact-phone strong{
    font-size:34px;
  }
  .mr-phone-panel span,
  .mr-contact-phone span{
    font-size:12px;
  }
  .mr-section{
    padding:52px 0;
  }
  .mr-section--soft::before,
  .mr-section--cream::before{
    height:22px;
  }
  .mr-reason__num{
    width:42px;
    height:42px;
    font-size:20px;
  }
  .mr-sticky-cta{
    display:flex;
  }
}


/* v6: uploaded photo integration */
.mr-brand__logo{
  width:46px;
  height:46px;
  display:grid;
  place-items:center;
  flex:0 0 auto;
}
.mr-brand__logo img{
  max-width:46px;
  max-height:46px;
  object-fit:contain;
}

.mr-hero-card{
  overflow:hidden;
}
.mr-hero-photo{
  margin:0 0 16px;
  border-radius:24px;
  overflow:hidden;
  box-shadow:0 16px 34px rgba(12,50,84,.14);
  border:5px solid #fff;
  background:#fff;
}
.mr-hero-photo img{
  width:100%;
  aspect-ratio:16/10;
  object-fit:cover;
  object-position:center;
}
.mr-hero-photo + .mr-hero-card__image{
  min-height:auto;
}

.mr-staff-band{
  position:relative;
  padding:54px 0 62px;
  background:
    radial-gradient(circle at 8% 20%, rgba(129,188,84,.24) 0 74px, transparent 75px),
    radial-gradient(circle at 92% 16%, rgba(129,188,84,.18) 0 66px, transparent 67px),
    linear-gradient(180deg,#f6fbeb 0%,#fff8ec 100%);
}
.mr-staff-band::before,
.mr-staff-band::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  height:18px;
  pointer-events:none;
  background:repeating-linear-gradient(135deg, rgba(47,125,92,.12) 0 12px, transparent 12px 24px);
  opacity:.5;
}
.mr-staff-band::before{top:0;}
.mr-staff-band::after{bottom:0;}
.mr-staff-band__head{
  text-align:center;
  margin-bottom:26px;
}
.mr-staff-band__head h2{
  margin:0 0 8px;
  color:var(--mr-green);
  font-size:clamp(25px,4vw,38px);
  line-height:1.25;
}
.mr-staff-band__head p{
  margin:0;
  color:#4b5f54;
}
.mr-staff-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.mr-staff-grid figure{
  margin:0;
  border-radius:24px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 18px 38px rgba(31,41,51,.12);
  border:6px solid #fff;
}
.mr-staff-grid img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  object-position:center;
}
.mr-staff-grid figcaption{
  padding:12px 14px 14px;
  font-weight:800;
  color:var(--mr-blue-deep);
  text-align:center;
  background:#fff;
  font-size:14px;
}

.mr-quote-stack--photo{
  gap:14px;
}
.mr-side-photo{
  margin:0;
  border-radius:28px;
  overflow:hidden;
  box-shadow:var(--mr-shadow);
  border:6px solid #fff;
  background:#fff;
}
.mr-side-photo img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
}

.mr-trust-gallery{
  margin-top:28px;
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:18px;
  align-items:stretch;
}
.mr-trust-gallery figure{
  margin:0;
  border-radius:24px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 16px 36px rgba(12,50,84,.1);
  border:1px solid rgba(219,231,240,.9);
}
.mr-trust-gallery img{
  width:100%;
  height:210px;
  object-fit:cover;
  background:#fff;
}
.mr-trust-gallery figure:nth-child(2) img{
  object-fit:contain;
  padding:22px;
}
.mr-trust-gallery figcaption{
  padding:14px 16px;
  font-weight:800;
  color:var(--mr-blue-deep);
  background:#fff;
}

.mr-voice{
  overflow:hidden;
}
.mr-voice__photo{
  margin:-24px -24px 18px;
  background:#fff;
}
.mr-voice__photo img{
  width:100%;
  aspect-ratio:16/9;
  object-fit:cover;
  object-position:center;
}
.mr-contact-intro{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  align-items:stretch;
  margin:0 0 22px;
}
.mr-contact-intro figure{
  margin:0;
  border-radius:24px;
  overflow:hidden;
  box-shadow:0 18px 38px rgba(31,41,51,.12);
  border:6px solid #fff;
}
.mr-contact-intro img{
  width:100%;
  height:100%;
  min-height:190px;
  object-fit:cover;
}

@media (max-width: 900px){
  .mr-staff-grid{
    grid-template-columns:1fr;
    gap:16px;
  }
  .mr-staff-grid figure{
    display:grid;
    grid-template-columns:128px 1fr;
    align-items:center;
  }
  .mr-staff-grid img{
    aspect-ratio:1/1;
    height:128px;
  }
  .mr-staff-grid figcaption{
    text-align:left;
    padding:14px 16px;
  }
  .mr-trust-gallery{
    grid-template-columns:1fr;
  }
  .mr-contact-intro{
    grid-template-columns:1fr;
  }
}

@media (max-width: 640px){
  .mr-hero-photo{
    border-width:4px;
    border-radius:20px;
  }
  .mr-staff-band{
    padding:42px 0 48px;
  }
  .mr-staff-grid figure{
    grid-template-columns:104px 1fr;
    border-radius:18px;
  }
  .mr-staff-grid img{
    width:104px;
    height:104px;
  }
  .mr-staff-grid figcaption{
    font-size:13px;
    line-height:1.55;
  }
  .mr-trust-gallery img{
    height:180px;
  }
  .mr-voice__photo{
    margin:-18px -18px 14px;
  }
  .mr-contact-intro img{
    min-height:160px;
  }
}


/* =========================================================
   v7: blue/orange exterior-reform inspired design
   Reference direction: trust-focused, strong blue bands, orange CTA,
   diagonal separators, warning cards, process cards.
   ========================================================= */

:root{
  --mr-blue:#0b4f8a;
  --mr-blue-deep:#00386b;
  --mr-blue-dark:#002c55;
  --mr-blue-soft:#e7f3fb;
  --mr-sky:#edf8ff;
  --mr-orange:#f28a24;
  --mr-orange-deep:#dd6f13;
  --mr-yellow:#fff36a;
  --mr-text:#172638;
  --mr-muted:#53697d;
  --mr-line:#c8ddea;
  --mr-cream:#f7fbff;
  --mr-radius:12px;
  --mr-shadow:0 16px 34px rgba(0,45,85,.16);
}

body{
  background:#fff;
  color:var(--mr-text);
}

.mr-page{
  background:
    linear-gradient(180deg,#ffffff 0%,#f6fbff 55%,#ffffff 100%);
}

/* global section rhythm */
.mr-section{
  position:relative;
  padding:84px 0;
}
.mr-section--soft{
  background:
    linear-gradient(180deg,#f1f8fd 0%,#ffffff 100%);
}
.mr-section--cream{
  background:
    linear-gradient(180deg,#eef8ff 0%,#ffffff 100%);
}
.mr-section-title{
  color:var(--mr-blue-deep);
  font-weight:900;
  letter-spacing:.01em;
}
.mr-section-title::after{
  content:"";
  display:block;
  width:82px;
  height:5px;
  margin:18px auto 0;
  background:linear-gradient(90deg,var(--mr-blue),var(--mr-orange));
  border-radius:999px;
}
.mr-split .mr-section-title::after,
.mr-text-card .mr-section-title::after{
  margin-left:0;
}
.mr-section-lead{
  color:#435a70;
}
.mr-eyebrow{
  color:#fff;
  background:var(--mr-blue);
  border-radius:0;
  clip-path:polygon(0 0, calc(100% - 12px) 0, 100% 50%, calc(100% - 12px) 100%, 0 100%);
  padding:7px 18px 7px 14px;
  box-shadow:0 8px 20px rgba(0,56,107,.12);
}
.mr-eyebrow::before{
  background:var(--mr-orange);
}

/* Header */
.mr-header{
  background:rgba(255,255,255,.97);
  border-bottom:4px solid var(--mr-blue);
}
.mr-brand__mark{
  background:#fff;
  color:var(--mr-blue);
  border:2px solid var(--mr-blue);
  box-shadow:none;
}
.mr-brand__name{color:var(--mr-blue-deep);}
.mr-header__cta .mr-btn,
.mr-btn{
  background:linear-gradient(180deg,var(--mr-orange),var(--mr-orange-deep));
  border:2px solid #fff;
  box-shadow:0 10px 0 rgba(0,0,0,.13), 0 18px 30px rgba(242,138,36,.28);
}
.mr-btn:hover{
  transform:translateY(1px);
  box-shadow:0 7px 0 rgba(0,0,0,.13), 0 12px 22px rgba(242,138,36,.25);
}

/* Hero: strong exterior reform style */
.mr-hero{
  position:relative;
  overflow:hidden;
  padding:64px 0 76px;
  background:
    linear-gradient(90deg,rgba(255,255,255,.95) 0%,rgba(255,255,255,.88) 45%,rgba(255,255,255,.35) 70%,rgba(255,255,255,.15) 100%),
    linear-gradient(135deg,rgba(11,79,138,.18),rgba(11,79,138,.02)),
    url("assets/images/house_kawara.jpg") right center / cover no-repeat;
}
.mr-hero::before{
  content:"";
  position:absolute;
  inset:auto -5% -54px -5%;
  height:112px;
  background:var(--mr-blue-deep);
  transform:skewY(-3deg);
  transform-origin:left top;
}
.mr-hero::after{
  content:"安心・長持ち";
  position:absolute;
  right:5vw;
  top:42px;
  color:rgba(255,255,255,.85);
  background:rgba(0,56,107,.68);
  border:1px solid rgba(255,255,255,.35);
  padding:9px 16px;
  font-weight:900;
  letter-spacing:.05em;
  font-size:14px;
}
.mr-hero__grid{
  position:relative;
  z-index:1;
}
.mr-hero__label{
  display:inline-block;
  background:var(--mr-blue-deep);
  color:#fff;
  font-weight:900;
  padding:8px 16px;
  border-radius:0;
  clip-path:polygon(0 0, calc(100% - 14px) 0, 100% 50%, calc(100% - 14px) 100%, 0 100%);
  margin-bottom:16px;
}
.mr-hero__title{
  color:var(--mr-blue-deep);
  text-shadow:0 2px 0 rgba(255,255,255,.9);
  font-size:clamp(33px,5vw,58px);
  line-height:1.18;
  font-weight:950;
}
.mr-hero__subtitle{
  color:#102f4b;
  font-size:clamp(18px,2.5vw,25px);
  font-weight:800;
  border-left:6px solid var(--mr-orange);
  padding-left:16px;
  background:rgba(255,255,255,.72);
  padding-top:10px;
  padding-bottom:10px;
}
.mr-hero__lead{
  background:rgba(255,255,255,.88);
  border:1px solid rgba(200,221,234,.8);
  padding:16px 18px;
  border-radius:10px;
  max-width:650px;
}
.mr-hero-card{
  background:rgba(255,255,255,.96);
  border:4px solid #fff;
  border-top:7px solid var(--mr-blue);
  border-radius:8px;
  box-shadow:var(--mr-shadow);
}
.mr-hero-photo img{
  min-height:210px;
  object-fit:cover;
}
.mr-hero-card__image{
  background:var(--mr-blue-deep);
  color:#fff;
  border-radius:8px;
}
.mr-hero-card__image strong{color:#fff;}
.mr-trust-list li::before{
  color:var(--mr-orange);
}

/* Two big CTA like reference */
.mr-entry-cta{
  align-items:stretch;
  gap:12px;
}
.mr-entry-cta__main,
.mr-entry-cta__phone{
  border-radius:6px;
  border:3px solid #fff;
  box-shadow:0 9px 0 rgba(0,0,0,.14), 0 16px 26px rgba(0,43,82,.2);
  text-decoration:none;
  position:relative;
  overflow:hidden;
}
.mr-entry-cta__main{
  background:linear-gradient(180deg,var(--mr-orange),var(--mr-orange-deep));
}
.mr-entry-cta__main::after,
.mr-entry-cta__phone::after{
  content:"›";
  position:absolute;
  right:18px;
  top:50%;
  transform:translateY(-50%);
  display:grid;
  place-items:center;
  width:34px;
  height:34px;
  border-radius:50%;
  color:#fff;
  border:2px solid rgba(255,255,255,.8);
  font-size:30px;
  line-height:1;
}
.mr-entry-cta__phone{
  background:linear-gradient(180deg,var(--mr-blue),var(--mr-blue-deep));
}
.mr-entry-cta__badge{
  background:var(--mr-yellow);
  color:#18324b;
  border-radius:0;
  font-weight:900;
}
.mr-entry-cta strong{
  padding-right:48px;
}
.mr-phone-panel,
.mr-contact-phone{
  background:#fff;
  border:3px solid var(--mr-blue);
  border-radius:6px;
}
.mr-phone-panel strong,
.mr-contact-phone strong{
  color:var(--mr-blue-deep);
}

/* Staff band */
.mr-staff-band{
  padding:54px 0 72px;
  background:var(--mr-blue-deep);
  color:#fff;
  position:relative;
}
.mr-staff-band::before{
  content:"";
  position:absolute;
  inset:-36px -5% auto -5%;
  height:72px;
  background:var(--mr-blue-deep);
  transform:skewY(-3deg);
}
.mr-staff-band__head h2,
.mr-staff-band__head p{
  color:#fff;
}
.mr-staff-grid figure{
  border-radius:6px;
  border:4px solid #fff;
  box-shadow:0 14px 26px rgba(0,0,0,.22);
}
.mr-staff-grid figcaption{
  background:rgba(0,56,107,.92);
  color:#fff;
  font-weight:800;
}

/* Worries: caution block */
#worries{
  background:
    linear-gradient(180deg,#ffffff 0%,#f3f7fa 100%);
}
#worries .mr-section-title::before{
  content:"ご注意ください！";
  display:block;
  width:max-content;
  max-width:100%;
  margin:0 auto 14px;
  padding:8px 18px;
  background:var(--mr-yellow);
  color:#172638;
  border:3px solid #172638;
  transform:rotate(-1.2deg);
  font-size:clamp(20px,3vw,30px);
  box-shadow:8px 8px 0 rgba(0,56,107,.18);
}
.mr-pain-grid{
  gap:20px;
}
.mr-pain-item{
  position:relative;
  background:#fff9cf;
  border:3px solid #172638;
  border-radius:0;
  padding:22px 20px 22px 54px;
  font-weight:800;
  box-shadow:10px 10px 0 rgba(0,56,107,.12);
  transform:rotate(-.5deg);
}
.mr-pain-item:nth-child(even){
  transform:rotate(.5deg);
}
.mr-pain-item::before{
  content:"!";
  position:absolute;
  left:18px;
  top:20px;
  width:24px;
  height:24px;
  border-radius:50%;
  background:var(--mr-orange);
  color:#fff;
  display:grid;
  place-items:center;
  font-weight:900;
}
.mr-message-box{
  background:var(--mr-blue-deep);
  color:#fff;
  border-radius:6px;
  border-left:8px solid var(--mr-orange);
}

/* Split point section */
.mr-text-card{
  border-radius:8px;
  border:1px solid var(--mr-line);
  border-top:7px solid var(--mr-blue);
  box-shadow:var(--mr-shadow);
}
.mr-side-photo{
  border-radius:6px;
  box-shadow:var(--mr-shadow);
  border:4px solid #fff;
}
.mr-quote-bubble{
  background:#fff;
  border:3px solid var(--mr-blue);
  color:var(--mr-blue-deep);
  font-weight:900;
  border-radius:6px;
}

/* Reason: Point cards */
#reason{
  background:
    linear-gradient(180deg,#eef8ff 0%,#fff 100%);
}
.mr-reasons{
  counter-reset:reason;
}
.mr-reason{
  position:relative;
  border-radius:6px;
  border:1px solid #c6dce9;
  border-left:7px solid var(--mr-blue);
  box-shadow:0 12px 30px rgba(0,56,107,.1);
}
.mr-reason__num{
  background:var(--mr-blue);
  color:#fff;
  border-radius:0;
  width:auto;
  min-width:74px;
  padding:8px 10px;
  font-size:14px;
}
.mr-reason__num::before{
  content:"Point ";
}
.mr-reason h3{
  color:var(--mr-blue-deep);
}
.mr-trust-gallery figure{
  border-radius:6px;
  border:4px solid #fff;
  box-shadow:var(--mr-shadow);
}
.mr-trust-gallery figcaption{
  background:var(--mr-blue-deep);
  color:#fff;
  font-weight:800;
}

/* Service */
.mr-service{
  border-radius:6px;
  border:1px solid #d5e5ee;
  border-top:6px solid var(--mr-blue);
  box-shadow:0 12px 28px rgba(0,56,107,.08);
}
.mr-service__icon{
  background:#edf7ff;
  color:var(--mr-blue-deep);
  border:2px solid var(--mr-blue);
  border-radius:50%;
}

/* Voice: interview style */
.mr-voice{
  border-radius:6px;
  overflow:hidden;
  border:0;
  box-shadow:var(--mr-shadow);
}
.mr-voice__photo{
  margin:-24px -24px 16px;
}
.mr-voice__photo img{
  width:100%;
  height:230px;
  object-fit:cover;
}
.mr-voice__quote{
  position:relative;
  background:var(--mr-blue);
  color:#fff;
  border-radius:6px;
  padding:16px 18px;
  font-weight:900;
}
.mr-voice__quote::after{
  content:"";
  position:absolute;
  left:28px;
  bottom:-12px;
  border:12px solid transparent;
  border-top-color:var(--mr-blue);
  border-left:0;
}

/* Flow blue area */
#flow{
  background:
    linear-gradient(rgba(0,56,107,.88),rgba(0,56,107,.88)),
    url("assets/images/house_kawara.jpg") center/cover no-repeat;
  color:#fff;
}
#flow .mr-section-title,
#flow .mr-section-lead{color:#fff;}
#flow .mr-section-title::after{background:var(--mr-orange);}
#flow .mr-eyebrow{background:#fff;color:var(--mr-blue-deep);}
.mr-flow{
  gap:18px;
}
.mr-flow-item{
  background:#fff;
  color:var(--mr-text);
  border-radius:6px;
  border:0;
  box-shadow:0 14px 28px rgba(0,0,0,.22);
}
.mr-flow-item__step{
  background:var(--mr-orange);
  color:#fff;
  border-radius:4px;
}
.mr-flow-item h3{color:var(--mr-blue-deep);}

/* Area/FAQ */
.mr-area-box,
.mr-faq details{
  border-radius:6px;
  border:1px solid #cddfea;
  box-shadow:0 10px 24px rgba(0,56,107,.08);
}
.mr-area-details summary,
.mr-faq summary{
  color:var(--mr-blue-deep);
  font-weight:900;
}

/* Articles */
.mr-post-card{
  border-radius:6px;
  box-shadow:0 12px 26px rgba(0,56,107,.08);
  border-top:5px solid var(--mr-blue);
}

/* Contact: navy block with white form */
.mr-contact{
  background:var(--mr-blue-deep);
  color:#fff;
}
.mr-contact .mr-section-title,
.mr-contact .mr-section-lead{color:#fff;}
.mr-contact .mr-eyebrow{
  background:#fff;
  color:var(--mr-blue-deep);
}
.mr-contact .mr-section-title::after{background:var(--mr-orange);}
.mr-contact-card{
  background:#fff;
  color:var(--mr-text);
  border-radius:6px;
  border:6px solid rgba(255,255,255,.2);
  box-shadow:0 18px 40px rgba(0,0,0,.24);
}
.mr-form-purpose{
  background:#fff6e8;
  border-left:7px solid var(--mr-orange);
  border-radius:6px;
}
.mr-field label{
  color:var(--mr-blue-deep);
  font-weight:900;
}
.mr-field input,
.mr-field textarea,
.mr-field select{
  border-radius:5px;
  border:1px solid #bed2df;
}
.mr-required{
  background:var(--mr-orange);
}
.mr-privacy{
  background:#f4f8fb;
  border-radius:6px;
}

/* Footer / sticky */
.mr-bottom-cta{
  background:rgba(0,44,85,.96);
  border-top:3px solid var(--mr-orange);
}
.mr-bottom-cta a:first-child{
  background:var(--mr-blue);
}
.mr-bottom-cta a:last-child{
  background:var(--mr-orange);
}

/* Desktop visual spacing */
@media (min-width: 880px){
  .mr-hero__grid{
    grid-template-columns:minmax(0,1.05fr) minmax(360px,.8fr);
    gap:42px;
  }
  .mr-entry-cta__main{
    flex:1.25;
  }
  .mr-entry-cta__phone{
    flex:1;
  }
}

/* Mobile */
@media (max-width: 767px){
  .mr-section{padding:62px 0;}
  .mr-hero{
    padding:34px 0 64px;
    background:
      linear-gradient(180deg,rgba(255,255,255,.96) 0%,rgba(255,255,255,.9) 74%,rgba(255,255,255,.72) 100%),
      url("assets/images/house_kawara.jpg") center top / cover no-repeat;
  }
  .mr-hero::after{
    display:none;
  }
  .mr-hero__title{
    font-size:34px;
  }
  .mr-hero__subtitle{
    font-size:17px;
  }
  .mr-entry-cta{
    display:grid;
    grid-template-columns:1fr;
  }
  .mr-entry-cta__main,
  .mr-entry-cta__phone{
    min-height:90px;
  }
  .mr-entry-cta__main strong,
  .mr-entry-cta__phone strong{
    font-size:20px;
  }
  .mr-pain-item{
    padding:20px 16px 20px 50px;
    box-shadow:7px 7px 0 rgba(0,56,107,.12);
  }
  .mr-voice__photo img{
    height:190px;
  }
  .mr-contact-card{
    border-width:3px;
  }
}
