@charset "utf-8";
/* =========================================================
   信州大学 アクア・リジェネレーション機構 フュージョン研究PJ
   common.css ― 全ページ共通の土台（トークン / リセット /
   レイアウト / ヘッダー / フッター / ボタン / 汎用UI）
   コンセプト：水から、未来の火を。 ／ 白黒ミニマル
   ========================================================= */

/* ---------- デザイントークン ---------- */
:root{
  --ink:#1a1a1a;        /* 主文字・主要要素 */
  --ink-2:#5e5e5e;      /* 補助テキスト */
  --ink-3:#8c8c8c;      /* キャプション・薄い文字 */
  --line:#e4e4e4;       /* 罫線 */
  --line-2:#efefef;     /* 薄い罫線 */
  --bg:#ffffff;
  --bg-2:#f6f6f5;       /* セクション交互背景 */
  --bg-3:#101010;       /* 反転（フッター等） */
  --maxw:1560px;       /* 横幅をいっぱい使うダイナミックレイアウト */
  --wrapw:1320px;
  --header-h:76px;
  --gut:clamp(20px,5vw,56px);
  --space:8px;
  --radius:8px;
  --radius-sm:6px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --serif:"Noto Serif JP",serif;
  --sans:"Noto Sans JP","Hiragino Sans","Yu Gothic",system-ui,sans-serif;
  --en:"Lato","Helvetica Neue",Arial,sans-serif;
  /* ブランドアクセント（水→エネルギー）。基調は白×墨、青はエネルギーの差し色 */
  --navy:#0a2444;        /* ロゴ濃紺 */
  --brand:#2f7fd6;       /* ブランドブルー（水） */
  --brand-2:#5cc6ec;     /* シアン（エネルギー） */
  --brand-grad:linear-gradient(135deg,#2f7fd6 0%,#5cc6ec 100%);
  --energy:#ff7d1a;      /* 水→火：エネルギーのオレンジ */
  --energy-2:#ffb24d;
}

/* ---------- リセット ---------- */
*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);
  font-size:16px;line-height:1.85;font-feature-settings:"palt";
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img,svg{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;}
ul,ol{margin:0;padding:0;list-style:none;}
h1,h2,h3,h4,h5,h6,p{margin:0;}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:0;}
:focus-visible{outline:2px solid var(--ink);outline-offset:3px;}

/* ---------- レイアウト ---------- */
.wrap{width:100%;max-width:var(--wrapw);margin-inline:auto;padding-inline:var(--gut);}
.wrap-wide{max-width:var(--maxw);}
.section{padding-block:clamp(56px,9vw,104px);}
.section--alt{background:var(--bg-2);}
/* 見出し（添付参照）：英語を大きく薄く・ブルー→チャコールのグラデ */
.eyebrow{
  display:block;font-family:var(--en);font-weight:400;text-transform:none;
  font-size:clamp(30px,4.8vw,62px);line-height:1.05;letter-spacing:-.012em;margin:0 0 10px;
  background:linear-gradient(95deg,#56aed4 0%,#3f8cbe 24%,#3a4750 62%,#2b333a 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;
}
/* 和文サブタイトル（小さな太字） */
.heading{font-size:clamp(15px,1.7vw,19px);line-height:1.6;font-weight:700;
  letter-spacing:.02em;color:#2b333a;}
.lead{color:var(--ink-2);font-size:clamp(15px,1.6vw,16px);line-height:2;max-width:44em;margin-top:18px;}
.sec-head{margin-bottom:clamp(32px,5vw,52px);}
.sec-head.center{text-align:center;}
.sec-head.center .lead{margin-inline:auto;}

/* ---------- ボタン ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;padding:14px 28px;
  border:1px solid var(--ink);border-radius:var(--radius-sm);
  font-size:14px;font-weight:600;letter-spacing:.04em;background:var(--bg);color:var(--ink);
  transition:background .3s var(--ease),color .3s var(--ease),transform .3s var(--ease);
}
.btn .arw{transition:transform .3s var(--ease);}
.btn:hover{background:var(--ink);color:#fff;}
.btn:hover .arw{transform:translateX(4px);}
.btn--primary{background:var(--ink);color:#fff;}
.btn--primary:hover{background:#000;}
.btn--ghost{border:0;border-bottom:1px solid var(--ink);border-radius:0;padding:8px 2px;}
.btn--ghost:hover{background:none;color:var(--ink-2);border-color:var(--ink-2);}
.btn--sm{padding:10px 18px;font-size:13px;}
/* 丸ピル（ヘッダーContact／添付参照のブルーグラデ） */
.btn--pill{border:0;border-radius:999px;color:#fff;background:var(--brand-grad);
  padding:13px 26px;box-shadow:0 8px 20px rgba(47,127,214,.28);}
.btn--pill:hover{background:var(--brand-grad);filter:brightness(1.06);
  transform:translateY(-1px);box-shadow:0 10px 26px rgba(47,127,214,.36);}
.btn--pill .btn__ico{flex:none;}
.btn-row{display:flex;flex-wrap:wrap;gap:14px;}
.center .btn-row{justify-content:center;}
.btn-row.is-center{justify-content:center;}

/* 余白ユーティリティ（インラインCSSの代替） */
.u-mt{margin-top:32px;}
.u-mt-sm{margin-top:20px;}

/* ---------- ヘッダー ---------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:100;background:transparent;
  border-bottom:1px solid transparent;
  transition:transform .4s var(--ease),background .3s var(--ease),border-color .3s var(--ease);
}
.site-header.is-hidden{transform:translateY(-100%);}
/* ヒーローを抜けたら、可読性のため薄いフロスト背景に */
.site-header.is-scrolled{background:rgba(255,255,255,.82);
  backdrop-filter:saturate(180%) blur(12px);border-bottom-color:var(--line);
  box-shadow:0 8px 24px rgba(0,0,0,.04);}
.header-inner{display:flex;align-items:center;gap:24px;max-width:var(--maxw);
  margin-inline:auto;padding:14px var(--gut);}
.brand{display:flex;align-items:center;flex:none;}
.brand__logo{height:46px;width:auto;display:block;}
.gnav{display:flex;align-items:center;gap:2px;margin-left:auto;}
.gnav a{padding:10px 14px;font-size:14px;font-weight:500;letter-spacing:.02em;position:relative;color:var(--navy);}
.gnav a::after{content:"";position:absolute;left:14px;right:14px;bottom:8px;height:2px;
  background:var(--brand-grad);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease);}
.gnav a:hover{color:var(--brand);}
.gnav a:hover::after{transform:scaleX(1);}
.header-actions{display:flex;align-items:center;gap:14px;margin-left:18px;}
.langsw{display:inline-flex;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;}
.langsw a{padding:7px 11px;font-family:var(--en);font-size:12px;font-weight:600;color:var(--ink-2);}
.langsw a.on{background:var(--ink);color:#fff;}
.langsw a+a{border-left:1px solid var(--line);}
.nav-toggle{display:none;width:44px;height:44px;border:1px solid var(--line);border-radius:var(--radius-sm);
  position:relative;}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{
  content:"";position:absolute;left:50%;top:50%;width:18px;height:1.5px;background:var(--ink);
  transform:translate(-50%,-50%);transition:.3s var(--ease);}
.nav-toggle span::before{transform:translate(-50%,-7px);} .nav-toggle span::after{transform:translate(-50%,5px);}

/* ---------- ドロワー（SP） ---------- */
.drawer{position:fixed;inset:0;z-index:120;visibility:hidden;}
.drawer__bg{position:absolute;inset:0;background:rgba(16,16,16,.5);opacity:0;transition:opacity .35s var(--ease);}
.drawer__panel{position:absolute;top:0;right:0;height:100%;width:min(420px,86vw);background:#fff;
  transform:translateX(100%);transition:transform .4s var(--ease);overflow-y:auto;padding:84px 28px 40px;}
.drawer.is-open{visibility:visible;}
.drawer.is-open .drawer__bg{opacity:1;}
.drawer.is-open .drawer__panel{transform:none;}
.drawer__panel a{display:block;padding:14px 4px;font-size:16px;border-bottom:1px solid var(--line-2);}
.drawer__panel a small{display:block;font-family:var(--en);font-size:11px;color:var(--ink-3);letter-spacing:.1em;}
.drawer__close{position:absolute;top:20px;right:24px;width:42px;height:42px;border:1px solid var(--line);
  border-radius:var(--radius-sm);font-size:20px;}
body.is-locked{overflow:hidden;}

/* ---------- フッター ---------- */
.site-footer{background:var(--bg-3);color:#cfcfcf;padding-block:clamp(48px,7vw,72px) 28px;}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px;
  max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut);}
.footer-brand .brand__logo{height:42px;width:auto;margin-bottom:16px;
  filter:brightness(0) invert(1);opacity:.92;}
.footer-brand p{font-size:13px;line-height:1.9;margin-top:0;color:#9a9a9a;}
.footer-grid h6{color:#fff;font-size:12px;letter-spacing:.1em;font-family:var(--en);
  text-transform:uppercase;margin-bottom:14px;}
.footer-grid li{padding:5px 0;}
.footer-grid a{font-size:13px;color:#bdbdbd;transition:color .3s var(--ease);}
.footer-grid a:hover{color:#fff;}
.footer-bottom{display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;align-items:center;
  max-width:var(--maxw);margin:36px auto 0;padding:20px var(--gut) 0;border-top:1px solid #2a2a2a;
  font-size:12px;color:#7d7d7d;}
.footer-sns{display:flex;gap:10px;}
.footer-sns a{width:34px;height:34px;border:1px solid #333;border-radius:50%;display:flex;
  align-items:center;justify-content:center;font-family:var(--en);font-size:11px;}
.footer-sns a:hover{border-color:#777;color:#fff;}

/* ---------- オレンジのエネルギー カーソル（fine pointer のみ） ---------- */
.cursor-dot,.cursor-glow{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;
  border-radius:50%;opacity:0;transition:opacity .35s ease,width .25s var(--ease),height .25s var(--ease);
  will-change:transform;}
.cursor-dot,.cursor-glow{transform-origin:center;}
.cursor-dot{width:10px;height:10px;background:var(--energy);
  box-shadow:0 0 12px 2px rgba(255,125,26,.85);}
.cursor-glow{width:46px;height:46px;filter:blur(2px);
  background:radial-gradient(circle,rgba(255,150,45,.42) 0%,rgba(255,110,20,.18) 46%,rgba(255,110,20,0) 70%);}
body.cursor-on{cursor:none;}
body.cursor-on a,body.cursor-on button,body.cursor-on .btn,body.cursor-on [role="button"]{cursor:none;}
body.cursor-on .cursor-dot,body.cursor-on .cursor-glow{opacity:1;}
body.cursor-hover .cursor-dot{width:14px;height:14px;}
body.cursor-hover .cursor-glow{width:72px;height:72px;
  background:radial-gradient(circle,rgba(255,165,55,.55) 0%,rgba(255,120,25,.24) 50%,rgba(255,110,20,0) 72%);}
body.cursor-press .cursor-glow{width:34px;height:34px;}
@media (pointer:coarse){.cursor-dot,.cursor-glow{display:none!important;}}

/* ---------- 汎用：プレースホルダ面 ---------- */
.media{position:relative;overflow:hidden;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);}
.media img{width:100%;height:100%;object-fit:cover;}
.r-21-9{aspect-ratio:21/9;} .r-16-9{aspect-ratio:16/9;} .r-4-3{aspect-ratio:4/3;}
.r-3-2{aspect-ratio:3/2;} .r-1-1{aspect-ratio:1/1;}

/* ---------- スクロール演出（共通） ---------- */
[data-reveal]{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
[data-reveal].is-in{opacity:1;transform:none;}
[data-reveal][data-delay="1"]{transition-delay:.08s;}
[data-reveal][data-delay="2"]{transition-delay:.16s;}
[data-reveal][data-delay="3"]{transition-delay:.24s;}
@media (prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1;transform:none;transition:none;}
  html{scroll-behavior:auto;}
}

/* ---------- レスポンシブ（共通） ---------- */
@media (max-width:900px){
  .gnav{display:none;}
  .nav-toggle{display:block;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .footer-brand{grid-column:1 / -1;}
}
@media (max-width:560px){
  body{font-size:15px;}
  .header-inner{gap:12px;padding-block:12px;}
  .brand__logo{height:36px;}
  .btn--pill{padding:11px 18px;}
  .langsw{display:none;}
  .footer-grid{grid-template-columns:1fr;gap:24px;}
  .footer-bottom{flex-direction:column;align-items:flex-start;}
}
