:root{
    --bg:#f6f6f3; --ink:#111; --ink-2:#2b2b2b; --mute:#6b6b6b;
    --line:#d8d8d2; --accent:#00d977; --accent-2:#00b6ff;
    --paper:#fff; --warn:#ff5b3a;
  }
  *{box-sizing:border-box;margin:0;padding:0;}
  html,body{background:var(--bg);color:var(--ink);font-family:"Zen Kaku Gothic New",sans-serif;-webkit-font-smoothing:antialiased;}
  body{overflow-x:hidden;}
  a{color:inherit;text-decoration:none;}
  .mono{font-family:"JetBrains Mono",monospace;letter-spacing:.02em;}
  .min{font-family:"Shippori Mincho",serif;}
  .vrt{writing-mode:vertical-rl;text-orientation:upright;}

  .grid-bg{position:fixed;inset:0;pointer-events:none;z-index:0;
    background-image:linear-gradient(to right,rgba(0,0,0,.04) 1px,transparent 1px),linear-gradient(to bottom,rgba(0,0,0,.04) 1px,transparent 1px);
    background-size:80px 80px;}
  .noise{position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.035;mix-blend-mode:multiply;
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");}

  header{position:fixed;top:0;left:0;right:0;z-index:50;
    display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
    padding:22px 36px;backdrop-filter:saturate(1.2) blur(10px);
    background:rgba(246,246,243,.7);border-bottom:1px solid var(--line);}
  .logo{display:flex;align-items:center;color:var(--ink);}
  .logo svg{height:32px;width:auto;display:block;}
  nav{display:flex;gap:28px;justify-content:center;}
  nav a{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);position:relative;padding:6px 0;}
  nav a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:var(--ink);transition:right .3s;}
  nav a:hover::after{right:0;}
  nav a.current::after{right:0;background:var(--accent);}
  .meta-right{justify-self:end;display:flex;align-items:center;gap:14px;font-size:11px;color:var(--mute);}
  .meta-right .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent);animation:pulse 2s infinite;}
  @keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

  /* ── HERO ── */
  .hero{position:relative;z-index:2;padding:140px 36px 80px;border-bottom:1px solid var(--line);}
  .breadcrumb{display:flex;align-items:center;gap:12px;font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--mute);margin-bottom:60px;letter-spacing:.15em;}
  .breadcrumb a:hover{color:var(--accent);}
  .breadcrumb .sep{color:var(--line);}
  .breadcrumb .current{color:var(--ink);}
  .hero-grid{display:grid;grid-template-columns:80px 1fr 320px;gap:36px;align-items:end;}
  .hero-vlabel{writing-mode:vertical-rl;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.3em;color:var(--mute);height:300px;}
  .hero-main h1{font-family:"Shippori Mincho",serif;font-weight:800;font-size:clamp(56px,8vw,128px);line-height:.92;letter-spacing:-.02em;}
  .hero-main h1 em{font-style:normal;color:var(--accent);}
  .hero-main .kicker{display:inline-flex;align-items:center;gap:10px;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.3em;color:var(--ink-2);border:1px solid var(--ink);padding:6px 14px;border-radius:100px;margin-bottom:36px;}
  .hero-main .kicker .blink{width:8px;height:8px;border-radius:50%;background:var(--accent);}
  .hero-main .lead{font-family:"Shippori Mincho",serif;font-size:22px;line-height:2;margin-top:38px;color:var(--ink-2);max-width:680px;}
  .hero-side{padding-left:30px;border-left:1px solid var(--line);}
  .hero-side .label{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--accent);letter-spacing:.25em;margin-bottom:14px;}
  .hero-side dl{display:grid;grid-template-columns:80px 1fr;gap:8px 14px;font-size:13px;line-height:1.6;}
  .hero-side dt{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--mute);letter-spacing:.1em;}
  .hero-side dd{color:var(--ink);}

  /* ── 共通セクション ── */
  section{position:relative;z-index:2;padding:120px 36px;}
  section + section{border-top:1px solid var(--line);}
  .sec-head{display:grid;grid-template-columns:80px 1fr auto;gap:36px;align-items:end;margin-bottom:72px;}
  .sec-num{writing-mode:vertical-rl;font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--mute);height:200px;letter-spacing:.2em;}
  .sec-title{font-family:"Shippori Mincho",serif;font-weight:800;font-size:clamp(40px,6vw,84px);line-height:1;letter-spacing:-.02em;}
  .sec-title .en{display:block;font-family:"JetBrains Mono",monospace;font-size:12px;font-weight:400;letter-spacing:.3em;color:var(--mute);margin-bottom:18px;}
  .sec-meta{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--mute);letter-spacing:.2em;text-align:right;}

  /* ── STORY 雑誌特集風 ── */
  .story-wrap{display:grid;grid-template-columns:80px 1fr;gap:60px;}
  .story-vrt{writing-mode:vertical-rl;font-family:"Shippori Mincho",serif;font-weight:700;font-size:24px;letter-spacing:.2em;color:var(--ink);height:480px;padding-left:14px;border-left:1px solid var(--line);}
  .story-vrt .acc{color:var(--accent);}
  .story-body{font-family:"Shippori Mincho",serif;font-size:22px;line-height:2.1;color:var(--ink);max-width:760px;}
  .story-body .lead-cap{font-size:90px;font-weight:800;line-height:1;float:left;margin:8px 16px 0 0;color:var(--accent);font-family:"Shippori Mincho",serif;}
  .story-body p{margin-bottom:32px;}
  .story-body strong{color:var(--accent);font-weight:700;}
  .story-pullquote{padding:30px 40px;border-left:4px solid var(--accent);background:var(--paper);font-family:"Shippori Mincho",serif;font-size:24px;line-height:1.8;color:var(--ink);margin:40px 0;font-weight:500;}
  .story-pullquote::before{content:"//";font-family:"JetBrains Mono",monospace;font-size:14px;color:var(--accent);margin-right:8px;letter-spacing:.2em;}

  /* ── TIMELINE ── */
  .timeline-section{background:linear-gradient(180deg,var(--bg),#eeeee8);}
  .timeline{display:grid;grid-template-columns:auto 1fr;gap:40px 50px;position:relative;max-width:1200px;}
  .timeline::before{content:"";position:absolute;left:160px;top:8px;bottom:8px;width:1px;background:var(--line);}
  .tl-year{font-family:"JetBrains Mono",monospace;font-size:14px;font-weight:600;color:var(--accent);letter-spacing:.15em;padding-top:6px;text-align:right;position:relative;}
  .tl-year::after{content:"";position:absolute;right:-44px;top:14px;width:12px;height:12px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 6px var(--bg);z-index:1;}
  .tl-block{padding-left:30px;padding-bottom:30px;}
  .tl-tag{display:inline-block;font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.2em;padding:3px 8px;background:var(--ink);color:var(--paper);margin-bottom:14px;}
  .tl-tag.industry{background:var(--accent);color:var(--ink);}
  .tl-block h3{font-family:"Shippori Mincho",serif;font-size:24px;line-height:1.4;margin-bottom:10px;}
  .tl-block .role{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--mute);letter-spacing:.1em;margin-bottom:14px;}
  .tl-block p{font-size:14px;line-height:1.9;color:var(--ink-2);max-width:600px;}
  .tl-block p strong{color:var(--ink);}

  /* ── NUMBERS ── */
  .numbers{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);background:var(--paper);}
  .num-card{padding:50px 32px;border-right:1px solid var(--line);text-align:left;}
  .num-card:last-child{border-right:none;}
  .num-card .val{font-family:"Shippori Mincho",serif;font-size:80px;font-weight:800;letter-spacing:-.04em;line-height:.95;color:var(--ink);}
  .num-card .val .acc{color:var(--accent);}
  .num-card .val small{font-family:"Zen Kaku Gothic New",sans-serif;font-size:18px;font-weight:400;color:var(--mute);margin-left:6px;}
  .num-card .lbl{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--accent);letter-spacing:.25em;margin-top:14px;}
  .num-card .desc{font-size:12px;line-height:1.8;color:var(--ink-2);margin-top:10px;}

  /* ── PHILOSOPHY ── */
  .philosophy-section{background:var(--ink);color:#fff;}
  .philosophy-section .sec-title{color:#fff;}
  .philosophy-section .sec-num,.philosophy-section .sec-meta{color:rgba(255,255,255,.5);}
  .philosophy{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
  .ph-card{padding:42px 36px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.02);transition:all .3s;position:relative;}
  .ph-card:hover{border-color:var(--accent);background:rgba(0,217,119,.04);}
  .ph-card .num{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--accent);letter-spacing:.25em;margin-bottom:18px;}
  .ph-card h3{font-family:"Shippori Mincho",serif;font-size:30px;line-height:1.3;margin-bottom:18px;color:#fff;}
  .ph-card h3 .en{display:block;font-family:"JetBrains Mono",monospace;font-size:11px;font-weight:400;letter-spacing:.2em;color:var(--accent);margin-top:6px;}
  .ph-card p{font-size:14px;line-height:1.9;color:rgba(255,255,255,.75);}

  /* ── PROFILE ── */
  .profile-wrap{display:grid;grid-template-columns:1fr 320px;gap:80px;}
  .profile-body{font-family:"Shippori Mincho",serif;font-size:20px;line-height:2;color:var(--ink);}
  .profile-body p{margin-bottom:28px;}
  .profile-body strong{color:var(--accent);font-weight:700;}
  .profile-card{background:var(--paper);border:1px solid var(--line);padding:30px;height:fit-content;}
  .profile-card .label{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--accent);letter-spacing:.25em;margin-bottom:18px;}
  .profile-card h4{font-family:"Shippori Mincho",serif;font-size:22px;margin-bottom:6px;}
  .profile-card .en{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--mute);letter-spacing:.1em;margin-bottom:20px;}
  .profile-card dl{display:grid;grid-template-columns:75px 1fr;gap:6px 14px;font-size:12px;line-height:1.7;}
  .profile-card dt{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--mute);letter-spacing:.1em;}
  .profile-card dd{color:var(--ink);}
  .profile-tags{margin-top:20px;padding-top:20px;border-top:1px dashed var(--line);}
  .profile-tags .label{margin-bottom:12px;}
  .profile-tags .tag{display:inline-block;font-family:"JetBrains Mono",monospace;font-size:10px;padding:4px 10px;background:var(--bg);color:var(--ink-2);margin:0 4px 6px 0;border-radius:100px;}

  /* ── SIDE STORIES（趣味・地域活動） ── */
  .side-stories{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px;}
  .side-card{background:var(--paper);border:1px solid var(--line);padding:30px;}
  .side-card .label{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--accent);letter-spacing:.25em;margin-bottom:14px;}
  .side-card h4{font-family:"Shippori Mincho",serif;font-size:22px;line-height:1.4;margin-bottom:12px;}
  .side-card p{font-size:13px;line-height:1.8;color:var(--ink-2);}

  /* ── VISION ── */
  .vision-wrap{display:grid;grid-template-columns:auto 1fr;gap:60px;align-items:start;}
  .vision-mark{writing-mode:vertical-rl;font-family:"Shippori Mincho",serif;font-weight:700;font-size:42px;letter-spacing:.2em;color:var(--ink);line-height:1.4;}
  .vision-mark .acc{color:var(--accent);}
  .vision-body{font-family:"Shippori Mincho",serif;font-size:22px;line-height:2.1;color:var(--ink);max-width:780px;}
  .vision-body p{margin-bottom:30px;}
  .vision-body strong{color:var(--accent);font-weight:700;}
  .vision-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:50px;}
  .vp-card{padding:24px;border-top:3px solid var(--accent);background:var(--paper);border:1px solid var(--line);border-top:3px solid var(--accent);}
  .vp-card .label{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--accent);letter-spacing:.25em;margin-bottom:10px;}
  .vp-card h4{font-family:"Shippori Mincho",serif;font-size:18px;line-height:1.4;margin-bottom:10px;}
  .vp-card p{font-size:12px;line-height:1.8;color:var(--ink-2);}

  /* ── CTA ── */
  .cta-section{background:var(--ink);color:#fff;border-top:none;}
  .cta-wrap{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:end;}
  .cta-section .sec-head{margin-bottom:60px;}
  .cta-section .sec-title{color:#fff;}
  .cta-section .sec-num,.cta-section .sec-meta{color:rgba(255,255,255,.4);}
  .cta-headline{font-family:"Shippori Mincho",serif;font-size:clamp(40px,6vw,80px);line-height:.95;letter-spacing:-.02em;}
  .cta-headline .acc{color:var(--accent);}
  .cta-right .label{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--accent);letter-spacing:.25em;margin-bottom:14px;display:block;}
  .cta-right p{font-size:14px;line-height:1.9;color:rgba(255,255,255,.8);margin-bottom:30px;}
  .cta-btn{display:inline-flex;align-items:center;gap:14px;padding:18px 28px;background:var(--accent);color:var(--ink);font-family:"JetBrains Mono",monospace;font-size:13px;letter-spacing:.2em;font-weight:600;transition:transform .3s;}
  .cta-btn:hover{transform:translateX(6px);}
  .cta-btn::after{content:"→";}

  /* フッター */
  footer{background:var(--ink);color:rgba(255,255,255,.85);padding:80px 36px 30px;border-top:1px solid rgba(255,255,255,.1);position:relative;z-index:2;}
  .foot-top{display:grid;grid-template-columns:auto 1fr;gap:80px;align-items:start;padding-bottom:50px;border-bottom:1px solid rgba(255,255,255,.12);}
  .foot-voxel{display:flex;align-items:center;justify-content:center;padding:10px;}
  .foot-voxel svg{width:130px;height:auto;display:block;}
  .foot-info{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;}
  .foot-info .col h5{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--accent);letter-spacing:.25em;margin-bottom:18px;}
  .foot-info .col .item{font-family:"Shippori Mincho",serif;font-size:16px;color:#fff;margin-bottom:8px;line-height:1.4;}
  .foot-info .col .sub{font-family:"JetBrains Mono",monospace;font-size:10px;color:rgba(255,255,255,.45);letter-spacing:.1em;}
  .foot-info .nav-links a{display:block;font-family:"Zen Kaku Gothic New",sans-serif;font-size:13px;color:rgba(255,255,255,.7);margin-bottom:10px;transition:color .2s;}
  .foot-info .nav-links a:hover{color:var(--accent);}
  .foot-bottom{padding-top:24px;display:flex;justify-content:space-between;align-items:center;font-family:"JetBrains Mono",monospace;font-size:10px;color:rgba(255,255,255,.4);letter-spacing:.2em;}
  .foot-bottom .tagline{color:var(--accent);}

  @media (max-width:900px){
    header{padding:16px 20px;grid-template-columns:1fr auto;}
    nav,.meta-right{display:none;}
    .hero{padding:90px 20px 50px;}
    .hero-grid{grid-template-columns:1fr;gap:30px;}
    .hero-vlabel{display:none;}
    .hero-side{padding-left:0;border-left:none;border-top:1px solid var(--line);padding-top:30px;}
    section{padding:70px 20px;}
    .sec-head{grid-template-columns:1fr;gap:14px;margin-bottom:40px;}
    .sec-num{writing-mode:horizontal-tb;height:auto;}
    .sec-meta{text-align:left;}
    .story-wrap{grid-template-columns:1fr;gap:30px;}
    .story-vrt{writing-mode:horizontal-tb;height:auto;border-left:none;border-bottom:1px solid var(--line);padding-left:0;padding-bottom:14px;font-size:18px;letter-spacing:.1em;}
    .story-body{font-size:16px;}
    .story-body .lead-cap{font-size:60px;}
    .story-pullquote{font-size:18px;padding:20px;}
    .timeline{grid-template-columns:1fr;gap:8px;}
    .timeline::before{display:none;}
    .tl-year{text-align:left;padding-top:0;}
    .tl-year::after{display:none;}
    .tl-block{padding-left:0;padding-bottom:30px;border-left:2px solid var(--accent);padding:10px 0 30px 20px;}
    .numbers{grid-template-columns:1fr 1fr;}
    .num-card{border-right:1px solid var(--line);border-bottom:1px solid var(--line);}
    .num-card:nth-child(2n){border-right:none;}
    .num-card:nth-last-child(-n+2){border-bottom:none;}
    .num-card .val{font-size:60px;}
    .philosophy,.side-stories,.vision-pillars{grid-template-columns:1fr;}
    .profile-wrap{grid-template-columns:1fr;gap:40px;}
    .profile-body{font-size:16px;}
    .vision-wrap{grid-template-columns:1fr;gap:30px;}
    .vision-mark{writing-mode:horizontal-tb;font-size:24px;}
    .vision-body{font-size:16px;}
    .cta-wrap{grid-template-columns:1fr;gap:40px;}
    .foot-top{grid-template-columns:1fr;gap:40px;}
    .foot-info{grid-template-columns:1fr;gap:30px;}
    .foot-voxel svg{width:100px;}
    .foot-bottom{flex-direction:column;gap:10px;text-align:center;}
  }
