/*
Theme Name: NEXTLIFE Corporate
Theme URI: https://nextlife-eco.com/
Author: NEXTLIFE / Web Renewal
Description: 株式会社NEXTLIFE コーポレートサイト用オリジナルテーマ。生前整理・遺品整理・リユース事業を「価値の循環」というコンセプトで再設計したクラシックテーマ。
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
Text Domain: nextlife
*/

/* ============ DESIGN TOKENS ============ */
:root{
  --paper:#F6F2E9;
  --paper-2:#EFE9DA;
  --paper-card:#FBF8F1;
  --ink:#1E1C16;
  --ink-soft:#56524A;
  --navy:#13324B;
  --navy-2:#1E4A6B;
  --blue:#2E86C4;
  --green:#6BA539;
  --green-deep:#4F7C2A;
  --line:rgba(30,28,22,.13);
  --line-soft:rgba(30,28,22,.07);
  --shadow:0 24px 60px -32px rgba(19,50,75,.4);
  --serif:'Zen Old Mincho',serif;
  --sans:'Zen Kaku Gothic New',sans-serif;
  --label:'Fraunces',serif;
  --maxw:1180px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);background:var(--paper);color:var(--ink);
  line-height:1.85;font-size:16px;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
::selection{background:var(--green);color:#fff}

/* phrase unit — prevents Japanese headings from breaking mid-word */
.np{display:inline-block;white-space:nowrap}

/* ============ SHARED ELEMENTS ============ */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.eyebrow{
  font-family:var(--label);font-style:italic;font-size:.92rem;
  letter-spacing:.04em;color:var(--green-deep);
  display:flex;align-items:center;gap:.6em;margin-bottom:1.1rem;
}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--green-deep);display:inline-block}
.eyebrow.light{color:#9ec77a}
.eyebrow.light::before{background:#9ec77a}
.s-title{
  font-family:var(--serif);font-weight:700;
  font-size:clamp(1.55rem,2.9vw,2.35rem);line-height:1.55;
  letter-spacing:.012em;word-break:keep-all;
}
.lead{color:var(--ink-soft);font-size:1.02rem;max-width:46em}

.btn{
  display:inline-flex;align-items:center;gap:.65em;
  font-weight:700;font-size:.96rem;letter-spacing:.02em;
  padding:1.05em 1.9em;border-radius:2px;
  transition:transform .25s ease,box-shadow .25s ease,background .25s ease;
}
.btn .arw{transition:transform .25s ease}
.btn:hover .arw{transform:translateX(4px)}
.btn-green{background:var(--green);color:#fff;box-shadow:0 14px 26px -14px rgba(107,165,57,.8)}
.btn-green:hover{transform:translateY(-3px);background:var(--green-deep)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{transform:translateY(-3px);background:var(--navy-2)}
.btn-ghost{border:1.5px solid var(--line);color:var(--ink);background:transparent}
.btn-ghost:hover{border-color:var(--navy);background:var(--navy);color:#fff;transform:translateY(-3px)}
.btn-ghost-light{border:1.5px solid rgba(255,255,255,.4);color:#fff}
.btn-ghost-light:hover{background:#fff;color:var(--navy);transform:translateY(-3px)}

/* image placeholder */
.ph{
  position:relative;background:
    linear-gradient(135deg,rgba(19,50,75,.05),rgba(107,165,57,.06)),
    repeating-linear-gradient(45deg,transparent,transparent 11px,rgba(19,50,75,.035) 11px,rgba(19,50,75,.035) 12px);
  border:1px solid var(--line);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;color:var(--navy);overflow:hidden;
}
.ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ph .ico{width:46px;height:46px;opacity:.5;margin-bottom:.7rem}
.ph .cap{font-size:.78rem;letter-spacing:.04em;opacity:.62;max-width:80%;line-height:1.6}
.ph .tag{font-family:var(--label);font-style:italic;font-size:.78rem;letter-spacing:.05em;opacity:.45;margin-top:.3rem}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s cubic-bezier(.16,.7,.3,1),transform .9s cubic-bezier(.16,.7,.3,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ============ HEADER ============ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:200;
  background:rgba(246,242,233,.9);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line-soft);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:80px}
.logo{display:flex;align-items:center;gap:.6rem}
.logo svg{width:38px;height:38px;flex:none}
.logo img{max-height:46px;width:auto}
.logo .wm{display:flex;flex-direction:column;line-height:1}
.logo .wm b{font-family:var(--serif);font-weight:900;font-size:1.32rem;color:var(--navy);letter-spacing:.06em}
.logo .wm span{font-size:.6rem;letter-spacing:.42em;color:var(--green-deep);margin-top:.2rem}
.menu{display:flex;align-items:center;gap:2px;list-style:none}
.menu li{position:relative}
.menu a{
  display:block;padding:.7em 1em;font-size:.9rem;font-weight:500;
  color:var(--ink);transition:color .2s;white-space:nowrap;
}
.menu a:hover,
.menu .current-menu-item>a,.menu .current_page_item>a,
.menu .current-menu-parent>a,.menu .current-menu-ancestor>a{color:var(--green-deep)}
.menu .menu-item-has-children>a::after{content:"▾";font-size:.7rem;margin-left:.35em;opacity:.6}
.menu .sub-menu{
  position:absolute;top:100%;left:0;min-width:228px;list-style:none;
  background:var(--paper-card);border:1px solid var(--line);
  box-shadow:var(--shadow);padding:.5rem;
  opacity:0;visibility:hidden;transform:translateY(8px);transition:.22s ease;
}
.menu .menu-item-has-children:hover>.sub-menu{opacity:1;visibility:visible;transform:none}
.menu .sub-menu a{padding:.7em .9em;font-size:.86rem;border-radius:2px;transition:background .15s}
.menu .sub-menu a:hover{background:var(--paper-2);color:var(--green-deep)}
.menu .sub-menu .menu-item-has-children>a::after{display:none}
.nav-cta{display:flex;align-items:center;gap:.9rem}
.nav-tel{font-family:var(--label);font-size:1.05rem;color:var(--navy);font-weight:500}
.nav-tel small{display:block;font-family:var(--sans);font-size:.6rem;letter-spacing:.1em;color:var(--ink-soft)}
.nav-cta .btn{padding:.8em 1.3em;font-size:.85rem}
.burger{display:none;width:44px;height:44px;flex-direction:column;justify-content:center;gap:6px;align-items:center}
.burger span{width:24px;height:2px;background:var(--ink);transition:.3s}
.burger.x span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger.x span:nth-child(2){opacity:0}
.burger.x span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

.site-main{padding-top:80px}

/* ============ HERO ============ */
.hero{position:relative;padding:clamp(3.5rem,8vw,7rem) 0 clamp(4rem,8vw,7rem);overflow:hidden}
.hero::before{
  content:"";position:absolute;right:-12%;top:-18%;width:560px;height:560px;
  background:radial-gradient(circle,rgba(107,165,57,.16),transparent 68%);z-index:0;
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,5rem);align-items:center;position:relative;z-index:1}
.hero h1{
  font-family:var(--serif);font-weight:700;word-break:keep-all;
  font-size:clamp(2.2rem,4.8vw,3.45rem);line-height:1.42;letter-spacing:.012em;
}
.hero h1 em{font-style:normal;color:var(--green-deep);position:relative}
.hero h1 em::after{content:"";position:absolute;left:0;right:0;bottom:.04em;height:.16em;background:rgba(107,165,57,.3);z-index:-1}
.hero p.sub{margin:1.7rem 0 2.2rem;font-size:1.06rem;color:var(--ink-soft);max-width:30em}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero-trust{display:flex;gap:1.8rem;margin-top:2.6rem;padding-top:1.7rem;border-top:1px solid var(--line);flex-wrap:wrap}
.hero-trust div{display:flex;flex-direction:column}
.hero-trust b{font-family:var(--label);font-size:1.5rem;color:var(--navy);font-weight:500;line-height:1.2}
.hero-trust span{font-size:.76rem;color:var(--ink-soft);letter-spacing:.03em}
.hero-visual{position:relative}
.hero-visual .ph{aspect-ratio:4/5;border-radius:3px}
.hero-visual .float{
  position:absolute;left:-34px;bottom:38px;background:var(--navy);color:#fff;
  padding:1.3rem 1.5rem;border-radius:3px;box-shadow:var(--shadow);max-width:230px;
}
.hero-visual .float .k{font-family:var(--label);font-style:italic;color:#9ec77a;font-size:.82rem;margin-bottom:.3rem}
.hero-visual .float .v{font-family:var(--serif);font-size:1.05rem;line-height:1.6}

/* ============ SECTION ============ */
.sec{padding:clamp(4rem,8vw,7rem) 0}
.sec.tint{background:var(--paper-2)}
.sec.dark{background:var(--navy);color:#fff}
.sec.dark .s-title{color:#fff}
.sec.dark .lead,.sec.dark p{color:rgba(255,255,255,.82)}
.sec-head{margin-bottom:3.2rem;max-width:38em}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head.center .eyebrow{justify-content:center}
.sec-head .s-title{margin-top:0}

/* problem cards */
.prob-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.prob{background:var(--paper-card);border:1px solid var(--line);padding:2.2rem 1.8rem;border-radius:3px}
.prob .n{font-family:var(--label);font-style:italic;font-size:2.4rem;color:var(--green);line-height:1}
.prob h3{font-family:var(--serif);font-size:1.18rem;margin:.9rem 0 .6rem;line-height:1.6}
.prob p{font-size:.92rem;color:var(--ink-soft)}

/* pillars */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.pillar{
  background:var(--paper-card);border:1px solid var(--line);border-radius:3px;
  overflow:hidden;display:flex;flex-direction:column;transition:transform .3s ease,box-shadow .3s ease;
}
.pillar:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.pillar .ph{aspect-ratio:3/2}
.pillar .body{padding:1.8rem;display:flex;flex-direction:column;flex:1}
.pillar .pn{font-family:var(--label);font-style:italic;color:var(--green-deep);font-size:.85rem}
.pillar h3{font-family:var(--serif);font-size:1.4rem;margin:.45rem 0 .7rem}
.pillar p{font-size:.92rem;color:var(--ink-soft);flex:1}
.pillar .more{margin-top:1.2rem;font-weight:700;font-size:.86rem;color:var(--navy);display:flex;align-items:center;gap:.4em}

/* circulation */
.circ-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.circ-grid .txt p{margin-top:1.2rem}
.diagram{width:100%;height:auto}

/* reasons */
.reasons{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}
.reason{display:flex;gap:1.3rem;background:var(--paper-card);border:1px solid var(--line);padding:1.9rem;border-radius:3px}
.reason .ri{width:52px;height:52px;flex:none;border-radius:50%;background:rgba(107,165,57,.13);display:flex;align-items:center;justify-content:center}
.reason .ri svg{width:26px;height:26px}
.reason h3{font-family:var(--serif);font-size:1.16rem;margin-bottom:.45rem}
.reason p{font-size:.9rem;color:var(--ink-soft)}

/* steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;counter-reset:st}
.step{position:relative;padding:2rem 1.4rem;background:var(--paper-card);border:1px solid var(--line);border-radius:3px}
.step::before{counter-increment:st;content:"0" counter(st);font-family:var(--label);font-style:italic;font-size:1.8rem;color:var(--green)}
.step h3{font-family:var(--serif);font-size:1.12rem;margin:.5rem 0 .5rem}
.step p{font-size:.85rem;color:var(--ink-soft)}

/* works */
.works-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.work{background:var(--paper-card);border:1px solid var(--line);border-radius:3px;overflow:hidden}
.work .ba{display:grid;grid-template-columns:1fr 1fr}
.work .ba .ph{aspect-ratio:1;border:none;border-right:1px solid var(--line)}
.work .ba .ph .badge{position:absolute;top:8px;left:8px;font-family:var(--label);font-style:italic;font-size:.7rem;background:var(--navy);color:#fff;padding:.15em .6em}
.work .ba .ph.aft .badge{background:var(--green)}
.work .wb{padding:1.5rem}
.work .wb .meta{font-size:.76rem;color:var(--green-deep);font-family:var(--label);font-style:italic;margin-bottom:.4rem}
.work .wb h3{font-family:var(--serif);font-size:1.1rem;margin-bottom:.5rem}
.work .wb p{font-size:.85rem;color:var(--ink-soft)}

/* voice */
.voices{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2.5rem}
.voice{background:var(--navy-2);color:#fff;padding:2rem;border-radius:3px}
.voice .q{font-family:var(--serif);font-size:3rem;color:#9ec77a;line-height:.6;height:.5em}
.voice p{font-size:.92rem;margin:1rem 0;color:rgba(255,255,255,.9)}
.voice .who{font-size:.78rem;color:#9ec77a}

/* csr */
.csr-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.csr-list{margin-top:1.6rem;display:flex;flex-direction:column;gap:.9rem;list-style:none}
.csr-list li{display:flex;gap:.8rem;font-size:.95rem}
.csr-list li::before{content:"";width:8px;height:8px;background:var(--green);border-radius:50%;margin-top:.6em;flex:none}

/* recruit band */
.recruit-band{position:relative;background:var(--navy);color:#fff;overflow:hidden}
.recruit-band .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center}
.recruit-band .ph{aspect-ratio:16/10;border-color:rgba(255,255,255,.18);background:
  linear-gradient(135deg,rgba(255,255,255,.04),rgba(107,165,57,.1)),
  repeating-linear-gradient(45deg,transparent,transparent 11px,rgba(255,255,255,.04) 11px,rgba(255,255,255,.04) 12px)}
.recruit-band .ph .ico,.recruit-band .ph .cap,.recruit-band .ph .tag{color:#fff}

/* news */
.news-list{display:flex;flex-direction:column}
.news-row{display:grid;grid-template-columns:130px 110px 1fr 30px;gap:1.4rem;align-items:center;
  padding:1.3rem .4rem;border-bottom:1px solid var(--line);transition:background .2s}
.news-row:hover{background:var(--paper-card)}
.news-row .date{font-family:var(--label);font-style:italic;color:var(--ink-soft);font-size:.9rem}
.news-row .cat{font-size:.72rem;text-align:center;padding:.3em .2em;border:1px solid var(--green-deep);color:var(--green-deep);border-radius:2px}
.news-row .ttl{font-size:.95rem;font-weight:500}
.news-row .arw{color:var(--green-deep)}
.news-empty{padding:2.5rem;text-align:center;color:var(--ink-soft);background:var(--paper-card);border:1px solid var(--line);border-radius:3px}

/* CTA band */
.cta-band{background:linear-gradient(120deg,var(--navy),var(--navy-2));color:#fff;text-align:center;padding:clamp(3.5rem,7vw,6rem) 0}
.cta-band h2{font-family:var(--serif);font-size:clamp(1.5rem,3vw,2.3rem);line-height:1.55;word-break:keep-all}
.cta-band p{color:rgba(255,255,255,.74);margin:1.1rem auto 2.2rem;max-width:34em}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* page header */
.page-head{background:var(--navy);color:#fff;padding:clamp(3rem,6vw,5rem) 0 clamp(2.6rem,5vw,4rem);position:relative;overflow:hidden}
.page-head::before{content:"";position:absolute;right:-8%;top:-30%;width:420px;height:420px;background:radial-gradient(circle,rgba(107,165,57,.22),transparent 68%)}
.crumb{font-size:.78rem;color:rgba(255,255,255,.6);margin-bottom:1rem;position:relative}
.crumb a:hover{color:#9ec77a}
.page-head h1{font-family:var(--serif);font-size:clamp(1.8rem,3.8vw,2.7rem);position:relative;line-height:1.45;word-break:keep-all}
.page-head .en{font-family:var(--label);font-style:italic;color:#9ec77a;font-size:.95rem;position:relative;display:block;margin-bottom:.5rem}

/* prose */
.prose{max-width:50em}
.prose p{margin-bottom:1.3rem;color:var(--ink-soft)}
.prose h2{font-family:var(--serif);font-size:1.6rem;margin:2.6rem 0 1.1rem;color:var(--ink);line-height:1.6}
.prose h3{font-family:var(--serif);font-size:1.2rem;margin:1.8rem 0 .7rem}
.prose ul,.prose ol{margin:0 0 1.3rem 1.3rem;color:var(--ink-soft)}
.prose img{margin:1.5rem 0;border-radius:3px}
.prose a{color:var(--green-deep);text-decoration:underline}

/* definition table */
.dl{border-top:1px solid var(--line)}
.dl .row{display:grid;grid-template-columns:220px 1fr;border-bottom:1px solid var(--line)}
.dl .row dt{padding:1.2rem 1rem 1.2rem 1.2rem;font-weight:700;font-size:.92rem;background:var(--paper-2)}
.dl .row dd{padding:1.2rem;font-size:.95rem;color:var(--ink-soft)}
.flag{display:inline-block;font-size:.68rem;background:#E8B23A;color:#3a2c00;padding:.1em .55em;border-radius:2px;margin-left:.5em;vertical-align:middle;font-weight:700}

/* generic columns / cards */
.cols-2{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.cols-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.icard{background:var(--paper-card);border:1px solid var(--line);padding:1.9rem;border-radius:3px;display:block}
.icard h3{font-family:var(--serif);font-size:1.18rem;margin-bottom:.6rem;line-height:1.6}
.icard p{font-size:.9rem;color:var(--ink-soft)}
.icard .tagline{font-family:var(--label);font-style:italic;color:var(--green-deep);font-size:.82rem;margin-bottom:.4rem}
.icard .more{margin-top:1rem;display:inline-block;font-weight:700;color:var(--navy);font-size:.85rem}
.sub-h{font-family:var(--serif);font-size:1.35rem;margin-bottom:1.2rem;line-height:1.6}

/* faq */
.faq{max-width:46em}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;text-align:left;display:flex;justify-content:space-between;gap:1rem;padding:1.4rem .2rem;font-weight:700;font-size:1rem;line-height:1.6}
.faq-q .pm{flex:none;color:var(--green-deep);font-size:1.3rem;transition:transform .25s}
.faq-item.open .pm{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-a p{padding:0 .2rem 1.5rem;color:var(--ink-soft);font-size:.93rem}

/* form */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:start}
.field{margin-bottom:1.3rem}
.field label{display:block;font-size:.85rem;font-weight:700;margin-bottom:.45rem}
.field label .req{color:#c0392b;font-size:.72rem;margin-left:.3em}
.field input,.field select,.field textarea{
  width:100%;font-family:inherit;font-size:.95rem;padding:.85em 1em;
  border:1px solid var(--line);background:var(--paper-card);border-radius:2px;color:var(--ink);
}
.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--green)}
.field textarea{resize:vertical;min-height:130px}
.contact-aside{background:var(--paper-2);border:1px solid var(--line);padding:2rem;border-radius:3px}
.contact-aside h3{font-family:var(--serif);font-size:1.2rem;margin-bottom:1rem}
.contact-aside .tel-big{font-family:var(--label);font-size:2rem;color:var(--navy);font-weight:500}
.contact-aside p{font-size:.85rem;color:var(--ink-soft);margin-bottom:1.2rem}

/* recruit positions */
.pos{display:flex;justify-content:space-between;align-items:center;gap:1rem;background:var(--paper-card);border:1px solid var(--line);padding:1.5rem 1.8rem;border-radius:3px;margin-bottom:1rem}
.pos h3{font-family:var(--serif);font-size:1.15rem;line-height:1.5}
.pos .pmeta{font-size:.82rem;color:var(--ink-soft)}

.mini-note{font-size:.78rem;color:var(--ink-soft);background:var(--paper-2);border-left:3px solid var(--green);padding:.8rem 1rem;border-radius:2px;margin-top:1.5rem}

/* single news */
.single-body{max-width:46em}
.single-body .post-meta{display:flex;gap:1rem;align-items:center;margin-bottom:1.5rem;font-size:.82rem;color:var(--ink-soft)}
.single-body .post-meta .cat{border:1px solid var(--green-deep);color:var(--green-deep);padding:.2em .7em;border-radius:2px}
.single-body .content{margin-bottom:2.5rem}
.single-body .content p{margin-bottom:1.2rem;color:var(--ink-soft)}
.pager{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:1.6rem}
.pagination{display:flex;gap:.5rem;justify-content:center;margin-top:2.5rem;flex-wrap:wrap}
.pagination .page-numbers{padding:.5em .9em;border:1px solid var(--line);border-radius:2px;font-size:.88rem;background:var(--paper-card)}
.pagination .page-numbers.current{background:var(--navy);color:#fff;border-color:var(--navy)}

/* footer */
.site-footer{background:var(--ink);color:rgba(255,255,255,.62);padding:4rem 0 2rem}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2.5rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-brand .logo .wm b{color:#fff}
.foot-brand p{font-size:.84rem;margin-top:1.2rem;line-height:1.9}
.foot-col h4{color:#fff;font-size:.82rem;letter-spacing:.08em;margin-bottom:1rem;font-family:var(--label);font-style:italic}
.foot-col a{display:block;font-size:.85rem;padding:.32rem 0;transition:color .15s}
.foot-col a:hover{color:#9ec77a}
.foot-col ul{list-style:none}
.foot-bot{display:flex;justify-content:space-between;padding-top:1.8rem;font-size:.74rem;flex-wrap:wrap;gap:1rem}
.foot-bot .links{display:flex;gap:1.4rem}

/* mobile bar */
.mbar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:190;grid-template-columns:1fr 1fr;background:#fff;box-shadow:0 -6px 20px rgba(0,0,0,.12)}
.mbar a{display:flex;align-items:center;justify-content:center;gap:.5em;padding:1em;font-weight:700;font-size:.9rem}
.mbar a:first-child{background:var(--navy);color:#fff}
.mbar a:last-child{background:var(--green);color:#fff}

/* skip link */
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:1rem;top:1rem;z-index:999;background:#fff;padding:.6em 1em;border-radius:3px}

/* ============ RESPONSIVE ============ */
@media(max-width:980px){
  .hero-grid,.circ-grid,.csr-grid,.recruit-band .wrap,.form-grid{grid-template-columns:1fr}
  .prob-grid,.pillars,.works-grid,.voices,.cols-3{grid-template-columns:1fr 1fr}
  .reasons,.steps{grid-template-columns:1fr}
  .hero-visual{order:-1;max-width:420px}
}
@media(max-width:760px){
  .wrap{padding:0 20px}
  .menu,.nav-tel{display:none}
  .burger{display:flex}
  .nav-cta .btn{display:none}
  .menu{
    position:fixed;top:80px;left:0;right:0;background:var(--paper-card);
    flex-direction:column;align-items:stretch;padding:1rem;gap:0;
    border-bottom:1px solid var(--line);box-shadow:var(--shadow);
    display:none;max-height:calc(100vh - 80px);overflow:auto;
  }
  .menu.open{display:flex}
  .menu>li>a{padding:1em .6em;font-size:1rem;border-bottom:1px solid var(--line-soft)}
  .menu .sub-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;background:var(--paper-2);padding:.2rem .2rem .6rem}
  .menu .menu-item-has-children>a::after{float:right}
  .prob-grid,.pillars,.works-grid,.voices,.cols-2,.cols-3{grid-template-columns:1fr}
  .dl .row{grid-template-columns:1fr}
  .dl .row dt{padding-bottom:.3rem}
  .dl .row dd{padding-top:.5rem}
  .news-row{grid-template-columns:1fr;gap:.4rem}
  .news-row .arw{display:none}
  .site-main{padding-bottom:64px}
  .mbar{display:grid}
  .hero-visual .float{left:0;right:0;margin:-30px auto 0;position:relative;bottom:auto;max-width:none}
  .foot-top{grid-template-columns:1fr 1fr}
}
