:root{
  --font-display: 'Zen Old Mincho', serif;
  --font-body: 'Zen Kaku Gothic New', sans-serif;
  --mono: 'JetBrains Mono', monospace;

  --washi: #f5f1e6;
  --washi-2: #ece5d4;
  --paper: #fbf9f3;
  --igusa: #6b7a4f;
  --igusa-deep: #54623d;
  --igusa-soft: #8a986e;
  --sumi: #2c3127;
  --sumi-soft: #5b6053;
  --line: #ddd5c1;
  --gold: #a8884e;

  --maxw: 1200px;
  --pad: clamp(20px, 5vw, 72px);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--washi);
  color:var(--sumi);
  font-family:var(--font-body);
  font-weight:400;
  line-height:1.85;
  letter-spacing:.02em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;line-height:1.4;margin:0;letter-spacing:.04em;}
p{margin:0;text-wrap:pretty;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad);}

/* ---------- woven heri border motif ---------- */
.weave{
  height:14px;
  background-image:
    repeating-linear-gradient(45deg, var(--igusa) 0 6px, var(--igusa-deep) 6px 12px),
    repeating-linear-gradient(45deg, transparent 0 11px, rgba(168,136,78,.55) 11px 12px);
}
.weave--thin{height:6px;}

/* ---------- placeholders ---------- */
.ph{
  position:relative;
  background:repeating-linear-gradient(135deg, #e8e1d0 0 16px, #ded6c2 16px 32px);
  display:flex;align-items:center;justify-content:center;
  color:#9a9279;overflow:hidden;
}
.ph::after{
  content:attr(data-label);
  font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;
  color:#8c856d;background:rgba(251,249,243,.78);
  padding:.4em .7em;border:1px solid #cfc6ae;border-radius:2px;
  max-width:80%;text-align:center;line-height:1.4;
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--font-body);font-weight:700;font-size:.95rem;letter-spacing:.06em;
  padding:.95em 1.7em;border-radius:3px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.btn--solid{background:var(--igusa);color:#fff;box-shadow:0 6px 18px -8px rgba(84,98,61,.7);}
.btn--solid:hover{background:var(--igusa-deep);transform:translateY(-2px);box-shadow:0 12px 26px -10px rgba(84,98,61,.8);}
.btn--ghost{background:transparent;color:var(--sumi);border-color:var(--sumi);}
.btn--ghost:hover{background:var(--sumi);color:var(--washi);transform:translateY(-2px);}
.btn--small{padding:.7em 1.2em;font-size:.85rem;}

.kicker{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--mono);font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--igusa-deep);font-weight:500;margin-bottom:1.3em;
}
.kicker::before{content:"";width:26px;height:1px;background:var(--igusa);}
.jp-label{font-family:var(--font-body);letter-spacing:.1em;}

.more{display:inline-flex;align-items:center;gap:.5em;font-weight:700;color:var(--igusa-deep);font-size:.95rem;}
.more::after{content:"→";transition:transform .2s ease;}
.more:hover::after{transform:translateX(5px);}

/* ---------- header ---------- */
.topbar{background:var(--sumi);color:var(--washi);font-size:.78rem;letter-spacing:.06em;}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;padding-block:.55rem;white-space:nowrap;}
.topbar .left{overflow:hidden;text-overflow:ellipsis;min-width:0;}
.topbar a{color:var(--washi);}
.topbar .sep{opacity:.45;margin-inline:.7em;}

header{position:sticky;top:0;z-index:50;background:rgba(245,241,230,.86);backdrop-filter:blur(10px);border-bottom:1px solid transparent;transition:border-color .3s ease, box-shadow .3s ease, background .3s ease;}
header.scrolled{border-color:var(--line);box-shadow:0 6px 24px -18px rgba(44,49,39,.6);}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding-block:1rem;}
.brand{display:flex;align-items:center;gap:.8rem;}
.brand .mark{
  width:42px;height:42px;flex:none;border-radius:50%;
  display:grid;place-items:center;background:var(--igusa);color:#fff;
  font-family:var(--font-display);font-weight:700;font-size:1.25rem;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.25);
}
.brand .name{font-family:var(--font-display);font-weight:700;font-size:1.3rem;letter-spacing:.1em;white-space:nowrap;}
.brand .name small{display:block;font-family:var(--mono);font-size:.6rem;letter-spacing:.28em;color:var(--igusa-deep);font-weight:400;margin-top:.25em;}
.nav-links{display:flex;align-items:center;gap:2rem;font-size:.95rem;font-weight:500;}
.nav-links a{position:relative;padding-block:.3em;transition:color .2s ease;}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--igusa);transition:width .25s ease;}
.nav-links a:hover{color:var(--igusa-deep);}
.nav-links a:hover::after{width:100%;}
.nav-links a.active{color:var(--igusa-deep);}
.nav-links a.active::after{width:100%;}
.nav-cta{display:flex;align-items:center;gap:1rem;}
.nav-tel{font-family:var(--font-display);font-weight:700;font-size:1.05rem;letter-spacing:.04em;color:var(--sumi);white-space:nowrap;}
.nav-tel small{display:block;font-family:var(--mono);font-size:.58rem;letter-spacing:.12em;color:var(--sumi-soft);font-weight:400;}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;}
.burger span{width:24px;height:2px;background:var(--sumi);transition:.25s;}

/* ---------- hero (home) ---------- */
.hero{position:relative;overflow:hidden;}
.hero-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(28px,5vw,64px);align-items:center;padding-top:clamp(48px,7vw,96px);padding-bottom:clamp(40px,6vw,80px);}
.hero-copy h1{font-size:clamp(2.4rem,5.2vw,4.1rem);line-height:1.32;font-weight:500;letter-spacing:.06em;}
.hero-copy h1 .accent{color:var(--igusa-deep);}
.hero-lead{margin-top:1.6rem;font-size:clamp(1rem,1.4vw,1.13rem);color:var(--sumi-soft);max-width:30em;}
.hero-actions{display:flex;gap:1rem;margin-top:2.4rem;flex-wrap:wrap;}
.hero-meta{display:flex;gap:2.2rem;margin-top:2.8rem;flex-wrap:wrap;}
.hero-meta div{display:flex;flex-direction:column;}
.hero-meta .num{font-family:var(--font-display);font-size:1.7rem;font-weight:700;color:var(--igusa-deep);line-height:1;}
.hero-meta .cap{font-size:.78rem;color:var(--sumi-soft);margin-top:.5em;letter-spacing:.06em;}
.hero-media{position:relative;}
.hero-media .ph{aspect-ratio:4/5;border-radius:4px;box-shadow:0 30px 60px -30px rgba(44,49,39,.55);}
.hero-media .weave{position:absolute;left:-10px;top:-10px;bottom:-10px;width:14px;height:auto;border-radius:3px;}
.hero-stamp{
  position:absolute;right:-14px;bottom:28px;width:118px;height:118px;border-radius:50%;
  background:var(--paper);border:1px solid var(--line);
  display:grid;place-items:center;text-align:center;
  box-shadow:0 16px 34px -18px rgba(44,49,39,.5);transform:rotate(-6deg);
}
.hero-stamp span{font-family:var(--font-display);line-height:1.45;font-size:.82rem;font-weight:500;color:var(--sumi);}
.hero-stamp .yr{color:var(--igusa-deep);font-weight:700;font-size:1.05rem;display:block;}

/* ---------- page hero (sub pages) ---------- */
.page-hero{background:var(--washi-2);padding-top:clamp(40px,6vw,72px);padding-bottom:clamp(36px,5vw,60px);position:relative;overflow:hidden;}
.page-hero .breadcrumb{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;color:var(--sumi-soft);margin-bottom:1.3rem;display:flex;gap:.55em;align-items:center;flex-wrap:wrap;}
.page-hero .breadcrumb a{color:var(--igusa-deep);}
.page-hero .breadcrumb .arw{opacity:.5;}
.page-hero .en{display:block;font-family:var(--mono);font-size:.72rem;letter-spacing:.28em;color:var(--igusa);text-transform:uppercase;margin-bottom:1rem;}
.page-hero h1{font-size:clamp(2.1rem,4.4vw,3.2rem);font-weight:500;letter-spacing:.06em;}
.page-hero p{margin-top:1.2rem;color:var(--sumi-soft);max-width:40em;}

/* ---------- section frame ---------- */
section{position:relative;}
.band{padding-block:clamp(64px,9vw,120px);}
.band--sm{padding-block:clamp(48px,7vw,88px);}
.band--paper{background:var(--paper);}
.band--sumi{background:var(--sumi);color:var(--washi);}
.band--washi2{background:var(--washi-2);}
.sec-head{max-width:46em;margin-bottom:clamp(36px,5vw,60px);}
.sec-head h2{font-size:clamp(1.9rem,3.4vw,2.7rem);font-weight:500;letter-spacing:.05em;}
.sec-head p{margin-top:1.1rem;color:var(--sumi-soft);font-size:1.02rem;}
.sec-head.center{margin-inline:auto;text-align:center;}
.sec-head.center .kicker{justify-content:center;}
.band--sumi .sec-head p{color:rgba(245,241,230,.72);}
.band--sumi .kicker{color:var(--igusa-soft);}
.band--sumi .kicker::before{background:var(--igusa-soft);}

/* ---------- reasons ---------- */
.reasons{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,40px);}
.reason .ico{
  width:54px;height:54px;border-radius:50%;border:1.5px solid var(--igusa);
  display:grid;place-items:center;margin-bottom:1.2rem;color:var(--igusa-deep);
  font-family:var(--font-display);font-size:1.4rem;font-weight:700;
}
.reason h3{font-size:1.3rem;margin-bottom:.7rem;letter-spacing:.06em;}
.reason p{color:var(--sumi-soft);font-size:.98rem;}

/* ---------- services (cards) ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.5vw,32px);}
.svc{
  background:var(--paper);border:1px solid var(--line);border-radius:5px;overflow:hidden;
  display:flex;flex-direction:column;transition:transform .25s ease, box-shadow .25s ease;
}
.svc:hover{transform:translateY(-5px);box-shadow:0 26px 44px -28px rgba(44,49,39,.5);}
.svc .pic{aspect-ratio:4/3;}
.svc .pic .ph{width:100%;height:100%;}
.svc .body{padding:1.7rem 1.6rem 1.9rem;display:flex;flex-direction:column;flex:1;}
.svc .tag{font-family:var(--mono);font-size:.66rem;letter-spacing:.2em;color:var(--igusa);text-transform:uppercase;margin-bottom:.7rem;}
.svc h3{font-size:1.55rem;font-weight:700;letter-spacing:.08em;}
.svc h3 .yomi{display:block;font-family:var(--mono);font-size:.62rem;letter-spacing:.18em;color:var(--sumi-soft);font-weight:400;margin-top:.5em;}
.svc .desc{margin-top:1rem;color:var(--sumi-soft);font-size:.96rem;flex:1;}
.svc .cycle{margin-top:1.4rem;padding-top:1.1rem;border-top:1px dashed var(--line);display:flex;align-items:baseline;gap:.6em;}
.svc .cycle b{font-family:var(--font-display);font-size:1.5rem;color:var(--igusa-deep);font-weight:700;}
.svc .cycle span{font-size:.82rem;color:var(--sumi-soft);}

/* ---------- services (detail rows) ---------- */
.svc-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center;}
.svc-row + .svc-row{margin-top:clamp(52px,7vw,96px);}
.svc-row .media{position:relative;}
.svc-row .media .ph{aspect-ratio:4/3;border-radius:5px;}
.svc-row .media .weave{position:absolute;left:-9px;top:18px;bottom:18px;width:12px;height:auto;border-radius:3px;}
.svc-row--rev .media{order:2;}
.svc-row .num{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;color:var(--igusa);text-transform:uppercase;}
.svc-row h2{font-size:clamp(1.8rem,3.2vw,2.5rem);margin-top:.7rem;font-weight:500;}
.svc-row h2 .yomi{display:block;font-family:var(--mono);font-size:.68rem;letter-spacing:.16em;color:var(--sumi-soft);font-weight:400;margin-top:.6em;}
.svc-row p{margin-top:1.3rem;color:var(--sumi-soft);}
.svc-row .meta{margin-top:1.6rem;display:inline-flex;align-items:baseline;gap:.7em;padding:.8em 1.3em;background:var(--washi-2);border-radius:4px;}
.svc-row .meta b{font-family:var(--font-display);font-size:1.6rem;color:var(--igusa-deep);font-weight:700;}
.svc-row .meta span{font-size:.85rem;color:var(--sumi-soft);}

/* ---------- flow ---------- */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,2.5vw,32px);}
.flow .step{position:relative;}
.flow .step .num{width:48px;height:48px;border-radius:50%;background:var(--igusa);color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:1.15rem;margin-bottom:1.1rem;}
.flow .step h3{font-size:1.18rem;margin-bottom:.6rem;letter-spacing:.04em;}
.flow .step p{font-size:.92rem;color:var(--sumi-soft);}

/* ---------- voices ---------- */
.voices{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,2.5vw,36px);}
.voices--3{grid-template-columns:repeat(3,1fr);}
.voice{background:var(--paper);border:1px solid var(--line);border-top:3px solid var(--igusa);border-radius:5px;padding:2.2rem 2.2rem 2rem;position:relative;display:flex;flex-direction:column;box-shadow:0 8px 28px -18px rgba(44,49,39,.25);transition:transform .25s ease,box-shadow .25s ease;}
.voice:hover{transform:translateY(-4px);box-shadow:0 18px 40px -20px rgba(44,49,39,.35);}
.voice-stars{color:var(--igusa);font-size:1rem;letter-spacing:.15em;margin-bottom:.9rem;}
.voice .quote{font-family:var(--font-display);font-size:5rem;color:var(--igusa);opacity:.18;line-height:.8;position:absolute;top:1.4rem;right:1.8rem;pointer-events:none;user-select:none;}
.voice p{font-size:1.02rem;margin-top:0;color:var(--sumi);line-height:1.9;flex:1;}
.voice .who{display:flex;align-items:center;gap:.9rem;margin-top:1.8rem;padding-top:1.4rem;border-top:1px solid var(--line);}
.voice .ava{width:46px;height:46px;border-radius:50%;flex:none;background:var(--igusa);display:grid;place-items:center;font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:rgba(255,255,255,.9);}
.voice .who .nm{font-weight:700;font-size:.95rem;}
.voice .who .mt{font-size:.76rem;color:var(--sumi-soft);font-family:var(--mono);letter-spacing:.06em;margin-top:.25em;}
.voice-svc-tag{display:inline-block;font-family:var(--mono);font-size:.65rem;letter-spacing:.14em;color:var(--igusa-deep);background:rgba(107,122,79,.1);border:1px solid rgba(107,122,79,.25);border-radius:2px;padding:.25em .6em;margin-top:.5em;}

/* ---------- knowledge strip ---------- */
.know{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center;}
.know .ph{aspect-ratio:5/4;border-radius:5px;}
.know ul{list-style:none;padding:0;margin:1.4rem 0 0;display:flex;flex-direction:column;gap:1.1rem;}
.know li{display:flex;gap:1rem;align-items:flex-start;}
.know li .n{font-family:var(--mono);font-size:.8rem;color:var(--igusa);padding-top:.25em;flex:none;}
.know li b{font-family:var(--font-display);font-weight:700;}
.know li p{color:rgba(245,241,230,.72);font-size:.94rem;margin-top:.2em;}
.band--paper .know li p{color:var(--sumi-soft);}

/* ---------- greeting ---------- */
.greeting{display:grid;grid-template-columns:.85fr 1.4fr;gap:clamp(28px,5vw,60px);align-items:center;}
.greeting .media{position:relative;}
.greeting .media .ph{aspect-ratio:3/4;border-radius:5px;}
.greeting .media .weave{position:absolute;left:-9px;top:18px;bottom:18px;width:12px;height:auto;border-radius:3px;}
.greeting h2{font-size:clamp(1.7rem,3vw,2.3rem);font-weight:500;}
.greeting p{margin-top:1.3rem;color:var(--sumi-soft);}
.greeting p + p{margin-top:1rem;}
.greeting .sign{margin-top:1.8rem;font-family:var(--font-display);font-size:1rem;color:var(--sumi);display:flex;align-items:baseline;gap:.6em;}
.greeting .sign b{font-size:1.5rem;font-weight:700;}

/* ---------- company spec ---------- */
.company-grid{display:grid;grid-template-columns:1fr 1.25fr;gap:clamp(32px,5vw,64px);align-items:start;}
.company-media{position:relative;}
.company-media .ph{aspect-ratio:4/3;border-radius:5px;}
.company-media .weave{position:absolute;left:-9px;top:18px;bottom:18px;width:12px;height:auto;border-radius:3px;}
.company-media .cap{margin-top:1rem;font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;color:var(--sumi-soft);display:flex;gap:.6em;align-items:center;}
.company-media .cap::before{content:"";width:18px;height:1px;background:var(--igusa);}
.spec{width:100%;border-top:1px solid var(--line);margin:0;}
.spec .row{display:grid;grid-template-columns:148px 1fr;gap:1.2rem;padding:1.05rem 0;border-bottom:1px solid var(--line);align-items:baseline;}
.spec .row dt{margin:0;font-weight:700;font-size:.9rem;letter-spacing:.04em;color:var(--sumi);}
.spec .row dt small{display:block;font-family:var(--mono);font-size:.6rem;letter-spacing:.16em;color:var(--igusa-deep);font-weight:400;text-transform:uppercase;margin-top:.35em;}
.spec .row dd{margin:0;font-size:.98rem;color:var(--sumi-soft);}
.spec .row dd b{color:var(--sumi);font-weight:500;}

/* ---------- access ---------- */
.access{display:grid;grid-template-columns:2fr 1fr;gap:clamp(28px,4vw,48px);align-items:stretch;}
.access .map{border-radius:5px;min-height:360px;height:100%;}
.access .ai{display:flex;flex-direction:column;gap:1.4rem;}
.access .ai .item .lab{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;color:var(--igusa);text-transform:uppercase;margin-bottom:.4em;}
.access .ai .item .val{font-size:1rem;}
.access .ai .item .val .big{font-family:var(--font-display);font-size:1.4rem;font-weight:700;color:var(--sumi);}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(32px,5vw,64px);align-items:start;}
.contact-info h2{font-size:clamp(1.8rem,3.2vw,2.5rem);}
.contact-info .lead{margin-top:1.2rem;color:var(--sumi-soft);}
.info-list{margin-top:2.2rem;display:flex;flex-direction:column;gap:1.5rem;}
.info-item{display:flex;gap:1rem;align-items:flex-start;}
.info-item .lab{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;color:var(--igusa);text-transform:uppercase;width:84px;flex:none;padding-top:.5em;}
.info-item .val{font-size:1rem;}
.info-item .val .big{font-family:var(--font-display);font-size:1.55rem;font-weight:700;letter-spacing:.04em;color:var(--sumi);}

.form{background:var(--paper);border:1px solid var(--line);border-radius:6px;padding:clamp(24px,3vw,40px);box-shadow:0 24px 50px -34px rgba(44,49,39,.4);}
.field{margin-bottom:1.3rem;}
.field label{display:block;font-size:.86rem;font-weight:700;margin-bottom:.55rem;letter-spacing:.04em;}
.field label .req{color:var(--gold);font-size:.75rem;margin-left:.4em;font-family:var(--mono);}
.field input,.field select,.field textarea{
  width:100%;font-family:var(--font-body);font-size:.98rem;color:var(--sumi);
  background:var(--washi);border:1.5px solid var(--line);border-radius:3px;
  padding:.85em 1em;transition:border-color .2s ease, box-shadow .2s ease;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--igusa);box-shadow:0 0 0 3px rgba(107,122,79,.15);}
.field textarea{resize:vertical;min-height:110px;}
.field.two{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.field .err{color:#a4423a;font-size:.78rem;margin-top:.4em;display:none;}
.field.invalid input,.field.invalid select{border-color:#a4423a;}
.field.invalid .err{display:block;}
.form .btn{width:100%;justify-content:center;margin-top:.6rem;}
.form-note{font-size:.78rem;color:var(--sumi-soft);text-align:center;margin-top:1rem;}
.form-success{display:none;text-align:center;padding:2rem 1rem;}
.form-success.show{display:block;}
.form-success .chk{width:64px;height:64px;border-radius:50%;background:var(--igusa);color:#fff;display:grid;place-items:center;margin:0 auto 1.2rem;font-size:1.8rem;}
.form-success h3{font-size:1.5rem;margin-bottom:.6rem;}
.form-success p{color:var(--sumi-soft);}

/* ---------- cta band ---------- */
.cta-band{background:var(--sumi);color:var(--washi);text-align:center;}
.cta-band .kicker{justify-content:center;color:var(--igusa-soft);}
.cta-band .kicker::before{background:var(--igusa-soft);}
.cta-band h2{font-size:clamp(1.9rem,3.6vw,2.8rem);font-weight:500;}
.cta-band p{color:rgba(245,241,230,.72);margin-top:1.1rem;max-width:34em;margin-inline:auto;}
.cta-band .actions{display:flex;gap:1rem;justify-content:center;margin-top:2.2rem;flex-wrap:wrap;}
.cta-band .btn--ghost{color:var(--washi);border-color:rgba(245,241,230,.55);}
.cta-band .btn--ghost:hover{background:var(--washi);color:var(--sumi);border-color:var(--washi);}
.cta-band .tel{margin-top:2rem;font-family:var(--font-display);font-size:1.7rem;font-weight:700;letter-spacing:.04em;}
.cta-band .tel small{display:block;font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;color:rgba(245,241,230,.6);font-weight:400;margin-top:.4em;}

/* ---------- footer ---------- */
footer{background:var(--sumi);color:var(--washi);padding-block:clamp(48px,6vw,72px) 0;}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem;padding-bottom:3rem;}
.foot-brand .name{font-family:var(--font-display);font-size:1.5rem;font-weight:700;letter-spacing:.12em;}
.foot-brand p{color:rgba(245,241,230,.6);font-size:.9rem;margin-top:1rem;max-width:24em;}
.foot-col h4{font-family:var(--mono);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--igusa-soft);font-weight:500;margin-bottom:1.1rem;}
.foot-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.7rem;font-size:.92rem;}
.foot-col a{color:rgba(245,241,230,.78);transition:color .2s;}
.foot-col a:hover{color:#fff;}
.foot-bottom{border-top:1px solid rgba(245,241,230,.14);padding-block:1.5rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;font-size:.76rem;color:rgba(245,241,230,.5);font-family:var(--mono);letter-spacing:.06em;}

/* ---------- reveal ---------- */
@keyframes revealRise{from{transform:translateY(14px);}to{transform:none;}}
@media (prefers-reduced-motion:no-preference){
  .reveal.in{animation:revealRise .7s cubic-bezier(.2,.7,.2,1) both;}
}

/* ---------- responsive ---------- */
@media (max-width:1080px){
  .nav-links,.nav-tel{display:none;}
  .burger{display:flex;}
  header.menu-open .nav-links{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--washi);border-bottom:1px solid var(--line);padding:1.4rem var(--pad);gap:1.2rem;box-shadow:0 18px 30px -20px rgba(44,49,39,.4);}
}
@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr;}
  .hero-media{order:-1;max-width:440px;}
  .reasons{grid-template-columns:1fr;gap:2rem;}
  .svc-grid{grid-template-columns:1fr;}
  .svc-row{grid-template-columns:1fr;gap:1.6rem;}
  .svc-row .media,.svc-row--rev .media{order:-1;max-width:520px;}
  .flow{grid-template-columns:repeat(2,1fr);gap:2rem;}
  .voices,.voices--3{grid-template-columns:1fr;}
  .know{grid-template-columns:1fr;}
  .know .ph{order:-1;}
  .greeting{grid-template-columns:1fr;}
  .greeting .media{order:-1;max-width:360px;}
  .company-grid{grid-template-columns:1fr;}
  .company-media{max-width:480px;}
  .access{grid-template-columns:1fr;}
  .access .map{min-height:260px;}
  .contact-grid{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr;gap:2rem;}
  .nav-links,.nav-tel{display:none;}
  .burger{display:flex;}
  header.menu-open .nav-links{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--washi);border-bottom:1px solid var(--line);padding:1.4rem var(--pad);gap:1.2rem;box-shadow:0 18px 30px -20px rgba(44,49,39,.4);}
}
@media (max-width:560px){
  .field.two{grid-template-columns:1fr;}
  .flow{grid-template-columns:1fr;}
  .hero-meta{gap:1.4rem;}
  .topbar .wrap{justify-content:center;}
  .topbar .right{display:none;}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
}
