/*
Theme Name: Daiwa Shoko Corporate
Theme URI: https://daiwas.jp
Author: Sunset films Inc.
Author URI: https://sunsetfilms.co.jp
Description: 大和商工株式会社 コーポレートサイト WordPress テーマ（PC Figma忠実 + SPレスポンシブ統合版）
Version: 1.0.0
Text Domain: daiwa-shoko
*/

/* ===== Reset ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --blue:#0082D8;
  --blue-dark:#0061C2;
  --teal:#94D2DE;
  --green:#009A84;
  --text:#181C1F;
  --white:#fff;
  --gray:#F1F1F1;
  --light:#EDF6FA;
  --line:#D9DFE6;
  --line-d:#BABFCA;
  --tab-inactive:#E4EAEE;
  --ja:'Noto Sans JP',sans-serif;
  --en:'Figtree',sans-serif;
}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--ja);color:var(--text);background:var(--white);line-height:1.8;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{max-width:100%;height:auto;display:block}
button{border:none;background:none;cursor:pointer;font-family:inherit}
input,textarea,select{font-family:inherit;font-size:inherit}

/* ===== Section Heading ===== */
.section-en{font-family:var(--en);font-weight:500;font-size:96px;line-height:1;color:var(--blue);text-transform:capitalize}
.section-ja{display:flex;align-items:center;gap:8px;margin-top:8px}
.section-dot{width:8px;height:8px;border-radius:50%;background:var(--blue-dark);flex-shrink:0}
.section-ja span:last-child{font-weight:500;font-size:16px;line-height:1.5;letter-spacing:.48px}

/* ===== CTA Button ===== */
.btn-cta{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:var(--blue);color:var(--white);font-family:var(--ja);font-weight:500;font-size:18px;letter-spacing:.54px;padding:16px 30px;border-radius:60px;border:none;cursor:pointer;transition:opacity .3s;min-width:220px}
.btn-cta:hover{opacity:.85}
.btn-cta__arrow{width:26px;height:26px;background:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.btn-cta__arrow i{font-size:13px;color:var(--blue)}
.btn-cta--white{background:var(--white);color:var(--blue)}
.btn-cta--white .btn-cta__arrow{background:var(--blue)}
.btn-cta--white .btn-cta__arrow i{color:var(--white)}

/* ========================================================================
   HEADER — PC
   ======================================================================== */
.header{position:fixed;top:20px;left:50%;transform:translateX(-50%);width:calc(100% - 60px);max-width:1380px;z-index:1000}
.header__inner{display:flex;align-items:center;background:var(--white);border-radius:10px;box-shadow:0 0 24px rgba(127,151,167,.2);padding:14px 20px}
.header__logo img{width:220px;height:33px;object-fit:contain}
.header__nav{display:flex;align-items:center;gap:30px;margin-left:auto}
.header__nav a{font-weight:500;font-size:16px;letter-spacing:.48px;line-height:1.4;transition:opacity .3s}
.header__nav a:hover{opacity:.7}
.header__cta{display:inline-flex;align-items:center;justify-content:center;background:var(--green);color:var(--white);font-weight:600;font-size:16px;letter-spacing:.48px;padding:10px 30px;border-radius:60px;margin-left:30px;transition:opacity .3s}
.header__cta:hover{opacity:.85}
.hamburger{display:none;flex-direction:column;gap:4px;width:40px;height:40px;align-items:center;justify-content:center;background:#EDF2F3;border-radius:50%}
.hamburger__line{display:block;width:15px;height:1px;background:var(--text)}

/* ===== Mobile Menu (hidden on PC) ===== */
.mobile-menu{position:fixed;inset:0;z-index:2000;pointer-events:none;opacity:0;transition:opacity .3s}
.mobile-menu.is-open{pointer-events:auto;opacity:1}
.mobile-menu__overlay{position:absolute;inset:0;background:rgba(0,0,0,.3)}
.mobile-menu__content{position:absolute;top:15px;left:15px;right:15px;background:#EDF2F3;border-radius:12px;padding:20px;transform:translateY(-20px);transition:transform .3s}
.mobile-menu.is-open .mobile-menu__content{transform:translateY(0)}
.mobile-menu__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.mobile-menu__logo{height:27px;width:auto}
.mobile-menu__close{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--text)}
.mobile-menu__nav{display:flex;flex-direction:column;gap:4px;margin-bottom:24px}
.mobile-menu__link{display:flex;align-items:center;justify-content:space-between;padding:16px 0;font-size:18px;font-weight:500;border-bottom:1px solid var(--line)}
.mobile-menu__arrow{width:32px;height:32px;border-radius:50%;background:var(--blue);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:12px}
.mobile-menu__cta{display:flex;align-items:center;justify-content:center;gap:16px;width:100%;background:var(--blue);color:var(--white);font-size:18px;font-weight:600;padding:16px 30px;border-radius:60px}
.mobile-menu__cta-arrow{width:32px;height:32px;border-radius:50%;background:var(--white);color:var(--blue);display:flex;align-items:center;justify-content:center;font-size:12px}

/* ========================================================================
   HERO — PC
   ======================================================================== */
.hero{position:relative;width:100%;height:768px;overflow:hidden;background:#0470B8}
.hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.hero__fallback{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(4,112,184,0) 8%,rgba(4,112,184,.9) 100%);z-index:2}
.hero__content{position:absolute;left:69px;bottom:60px;width:612px;color:var(--white);z-index:3}
.hero__title{font-weight:400;font-size:56px;line-height:1.4;letter-spacing:5.6px;margin-bottom:8px}
.hero__subtitle{font-family:var(--en);font-weight:500;font-size:18px;line-height:1.5;text-transform:capitalize}
.hero__scroll{position:absolute;right:30px;bottom:60px;writing-mode:vertical-rl;font-family:var(--en);font-size:16px;line-height:1.5;letter-spacing:2px;color:var(--white);display:flex;align-items:center;gap:10px;z-index:3;text-transform:capitalize}
.hero__scroll::after{content:'';display:block;width:1px;height:85px;background:var(--white);animation:scrollLine 1.5s ease-in-out infinite}
@keyframes scrollLine{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ========================================================================
   MARQUEE — PC
   ======================================================================== */
.marquee{position:absolute;top:-49px;left:0;width:100%;height:320px;overflow:hidden;display:flex;align-items:center;mix-blend-mode:multiply;opacity:.5;z-index:0;pointer-events:none}
.marquee__inner{display:flex;white-space:nowrap;animation:mq 25s linear infinite}
.marquee__text{font-family:var(--en);font-weight:600;font-size:300px;line-height:1;text-transform:capitalize;background:linear-gradient(to bottom,#fff,#E2F3FF);-webkit-background-clip:text;background-clip:text;color:transparent;padding-right:60px;flex-shrink:0}
@keyframes mq{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ========================================================================
   ABOUT + SERVICE WRAPPER — PC
   ======================================================================== */
.about-service-wrapper{position:relative;overflow:hidden;background:var(--white)}
.service-bg-grad{position:absolute;left:0;width:100%;height:1271px;bottom:0;background:linear-gradient(to bottom,rgba(148,210,222,.5) 0%,rgba(148,210,222,.1) 41.8%,rgba(255,255,255,.5) 100%);pointer-events:none;z-index:0}
.bg-wave{position:absolute;pointer-events:none;z-index:0;display:block}
.bg-wave--left{width:1820px;height:607px;top:340px;left:-190px}
.bg-wave--right{width:1820px;height:1314px;top:421px;right:-380px}

/* --- About --- */
.about{position:relative;z-index:1;padding:100px 100px 60px;display:flex;gap:175px;align-items:flex-start}
.about__header{flex-shrink:0;width:405px}
.about__text{font-size:18px;line-height:2.2;letter-spacing:.54px;max-width:660px}

/* --- Service --- */
.service{position:relative;z-index:1;padding:0 100px 100px}
.service__header{margin-bottom:80px}
.service__list{display:flex;flex-direction:column;gap:40px}

/* --- Service Card --- */
.service-card{position:relative;background:var(--white);border-radius:20px;overflow:hidden;display:flex;min-height:539px}
.service-card__wave{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.service-card__wave svg{position:absolute;left:0;top:0;width:100%;height:100%}
.service-card__num-area{position:absolute;left:30px;top:40px;display:flex;align-items:flex-start;z-index:2}
.service-card__num{font-family:var(--en);font-weight:700;font-size:28px;color:var(--blue);writing-mode:vertical-rl;line-height:1}
.service-card__line{width:1px;min-height:459px;background:var(--blue);opacity:.4;margin-left:24px}
.service-card__line--tall{min-height:501px}
.service-card__body{padding:100px 0 60px 142px;flex:1;position:relative;z-index:2;max-width:600px}
.service-card__badge{display:inline-flex;align-items:center;border:1px solid var(--blue);background:var(--white);color:var(--blue);font-weight:500;font-size:14px;letter-spacing:.42px;padding:3px 18px;border-radius:50px;margin-bottom:10px;line-height:1.5}
.service-card__title{font-weight:500;font-size:40px;letter-spacing:1.2px;line-height:1.5;margin-bottom:12px}
.service-card__title-en{font-family:var(--en);font-weight:500;font-size:14px;color:var(--green);text-transform:capitalize;margin-bottom:40px;line-height:1}
.service-card__desc{font-size:16px;line-height:2.2;letter-spacing:.48px;font-weight:400;color:#000}
.service-card__cta{margin-top:32px}
.service-card__img{position:absolute;right:40px;top:40px;width:383px;height:459px;border-radius:20px;overflow:hidden;z-index:2}
.service-card__img img{width:100%;height:100%;object-fit:cover}
.service-card__logo-overlay{position:absolute!important;bottom:0;left:0;width:100%!important;height:auto!important;object-fit:contain!important;padding:20px}

/* Dark Card (04) */
.service-card--dark{background:rgba(0,130,216,.8);min-height:581px}
.service-card--dark .service-card__body{padding-top:80px;max-width:615px}
.service-card--dark .service-card__badge{border-color:var(--white);background:transparent;color:var(--white)}
.service-card--dark .service-card__title{color:var(--white)}
.service-card--dark .service-card__title-en{color:var(--blue-dark);margin-bottom:32px}
.service-card--dark .service-card__desc{color:var(--white);opacity:.8}
.service-card--dark .service-card__num{color:var(--white)}
.service-card--dark .service-card__line{background:var(--white)}
.service-card--dark .service-card__img{height:501px}

/* ========================================================================
   ACHIEVEMENT — PC
   ======================================================================== */
.achievement{position:relative;background:linear-gradient(to bottom,#DDE9F1,rgba(221,233,241,0));background-size:100% 476px;background-repeat:no-repeat;min-height:652px;overflow:hidden}
.achievement__defs{position:absolute;width:0;height:0;overflow:hidden}
.achievement__photo{position:absolute;left:-190px;top:45px;width:1820px;height:607px;clip-path:url(#ach-wave-clip);pointer-events:none;opacity:.8}
.achievement__photo-img{position:absolute;left:65px;top:-88px;width:1565px;height:854px;object-fit:cover;max-width:none}
.achievement__teal{position:absolute;inset:0;background:linear-gradient(110deg,rgba(148,210,222,0) 35%,rgba(148,210,222,1) 100%)}
.achievement__fade{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 30%,rgba(255,255,255,.3) 60%,rgba(255,255,255,.7) 85%,#fff 100%)}
.achievement__text{position:relative;z-index:1;display:flex;gap:130px;padding:80px 140px 60px;align-items:flex-start}
.achievement__title{font-weight:500;font-size:42px;line-height:1.5;letter-spacing:1.26px;flex-shrink:0}
.achievement__title p{margin:0}
.achievement__title p+p{margin-top:8px}
.achievement__blue{color:var(--blue)}
.achievement__desc{font-size:16px;line-height:2.2;letter-spacing:.48px;max-width:600px}
.achievement__desc p+p{margin-top:1.6em}

/* ========================================================================
   FLOW — PC
   ======================================================================== */
.flow{padding:100px}
.flow__inner{position:relative}
.flow__header{margin-bottom:80px}
.flow__body{display:flex;flex-direction:column}
.flow__item{display:grid;grid-template-columns:80px 1fr;gap:60px;align-items:start;margin-bottom:60px}
.flow__item:last-child{margin-bottom:0}
.flow__step{display:flex;flex-direction:column;align-items:center;overflow:visible}
.flow__circle{width:80px;height:80px;border-radius:50%;background:var(--white);box-shadow:0 0 0 16px rgba(148,210,222,.4);display:flex;align-items:center;justify-content:center;position:relative;z-index:1;flex-shrink:0;font-family:var(--en);font-weight:500;font-size:18px;line-height:1;color:var(--text)}
.flow__step-line{width:4px;flex:1;min-height:60px;background-image:radial-gradient(circle,var(--text) 2px,transparent 2px);background-size:4px 12px;background-repeat:repeat-y;background-position:center top;margin-top:26px}
.flow__card{display:flex;align-items:flex-start;gap:40px}
.flow__card-img{width:243px;height:280px;border-radius:12px;overflow:hidden;flex-shrink:0}
.flow__card-img img{width:100%;height:100%;object-fit:cover}
.flow__card-text{display:flex;flex-direction:column;gap:16px;flex:1;padding-top:20px}
.flow__card-text h4{font-weight:500;font-size:28px;letter-spacing:.84px;line-height:1.6;color:var(--blue)}
.flow__card-text p{font-size:16px;line-height:2;letter-spacing:.48px}
.flow__cta{text-align:center;padding-top:60px}
.flow__item:last-child .flow__step-line{display:none}

/* ========================================================================
   COMPANY — PC
   ======================================================================== */
.company{position:relative;padding:100px;overflow:hidden}
.company__bg-block{position:absolute;top:587px;left:0;width:100%;height:1086px;background:var(--light);z-index:0}
.company__wave{position:absolute;pointer-events:none;z-index:0;display:block;width:1820px;height:607px;left:-190px;top:487px}
.company__header{position:relative;z-index:1;margin-bottom:80px}
.company__content{position:relative;z-index:1;display:flex;gap:135px}
.company__sidebar{display:flex;flex-direction:column;gap:16px;width:240px;flex-shrink:0}
.company__tab{display:flex;align-items:center;justify-content:space-between;width:240px;height:98px;background:var(--tab-inactive);border:none;border-radius:4px;padding:0 24px;font-weight:500;font-size:24px;line-height:1.6;cursor:pointer;transition:all .3s;position:relative;overflow:visible}
.company__tab--active{background:var(--blue);color:var(--white)}
.company__tab-arrow{position:absolute;right:-15px;top:50%;transform:translateY(-50%);width:0;height:0;border-top:17px solid transparent;border-bottom:17px solid transparent;border-left:20px solid var(--blue-dark)}
.company__tab:not(.company__tab--active) .company__tab-arrow{display:none}
.company__panel{display:none;flex:1;max-width:865px}
.company__panel--active{display:block}
.company__table{width:100%;border-collapse:collapse}
.company__table tr{border-top:1px solid var(--line)}
.company__table th,.company__table td{padding:24px 0;font-size:18px;line-height:1.6;letter-spacing:.54px;vertical-align:top;text-align:left}
.company__table th{width:240px;font-weight:500;color:var(--blue)}
.company__table td{font-weight:400;width:625px}
.company__table td a{display:inline-flex;align-items:center;gap:7px;opacity:.7}
.company__table td a i{font-size:14px}
.company__table--history th{width:160px}

/* Clients Panel */
.clients{display:flex;flex-direction:column;gap:40px}
.clients__section{display:flex;flex-direction:column;gap:24px}
.clients__heading{display:flex;align-items:center;gap:12px;font-weight:500;font-size:28px;line-height:1.6;letter-spacing:.84px;color:var(--blue)}
.clients__heading .section-dot{width:8px;height:8px}
.clients__line{width:100%;height:1px;background:var(--line)}
.clients__text{font-size:18px;line-height:1.6;letter-spacing:.54px}
.clients__prefectures{display:flex;flex-direction:column;gap:30px}
.clients__pref{display:flex;flex-direction:column;gap:18px}
.clients__pref-label{background:#E3F2F4;padding:10px 20px;font-weight:500;font-size:20px;line-height:1.4;letter-spacing:.6px}
.clients__pref-text{font-size:16px;line-height:2;letter-spacing:.48px}
.clients__gallery{width:100%;display:flex;gap:20px;overflow-x:auto;overflow-y:hidden}
.clients__gallery-item{width:320px;height:200px;flex-shrink:0;border-radius:4px;overflow:hidden}
.clients__gallery-item img{width:100%;height:100%;object-fit:cover}

/* ========================================================================
   CONTACT — PC
   ======================================================================== */
.contact{position:relative;padding:100px;overflow:hidden}
.contact__wave{position:absolute;pointer-events:none;z-index:0;display:block}
.contact__wave--top{width:1820px;height:607px;left:-190px;top:-100px}
.contact__header{position:relative;z-index:1;margin-bottom:80px;padding-top:40px}
.contact__form-wrap{position:relative;z-index:1;background:var(--white);border-radius:20px;padding:60px 80px}
.contact__grid{display:flex;flex-wrap:wrap;gap:30px;margin-bottom:40px}
.contact__field{display:flex;flex-direction:column;gap:12px}
.contact__field--half{width:calc(50% - 15px)}
.contact__field--full{width:100%}
.contact__label{display:flex;align-items:center;gap:8px;font-weight:500;font-size:18px;letter-spacing:.54px;line-height:1.8}
.contact__label .req{color:var(--blue)}
.contact__field input,.contact__field textarea{width:100%;background:var(--gray);border:none;border-radius:4px;padding:24px 32px;font-family:var(--ja);font-weight:500;font-size:16px;letter-spacing:.48px;line-height:1.8;color:var(--text);outline:none;transition:box-shadow .3s}
.contact__field input::placeholder,.contact__field textarea::placeholder{color:#ACAFB2}
.contact__field input:focus,.contact__field textarea:focus{box-shadow:0 0 0 2px var(--blue)}
.contact__field textarea{height:208px;resize:vertical}
.contact__check{display:flex;align-items:center;gap:10px;margin-bottom:40px}
.contact__check input[type="checkbox"]{width:20px;height:20px;border:1px solid var(--line-d);border-radius:2px;appearance:none;-webkit-appearance:none;background:var(--white);cursor:pointer;flex-shrink:0}
.contact__check input[type="checkbox"]:checked{background:var(--blue);border-color:var(--blue)}
.contact__check label{font-weight:500;font-size:18px;letter-spacing:.54px;line-height:1.8;cursor:pointer}
.contact__submit{text-align:center}

/* CF7 compatibility */
.wpcf7-form-control-wrap{display:block;width:100%}
.wpcf7-form-control-wrap input,.wpcf7-form-control-wrap textarea{width:100%;background:var(--gray);border:none;border-radius:4px;padding:24px 32px;font-size:16px;font-weight:500;letter-spacing:.48px;line-height:1.8;outline:none;transition:box-shadow .3s;font-family:var(--ja)}
.wpcf7-form-control-wrap input:focus,.wpcf7-form-control-wrap textarea:focus{box-shadow:0 0 0 2px var(--blue)}

/* ========================================================================
   FOOTER — PC
   ======================================================================== */
.footer{background:var(--white);padding:60px 60px 45px}
.footer__banner{width:100%;max-width:1320px;height:332px;border-radius:12px;overflow:hidden;margin:0 auto 40px;background:var(--gray)}
.footer__banner img{width:100%;height:100%;object-fit:cover}
.footer__main{display:flex;align-items:center;justify-content:space-between;margin-bottom:40px;max-width:1320px;margin-left:auto;margin-right:auto}
.footer__logo img{width:300px;height:45px;object-fit:contain}
.footer__nav{display:flex;gap:40px}
.footer__nav a{font-weight:500;font-size:18px;letter-spacing:.54px;line-height:1.4;transition:opacity .3s}
.footer__nav a:hover{opacity:.7}
.footer__info{display:flex;justify-content:space-between;align-items:flex-end;gap:60px;max-width:1320px;margin:0 auto}
.footer__address{font-size:16px;line-height:1.8;letter-spacing:.48px}
.footer__meister{width:220px}
.footer__meister img{width:100%;height:auto}
.footer__divider{width:100%;max-width:1320px;height:1px;background:var(--line);margin:50px auto 18px}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;max-width:1320px;margin:0 auto}
.footer__group{font-weight:500;font-size:12px;line-height:1.6;opacity:.7;display:flex;align-items:center;gap:7px}
.footer__group a{text-decoration:underline}
.footer__group i{font-size:12px}
.footer__copy{font-family:var(--en);font-weight:400;font-size:14px;line-height:1;letter-spacing:.42px;opacity:.7}

/* ========================================================================
   SCROLL ANIMATION
   ======================================================================== */
.fade-in{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}
.fade-in.is-visible{opacity:1;transform:translateY(0)}

/* ========================================================================
   SP RESPONSIVE — max-width:768px
   ======================================================================== */
@media(max-width:768px){

  /* Header SP */
  .header{top:15px;width:calc(100% - 30px)}
  .header__inner{padding:10px;border-radius:8px}
  .header__logo img{width:180px;height:27px;object-fit:contain}
  .header__nav,.header__cta{display:none}
  .hamburger{display:flex;margin-left:auto}

  /* Hero SP */
  .hero{height:100vh;min-height:100vh;max-height:none}
  .hero__content{left:20px;right:20px;bottom:80px;width:auto}
  .hero__title{font-size:32px;letter-spacing:3.2px}
  .hero__subtitle{font-size:14px}
  .hero__scroll{right:20px;bottom:40px;font-size:12px}

  /* Marquee SP */
  .marquee{position:relative;top:0;height:auto;padding:10px 0;opacity:.5}
  .marquee__text{font-size:80px;padding-right:30px}

  /* About SP */
  .about{flex-direction:column;padding:60px 20px 40px;gap:30px}
  .about__header{width:100%}
  .about__text{font-size:14px;line-height:2;max-width:100%}

  /* Section Heading SP */
  .section-en{font-size:48px}
  .section-ja span:last-child{font-size:14px}

  /* Service SP */
  .service{padding:0 20px 60px}
  .service__header{margin-bottom:40px}
  .service__list{gap:24px}

  .service-card{flex-direction:column;min-height:auto;border-radius:12px}
  .service-card__wave{display:none}
  .service-card__num-area{position:static;display:flex;flex-direction:column;padding:20px 20px 0;gap:0}
  .service-card__num{writing-mode:horizontal-tb;font-size:20px;font-weight:700}
  .service-card__line{display:block;width:100%;min-height:0;height:1px;background:currentColor;opacity:.3;margin-left:0;margin-top:12px}
  .service-card__body{padding:16px 20px 30px;max-width:100%}
  .service-card__badge{font-size:12px;padding:3px 18px}
  .service-card__title{font-size:22px;margin-bottom:8px}
  .service-card__title-en{font-size:12px;margin-bottom:16px}
  .service-card__desc{font-size:14px;line-height:2.2;letter-spacing:.42px}
  .service-card__img{position:static;width:100%;height:240px;border-radius:0;order:unset}
  .service-card--dark{min-height:auto}
  .service-card--dark .service-card__body{padding-top:16px}
  .service-card--dark .service-card__img{height:240px}
  .service-card__logo-overlay{padding:10px!important}

  /* Background Waves SP */
  .bg-wave,.service-bg-grad{display:none}

  /* Achievement SP */
  .achievement{min-height:auto;padding:60px 0}
  .achievement__photo{display:none}
  .achievement__text{flex-direction:column;gap:24px;padding:0 20px}
  .achievement__title{font-size:24px}
  .achievement__desc{font-size:14px;line-height:1.8}

  /* Flow SP */
  .flow{padding:60px 20px}
  .flow__header{margin-bottom:40px}
  .flow__item{grid-template-columns:40px 1fr;gap:16px;margin-bottom:24px}
  .flow__circle{width:40px;height:40px;font-size:14px;box-shadow:0 0 0 8px rgba(148,210,222,.4)}
  .flow__step-line{min-height:40px;width:3px;margin-top:16px;background-image:radial-gradient(circle,var(--text) 1.5px,transparent 1.5px);background-size:3px 11px}
  .flow__card{flex-direction:column;gap:16px}
  .flow__card-img{width:100%;height:160px}
  .flow__card-text{padding-top:0}
  .flow__card-text h4{font-size:20px;letter-spacing:.6px}
  .flow__card-text p{font-size:14px;line-height:2}
  .flow__cta{padding-top:20px}

  /* Company SP */
  .company{padding:60px 20px}
  .company__bg-block{display:none}
  .company__wave{display:none}
  .company__header{margin-bottom:40px}
  .company__content{flex-direction:column;gap:24px}
  .company__sidebar{flex-direction:row;width:100%;gap:8px;overflow-x:auto}
  .company__tab{width:auto;min-width:auto;height:auto;padding:12px 20px;font-size:16px;flex-shrink:0}
  .company__tab-arrow{display:none!important}
  .company__panel{max-width:100%}
  .company__table th,.company__table td{display:block;width:100%;font-size:15px;padding:8px 0}
  .company__table th{padding-top:16px;padding-bottom:4px}
  .company__table td{padding-bottom:16px}
  .company__table--history th{width:100%}
  .clients__heading{font-size:20px}
  .clients__text{font-size:14px}
  .clients__pref-label{font-size:16px;padding:8px 16px}
  .clients__pref-text{font-size:14px;line-height:1.8}
  .clients__gallery{gap:12px}
  .clients__gallery-item{width:240px;height:150px}

  /* Contact SP */
  .contact{padding:60px 20px}
  .contact__wave{display:none}
  .contact__header{padding-top:0;margin-bottom:40px}
  .contact__form-wrap{padding:30px 20px;border-radius:12px}
  .contact__field--half{width:100%}
  .contact__field input,.contact__field textarea{padding:16px 20px;font-size:15px}
  .contact__check label{font-size:15px}

  /* Button SP */
  .btn-cta{font-size:16px;padding:14px 24px;min-width:180px}

  /* Footer SP */
  .footer{padding:30px 15px 20px}
  .footer__banner{height:auto;border-radius:8px;margin-bottom:30px}
  .footer__main{flex-direction:column;align-items:flex-start;gap:24px;margin-bottom:30px}
  .footer__logo img{width:200px;height:auto}
  .footer__nav{flex-direction:column;gap:16px}
  .footer__nav a{font-size:16px}
  .footer__info{flex-direction:column;align-items:flex-start;gap:20px}
  .footer__address{font-size:14px}
  .footer__meister{width:160px}
  .footer__divider{margin:30px 0 14px}
  .footer__bottom{flex-direction:column-reverse;gap:16px;align-items:flex-start}
}
