*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --w:#FFFFFF;
  --k:#0A0A0A;
  --g50:#FAFAFA;
  --g200:#E8E8E8;
  --g400:#AAAAAA;
  --g500:#888888;
  --g600:#555555;
  --r:#f43b47;
  --p:#453a94;
  --grad:linear-gradient(135deg,#f43b47 0%,#453a94 100%);
  --grad-v:linear-gradient(to top,#f43b47 0%,#453a94 100%);
  --max:1100px;
  --font-d:'Barlow',sans-serif;
  --font-b:'Noto Sans JP',sans-serif;
  --font-m:'Barlow',sans-serif;
}

html{scroll-behavior:smooth}
body{background:var(--w);color:var(--k);font-family:var(--font-b);font-weight:500;font-size:13px;line-height:1.8;letter-spacing:.1em;overflow-x:hidden;-webkit-font-smoothing:antialiased;font-feature-settings:"palt"}

body::before{content:'';position:fixed;inset:0;z-index:9997;pointer-events:none;opacity:.022;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px 200px}

::-webkit-scrollbar{width:2px}
::-webkit-scrollbar-track{background:var(--w)}
::-webkit-scrollbar-thumb{background:var(--grad)}
::selection{background:#453a94;color:#fff}

/* CURSOR */
.cursor{position:fixed;width:5px;height:5px;border-radius:50%;background:var(--grad);pointer-events:none;z-index:9998;mix-blend-mode:multiply;transform:translate(-50%,-50%);transition:transform .08s}


/* CONTAINER */
.container{max-width:var(--max);margin:0 auto;padding:0 40px}

/* GRAD TEXT */
.gt{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* REVEAL */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .85s cubic-bezier(.16,1,.3,1),transform .85s cubic-bezier(.16,1,.3,1)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* PAGE HERO */
#hero{min-height:100vh;display:flex;align-items:flex-end;border-bottom:1px solid var(--g200);background:var(--g50);position:relative;overflow:hidden}
.hero-bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(232,232,232,.5) 1px,transparent 1px),linear-gradient(90deg,rgba(232,232,232,.5) 1px,transparent 1px);background-size:calc(100%/12) 72px;pointer-events:none}
.hero-inner-wrap{max-width:var(--max);margin:0;padding:0 40px 48px;position:relative;z-index:1}
.page-eyebrow{font-family:var(--font-m);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--g400);margin-bottom:28px;display:flex;align-items:center;gap:14px;opacity:0;animation:fadeUp .9s cubic-bezier(.16,1,.3,1) .4s forwards}
.page-eyebrow::before{content:'';width:14px;height:1px;background:var(--grad);flex-shrink:0}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
.page-title{font-family:var(--font-d);font-size:clamp(40px,7.5vw,96px);line-height:.88;letter-spacing:-.03em;opacity:0;animation:fadeUp .9s cubic-bezier(.16,1,.3,1) .2s forwards}

/* NEWS SECTION */
#news-section{padding:80px 0 120px}

/* FILTER */
.news-filter{display:flex;gap:0;margin-bottom:56px;border-bottom:1px solid var(--g200)}
.filter-btn{font-family:var(--font-m);font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--g400);background:none;border:none;padding:14px 20px;cursor:pointer;transition:color .2s;position:relative}
.filter-btn::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:1.5px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .3s cubic-bezier(.16,1,.3,1)}
.filter-btn:hover{color:var(--k)}
.filter-btn.active{color:var(--k)}
.filter-btn.active::after{transform:scaleX(1)}

/* NEWS GRID */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--g200);border:1px solid var(--g200)}
.news-card{background:var(--w);padding:36px 32px;text-decoration:none;color:var(--k);display:block;transition:background .25s;position:relative;overflow:hidden}
.news-card:hover{background:rgba(244,59,71,.012)}
.news-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1.5px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .5s cubic-bezier(.16,1,.3,1)}
.news-card:hover::before{transform:scaleX(1)}
.news-card.hidden{display:none}
.news-date{font-family:var(--font-m);font-size:9px;letter-spacing:.1em;color:var(--g400);margin-bottom:6px}
.news-cat{font-family:var(--font-m);font-size:8px;letter-spacing:.12em;text-transform:uppercase;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:16px;display:block}
.news-title-text{font-size:13px;font-weight:500;line-height:1.6;margin-bottom:10px}
.news-desc{font-size:12px;color:var(--g600);line-height:1.9}

/* NAV RECRUIT ACCENT */


@media(hover:none){.cursor{display:none}}

@media(max-width:960px){
  #hero{padding:120px 0 64px}
  .news-grid{grid-template-columns:1fr}
  .news-filter{flex-wrap:wrap}
  .container{padding:0 24px}
  .hero-inner-wrap{padding:0 24px 40px}
  #news-section{padding:56px 0 80px}
}
@media(max-width:480px){
  .news-card{padding:28px 20px}
  .hero-inner-wrap{padding:0 16px 32px}
}
