:root{
  --navy:#082a61;
  --navy-dark:#041a3f;
  --navy-deep:#03132f;
  --blue:#155db6;
  --line:#08b53f;
  --line-dark:#079837;
  --white:#fff;
  --soft:#f4f7fb;
  --soft-blue:#eaf1fb;
  --text:#172033;
  --muted:#667085;
  --border:#dfe6ef;
  --accent:#dca94a;
  --shadow:0 18px 50px rgba(4,26,63,.12);
  --radius:22px;
  --shell:min(1180px,calc(100% - 36px));
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;color:var(--text);background:#fff;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,sans-serif;line-height:1.75;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit}
.shell{width:var(--shell);margin-inline:auto}
.narrow{max-width:900px}
.skip-link{position:fixed;top:-60px;left:16px;z-index:9999;background:#fff;color:#000;padding:10px 14px;border-radius:8px;box-shadow:var(--shadow)}
.skip-link:focus{top:16px}
.top-note{padding:7px 12px;background:var(--navy-deep);color:#dce8ff;text-align:center;font-size:12px;font-weight:700;letter-spacing:.04em}
.site-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.94);backdrop-filter:blur(16px);border-bottom:1px solid rgba(8,42,97,.08)}
.header-inner{min-height:82px;display:flex;align-items:center;justify-content:space-between;gap:28px}
.brand{display:flex;align-items:center;gap:11px;min-width:265px}
.brand img{width:76px;height:42px;object-fit:contain}
.brand span{display:flex;flex-direction:column;line-height:1.35}
.brand strong{color:var(--navy);font-size:17px;letter-spacing:.03em}
.brand small{color:var(--muted);font-size:10px;font-weight:700}
.desktop-nav{display:flex;align-items:center;gap:25px;font-size:14px;font-weight:800}
.desktop-nav a{position:relative;padding:29px 0 25px}
.desktop-nav a::after{content:"";position:absolute;left:0;right:100%;bottom:18px;height:2px;background:var(--navy);transition:.2s}
.desktop-nav a:hover::after{right:0}
.header-actions{display:flex;align-items:center;gap:12px}
.header-phone{display:flex;flex-direction:column;text-align:right;line-height:1.25}
.header-phone small{color:var(--muted);font-size:10px}
.header-phone strong{color:var(--navy);font-size:16px}
.button{display:inline-flex;align-items:center;justify-content:center;gap:12px;min-height:52px;padding:12px 22px;border:0;border-radius:14px;font-weight:900;letter-spacing:.01em;transition:transform .18s,box-shadow .18s,background .18s}
.button:hover{transform:translateY(-2px)}
.button-line{background:var(--line);color:#fff;box-shadow:0 10px 26px rgba(8,181,63,.24)}
.button-line:hover{background:var(--line-dark)}
.button-outline{background:#fff;color:var(--navy);border:1px solid rgba(8,42,97,.22);box-shadow:0 8px 22px rgba(8,42,97,.07)}
.button-white{background:#fff;color:var(--navy);box-shadow:0 12px 30px rgba(0,0,0,.15)}
.button-large{min-height:64px;padding-inline:24px;font-size:16px;justify-content:space-between}
.line-icon{display:grid;place-items:center;min-width:48px;height:30px;padding:0 8px;border-radius:999px;background:#fff;color:var(--line);font-size:11px;font-weight:1000}
.header-line{min-height:44px;padding:10px 15px;border-radius:10px;font-size:13px}
.menu-button{display:none;width:45px;height:45px;border:0;background:#fff;border-radius:10px;box-shadow:0 3px 14px rgba(8,42,97,.12);padding:10px}
.menu-button span{display:block;height:2px;margin:5px 0;background:var(--navy)}
.mobile-menu{display:none;padding:10px 18px 18px;background:#fff;border-top:1px solid var(--border)}
.mobile-menu[hidden]{display:none!important}
body.menu-open{overflow:hidden}
.mobile-menu a{display:block;padding:13px 4px;border-bottom:1px solid var(--border);font-weight:800}
.hero{position:relative;overflow:hidden;padding:76px 0 82px;background:linear-gradient(135deg,#fff 0%,#f6f9fd 55%,#e9f1fb 100%)}
.hero::before{content:"";position:absolute;width:580px;height:580px;border-radius:50%;right:-220px;top:-240px;background:radial-gradient(circle,rgba(21,93,182,.15),rgba(21,93,182,0) 70%)}
.hero-grid{position:relative;display:grid;grid-template-columns:minmax(0,1fr) minmax(440px,.92fr);gap:70px;align-items:center}
.eyebrow,.section-kicker{margin:0 0 10px;color:var(--blue);font-size:12px;font-weight:1000;letter-spacing:.18em}
.hero h1{margin:0;color:var(--navy-dark);font-size:clamp(46px,5.1vw,76px);line-height:1.15;letter-spacing:-.055em}
.hero h1 span{color:var(--blue)}
.hero-lead{max-width:680px;margin:24px 0 0;color:#48566b;font-size:17px;line-height:1.9;font-weight:600}
.hero-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:23px}
.hero-tags span{padding:7px 12px;border:1px solid rgba(8,42,97,.13);border-radius:999px;background:#fff;color:var(--navy);font-size:12px;font-weight:900;box-shadow:0 5px 16px rgba(8,42,97,.06)}
.hero-buttons{display:grid;grid-template-columns:1.45fr .75fr;gap:12px;margin-top:28px}
.hero-note{margin:12px 0 0;color:var(--muted);font-size:11px}
.hero-visual{position:relative;min-height:650px}
.hero-main-photo{position:absolute;inset:0 58px 45px 0;margin:0;overflow:hidden;border-radius:32px;box-shadow:0 28px 70px rgba(3,19,47,.24)}
.hero-main-photo img{width:100%;height:100%;object-fit:cover;object-position:center 38%}
.hero-photo-label{position:absolute;top:28px;left:-18px;padding:9px 15px;border-radius:999px;background:#fff;color:var(--navy);font-size:12px;font-weight:1000;box-shadow:0 10px 24px rgba(3,19,47,.15)}
.hero-sub-photo{position:absolute;margin:0;overflow:hidden;border:8px solid #fff;border-radius:21px;box-shadow:0 18px 45px rgba(3,19,47,.22)}
.hero-sub-photo img{width:100%;height:100%;object-fit:cover}
.hero-sub-one{right:0;bottom:0;width:185px;height:225px}
.hero-sub-two{left:-55px;bottom:13px;width:195px;height:195px}
.trust-strip{background:#fff;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.trust-grid div{display:flex;flex-direction:column;align-items:center;gap:1px;padding:23px 14px;border-left:1px solid var(--border);text-align:center}
.trust-grid div:last-child{border-right:1px solid var(--border)}
.trust-grid strong{color:var(--navy);font-size:20px}
.trust-grid span{color:var(--muted);font-size:11px;font-weight:700}
.section{padding:90px 0}
.section-soft{background:var(--soft)}
.section-heading{max-width:780px;margin:0 auto 40px;text-align:center}
.section-heading h2,.heading-left h2,.line-copy h2,.business-copy h2,.referral-copy h2,.area-layout h2,.contact-inner h2{margin:0;color:var(--navy-dark);font-size:clamp(32px,4vw,52px);line-height:1.3;letter-spacing:-.035em}
.section-heading p:not(.section-kicker){margin:13px 0 0;color:var(--muted)}
.heading-left{max-width:none;display:grid;grid-template-columns:.7fr 1fr;align-items:end;gap:50px;text-align:left}
.heading-left>p{margin:0;color:var(--muted)}
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.service-card{overflow:hidden;border:1px solid var(--border);border-radius:var(--radius);background:#fff;box-shadow:0 12px 35px rgba(8,42,97,.07);transition:transform .2s,box-shadow .2s}
.service-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.service-card-photo>img{width:100%;height:215px;object-fit:cover}
.service-card-body{padding:23px 22px 24px}
.service-number{color:var(--blue);font-size:11px;font-weight:1000;letter-spacing:.15em}
.service-card h3{margin:8px 0 8px;color:var(--navy);font-size:22px;line-height:1.45}
.service-card p{margin:0;color:var(--muted);font-size:13px}
.service-card a{display:inline-flex;align-items:center;gap:8px;margin-top:18px;color:var(--navy);font-size:13px;font-weight:900}
.service-card-placeholder{display:grid;grid-template-columns:135px 1fr;align-items:center;min-height:276px}
.placeholder-icon{width:92px;height:92px;display:grid;place-items:center;justify-self:center;border-radius:50%;background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;font-size:30px;font-weight:1000;box-shadow:0 15px 30px rgba(8,42,97,.18)}
.price-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.price-card{padding:28px 22px;border:1px solid var(--border);border-radius:20px;background:#fff;box-shadow:0 12px 35px rgba(8,42,97,.06)}
.price-card.featured{border:2px solid var(--blue);background:linear-gradient(180deg,#fafdff,#fff)}
.price-label{display:inline-block;padding:5px 10px;border-radius:999px;background:var(--soft-blue);color:var(--navy);font-size:10px;font-weight:1000}
.price-card h3{min-height:52px;margin:14px 0 8px;color:var(--navy);font-size:18px;line-height:1.45}
.price-value{display:flex;align-items:flex-end;gap:4px;color:#d34135}
.price-value strong{font-size:38px;line-height:1;font-variant-numeric:tabular-nums}
.price-value span{padding-bottom:4px;font-weight:900}
.price-card ul{margin:20px 0 0;padding:18px 0 0;border-top:1px solid var(--border);list-style:none}
.price-card li{position:relative;padding-left:1.45em;color:var(--muted);font-size:12px}
.price-card li+li{margin-top:6px}
.price-card li::before{content:"✓";position:absolute;left:0;color:var(--line);font-weight:1000}
.price-footer{display:flex;align-items:center;justify-content:space-between;gap:25px;margin-top:24px;padding:20px 23px;border-radius:16px;background:var(--soft);border:1px solid var(--border)}
.price-footer div{display:flex;flex-direction:column;gap:3px}
.price-footer strong{color:var(--navy)}
.price-footer span{color:var(--muted);font-size:12px}
.text-link{display:inline-flex;align-items:center;gap:8px;color:var(--navy);font-weight:900;white-space:nowrap}
.section-navy{background:radial-gradient(circle at 85% 10%,#16477f 0%,var(--navy-dark) 42%,var(--navy-deep) 100%);color:#fff}
.section-heading.light h2{color:#fff}
.section-heading.light p:not(.section-kicker){color:rgba(255,255,255,.7)}
.section-heading.light .section-kicker,.light-green{color:#79e39d}
.works-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:255px;gap:16px}
.work-card{position:relative;overflow:hidden;border-radius:20px;background:#0b214a;box-shadow:0 18px 40px rgba(0,0,0,.22)}
.work-card img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
.work-card:hover img{transform:scale(1.035)}
.work-card::after{content:"";position:absolute;inset:45% 0 0;background:linear-gradient(transparent,rgba(3,19,47,.92))}
.work-card>div{position:absolute;z-index:2;left:18px;right:18px;bottom:16px}
.work-card span{display:inline-block;padding:4px 8px;border-radius:999px;background:rgba(255,255,255,.92);color:var(--navy);font-size:9px;font-weight:1000}
.work-card h3{margin:7px 0 0;color:#fff;font-size:16px;line-height:1.45}
.work-card-tall{grid-row:span 2}
.work-card.wide{grid-column:span 2}
.line-section{background:linear-gradient(135deg,#f3f8ff,#f9fcff 55%,#edf9f1)}
.line-layout{display:grid;grid-template-columns:1fr .72fr;gap:60px;align-items:center}
.line-copy h2{max-width:700px}
.line-copy>p:not(.section-kicker):not(.coupon-copy){color:var(--muted)}
.line-steps{display:grid;gap:12px;margin:28px 0;padding:0;list-style:none}
.line-steps li{display:grid;grid-template-columns:46px 1fr;gap:13px;align-items:center;padding:14px 16px;border:1px solid rgba(8,42,97,.1);border-radius:14px;background:rgba(255,255,255,.8)}
.line-steps li>span{width:40px;height:40px;display:grid;place-items:center;border-radius:50%;background:var(--navy);color:#fff;font-weight:1000}
.line-steps div{display:flex;flex-direction:column}
.line-steps strong{color:var(--navy)}
.line-steps small{color:var(--muted)}
.line-main-button{max-width:500px}
.coupon-copy{max-width:530px;color:var(--muted);font-size:11px}
.line-side{display:grid;gap:18px}
.qr-card{padding:28px;border-radius:24px;background:#fff;text-align:center;box-shadow:var(--shadow)}
.qr-card img{width:min(240px,75%);margin:auto}
.qr-card strong,.qr-card span{display:block}
.qr-card strong{margin-top:13px;color:var(--navy);font-size:18px}
.qr-card span{color:var(--muted);font-size:12px}
.line-photo-stack{overflow:hidden;border-radius:20px;background:#fff;box-shadow:0 12px 35px rgba(8,42,97,.09)}
.estimate-photo-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:2px;background:#dce6f2}
.estimate-photo-item{position:relative;min-width:0;overflow:hidden;background:#eef3f8}
.estimate-photo-item>img{display:block;width:100%;aspect-ratio:4/3;object-fit:cover;background:#eef5fb}
.estimate-photo-item:first-child>img{object-position:center 35%}
.estimate-photo-label{display:grid;grid-template-columns:30px 1fr;column-gap:9px;align-items:center;padding:12px 12px 13px;background:#fff;border-top:1px solid #e1eaf3}
.estimate-photo-label b{grid-row:1/3;width:28px;height:28px;display:grid;place-items:center;border-radius:50%;background:var(--navy);color:#fff;font-size:12px}
.estimate-photo-label span{color:var(--navy);font-size:12px;font-weight:900;line-height:1.2}
.estimate-photo-label small{color:var(--muted);font-size:9px;line-height:1.35}
.estimate-photo-copy{padding:17px 18px}
.estimate-photo-copy strong,.estimate-photo-copy span{display:block}
.estimate-photo-copy strong{color:var(--navy)}
.estimate-photo-copy span{margin-top:4px;color:var(--muted);font-size:12px;line-height:1.6}
.business-section{background:var(--navy-deep);color:#fff}
.business-layout{display:grid;grid-template-columns:.92fr 1fr;gap:65px;align-items:center}
.business-photo{position:relative}
.business-photo img{width:100%;min-height:570px;object-fit:cover;border-radius:28px;box-shadow:0 25px 60px rgba(0,0,0,.28)}
.business-badge{position:absolute;left:22px;bottom:22px;padding:10px 16px;border-radius:999px;background:#fff;color:var(--navy);font-size:12px;font-weight:1000}
.business-copy h2{color:#fff}
.business-copy>p:not(.section-kicker){color:rgba(255,255,255,.72)}
.business-list{display:flex;flex-wrap:wrap;gap:8px;margin:24px 0}
.business-list span{padding:7px 11px;border:1px solid rgba(255,255,255,.16);border-radius:999px;background:rgba(255,255,255,.07);font-size:11px;font-weight:800}
.business-points{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:23px 0}
.business-points div{padding:14px 12px;border-radius:14px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.11)}
.business-points strong,.business-points span{display:block}
.business-points strong{font-size:13px}
.business-points span{color:rgba(255,255,255,.62);font-size:10px}
.referral-section{background:#fff}
.referral-layout{display:grid;grid-template-columns:1fr .86fr;gap:60px;align-items:center}
.referral-copy>p:not(.section-kicker):not(.small-note){color:var(--muted)}
.referral-numbers{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:25px 0}
.referral-numbers div{padding:18px 12px;border-radius:16px;background:var(--soft);border:1px solid var(--border);text-align:center}
.referral-numbers strong,.referral-numbers span{display:block}
.referral-numbers strong{color:var(--navy);font-size:21px}
.referral-numbers span{color:#2d8c49;font-weight:900;font-size:12px}
.small-note{color:var(--muted);font-size:11px}
.referral-image img{width:min(520px,100%);margin-left:auto;border-radius:20px;box-shadow:var(--shadow)}
.area-layout{display:grid;grid-template-columns:.85fr 1fr;gap:60px;align-items:center}
.area-main{margin:16px 0 14px;color:var(--navy);font-size:24px;font-weight:1000}
.area-tags{display:flex;flex-wrap:wrap;gap:8px}
.area-tags span{padding:8px 14px;border-radius:999px;background:var(--navy);color:#fff;font-size:12px;font-weight:900}
.area-card{padding:28px;border:1px solid var(--border);border-radius:20px;background:#fff;box-shadow:0 12px 35px rgba(8,42,97,.07)}
.area-card h3{margin:0;color:var(--navy);font-size:21px}
.area-card p{margin:10px 0 0;color:var(--muted)}
.faq-list{display:grid;gap:10px}
.faq-list details{border:1px solid var(--border);border-radius:14px;background:#fff}
.faq-list summary{position:relative;padding:18px 50px 18px 20px;color:var(--navy);font-weight:900;cursor:pointer;list-style:none}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:"+";position:absolute;right:20px;top:50%;transform:translateY(-50%);font-size:24px;color:var(--blue)}
.faq-list details[open] summary::after{content:"−"}
.faq-list p{margin:0;padding:0 20px 19px;color:var(--muted);font-size:13px}
.contact-section{padding:84px 0;background:linear-gradient(135deg,var(--navy),var(--navy-deep));color:#fff;text-align:center}
.contact-inner{max-width:840px}
.contact-inner h2{color:#fff}
.contact-inner>p:not(.section-kicker):not(.contact-note){color:rgba(255,255,255,.72)}
.contact-buttons{display:grid;grid-template-columns:1fr 1fr;gap:12px;max-width:720px;margin:28px auto 0}
.contact-note{color:rgba(255,255,255,.58);font-size:11px}
.site-footer{padding:42px 0 105px;background:#020e24;color:rgba(255,255,255,.7)}
.footer-grid{display:grid;grid-template-columns:1.2fr .8fr 1fr;gap:30px;align-items:start}
.footer-brand{display:flex;align-items:center;gap:13px}
.footer-brand img{width:74px;height:44px;object-fit:contain;filter:brightness(0) invert(1)}
.footer-brand div,.footer-info{display:flex;flex-direction:column}
.footer-brand strong{color:#fff}
.footer-brand span,.footer-info span{font-size:11px}
.footer-links{display:flex;flex-wrap:wrap;gap:8px 16px;font-size:12px}
.copyright{margin-top:28px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1);font-size:10px}
.mobile-bottom{display:none}
@media(max-width:1020px){
  .desktop-nav,.header-phone{display:none}
  .menu-button{display:block}
  .hero-grid{grid-template-columns:1fr .8fr;gap:34px}
  .hero-visual{min-height:570px}
  .service-grid{grid-template-columns:repeat(2,1fr)}
  .price-grid{grid-template-columns:repeat(2,1fr)}
  .works-grid{grid-template-columns:repeat(3,1fr)}
  .work-card.wide{grid-column:span 1}
  .line-layout,.business-layout,.referral-layout{gap:38px}
}
@media(max-width:760px){
  :root{--shell:min(100% - 28px,680px)}
  body{padding-bottom:64px}
  .top-note{font-size:10px}
  .header-inner{min-height:66px}
  .brand{min-width:0;gap:7px}
  .brand img{width:58px;height:34px}
  .brand strong{font-size:14px}
  .brand small{font-size:8px}
  .header-line{display:none}
  .mobile-menu{display:block}
  .hero{padding:48px 0 52px}
  .hero-grid{grid-template-columns:1fr;gap:30px}
  .hero h1{font-size:clamp(40px,12vw,58px)}
  .hero-lead{font-size:14px}
  .hero-buttons{grid-template-columns:1fr}
  .hero-visual{min-height:500px}
  .hero-main-photo{inset:0 28px 42px 0}
  .hero-sub-one{width:145px;height:178px}
  .hero-sub-two{left:-5px;width:145px;height:145px}
  .hero-photo-label{left:8px;top:17px}
  .trust-grid{grid-template-columns:repeat(2,1fr)}
  .trust-grid div{border-bottom:1px solid var(--border)}
  .trust-grid strong{font-size:17px}
  .section{padding:66px 0}
  .section-heading{margin-bottom:30px}
  .heading-left{display:block}
  .heading-left>p{margin-top:12px}
  .service-grid{grid-template-columns:1fr}
  .service-card-photo>img{height:235px}
  .service-card-placeholder{grid-template-columns:110px 1fr;min-height:230px}
  .placeholder-icon{width:78px;height:78px}
  .price-grid{grid-template-columns:1fr}
  .price-card h3{min-height:0}
  .price-footer{align-items:flex-start;flex-direction:column}
  .works-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:210px}
  .work-card-tall{grid-row:span 1}
  .works-grid .work-card:first-child{grid-column:span 2;grid-row:span 2}
  .line-layout,.business-layout,.referral-layout,.area-layout{grid-template-columns:1fr}
  .line-side{grid-template-columns:1fr 1fr;align-items:stretch}
  .qr-card{padding:18px}
  .business-photo img{min-height:360px}
  .business-points{grid-template-columns:1fr}
  .referral-image img{margin:auto}
  .contact-buttons{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .mobile-bottom{position:fixed;z-index:1200;right:0;bottom:0;left:0;display:grid;grid-template-columns:1fr 1fr;padding-bottom:env(safe-area-inset-bottom);background:var(--navy-deep);box-shadow:0 -8px 24px rgba(0,0,0,.18)}
  .mobile-bottom a{min-height:58px;display:flex;flex-direction:row;gap:8px;align-items:center;justify-content:center;color:#fff}
  .mobile-bottom a:first-child{border-right:1px solid rgba(255,255,255,.14)}
  .mobile-bottom .mobile-bottom-icon{font-size:17px;line-height:1;opacity:1}
  .mobile-bottom strong{font-size:14px;line-height:1;font-weight:900}
  .mobile-bottom .mobile-line{background:var(--line)}
}
@media(max-width:470px){
  .hero-visual{min-height:440px}
  .hero-main-photo{inset:0 20px 38px 0}
  .hero-sub-one{width:120px;height:150px}
  .hero-sub-two{width:118px;height:118px}
  .line-side{grid-template-columns:1fr}
  .works-grid{grid-template-columns:1fr;grid-auto-rows:250px}
  .works-grid .work-card:first-child{grid-column:span 1;grid-row:span 1}
  .trust-grid strong{font-size:15px}
  .service-card-placeholder{grid-template-columns:1fr;text-align:center}
  .placeholder-icon{margin-top:24px}
  .service-card-placeholder .service-card-body{padding-top:14px}
}

@media(max-width:470px){
  .estimate-photo-grid{grid-template-columns:1fr;gap:10px;padding:10px;background:#eef3f8}
  .estimate-photo-item{border-radius:14px;box-shadow:0 6px 18px rgba(8,42,97,.08)}
  .estimate-photo-item>img{aspect-ratio:16/9}
  .estimate-photo-label{padding:12px 14px 14px}
  .estimate-photo-label span{font-size:13px}
  .estimate-photo-label small{font-size:10px}
}

@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}.button,.service-card,.work-card img{transition:none}}

/* Mobile first-view refinement v2 */
@media(max-width:760px){
  .hero{padding:32px 0 38px}
  .hero-grid{gap:22px}
  .eyebrow{margin-bottom:8px;font-size:10px;letter-spacing:.16em}
  .hero h1{font-size:clamp(31px,9.4vw,38px);line-height:1.18;letter-spacing:-.045em;word-break:keep-all}
  .hero-lead{margin-top:18px;font-size:13px;line-height:1.78}
  .hero-tags{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:7px;margin-top:17px}
  .hero-tags span{display:grid;place-items:center;min-height:46px;padding:6px 5px;border-radius:12px;font-size:10px;line-height:1.35;text-align:center}
  .hero-buttons{margin-top:17px}
  .hero-buttons .button-line{display:none}
  .hero-buttons .button-outline{min-height:50px;padding:10px 18px;font-size:14px}
  .hero-note{display:none}
  .hero-visual{min-height:370px}
  .hero-main-photo{inset:0 0 26px 0;border-radius:22px}
  .hero-main-photo img{object-position:center 35%}
  .hero-photo-label{top:12px;left:12px;padding:7px 11px;font-size:10px}
  .hero-sub-one{right:10px;bottom:0;width:108px;height:130px;border-width:5px;border-radius:16px}
  .hero-sub-two{display:none}
}
@media(max-width:390px){
  :root{--shell:min(100% - 24px,680px)}
  .hero h1{font-size:clamp(30px,9.2vw,35px)}
  .hero-lead{font-size:12.5px}
  .hero-tags span{font-size:9.5px}
  .hero-visual{min-height:340px}
}

/* =========================================================
   Responsive typography & accessibility hardening v3
   - Prevent text clipping/horizontal overflow
   - Let text-containing controls grow vertically
   - Keep fixed CTA clear of page content via JS-measured height
   ========================================================= */
:root{
  --mobile-cta-height:0px;
}
html{
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
}
body,
main,
header,
footer,
section,
.shell,
.header-inner,
.hero-grid,
.service-grid,
.price-grid,
.works-grid,
.line-layout,
.business-layout,
.referral-layout,
.area-layout,
.contact-buttons,
.footer-grid,
.brand,
.brand span,
.hero-copy,
.hero-visual,
.service-card,
.service-card-body,
.price-card,
.work-card,
.line-copy,
.line-side,
.business-copy,
.referral-copy,
.area-card{
  min-width:0;
}
p,h1,h2,h3,li,summary,strong,small,span,a{
  max-width:100%;
}
.brand strong{
  min-width:0;
  white-space:nowrap;
}
.brand-name-short{display:none}
.button{
  height:auto;
  max-width:100%;
  white-space:normal;
  text-align:center;
  line-height:1.35;
  overflow-wrap:anywhere;
}
.button>span{min-width:0}
.button>span:last-child{flex:0 0 auto}
.hero h1{
  max-width:100%;
  overflow-wrap:anywhere;
  word-break:normal;
  line-break:strict;
  text-wrap:balance;
}
.hero-line{display:block}
.hero-line-accent{color:var(--blue)}
.hero-lead,
.section-heading p,
.service-card p,
.price-card li,
.business-copy p,
.area-card p,
.faq-list p,
.contact-inner p{
  overflow-wrap:anywhere;
}
.contact-phone-text{
  display:flex;
  min-width:0;
  flex-direction:column;
  align-items:flex-start;
  line-height:1.25;
}
.contact-phone-text strong,
.contact-phone-text small{
  display:block;
  white-space:normal;
}
.contact-phone-text small{font-size:.72em;font-weight:800}

@media(max-width:760px){
  body{
    padding-bottom:calc(var(--mobile-cta-height, 72px) + 16px + env(safe-area-inset-bottom));
  }
  .top-note{
    min-height:0;
    padding-block:7px;
    line-height:1.45;
    white-space:normal;
  }
  .header-inner{
    min-height:66px;
    height:auto;
    padding-block:8px;
    gap:8px;
  }
  .brand{
    flex:1 1 auto;
    gap:7px;
    min-width:0;
  }
  .brand img{
    flex:0 0 auto;
    width:52px;
    height:32px;
  }
  .brand span{min-width:0}
  .brand strong{
    font-size:clamp(.78rem,3.5vw,.9rem);
    line-height:1.25;
    letter-spacing:.01em;
  }
  .brand small{
    font-size:clamp(.62rem,2.3vw,.7rem);
    line-height:1.35;
    white-space:normal;
  }
  .brand-name-full{display:none}
  .brand-name-short{display:inline}
  .header-actions{flex:0 0 auto;gap:7px}
  .menu-button{
    flex:0 0 45px;
    width:45px;
    min-width:45px;
    height:45px;
  }
  .mobile-menu{
    max-height:calc(100dvh - 66px - env(safe-area-inset-bottom));
    overflow-y:auto;
    overscroll-behavior:contain;
  }
  .mobile-menu a{
    min-height:48px;
    height:auto;
    white-space:normal;
    overflow-wrap:anywhere;
  }
  .hero h1{
    font-size:clamp(1.9rem,9.4vw,2.375rem);
    line-height:1.2;
    letter-spacing:-.04em;
    word-break:normal;
    overflow-wrap:anywhere;
  }
  .hero-line{
    width:100%;
    white-space:normal;
  }
  .hero-lead{
    font-size:clamp(.84rem,3.35vw,.95rem);
    line-height:1.8;
  }
  .hero-tags{
    grid-template-columns:repeat(auto-fit,minmax(min(100%,8rem),1fr));
  }
  .hero-tags span{
    min-height:0;
    height:auto;
    padding:9px 7px;
    font-size:clamp(.7rem,2.7vw,.8rem);
    overflow-wrap:anywhere;
  }
  .hero-buttons .button-outline,
  .line-main-button,
  .contact-buttons .button,
  .business-copy .button{
    min-height:50px;
    height:auto;
    padding-block:12px;
  }
  .section-heading h2,
  .heading-left h2,
  .line-copy h2,
  .business-copy h2,
  .referral-copy h2,
  .area-layout h2,
  .contact-inner h2{
    font-size:clamp(1.75rem,8vw,2.65rem);
    line-height:1.3;
    overflow-wrap:anywhere;
    text-wrap:balance;
  }
  .service-card-placeholder{
    min-height:0;
  }
  .service-card-body,
  .price-card,
  .area-card{
    height:auto;
  }
  .price-value{
    flex-wrap:wrap;
  }
  .price-value strong{
    font-size:clamp(2rem,10vw,2.4rem);
    overflow-wrap:anywhere;
  }
  .price-footer{
    height:auto;
  }
  .works-grid{
    grid-auto-rows:minmax(210px,auto);
  }
  .work-card{
    min-height:210px;
    height:auto;
  }
  .work-card div{
    min-width:0;
  }
  .work-card h3{
    overflow-wrap:anywhere;
  }
  .line-steps li{
    min-width:0;
    height:auto;
  }
  .line-steps li div{min-width:0}
  .referral-numbers{
    grid-template-columns:repeat(auto-fit,minmax(min(100%,7.5rem),1fr));
  }
  .business-list span,
  .area-tags span{
    white-space:normal;
    overflow-wrap:anywhere;
  }
  .faq-list summary{
    min-height:0;
    height:auto;
    padding-right:52px;
    overflow-wrap:anywhere;
  }
  .contact-phone-button{
    justify-content:space-between;
  }
  .site-footer{
    padding-bottom:calc(var(--mobile-cta-height, 72px) + 44px + env(safe-area-inset-bottom));
  }
  .footer-brand,
  .footer-info,
  .footer-links{
    min-width:0;
  }
  .footer-brand strong,
  .footer-brand span,
  .footer-info span,
  .footer-links a{
    white-space:normal;
    overflow-wrap:anywhere;
  }
  .mobile-bottom{
    grid-template-columns:repeat(2,minmax(0,1fr));
    height:auto;
    min-height:0;
    align-items:stretch;
  }
  .mobile-bottom a{
    min-width:0;
    min-height:66px;
    height:auto;
    padding:10px 8px;
    line-height:1.25;
    white-space:normal;
    overflow-wrap:anywhere;
    text-align:center;
  }
  .mobile-bottom span{
    font-size:clamp(.68rem,2.7vw,.8rem);
    line-height:1.2;
  }
  .mobile-bottom strong{
    font-size:clamp(.88rem,3.6vw,1rem);
    line-height:1.25;
    overflow-wrap:anywhere;
  }
}

@media(max-width:390px){
  :root{--shell:min(100% - 22px,680px)}
  .brand img{width:46px;height:30px}
  .brand small{display:none}
  .hero h1{font-size:clamp(1.78rem,9vw,2.15rem)}
  .hero-tags{grid-template-columns:1fr}
  .trust-grid{grid-template-columns:1fr 1fr}
  .referral-numbers{grid-template-columns:1fr}
}

@media(max-width:320px){
  .mobile-bottom{grid-template-columns:1fr}
  .mobile-bottom a{min-height:52px}
}

@media(max-width:760px){
  .text-link{
    white-space:normal;
    flex-wrap:wrap;
    overflow-wrap:anywhere;
  }
  .works-grid{
    grid-auto-rows:auto;
  }
  .work-card,
  .work-card-tall,
  .work-card.wide,
  .works-grid .work-card:first-child{
    display:flex;
    grid-column:auto;
    grid-row:auto;
    flex-direction:column;
    min-height:0;
  }
  .work-card img{
    width:100%;
    height:auto;
    aspect-ratio:4/3;
    object-fit:cover;
  }
  .work-card::after{display:none}
  .work-card>div{
    position:static;
    padding:14px 16px 16px;
    background:linear-gradient(135deg,#0b214a,var(--navy-dark));
  }
  .work-card h3{
    margin-top:7px;
    font-size:clamp(1rem,4vw,1.15rem);
  }
  .business-badge{
    right:12px;
    bottom:12px;
    left:12px;
    width:max-content;
    max-width:calc(100% - 24px);
    white-space:normal;
    overflow-wrap:anywhere;
  }
}

/* Brand visibility correction for nested spans */
.brand strong .brand-name-full{display:inline!important}
.brand strong .brand-name-short{display:none!important}

@media(max-width:760px){
  .top-note{
    font-size:clamp(.68rem,2.5vw,.78rem);
  }
  .brand strong .brand-name-full{display:none!important}
  .brand strong .brand-name-short{display:inline!important}
  .brand>span>small{display:none!important}
}

@media(min-width:1021px){
  .hero-grid{
    grid-template-columns:minmax(0,1.08fr) minmax(440px,.92fr);
    gap:60px;
  }
  .hero h1{
    font-size:clamp(46px,4.45vw,64px);
  }
  .hero-line{
    white-space:nowrap;
  }
}


/* v5 additional house-cleaning gallery */
.compare-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.compare-card{overflow:hidden;border:1px solid var(--border);border-radius:22px;background:#fff;box-shadow:0 12px 35px rgba(8,42,97,.07)}
.compare-images{display:grid;grid-template-columns:1fr 1fr;gap:0;background:#eef3fa}
.compare-images figure{position:relative;margin:0}
.compare-images img{width:100%;height:250px;object-fit:cover}
.compare-images figcaption{position:absolute;left:14px;top:14px;padding:5px 10px;border-radius:999px;background:rgba(255,255,255,.94);color:var(--navy);font-size:11px;font-weight:1000}
.compare-body{padding:20px 22px 24px}
.compare-body span{display:inline-block;padding:5px 10px;border-radius:999px;background:var(--soft-blue);color:var(--navy);font-size:10px;font-weight:1000}
.compare-body h3{margin:12px 0 8px;color:var(--navy);font-size:22px;line-height:1.45}
.compare-body p{margin:0;color:var(--muted);font-size:13px}
.work-scene-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:18px}
.work-scene-strip figure{margin:0;overflow:hidden;border-radius:18px;box-shadow:0 12px 30px rgba(8,42,97,.08);background:#fff}
.work-scene-strip img{width:100%;height:230px;object-fit:cover}
@media(max-width:1020px){
  .compare-grid{grid-template-columns:1fr}
  .work-scene-strip{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  .compare-images img{height:190px}
  .compare-body h3{font-size:19px}
}
@media(max-width:470px){
  .compare-images{grid-template-columns:1fr}
  .work-scene-strip{grid-template-columns:1fr}
  .work-scene-strip img{height:250px}
}


/* v6 immersive scroll scene inspired by editorial restaurant sites */
.scroll-scene{
  --scene-shift:0px;
  position:relative;
  min-height:clamp(680px,88vh,920px);
  display:grid;
  align-items:center;
  overflow:hidden;
  isolation:isolate;
  background:var(--navy-deep);
}
.scroll-scene-media{
  position:absolute;
  z-index:-3;
  inset:-12% 0;
  overflow:hidden;
}
.scroll-scene-media img{
  width:100%;
  height:124%;
  max-width:none;
  object-fit:cover;
  object-position:center 55%;
  transform:translate3d(0,var(--scene-shift),0) scale(1.055);
  will-change:transform;
}
.scroll-scene-shade{
  position:absolute;
  z-index:-2;
  inset:0;
  background:
    linear-gradient(90deg,rgba(3,19,47,.92) 0%,rgba(3,19,47,.76) 38%,rgba(3,19,47,.25) 72%,rgba(3,19,47,.12) 100%),
    linear-gradient(180deg,rgba(3,19,47,.12),rgba(3,19,47,.45));
}
.scroll-scene::before,
.scroll-scene::after{
  content:"";
  position:absolute;
  z-index:-1;
  left:0;
  right:0;
  height:110px;
  pointer-events:none;
}
.scroll-scene::before{top:0;background:linear-gradient(180deg,rgba(3,19,47,.68),transparent)}
.scroll-scene::after{bottom:0;background:linear-gradient(0deg,rgba(3,19,47,.72),transparent)}
.scroll-scene-inner{display:flex;align-items:center;min-height:inherit;padding-block:90px}
.scroll-scene-copy{
  width:min(650px,100%);
  padding:clamp(28px,4vw,52px);
  border:1px solid rgba(255,255,255,.2);
  border-radius:28px;
  background:linear-gradient(145deg,rgba(3,19,47,.76),rgba(8,42,97,.48));
  box-shadow:0 26px 70px rgba(0,0,0,.3);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.scroll-scene-copy h2{
  margin:0;
  color:#fff;
  font-size:clamp(38px,5.4vw,72px);
  line-height:1.22;
  letter-spacing:-.05em;
  text-wrap:balance;
}
.scroll-scene-copy h2 span{color:#a9d2ff}
.scroll-scene-copy>p:not(.section-kicker){
  max-width:570px;
  margin:22px 0 0;
  color:rgba(255,255,255,.82);
  font-size:clamp(14px,1.4vw,17px);
  line-height:1.9;
  font-weight:600;
}
.scroll-scene-tags{display:flex;flex-wrap:wrap;gap:8px;margin:25px 0}
.scroll-scene-tags span{
  padding:7px 12px;
  border:1px solid rgba(255,255,255,.2);
  border-radius:999px;
  background:rgba(255,255,255,.1);
  color:#fff;
  font-size:11px;
  font-weight:900;
}
.scene-button{min-width:210px;justify-content:space-between}
.scroll-scene-guide{
  position:absolute;
  right:clamp(18px,4vw,60px);
  bottom:38px;
  display:flex;
  align-items:center;
  gap:11px;
  color:rgba(255,255,255,.72);
  font-size:9px;
  font-weight:1000;
  letter-spacing:.24em;
  writing-mode:vertical-rl;
}
.scroll-scene-guide span{
  width:1px;
  height:58px;
  background:linear-gradient(#fff,rgba(255,255,255,0));
  animation:scene-guide 1.8s ease-in-out infinite;
}
@keyframes scene-guide{
  0%,100%{transform:scaleY(.55);transform-origin:top;opacity:.45}
  50%{transform:scaleY(1);transform-origin:top;opacity:1}
}
.reveal-on-scroll{
  opacity:0;
  transform:translate3d(0,42px,0);
  transition:opacity .8s ease,transform .9s cubic-bezier(.22,1,.36,1);
}
.reveal-on-scroll.is-visible{opacity:1;transform:none}

@media(max-width:760px){
  .scroll-scene{min-height:760px;align-items:end}
  .scroll-scene-media{inset:-7% -20%}
  .scroll-scene-media img{height:114%;object-position:61% center;transform:translate3d(0,var(--scene-shift),0) scale(1.08)}
  .scroll-scene-shade{
    background:
      linear-gradient(180deg,rgba(3,19,47,.12) 0%,rgba(3,19,47,.4) 38%,rgba(3,19,47,.94) 100%);
  }
  .scroll-scene-inner{align-items:flex-end;padding-block:120px 74px}
  .scroll-scene-copy{
    padding:26px 22px;
    border-radius:22px;
    background:rgba(3,19,47,.78);
  }
  .scroll-scene-copy h2{font-size:clamp(2.15rem,10vw,3.25rem);line-height:1.22}
  .scroll-scene-copy>p:not(.section-kicker){font-size:14px;line-height:1.8}
  .scroll-scene-guide{right:12px;bottom:20px}
}


@media(max-width:470px){
  .estimate-photo-grid{grid-template-columns:1fr;gap:10px;padding:10px;background:#eef3f8}
  .estimate-photo-item{border-radius:14px;box-shadow:0 6px 18px rgba(8,42,97,.08)}
  .estimate-photo-item>img{aspect-ratio:16/9}
  .estimate-photo-label{padding:12px 14px 14px}
  .estimate-photo-label span{font-size:13px}
  .estimate-photo-label small{font-size:10px}
}

@media(prefers-reduced-motion:reduce){
  .scroll-scene-media img{transform:scale(1.04)!important;will-change:auto}
  .reveal-on-scroll{opacity:1;transform:none;transition:none}
  .scroll-scene-guide span{animation:none}
}


/* =========================================================
   v7 immersive first view + page-wide scroll rhythm
   ========================================================= */
.immersive-home{--hero-progress:0;--hero-shift:0px}
.immersive-home .site-header{
  background:rgba(3,19,47,.14);
  border-bottom:1px solid rgba(255,255,255,.14);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  transition:background .3s ease,border-color .3s ease,box-shadow .3s ease;
}
.immersive-home .site-header:not(.is-scrolled) .brand img{filter:brightness(0) invert(1)}
.immersive-home .site-header:not(.is-scrolled) .brand strong,
.immersive-home .site-header:not(.is-scrolled) .brand small,
.immersive-home .site-header:not(.is-scrolled) .desktop-nav a,
.immersive-home .site-header:not(.is-scrolled) .header-phone strong,
.immersive-home .site-header:not(.is-scrolled) .header-phone small{color:#fff}
.immersive-home .site-header:not(.is-scrolled) .desktop-nav a::after{background:#fff}
.immersive-home .site-header:not(.is-scrolled) .menu-button{background:rgba(255,255,255,.12);box-shadow:none;border:1px solid rgba(255,255,255,.22)}
.immersive-home .site-header:not(.is-scrolled) .menu-button span{background:#fff}
.immersive-home .site-header.is-scrolled{
  background:rgba(255,255,255,.96);
  border-color:rgba(8,42,97,.08);
  box-shadow:0 10px 35px rgba(3,19,47,.08);
}
.hero-v7{
  position:relative;
  min-height:calc(100svh - 29px - 82px);
  display:grid;
  align-items:center;
  overflow:hidden;
  isolation:isolate;
  background:#061a39;
  color:#fff;
}
.hero-v7-media{position:absolute;z-index:-4;inset:-5%;overflow:hidden}
.hero-v7-media img{
  width:100%;height:110%;max-width:none;object-fit:cover;object-position:center 51%;
  transform:translate3d(0,var(--hero-shift),0) scale(calc(1.035 + var(--hero-progress) * .065));
  filter:saturate(.9) contrast(1.02);
  will-change:transform;
}
.hero-v7-overlay{
  position:absolute;z-index:-3;inset:0;
  background:
    linear-gradient(90deg,rgba(2,12,31,.97) 0%,rgba(3,19,47,.89) 38%,rgba(3,19,47,.5) 68%,rgba(3,19,47,.18) 100%),
    linear-gradient(180deg,rgba(2,12,31,.08),rgba(2,12,31,.58));
  opacity:calc(1 - var(--hero-progress) * .16);
}
.hero-v7-light{
  position:absolute;z-index:-2;right:-12%;bottom:-55%;width:70vw;height:70vw;border-radius:50%;
  background:radial-gradient(circle,rgba(93,162,255,.26),rgba(93,162,255,0) 68%);
  transform:translate3d(0,calc(var(--hero-progress) * -55px),0);
}
.hero-v7::after{
  content:"";position:absolute;z-index:-1;inset:auto 0 0;height:180px;
  background:linear-gradient(0deg,rgba(2,12,31,.82),transparent);
  pointer-events:none;
}
.hero-v7-inner{
  min-height:inherit;display:grid;grid-template-columns:minmax(0,1.08fr) minmax(290px,.52fr);
  align-items:center;gap:clamp(38px,7vw,110px);padding-block:clamp(70px,9vh,120px) 120px;
}
.hero-v7-copy{max-width:820px;transform:translate3d(0,calc(var(--hero-progress) * -34px),0);opacity:calc(1 - var(--hero-progress) * .42)}
.hero-v7-eyebrow{margin:0 0 16px;color:#9fd3ff;font-size:12px;font-weight:1000;letter-spacing:.2em}
.hero-v7 h1{margin:0;font-size:clamp(58px,7.1vw,108px);line-height:.98;letter-spacing:-.065em;text-wrap:balance}
.hero-title-line{display:block;color:#fff;text-shadow:0 10px 40px rgba(0,0,0,.25)}
.hero-title-accent{color:#9fd3ff}
.hero-v7-lead{max-width:720px;margin:28px 0 0;color:rgba(255,255,255,.82);font-size:clamp(15px,1.5vw,19px);line-height:1.9;font-weight:650}
.hero-v7-buttons{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}
.hero-v7-buttons .button{min-width:280px}
.hero-ghost-button{border:1px solid rgba(255,255,255,.38);background:rgba(255,255,255,.09);color:#fff;box-shadow:none;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.hero-ghost-button:hover{background:rgba(255,255,255,.16)}
.hero-v7-points{display:flex;flex-wrap:wrap;gap:9px;margin-top:22px}
.hero-v7-points span{padding:7px 12px;border:1px solid rgba(255,255,255,.2);border-radius:999px;background:rgba(255,255,255,.08);color:#fff;font-size:11px;font-weight:900;backdrop-filter:blur(7px)}
.hero-v7-proof{align-self:end;margin-bottom:18px;padding:15px;border:1px solid rgba(255,255,255,.2);border-radius:24px;background:rgba(3,19,47,.54);box-shadow:0 24px 70px rgba(0,0,0,.28);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}
.hero-proof-images{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.hero-proof-slot{position:relative;height:155px;overflow:hidden;border-radius:15px;background:#071a3a}
.hero-proof-slot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.035);transition:opacity .75s ease,transform 4.8s ease;pointer-events:none}
.hero-proof-slot img.is-active{z-index:1;opacity:1;transform:scale(1)}
.hero-proof-copy{padding:14px 5px 3px;display:flex;flex-direction:column}
.hero-proof-copy span{color:#79e39d;font-size:9px;font-weight:1000;letter-spacing:.18em}
.hero-proof-copy strong{margin-top:5px;color:#fff;font-size:17px;line-height:1.45}
.hero-proof-copy small{margin-top:4px;color:rgba(255,255,255,.62);font-size:10px}
.hero-scroll-guide{position:absolute;left:50%;bottom:22px;display:flex;flex-direction:column;align-items:center;gap:8px;transform:translateX(-50%);color:rgba(255,255,255,.72);font-size:8px;font-weight:1000;letter-spacing:.28em}
.hero-scroll-guide i{display:block;width:1px;height:46px;background:linear-gradient(#fff,rgba(255,255,255,0));animation:v7-scroll-guide 1.8s ease-in-out infinite}
@keyframes v7-scroll-guide{0%,100%{transform:scaleY(.4);transform-origin:top;opacity:.4}50%{transform:scaleY(1);transform-origin:top;opacity:1}}
.hero-enter{opacity:0;transform:translate3d(0,36px,0);animation:v7-hero-enter .9s cubic-bezier(.22,1,.36,1) forwards;animation-delay:var(--enter-delay,0s)}
@keyframes v7-hero-enter{to{opacity:1;transform:none}}
.trust-strip-v7{position:relative;z-index:4;margin-top:-1px;border-top:0;background:#fff;border-radius:28px 28px 0 0;box-shadow:0 -18px 55px rgba(3,19,47,.16)}

/* Global reveal rhythm */
.reveal-item{opacity:0;transform:translate3d(0,38px,0);transition:opacity .75s ease,transform .9s cubic-bezier(.22,1,.36,1);transition-delay:var(--reveal-delay,0ms)}
.reveal-item.reveal-left{transform:translate3d(-46px,0,0)}
.reveal-item.reveal-right{transform:translate3d(46px,0,0)}
.reveal-item.reveal-scale{transform:scale(.94)}
.reveal-item.is-visible{opacity:1;transform:none}
.service-card-photo img,.work-card img,.compare-images img{transition:clip-path 1.05s cubic-bezier(.22,1,.36,1),transform .5s ease;clip-path:inset(0 100% 0 0)}
.service-card-photo.is-visible img,.work-card.is-visible img,.compare-card.is-visible .compare-images img{clip-path:inset(0 0 0 0)}
.service-card-photo:nth-child(even) img,.work-card:nth-child(even) img,.compare-card:nth-child(even) .compare-images img{clip-path:inset(0 0 0 100%)}
.service-card-photo:nth-child(even).is-visible img,.work-card:nth-child(even).is-visible img,.compare-card:nth-child(even).is-visible .compare-images img{clip-path:inset(0)}
.section-heading.reveal-item h2{transition:letter-spacing .9s cubic-bezier(.22,1,.36,1);letter-spacing:-.06em}
.section-heading.reveal-item.is-visible h2{letter-spacing:-.035em}

@media(max-width:1020px){
  .hero-v7-inner{grid-template-columns:1fr .42fr;gap:30px}
  .hero-v7 h1{font-size:clamp(54px,8vw,80px)}
  .hero-v7-proof{align-self:center;padding:11px;border-radius:20px}
  .hero-proof-images{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}
  .hero-proof-slot{height:118px;border-radius:12px}
  .hero-proof-copy{padding:11px 3px 2px}
  .hero-proof-copy strong{font-size:14px}
}
@media(max-width:760px){
  .immersive-home .site-header:not(.is-scrolled) .brand-name-full{display:inline!important}
  .immersive-home .site-header:not(.is-scrolled) .brand-name-short{display:none!important}
  .immersive-home .site-header:not(.is-scrolled) .brand strong{font-size:clamp(.72rem,3.35vw,.84rem)}
  .immersive-home .site-header:not(.is-scrolled) .brand>span>small{display:none!important}
  .immersive-home .site-header.is-scrolled .brand-name-full{display:inline!important}
  .immersive-home .site-header.is-scrolled .brand-name-short{display:none!important}
  .immersive-home .site-header.is-scrolled .brand strong{font-size:clamp(.72rem,3.35vw,.84rem)}
  .immersive-home .site-header.is-scrolled .brand>span>small{display:none!important}
  .hero-v7{min-height:calc(100svh - 28px - 66px);align-items:end}
  .hero-v7-media{inset:-3% -38% -3% -26%}
  .hero-v7-media img{height:106%;object-position:61% center;transform:translate3d(0,var(--hero-shift),0) scale(calc(1.04 + var(--hero-progress) * .06))}
  .hero-v7-overlay{background:linear-gradient(180deg,rgba(2,12,31,.18) 0%,rgba(2,12,31,.58) 42%,rgba(2,12,31,.97) 100%)}
  .hero-v7-inner{grid-template-columns:1fr;gap:20px;align-items:end;padding-block:110px 84px}
  .hero-v7-copy{align-self:end}
  .hero-v7 h1{font-size:clamp(2.65rem,13.2vw,4.15rem);line-height:1.02;letter-spacing:-.06em}
  .hero-v7-eyebrow{font-size:9px;margin-bottom:11px}
  .hero-v7-lead{margin-top:20px;font-size:13px;line-height:1.75}
  .hero-v7-buttons{display:grid;grid-template-columns:1fr;margin-top:20px}
  .hero-v7-buttons .button{min-width:0;width:100%;min-height:54px}
  .hero-v7-points{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;margin-top:14px}
  .hero-v7-points span{display:grid;place-items:center;padding:7px 4px;border-radius:10px;font-size:9px;line-height:1.35;text-align:center}
  .hero-v7-proof{display:block;width:100%;margin:2px 0 0;padding:10px;border-radius:18px;background:rgba(3,19,47,.72)}
  .hero-proof-images{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}
  .hero-proof-slot{height:96px;border-radius:12px}
  .hero-proof-copy{padding:9px 3px 1px}
  .hero-proof-copy span{font-size:7.5px}
  .hero-proof-copy strong{margin-top:3px;font-size:13px;line-height:1.35}
  .hero-proof-copy small{margin-top:3px;font-size:9px}
  .hero-scroll-guide{display:flex;left:50%;bottom:18px;z-index:3;font-size:7px;gap:6px}
  .trust-strip-v7{border-radius:20px 20px 0 0}
  .reveal-item.reveal-left,.reveal-item.reveal-right{transform:translate3d(0,34px,0)}
}
@media(max-width:390px){
  .hero-v7 h1{font-size:clamp(2.4rem,12.5vw,3.25rem)}
  .hero-v7-lead{font-size:12px}
  .hero-v7-points span{font-size:8.5px}
}

@media(max-width:470px){
  .estimate-photo-grid{grid-template-columns:1fr;gap:10px;padding:10px;background:#eef3f8}
  .estimate-photo-item{border-radius:14px;box-shadow:0 6px 18px rgba(8,42,97,.08)}
  .estimate-photo-item>img{aspect-ratio:16/9}
  .estimate-photo-label{padding:12px 14px 14px}
  .estimate-photo-label span{font-size:13px}
  .estimate-photo-label small{font-size:10px}
}

@media(prefers-reduced-motion:reduce){
  .hero-v7-media img{transform:scale(1.04)!important;will-change:auto}
  .hero-v7-copy{transform:none!important;opacity:1!important}
  .hero-enter,.reveal-item{opacity:1;transform:none;animation:none;transition:none}
  .hero-scroll-guide i{animation:none}
  .service-card-photo img,.work-card img,.compare-images img{clip-path:none;transition:none}
}

/* v7 visual corrections after desktop/mobile preview */
.immersive-home .site-header{margin-bottom:-82px}
.hero-v7{min-height:calc(100svh - 29px)}
.hero-v7-inner{grid-template-columns:minmax(0,1fr) 330px;gap:38px}
.hero-v7-copy{max-width:860px}
.hero-v7 h1{font-size:clamp(56px,6.15vw,88px)}
.hero-v7 h1 .hero-title-line{color:#fff;white-space:nowrap}
.hero-v7 h1 .hero-title-accent{color:#9fd3ff}
@media(max-width:1020px){
  .hero-v7-inner{grid-template-columns:minmax(0,1fr) 260px;gap:26px}
  .hero-v7 h1{font-size:clamp(50px,7.1vw,72px)}
}
@media(max-width:760px){
  .immersive-home .site-header{margin-bottom:-66px}
  .hero-v7{min-height:calc(100svh - 28px)}
  .hero-v7-inner{grid-template-columns:1fr}
  .hero-v7 h1{font-size:clamp(2.35rem,11.3vw,3.05rem)}
  .hero-v7 h1 .hero-title-line{white-space:nowrap}
}


/* v9 corrections */
.trust-strip-v7{border-bottom:0!important;}
.trust-strip-v7 + .section-soft{border-top:0;}
.scroll-scene-media img{object-position:center 42%;}
@media(max-width:760px){
  .scroll-scene-media img{object-position:55% center;}
}


/* v13: reveal the real-work photo and remove the unnecessary mid-page scroll guide */
.scroll-scene-guide{display:none!important;}
@media(min-width:761px){
  .scroll-scene-shade{
    background:
      linear-gradient(90deg,rgba(3,19,47,.10) 0%,rgba(3,19,47,.14) 34%,rgba(3,19,47,.54) 66%,rgba(3,19,47,.84) 100%),
      linear-gradient(180deg,rgba(3,19,47,.10),rgba(3,19,47,.38));
  }
  .scroll-scene-inner{justify-content:flex-end;}
  .scroll-scene-copy{
    width:min(520px,47vw);
    padding:clamp(32px,3.2vw,44px);
    border-color:rgba(255,255,255,.17);
    background:linear-gradient(145deg,rgba(3,19,47,.70),rgba(8,42,97,.46));
    box-shadow:0 22px 56px rgba(0,0,0,.24);
    backdrop-filter:blur(7px);
    -webkit-backdrop-filter:blur(7px);
  }
  .scroll-scene-copy h2{font-size:clamp(36px,4.4vw,62px);}
}

/* v15: show the high-window cleaning action and use the copy panel to cover the worker's lower back */
@media(min-width:761px){
  .scroll-scene-shade{
    background:
      linear-gradient(90deg,rgba(3,19,47,.34) 0%,rgba(3,19,47,.20) 42%,rgba(3,19,47,.07) 70%,rgba(3,19,47,.03) 100%),
      linear-gradient(180deg,rgba(3,19,47,.06),rgba(3,19,47,.30));
  }
  .scroll-scene-inner{
    justify-content:flex-start;
  }
  .scroll-scene-copy{
    width:min(540px,49vw);
    margin-left:clamp(18px,4vw,62px);
    padding:clamp(30px,3vw,42px);
    background:linear-gradient(145deg,rgba(3,19,47,.82),rgba(8,42,97,.64));
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
  }
  .scroll-scene-copy h2{
    font-size:clamp(34px,4.05vw,58px);
  }
}

/* v17: reveal the window-cleaning hand while keeping the worker's lower back behind the copy panel */
@media(min-width:761px){
  .scroll-scene-media img{
    object-position:38% 42%;
  }
  .scroll-scene-copy{
    width:min(455px,40vw);
    margin-left:clamp(12px,2.2vw,28px);
    padding:clamp(26px,2.4vw,34px);
  }
  .scroll-scene-copy h2{
    font-size:clamp(31px,3.35vw,44px);
  }
  .scroll-scene-copy>p:not(.section-kicker){
    font-size:14px;
    line-height:1.75;
  }
  .scroll-scene-tags{
    margin:18px 0;
  }
  .scroll-scene-tags span{
    padding:6px 10px;
    font-size:10px;
  }
  .scene-button{
    min-width:175px;
  }
}

/* v19: tighten the high-window scene and crop out the visually empty lower wall */
@media(min-width:761px){
  .scroll-scene{
    min-height:clamp(620px,74vh,760px);
  }
  .scroll-scene-media img{
    object-position:38% 25%;
  }
  .scroll-scene-inner{
    padding-block:68px;
  }
}

@media(prefers-reduced-motion:reduce){.hero-proof-slot img{transition:none}}

/* v24: clearly separate close-up and installation-context guides, and align 1–3 labels */
.estimate-photo-item{display:flex;flex-direction:column}
.estimate-photo-label{
  min-height:86px;
  grid-template-columns:30px minmax(0,1fr);
  grid-template-rows:auto 1fr;
  align-items:start;
  align-content:start;
}
.estimate-photo-label b{
  align-self:start;
  margin-top:1px;
}
.estimate-photo-label span,
.estimate-photo-label small{
  align-self:start;
}
.estimate-photo-label small{
  min-height:2.7em;
}
@media(max-width:760px){
  .estimate-photo-label{min-height:76px}
  .estimate-photo-label small{min-height:0}
}

/* v27: align the three guide illustrations at the top of the LINE estimate card */
@media (min-width:761px){
  .estimate-photo-item>img{
    height:132px;
    aspect-ratio:auto;
    object-fit:contain;
    object-position:center;
  }
  .estimate-photo-item:nth-child(2)>img{
    transform:scale(1.08);
    transform-origin:center;
  }
}

/* v28: restore mobile hero scroll guide and keep it below the proof card */
@media(max-width:760px){
  .hero-scroll-guide i{height:30px;}
}

/* v31: 選ばれる理由・ご依頼の流れ・FAQ拡充 */
.reasons-section{background:#fff}
.reasons-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.reason-card{position:relative;min-height:225px;padding:28px 25px;border:1px solid var(--border);border-radius:20px;background:linear-gradient(180deg,#fff,#f9fbfe);box-shadow:0 12px 34px rgba(8,42,97,.06)}
.reason-card-featured{background:linear-gradient(145deg,var(--navy),#0e4b91);border-color:transparent;color:#fff}
.reason-number{display:inline-grid;place-items:center;width:40px;height:40px;border-radius:50%;background:var(--soft-blue);color:var(--navy);font-size:11px;font-weight:1000;letter-spacing:.08em}
.reason-card-featured .reason-number{background:rgba(255,255,255,.14);color:#fff}
.reason-card h3{margin:18px 0 9px;color:var(--navy);font-size:20px;line-height:1.45}
.reason-card p{margin:0;color:var(--muted);font-size:13px;line-height:1.8}
.reason-card-featured h3{color:#fff}
.reason-card-featured p{color:rgba(255,255,255,.76)}

.flow-section{background:var(--soft)}
.flow-grid{position:relative;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;margin:0;padding:0;list-style:none}
.flow-grid::before{content:"";position:absolute;left:8%;right:8%;top:31px;height:2px;background:#cdd9e8}
.flow-grid li{position:relative;z-index:1;min-width:0;padding:0 8px;text-align:center}
.flow-number{display:grid;place-items:center;width:64px;height:64px;margin:0 auto 18px;border:7px solid var(--soft);border-radius:50%;background:var(--navy);color:#fff;font-size:18px;font-weight:1000;box-shadow:0 8px 20px rgba(8,42,97,.16)}
.flow-grid h3{margin:0;color:var(--navy);font-size:16px;line-height:1.45}
.flow-grid p{margin:9px 0 0;color:var(--muted);font-size:12px;line-height:1.75}

@media(max-width:1020px){
  .reasons-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .flow-grid{grid-template-columns:repeat(3,minmax(0,1fr));row-gap:30px}
  .flow-grid::before{display:none}
}
@media(max-width:760px){
  .reasons-grid{grid-template-columns:1fr;gap:12px}
  .reason-card{min-height:0;padding:22px 20px}
  .reason-card h3{font-size:18px}
  .flow-grid{grid-template-columns:1fr;gap:12px}
  .flow-grid li{display:grid;grid-template-columns:56px 1fr;column-gap:14px;align-items:start;padding:18px;text-align:left;border:1px solid var(--border);border-radius:16px;background:#fff}
  .flow-number{grid-row:1/3;width:50px;height:50px;margin:0;border:0;font-size:15px}
  .flow-grid h3{align-self:end;font-size:16px}
  .flow-grid p{margin-top:4px}
}


/* v32: independent Before/After works page */
.works-page{background:#f5f7fa}
.works-page .site-header{position:sticky;top:0}
.works-page .desktop-nav a[aria-current="page"]{color:var(--green)}
.works-page-hero{padding:92px 0 68px;background:radial-gradient(circle at 88% 10%,#194d86 0%,var(--navy-dark) 44%,var(--navy-deep) 100%);color:#fff}
.works-page-hero .section-kicker{color:#74efb4}
.works-page-hero h1{margin:8px 0 14px;font-size:clamp(42px,7vw,78px);line-height:1;letter-spacing:-.04em}
.works-page-hero p:last-child{max-width:680px;color:rgba(255,255,255,.78);font-size:16px}
.works-page-section{padding-top:58px}
.case-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px}
.case-card{overflow:hidden;border:1px solid var(--border);border-radius:24px;background:#fff;box-shadow:0 16px 44px rgba(8,42,97,.08)}
.case-card-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;padding:24px 24px 18px}
.case-number{display:block;margin-bottom:6px;color:var(--green-dark);font-size:10px;font-weight:800;letter-spacing:.16em}
.case-card h2{margin:0;font-size:clamp(20px,2.3vw,28px);line-height:1.25}
.case-location{flex:none;margin:0;color:var(--muted);font-size:12px;font-weight:700}
.case-compare{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:#d7dde5}
.case-photo{position:relative;display:block;overflow:hidden;padding:0;border:0;background:#e9edf2;cursor:zoom-in;aspect-ratio:4/3}
.case-photo img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}
.case-photo:hover img{transform:scale(1.025)}
.case-photo>span{position:absolute;z-index:2;top:10px;left:10px;padding:6px 9px;background:rgba(7,24,48,.84);color:#fff;font-size:9px;font-weight:900;letter-spacing:.12em;border-radius:999px}
.case-description{min-height:72px;margin:0;padding:19px 24px 24px;color:var(--text);font-size:14px;line-height:1.8}
.works-more{display:flex;justify-content:center;margin-top:32px}
.photo-lightbox{position:fixed;z-index:3000;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 18px 28px;background:rgba(2,12,28,.94)}
.photo-lightbox[hidden]{display:none}
.photo-lightbox img{max-width:min(1200px,96vw);max-height:78vh;object-fit:contain;border-radius:12px;box-shadow:0 24px 70px rgba(0,0,0,.4)}
.photo-lightbox p{margin:14px 0 0;color:#fff;font-size:13px;font-weight:700}
.photo-lightbox-close{position:absolute;top:max(18px,env(safe-area-inset-top));right:18px;width:44px;height:44px;border:1px solid rgba(255,255,255,.3);border-radius:50%;background:rgba(255,255,255,.12);color:#fff;font-size:30px;line-height:1;cursor:pointer}
body.lightbox-open{overflow:hidden}
@media(max-width:760px){
  .works-page-hero{padding:62px 0 48px}
  .works-page-hero p:last-child{font-size:14px}
  .works-page-section{padding-top:34px}
  .case-grid{grid-template-columns:1fr;gap:18px}
  .case-card{border-radius:18px}
  .case-card-head{align-items:flex-start;padding:18px 16px 14px}
  .case-card h2{font-size:20px}
  .case-location{padding-top:21px;font-size:10px}
  .case-photo>span{top:7px;left:7px;padding:5px 7px;font-size:8px}
  .case-description{min-height:0;padding:15px 16px 19px;font-size:13px}
}


/* v34: contact form, completion page and privacy page */
.contact-form-link{display:inline-flex;align-items:center;gap:9px;margin-top:18px;color:#fff;font-weight:900;border-bottom:1px solid rgba(255,255,255,.42);padding-bottom:3px}
.contact-form-link:hover{border-color:#fff}
.form-page-hero,.policy-hero{padding:76px 0 58px;background:radial-gradient(circle at 88% 10%,#194d86 0%,var(--navy-dark) 44%,var(--navy-deep) 100%);color:#fff}
.form-page-hero .section-kicker,.policy-hero .section-kicker{color:#74efb4}
.form-page-hero h1,.policy-hero h1{margin:8px 0 13px;font-size:clamp(40px,6vw,68px);line-height:1.1;letter-spacing:-.04em}
.form-page-hero p:last-child{max-width:680px;margin:0;color:rgba(255,255,255,.76)}
.form-page-section{background:#f3f6fa}
.form-page-layout{display:grid;grid-template-columns:minmax(0,.78fr) minmax(520px,1.22fr);gap:52px;align-items:start}
.form-guide{position:sticky;top:118px;padding:10px 0}
.form-guide h2{margin:0;color:var(--navy-dark);font-size:clamp(30px,3.5vw,46px);line-height:1.35;letter-spacing:-.035em}
.form-guide>p:not(.section-kicker){margin:18px 0 0;color:var(--muted)}
.form-guide-actions{display:grid;gap:10px;margin-top:26px}
.form-guide-actions .button{justify-content:space-between}
.form-guide-info{margin:28px 0 0;padding:0;border-top:1px solid var(--border)}
.form-guide-info div{display:grid;grid-template-columns:90px 1fr;gap:14px;padding:13px 0;border-bottom:1px solid var(--border)}
.form-guide-info dt{color:var(--muted);font-size:12px;font-weight:800}
.form-guide-info dd{margin:0;color:var(--navy);font-size:13px;font-weight:900}
.inquiry-form-card{overflow:hidden;border:1px solid var(--border);border-radius:24px;background:#fff;box-shadow:0 18px 50px rgba(8,42,97,.09)}
.form-card-head{padding:25px 28px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,#fff,#f8fbff)}
.form-card-head span{display:block;color:var(--navy);font-size:22px;font-weight:1000}
.form-card-head p{margin:5px 0 0;color:var(--muted);font-size:12px}
.form-card-head b{color:#c73535}
.inquiry-form{display:grid;gap:20px;padding:28px}
.form-field{display:grid;gap:8px}
.form-field-split{grid-template-columns:1fr 1fr;gap:16px}
.form-field-split>div{display:grid;gap:8px}
.form-field label{color:var(--navy);font-size:13px;font-weight:900}
.form-field label em{display:inline-block;margin-left:7px;padding:2px 7px;border-radius:999px;background:#c73535;color:#fff;font-size:9px;font-style:normal;vertical-align:2px}
.form-field label span{margin-left:6px;color:var(--muted);font-size:10px}
.form-field input,.form-field select,.form-field textarea{width:100%;border:1px solid #cfd9e6;border-radius:12px;background:#fff;color:var(--text);font:inherit;font-size:15px;line-height:1.5;outline:none;transition:border-color .18s,box-shadow .18s}
.form-field input,.form-field select{min-height:54px;padding:12px 14px}
.form-field textarea{min-height:170px;padding:14px;resize:vertical}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(21,93,182,.12)}
.form-honey{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;opacity:0!important;pointer-events:none!important}
.privacy-check{display:grid;grid-template-columns:22px 1fr;gap:10px;align-items:start;padding:15px;border-radius:12px;background:var(--soft);color:var(--muted);font-size:12px;line-height:1.7;cursor:pointer}
.privacy-check input{width:18px;height:18px;margin:3px 0 0;accent-color:var(--navy)}
.privacy-check a{color:var(--navy);font-weight:900;text-decoration:underline;text-underline-offset:3px}
.form-submit-button{width:100%;min-height:60px;background:var(--navy);color:#fff;font-size:16px;justify-content:center;box-shadow:0 12px 30px rgba(8,42,97,.2)}
.form-submit-button:hover{background:#0d3d7b}
.form-small-note{margin:0;color:var(--muted);font-size:11px;text-align:center}
.thanks-main{min-height:100svh;display:grid;place-items:center;padding:28px;background:radial-gradient(circle at 80% 10%,#194d86 0%,var(--navy-dark) 48%,var(--navy-deep) 100%)}
.thanks-card{width:min(650px,100%);padding:48px 40px;border-radius:28px;background:#fff;text-align:center;box-shadow:0 28px 80px rgba(0,0,0,.28)}
.thanks-brand{display:inline-flex;align-items:center;gap:10px;color:var(--navy);font-size:14px;font-weight:1000}
.thanks-brand img{width:72px;height:42px;object-fit:contain}
.thanks-check{display:grid;place-items:center;width:74px;height:74px;margin:30px auto 20px;border-radius:50%;background:#e5f7eb;color:var(--line-dark);font-size:34px;font-weight:1000}
.thanks-card h1{margin:0;color:var(--navy-dark);font-size:clamp(30px,5vw,44px);line-height:1.3}
.thanks-card p{margin:16px auto 0;max-width:500px;color:var(--muted)}
.thanks-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:30px}
.policy-section{background:#f3f6fa}
.policy-card{padding:38px;border:1px solid var(--border);border-radius:24px;background:#fff;box-shadow:0 18px 50px rgba(8,42,97,.08)}
.policy-card>p:first-child{margin-top:0}
.policy-card h2{margin:30px 0 8px;color:var(--navy);font-size:20px}
.policy-card p{color:var(--muted);font-size:14px}
.policy-contact{display:flex;flex-direction:column;gap:3px;margin-top:34px;padding:20px;border-radius:14px;background:var(--soft)}
.policy-contact strong{color:var(--navy)}
.policy-contact span,.policy-contact a{font-size:13px}
.policy-date{margin:24px 0;color:var(--muted);font-size:12px}
@media(max-width:900px){
  .form-page-layout{grid-template-columns:1fr;gap:28px}
  .form-guide{position:static}
  .form-guide-actions{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .form-page-hero,.policy-hero{padding:54px 0 42px}
  .form-page-section{padding-top:34px}
  .form-guide{padding:0}
  .form-guide h2{font-size:28px}
  .form-guide-actions{grid-template-columns:1fr}
  .inquiry-form-card{border-radius:18px}
  .form-card-head{padding:20px}
  .inquiry-form{gap:17px;padding:20px}
  .form-field-split{grid-template-columns:1fr}
  .form-field input,.form-field select{min-height:52px;font-size:16px}
  .form-field textarea{font-size:16px}
  .thanks-main{padding:18px}
  .thanks-card{padding:36px 20px;border-radius:22px}
  .thanks-actions{grid-template-columns:1fr}
  .policy-card{padding:24px 20px;border-radius:18px}
}

/* v35: Japanese-only AJAX form status */
.form-submit-status {
  min-height: 1.6em;
  margin: 12px 0 0;
  color: #173f73;
  font-size: 0.92rem;
  font-weight: 700;
  line-height: 1.6;
}
.form-submit-status:empty { display: none; }
.form-submit-status.is-error { color: #b42318; }
.form-submit-button:disabled {
  cursor: wait;
  opacity: 0.68;
}
