/* ===== RESET & BASE ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:"Hiragino Kaku Gothic ProN","Noto Sans JP",sans-serif;color:#222;line-height:1.8;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
strong{font-weight:700}

/* ===== DESIGN TOKENS ===== */
:root{
  --primary:#1b4d7a;
  --primary-dark:#0f3356;
  --primary-light:#e8f0f7;
  --accent:#d4a737;
  --accent-dark:#b88e25;
  --white:#fff;
  --gray-50:#f7f8fa;
  --gray-100:#f0f2f5;
  --gray-200:#e1e4e8;
  --gray-400:#9ca3af;
  --gray-600:#6b7280;
  --gray-800:#333;
  --dark:#1a1a2e;
  --radius:8px;
  --radius-lg:12px;
  --shadow:0 4px 20px rgba(0,0,0,.06);
  --shadow-lg:0 8px 32px rgba(0,0,0,.10);
  --transition:all .3s ease;
}

/* ===== UTILITIES ===== */
.container{max-width:1100px;margin:0 auto;padding:0 20px}
.section{padding:80px 0}
.section--dark{background:var(--dark);color:var(--white)}
.section--gray{background:var(--gray-50)}
.section__label{text-align:center;font-size:.8rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:8px}
.section__label--light{color:var(--accent)}
.section__title{font-size:1.7rem;font-weight:800;text-align:center;margin-bottom:48px;line-height:1.5;color:var(--gray-800)}
.section__title--light{color:var(--white)}
.section--dark .section__title{color:var(--white)}

/* ===== REVEAL ===== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.is-visible{opacity:1;transform:translateY(0)}

/* ===== BUTTON ===== */
.btn{display:inline-block;font-weight:700;text-align:center;border:none;cursor:pointer;transition:var(--transition);border-radius:var(--radius);font-family:inherit}
.btn--primary{background:var(--primary);color:var(--white);padding:16px 36px;font-size:1rem;letter-spacing:.04em;box-shadow:0 4px 16px rgba(27,77,122,.25)}
.btn--primary:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 6px 24px rgba(27,77,122,.35)}
.btn--full{width:100%;padding:18px}

/* ===== HEADER ===== */
.header{position:fixed;top:0;left:0;right:0;z-index:1000;transition:var(--transition);padding:12px 0}
.header.is-scrolled{background:rgba(255,255,255,.96);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 2px 20px rgba(0,0,0,.06);padding:8px 0}
.header__inner{max-width:1100px;margin:0 auto;padding:0 20px;display:flex;align-items:center;justify-content:space-between}
.header__logo-img{height:44px;width:auto}
.header.is-scrolled .header__logo-img{height:36px}
.header__nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--white);box-shadow:var(--shadow-lg);padding:24px 20px;flex-direction:column;gap:0}
.header__nav.is-open{display:flex}
.header__nav-link{display:block;padding:14px 0;font-size:.95rem;font-weight:600;color:var(--gray-800);border-bottom:1px solid var(--gray-100);letter-spacing:.06em}
.header__nav-link:last-child{border-bottom:none}
.header__nav-link--cta{color:var(--primary);font-weight:700}
.header__menu-btn{display:flex;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;z-index:10}
.header__menu-btn span{display:block;width:24px;height:2px;background:var(--gray-800);transition:var(--transition)}
.header.is-scrolled .header__menu-btn span{background:var(--gray-800)}
.header:not(.is-scrolled) .header__menu-btn span{background:var(--white)}
.header__menu-btn.is-open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.header__menu-btn.is-open span:nth-child(2){opacity:0}
.header__menu-btn.is-open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ===== HERO ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero__slider{position:absolute;inset:0}
.hero__slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1.5s ease}
.hero__slide--active{opacity:1}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,26,46,.55) 0%,rgba(26,26,46,.70) 100%)}
.hero__content{position:relative;z-index:1;text-align:center;padding:40px 20px}
.hero__badge{display:inline-block;background:rgba(212,167,55,.9);color:var(--white);font-size:.75rem;font-weight:700;padding:6px 20px;border-radius:100px;letter-spacing:.1em;margin-bottom:20px}
.hero__headline{color:var(--white);font-size:2.2rem;font-weight:900;line-height:1.4;margin-bottom:16px;letter-spacing:.04em}
.hero__sub{color:rgba(255,255,255,.8);font-size:.95rem;line-height:1.8;margin-bottom:32px}
.hero__scroll{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,.5);font-size:.65rem;letter-spacing:.15em}
.hero__scroll-line{width:1px;height:40px;background:linear-gradient(180deg,rgba(255,255,255,.5),transparent);animation:scrollLine 2s infinite}
@keyframes scrollLine{0%{opacity:1;transform:scaleY(1)}100%{opacity:0;transform:scaleY(0);transform-origin:top}}

/* ===== FEATURES ===== */
.features__grid{display:grid;grid-template-columns:1fr;gap:24px}
.feature-card{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);transition:var(--transition);position:relative}
.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.feature-card__img-wrap{overflow:hidden;aspect-ratio:16/10}
.feature-card__img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.feature-card:hover .feature-card__img{transform:scale(1.05)}
.feature-card__num{position:absolute;top:12px;left:12px;background:var(--primary);color:var(--white);font-size:.75rem;font-weight:900;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:"Helvetica Neue",sans-serif;z-index:1}
.feature-card__title{font-size:1.05rem;font-weight:800;padding:20px 20px 8px;line-height:1.5;color:var(--gray-800)}
.feature-card__text{font-size:.85rem;padding:0 20px 24px;line-height:1.8;color:var(--gray-600)}

/* ===== BEFORE / AFTER ===== */
.ba__grid{display:grid;grid-template-columns:1fr;gap:32px;max-width:900px;margin:0 auto}
.ba__item{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);padding:16px}
.ba__pair{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ba__img-wrap{position:relative;border-radius:var(--radius);overflow:hidden}
.ba__img{width:100%;aspect-ratio:3/2;object-fit:cover}
.ba__badge{position:absolute;top:10px;left:10px;font-size:.75rem;font-weight:900;padding:5px 16px;border-radius:100px;color:var(--white);letter-spacing:.06em}
.ba__badge--before{background:var(--gray-600)}
.ba__badge--after{background:var(--primary)}

/* ===== SYMPTOMS ===== */
.symptoms__lead{text-align:center;color:rgba(255,255,255,.75);font-size:.9rem;margin-top:-32px;margin-bottom:40px;line-height:1.8}
.symptoms__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:36px}
.symptom-card{border-radius:var(--radius);overflow:hidden}
.symptom-card__img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .4s ease}
.symptom-card:hover .symptom-card__img{transform:scale(1.08)}
.symptom-card__label{text-align:center;font-size:.8rem;font-weight:700;color:var(--white);padding:10px 8px 4px;letter-spacing:.04em}
.symptoms__cta{text-align:center}

/* ===== SERVICE TYPES ===== */
.service-types__lead{text-align:center;color:var(--gray-600);margin-top:-32px;margin-bottom:40px;font-size:.95rem}
.service-types__category{font-size:1.1rem;font-weight:800;color:var(--primary);margin-bottom:16px;padding-left:12px;border-left:4px solid var(--accent)}
.service-types__items{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:40px}
.service-types__items:last-child{margin-bottom:0}
.service-item{border-radius:var(--radius);overflow:hidden}
.service-item__img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .4s ease}
.service-item:hover .service-item__img{transform:scale(1.08)}

/* ===== FLOW ===== */
.flow__timeline{position:relative;padding-left:40px}
.flow__timeline::before{content:"";position:absolute;left:16px;top:0;bottom:0;width:2px;background:var(--gray-200)}
.flow__step{position:relative;margin-bottom:32px}
.flow__step:last-child{margin-bottom:0}
.flow__step-marker{position:absolute;left:-40px;top:0;width:34px;height:34px;background:var(--primary);color:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:.8rem;z-index:1;box-shadow:0 2px 8px rgba(27,77,122,.3)}
.flow__step-content{background:var(--white);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow)}
.flow__step-title{font-size:1.1rem;font-weight:800;color:var(--primary);margin-bottom:8px}
.flow__step-content>p{font-size:.9rem;color:var(--gray-600);line-height:1.8}
.flow__substeps-sequence{margin-top:16px}
.flow__seq-step{padding:14px 16px;background:var(--gray-50);border-radius:var(--radius);border-left:3px solid var(--accent);position:relative}
.flow__seq-num{position:absolute;top:-1px;right:12px;background:var(--accent);color:var(--white);font-size:.7rem;font-weight:900;padding:3px 10px;border-radius:0 0 var(--radius) var(--radius);font-family:"Helvetica Neue",sans-serif}
.flow__seq-title{font-size:.9rem;font-weight:700;color:var(--gray-800);margin-bottom:4px}
.flow__seq-text{font-size:.8rem;color:var(--gray-600);line-height:1.7}
.flow__seq-arrow{display:flex;flex-direction:column;align-items:center;padding:0;height:28px;position:relative}
.flow__seq-arrow::before{content:"";width:2px;height:20px;background:var(--accent)}
.flow__seq-arrow::after{content:"";width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:8px solid var(--accent)}

/* ===== GREETING ===== */
.greeting__grid{display:grid;grid-template-columns:1fr;gap:32px;align-items:start}
.greeting__img-wrap{max-width:280px;margin:0 auto;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}
.greeting__img{width:100%;aspect-ratio:2/3;object-fit:cover}
.greeting__text{font-size:.95rem;margin-bottom:16px;line-height:1.9}
.greeting__quote{margin:24px 0;padding:24px;background:var(--primary-light);border-left:4px solid var(--primary);border-radius:0 var(--radius) var(--radius) 0}
.greeting__quote p{font-size:.95rem;line-height:1.8;margin-bottom:4px}
.greeting__quote p:last-child{margin-bottom:0}
.greeting__name{font-size:1.1rem;font-weight:800;margin-top:24px;color:var(--primary)}

/* ===== COMPANY ===== */
.company__table-wrap{max-width:800px;margin:0 auto}
.company__table{width:100%;border-collapse:collapse}
.company__table th,.company__table td{padding:16px 12px;text-align:left;border-bottom:1px solid var(--gray-200);font-size:.9rem;line-height:1.7;vertical-align:top}
.company__table th{font-weight:700;color:var(--primary);white-space:nowrap;width:120px;background:var(--white)}
.company__table td{color:var(--gray-800)}

/* ===== CONTACT ===== */
.contact__grid{max-width:800px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:40px}
.contact__phone{text-align:center;padding:32px;background:var(--primary-light);border-radius:var(--radius-lg)}
.contact__phone-label{font-size:.85rem;color:var(--gray-600);margin-bottom:8px}
.contact__phone-number{display:block;font-size:2rem;font-weight:900;color:var(--primary);letter-spacing:.04em;margin-bottom:4px}
.contact__phone-hours{font-size:.8rem;color:var(--gray-600)}
.contact__form-lead{font-size:1rem;font-weight:700;margin-bottom:20px;color:var(--gray-800)}
.contact__field{margin-bottom:20px}
.contact__field label{display:block;font-size:.85rem;font-weight:700;margin-bottom:6px;color:var(--gray-800)}
.required{color:#c0392b;font-size:.75rem;margin-left:4px}
.contact__field input,.contact__field textarea{width:100%;padding:12px 14px;border:1px solid var(--gray-200);border-radius:var(--radius);font-size:.95rem;font-family:inherit;transition:border-color .3s;line-height:1.6}
.contact__field input:focus,.contact__field textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(27,77,122,.1)}
.contact__field textarea{resize:vertical}

/* ===== FOOTER ===== */
.footer{background:var(--dark);color:rgba(255,255,255,.7);padding:48px 0 24px}
.footer__inner{display:grid;grid-template-columns:1fr;gap:28px;margin-bottom:32px}
.footer__logo{height:36px;width:auto;margin-bottom:12px;filter:brightness(0) invert(1);opacity:.7}
.footer__address,.footer__tel{font-size:.8rem;line-height:1.6}
.footer__nav{display:flex;flex-direction:column;gap:8px}
.footer__nav a{font-size:.85rem;color:rgba(255,255,255,.6);transition:color .3s}
.footer__nav a:hover{color:var(--white)}
.footer__copy{text-align:center;font-size:.7rem;color:rgba(255,255,255,.35);border-top:1px solid rgba(255,255,255,.08);padding-top:20px}

/* ===== FLOATING CTA ===== */
.floating-cta{position:fixed;bottom:0;left:0;right:0;z-index:100;display:flex}
.floating-cta a{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:14px;font-size:.85rem;font-weight:700;color:var(--white);text-align:center}
.floating-cta__phone{background:var(--primary)}
.floating-cta__mail{background:var(--accent-dark)}
.floating-cta__icon{font-size:.65rem;font-weight:900;letter-spacing:.06em;background:rgba(255,255,255,.2);padding:3px 8px;border-radius:4px}

/* ===== RESPONSIVE: TABLET (768px+) ===== */
@media(min-width:768px){
  .section{padding:100px 0}
  .section__title{font-size:2rem}

  .hero__headline{font-size:3rem}

  .header__nav{display:flex;position:static;background:none;box-shadow:none;padding:0;flex-direction:row;gap:0;align-items:center}
  .header__nav-link{display:inline-block;padding:8px 16px;font-size:.85rem;border-bottom:none;color:var(--white);transition:var(--transition)}
  .header.is-scrolled .header__nav-link{color:var(--gray-800)}
  .header__nav-link:hover{opacity:.7}
  .header__nav-link--cta{background:var(--primary);color:var(--white)!important;border-radius:var(--radius);padding:8px 20px;margin-left:8px}
  .header__nav-link--cta:hover{background:var(--primary-dark);opacity:1}
  .header__menu-btn{display:none}

  .features__grid{grid-template-columns:repeat(2,1fr)}

  .ba__grid{grid-template-columns:1fr;gap:28px}

  .symptoms__grid{grid-template-columns:repeat(3,1fr);gap:16px}

  .service-types__items{grid-template-columns:repeat(3,1fr);gap:16px}

  .greeting__grid{grid-template-columns:280px 1fr;gap:40px}
  .greeting__img-wrap{max-width:none}

  .footer__inner{grid-template-columns:1fr auto}
  .footer__nav{flex-direction:row;gap:20px}
}

/* ===== RESPONSIVE: DESKTOP (1024px+) ===== */
@media(min-width:1024px){
  .section__title{font-size:2.2rem}
  .hero__headline{font-size:3.4rem}

  .features__grid{grid-template-columns:repeat(3,1fr)}

  .floating-cta{display:none}

  .contact__grid{grid-template-columns:300px 1fr;gap:48px;align-items:start}
  .contact__phone{position:sticky;top:100px}
}

/* ===== FINAL POLISH ===== */
:root{
  --primary:#185682;
  --primary-dark:#0d3554;
  --primary-light:#edf5fa;
  --accent:#c49a2f;
  --ink:#1f2a33;
  --paper:#fbfaf7;
  --radius-lg:8px;
}

html{scroll-padding-top:86px}
body{background:var(--paper);color:var(--ink);padding-bottom:58px}

.skip-link{position:fixed;top:10px;left:10px;z-index:2000;background:var(--primary-dark);color:var(--white);padding:10px 14px;border-radius:var(--radius);transform:translateY(-140%);transition:transform .2s ease}
.skip-link:focus{transform:translateY(0)}

.section{position:relative}
.section__lead{max-width:760px;margin:-28px auto 44px;text-align:center;color:var(--gray-600);font-size:.95rem;line-height:1.9}

.header{background:rgba(255,255,255,.94);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(24,86,130,.10);box-shadow:0 8px 28px rgba(12,35,54,.06);padding:10px 0}
.header.is-scrolled{padding:8px 0}
.header__logo-img{height:46px;transition:height .3s ease}
.header.is-scrolled .header__logo-img{height:40px}
.header__menu-btn{width:44px;height:44px;align-items:center;justify-content:center;border:1px solid rgba(24,86,130,.16);border-radius:var(--radius);background:rgba(255,255,255,.82)}
.header__menu-btn span{background:var(--ink)!important}
.header:not(.is-scrolled) .header__menu-btn span{background:var(--ink)}
.header__nav-link{color:var(--ink)}
.header__menu-btn:focus-visible,.btn:focus-visible,.header__nav-link:focus-visible,.floating-cta a:focus-visible,.footer__nav a:focus-visible{outline:3px solid rgba(196,154,47,.55);outline-offset:3px}

.hero{height:92svh;min-height:640px;max-height:920px;justify-content:center}
.hero__slide{object-position:center}
.hero__overlay{background:linear-gradient(90deg,rgba(13,35,54,.76) 0%,rgba(13,35,54,.52) 46%,rgba(13,35,54,.24) 100%),linear-gradient(180deg,rgba(13,35,54,.28) 0%,rgba(13,35,54,.62) 100%)}
.hero__content{width:100%;max-width:1100px;margin:0 auto;text-align:center;padding:120px 20px 70px}
.hero__badge{background:rgba(196,154,47,.96);box-shadow:0 10px 24px rgba(87,65,9,.20)}
.hero__headline{max-width:760px;margin-left:auto;margin-right:auto;font-size:clamp(2rem,6vw,3.7rem);line-height:1.32;text-shadow:0 10px 30px rgba(0,0,0,.32)}
.hero__sub{max-width:660px;margin-left:auto;margin-right:auto;color:rgba(255,255,255,.88);font-size:1rem}
.hero__proof{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin:0 auto 28px;max-width:720px}
.hero__proof div{min-width:138px;padding:10px 14px;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.12);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:var(--radius)}
.hero__proof span{display:block;color:var(--white);font-weight:900;line-height:1.35;letter-spacing:.04em}
.hero__proof small{display:block;color:rgba(255,255,255,.72);font-size:.72rem;line-height:1.5}
.hero__actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.btn--ghost{border:1px solid rgba(255,255,255,.45);color:var(--white);padding:15px 28px;background:rgba(255,255,255,.10);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.btn--ghost:hover{background:rgba(255,255,255,.18);transform:translateY(-2px)}
.hero__scroll{bottom:18px}

.feature-card,.ba__item,.flow__step-content,.greeting__img-wrap,.contact__phone,.faq__item{border:1px solid rgba(24,86,130,.08)}
.feature-card__title{font-size:1.08rem}
.feature-card__text{color:#52606b}
.ba__item{background:#fffdf8}
.symptoms{background:linear-gradient(135deg,#162332 0%,#0e3a59 100%)}
.service-item,.symptom-card{background:rgba(255,255,255,.06)}

.faq{background:var(--white)}
.faq__grid{max-width:860px;margin:0 auto;display:grid;gap:14px}
.faq__item{background:var(--paper);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.faq__item summary{cursor:pointer;list-style:none;padding:20px 52px 20px 22px;font-weight:800;color:var(--ink);position:relative;line-height:1.6}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";position:absolute;right:22px;top:50%;transform:translateY(-50%);font-size:1.4rem;color:var(--primary);font-weight:700}
.faq__item[open] summary::after{content:"-"}
.faq__item p{padding:0 22px 22px;color:var(--gray-600);font-size:.92rem;line-height:1.9}

.contact__info{display:grid;gap:18px}
.contact__points{display:grid;gap:10px;padding:18px 20px;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);box-shadow:var(--shadow)}
.contact__points li{position:relative;padding-left:18px;font-size:.88rem;color:var(--gray-600);line-height:1.6}
.contact__points li::before{content:"";position:absolute;left:0;top:.72em;width:7px;height:7px;border-radius:50%;background:var(--accent)}
.contact__field select{width:100%;padding:12px 14px;border:1px solid var(--gray-200);border-radius:var(--radius);font-size:.95rem;font-family:inherit;background:var(--white);line-height:1.6}
.contact__field select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(27,77,122,.1)}

.floating-cta{box-shadow:0 -10px 24px rgba(0,0,0,.12)}
.floating-cta a{min-width:0;white-space:nowrap;padding:13px 10px}
.floating-cta__icon{flex:0 0 auto}

@media(min-width:768px){
  body{padding-bottom:0}
  .header__nav-link{color:var(--ink)}
  .header:not(.is-scrolled) .header__nav-link{color:var(--ink)}
  .hero__content{text-align:left}
  .hero__headline,.hero__sub{margin-left:0}
  .hero__proof{justify-content:flex-start;margin-left:0}
  .hero__actions{justify-content:flex-start}
  .features__grid .feature-card:first-child{grid-column:span 2;display:grid;grid-template-columns:1fr 1fr}
  .features__grid .feature-card:first-child .feature-card__img-wrap{aspect-ratio:auto;height:100%}
}

@media(min-width:1024px){
  .hero__headline{font-size:3.8rem}
  .hero__sub{font-size:1.08rem}
  .contact__grid{grid-template-columns:320px 1fr}
}

@media(max-width:520px){
  .container{padding:0 18px}
  .section{padding:72px 0}
  .section__title{font-size:1.5rem;margin-bottom:40px}
  .section__lead{margin-top:-24px;margin-bottom:36px;text-align:left}
  .header__logo-img{height:38px}
  .header.is-scrolled .header__logo-img{height:36px}
  .header__menu-btn{position:fixed;top:8px;right:18px;z-index:1101}
  .hero{min-height:720px;height:92svh}
  .hero__content{padding:104px 18px 72px}
  .hero__headline{font-size:1.98rem;line-height:1.38}
  .hero__sub{font-size:.93rem;line-height:1.9}
  .hero__proof{display:grid;grid-template-columns:1fr;max-width:280px}
  .hero__proof div{min-width:0}
  .hero__actions{width:100%;max-width:354px;margin-left:auto;margin-right:auto}
  .hero__actions .btn{width:100%;min-width:0;padding-left:16px;padding-right:16px}
  .service-types__items{gap:10px}
  .contact__phone-number{font-size:1.7rem}
}

@media(max-width:430px){
  .hero__content{padding-left:16px;padding-right:16px}
  .hero__headline{font-size:1.86rem}
  .hero__sub{font-size:.9rem}
  .hero__proof{max-width:260px}
  .hero__actions{max-width:320px}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}
}

/* ===== REAL-IMAGE REDESIGN ===== */
.hero{background:#0b2031;isolation:isolate}
.hero__slider::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 78% 38%,rgba(255,255,255,.20),transparent 26%),linear-gradient(90deg,rgba(5,22,35,.88) 0%,rgba(6,27,45,.72) 42%,rgba(7,32,54,.28) 100%)}
.hero__slide{filter:saturate(.9) contrast(1.08);transform:scale(1.02)}
.hero__slide--active{animation:heroZoom 8s ease forwards}
@keyframes heroZoom{from{transform:scale(1.02)}to{transform:scale(1.07)}}
.hero__linework{position:absolute;inset:auto 0 0;z-index:1;height:42%;background:linear-gradient(135deg,transparent 0 58%,rgba(196,154,47,.22) 58.2%,transparent 58.8%),linear-gradient(145deg,transparent 0 66%,rgba(255,255,255,.14) 66.2%,transparent 66.8%);pointer-events:none;opacity:.72}
.hero__content{z-index:2}
.hero__badge{border-radius:0;padding:8px 18px;background:rgba(196,154,47,.92);box-shadow:none;letter-spacing:.08em}
.hero__headline{font-feature-settings:"palt";letter-spacing:.01em}
.hero__sub{max-width:690px}
.hero__proof div{border-color:rgba(255,255,255,.30);background:rgba(8,31,49,.54)}
.hero__photo-strip{position:absolute;right:max(28px,calc((100vw - 1100px) / 2));bottom:70px;z-index:2;display:none;grid-template-columns:118px;gap:12px}
.hero__photo-strip img{width:118px;height:92px;object-fit:cover;border:1px solid rgba(255,255,255,.28);box-shadow:0 20px 48px rgba(0,0,0,.28)}
.hero__photo-strip img:nth-child(2){transform:translateX(-34px)}
.hero__photo-strip img:nth-child(3){transform:translateX(10px)}

.features{background:linear-gradient(180deg,#fbfaf7 0%,#f4f7f9 100%)}
.features__grid .feature-card:first-child .feature-card__img{object-position:center 18%}
.feature-card__img{filter:saturate(.96) contrast(1.04)}

.real-work{background:#102f49;color:var(--white);overflow:hidden}
.real-work::before{content:"";position:absolute;inset:0;background:linear-gradient(115deg,rgba(196,154,47,.12),transparent 38%),radial-gradient(circle at 84% 20%,rgba(255,255,255,.12),transparent 24%);pointer-events:none}
.real-work .section__title{color:var(--white)}
.real-work .section__lead{color:rgba(255,255,255,.74)}
.real-work__grid{position:relative;display:grid;grid-template-columns:1fr;gap:14px}
.real-work__item{position:relative;overflow:hidden;border-radius:var(--radius);min-height:220px;background:#0b2031;box-shadow:0 20px 50px rgba(0,0,0,.18)}
.real-work__item img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3;filter:saturate(.95) contrast(1.08);transition:transform .55s ease}
.real-work__item:hover img{transform:scale(1.05)}
.real-work__item figcaption{position:absolute;left:14px;bottom:14px;padding:7px 12px;background:rgba(9,31,49,.82);color:var(--white);font-size:.82rem;font-weight:800;letter-spacing:.04em;border-left:3px solid var(--accent)}

.symptoms__grid{gap:16px}
.symptom-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.10)}
.symptom-card__img{background:#dfe7ec}
.symptom-card__label{padding:12px 8px;color:rgba(255,255,255,.92)}

.greeting__img{object-position:center top}

@media(min-width:768px){
  .hero__photo-strip{display:grid}
  .hero__content{padding-right:180px}
  .real-work__grid{grid-template-columns:1.3fr 1fr 1fr;grid-auto-rows:220px}
  .real-work__item img{aspect-ratio:auto}
  .real-work__item--large{grid-row:span 2}
}

@media(min-width:1024px){
  .hero{height:88svh;min-height:700px}
  .hero__headline{max-width:740px}
  .real-work__grid{grid-auto-rows:250px}
}

@media(max-width:767px){
  .hero__slider::after{background:linear-gradient(180deg,rgba(8,31,49,.78),rgba(8,31,49,.72)),linear-gradient(90deg,rgba(8,31,49,.88),rgba(8,31,49,.42))}
  .hero__slide{object-position:center}
  .hero__badge{font-size:.68rem}
}
