:root{
  --ink:#0B1220; --ink2:#070C16; --blue:#149EFF; --blue-l:#5BBAFF; --orange:#FF9210;
  --t1:#0B1220; --t2:#42506A; --t3:#8A93A8; --line:#E6EAF2; --soft:#F4F6FA; --white:#fff;
  --sans:'Noto Sans JP',sans-serif; --eng:'Inter',sans-serif;
  --rc:18px; --rb:11px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--t1);background:var(--white);line-height:1.75;-webkit-font-smoothing:antialiased;overflow-x:hidden;font-weight:400;
  /* 日本語の改行制御: 行頭禁則（句読点・閉じ括弧を行頭に置かない）。
     英単語の途中切断は避ける（overflow-wrap:anywhere は使わない＝指示）。 */
  line-break:strict;overflow-wrap:normal;word-break:normal}
a{color:inherit;text-decoration:none}

/* ===== 日本語テキストの自然改行（auto-phrase）=====
   見出し・キャッチ・本文を「文節（ぶんせつ）」単位で改行し、文の途中で不自然に
   折り返さないようにする。auto-phrase 対応ブラウザ（Chrome/Edge等）で有効。
   非対応（Safari/Firefox）では無視され、上の line-break:strict の禁則だけが効く＝
   どの環境でも“句読点が行頭に来ない”は最低限担保される。
   ※ ラテン文字主体の要素（.eyebrow/.en/.crumb/.place/.pk 等）には掛けない＝英語に文節改行は不要。 */
.h2,.lead,.hero h1,.hero .htag,.intro .big,.intro .sub,
.page-hero h1,.page-hero .ptag,
.bcard p,.bcard .nm h3,.vc h3,.vc p,.vfoot,
.pcard h3,.pcard p,.phil .pk+h3,
.msg-full .mtxt h3,.msg-full .mtxt p,
.samhead .lead,.samnote,.cf-card figcaption,
.corp dd,.access .addr b,.access .addr span,
.nrow .nt,.ctease .info .lead,.fdesc,
.fcta .lead,.legal p,.legal li,.legal-intro,.creed .cv,.creed .cd{
  word-break:auto-phrase;
}
img{max-width:100%;display:block}
.in{max-width:1200px;margin:0 auto;padding:0 28px;position:relative;z-index:2}
.narrow{max-width:780px}
section{position:relative;overflow:hidden}

/* type helpers */
.eyebrow{font-family:var(--eng);font-size:12.5px;font-weight:600;letter-spacing:3px;text-transform:uppercase;display:inline-flex;align-items:center;gap:13px;color:var(--blue)}
.eyebrow::before{content:'';width:30px;height:1px;background:currentColor;opacity:.5}
.eyebrow.c{justify-content:center}
.h2{font-size:clamp(28px,4vw,46px);font-weight:800;line-height:1.34;letter-spacing:.01em;margin-top:20px}
.lead{font-size:clamp(15px,1.5vw,17px);line-height:2;color:var(--t2);margin-top:22px;font-weight:400}
.dark .h2{color:#fff}.dark .lead{color:rgba(255,255,255,.74)}.dark .eyebrow{color:var(--blue-l)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;background:var(--orange);color:#0B1220;font-weight:700;letter-spacing:.02em;padding:16px 34px;border-radius:var(--rb);font-size:15px;box-shadow:0 10px 30px -10px rgba(255,146,16,.55);transition:transform .3s cubic-bezier(.2,.7,.3,1),box-shadow .3s}
.btn:hover{transform:translateY(-3px);box-shadow:0 18px 44px -10px rgba(255,146,16,.65)}
.btn svg{width:17px;height:17px;transition:transform .3s}
.btn:hover svg{transform:translateX(3px)}
.btn.ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.32);box-shadow:none}
.btn.ghost:hover{border-color:#fff;background:rgba(255,255,255,.07)}
.btn.line{background:transparent;color:var(--blue);border:1.5px solid rgba(20,158,255,.5);box-shadow:none}
.btn.line:hover{background:rgba(20,158,255,.07);border-color:var(--blue)}

/* header */
.hd{position:fixed;top:0;left:0;right:0;z-index:100;padding:22px 0;transition:background .35s,padding .35s,box-shadow .35s}
.hd.solid{background:rgba(255,255,255,.9);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);padding:13px 0;box-shadow:0 1px 0 rgba(11,18,32,.07)}
.hd .in{display:flex;align-items:center;justify-content:space-between}
.brand{position:relative;height:30px;width:83px;flex:0 0 auto}
.brand img{height:30px;width:auto;position:absolute;top:0;left:0;transition:opacity .35s}
.brand .ld{opacity:0}
.hd.solid .brand .lw{opacity:0}
.hd.solid .brand .ld{opacity:1}
.nav{display:flex;align-items:center;gap:34px}
.nav a.lk{font-size:14.5px;font-weight:500;color:rgba(255,255,255,.85);transition:color .25s;position:relative}
.nav a.lk::after{content:'';position:absolute;left:0;bottom:-6px;width:0;height:1.5px;background:var(--orange);transition:width .3s}
.nav a.lk:hover::after{width:100%}
.hd.solid .nav a.lk{color:var(--t2)}
.hd.solid .nav a.lk:hover{color:var(--t1)}
.nav .btn{padding:11px 24px;font-size:13.5px}
.menu-btn{display:none;background:none;border:0;color:#fff;cursor:pointer;padding:4px}
.hd.solid .menu-btn{color:var(--t1)}

/* hero */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;background:var(--ink);padding:120px 0 100px}
.hero-bg{position:absolute;inset:0;overflow:hidden;z-index:0}
.hero-bg img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;animation:heroCycle 21s infinite}
.hero-bg img:nth-child(1){animation-delay:0s}
.hero-bg img:nth-child(2){animation-delay:7s}
.hero-bg img:nth-child(3){animation-delay:14s}
.hero::after{content:'';position:absolute;inset:0;z-index:1;background:
  linear-gradient(105deg,rgba(7,12,22,.92) 0%,rgba(7,12,22,.62) 46%,rgba(7,12,22,.28) 100%),
  radial-gradient(60% 80% at 88% 18%,rgba(20,158,255,.22) 0%,transparent 62%)}
@keyframes heroCycle{0%{opacity:0;transform:scale(1.05)}3%{opacity:.5}30%{opacity:.5}36%{opacity:0;transform:scale(1.14)}100%{opacity:0;transform:scale(1.14)}}
.hero .in{position:relative;z-index:2}
.hero .eyebrow{color:var(--blue-l)}
.hero h1{font-size:clamp(40px,7.4vw,88px);font-weight:900;line-height:1.16;color:#fff;letter-spacing:.005em;margin-top:24px}
.hero h1 .pin{position:relative;display:inline-block;margin-right:.55em}
.hero h1 .pin::after{content:'';position:absolute;right:-.44em;bottom:.1em;width:.42em;height:.42em;border-radius:50%;background:var(--orange);box-shadow:0 6px 20px rgba(255,146,16,.55)}
.hero .htag{color:rgba(255,255,255,.8);max-width:30em;font-size:clamp(15px,1.7vw,19px);margin-top:28px;line-height:1.9}
.hero .cta{display:flex;gap:16px;margin-top:42px;flex-wrap:wrap}
.hero .place{margin-top:34px;font-family:var(--eng);font-size:12px;letter-spacing:1.5px;color:rgba(255,255,255,.5);text-transform:uppercase}
.scrollcue{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;color:rgba(255,255,255,.45);font-family:var(--eng);font-size:10.5px;letter-spacing:2px;text-align:center}
.scrollcue .ln{display:block;width:1px;height:42px;background:linear-gradient(rgba(255,255,255,.5),transparent);margin:9px auto 0;transform-origin:top;animation:drop 1.9s ease-in-out infinite}
@keyframes drop{0%,100%{opacity:.3;transform:scaleY(.55)}50%{opacity:1;transform:scaleY(1)}}

/* trust */
.trust{background:var(--ink);padding:8px 0 92px}
.trust .cap{text-align:center;font-size:11.5px;letter-spacing:2px;color:rgba(255,255,255,.4);font-family:var(--eng);font-weight:600;text-transform:uppercase}
.tk{margin-top:30px;overflow:hidden;position:relative;-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 7%,#000 93%,transparent 100%);mask-image:linear-gradient(90deg,transparent 0,#000 7%,#000 93%,transparent 100%)}
.tk-track{display:flex;width:max-content;animation:tk-scroll 40s linear infinite}
.tk:hover .tk-track,.tk:focus-within .tk-track{animation-play-state:paused}
.tk-set{display:flex;align-items:center;margin:0;padding:0;list-style:none;flex:0 0 auto}
.tk-item{position:relative;white-space:nowrap;padding:0 32px;font-size:13.5px;font-weight:500;letter-spacing:.02em;color:rgba(255,255,255,.7)}
.tk-item::after{content:"";position:absolute;right:0;top:50%;width:4px;height:4px;margin-top:-2px;border-radius:50%;background:rgba(20,158,255,.55)}
@keyframes tk-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){
  .tk{-webkit-mask-image:none;mask-image:none}
  .tk-track{animation:none;flex-wrap:wrap;justify-content:center;width:auto;max-width:920px;margin:0 auto}
  .tk-set{flex-wrap:wrap;justify-content:center}
  .tk-set[aria-hidden="true"]{display:none}
  .tk-item{padding:7px 16px;font-size:13px}
  .tk-item::after{display:none}
}

/* section rhythm */
.pad{padding:clamp(88px,12vw,150px) 0}
.dark{background:var(--ink);color:#fff}
.soft{background:var(--soft)}

/* intro / philosophy */
.intro{text-align:center}
.intro .big{font-size:clamp(26px,4.6vw,52px);font-weight:800;line-height:1.5;letter-spacing:.01em;max-width:16em;margin:22px auto 0}
.intro .big .o{color:var(--orange)}
.intro .sub{font-size:clamp(14px,1.5vw,16.5px);color:var(--t2);margin-top:30px;max-width:34em;margin-left:auto;margin-right:auto;line-height:2.05}
.creed{display:flex;justify-content:center;gap:0;flex-wrap:wrap;margin-top:54px}
.creed .cx{padding:0 clamp(20px,4vw,44px);position:relative}
.creed .cx+.cx::before{content:'';position:absolute;left:0;top:14%;height:72%;width:1px;background:var(--line)}
.creed .cw{font-family:var(--eng);font-size:11px;font-weight:700;letter-spacing:1.5px;color:var(--blue);text-transform:uppercase}
.creed .cv{font-size:clamp(17px,2vw,21px);font-weight:800;margin-top:8px}
.creed .cd{font-size:12.5px;color:var(--t3);margin-top:4px}

/* business grid */
.bizhead{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px}
.biz-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,2.6vw,32px);margin-top:54px}
.bcard{position:relative;border-radius:var(--rc);overflow:hidden;background:#fff;border:1px solid var(--line);transition:transform .45s cubic-bezier(.2,.7,.3,1),box-shadow .45s;display:flex;flex-direction:column}
.bcard:hover{transform:translateY(-6px);box-shadow:0 28px 60px -24px rgba(11,18,32,.28)}
.bcard .thumb{position:relative;aspect-ratio:16/9;overflow:hidden}
.bcard .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.2,.7,.3,1)}
.bcard:hover .thumb img{transform:scale(1.07)}
.bcard .thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(7,12,22,.4),transparent 52%)}
.bcard .status{position:absolute;top:15px;left:15px;z-index:2;font-size:11.5px;font-weight:700;letter-spacing:.04em;padding:6px 13px;border-radius:999px;background:rgba(255,255,255,.92);color:var(--ink);backdrop-filter:blur(6px)}
.bcard .status.hot{background:var(--orange);color:#0B1220}
.bcard .body{padding:26px 28px 28px;flex:1;display:flex;flex-direction:column}
.bcard .nm{display:flex;align-items:baseline;gap:10px}
.bcard .nm h3{font-size:21px;font-weight:800;letter-spacing:.01em}
.bcard .nm .en{font-family:var(--eng);font-size:11px;font-weight:600;letter-spacing:1px;color:var(--t3);text-transform:uppercase}
.bcard p{font-size:14px;color:var(--t2);margin-top:11px;line-height:1.8;flex:1}
.bcard .go{display:inline-flex;align-items:center;gap:8px;margin-top:20px;font-size:13.5px;font-weight:700;color:var(--blue)}
.bcard .go svg{width:15px;height:15px;transition:transform .3s}
.bcard:hover .go svg{transform:translateX(4px)}

/* samples */
.samhead{text-align:center}
.samnote{font-size:12.5px;color:var(--t3);margin-top:12px}
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2vw,22px);margin-top:48px}
.gcard{position:relative;border-radius:var(--rc);overflow:hidden;border:1px solid var(--line);aspect-ratio:4/3}
.gcard img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.3,1)}
.gcard:hover img{transform:scale(1.06)}
.gcard .cap{position:absolute;left:0;right:0;bottom:0;padding:30px 18px 15px;background:linear-gradient(to top,rgba(7,12,22,.78),transparent);color:#fff;font-size:14px;font-weight:700;letter-spacing:.02em}
.gcard .cap span{display:block;font-size:11px;font-weight:500;color:rgba(255,255,255,.7);font-family:var(--eng);letter-spacing:.5px;margin-top:1px}

/* samples: 3D遠近カルーセル（coverflow）— 実際の完成見本HPの縦長スクショが循環。
   中央=手前で大きく、左右に離れるほど奥へ小さく薄く見切れる。横幅いっぱいは使わずダイナミックに。 */
#samples{overflow:hidden}
.cflow{margin-top:54px;position:relative}
.cflow-stage{position:relative;height:clamp(420px,56vw,560px);perspective:1700px;transform-style:preserve-3d}
.cf-card{position:absolute;left:50%;top:50%;width:clamp(186px,20vw,250px);
  margin:0;border-radius:16px;overflow:hidden;background:#0e1726;
  border:1px solid var(--line);box-shadow:0 30px 70px -28px rgba(7,12,22,.55);
  transform:translate(-50%,-50%);
  transition:transform .7s cubic-bezier(.22,.7,.27,1),opacity .7s cubic-bezier(.22,.7,.27,1),box-shadow .5s;
  will-change:transform,opacity;cursor:pointer;backface-visibility:hidden}
.cf-card img{width:100%;height:clamp(420px,56vw,560px);object-fit:cover;object-position:top center;display:block}
/* 縦長スクショの“下に続く”余韻＝下端をやわらかくフェード */
.cf-card::after{content:'';position:absolute;left:0;right:0;bottom:0;height:42%;
  background:linear-gradient(to top,rgba(8,13,22,.92),rgba(8,13,22,.55) 38%,transparent);pointer-events:none}
.cf-card figcaption{position:absolute;left:0;right:0;bottom:0;z-index:2;
  padding:18px 18px 16px;color:#fff;font-size:15px;font-weight:700;letter-spacing:.02em}
.cf-card figcaption span{display:block;font-family:var(--eng);font-size:10.5px;font-weight:500;
  letter-spacing:.6px;color:rgba(255,255,255,.62);margin-top:2px}
.cf-card.is-active{box-shadow:0 44px 90px -30px rgba(7,12,22,.7),0 0 0 1px rgba(20,158,255,.28)}
/* 操作部（前後ボタン＋ドット） */
.cflow-ctrl{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:34px}
.cf-nav{width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:#fff;
  color:var(--t1);display:flex;align-items:center;justify-content:center;cursor:pointer;
  transition:.25s;box-shadow:0 8px 22px -12px rgba(11,18,32,.3)}
.cf-nav:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px)}
.cf-nav svg{width:20px;height:20px}
.cf-dots{display:flex;gap:9px;align-items:center}
.cf-dot{width:8px;height:8px;border-radius:50%;border:0;padding:0;cursor:pointer;
  background:var(--line);transition:.3s}
.cf-dot.is-on{background:var(--orange);width:24px;border-radius:5px}
@media(max-width:760px){
  .cf-card{width:clamp(168px,58vw,220px)}
  .cflow-stage{perspective:1200px}
}
/* prefers-reduced-motion: 3D回転をやめ、静的な横スクロール一覧に切替（自動再生なし） */
@media(prefers-reduced-motion:reduce){
  #samples .cflow .cf-card{transition:none}
}
.cflow.cf-static .cflow-stage{height:auto;perspective:none;display:flex;gap:16px;
  overflow-x:auto;-webkit-overflow-scrolling:touch;padding:4px 0 12px;scroll-snap-type:x proximity}
.cflow.cf-static .cf-card{position:static;transform:none;opacity:1;left:auto;top:auto;
  flex:0 0 auto;width:clamp(190px,62vw,250px);scroll-snap-align:center;box-shadow:0 20px 50px -26px rgba(7,12,22,.5)}
.cflow.cf-static .cf-card:first-child{margin-left:max(28px,calc((100vw - 1200px)/2 + 28px))}
.cflow.cf-static .cf-card:last-child{margin-right:28px}
.cflow.cf-static .cflow-ctrl{display:none}

/* values dark */
.vgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,26px);margin-top:56px}
.vc{position:relative;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.1);border-radius:var(--rc);padding:38px 32px;transition:.4s;overflow:hidden}
.vc:hover{background:rgba(255,255,255,.06);border-color:rgba(91,186,255,.4);transform:translateY(-5px)}
.vc .vn{font-family:var(--eng);font-size:13px;font-weight:700;color:var(--orange);letter-spacing:1px}
.vc h3{font-size:27px;font-weight:900;color:#fff;margin-top:16px;letter-spacing:.04em}
.vc p{font-size:14px;color:rgba(255,255,255,.66);margin-top:14px;line-height:1.95}
.vfoot{text-align:center;margin-top:40px;font-size:14.5px;color:rgba(255,255,255,.62);letter-spacing:.02em}
.vfoot b{color:#fff;font-weight:700}

/* company + message */
.cols{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,5vw,72px);align-items:start;margin-top:56px}
.corp dl{border-top:1px solid var(--line)}
.corp .row{display:grid;grid-template-columns:128px 1fr;gap:18px;padding:19px 4px;border-bottom:1px solid var(--line)}
.corp dt{font-size:13px;font-weight:700;color:var(--t3);letter-spacing:.02em}
.corp dd{font-size:14.5px;color:var(--t1);line-height:1.7}
.corp dd .todo{color:var(--orange);font-size:12.5px;font-weight:600}
.msg{background:var(--soft);border-radius:var(--rc);overflow:hidden;border:1px solid var(--line)}
.msg .photo{aspect-ratio:7/5;background:linear-gradient(135deg,#e8edf5,#d6deec);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--t3);position:relative}
.msg .photo svg{width:48px;height:48px;opacity:.5}
.msg .photo .pn{font-size:12px;letter-spacing:.04em;color:var(--t3);background:rgba(255,255,255,.75);padding:5px 13px;border-radius:999px}
.msg .mb{padding:28px 32px 32px}
.msg .mb .role{font-size:12.5px;color:var(--t3);font-family:var(--eng);letter-spacing:.04em}
.msg .mb .who{font-size:19px;font-weight:800;margin-top:4px}
.msg .mb .pend{font-size:13.5px;color:var(--t2);margin-top:16px;line-height:1.9;padding:14px 16px;background:#fff;border:1px dashed var(--line);border-radius:10px}

/* final cta */
.fcta{background:radial-gradient(56% 70% at 50% 32%,rgba(20,158,255,.22) 0,transparent 64%),var(--ink2);text-align:center;padding:clamp(96px,13vw,150px) 0}
.fcta .h2{color:#fff}
.fcta .lead{color:rgba(255,255,255,.78);max-width:30em;margin:22px auto 0}
.fcta .ctc{display:flex;gap:30px;justify-content:center;flex-wrap:wrap;margin-top:30px;font-size:14.5px;color:rgba(255,255,255,.86)}
.fcta .ctc a{display:inline-flex;align-items:center;gap:9px;font-weight:600}
.fcta .ctc svg{width:16px;height:16px;color:var(--blue-l)}
.fcta .btn{margin-top:40px}

/* footer */
.ft{background:#060912;color:rgba(255,255,255,.6);padding:72px 0 32px}
.ft-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.1)}
.ft .brand{height:26px;width:72px;margin-bottom:18px}
.ft .brand img{height:26px}
.ft .fdesc{font-size:12.5px;line-height:1.9;color:rgba(255,255,255,.46);max-width:265px}
.ft h5{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.4);font-family:var(--eng);font-weight:600;margin-bottom:16px}
.ft ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.ft ul a{font-size:13px;color:rgba(255,255,255,.62);transition:.2s}
.ft ul a:hover{color:#fff}
.ft-bot{padding-top:26px;display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;font-size:11.5px;color:rgba(255,255,255,.4);font-family:var(--eng);letter-spacing:.04em}

/* reveal */
html.js .reveal{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.2,.7,.3,1),transform .8s cubic-bezier(.2,.7,.3,1)}
html.js .reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}

/* mobile menu */
.drawer{position:fixed;inset:0;z-index:200;background:rgba(7,12,22,.97);backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;opacity:0;pointer-events:none;transition:opacity .3s}
.drawer.open{opacity:1;pointer-events:auto}
.drawer a{color:#fff;font-size:21px;font-weight:700;padding:14px}
.drawer .x{position:absolute;top:26px;right:26px;background:none;border:0;color:#fff;cursor:pointer}

/* responsive */
@media(max-width:920px){
  .biz-grid{grid-template-columns:1fr}
  .cols{grid-template-columns:1fr;gap:44px}
  .creed{gap:8px}
}
@media(max-width:760px){
  .nav .lk{display:none}.nav .btn{display:none}.menu-btn{display:block}
  .gal{grid-template-columns:1fr;max-width:420px;margin-left:auto;margin-right:auto}
  .vgrid{grid-template-columns:1fr}
  .ft-top{grid-template-columns:1fr 1fr;gap:30px}
  .creed .cx{padding:14px 22px}
  .creed .cx+.cx::before{display:none}
  .hero{min-height:92vh}
}
@media(prefers-reduced-motion:reduce){
  html.js .reveal{opacity:1;transform:none;transition:none}
  .hero-bg img{animation:none;transform:none;opacity:0}
  .hero-bg img:first-child{opacity:.5}
  .scrollcue .ln{animation:none}
  html{scroll-behavior:auto}
}

/* ===== sub pages (company / news) ===== */
.page-hero{position:relative;background:var(--ink);padding:168px 0 76px;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(60% 90% at 82% 8%,rgba(20,158,255,.2),transparent 60%)}
.page-hero .in{position:relative;z-index:2}
.page-hero .crumb{font-family:var(--eng);font-size:12px;letter-spacing:.06em;color:rgba(255,255,255,.5);text-transform:uppercase}
.page-hero .crumb a{color:rgba(255,255,255,.5)}
.page-hero .crumb a:hover{color:#fff}
.page-hero h1{font-size:clamp(32px,5vw,58px);font-weight:900;color:#fff;margin-top:20px;letter-spacing:.01em}
.page-hero h1 .o{color:var(--orange)}
.page-hero .ptag{color:rgba(255,255,255,.72);margin-top:20px;font-size:clamp(14px,1.6vw,17px);max-width:36em;line-height:1.9}

/* news list */
.nlist{max-width:880px;margin:0 auto}
.nrow{display:grid;grid-template-columns:130px 1fr auto;gap:24px;align-items:center;padding:26px 10px;border-bottom:1px solid var(--line);transition:.25s}
.nrow:hover{background:var(--soft);padding-left:18px;padding-right:18px;border-radius:12px}
.nrow .nd{font-family:var(--eng);font-size:13px;color:var(--t3);letter-spacing:.02em}
.nrow .nt{font-size:15.5px;font-weight:500;line-height:1.7}
.nrow .ng{font-size:11px;font-weight:700;color:var(--blue);border:1px solid rgba(20,158,255,.3);padding:4px 12px;border-radius:999px;white-space:nowrap}
.nrow.up .nt{color:var(--t3)}
.nrow.up .ng{color:var(--t3);border-color:var(--line)}
@media(max-width:680px){.nrow{grid-template-columns:1fr;gap:7px}.nrow .ng{justify-self:start}}

/* home teasers */
.ntease{margin-top:44px;max-width:840px;margin-left:auto;margin-right:auto}
.ntease .nrow{grid-template-columns:120px 1fr auto}

/* message (company page) */
.msg-full{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(30px,4vw,60px);align-items:center;margin-top:52px}
.msg-full .photo{position:relative;aspect-ratio:4/5;background:linear-gradient(140deg,#e8edf5,#d3dcea);border-radius:var(--rc);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:var(--t3);border:1px solid var(--line);overflow:hidden}
.msg-full .photo svg{width:56px;height:56px;opacity:.5}
.msg-full .photo .pn{font-size:12.5px;background:rgba(255,255,255,.82);padding:6px 15px;border-radius:999px}
.msg-full .photo.has-img{background:#0B1220}
.msg-full .photo.has-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 20%}
.msg-full .photo.has-img .pn{position:absolute;left:14px;bottom:14px;z-index:2;font-size:11px;color:rgba(255,255,255,.9);background:rgba(11,18,32,.55);backdrop-filter:blur(4px)}
.msg-full .mtxt .role{font-family:var(--eng);font-size:12px;letter-spacing:.06em;color:var(--t3);text-transform:uppercase}
.msg-full .mtxt h3{font-size:clamp(20px,2.4vw,27px);font-weight:800;margin:7px 0 20px;line-height:1.5}
.msg-full .mtxt h3 .o{color:var(--orange)}
.msg-full .mtxt p{font-size:14.5px;color:var(--t2);line-height:2.05;margin-bottom:15px}
.msg-full .mtxt .pend{font-size:14px;color:var(--t2);line-height:1.95;padding:18px 20px;background:var(--soft);border:1px dashed var(--line);border-radius:12px}
.msg-full .mtxt .sign{margin-top:22px;font-size:15px;font-weight:700}
@media(max-width:820px){.msg-full{grid-template-columns:1fr;gap:26px}.msg-full .photo{aspect-ratio:7/5;max-width:440px}.msg-full .photo.has-img img{object-position:center 22%}}

/* philosophy detail cards */
.phil{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(18px,2.6vw,28px);margin-top:50px}
.pcard{background:#fff;border:1px solid var(--line);border-radius:var(--rc);padding:36px 34px;transition:.4s}
.pcard:hover{transform:translateY(-5px);box-shadow:0 22px 54px -22px rgba(11,18,32,.16);border-color:rgba(20,158,255,.35)}
.pcard .pk{font-family:var(--eng);font-size:11px;font-weight:700;letter-spacing:1.5px;color:var(--blue);text-transform:uppercase}
.pcard h3{font-size:23px;font-weight:800;margin:12px 0 14px}
.pcard p{font-size:14.5px;color:var(--t2);line-height:1.95}
@media(max-width:680px){.phil{grid-template-columns:1fr}}

/* access band */
.access{margin-top:48px;border-radius:var(--rc);overflow:hidden;border:1px solid var(--line);position:relative}
.access img{width:100%;height:auto;display:block;aspect-ratio:16/6;object-fit:cover}
.access .addr{padding:24px 28px;background:#fff;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;align-items:center}
.access .addr b{font-size:15px;font-weight:700}
.access .addr span{font-size:13.5px;color:var(--t2)}
@media(max-width:680px){.access img{aspect-ratio:4/3}}

/* home company teaser */
.ctease{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,4vw,56px);align-items:center;margin-top:8px}
.ctease .ph{border-radius:var(--rc);overflow:hidden;aspect-ratio:4/3;border:1px solid var(--line)}
.ctease .ph img{width:100%;height:100%;object-fit:cover;transition:transform .9s}
.ctease:hover .ph img{transform:scale(1.05)}
.ctease .info .mini{display:grid;grid-template-columns:auto 1fr;gap:10px 20px;margin:22px 0 26px}
.ctease .info .mini dt{font-size:12.5px;font-weight:700;color:var(--t3)}
.ctease .info .mini dd{font-size:14px}
@media(max-width:820px){.ctease{grid-template-columns:1fr;gap:26px}}

/* rich: card icons (values & philosophy) */
.vc .vbg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;opacity:.08;pointer-events:none;transition:opacity .4s}
.vc:hover .vbg{opacity:.13}
.vc>.vic,.vc>.vn,.vc>h3,.vc>p{position:relative;z-index:1}
.vc .vic{width:54px;height:54px;display:flex;align-items:center;justify-content:center;color:var(--blue-l);background:rgba(91,186,255,.1);border:1px solid rgba(91,186,255,.22);border-radius:15px;margin-bottom:20px;transition:.4s}
.vc:hover .vic{background:rgba(91,186,255,.18);transform:translateY(-3px)}
.vc .vic svg{width:27px;height:27px}
.pcard{position:relative;overflow:hidden}
.pcard .pbg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;opacity:.07;pointer-events:none;transition:opacity .4s}
.pcard:hover .pbg{opacity:.12}
.pcard .pk,.pcard>h3,.pcard>p{position:relative;z-index:1}
.pcard .pic{position:absolute;right:26px;top:34px;z-index:1;width:48px;height:48px;display:flex;align-items:center;justify-content:center;color:var(--blue);background:rgba(20,158,255,.08);border:1px solid rgba(20,158,255,.16);border-radius:13px;transition:.4s}
.pcard:hover .pic{background:rgba(20,158,255,.16);transform:rotate(-6deg)}
.pcard .pic svg{width:24px;height:24px}
.pcard h3{padding-right:64px}

/* ===== legal pages (privacy / terms) ===== */
.legal{font-size:15px;line-height:1.95;color:var(--t1)}
.legal .legal-intro{color:var(--t2);font-size:14.5px;line-height:2.05;margin-bottom:18px}
.legal h2{font-size:clamp(17px,2.1vw,20px);font-weight:800;color:var(--t1);margin:46px 0 14px;padding-top:24px;border-top:1px solid var(--line);letter-spacing:.01em}
.legal h2:first-of-type{margin-top:8px}
.legal p{color:var(--t2);font-size:14.5px;line-height:2;margin:0 0 4px}
.legal a{color:var(--blue);font-weight:500;border-bottom:1px solid rgba(20,158,255,.3);transition:.2s}
.legal a:hover{border-color:var(--blue)}
.legal a.btn,.legal a.btn:hover{border-bottom:0}
.legal ol.legal-ol{counter-reset:item;list-style:none;margin:8px 0 4px;padding:0}
.legal ol.legal-ol>li{position:relative;padding-left:34px;margin-bottom:13px;color:var(--t2);font-size:14.5px;line-height:2;counter-increment:item}
.legal ol.legal-ol>li::before{content:counter(item)".";position:absolute;left:0;top:0;font-weight:700;color:var(--blue);font-family:var(--eng);font-size:14px}
.legal ol.legal-sub{counter-reset:sub;list-style:none;margin:10px 0 6px;padding:0}
.legal ol.legal-sub>li{position:relative;padding-left:32px;margin-bottom:9px;color:var(--t2);font-size:14px;line-height:1.9;counter-increment:sub}
.legal ol.legal-sub>li::before{content:"("counter(sub)")";position:absolute;left:0;top:0;color:var(--t3);font-family:var(--eng);font-size:13px;font-weight:600}
.legal ul.legal-ul{list-style:none;margin:10px 0 6px;padding:0}
.legal ul.legal-ul>li{position:relative;padding-left:22px;margin-bottom:7px;color:var(--t2);font-size:14px;line-height:1.85}
.legal ul.legal-ul>li::before{content:"";position:absolute;left:2px;top:.85em;width:6px;height:6px;border-radius:50%;background:var(--blue);opacity:.55}
.legal-box{background:var(--soft);border:1px solid var(--line);border-radius:var(--rc);padding:24px 28px;margin:18px 0 6px}
.legal-box p{color:var(--t1);font-size:14.5px;line-height:1.95;margin:0}
.legal-meta{margin-top:52px;padding-top:26px;border-top:1px solid var(--line)}
.legal-meta p{color:var(--t3);font-size:13.5px;line-height:1.9;font-family:var(--eng);letter-spacing:.01em}
.legal-back{margin-top:48px;text-align:center}
@media(max-width:680px){
  .legal ol.legal-ol>li{padding-left:28px}
  .legal-box{padding:20px 20px}
}
