/* ============================================================
   index.css — Top page (Okamoto Densetsu)
   ============================================================ */

/* ============================================================
   HERO Full-width (sample-aligned)
   ============================================================ */
.hero-fw{
  position:relative;
  height:100vh;min-height:640px;
  margin-top:0;
  overflow:hidden;
}
.hero-fw__bg{position:absolute;inset:0;z-index:0}
.hero-fw__bg img{width:100%;height:100%;object-fit:cover;display:block}
.hero-fw__overlay{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg,rgba(28,23,20,.55) 0%,rgba(28,23,20,.30) 45%,rgba(28,23,20,.65) 100%),
    linear-gradient(135deg,rgba(184,90,34,.35) 0%,rgba(184,90,34,0) 55%,rgba(28,23,20,.25) 100%);
}
.hero-fw__inner{
  position:relative;z-index:2;
  height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  padding:var(--hd-h) 24px 80px;color:#fff;
  max-width:980px;margin:0 auto;
}
.hero-fw__eyebrow{
  font-family:var(--f-en);font-style:italic;font-size:13px;letter-spacing:.32em;
  color:rgba(255,255,255,.85);text-transform:uppercase;margin-bottom:28px;
  padding:6px 22px;border-top:1px solid rgba(255,255,255,.5);border-bottom:1px solid rgba(255,255,255,.5);
}
.hero-fw__title{
  font-family:var(--f-serif);font-weight:500;
  font-size:clamp(34px,5.2vw,64px);line-height:1.45;letter-spacing:.06em;
  margin:0 0 32px;color:#fff;
  text-shadow:0 4px 24px rgba(0,0,0,.35);
}
.hero-fw__title .em{color:var(--c-orange-soft)}
.hero-fw__lead{
  font-size:15px;line-height:2;color:rgba(255,255,255,.9);
  margin:0;letter-spacing:.06em;
  text-shadow:0 2px 16px rgba(0,0,0,.4);
}
.hero-fw__scroll{
  position:absolute;left:50%;bottom:36px;transform:translateX(-50%);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:14px;
  font-family:var(--f-en);font-style:italic;font-size:11px;letter-spacing:.32em;
  color:rgba(255,255,255,.75);
}
.hero-fw__scroll-line{
  width:1px;height:48px;background:rgba(255,255,255,.5);position:relative;overflow:hidden;
}
.hero-fw__scroll-line::after{
  content:"";position:absolute;top:-48px;left:0;width:1px;height:48px;background:#fff;
  animation:scroll-down 2.4s var(--ease) infinite;
}
@keyframes scroll-down{
  0%{top:-48px}100%{top:48px}
}
@media (max-width:720px){
  .hero-fw{height:90vh;min-height:520px}
  .hero-fw__title{letter-spacing:.04em}
  .hero-fw__lead{font-size:13px}
  .hero-fw__scroll{display:none}
}

/* ============================================================
   HERO (legacy - kept for ref)
   ============================================================ */
.hero{
  position:relative;
  min-height:100vh;
  padding-top:var(--hd-h);
  background:var(--c-bg);
  overflow:hidden;
}
.hero__inner{
  position:relative;
  max-width:1400px;margin:0 auto;
  padding:80px 48px 120px;
  display:grid;grid-template-columns:1.05fr .95fr;gap:80px;align-items:center;
  min-height:calc(100vh - var(--hd-h));
}
/* big watermark word */
.hero__watermark{
  position:absolute;left:-1.5%;bottom:-8%;z-index:0;
  font-family:var(--f-en);font-style:italic;font-weight:500;
  font-size:clamp(180px,22vw,360px);line-height:.85;
  color:rgba(224,122,60,.06);letter-spacing:-.02em;
  pointer-events:none;
  white-space:nowrap;
}
/* meta on left edge */
.hero__meta{
  position:absolute;left:32px;top:50%;transform:translateY(-50%) rotate(-90deg);transform-origin:left center;
  font-family:var(--f-en);font-style:italic;font-size:11px;letter-spacing:.36em;color:var(--c-ink-3);
  z-index:2;
}
.hero__meta::after{
  content:"";display:inline-block;width:48px;height:1px;background:var(--c-orange);
  vertical-align:middle;margin-left:14px;
}

.hero__copy{position:relative;z-index:2}
.hero__eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--f-en);font-style:italic;font-size:18px;color:var(--c-orange);font-weight:500;
}
.hero__eyebrow::before{content:"";width:36px;height:1px;background:currentColor}
.hero__eyebrow .num{font-family:var(--f-mono);font-size:11px;font-style:normal;color:var(--c-ink-3);letter-spacing:.18em}

.hero__title{
  font-family:var(--f-serif);font-weight:500;
  font-size:clamp(40px,5.6vw,76px);line-height:1.4;letter-spacing:.04em;
  margin:24px 0 0;color:var(--c-ink);
  text-wrap:balance;
}
.hero__title .em{
  color:var(--c-orange);
  font-weight:600;
  position:relative;
}
.hero__title .em::after{
  content:"";position:absolute;left:-2%;right:-2%;bottom:-.05em;height:.18em;
  background:var(--c-orange-pale);z-index:-1;border-radius:1px;
}
.hero__title .br{display:block}

.hero__lead{
  margin:36px 0 0;
  font-size:15px;line-height:2.2;color:var(--c-ink-2);
  max-width:36ch;letter-spacing:.04em;
  text-wrap:pretty;
}
.hero__sign{
  display:flex;align-items:center;gap:14px;margin-top:36px;
  font-family:var(--f-en);font-style:italic;font-size:13px;color:var(--c-ink-3);letter-spacing:.04em;
}
.hero__sign::before{content:"";width:36px;height:1px;background:var(--c-line-2)}

.hero__ctas{display:flex;gap:14px;margin-top:48px;flex-wrap:wrap}

/* Image side */
.hero__image{
  position:relative;z-index:1;
  aspect-ratio:4/5;
}
.hero__image .scene{
  position:absolute;inset:0;border-radius:4px;overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.hero__image .scene__caption{
  font-size:11px;letter-spacing:.18em;
}
.hero__badge{
  position:absolute;left:-40px;top:60px;
  background:#fff;padding:24px 32px;
  box-shadow:var(--shadow-md);
  z-index:3;
  border-left:2px solid var(--c-orange);
}
.hero__badge-num{
  font-family:var(--f-en);font-style:italic;font-size:48px;color:var(--c-orange);
  line-height:1;font-weight:500;
}
.hero__badge-label{
  font-size:11px;letter-spacing:.18em;color:var(--c-ink-2);margin-top:6px;font-weight:500;
}
.hero__badge-sub{font-size:10px;color:var(--c-ink-3);margin-top:4px;font-family:var(--f-en);font-style:italic;letter-spacing:.04em}

.hero__quals{
  position:absolute;right:-30px;bottom:60px;
  background:var(--c-ink);color:#fff;
  padding:24px 28px;
  z-index:3;
  max-width:260px;
}
.hero__quals-label{
  font-family:var(--f-en);font-style:italic;font-size:12px;color:var(--c-orange-soft);letter-spacing:.04em;
}
.hero__quals-title{
  font-family:var(--f-serif);font-size:14px;line-height:1.7;margin:6px 0 12px;letter-spacing:.04em;font-weight:400;
}
.hero__quals ul{list-style:none;margin:0;padding:0;font-size:11px;color:#cbb9a3;letter-spacing:.04em;line-height:1.9}
.hero__quals li::before{content:"— ";color:var(--c-orange-soft)}

/* scroll cue */
.hero__scroll{
  position:absolute;left:50%;bottom:32px;transform:translateX(-50%);z-index:2;
  font-family:var(--f-en);font-style:italic;font-size:11px;letter-spacing:.18em;color:var(--c-ink-3);
  display:flex;flex-direction:column;align-items:center;gap:12px;
}
.hero__scroll-line{
  width:1px;height:40px;background:linear-gradient(to bottom,var(--c-line-2),transparent);
  animation:scrollCue 2.4s var(--ease) infinite;
}
@keyframes scrollCue{
  0%{transform:scaleY(.3);transform-origin:top}
  50%{transform:scaleY(1);transform-origin:top}
  51%{transform:scaleY(1);transform-origin:bottom}
  100%{transform:scaleY(.3);transform-origin:bottom}
}

/* ============================================================
   INTRO centered (sample-aligned)
   ============================================================ */
.intro-c{padding:120px 0 80px;background:var(--c-bg);text-align:center}
.intro-c__inner{max-width:780px;margin:0 auto;padding:0 24px}
.intro-c__lead{
  font-family:var(--f-serif);font-size:15.5px;line-height:2.4;color:var(--c-ink-2);
  letter-spacing:.08em;margin:0;text-wrap:pretty;text-align:left;
}
.intro-c__sign{
  margin-top:48px;display:inline-flex;align-items:center;gap:18px;
  font-family:var(--f-serif);font-size:13px;color:var(--c-ink-3);letter-spacing:.06em;
}
.intro-c__sign::before{content:"";width:36px;height:1px;background:var(--c-orange)}
.intro-c__sign strong{color:var(--c-ink);font-weight:500}
@media (max-width:720px){
  .intro-c{padding:72px 0 48px}
  .intro-c__lead{font-size:14px;line-height:2.1}
}

/* ============================================================
   INTRO — editorial paragraph (legacy)
   ============================================================ */
.intro{padding:140px 0 120px;background:var(--c-bg);position:relative}
.intro__inner{
  max-width:1100px;margin:0 auto;padding:0 48px;
  display:grid;grid-template-columns:1fr 1.6fr;gap:80px;align-items:start;
}
.intro__label{
  display:flex;flex-direction:column;gap:8px;
  position:sticky;top:120px;
}
.intro__label .num{
  font-family:var(--f-mono);font-size:11px;letter-spacing:.18em;color:var(--c-ink-3);
}
.intro__label .en{font-family:var(--f-en);font-style:italic;color:var(--c-orange);font-size:24px;font-weight:500}
.intro__label .ja{
  margin-top:18px;font-family:var(--f-serif);font-size:14px;letter-spacing:.16em;color:var(--c-ink);
  writing-mode:vertical-rl;text-orientation:mixed;
}
.intro__body h2{
  font-family:var(--f-serif);font-weight:500;
  font-size:clamp(28px,3.4vw,40px);line-height:1.7;letter-spacing:.04em;
  margin:0;text-wrap:balance;
}
.intro__body h2 .em{color:var(--c-orange);font-weight:600}
.intro__body p{
  margin:36px 0 0;font-size:15px;line-height:2.15;color:var(--c-ink-2);max-width:54ch;
  text-wrap:pretty;
}
.intro__signature{
  margin-top:44px;display:flex;align-items:center;gap:20px;
  font-family:var(--f-serif);font-size:13px;color:var(--c-ink-3);letter-spacing:.06em;
}
.intro__signature::before{content:"";width:40px;height:1px;background:var(--c-orange)}
.intro__signature strong{color:var(--c-ink);font-weight:500}

/* ============================================================
   SERVICES
   ============================================================ */
.services{position:relative;background:var(--c-bg-2);padding:120px 0}
@media (max-width:720px){.services{padding:72px 0}}
.services__head{
  max-width:1200px;margin:0 auto;padding:0 48px;
  display:flex;justify-content:space-between;align-items:flex-end;gap:48px;flex-wrap:wrap;
  margin-bottom:64px;
}
.services__head-text{max-width:560px}
.services__index{
  font-family:var(--f-en);font-style:italic;font-size:14px;color:var(--c-ink-3);letter-spacing:.04em;
}
.services__list{
  max-width:1200px;margin:0 auto;padding:0 48px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:8px;
}
.svc-card{
  background:#fff;padding:0;
  display:flex;flex-direction:column;
  position:relative;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
.svc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.svc-card__media{
  aspect-ratio:4/3;position:relative;overflow:hidden;
}
.svc-card__num{
  position:absolute;top:18px;left:18px;z-index:3;
  font-family:var(--f-mono);font-size:11px;color:#fff;letter-spacing:.18em;
  background:rgba(28,23,20,.6);padding:5px 10px;backdrop-filter:blur(6px);
}
.svc-card__body{padding:32px 28px 32px}
.svc-card__en{font-family:var(--f-en);font-style:italic;font-size:14px;color:var(--c-orange);letter-spacing:.04em;font-weight:500}
.svc-card__title{
  font-family:var(--f-serif);font-weight:500;font-size:22px;letter-spacing:.06em;
  margin:8px 0 14px;line-height:1.55;
}
.svc-card__desc{
  font-size:13.5px;line-height:2;color:var(--c-ink-2);margin:0 0 24px;letter-spacing:.04em;
  text-wrap:pretty;
}
.svc-card__tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:28px}
.svc-card__tags span{
  font-size:11px;color:var(--c-ink-2);background:var(--c-bg);padding:4px 10px;border-radius:2px;letter-spacing:.04em;
}
.svc-card__more{
  display:inline-flex;align-items:center;gap:10px;font-size:12.5px;letter-spacing:.06em;color:var(--c-ink);font-weight:500;
  padding-top:16px;border-top:1px solid var(--c-line);font-family:var(--f-en);font-style:italic;
}
.svc-card__more::after{content:"→";transition:transform .3s var(--ease)}
.svc-card:hover .svc-card__more::after{transform:translateX(4px)}
.svc-card:hover .svc-card__more{color:var(--c-orange)}

/* ============================================================
   STRENGTHS — editorial style
   ============================================================ */
.strengths{background:var(--c-bg);padding:120px 0}
@media (max-width:720px){.strengths{padding:72px 0}}
.strengths__head{
  max-width:1100px;margin:0 auto 80px;padding:0 48px;
  display:grid;grid-template-columns:1fr 1.6fr;gap:80px;align-items:end;
}
.strengths__list{max-width:1100px;margin:0 auto;padding:0 48px;display:flex;flex-direction:column;gap:0}

.str-item{
  display:grid;grid-template-columns:.6fr 1fr 1fr;gap:64px;
  padding:64px 0;border-top:1px solid var(--c-line);align-items:start;
}
.str-item:last-child{border-bottom:1px solid var(--c-line)}
.str-item__num{
  font-family:var(--f-en);font-style:italic;font-size:64px;color:var(--c-orange);font-weight:500;line-height:1;
}
.str-item__num small{
  display:block;font-family:var(--f-mono);font-size:10px;color:var(--c-ink-3);letter-spacing:.18em;
  margin-top:20px;font-style:normal;
}
.str-item__title{
  font-family:var(--f-serif);font-weight:500;font-size:24px;line-height:1.7;letter-spacing:.06em;margin:0;
  text-wrap:balance;
}
.str-item__title .em{color:var(--c-orange)}
.str-item__title small{
  display:block;font-family:var(--f-en);font-style:italic;font-size:13px;color:var(--c-ink-3);
  font-weight:500;margin-top:12px;letter-spacing:.04em;
}
.str-item__desc{
  font-size:14px;line-height:2.1;color:var(--c-ink-2);margin:0;letter-spacing:.04em;
  text-wrap:pretty;
}
.str-item__quote{
  margin-top:18px;padding-left:16px;border-left:1px solid var(--c-orange);
  font-family:var(--f-serif);font-size:13px;color:var(--c-ink);font-style:italic;line-height:1.9;
}

/* ============================================================
   FLOW — horizontal timeline
   ============================================================ */
.flow{background:var(--c-orange-tint);position:relative;overflow:hidden;padding:120px 0}
@media (max-width:720px){.flow{padding:72px 0}}
.flow__head{max-width:1200px;margin:0 auto 64px;padding:0 48px}
.flow__rail{
  max-width:1300px;margin:0 auto;padding:0 48px;
  display:grid;grid-template-columns:repeat(5,1fr);gap:20px;position:relative;
}
.flow__line{
  position:absolute;left:48px;right:48px;top:48px;height:1px;
  background:repeating-linear-gradient(90deg,var(--c-orange) 0 6px,transparent 6px 14px);
  z-index:0;
}
.flow-step{
  background:transparent;text-align:left;position:relative;padding-top:0;
}
.flow-step__dot{
  width:96px;height:96px;border-radius:50%;background:#fff;border:1px solid var(--c-line);
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  position:relative;z-index:1;margin:0 0 28px;
}
.flow-step__dot::after{
  content:"";position:absolute;inset:6px;border-radius:50%;border:1px dashed var(--c-orange);
}
.flow-step__num{font-family:var(--f-en);font-style:italic;font-size:28px;color:var(--c-orange);font-weight:500;line-height:1}
.flow-step__num small{display:block;font-family:var(--f-mono);font-style:normal;font-size:9px;color:var(--c-ink-3);letter-spacing:.18em;margin-top:4px}
.flow-step__title{font-family:var(--f-serif);font-weight:500;font-size:17px;letter-spacing:.06em;margin:0 0 10px}
.flow-step__desc{font-size:12.5px;line-height:1.95;color:var(--c-ink-2);margin:0;letter-spacing:.04em}

/* ============================================================
   WORKS preview
   ============================================================ */
.works{background:var(--c-bg);padding:120px 0}
@media (max-width:720px){.works{padding:72px 0}}
.works__head{
  max-width:1300px;margin:0 auto 64px;padding:0 48px;
  display:flex;justify-content:space-between;align-items:flex-end;gap:32px;flex-wrap:wrap;
}
.works__grid{
  max-width:1300px;margin:0 auto;padding:0 48px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:48px 32px;
}
.work-card{display:block}
.work-card__media{
  aspect-ratio:4/3;overflow:hidden;position:relative;border-radius:2px;
  transition:transform .5s var(--ease);
}
.work-card:hover .work-card__media{transform:translateY(-4px)}
.work-card__meta{
  display:flex;justify-content:space-between;align-items:baseline;
  margin-top:18px;font-family:var(--f-en);font-style:italic;font-size:12px;color:var(--c-ink-3);letter-spacing:.04em;
}
.work-card__cat{color:var(--c-orange)}
.work-card__title{
  font-family:var(--f-serif);font-weight:500;font-size:17px;letter-spacing:.04em;margin:6px 0 8px;line-height:1.7;
}
.work-card__caption{font-size:12.5px;color:var(--c-ink-2);margin:0;letter-spacing:.04em;line-height:1.9}
.works__more{
  max-width:1300px;margin:64px auto 0;padding:0 48px;text-align:center;
}

/* ============================================================
   CTA band — handwritten lead
   ============================================================ */
.cta-band{
  background:var(--c-ink);color:#f1e8da;padding:120px 0;
  position:relative;overflow:hidden;
}
.cta-band::before{
  content:"CONTACT";position:absolute;left:-2%;top:-30%;
  font-family:var(--f-en);font-style:italic;font-size:clamp(140px,18vw,260px);
  color:rgba(232,116,60,.07);letter-spacing:0;line-height:1;font-weight:500;
}
.cta-band__inner{
  position:relative;max-width:1100px;margin:0 auto;padding:0 48px;
  display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;
}
.cta-band__lead{}
.cta-band__hand{
  font-family:var(--f-en);font-style:italic;font-size:24px;color:var(--c-orange-soft);font-weight:500;
}
.cta-band__title{
  font-family:var(--f-serif);font-weight:500;font-size:clamp(28px,3.6vw,42px);
  letter-spacing:.06em;line-height:1.6;margin:18px 0 24px;color:#fff;text-wrap:balance;
}
.cta-band__sub{
  font-size:14px;line-height:2;color:#cbb9a3;letter-spacing:.04em;margin:0;
  text-wrap:pretty;
}
.cta-band__contact{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  padding:48px;
}
.cta-band__tel{
  display:block;color:#fff;
}
.cta-band__tel small{font-family:var(--f-en);font-style:italic;font-size:13px;color:var(--c-orange-soft);letter-spacing:.04em}
.cta-band__tel strong{
  display:block;font-family:var(--f-en);font-style:normal;font-weight:600;font-size:48px;letter-spacing:.02em;
  margin:8px 0 4px;color:#fff;
}
.cta-band__tel span{font-family:var(--f-en);font-style:italic;font-size:12px;color:#a89b8a;letter-spacing:.16em}
.cta-band__divider{height:1px;background:rgba(255,255,255,.1);margin:28px 0}
.cta-band__row{display:flex;gap:10px}
.cta-band__row a{
  flex:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 16px;border-radius:6px;font-size:13px;font-weight:600;letter-spacing:.04em;
  transition:all .25s var(--ease);
}
.cta-band__row .is-line{background:#06C755;color:#fff}
.cta-band__row .is-line:hover{background:#05a847;color:#fff;transform:translateY(-1px)}
.cta-band__row .is-ig{
  background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);color:#fff;
}
.cta-band__row .is-ig:hover{transform:translateY(-1px);color:#fff;filter:brightness(1.05)}

/* ============================================================
   INFO (area / contact)
   ============================================================ */
.info{background:var(--c-bg-2);padding:120px 0}
.info__inner{
  max-width:1200px;margin:0 auto;padding:0 48px;
  display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:start;
}
@media (max-width:960px){
  .info{padding:72px 0}
  .info__inner{grid-template-columns:1fr;gap:32px;padding:0 24px}
}
.info__map{
  background:#E8DBC1;aspect-ratio:4/3;position:relative;overflow:hidden;border-radius:2px;
}
.info__map::before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(rgba(80,55,30,.32) 1px,transparent 1px) 0 0/40px 40px,
    linear-gradient(90deg,rgba(80,55,30,.32) 1px,transparent 1px) 0 0/40px 40px;
}
.info__map::after{
  content:"";position:absolute;left:50%;top:50%;width:12px;height:12px;border-radius:50%;
  background:var(--c-orange);box-shadow:0 0 0 8px rgba(224,122,60,.2),0 0 0 16px rgba(224,122,60,.1);
  transform:translate(-50%,-50%);
}
.info__map-tag{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-100%) translateY(-20px);
  background:#fff;padding:10px 16px;font-size:12px;font-weight:500;letter-spacing:.06em;
  box-shadow:var(--shadow-sm);white-space:nowrap;
}
.info__map-tag::after{
  content:"";position:absolute;left:50%;bottom:-6px;width:0;height:0;
  border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid #fff;
  transform:translateX(-50%);
}

.info__list{font-family:var(--f-sans)}
.info__list dl{display:grid;grid-template-columns:140px 1fr;gap:0;margin:0}
.info__list dt,.info__list dd{
  padding:20px 0;border-bottom:1px solid var(--c-line);margin:0;font-size:14px;line-height:1.9;
}
.info__list dt{
  font-family:var(--f-en);font-style:italic;color:var(--c-orange);font-weight:500;letter-spacing:.04em;
}
.info__list dd{color:var(--c-ink-2)}
.info__list dd strong{color:var(--c-ink);font-weight:500}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 1100px){
  .hero__inner{grid-template-columns:1fr;gap:48px;padding:48px 32px 96px}
  .hero__image{max-width:520px;margin:0 auto;width:100%}
  .hero__meta{display:none}
  .hero__watermark{font-size:clamp(140px,40vw,280px);bottom:-3%}
  .intro__inner,.strengths__head{grid-template-columns:1fr;gap:32px}
  .intro__label{position:static}
  .intro__label .ja{writing-mode:horizontal-tb;height:auto}
  .services__list,.works__grid{grid-template-columns:repeat(2,1fr)}
  .flow__rail{grid-template-columns:repeat(3,1fr);gap:48px 20px}
  .flow__line{display:none}
  .str-item{grid-template-columns:1fr;gap:24px;padding:48px 0}
  .cta-band__inner{grid-template-columns:1fr;gap:40px}
  .info__inner{grid-template-columns:1fr;gap:40px}
}
@media (max-width: 720px){
  .hero__title{font-size:clamp(34px,9vw,52px)}
  .services__list,.works__grid{grid-template-columns:1fr}
  .flow__rail{grid-template-columns:1fr;gap:32px}
  .hero__badge{left:16px;top:16px;padding:14px 18px}
  .hero__badge-num{font-size:32px}
  .hero__quals{right:0;bottom:-30px;left:0;max-width:none;padding:20px}
  .hero__inner{padding-bottom:140px}
  .info__list dl{grid-template-columns:100px 1fr}
  .cta-band__contact{padding:32px 24px}
  .cta-band__tel strong{font-size:36px}
}
