/* ============================================================
   Tサクセス株式会社 — 採用 / コーポレートサイト
   白ベース + 青アクセント。構成・写真配置・アニメは
   freuden-recruit.com の組み方をサンプリング。
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@200;300;400;500;600;700&family=Zen+Kaku+Gothic+New:wght@400;500;700;900&display=swap');

:root{
  --blue:        #1763c4;   /* primary */
  --blue-deep:   #0e3f86;
  --blue-bright: #2d83e6;
  --blue-soft:   #eaf2fc;   /* tint bg */
  --blue-mist:   #f4f8fd;
  --ink:         #16202c;
  --ink-soft:    #3a4655;
  --muted:       #6b7686;
  --line:        #e4e9f0;
  --white:       #ffffff;
  --paper:       #f7f9fc;

  --maxw: 1180px;
  --gut: clamp(20px, 5vw, 64px);

  --jp: "Zen Kaku Gothic New", system-ui, sans-serif;
  --en: "Outfit", var(--jp);

  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--jp);
  color:var(--ink);
  background:var(--white);
  line-height:1.85;
  -webkit-font-smoothing:antialiased;
  letter-spacing:.02em;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

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

/* ---------- section label pattern ---------- */
.eyebrow{
  font-family:var(--en);
  font-weight:300;
  font-size:clamp(46px, 7vw, 88px);
  line-height:1;
  letter-spacing:.04em;
  color:var(--blue);
  display:block;
}
.eyebrow .dot{ color:var(--blue-bright); }
.sublabel{
  display:inline-flex; align-items:center; gap:10px;
  font-size:13px; font-weight:700; letter-spacing:.18em;
  color:var(--muted); margin-top:14px;
}
.sublabel::before{
  content:""; width:30px; height:1px; background:var(--blue);
}
.section{ padding-block:clamp(72px,11vw,140px); }

/* ============================================================
   HEADER
   ============================================================ */
.header{
  position:fixed; inset:0 0 auto 0; z-index:60;
  height:74px; display:flex; align-items:center;
  background:rgba(255,255,255,0);
  transition:background .4s var(--ease), box-shadow .4s var(--ease), height .4s var(--ease);
}
.header.scrolled{
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(10px);
  box-shadow:0 6px 30px -18px rgba(14,63,134,.5);
  height:64px;
}
.header .wrap{ display:flex; align-items:center; gap:24px; width:100%; }
.brand{ display:flex; align-items:center; gap:11px; margin-right:auto; }
.brand .mark{
  width:42px; height:42px; border-radius:11px;
  background:#fff;
  display:grid; place-items:center; overflow:hidden; flex:0 0 auto;
  box-shadow:0 6px 18px -6px rgba(14,63,134,.5);
}
.brand .mark img{ width:100%; height:100%; object-fit:contain; padding:3px; }
.brand .name{ font-weight:700; font-size:17px; letter-spacing:.04em; white-space:nowrap; }
.brand .name span{ color:var(--blue); }
/* on transparent hero header, brand text is white */
.header:not(.scrolled) .brand .name{ color:#fff; text-shadow:0 1px 14px rgba(0,0,0,.35); }
.header:not(.scrolled) .nav a{ color:#fff; text-shadow:0 1px 12px rgba(0,0,0,.4); }
.header:not(.scrolled) .tel{ color:#fff; }
.header:not(.scrolled) .tel small{ color:rgba(255,255,255,.8); }

.nav{ display:flex; gap:22px; font-size:13.5px; font-weight:500; }
.nav a{ position:relative; padding-block:6px; white-space:nowrap; transition:color .25s; }
.nav a::after{
  content:""; position:absolute; left:0; right:100%; bottom:0; height:2px;
  background:var(--blue); transition:right .3s var(--ease);
}
.nav a:hover{ color:var(--blue); }
.nav a:hover::after{ right:0; }

.tel{ display:flex; flex-direction:column; line-height:1.2; font-family:var(--en);
  font-weight:600; font-size:19px; color:var(--ink); white-space:nowrap; }
.tel small{ font-size:10px; letter-spacing:.12em; font-weight:500; color:var(--muted); font-family:var(--jp); white-space:nowrap; }

.btn{
  display:inline-flex; align-items:center; gap:9px;
  font-weight:700; font-size:14px; letter-spacing:.04em;
  padding:13px 24px; border-radius:999px; cursor:pointer; border:0;
  background:var(--blue); color:#fff; white-space:nowrap;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s;
  box-shadow:0 12px 26px -12px rgba(23,99,196,.85);
}
.btn:hover{ transform:translateY(-2px); background:var(--blue-deep); box-shadow:0 18px 34px -12px rgba(14,63,134,.9); }
.btn .arr{ transition:transform .25s var(--ease); }
.btn:hover .arr{ transform:translateX(4px); }
.btn.ghost{ background:#fff; color:var(--blue); box-shadow:inset 0 0 0 1.5px var(--blue); }
.btn.ghost:hover{ background:var(--blue-soft); }
.btn.lg{ padding:18px 38px; font-size:16px; }
.btn-short{ display:none; }

/* hamburger toggle */
.navtoggle{
  display:none; flex:0 0 auto; width:46px; height:46px; padding:0; border:0;
  background:transparent; cursor:pointer; border-radius:12px;
  flex-direction:column; align-items:center; justify-content:center; gap:5px;
}
.navtoggle span{ display:block; width:24px; height:2px; border-radius:2px; background:var(--ink); transition:background .3s; }
.header:not(.scrolled) .navtoggle span{ background:#fff; }

/* mobile menu — 目次 overlay */
body.menu-open{ overflow:hidden; }
.menu{
  position:fixed; inset:0; z-index:80; visibility:hidden; opacity:0;
  color:#fff; overflow-y:auto; -webkit-overflow-scrolling:touch;
  background:linear-gradient(165deg,#0e3f86 0%,#08203f 58%,#061327 100%);
  transition:opacity .4s var(--ease), visibility .4s var(--ease);
}
.menu.open{ visibility:visible; opacity:1; }
.menu-inner{ min-height:100%; max-width:var(--maxw); margin-inline:auto;
  padding:0 var(--gut) clamp(32px,7vw,56px); display:flex; flex-direction:column; }
.menu-top{ display:flex; align-items:center; justify-content:space-between; height:74px; }
.menu-top .logo{ display:flex; align-items:center; gap:10px; font-weight:700; font-size:16px; letter-spacing:.03em; }
.menu-top .logo img{ width:38px; height:38px; border-radius:10px; background:#fff; padding:3px; object-fit:contain; }
.menu-close{ position:relative; width:46px; height:46px; border:0; border-radius:12px;
  background:rgba(255,255,255,.1); cursor:pointer; transition:background .25s; }
.menu-close:hover{ background:rgba(255,255,255,.2); }
.menu-close::before, .menu-close::after{ content:""; position:absolute; left:50%; top:50%;
  width:19px; height:2px; background:#fff; border-radius:2px; }
.menu-close::before{ transform:translate(-50%,-50%) rotate(45deg); }
.menu-close::after{ transform:translate(-50%,-50%) rotate(-45deg); }
.menu-label{ font-family:var(--en); font-size:12px; letter-spacing:.34em;
  color:rgba(255,255,255,.5); margin:clamp(18px,5vw,40px) 0 4px; }
.menu-nav{ display:flex; flex-direction:column; }
.menu-nav a{ display:flex; align-items:baseline; gap:16px; padding:clamp(15px,3.4vw,20px) 0;
  border-bottom:1px solid rgba(255,255,255,.12); opacity:0; transform:translateY(14px); }
.menu.open .menu-nav a{ animation:menuIn .55s var(--ease) forwards; }
.menu-nav a .i{ font-family:var(--en); font-size:13px; font-weight:600; color:var(--blue-bright); }
.menu-nav a b{ font-size:clamp(20px,5.4vw,29px); font-weight:800; letter-spacing:.03em; transition:color .2s; }
.menu-nav a small{ margin-left:auto; font-family:var(--en); font-size:12px; font-weight:500;
  letter-spacing:.18em; color:rgba(255,255,255,.42); }
.menu-nav a:hover b, .menu-nav a:active b{ color:var(--blue-bright); }
@keyframes menuIn{ to{ opacity:1; transform:none; } }
.menu.open .menu-nav a:nth-child(1){ animation-delay:.05s; }
.menu.open .menu-nav a:nth-child(2){ animation-delay:.10s; }
.menu.open .menu-nav a:nth-child(3){ animation-delay:.15s; }
.menu.open .menu-nav a:nth-child(4){ animation-delay:.20s; }
.menu.open .menu-nav a:nth-child(5){ animation-delay:.25s; }
.menu.open .menu-nav a:nth-child(6){ animation-delay:.30s; }
.menu-foot{ margin-top:auto; padding-top:clamp(28px,6vw,44px); display:flex; flex-direction:column; gap:18px; }
.menu-tel{ display:flex; flex-direction:column; font-family:var(--en); font-weight:700; font-size:27px; letter-spacing:.02em; }
.menu-tel small{ font-family:var(--jp); font-size:12px; font-weight:500; letter-spacing:.08em; color:rgba(255,255,255,.6); margin-top:2px; }
.menu-foot .btn{ width:100%; justify-content:center; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end;
  color:#fff; overflow:hidden; isolation:isolate; }
.hero-bg{ position:absolute; inset:0; z-index:-2; overflow:hidden; background:#0b2342; }
.hero-bg img, .hero-bg video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.hero-bg .hero-vid{ opacity:0; transition:opacity 1.4s var(--ease); }
.hero-bg .hero-vid.ready{ opacity:1; }
.hero-bg::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(95deg, rgba(6,22,48,.9) 0%, rgba(6,22,48,.62) 40%, rgba(6,22,48,.22) 70%, rgba(6,22,48,.08) 100%),
    linear-gradient(0deg, rgba(6,22,48,.82) 0%, rgba(6,22,48,.1) 40%, rgba(6,22,48,0) 60%),
    radial-gradient(120% 80% at 18% 78%, rgba(6,22,48,.5), transparent 60%);
}
.hero .vline{
  position:absolute; left:clamp(14px,3vw,40px); top:0; bottom:0; z-index:2;
  display:flex; align-items:center; pointer-events:none;
}
.hero .vline span{
  writing-mode:vertical-rl; font-family:var(--en); font-weight:300;
  font-size:clamp(56px,9vw,120px); letter-spacing:.12em; line-height:1;
  color:rgba(255,255,255,.16); text-transform:uppercase;
}
.hero-inner{ position:relative; z-index:3; width:100%; padding-block:96px clamp(56px,8vw,104px); }
.badges{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:30px; }
.badge{
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.5);
  backdrop-filter:blur(6px);
  padding:9px 18px; border-radius:999px; font-size:13.5px; font-weight:700;
}
.badge::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--blue-bright); box-shadow:0 0 0 4px rgba(45,131,230,.35); }
.hero h1{
  font-weight:900; font-size:clamp(40px,7.4vw,90px); line-height:1.12;
  letter-spacing:.01em; text-shadow:0 4px 40px rgba(0,0,0,.3);
}
.hero h1 .accent{ color:#fff; }
.hero .lead{
  margin-top:22px; max-width:32ch; font-size:clamp(15px,1.7vw,19px);
  font-weight:500; line-height:1.85; color:rgba(255,255,255,.92);
  text-shadow:0 2px 18px rgba(0,0,0,.35);
}
.hero .sig{ margin-top:18px; font-family:var(--en); font-weight:500; letter-spacing:.16em;
  font-size:13px; color:rgba(255,255,255,.8); }

/* floating round CTA */
.float-cta{
  position:absolute; z-index:5; right:clamp(16px,4vw,56px); bottom:clamp(24px,6vw,90px);
  width:clamp(118px,15vw,158px); aspect-ratio:1; border-radius:50%;
  background:linear-gradient(140deg,var(--blue-bright),var(--blue-deep));
  color:#fff; display:grid; place-items:center; text-align:center;
  font-weight:800; font-size:clamp(13px,1.5vw,16px); line-height:1.5;
  box-shadow:0 20px 50px -16px rgba(14,63,134,.95);
  animation:bob 3.4s var(--ease) infinite; transition:transform .3s var(--ease);
}
.float-cta:hover{ transform:scale(1.06); }
.float-cta::after{
  content:""; position:absolute; inset:-9px; border-radius:50%;
  border:1.5px dashed rgba(255,255,255,.55); animation:spin 14s linear infinite;
}
.float-cta small{ display:block; font-size:10px; letter-spacing:.2em; opacity:.85; margin-top:4px; font-family:var(--en); }
@keyframes bob{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-10px); } }
@keyframes spin{ to{ transform:rotate(360deg); } }

/* ============================================================
   IMAGE PLACEHOLDER w/ graceful fallback
   ============================================================ */
.ph{ position:relative; overflow:hidden; background:var(--blue-soft);
  background-image:
    linear-gradient(135deg, rgba(23,99,196,.10), rgba(14,63,134,.16)),
    repeating-linear-gradient(135deg, rgba(23,99,196,.06) 0 12px, transparent 12px 24px);
  display:grid; place-items:center; }
.ph::after{
  content:attr(data-label); position:absolute; bottom:14px; left:14px;
  font-family:ui-monospace,monospace; font-size:11px; letter-spacing:.06em;
  color:var(--blue-deep); background:rgba(255,255,255,.78);
  padding:5px 10px; border-radius:6px; opacity:.9;
}
.ph img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  opacity:0; transition:opacity .8s var(--ease); z-index:1; }
.ph img.loaded{ opacity:1; }
.ph.is-failed::after{ z-index:2; }

/* ============================================================
   ABOUT
   ============================================================ */
.about{ background:var(--white); }
.about .grid{ display:grid; grid-template-columns:1fr 1.04fr; gap:clamp(34px,5vw,76px); align-items:center; }
.about h2{ font-size:clamp(26px,3.4vw,40px); font-weight:900; line-height:1.5; margin-top:20px; }
.about h2 b{ color:var(--blue); }
.about p{ margin-top:24px; color:var(--ink-soft); font-size:16px; }
.about .figure{ position:relative; }
.about .figure .ph{ aspect-ratio:4/3.2; border-radius:18px; box-shadow:0 40px 80px -40px rgba(14,63,134,.55); }
.about .figure .tag{
  position:absolute; left:-18px; bottom:-18px; background:var(--blue); color:#fff;
  padding:18px 24px; border-radius:14px; box-shadow:0 24px 50px -22px rgba(14,63,134,.9);
  font-family:var(--en); font-weight:600; line-height:1.2;
}
.about .figure .tag b{ display:block; font-size:34px; }
.about .figure .tag small{ font-size:11px; letter-spacing:.16em; opacity:.85; font-family:var(--jp); }

.statrow{ display:flex; flex-wrap:wrap; gap:14px; margin-top:34px; }
.stat{ flex:1 1 130px; border:1px solid var(--line); border-radius:14px; padding:18px 20px; background:var(--paper); }
.stat b{ font-family:var(--en); font-weight:600; font-size:26px; color:var(--blue); line-height:1; }
.stat span{ display:block; font-size:12.5px; color:var(--muted); margin-top:8px; letter-spacing:.04em; }

/* ============================================================
   SERVICE
   ============================================================ */
.service{ background:var(--blue-mist); position:relative; }
.service .head{ display:flex; justify-content:space-between; align-items:flex-end; flex-wrap:wrap; gap:24px; }
.service .head p{ max-width:46ch; color:var(--ink-soft); font-size:15.5px; }
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:clamp(40px,6vw,68px); }
.scard{ background:#fff; border-radius:16px; overflow:hidden; border:1px solid var(--line);
  transition:transform .4s var(--ease), box-shadow .4s var(--ease); }
.scard:hover{ transform:translateY(-8px); box-shadow:0 34px 60px -34px rgba(14,63,134,.55); }
.scard .ph{ aspect-ratio:16/10; }
.scard .body{ padding:24px 24px 28px; }
.scard .num{ font-family:var(--en); font-size:13px; font-weight:600; color:var(--blue-bright); letter-spacing:.12em; }
.scard h3{ font-size:20px; font-weight:700; margin-top:6px; }
.scard ul{ margin-top:14px; list-style:none; display:flex; flex-direction:column; gap:8px; }
.scard li{ position:relative; padding-left:18px; font-size:14px; color:var(--ink-soft); }
.scard li::before{ content:""; position:absolute; left:0; top:.65em; width:7px; height:7px;
  border-radius:2px; background:var(--blue); transform:rotate(45deg); }

/* ============================================================
   MESSAGE
   ============================================================ */
.message{ position:relative; background:var(--white); overflow:hidden; }
.message .grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(34px,5vw,70px); align-items:center; position:relative; z-index:2; }
.message .band{ position:absolute; right:0; top:18%; bottom:6%; left:34%; z-index:1;
  background:linear-gradient(120deg,var(--blue-deep),var(--blue-bright));
  border-radius:30px 0 0 30px; }
.message .txt h2{ font-size:clamp(24px,3.2vw,38px); font-weight:900; line-height:1.55; margin-top:18px; }
.message .txt h2 b{ color:var(--blue); }
.message .txt p{ margin-top:22px; color:var(--ink-soft); font-size:15.5px; }
.message .figure{ position:relative; }
.message .figure .ph{ aspect-ratio:4/4.6; border-radius:18px; box-shadow:0 40px 90px -40px rgba(0,0,0,.5); }
.message .namecard{
  position:absolute; left:-26px; bottom:34px; background:#fff; padding:20px 26px;
  border-radius:14px; box-shadow:0 30px 60px -30px rgba(14,63,134,.7); min-width:200px;
}
.message .namecard small{ font-size:11px; color:var(--muted); letter-spacing:.14em; }
.message .namecard b{ display:block; font-size:24px; font-weight:900; margin-top:4px; }
.message .namecard em{ font-family:var(--en); font-style:normal; font-size:12px; color:var(--blue); letter-spacing:.12em; }

/* ============================================================
   RECRUIT
   ============================================================ */
.recruit{ background:var(--blue-mist); }
.rgrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:clamp(40px,6vw,64px); }
.rcard{ background:#fff; border-radius:18px; padding:32px 30px 36px; border:1px solid var(--line);
  position:relative; overflow:hidden; }
.rcard::before{ content:""; position:absolute; inset:0 0 auto 0; height:5px;
  background:linear-gradient(90deg,var(--blue-bright),var(--blue-deep)); }
.rcard .ic{ width:50px; height:50px; border-radius:13px; background:var(--blue-soft);
  display:grid; place-items:center; color:var(--blue); margin-bottom:18px; }
.rcard h3{ font-size:20px; font-weight:800; }
.rcard .lbl{ font-family:var(--en); font-size:12px; font-weight:600; letter-spacing:.14em; color:var(--blue-bright); }
.rcard ul{ list-style:none; margin-top:16px; display:flex; flex-direction:column; gap:12px; }
.rcard li{ position:relative; padding-left:22px; font-size:14.5px; color:var(--ink-soft); }
.rcard li::before{ content:"✓"; position:absolute; left:0; top:0; color:var(--blue); font-weight:800; }
.rcard .big{ font-family:var(--en); font-weight:700; font-size:30px; color:var(--ink); line-height:1.2; }
.rcard .big small{ font-size:14px; color:var(--muted); font-family:var(--jp); font-weight:500; }
.rcard .note{ font-size:12.5px; color:var(--muted); margin-top:10px; }

/* ============================================================
   SDGs
   ============================================================ */
.sdgs{ background:linear-gradient(160deg,var(--blue-deep),#0b3168); color:#fff; }
.sdgs .grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(34px,5vw,70px); align-items:center; }
.sdgs .eyebrow{ color:rgba(255,255,255,.9); }
.sdgs .sublabel{ color:rgba(255,255,255,.7); }
.sdgs .sublabel::before{ background:rgba(255,255,255,.7); }
.sdgs h2{ font-size:clamp(24px,3vw,34px); font-weight:900; line-height:1.5; margin-top:18px; }
.sdgs p{ margin-top:22px; color:rgba(255,255,255,.82); font-size:15px; }
.dots{ display:grid; grid-template-columns:repeat(6,1fr); gap:12px; }
.dots i{ aspect-ratio:1; border-radius:12px; display:grid; place-items:center; color:#fff;
  font-family:var(--en); font-weight:700; font-size:18px; box-shadow:0 14px 30px -16px rgba(0,0,0,.6); }

/* ============================================================
   CTA band
   ============================================================ */
.cta{ background:
    linear-gradient(120deg, rgba(14,63,134,.92), rgba(23,99,196,.86)),
    var(--blue-deep);
  position:relative; color:#fff; text-align:center; overflow:hidden; }
.cta .bg{ position:absolute; inset:0; z-index:-1; opacity:.28; }
.cta .quote{ font-size:clamp(26px,4.6vw,56px); font-weight:900; line-height:1.4; letter-spacing:.02em; }
.cta .sub{ margin-top:22px; font-size:16px; color:rgba(255,255,255,.9); max-width:50ch; margin-inline:auto; }
.cta .acts{ margin-top:40px; display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }
.cta .btn.ghost{ background:transparent; color:#fff; box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.7); }
.cta .btn.ghost:hover{ background:rgba(255,255,255,.12); }
.cta .btn.solid{ background:#fff; color:var(--blue-deep); box-shadow:0 16px 40px -14px rgba(0,0,0,.5); }

/* ============================================================
   COMPANY
   ============================================================ */
.company{ background:var(--white); }
.ctable{ margin-top:clamp(36px,5vw,56px); border-top:1px solid var(--line); }
.ctable .row{ display:grid; grid-template-columns:220px 1fr; gap:24px;
  padding:22px 8px; border-bottom:1px solid var(--line); align-items:baseline; }
.ctable .row dt{ font-weight:700; font-size:14px; letter-spacing:.06em; color:var(--blue-deep); }
.ctable .row dd{ font-size:15px; color:var(--ink-soft); }
.ctable .row dd b{ color:var(--ink); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:#0c1722; color:#cdd6e2; padding-block:clamp(54px,7vw,80px) 30px; }
.footer .top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; }
.footer .brand .name{ color:#fff; font-size:20px; }
.footer .brand .name span{ color:var(--blue-bright); }
.footer .addr{ margin-top:18px; font-size:13.5px; line-height:2; color:#9fadbe; }
.footer h4{ font-family:var(--en); font-size:12px; letter-spacing:.18em; color:#7e8da0; margin-bottom:14px; }
.footer .fnav{ display:flex; flex-direction:column; gap:11px; font-size:14px; }
.footer .fnav a:hover{ color:#fff; }
.footer .tel-big{ font-family:var(--en); font-weight:600; font-size:24px; color:#fff; }
.footer .tel-big small{ font-family:var(--jp); font-size:12px; color:#9fadbe; display:block; letter-spacing:.1em; }
.footer .copy{ margin-top:48px; padding-top:22px; border-top:1px solid rgba(255,255,255,.08);
  font-size:11.5px; letter-spacing:.06em; color:#7e8da0; display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; }
.footer .copy .reg{ font-family:ui-monospace,monospace; }

/* ============================================================
   reveal animation — richer, varied entrances
   ============================================================ */
[data-reveal]{
  transition:opacity 1s var(--ease), transform 1.1s var(--ease), filter 1s var(--ease);
  will-change:opacity, transform, filter;
}
/* hidden start only once JS arms it */
[data-reveal].armed{ opacity:0; transform:translateY(34px); filter:blur(8px); }
[data-reveal].armed.in{ opacity:1; transform:none; filter:blur(0); }

/* directional / scale variants (only when armed) */
[data-reveal="left"].armed{ transform:translateX(-46px); }
[data-reveal="right"].armed{ transform:translateX(46px); }
[data-reveal="zoom"].armed{ transform:scale(.86); filter:blur(4px); }
[data-reveal="rise"].armed{ transform:translateY(56px); }
[data-reveal].armed.in{ transform:none !important; filter:blur(0) !important; }

/* image clip-reveal: only ACTIVE once JS adds .armed (progressive enhancement —
   if JS fails or is cached-stale, images stay visible) */
.reveal-img.armed{ clip-path:inset(0 0 100% 0); transition:clip-path 1.15s var(--ease); }
.reveal-img.armed.in{ clip-path:inset(0 0 0 0); }
.reveal-img.armed img{ transform:scale(1.14); transition:transform 2s var(--ease); }
.reveal-img.armed.in img{ transform:scale(1); }

[data-reveal][data-delay="1"]{ transition-delay:.1s; }
[data-reveal][data-delay="2"]{ transition-delay:.2s; }
[data-reveal][data-delay="3"]{ transition-delay:.32s; }
[data-reveal][data-delay="4"]{ transition-delay:.44s; }
.reveal-img[data-delay="1"]{ transition-delay:.1s; }
.reveal-img[data-delay="2"]{ transition-delay:.2s; }

@media (prefers-reduced-motion: reduce){
  [data-reveal]{ opacity:1; transform:none; filter:none; transition:none; }
  .reveal-img{ clip-path:none; }
  .reveal-img img{ transform:none; }
  .hero-bg .hero-vid{ opacity:1; }
  .float-cta, .float-cta::after{ animation:none; }
  html{ scroll-behavior:auto; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1100px){
  .nav{ display:none; }
  .tel{ display:none; }
  .navtoggle{ display:inline-flex; }
}
@media (max-width: 960px){
  .about .grid, .message .grid, .sdgs .grid{ grid-template-columns:1fr; }
  .message .band{ display:none; }
  .cards, .rgrid{ grid-template-columns:repeat(2,1fr); }
  .message .figure{ order:-1; }
}
@media (max-width: 680px){
  .header .wrap{ gap:12px; }
  .header .btn{ padding:10px 16px; font-size:13px; }
  .btn-full{ display:none; }
  .btn-short{ display:inline; }
  .brand{ gap:9px; }
  .brand .mark{ width:38px; height:38px; }
  .brand .name{ font-size:15px; }
  .hero .vline{ display:none; }
  .hero .sig{ display:none; }
  .hero-inner{ padding-block:72px 118px; }
  .badges{ margin-bottom:22px; }
  .cards, .rgrid{ grid-template-columns:1fr; }
  .dots{ grid-template-columns:repeat(4,1fr); }
  .ctable .row{ grid-template-columns:1fr; gap:6px; padding:16px 4px; }
  .footer .top{ grid-template-columns:1fr; gap:30px; }
  .hero{ min-height:92svh; }
  .float-cta{ width:96px; right:16px; bottom:18px; font-size:12px; }
}
