*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --forest:#2d4a3e;--forest-d:#1a2e27;--sage:#6b7c5c;--sage-l:#c8d4c0;
  --gold:#b8a06a;--gold-l:#d4bc8a;--cream:#faf8f4;--parch:#f5f0e8;
  --ink:#2c2c2a;--ink-l:#5a5a58;--ink-ll:#999994;
  --fm:'Noto Serif JP',serif;--fmin:'Shippori Mincho',serif;--flat:'Cormorant Garamond',serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--fm);color:var(--ink);background:var(--cream);overflow-x:hidden}

/* ── NAV ── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  padding:0 48px;height:76px;
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(22,41,39,.92);backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(200,212,192,.1);
  transition:height .4s,background .4s;
}
.nav.sc{height:60px;background:rgba(22,41,39,.98)}
.nav-logo{display:flex;align-items:center;text-decoration:none}
.nav-logo img{height:44px;width:auto;object-fit:contain;transition:height .4s}
.nav.sc .nav-logo img{height:34px}
.nav-links{display:flex;align-items:center;gap:36px;list-style:none}
.nav-links a{font-family:var(--flat);font-size:.72rem;letter-spacing:.3em;color:rgba(255,255,255,.6);text-decoration:none;text-transform:uppercase;transition:color .3s}
.nav-links a:hover{color:var(--sage-l)}
.nav-cta{font-family:var(--fmin)!important;font-size:.72rem!important;color:var(--forest-d)!important;background:var(--sage-l);padding:9px 22px;transition:background .3s!important;letter-spacing:.15em!important}
.nav-cta:hover{background:#fff!important}

/* ── HERO ── */
.hero{min-height:100vh;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:url('https://onsensui-junmei.com/wp-content/uploads/2026/02/S__2998275.jpg') center/cover no-repeat;animation:zoom 16s ease-in-out infinite alternate}
@keyframes zoom{from{transform:scale(1.07)}to{transform:scale(1)}}
.hero-ov1{position:absolute;inset:0;background:linear-gradient(160deg,rgba(22,41,39,.82) 0%,rgba(26,46,39,.62) 55%,rgba(45,74,62,.48) 100%)}
.hero-ov2{position:absolute;inset:0;background:linear-gradient(to top,rgba(22,41,39,.9) 0%,transparent 50%)}
.hero-c{position:relative;z-index:1;text-align:center;max-width:860px;padding:0 40px;animation:heroin 1.6s cubic-bezier(.16,1,.3,1) both}
@keyframes heroin{from{opacity:0;transform:translateY(36px)}to{opacity:1;transform:none}}
.hero-logo{margin-bottom:40px;display:flex;justify-content:center}
.hero-logo img{height:80px;width:auto;object-fit:contain;filter:drop-shadow(0 4px 28px rgba(0,0,0,.45))}
.hero-ey{font-family:var(--flat);font-size:.7rem;letter-spacing:.55em;color:var(--sage-l);text-transform:uppercase;display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:28px}
.hero-ey::before,.hero-ey::after{content:'';flex:0 0 48px;height:1px;background:rgba(200,212,192,.5)}
.hero-h1{font-family:var(--fmin);font-size:clamp(3rem,7vw,5.5rem);font-weight:500;color:#fff;line-height:1.5;letter-spacing:.12em;margin-bottom:20px}
.hero-h1 em{font-family:var(--flat);font-style:italic;font-size:.72em;color:var(--sage-l);display:block;letter-spacing:.18em;font-weight:300;margin-top:8px}
.hero-desc{font-size:.86rem;line-height:2.4;color:rgba(255,255,255,.5);max-width:540px;margin:0 auto 52px}
.scroll-ind{display:flex;flex-direction:column;align-items:center;gap:10px;font-family:var(--flat);font-size:.65rem;letter-spacing:.4em;color:rgba(200,212,192,.45);text-transform:uppercase;animation:bob 2.2s ease-in-out infinite}
.scroll-ind::after{content:'';width:1px;height:52px;background:linear-gradient(to bottom,rgba(200,212,192,.45),transparent)}
@keyframes bob{0%,100%{transform:none}50%{transform:translateY(7px)}}

/* ── REVEAL ── */
.rv{opacity:0;transform:translateY(28px);transition:opacity .85s ease,transform .85s ease}
.rv.vis{opacity:1;transform:none}
.d1{transition-delay:.12s}.d2{transition-delay:.24s}.d3{transition-delay:.36s}

/* ── SECTION COMMON ── */
.sec-lbl{font-family:var(--flat);font-size:.68rem;letter-spacing:.5em;text-transform:uppercase;display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:18px}
.sec-lbl::before,.sec-lbl::after{content:'';flex:0 0 32px;height:1px}
.sec-lbl.sage{color:var(--sage)}.sec-lbl.sage::before,.sec-lbl.sage::after{background:rgba(107,124,92,.5)}
.sec-lbl.gold{color:var(--gold)}.sec-lbl.gold::before,.sec-lbl.gold::after{background:rgba(184,160,106,.4)}
.sec-lbl.light{color:var(--sage-l)}.sec-lbl.light::before,.sec-lbl.light::after{background:rgba(200,212,192,.3)}
.sec-t{font-family:var(--fmin);font-size:clamp(1.7rem,3vw,2.6rem);font-weight:500;letter-spacing:.1em;line-height:1.55}

/* ── BUSINESSES (3 cards) ── */
.biz{padding:100px 72px;background:var(--cream)}
.biz-hd{text-align:center;margin-bottom:64px}
.biz-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;max-width:1200px;margin:0 auto}

/* card base */
.biz-card{position:relative;overflow:hidden;display:flex;flex-direction:column;text-decoration:none;color:inherit;transition:transform .4s}
.biz-card:hover{transform:translateY(-6px)}

.biz-card:hover .biz-bar{width:100%}



.biz-body{padding:36px 32px 44px;flex:1;display:flex;flex-direction:column;background:var(--parch);position:relative;z-index:2}
.biz-tag{font-family:var(--flat);font-size:.64rem;letter-spacing:.42em;color:var(--gold);text-transform:uppercase;display:block;margin-bottom:12px}
.biz-name{font-family:var(--fmin);font-size:1.45rem;font-weight:500;color:var(--forest);letter-spacing:.08em;margin-bottom:6px}
.biz-sub{font-family:var(--flat);font-style:italic;font-size:.9rem;color:var(--ink-ll);margin-bottom:18px;line-height:1.5}
.biz-desc{font-size:.8rem;line-height:2.3;color:var(--ink-l);margin-bottom:auto;padding-bottom:28px}
.biz-concept{margin-bottom:28px}
.biz-concept p{font-family:var(--fmin);font-size:.85rem;color:var(--forest);line-height:2;letter-spacing:.04em}
.biz-concept p::before{content:'「';color:var(--sage)}.biz-concept p::after{content:'」';color:var(--sage)}
.btn-link{display:inline-flex;align-items:center;gap:10px;font-family:var(--fmin);font-size:.78rem;letter-spacing:.2em;color:var(--forest);border:1px solid rgba(45,74,62,.35);padding:12px 24px;text-decoration:none;transition:all .3s;align-self:flex-start;position:relative;z-index:10;cursor:pointer}
.btn-link::after{content:'→';transition:transform .3s}
.btn-link:hover{background:var(--forest);color:#fff;border-color:var(--forest)}
.btn-link:hover::after{transform:translateX(4px)}
.biz-bar{position:absolute;bottom:0;left:0;height:3px;width:0;background:linear-gradient(to right,var(--sage),var(--sage-l));transition:width .5s ease;z-index:1}

/* OEM card dark */
.biz-card.oem-card .biz-body{background:var(--forest-d)}
.biz-card.oem-card .biz-tag{color:var(--gold-l)}
.biz-card.oem-card .biz-name{color:#fff}
.biz-card.oem-card .biz-sub{color:rgba(200,212,192,.5)}
.biz-card.oem-card .biz-desc{color:rgba(255,255,255,.5)}
.biz-card.oem-card .btn-link{color:var(--gold-l);border-color:rgba(200,212,192,.25)}
.biz-card.oem-card .btn-link:hover{background:var(--gold-l);color:var(--forest-d);border-color:var(--gold-l)}

/* mine: card dark */
.biz-card.mine-card .biz-body{background:#2a4a3a}
.biz-card.mine-card .biz-tag{color:rgba(200,212,192,.85)}
.biz-card.mine-card .biz-name{color:#fff}
.biz-card.mine-card .biz-sub{color:rgba(200,212,192,.7)}
.biz-card.mine-card .biz-concept p{color:#e8f0e4;font-size:.9rem}
.biz-card.mine-card .biz-concept p::before,.biz-card.mine-card .biz-concept p::after{color:rgba(200,212,192,.4)}
.biz-card.mine-card .btn-link{color:var(--sage-l);border-color:rgba(200,212,192,.2)}
.biz-card.mine-card .btn-link:hover{background:rgba(200,212,192,.1);color:#fff;border-color:rgba(200,212,192,.4)}
.biz-bar-light{background:linear-gradient(to right,rgba(200,212,192,.4),rgba(200,212,192,.8))}

/* ── NEWS ── */
.news{padding:100px 72px;background:var(--parch)}
.news-in{display:grid;grid-template-columns:240px 1fr;gap:72px;max-width:1100px;margin:0 auto;align-items:start}
.news-hd .sec-t{color:var(--forest);margin-bottom:28px}
.news-more{display:inline-flex;align-items:center;gap:10px;font-family:var(--flat);font-size:.7rem;letter-spacing:.35em;text-transform:uppercase;color:var(--sage);text-decoration:none;transition:gap .3s}
.news-more::after{content:'→'}
.news-more:hover{gap:16px}
.news-list{list-style:none}
.news-item{display:grid;grid-template-columns:110px 60px 1fr;gap:0 18px;align-items:center;padding:22px 0;border-bottom:1px solid rgba(107,124,92,.14);text-decoration:none;color:inherit}
.news-item:first-child{border-top:1px solid rgba(107,124,92,.14)}
.news-item:hover .n-title{color:var(--forest)}
.n-date{font-family:var(--flat);font-size:.78rem;color:var(--ink-ll);letter-spacing:.05em}
.n-cat{font-size:.63rem;letter-spacing:.1em;color:var(--gold);border:1px solid rgba(184,160,106,.4);padding:3px 8px;text-align:center;white-space:nowrap}
.n-title{font-family:var(--fmin);font-size:.84rem;color:var(--ink-l);transition:color .3s;line-height:1.65}

/* ── MISSION ── */
.mission{padding:100px 72px;background:var(--cream)}
.mission-in{display:grid;grid-template-columns:1fr 1fr;gap:0;max-width:1200px;margin:0 auto}
.mission-l{padding-right:72px;border-right:1px solid rgba(107,124,92,.18)}
.m-lbl{font-family:var(--flat);font-size:.67rem;letter-spacing:.5em;color:var(--sage);text-transform:uppercase;margin-bottom:18px;display:block}
.m-t{font-family:var(--fmin);font-size:clamp(1.7rem,3vw,2.5rem);font-weight:500;color:var(--forest);line-height:1.55;letter-spacing:.1em;margin-bottom:28px}
.m-body{font-size:.83rem;line-height:2.7;color:var(--ink-l)}
.m-body strong{color:var(--forest);font-family:var(--fmin);font-weight:500}
.mission-r{padding-left:72px;display:grid;grid-template-columns:1fr 1fr;align-content:center}
.m-stat{padding:30px 20px;text-align:center;border-bottom:1px solid rgba(107,124,92,.14);border-right:1px solid rgba(107,124,92,.14)}
.m-stat:nth-child(2n){border-right:none}
.m-stat:nth-child(3),.m-stat:nth-child(4){border-bottom:none}
.m-stat-n{font-family:var(--flat);font-size:2.6rem;font-weight:300;color:var(--forest);line-height:1;margin-bottom:8px}
.m-stat-n sup{font-size:.9rem;vertical-align:super}
.m-stat-l{font-family:var(--fmin);font-size:.71rem;color:var(--ink-ll);letter-spacing:.08em}

/* ── COMPANY ── */
.company{padding:100px 72px;background:var(--parch)}
.co-in{display:grid;grid-template-columns:1fr 380px;gap:60px;max-width:1200px;margin:0 auto}
.greeting{background:var(--cream);padding:36px 32px;border-left:3px solid var(--sage);margin-bottom:40px}
.greeting-text{font-size:.84rem;line-height:2.7;color:var(--ink-l);margin-bottom:20px}
.greeting-sig{font-family:var(--fmin);font-size:.82rem;color:var(--forest);letter-spacing:.08em;text-align:right}
.co-tbl{width:100%;border-collapse:collapse}
.co-tbl tr{border-bottom:1px solid rgba(107,124,92,.15)}
.co-tbl tr:first-child{border-top:1px solid rgba(107,124,92,.15)}
.co-tbl th{font-family:var(--fmin);font-size:.77rem;font-weight:500;color:var(--forest);padding:16px 0;width:100px;vertical-align:top;text-align:left;letter-spacing:.06em}
.co-tbl td{font-size:.81rem;line-height:2.1;color:var(--ink-l);padding:16px 0 16px 20px;vertical-align:top}
.co-r{display:flex;flex-direction:column;gap:3px;position:sticky;top:100px;align-self:start}
.co-photo{width:100%;height:260px;object-fit:cover;display:block}
.co-map iframe{width:100%;height:200px;border:none;display:block}
.co-map-lbl{background:var(--forest);padding:12px 16px;font-family:var(--fmin);font-size:.74rem;color:rgba(255,255,255,.62);letter-spacing:.08em}

/* ── CTA ── */
.cta{padding:100px 72px;background:linear-gradient(150deg,var(--forest-d) 0%,var(--forest) 100%);text-align:center;position:relative;overflow:hidden}
.cta::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(200,212,192,.07) 0%,transparent 60%)}
.cta-in{position:relative;z-index:1;max-width:600px;margin:0 auto}
.cta h2{font-family:var(--fmin);font-size:clamp(1.7rem,3vw,2.5rem);font-weight:500;color:#fff;letter-spacing:.1em;line-height:1.55;margin-bottom:20px}
.cta p{font-size:.85rem;line-height:2.4;color:rgba(255,255,255,.5);margin-bottom:48px}
.btn-gold{display:inline-flex;align-items:center;gap:14px;font-family:var(--fmin);font-size:.85rem;letter-spacing:.22em;color:var(--forest-d);background:var(--gold-l);padding:18px 44px;text-decoration:none;transition:background .3s}
.btn-gold::after{content:'→';transition:transform .3s}
.btn-gold:hover{background:#fff}
.btn-gold:hover::after{transform:translateX(5px)}

/* ── FOOTER ── */
.footer{background:var(--forest-d);padding:60px 48px 32px}
.footer-in{max-width:1200px;margin:0 auto}
.footer-top{display:grid;grid-template-columns:1fr auto;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(200,212,192,.1);margin-bottom:28px}
.f-logo{height:38px;width:auto;object-fit:contain;margin-bottom:14px;display:block}
.f-addr{font-size:.74rem;line-height:2.2;color:rgba(255,255,255,.32)}
.f-nav{display:flex;flex-direction:column;gap:13px;align-items:flex-end}
.f-nav a{font-family:var(--flat);font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(200,212,192,.42);text-decoration:none;transition:color .3s}
.f-nav a:hover{color:var(--sage-l)}
.f-btm{display:flex;justify-content:space-between;align-items:center}
.f-copy{font-family:var(--flat);font-size:.65rem;letter-spacing:.14em;color:rgba(255,255,255,.2)}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .biz-grid{grid-template-columns:1fr 1fr}
  .mission-in{grid-template-columns:1fr}
  .mission-l{border-right:none;padding-right:0;padding-bottom:60px;border-bottom:1px solid rgba(107,124,92,.18);margin-bottom:60px}
  .mission-r{padding-left:0}
  .mission{padding:80px 24px}
  .co-in{grid-template-columns:1fr;gap:40px}
  .co-r{position:static}
  .news-in{grid-template-columns:1fr;gap:48px}
}
@media(max-width:768px){
  .nav{padding:0 20px}.nav-links{display:none}
  .hero-c{padding:0 24px}.hero-logo img{height:60px}
  .biz,.news,.company,.cta,.footer{padding:80px 24px}
  .biz-grid{grid-template-columns:1fr}
  .news-item{grid-template-columns:94px 52px 1fr;gap:0 10px}
  .footer{padding:48px 24px 24px}
  .footer-top{grid-template-columns:1fr}.f-nav{align-items:flex-start}
}

/* ── PROCESS ── */
.process{padding:100px 72px;background:var(--forest-d);position:relative;overflow:hidden}
.process::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse at 100% 0%,rgba(200,212,192,.05) 0%,transparent 50%)}
.process-hd{text-align:center;margin-bottom:72px;position:relative;z-index:1}
.process-hd .sec-t{color:#fff}
.process-wrap{max-width:1200px;margin:0 auto;position:relative;z-index:1;display:flex;flex-direction:column;gap:3px;padding-left:60px}
/* 左端縦ライン */
.process-wrap::before{content:'';position:absolute;left:22px;top:10px;bottom:10px;width:1px;background:linear-gradient(to bottom,transparent,rgba(200,212,192,.4) 5%,rgba(200,212,192,.4) 95%,transparent)}
/* 各カード行 */
.pcard{background:rgba(255,255,255,.05);border:1px solid rgba(200,212,192,.1);overflow:hidden;display:flex;transition:background .3s,transform .3s;position:relative}
.pcard:hover{background:rgba(255,255,255,.09);transform:translateY(-3px)}
/* ドット */
.pcard::before{
  content:attr(data-step);position:absolute;left:-49px;top:50%;transform:translateY(-50%);
  width:36px;height:36px;border-radius:50%;
  background:var(--forest-d);border:1px solid var(--sage);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--flat);font-size:.78rem;color:var(--sage-l);z-index:3;
}
.pcard:hover::before{background:var(--sage);color:var(--forest-d)}
.pcard-img{width:280px;min-width:280px;height:200px;object-fit:cover;display:block;filter:brightness(.8);transition:filter .4s;flex-shrink:0}
.pcard:hover .pcard-img{filter:brightness(1)}
.pcard-body{padding:32px 40px;display:flex;flex-direction:column;justify-content:center;flex:1}
.pcard-step{font-family:var(--flat);font-size:.63rem;letter-spacing:.5em;color:var(--gold);text-transform:uppercase;display:block;margin-bottom:8px}
.pcard-title{font-family:var(--fmin);font-size:1.1rem;font-weight:500;color:#fff;letter-spacing:.08em;margin-bottom:10px}
.pcard-desc{font-size:.8rem;line-height:2.2;color:rgba(255,255,255,.55)}
@media(max-width:768px){
  .process{padding:72px 24px}
  .process-wrap{padding-left:44px}
  .process-wrap::before{left:16px}
  .pcard::before{left:-34px;width:28px;height:28px;font-size:.68rem}
  .pcard-img{width:160px;min-width:160px;height:160px}
  .pcard-body{padding:20px 24px}
}
@media(max-width:560px){
  .process-wrap{padding-left:36px}
  .pcard{flex-direction:column}
  .pcard::before{left:-28px;top:20px;transform:none}
  .pcard-img{width:100%;min-width:unset;height:180px}
}

/* left line dot per row */
.pc-row{position:relative}
.pc-row::before{content:attr(data-step);position:absolute;left:-54px;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:50%;background:var(--forest-d);border:1px solid var(--sage);display:flex;align-items:center;justify-content:center;font-family:var(--flat);font-size:.8rem;color:var(--sage-l);z-index:3;display:flex;align-items:center;justify-content:center}
.pcard-title{font-family:var(--fmin);font-size:1.05rem;font-weight:500;color:#fff;letter-spacing:.08em;margin-bottom:10px}
.pcard-desc{font-size:.78rem;line-height:2.1;color:rgba(255,255,255,.55)}
@media(max-width:900px){.pc-row{grid-template-columns:1fr}}
@media(max-width:768px){
  .process-wrap::before{display:none}
  .pc-row::before{display:none}
  .process{padding:72px 24px}
}
@media(max-width:600px){
  .pcard{flex-direction:column}
  .pcard-img{width:100%;min-width:unset;height:180px}
}

/* PC: 左ライン＋2カラムグリッド */
.process-grid-wrap{
  display:grid;grid-template-columns:1fr 1fr;
  gap:3px;
}
/* 左端縦ライン（スマホ用、PC非表示） */
.process-timeline::before{display:none}
/* ドット（PC非表示） */
.process-dot{display:none}
/* カード */
.process-card{
  background:rgba(255,255,255,.05);border:1px solid rgba(200,212,192,.1);
  overflow:hidden;transition:background .3s,transform .3s;
}
.process-card:hover{background:rgba(255,255,255,.09);transform:translateY(-3px)}
.process-inner{display:flex;flex-direction:column;align-items:stretch}
.process-img{width:100%;height:220px;object-fit:cover;display:block;filter:brightness(.78);transition:filter .4s}
.process-card:hover .process-img{filter:brightness(1)}
.process-body{padding:28px 32px;flex:1;display:flex;flex-direction:column;justify-content:center}
.process-step{font-family:var(--flat);font-size:.65rem;letter-spacing:.5em;color:var(--gold);text-transform:uppercase;display:block;margin-bottom:8px}
.process-title{font-family:var(--fmin);font-size:1.1rem;font-weight:500;color:#fff;letter-spacing:.08em;margin-bottom:10px}
.process-desc{font-size:.8rem;line-height:2.1;color:rgba(255,255,255,.55)}
/* PC: rowクラスは不要なのでgrid-wrapの直接の子としてカードを並べる */
.process-row{display:contents}
.process-empty{display:none}
@media(max-width:768px){
  
  .process-grid-wrap{grid-template-columns:1fr 1fr}
  .process-img{height:160px}
  .process-body{padding:20px 20px}
}
@media(max-width:560px){
  .process-grid-wrap{grid-template-columns:1fr}
  /* スマホ：左ライン＋ドット復活 */
  .process-timeline::before{
    display:block;
    content:'';position:absolute;left:22px;top:0;bottom:0;width:1px;
    background:linear-gradient(to bottom,transparent,rgba(200,212,192,.35) 5%,rgba(200,212,192,.35) 95%,transparent);
  }
  .process-row{display:grid;grid-template-columns:44px 1fr;gap:0 16px;align-items:flex-start;margin-bottom:24px}
  .process-row:last-child{margin-bottom:0}
  .process-dot{display:flex;justify-content:center;padding-top:16px;position:relative;z-index:2}
  .process-dot-inner{
    width:44px;height:44px;border-radius:50%;flex-shrink:0;
    background:var(--forest-d);border:1px solid var(--sage);
    display:flex;align-items:center;justify-content:center;
    font-family:var(--flat);font-size:.82rem;color:var(--sage-l);
  }
  .process-card{grid-column:2}
  .process-inner{flex-direction:column}
  .process-img{width:100%;height:160px;min-width:unset}
}

/* ══ ENHANCED ANIMATIONS ══ */

/* reveal variants */
.rv-left{opacity:0;transform:translateX(-36px);transition:opacity .9s ease,transform .9s ease}
.rv-left.vis{opacity:1;transform:none}
.rv-right{opacity:0;transform:translateX(36px);transition:opacity .9s ease,transform .9s ease}
.rv-right.vis{opacity:1;transform:none}
.rv-scale{opacity:0;transform:scale(.92);transition:opacity .9s ease,transform .9s cubic-bezier(.16,1,.3,1)}
.rv-scale.vis{opacity:1;transform:scale(1)}

/* hero eyebrow line grow */
.hero-ey::before{transform-origin:left;animation:lineGrow 1.2s 0.4s cubic-bezier(.16,1,.3,1) both}
.hero-ey::after{transform-origin:right;animation:lineGrow 1.2s 0.6s cubic-bezier(.16,1,.3,1) both}
@keyframes lineGrow{from{transform:scaleX(0);opacity:0}to{transform:scaleX(1);opacity:1}}

/* floating particles on hero */
.hero::after{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:radial-gradient(circle,rgba(200,212,192,.25) 1px,transparent 1px);
  background-size:60px 60px;
  animation:particleDrift 20s linear infinite;
  opacity:.4;
}
@keyframes particleDrift{from{background-position:0 0}to{background-position:60px 60px}}

/* section label line grow */
.sec-lbl::before{transform-origin:right}
.sec-lbl::after{transform-origin:left}
.sec-lbl.vis-lbl::before{animation:lineGrow .8s .2s ease both}
.sec-lbl.vis-lbl::after{animation:lineGrow .8s .4s ease both}

/* stat counter pulse */
.m-stat-n{display:inline-block}
.m-stat.vis-stat .m-stat-n{animation:statPop .6s cubic-bezier(.16,1,.3,1) both}
.m-stat:nth-child(1).vis-stat .m-stat-n{animation-delay:.0s}
.m-stat:nth-child(2).vis-stat .m-stat-n{animation-delay:.1s}
.m-stat:nth-child(3).vis-stat .m-stat-n{animation-delay:.2s}
.m-stat:nth-child(4).vis-stat .m-stat-n{animation-delay:.3s}
@keyframes statPop{from{opacity:0;transform:translateY(20px) scale(.8)}to{opacity:1;transform:none}}

/* process step number shimmer */
.process-step{position:relative;overflow:hidden}
.process-card:hover .process-step::after{
  content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;
  background:linear-gradient(to right,transparent,rgba(184,160,106,.4),transparent);
  animation:shimmer .5s ease forwards;
}
@keyframes shimmer{to{left:150%}}

/* biz card body slide up on hover */
.biz-body{transition:transform .4s cubic-bezier(.16,1,.3,1),background .3s}
.biz-card:hover .biz-body{transform:translateY(-3px)}

/* news item underline */
.news-item{position:relative}
.news-item::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(to right,var(--sage),var(--sage-l));
  transform:scaleX(0);transform-origin:left;
  transition:transform .4s ease;
}
.news-item:hover::after{transform:scaleX(1)}

/* greeting border pulse */
.greeting{position:relative;overflow:hidden}
.greeting::before{
  content:'';position:absolute;top:0;left:0;width:3px;height:0;
  background:linear-gradient(to bottom,var(--sage),var(--sage-l));
  transition:height 1.2s ease;
}
.greeting.vis-gr::before{height:100%}
.greeting{border-left:none}


/* company photo overlay sweep */
.co-photo{position:relative}
.co-r{overflow:hidden}
.co-photo{transition:transform .6s ease}
.co-r:hover .co-photo{transform:scale(1.03)}

/* footer logo float */
.f-logo{animation:float 4s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}

/* btn arrow bounce */
.btn-link:hover::after{animation:arrowBounce .4s ease infinite alternate}
.btn-gold:hover::after{animation:arrowBounce .4s ease infinite alternate}
.btn-brand:hover::after{animation:arrowBounce .4s ease infinite alternate}
@keyframes arrowBounce{from{transform:translateX(0)}to{transform:translateX(6px)}}

/* scroll indicator glow */
.scroll-ind{text-shadow:0 0 12px rgba(200,212,192,.3)}
.scroll-ind::after{animation:bob 2.2s ease-in-out infinite}


/* nav link underline slide */
.nav-links a{position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:1px;background:var(--sage-l);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}
.nav-links a:hover::after{transform:scaleX(1)}