
  :root{
    --green:#9dc93c;
    --green-deep:#7fb026;
    --green-dark:#4a6b1f;
    --green-text:#5d7a2a;
    --green-soft:#eaf3d6;
    --green-softer:#f4f9e6;
    --yellow:#fce96a;
    --yellow-soft:#fff4a6;
    --pink:#f48fa1;
    --pink-soft:#fde4e8;
    --pink-softer:#fdf1f3;
    --ink:#2f3a23;
    --ink-soft:#56624b;
    --bg:#fdfdf9;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html,body{
    background:var(--bg);
    color:var(--ink);
    font-family:"Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;
    font-feature-settings:"palt";
    -webkit-font-smoothing:antialiased;
    line-height:1.7;
  }
  img{display:block;max-width:100%}
  a{color:inherit;text-decoration:none}

  .page{max-width:1240px;margin:0 auto;position:relative;overflow:hidden}

  /* ---------- decorative blobs ---------- */
  .blob{position:absolute;pointer-events:none;z-index:0}
  .dots{position:absolute;pointer-events:none;z-index:0}

  /* ---------- header ---------- */
  header.nav{
    position:relative;z-index:5;
    display:flex;align-items:center;justify-content:space-between;
    padding:24px 56px 18px;
  }
  .brand{display:flex;align-items:center;gap:14px}
  .brand-logo{width:54px;height:54px;flex-shrink:0}
  .brand-text{line-height:1.1}
  .brand-jp{
    font-weight:700;font-size:22px;letter-spacing:.04em;color:#3a4a23;
    display:flex;align-items:baseline;gap:6px;
  }
  .brand-jp .corp{font-size:14px;font-weight:500;color:#56624b;letter-spacing:.06em}
  .brand-en{font-size:11px;letter-spacing:.18em;color:#7a8a5e;margin-top:2px;font-family:"Inter",sans-serif;font-weight:500}

  nav.menu{display:flex;align-items:center;gap:40px}
  nav.menu a{
    font-size:14px;font-weight:500;color:#3a4a23;letter-spacing:.06em;
    transition:color .2s;
  }
  nav.menu a:hover{color:var(--green-deep)}
  .cta-btn{
    display:inline-flex;align-items:center;gap:10px;
    background:var(--green);color:#fff;
    padding:14px 28px 14px 22px;border-radius:999px;
    font-weight:700;font-size:14px;letter-spacing:.04em;
    box-shadow:0 6px 18px rgba(157,201,60,.35);
    transition:transform .15s, box-shadow .2s;
  }
  .cta-btn:hover{transform:translateY(-1px);box-shadow:0 8px 22px rgba(157,201,60,.45)}
  .cta-btn .ic{
    width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;
  }

  /* ---------- hero ---------- */
  .hero{
    position:relative;
    display:grid;grid-template-columns:1.05fr 1fr;
    gap:40px;
    padding:30px 56px 80px;
    align-items:center;
  }
  .hero-img-wrap{
    position:relative;
    aspect-ratio: 1/1.05;
    max-width:560px;
    width:100%;
  }
  /* organic blob clip for hero image */
  .blob-mask{
    width:100%;height:100%;
    background-size:cover;background-position:center;
    -webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 600 620'><path d='M300 18 C420 8 540 70 575 180 C610 290 600 410 530 500 C470 575 360 610 250 605 C140 600 50 540 22 430 C-8 310 20 180 95 100 C160 32 230 22 300 18 Z' fill='black'/></svg>");
    mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 600 620'><path d='M300 18 C420 8 540 70 575 180 C610 290 600 410 530 500 C470 575 360 610 250 605 C140 600 50 540 22 430 C-8 310 20 180 95 100 C160 32 230 22 300 18 Z' fill='black'/></svg>");
    -webkit-mask-size:contain;mask-size:contain;
    -webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;
    -webkit-mask-position:center;mask-position:center;
  }
  .hero-img{
    background-image:url("assets/hero.png");
    background-size:cover;background-position:center;
  }
  .hero-img::after{
    content:"スタッフ写真";
    position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
    font-family:"Inter",monospace;font-size:11px;color:#fff;
    background:rgba(0,0,0,.35);padding:4px 10px;border-radius:4px;
    letter-spacing:.06em;
    display:none;
  }
  .hero-script{
    position:absolute;
    right:-10px;bottom:30px;
    font-family:"Caveat",cursive;
    font-size:34px;color:#7fb026;
    line-height:1.2;
    transform:rotate(-3deg);
    text-shadow:0 1px 0 rgba(255,255,255,.6);
  }
  .hero-script span{display:block}
  .hero-blob-y{
    position:absolute;left:-30px;bottom:30px;
    width:90px;height:90px;
    background:var(--yellow-soft);
    border-radius:50%;
    opacity:.85;z-index:-1;
  }
  .hero-blob-g{
    position:absolute;left:-20px;top:50px;
    width:80px;height:55px;
    background:var(--green);
    opacity:.85;
    z-index:-1;
  }
  .hero-blob-g2{
    position:absolute;right:-20px;top:0;
    width:55px;height:55px;
    background:var(--green-soft);
    border-radius:50%;
    z-index:-1;
  }
  .dots-hero{
    position:absolute;left:-10px;top:50px;width:90px;height:50px;z-index:-1;
  }

  .hero-text{padding-left:20px;position:relative}
  .section-label{
    display:flex;align-items:baseline;gap:18px;
    margin-bottom:22px;
  }
  .section-label .en{
    font-family:"Inter",sans-serif;
    font-weight:600;letter-spacing:.22em;
    color:var(--green-text);font-size:15px;
  }
  .section-label .jp{
    font-weight:700;color:var(--ink);font-size:14px;letter-spacing:.1em;
  }

  .hero h1{
    font-size:38px;line-height:1.55;font-weight:700;color:#2a3a18;
    letter-spacing:.02em;margin-bottom:30px;
  }
  .hero h1 .hl{
    background:linear-gradient(transparent 65%, var(--yellow) 65%, var(--yellow) 92%, transparent 92%);
    padding:0 4px;
  }

  .hero p{
    color:#3a4730;font-size:15px;line-height:2.05;margin-bottom:14px;
  }
  .hero p:last-of-type{margin-bottom:0}

  .leaf-deco{
    position:absolute;right:-10px;top:170px;
    width:90px;opacity:.55;
  }

  /* ---------- service ---------- */
  .service{
    position:relative;
    padding:40px 56px 90px;
    text-align:center;
  }
  .section-label.center{justify-content:center}
  .section-label.center .en{font-size:18px;letter-spacing:.28em}
  .section-label.center .jp{font-size:28px;letter-spacing:.08em}
  .service-sub{
    color:var(--ink-soft);font-size:14px;margin-top:6px;margin-bottom:60px;
    letter-spacing:.04em;
  }
  .service-grid{
    display:grid;grid-template-columns:repeat(4,1fr);
    gap:24px;max-width:1080px;margin:0 auto;
  }
  .svc{
    display:flex;flex-direction:column;align-items:center;text-align:center;
  }
  .svc-circle{
    width:140px;height:140px;border-radius:50%;
    background:var(--green-softer);
    display:flex;align-items:center;justify-content:center;
    margin-bottom:22px;
  }
  .svc-circle svg{width:74px;height:74px;color:var(--green-deep)}
  .svc h3{
    font-size:18px;font-weight:700;color:#2a3a18;margin-bottom:10px;
    letter-spacing:.04em;white-space:nowrap;
  }
  .svc p{
    font-size:13px;line-height:1.85;color:var(--ink-soft);
  }

  .blob-service-r{
    position:absolute;right:-20px;top:50px;
    width:160px;height:140px;background:var(--green-soft);opacity:.7;
    border-radius:55% 45% 50% 50% / 60% 40% 60% 40%;z-index:0;
  }
  .blob-service-l{
    position:absolute;left:-30px;bottom:20px;
    width:120px;height:90px;background:var(--green-soft);opacity:.6;
    border-radius:60% 40% 55% 45% / 50% 60% 40% 50%;z-index:0;
  }

  /* ---------- vision ---------- */
  .vision{
    position:relative;
    display:grid;grid-template-columns:1fr 1fr;gap:50px;
    padding:30px 56px 80px;align-items:center;
  }
  .vision-text{position:relative}
  .vision h2{
    font-size:32px;font-weight:700;line-height:1.65;color:#2a3a18;
    margin-bottom:32px;letter-spacing:.02em;
  }
  .vision h2 .hl{
    background:linear-gradient(transparent 65%, var(--yellow) 65%, var(--yellow) 92%, transparent 92%);
    padding:0 3px;
  }
  .vision p{
    color:#3a4730;font-size:14.5px;line-height:2.1;margin-bottom:14px;
  }
  .vision-img-wrap{
    position:relative;
    aspect-ratio:1.05/1;
    max-width:560px;width:100%;
    justify-self:end;
  }
  .vision-img{
    width:100%;height:100%;
    background-image:url("assets/pruning.png");
    background-size:cover;background-position:center;
    border-radius:18px;
  }
  .dots-vision{position:absolute;right:-10px;top:-20px;width:80px;height:60px;z-index:-1}

  /* ---------- recruit ---------- */
  .recruit{
    position:relative;
    background:var(--pink-softer);
    padding:60px 56px 70px;
    margin-top:30px;
  }
  .recruit-top{
    display:grid;grid-template-columns:auto 1fr auto;
    gap:40px;align-items:center;margin-bottom:50px;
  }
  .recruit-label .en{
    font-family:"Inter",sans-serif;
    font-weight:600;letter-spacing:.28em;color:#e87c91;font-size:15px;
    display:block;margin-bottom:8px;
  }
  .recruit-label .jp{
    font-size:30px;font-weight:700;color:#2a3a18;letter-spacing:.06em;
    display:flex;align-items:center;gap:10px;
  }
  .recruit-label .leaf{font-size:18px}
  .recruit-lead{
    font-size:16px;line-height:2;color:#3a4730;font-weight:500;
  }

  .badge-row{
    display:grid;grid-template-columns:repeat(5,1fr);
    gap:8px;max-width:560px;
    align-items:start;
  }
  .badge{
    display:flex;flex-direction:column;align-items:center;text-align:center;
    gap:10px;min-width:0;
  }
  .badge-circle{
    width:80px;height:80px;border-radius:50%;
    background:#fff;
    display:flex;align-items:center;justify-content:center;
  }
  .badge-circle svg{width:42px;height:42px;color:var(--pink)}
  .badge-text{
    font-size:11.5px;font-weight:700;color:#2a3a18;line-height:1.5;letter-spacing:.02em;
    white-space:nowrap;
  }

  .recruit-bottom{
    display:grid;grid-template-columns:560px 1fr 220px;
    gap:24px;align-items:center;
  }
  .recruit-img-wrap{
    position:relative;width:100%;max-width:280px;aspect-ratio:1.05/1;
    justify-self:center;
  }
  .recruit-img{
    width:100%;height:100%;
    background-image:url("assets/team.png");
    background-size:cover;background-position:center;
    position:relative;
    border-radius:14px;
  }
  .recruit-blob-pink{
    position:absolute;right:-10px;bottom:10px;
    width:80px;height:60px;background:#f9b5c0;opacity:.55;
    border-radius:55% 45% 60% 40% / 50% 55% 45% 50%;z-index:1;
  }
  .recruit-cta-block{text-align:center}
  .recruit-cta-block p{
    font-size:16px;font-weight:700;color:#2a3a18;line-height:1.85;
    margin-bottom:20px;letter-spacing:.04em;
  }
  .cta-btn.pink{
    background:var(--pink);box-shadow:0 6px 18px rgba(244,143,161,.35);
  }
  .cta-btn.pink:hover{box-shadow:0 8px 22px rgba(244,143,161,.45)}

  /* ---------- company ---------- */
  .company{
    position:relative;
    padding:80px 56px 60px;
    display:grid;grid-template-columns:340px 1fr 360px;gap:40px;
    align-items:start;
  }
  .company-label .en{
    font-family:"Inter",sans-serif;
    font-weight:600;letter-spacing:.28em;color:var(--pink);font-size:14px;
    display:block;margin-bottom:14px;text-align:center;
  }
  .company-label .jp{
    font-size:34px;font-weight:700;color:#2a3a18;letter-spacing:.08em;
    text-align:center;margin-bottom:24px;
  }
  .company-img-wrap{
    width:100%;aspect-ratio:1/.85;
  }
  .company-img{
    width:100%;height:100%;
    background-image:url("assets/vision.png"),url("assets/grass.png");
    background-image:url("assets/icon-people.png");
    background-image:url("assets/grass.png");
    background-image:url("assets/recruit.png");
  }
  .company-img{
    background-image:url("assets/vision.png");
    background-image:url("assets/grass.png");
    background-image:url("assets/recruit.png");
    background-image:url("assets/vision.png");
  }
  /* (override above placeholder, real definition below) */
  .company-img{
    background-image:url("assets/vision.png");
  }
  .company-img.real{
    background-image:url("assets/vision.png");
  }
  .company-img{
    background-image:url("assets/vision.png");
  }
  .company-img.house{
    background-image:url("assets/vision.png");
  }
  .company-img-wrap .img{
    width:100%;height:100%;
    background-image:url("assets/vision.png");
    background-size:cover;background-position:center;
    -webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 600 520'><path d='M120 30 C260 10 410 40 500 120 C580 190 590 320 510 400 C440 470 320 500 220 480 C110 460 30 360 25 250 C20 150 60 60 120 30 Z' fill='black'/></svg>");
    mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 600 520'><path d='M120 30 C260 10 410 40 500 120 C580 190 590 320 510 400 C440 470 320 500 220 480 C110 460 30 360 25 250 C20 150 60 60 120 30 Z' fill='black'/></svg>");
    -webkit-mask-size:contain;mask-size:contain;
    -webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;
    -webkit-mask-position:center;mask-position:center;
  }
  .company-img-wrap .img.house{background-image:url("assets/vision.png")}

  .company-table{
    width:100%;border-collapse:collapse;font-size:13.5px;
  }
  .company-table th, .company-table td{
    text-align:left;padding:14px 16px;vertical-align:top;
    border-bottom:1px solid #e7ecd6;
  }
  .company-table th{
    width:90px;color:var(--green-text);font-weight:600;
    background:var(--green-softer);
    letter-spacing:.06em;
  }
  .company-table td{color:#3a4730;font-weight:500;line-height:1.85}

  .company-contact{
    background:var(--green-softer);border-radius:18px;
    padding:32px 30px 34px;text-align:center;
    margin-top:40px;
  }
  .company-contact h3{
    font-size:17px;font-weight:700;color:#2a3a18;letter-spacing:.04em;
    margin-bottom:14px;
  }
  .company-contact p{
    font-size:13px;color:#3a4730;line-height:1.85;margin-bottom:22px;
  }

  /* ---------- footer ---------- */
  footer{
    position:relative;
    padding:30px 56px 40px;text-align:center;
    color:var(--ink-soft);font-size:12px;letter-spacing:.06em;
    font-family:"Inter",sans-serif;
  }
  .footer-blob-l{position:absolute;left:0;bottom:0;width:160px;height:120px;background:var(--green-soft);opacity:.6;border-radius:60% 40% 55% 45% / 50% 55% 45% 50%;z-index:-1}
  .footer-blob-r{position:absolute;right:20px;top:-20px;width:60px;height:50px;background:var(--green-soft);opacity:.6;border-radius:55% 45% 60% 40% / 50% 60% 40% 50%;z-index:-1}

  /* dot pattern util */
  .dotpat{
    background-image:radial-gradient(circle, var(--green) 1.2px, transparent 1.4px);
    background-size:8px 8px;
  }
  .dotpat-yellow{
    background-image:radial-gradient(circle, var(--yellow) 1.2px, transparent 1.4px);
    background-size:8px 8px;
  }

  /* ---------- icon helpers (SVG icons inline) ---------- */
  .ic-mail{display:inline-block}

  /* company logo art */
  .company-logo-art{
    margin-top:10px;text-align:center;
  }
  .company-logo-art svg{width:80%;max-width:240px;margin:0 auto;display:block}
  .company-logo-text{
    margin-top:6px;letter-spacing:.4em;
    font-family:"Noto Serif JP","Yu Mincho",serif;
    color:#3a4a23;
  }
  .company-logo-text .corp{display:block;font-size:14px;letter-spacing:.5em;margin-bottom:6px}
  .company-logo-text .name{font-size:30px;font-weight:600;letter-spacing:.4em}

  /* recruit tulip deco */
  .tulip-deco{
    position:absolute;right:30px;top:30px;
    width:130px;height:160px;pointer-events:none;
  }


/* ---------- multi-page additions ---------- */
header.nav.fixed{
  position:fixed;top:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:1240px;
  background:rgba(253,253,249,.92);backdrop-filter:blur(8px);
  z-index:100;padding:18px 56px 14px;
  border-bottom:1px solid rgba(157,201,60,.15);
}
body.has-fixed-nav{padding-top:96px}

.page-hero{
  position:relative;padding:60px 56px 60px;text-align:center;
}
.page-hero .crumb{font-family:"Inter",sans-serif;font-size:11px;letter-spacing:.22em;color:#7a8a5e;margin-bottom:16px}
.page-hero .crumb a{color:#7a8a5e;transition:color .2s}
.page-hero .crumb a:hover{color:var(--green-deep)}
.page-hero .crumb span{margin:0 10px;color:#cfd9b5}
.page-hero h1.page-title{
  font-size:42px;font-weight:700;color:#2a3a18;letter-spacing:.06em;
  margin-bottom:10px;line-height:1.4;
}
.page-hero .en-title{
  font-family:"Inter",sans-serif;font-weight:600;letter-spacing:.3em;
  color:var(--green-text);font-size:14px;margin-bottom:6px;
}
.page-hero .lead{
  color:var(--ink-soft);font-size:15px;line-height:2;margin-top:16px;
}
.page-hero .deco-blob{
  position:absolute;background:var(--green-soft);opacity:.6;pointer-events:none;
  z-index:-1;
}
.page-hero .deco-blob.l{
  left:30px;top:40px;width:90px;height:60px;
  border-radius:60% 40% 55% 45% / 50% 60% 40% 50%;
}
.page-hero .deco-blob.r{
  right:60px;bottom:0;width:120px;height:80px;
  background:var(--yellow-soft);opacity:.7;
  border-radius:55% 45% 60% 40% / 50% 55% 45% 50%;
}
.page-hero .deco-blob.dot{
  right:140px;top:50px;width:40px;height:40px;
  background:var(--green);border-radius:50%;
}

.section-block{padding:50px 56px;position:relative}
.section-block.alt{background:var(--green-softer)}
.section-block h2.bk-title{
  font-size:26px;font-weight:700;color:#2a3a18;letter-spacing:.04em;
  margin-bottom:20px;display:flex;align-items:baseline;gap:14px;
}
.section-block h2.bk-title .en{
  font-family:"Inter",sans-serif;font-size:13px;letter-spacing:.2em;
  color:var(--green-text);font-weight:600;
}
.section-block p{color:#3a4730;font-size:14.5px;line-height:2;margin-bottom:14px}

.detail-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:30px}
.detail-card{
  background:#fff;border:1px solid var(--green-soft);
  border-radius:18px;padding:26px 28px;
}
.detail-card h3{
  font-size:18px;font-weight:700;color:#2a3a18;margin-bottom:10px;
  display:flex;align-items:center;gap:10px;
}
.detail-card .dot{
  width:8px;height:8px;border-radius:50%;background:var(--green);
}
.detail-card p{font-size:13.5px;color:var(--ink-soft);line-height:1.9;margin:0}

.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:30px}
.gallery-item{
  aspect-ratio:1.2/1;border-radius:14px;
  background-size:cover;background-position:center;background-color:var(--green-soft);
  position:relative;overflow:hidden;
}
.gallery-item .cap{
  position:absolute;left:0;right:0;bottom:0;
  background:linear-gradient(transparent, rgba(0,0,0,.55));
  color:#fff;padding:14px 16px 12px;font-size:12px;font-weight:600;letter-spacing:.04em;
}

.form-wrap{max-width:680px;margin:0 auto;padding:20px 0 40px}
.form-row{margin-bottom:22px}
.form-row label{
  display:flex;align-items:center;gap:10px;
  font-size:13.5px;font-weight:700;color:#2a3a18;letter-spacing:.04em;margin-bottom:8px;
}
.form-row label .req{
  background:var(--pink);color:#fff;font-size:10px;
  padding:2px 8px;border-radius:4px;letter-spacing:.04em;font-weight:700;
}
.form-row label .opt{
  background:var(--green-soft);color:var(--green-text);font-size:10px;
  padding:2px 8px;border-radius:4px;letter-spacing:.04em;font-weight:700;
}
.form-row input,.form-row textarea{
  width:100%;border:1px solid #d8e2bc;background:#fff;
  border-radius:10px;padding:14px 16px;font-size:14px;
  font-family:inherit;color:#2a3a18;
  transition:border-color .2s, box-shadow .2s;
}
.form-row textarea{min-height:140px;resize:vertical;line-height:1.7}
.form-row input:focus,.form-row textarea:focus{
  outline:none;border-color:var(--green);
  box-shadow:0 0 0 3px rgba(157,201,60,.18);
}
.form-submit{text-align:center;margin-top:30px}
.form-submit .cta-btn{padding:16px 40px;font-size:15px}

.faq-item{
  background:#fff;border:1px solid var(--green-soft);
  border-radius:12px;padding:18px 24px;margin-bottom:12px;
}
.faq-q{font-size:15px;font-weight:700;color:#2a3a18;margin-bottom:8px;display:flex;gap:10px}
.faq-q::before{content:"Q.";color:var(--green-deep);font-family:"Inter",sans-serif}
.faq-a{font-size:13.5px;color:var(--ink-soft);line-height:1.9;display:flex;gap:10px;padding-left:0}
.faq-a::before{content:"A.";color:var(--pink);font-family:"Inter",sans-serif;font-weight:700}

/* footer-full */
footer.full{
  position:relative;padding:60px 56px 30px;
  background:#f4f9e6;margin-top:60px;
}
footer.full .ft-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px;
}
footer.full .ft-brand .name{
  font-size:18px;font-weight:700;color:#2a3a18;margin-bottom:10px;letter-spacing:.04em;
}
footer.full .ft-brand p{font-size:12px;color:var(--ink-soft);line-height:1.85}
footer.full .ft-col h4{
  font-size:12px;font-weight:700;color:var(--green-text);
  letter-spacing:.2em;margin-bottom:14px;font-family:"Inter",sans-serif;
}
footer.full .ft-col a{
  display:block;font-size:13px;color:#3a4730;margin-bottom:8px;
  transition:color .2s;
}
footer.full .ft-col a:hover{color:var(--green-deep)}
footer.full .ft-sns{display:flex;gap:10px;margin-top:8px}
footer.full .ft-sns a{
  width:34px;height:34px;border-radius:50%;background:#fff;
  display:flex;align-items:center;justify-content:center;
  margin:0;
}
footer.full .ft-sns svg{width:16px;height:16px;color:var(--green-deep)}
footer.full .ft-bottom{
  border-top:1px solid #d8e2bc;padding-top:20px;
  display:flex;justify-content:space-between;align-items:center;
  font-size:11px;color:var(--ink-soft);letter-spacing:.06em;
  font-family:"Inter",sans-serif;
}
footer.full .ft-bottom .legal{display:flex;gap:20px}

/* section detail link */
.detail-link{
  display:inline-flex;align-items:center;gap:8px;
  margin-top:16px;font-size:13px;font-weight:700;color:var(--green-deep);
  letter-spacing:.06em;
}
.detail-link::after{content:"→";font-size:14px;transition:transform .2s}
.detail-link:hover::after{transform:translateX(4px)}
.center-cta{text-align:center;margin-top:40px}


/* =============================================
   RESPONSIVE — mobile / tablet
   ============================================= */
@media (max-width: 900px){
  .page{max-width:100%;overflow-x:hidden}

  /* HEADER */
  header.nav{padding:14px 18px;flex-wrap:wrap;gap:8px}
  header.nav.fixed{position:relative}
  body.has-fixed-nav{padding-top:0}
  .brand-logo{width:42px;height:42px}
  .brand-jp{font-size:17px}
  .brand-jp .corp{font-size:11px}
  .brand-en{font-size:9px}
  nav.menu{
    order:3;width:100%;
    overflow-x:auto;-webkit-overflow-scrolling:touch;
    gap:18px;padding:6px 0 4px;
    scrollbar-width:none;
  }
  nav.menu::-webkit-scrollbar{display:none}
  nav.menu a{font-size:12px;white-space:nowrap;flex-shrink:0}

  /* HERO */
  .hero{
    grid-template-columns:1fr;
    padding:20px 20px 50px;gap:30px;
  }
  .hero-img-wrap{max-width:100%;margin:0 auto}
  .hero-text{padding-left:0}
  .hero h1{font-size:24px;line-height:1.6}
  .hero p{font-size:13.5px;line-height:1.95}
  .hero p br{display:none}
  .hero-script{font-size:22px;right:10px;bottom:10px}
  .leaf-deco{display:none}
  .section-label .en{font-size:13px}
  .section-label .jp{font-size:13px}

  /* SERVICE */
  .service{padding:30px 20px 60px}
  .section-label.center .en{font-size:14px;letter-spacing:.2em}
  .section-label.center .jp{font-size:22px}
  .service-sub{font-size:13px;margin-bottom:36px}
  .service-grid{grid-template-columns:repeat(2,1fr);gap:30px 14px}
  .svc-circle{width:110px;height:110px}
  .svc-circle svg{width:58px;height:58px}
  .svc h3{font-size:15px;white-space:normal}
  .svc p{font-size:12px}
  .svc p br{display:none}

  /* VISION */
  .vision{
    grid-template-columns:1fr;
    padding:20px 20px 60px;gap:24px;
  }
  .vision h2{font-size:21px;line-height:1.65;margin-bottom:20px}
  .vision p{font-size:13.5px;line-height:1.95}
  .vision p br{display:none}
  .vision-img-wrap{max-width:100%;justify-self:center;aspect-ratio:1.2/1}

  /* RECRUIT */
  .recruit{padding:40px 20px 50px}
  .recruit-top{
    grid-template-columns:1fr;gap:18px;margin-bottom:30px;text-align:center;
  }
  .recruit-label .jp{font-size:24px;justify-content:center}
  .recruit-lead{font-size:14px}
  .recruit-bottom{
    grid-template-columns:1fr !important;gap:30px;
  }
  .badge-row{
    grid-template-columns:repeat(5,1fr);
    gap:6px;max-width:100%;
  }
  .badge-circle{width:54px;height:54px}
  .badge-circle svg{width:28px;height:28px}
  .badge-text{font-size:9.5px;white-space:normal;line-height:1.4}
  .recruit-img-wrap{max-width:240px;width:100%}
  .recruit-cta-block p{font-size:14px}

  /* COMPANY */
  .company{
    grid-template-columns:1fr;
    padding:40px 20px 40px;gap:30px;
  }
  .company-img-wrap{max-width:300px;margin:0 auto}
  .company-table{font-size:12.5px}
  .company-table th{width:80px;padding:10px 10px}
  .company-table td{padding:10px 10px}
  .company-contact{padding:24px 20px;margin-top:20px}

  /* PAGE HERO (subpages) */
  .page-hero{padding:60px 20px 40px !important}
  .page-hero .en-title{font-size:13px !important}
  .page-hero .page-title{font-size:28px !important}
  .page-hero .lead{font-size:13.5px !important}
  .crumb{font-size:11px !important}

  /* SECTION BLOCK (subpages) */
  .section-block{padding:40px 20px !important}
  .bk-title{font-size:20px !important;flex-direction:column;align-items:flex-start;gap:6px}
  .bk-title .en{font-size:12px !important}
  .detail-cards{grid-template-columns:1fr !important;gap:14px !important}

  /* FORM */
  .form-wrap{padding:0 !important;max-width:100% !important}
  .form-row{margin-bottom:18px}
  .form-row label{font-size:13px}
  .form-row input,.form-row textarea{font-size:14px;padding:12px 14px}

  /* FOOTER */
  footer.full{padding:40px 20px 24px}
  .ft-grid{
    grid-template-columns:1fr 1fr !important;gap:24px !important;
  }
  .ft-brand{grid-column:span 2}
  .ft-bottom{
    flex-direction:column;gap:10px;text-align:center;font-size:11px;
  }
  .ft-bottom .legal{gap:14px}

  /* CTA buttons */
  .cta-btn{padding:12px 22px;font-size:13px}

  /* misc decorations: tone down on mobile */
  .blob-service-r,.blob-service-l,.hero-blob-y,.hero-blob-g,
  .recruit-blob-pink,.dots-hero,.dots-vision,
  .footer-blob-l,.footer-blob-r{transform:scale(.6);opacity:.5}
}

/* extra-small phones */
@media (max-width: 380px){
  .badge-text{font-size:8.5px}
  .badge-circle{width:46px;height:46px}
  .badge-circle svg{width:24px;height:24px}
  .hero h1{font-size:21px}
  .vision h2{font-size:19px}
}
