
:root{--bg:#050816;--bg2:#07111f;--card:rgba(13,25,48,.78);--card2:rgba(19,40,75,.72);--text:#eef6ff;--muted:#9fb4cc;--primary:#00e5ff;--secondary:#7c3cff;--accent:#3cffb5;--line:rgba(255,255,255,.12);--shadow:0 24px 80px rgba(0,229,255,.18);--radius:22px}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Hiragino Sans","Yu Gothic",Meiryo,sans-serif;background:radial-gradient(circle at 20% 10%,rgba(0,229,255,.22),transparent 28%),radial-gradient(circle at 80% 0%,rgba(124,60,255,.28),transparent 30%),radial-gradient(circle at 80% 85%,rgba(60,255,181,.10),transparent 25%),linear-gradient(180deg,var(--bg),var(--bg2));color:var(--text);line-height:1.75;overflow-x:hidden}
body:before{content:"";position:fixed;inset:0;pointer-events:none;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:56px 56px;mask-image:linear-gradient(to bottom,rgba(0,0,0,.9),transparent 72%);z-index:0}
a{color:inherit;text-decoration:none}.container{width:min(1120px,calc(100% - 40px));margin:0 auto;position:relative;z-index:1}.header{position:sticky;top:0;z-index:20;backdrop-filter:blur(18px);background:rgba(5,8,22,.72);border-bottom:1px solid var(--line)}.nav{display:flex;align-items:center;justify-content:space-between;min-height:72px;gap:24px}.logo{display:flex;align-items:center;gap:12px;font-weight:800;letter-spacing:.04em}.logo-image{height:42px;width:auto;display:block;filter:drop-shadow(0 0 10px rgba(0,229,255,.35)) drop-shadow(0 0 24px rgba(124,60,255,.22));transition:transform .2s ease}.logo-image:hover{transform:scale(1.04)}.menu{display:flex;gap:22px;color:var(--muted);font-size:14px}.menu a:hover,.menu a.active{color:var(--primary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 20px;border-radius:999px;border:1px solid rgba(0,229,255,.35);background:linear-gradient(135deg,rgba(0,229,255,.18),rgba(124,60,255,.20));color:var(--text);font-weight:700;box-shadow:0 0 30px rgba(0,229,255,.16);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.btn:hover{transform:translateY(-2px);border-color:rgba(0,229,255,.75);box-shadow:var(--shadow)}.btn.secondary{background:rgba(255,255,255,.04);border-color:var(--line);color:var(--muted);box-shadow:none}
.hero{padding:84px 0 72px;position:relative}.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}.badge{display:inline-flex;align-items:center;gap:10px;padding:8px 13px;border-radius:999px;border:1px solid rgba(0,229,255,.28);background:rgba(0,229,255,.08);color:#bff7ff;font-size:13px;margin-bottom:24px}.pulse{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 18px var(--accent)}h1{margin:0 0 22px;font-size:clamp(40px,6vw,72px);line-height:1.08;letter-spacing:-.04em}.gradient-text{background:linear-gradient(90deg,#fff,var(--primary),var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent}.lead{font-size:clamp(16px,2vw,20px);color:var(--muted);margin:0 0 34px;max-width:760px}.hero-actions{display:flex;gap:14px;flex-wrap:wrap}.visual{position:relative;min-height:420px;border-radius:34px;border:1px solid var(--line);background:linear-gradient(145deg,rgba(255,255,255,.09),rgba(255,255,255,.02)),radial-gradient(circle at 30% 20%,rgba(0,229,255,.28),transparent 25%),radial-gradient(circle at 70% 70%,rgba(124,60,255,.30),transparent 30%);box-shadow:var(--shadow);overflow:hidden}.visual:before{content:"";position:absolute;inset:24px;border:1px solid rgba(255,255,255,.12);border-radius:26px;background-image:linear-gradient(rgba(0,229,255,.12) 1px,transparent 1px),linear-gradient(90deg,rgba(0,229,255,.12) 1px,transparent 1px);background-size:34px 34px}.orb{position:absolute;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(0,229,255,.95),rgba(124,60,255,.12) 58%,transparent 70%);top:82px;left:50%;transform:translateX(-50%);animation:float 5s ease-in-out infinite}.panel{position:absolute;border:1px solid rgba(255,255,255,.13);background:rgba(5,12,28,.74);backdrop-filter:blur(16px);border-radius:18px;padding:16px;box-shadow:0 16px 44px rgba(0,0,0,.28)}.panel strong{display:block;font-size:14px}.panel span{color:var(--muted);font-size:12px}.panel.one{top:48px;left:32px;width:190px}.panel.two{right:30px;top:188px;width:205px}.panel.three{left:56px;bottom:48px;width:230px}.code-line{height:8px;border-radius:99px;background:rgba(255,255,255,.13);margin-top:10px;overflow:hidden}.code-line:after{content:"";display:block;width:62%;height:100%;background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:inherit}@keyframes float{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,-16px)}}
section{padding:74px 0}.section-head{max-width:780px;margin-bottom:34px}.eyebrow{color:var(--primary);font-weight:800;font-size:13px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:10px}h2{margin:0 0 14px;font-size:clamp(30px,4vw,46px);line-height:1.18;letter-spacing:-.03em}.section-head p{color:var(--muted);margin:0}.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.card{border:1px solid var(--line);background:linear-gradient(180deg,var(--card),rgba(9,18,35,.65));border-radius:var(--radius);padding:26px;min-height:220px;transition:transform .2s ease,border-color .2s ease,background .2s ease}.card:hover{transform:translateY(-6px);border-color:rgba(0,229,255,.46);background:linear-gradient(180deg,var(--card2),rgba(9,18,35,.76))}.icon{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(0,229,255,.22),rgba(124,60,255,.22));border:1px solid rgba(255,255,255,.12);margin-bottom:18px;font-size:22px}.card h3{margin:0 0 10px;font-size:20px}.card p{margin:0;color:var(--muted);font-size:14px}.split{display:grid;grid-template-columns:.9fr 1.1fr;gap:34px;align-items:stretch}.glass{border:1px solid var(--line);border-radius:28px;background:rgba(255,255,255,.045);padding:32px;overflow:visible}.list{display:grid;gap:14px;margin:0;padding:0;list-style:none}.list li{display:flex;gap:12px;color:var(--muted);padding:14px;border-radius:16px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.08)}.check{color:var(--accent);font-weight:900}.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:24px}.stat{padding:18px;border-radius:18px;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.18)}.stat b{display:block;font-size:24px;color:var(--primary)}.stat span{color:var(--muted);font-size:12px}.news{display:grid;gap:12px}.news a{display:grid;grid-template-columns:120px 1fr;gap:16px;padding:18px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.04);color:var(--muted)}.news time{color:var(--primary);font-weight:700}.table{display:grid;gap:12px}.row{display:grid;grid-template-columns:180px 1fr;gap:18px;padding:18px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.04)}.row b{color:#fff}.row span{color:var(--muted)}.cta{padding:80px 0 96px}.cta-box{position:relative;overflow:hidden;border-radius:34px;border:1px solid rgba(0,229,255,.28);background:radial-gradient(circle at 20% 10%,rgba(0,229,255,.25),transparent 30%),radial-gradient(circle at 85% 85%,rgba(124,60,255,.30),transparent 34%),rgba(255,255,255,.055);padding:46px;box-shadow:var(--shadow)}.cta-box h2{max-width:780px}.cta-box p{color:var(--muted);max-width:760px}.footer{border-top:1px solid var(--line);padding:34px 0;color:var(--muted);font-size:13px}.footer-inner{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}
@media(max-width:900px){.menu{display:none}.hero{padding-top:64px}.hero-grid,.split{grid-template-columns:1fr}.visual{min-height:390px}.cards{grid-template-columns:1fr}.stats{grid-template-columns:1fr}.news a,.row{grid-template-columns:1fr}}@media(max-width:520px){.container{width:min(100% - 28px,1120px)}.header .btn:not(.lang-btn){display:none}.hero-actions .btn{width:100%}.visual{display:none}.cta-box{padding:28px}}


.link-card{position:relative;display:block;color:inherit}
.link-card:after{content:"詳しく見る →";display:inline-flex;margin-top:18px;color:var(--primary);font-weight:800;font-size:13px}
.detail-nav{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.detail-nav a{padding:10px 14px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--muted);font-size:13px}
.detail-nav a:hover{color:var(--primary);border-color:rgba(0,229,255,.45)}
.flow{counter-reset:step;display:grid;gap:14px}
.flow .step{counter-increment:step;padding:18px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.04)}
.flow .step:before{content:"STEP " counter(step);display:inline-block;margin-bottom:8px;color:var(--primary);font-weight:900;font-size:12px;letter-spacing:.08em}


/* ===== Responsive readability fix ===== */
h1,h2,h3,p,li,.lead,.card,.row,.news a,.btn,.badge,.logo span{
  overflow-wrap: normal;
}

h1,h2,h3{
  word-break: keep-all;
  line-break: strict;
}

.lead,
.section-head p,
.card p,
.list li,
.row span,
.news a{
  word-break: normal;
  line-break: strict;
}

.logo span{
  white-space: nowrap;
}

.card{
  height: auto;
}

.card.link-card{
  min-height: 240px;
}

@media(max-width:900px){
  .hero{
    padding:56px 0 52px;
  }

  h1{
    font-size:clamp(34px,9vw,54px);
    line-height:1.18;
    letter-spacing:-.025em;
  }

  h2{
    font-size:clamp(26px,7vw,40px);
    line-height:1.25;
  }

  .lead{
    font-size:16px;
  }

  .cards{
    grid-template-columns:1fr;
  }

  .card,
  .card.link-card{
    min-height:auto;
  }

  .table{
    gap:10px;
  }

  .row{
    grid-template-columns:1fr;
    gap:6px;
  }

  .row b{
    font-size:14px;
    color:var(--primary);
  }

  .row span{
    font-size:14px;
  }
}

@media(max-width:640px){
  .container{
    width:min(100% - 28px,1120px);
  }

  .nav{
    min-height:64px;
    gap:10px;
  }

  .logo{
    gap:8px;
    min-width:0;
  }

  .logo-image{
    height:34px;
  }

  .logo span{
    font-size:14px;
  }

  .badge{
    max-width:100%;
    white-space:normal;
    align-items:flex-start;
  }

  .hero{
    padding:42px 0 42px;
  }

  section{
    padding:48px 0;
  }

  h1{
    font-size:clamp(30px,10vw,42px);
    line-height:1.22;
  }

  h2{
    font-size:clamp(24px,8vw,34px);
  }

  .lead{
    margin-bottom:24px;
  }

  .hero-actions{
    gap:10px;
  }

  .hero-actions .btn,
  .cta-box .btn{
    width:100%;
  }

  .glass,
  .card,
  .cta-box{
    padding:22px;
    border-radius:20px;
  }

  .list li{
    padding:12px;
    font-size:14px;
  }

  .detail-nav{
    gap:8px;
  }

  .detail-nav a{
    width:100%;
    text-align:center;
  }

  .news a{
    padding:14px;
  }

  .footer-inner{
    display:grid;
    gap:8px;
  }
}

@media(max-width:380px){
  .logo span{
    display:none;
  }

  h1{
    font-size:28px;
  }

  .btn{
    padding:12px 14px;
    font-size:14px;
  }
}


/* ===== Vertical Icon Flow UI ===== */
.process-flow{
  display:grid;
  grid-template-columns:1fr;
  gap:18px;
  margin-top:22px;
  position:relative;
}

.process-flow::before{
  content:"";
  position:absolute;
  left:38px;
  top:34px;
  bottom:34px;
  width:2px;
  background:linear-gradient(180deg,var(--primary),var(--secondary),var(--accent));
  box-shadow:0 0 18px rgba(0,229,255,.45);
  opacity:.72;
}

.process-flow-item{
  position:relative;
  display:grid;
  grid-template-columns:76px 1fr;
  gap:18px;
  align-items:start;
  min-height:118px;
  padding:18px 20px 18px 0;
  border-radius:24px;
}

.process-flow-icon{
  position:relative;
  z-index:2;
  width:76px;
  height:76px;
  display:grid;
  place-items:center;
  border-radius:24px;
  font-size:36px;
  line-height:1;
  border:1px solid rgba(0,229,255,.38);
  background:
    radial-gradient(circle at 30% 20%,rgba(255,255,255,.35),transparent 20%),
    linear-gradient(135deg,rgba(0,229,255,.28),rgba(124,60,255,.32));
  box-shadow:
    0 0 0 8px rgba(5,8,22,.92),
    0 18px 44px rgba(0,0,0,.35),
    0 0 30px rgba(0,229,255,.28);
  font-size:30px;
  color:var(--primary);
}
.process-flow-icon .ico{width:34px;height:34px}

.process-flow-body{
  padding:20px 22px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.12);
  background:
    linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.035)),
    rgba(8,18,35,.72);
  box-shadow:0 18px 46px rgba(0,0,0,.22), inset 0 0 0 1px rgba(255,255,255,.035);
}

.process-flow-meta{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:8px;
  color:var(--primary);
  font-size:12px;
  font-weight:900;
  letter-spacing:.12em;
}

.process-flow-no{
  display:inline-grid;
  place-items:center;
  min-width:34px;
  height:26px;
  padding:0 10px;
  border-radius:999px;
  color:#06101f;
  background:linear-gradient(135deg,var(--primary),var(--accent));
  box-shadow:0 0 18px rgba(0,229,255,.25);
  letter-spacing:0;
}

.process-flow-title{
  display:block;
  margin-bottom:8px;
  color:#fff;
  font-size:18px;
  font-weight:900;
  line-height:1.45;
}

.process-flow-text{
  display:block;
  color:var(--muted);
  font-size:14px;
  line-height:1.75;
}

.process-flow-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:14px;
}

.process-flow-tags span{
  padding:5px 9px;
  border-radius:999px;
  border:1px solid rgba(0,229,255,.20);
  background:rgba(0,229,255,.06);
  color:#bff7ff;
  font-size:12px;
}

@media(max-width:640px){
  .process-flow::before{
    left:29px;
  }

  .process-flow-item{
    grid-template-columns:58px 1fr;
    gap:12px;
    min-height:auto;
    padding-right:0;
  }

  .process-flow-icon{
    width:58px;
    height:58px;
    border-radius:18px;
    font-size:24px;
    box-shadow:
      0 0 0 6px rgba(5,8,22,.92),
      0 12px 30px rgba(0,0,0,.35),
      0 0 22px rgba(0,229,255,.24);
  }

  .process-flow-body{
    padding:16px;
    border-radius:18px;
  }

  .process-flow-title{
    font-size:16px;
  }

  .process-flow-text{
    font-size:13px;
  }
}


/* ===== Japanese line-break refinement ===== */
html:lang(ja) h1,
html:lang(ja) h2,
html:lang(ja) h3,
html:lang(ja) p,
html:lang(ja) li,
html:lang(ja) .lead,
html:lang(ja) .card,
html:lang(ja) .row,
html:lang(ja) .news a,
html:lang(ja) .btn,
html:lang(ja) .badge,
html:lang(ja) .logo span,
html:lang(ja) .process-flow-title,
html:lang(ja) .process-flow-text,
html:lang(ja) .process-flow-tags span {
  word-break: keep-all;
  overflow-wrap: normal;
  line-break: strict;
}



html:lang(ja) .card p,
html:lang(ja) .process-flow-text,
html:lang(ja) .list li {
  text-align: justify;
}

@media(max-width:640px){
  html:lang(ja) .card,
  html:lang(ja) .glass,
  html:lang(ja) .process-flow-body {
    padding-left:18px;
    padding-right:18px;
  }

  html:lang(ja) .cards {
    gap:14px;
  }

  html:lang(ja) .card p,
  html:lang(ja) .process-flow-text,
  html:lang(ja) .list li,
  html:lang(ja) .row span {
    font-size:14px;
    line-height:1.9;
  }
}

/* English pages can wrap long words/phrases more flexibly */
html:lang(en) h1,
html:lang(en) h2,
html:lang(en) h3,
html:lang(en) p,
html:lang(en) li,
html:lang(en) .lead,
html:lang(en) .card,
html:lang(en) .row,
html:lang(en) .process-flow-text {
  word-break: normal;
  overflow-wrap: anywhere;
  line-break: auto;
}


/* ===== Japanese spacing hotfix ===== */
html:lang(ja) body,
html:lang(ja) p,
html:lang(ja) li,
html:lang(ja) span,
html:lang(ja) a,
html:lang(ja) h1,
html:lang(ja) h2,
html:lang(ja) h3,
html:lang(ja) .lead,
html:lang(ja) .card p,
html:lang(ja) .process-flow-text,
html:lang(ja) .process-flow-title {
  letter-spacing: 0 !important;
  word-spacing: 0 !important;
  font-feature-settings: normal;
  text-spacing: normal;
}

html:lang(ja) .card p,
html:lang(ja) .process-flow-text,
html:lang(ja) .lead {
  text-align: left;
}

/* ===== Final header, language switch, and visual card fix ===== */
.header .nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:22px;
}

.header .menu{
  margin-left:auto;
  margin-right:28px;
  flex:0 1 auto;
}

.lang-btn{
  margin-left:0;
  white-space:nowrap;
  padding:12px 18px;
}

.lang-btn .flag{
  display:inline-block;
  width:25px;
  height:17px;
  margin-right:8px;
  border-radius:3px;
  vertical-align:-3px;
  box-shadow:0 0 0 1px rgba(255,255,255,.45), 0 0 10px rgba(0,229,255,.12);
  overflow:hidden;
}

.flag-us{
  background:
    repeating-linear-gradient(
      to bottom,
      #b22234 0 1.3px,
      #fff 1.3px 2.6px
    );
  position:relative;
}

.flag-us::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  width:11px;
  height:9px;
  background:#3c3b6e;
}

.flag-jp{
  background:#fff;
  position:relative;
}

.flag-jp::before{
  content:"";
  position:absolute;
  width:8px;
  height:8px;
  border-radius:50%;
  background:#bc002d;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
}

.cards{
  align-items:stretch;
}

.cards > .card,
.cards > a.card{
  width:100%;
}

.card{
  display:flex;
  flex-direction:column;
}

.card .icon{
  flex:0 0 auto;
}

.card h3{
  flex:0 0 auto;
}

.card p{
  flex:1 1 auto;
}

.link-card::after{
  flex:0 0 auto;
}

.recruit-cards .card{
  text-align:center;
  min-height:420px;
  padding:28px 24px;
}

.recruit-cards .icon{
  width:82px;
  height:82px;
  margin:0 auto 22px;
  border-radius:50%;
  font-size:38px;
  background:
    radial-gradient(circle at 30% 20%,rgba(255,255,255,.95),rgba(255,255,255,.75) 42%,rgba(0,229,255,.18) 100%);
  color:#0b1730;
  box-shadow:0 18px 44px rgba(0,0,0,.30), 0 0 28px rgba(0,229,255,.18);
}

.recruit-cards h3{
  font-size:24px;
  margin-bottom:12px;
}

.recruit-cards h3::after{
  content:"";
  display:block;
  width:54px;
  height:2px;
  margin:14px auto 0;
  background:linear-gradient(90deg,var(--primary),var(--accent));
  box-shadow:0 0 14px rgba(0,229,255,.5);
}

.recruit-cards .card p{
  text-align:center !important;
  line-height:1.8;
  margin-bottom:18px;
}

.visual-points{
  display:grid;
  gap:8px;
  margin:18px 0 18px;
  padding-top:18px;
  border-top:1px dashed rgba(255,255,255,.16);
}

.visual-point{
  display:grid;
  grid-template-columns:32px 1fr;
  align-items:center;
  gap:10px;
  padding:9px 10px;
  border-radius:10px;
  background:rgba(255,255,255,.045);
  border:1px solid rgba(255,255,255,.08);
  color:var(--muted);
  text-align:left;
  font-size:14px;
  line-height:1.45;
}

.visual-point .vp-icon{
  display:grid;
  place-items:center;
  width:28px;
  height:28px;
  border-radius:8px;
  background:linear-gradient(135deg,rgba(0,229,255,.22),rgba(124,60,255,.22));
  font-size:17px;
}

.conditions-visual{
  display:grid;
  grid-template-columns:1.05fr repeat(4,1fr);
  gap:0;
  overflow:hidden;
}

.conditions-visual .condition-main,
.conditions-visual .condition-item{
  padding:24px;
  border-right:1px solid rgba(255,255,255,.10);
}

.conditions-visual .condition-main{
  display:flex;
  align-items:center;
  gap:18px;
}

.conditions-visual .condition-item:last-child{
  border-right:0;
}

.condition-big-icon{
  display:grid;
  place-items:center;
  width:76px;
  height:76px;
  flex:0 0 auto;
  border-radius:50%;
  background:radial-gradient(circle at 30% 20%,#fff,rgba(0,229,255,.20));
  font-size:34px;
}

.condition-item{
  display:grid;
  grid-template-columns:48px 1fr;
  gap:12px;
  align-items:start;
}

.condition-icon{
  width:48px;
  height:48px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,rgba(0,229,255,.35),rgba(124,60,255,.35));
  border:1px solid rgba(0,229,255,.38);
  font-size:24px;
}

.condition-item b{
  color:#fff;
  display:block;
  margin-bottom:4px;
}

.condition-item span{
  color:var(--muted);
  font-size:13px;
  line-height:1.65;
}

@media(min-width:901px){
  .cards{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
}

@media(max-width:1100px){
  .header .menu{
    margin-right:10px;
  }
  .lang-btn{
    padding:10px 14px;
  }
}

@media(max-width:900px){
  .header .menu{
    display:none;
  }
  .lang-btn{
    margin-left:auto;
  }
  .conditions-visual{
    grid-template-columns:1fr;
  }
  .conditions-visual .condition-main,
  .conditions-visual .condition-item{
    border-right:0;
    border-bottom:1px solid rgba(255,255,255,.10);
  }
  .conditions-visual .condition-item:last-child{
    border-bottom:0;
  }
}

@media(max-width:640px){
  .header .nav{
    gap:8px;
  }
  .logo span{
    font-size:13px;
  }
  .lang-btn{
    padding:9px 11px;
    font-size:13px;
  }
  .lang-btn .flag{
    width:22px;
    height:15px;
    margin-right:5px;
  }
  .header .btn:not(.lang-btn){
    padding:10px 12px;
    font-size:13px;
  }
  .recruit-cards .card{
    min-height:auto;
  }
  .condition-main{
    flex-direction:column;
    align-items:flex-start !important;
  }
}


/* ===== Company page visual refinement ===== */
.breadcrumb {
  display:flex;
  gap:8px;
  align-items:center;
  color:var(--muted);
  font-size:14px;
  margin:34px 0 22px;
}

.breadcrumb a {
  color:var(--primary);
}

.company-page {
  padding-top:0;
}

.company-grid {
  display:grid;
  grid-template-columns:minmax(0, .95fr) minmax(0, 1.1fr);
  gap:34px;
  align-items:start;
}

.company-profile-card {
  border:1px solid rgba(0,229,255,.26);
  border-radius:28px;
  background:
    radial-gradient(circle at 12% 0%, rgba(0,229,255,.18), transparent 30%),
    rgba(255,255,255,.045);
  padding:34px;
  overflow:hidden;
  box-shadow:0 24px 70px rgba(0,0,0,.22);
}

.company-profile-card .company-title,
h1.company-title {
  margin:0 0 12px;
  font-size:clamp(24px,2.4vw,32px) !important;
  line-height:1.3 !important;
  letter-spacing:0 !important;
  word-break:break-word !important;
  overflow-wrap:break-word !important;
  line-break:auto !important;
}

.company-subtitle {
  margin:0 0 28px;
  font-size:clamp(18px,2vw,24px);
  color:#fff;
  font-weight:800;
}

.company-profile-card .lead {
  margin-bottom:28px;
}

.company-stats {
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
  margin:26px 0 30px;
}

.company-stat {
  min-height:142px;
  padding:22px 16px;
  border:1px solid rgba(255,255,255,.11);
  border-radius:18px;
  background:rgba(0,0,0,.16);
  text-align:center;
}

.company-stat-icon {
  display:grid;
  place-items:center;
  width:46px;
  height:46px;
  margin:0 auto 12px;
  border-radius:50%;
  border:1px solid rgba(0,229,255,.42);
  color:var(--primary);
  font-size:24px;
  box-shadow:0 0 20px rgba(0,229,255,.14);
}

.company-stat b {
  display:block;
  color:var(--primary);
  font-size:26px;
  line-height:1.2;
}

.company-stat span {
  color:var(--muted);
  font-size:13px;
}

.company-mission {
  display:grid;
  grid-template-columns:180px 1fr;
  gap:24px;
  align-items:center;
  padding:22px;
  border:1px solid rgba(0,229,255,.20);
  border-radius:20px;
  background:rgba(0,0,0,.16);
}

.city-line {
  min-height:112px;
  border-radius:16px;
  background:
    linear-gradient(to top, rgba(0,229,255,.18), transparent 34%),
    linear-gradient(90deg, transparent 0 8%, rgba(0,229,255,.5) 8% 9%, transparent 9% 16%, rgba(0,229,255,.35) 16% 17%, transparent 17% 30%, rgba(0,229,255,.45) 30% 31%, transparent 31% 42%, rgba(0,229,255,.35) 42% 43%, transparent 43% 62%, rgba(0,229,255,.45) 62% 63%, transparent 63% 78%, rgba(0,229,255,.3) 78% 79%, transparent 79%);
  border-bottom:1px solid rgba(0,229,255,.45);
  position:relative;
}

.city-line::before,
.city-line::after {
  content:"";
  position:absolute;
  bottom:0;
  border:1px solid rgba(0,229,255,.55);
  border-bottom:0;
}

.city-line::before {
  left:20px;
  width:52px;
  height:58px;
  clip-path:polygon(50% 0,100% 36%,100% 100%,0 100%,0 36%);
}

.city-line::after {
  right:26px;
  width:42px;
  height:86px;
  border-radius:22px 22px 0 0;
}

.company-mission h3 {
  color:var(--primary);
  margin:0 0 8px;
  font-size:18px;
}

.company-mission p {
  margin:0;
  color:#fff;
  line-height:1.9;
}

.company-info-table {
  border:1px solid var(--line);
  border-radius:26px;
  overflow:hidden;
  background:rgba(255,255,255,.045);
  box-shadow:0 24px 70px rgba(0,0,0,.18);
}

.company-info-row {
  display:grid;
  grid-template-columns:260px 1fr;
  min-height:72px;
  border-bottom:1px solid rgba(255,255,255,.10);
}

.company-info-row:last-child {
  border-bottom:0;
}

.company-info-label {
  display:flex;
  align-items:center;
  gap:16px;
  padding:18px 22px;
  border-right:1px solid rgba(255,255,255,.10);
  color:#fff;
  font-weight:900;
}

.company-info-icon {
  display:grid;
  place-items:center;
  width:34px;
  height:34px;
  font-size:24px;
  color:var(--primary);
  flex:0 0 auto;
}

.company-info-value {
  padding:18px 22px;
  color:#dceaff;
  line-height:1.85;
  word-break:keep-all;
  overflow-wrap:break-word;
}

.company-info-value small {
  color:var(--muted);
  font-size:15px;
}

@media(max-width:1000px){
  .company-grid {
    grid-template-columns:1fr;
  }
  .company-info-row {
    grid-template-columns:220px 1fr;
  }
}

@media(max-width:640px){
  .company-profile-card {
    padding:24px;
  }
  .company-title {
    font-size:clamp(22px,6.5vw,28px);
    word-break:break-word;
    overflow-wrap:break-word;
    line-break:auto;
  }
  .company-stats {
    grid-template-columns:1fr;
  }
  .company-mission {
    grid-template-columns:1fr;
  }
  .company-info-row {
    grid-template-columns:1fr;
  }
  .company-info-label {
    border-right:0;
    border-bottom:1px solid rgba(255,255,255,.08);
    padding-bottom:10px;
  }
  .company-info-value {
    padding-top:12px;
  }
}


/* ===== Security policy / ISMS footer ===== */
.footer {
  border-top: 1px solid var(--line);
  padding: 28px 0;
}

.footer-inner {
  display: grid;
  grid-template-columns: 260px 1fr auto;
  align-items: center;
  gap: 28px;
}

.footer-isms {
  display: flex;
  align-items: center;
}

.footer-isms img {
  width: 220px;
  max-width: 100%;
  height: auto;
  display: block;
  background: #fff;
  border-radius: 4px;
}

.footer-policy {
  display: flex;
  justify-content: center;
  align-items: center;
}

.footer-policy a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #eaf6ff;
  font-weight: 700;
  text-decoration: none;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.035);
}

.footer-policy a:hover {
  color: var(--primary);
  border-color: rgba(0,229,255,.35);
}

.footer-copy {
  color: var(--muted);
  white-space: nowrap;
}

@media(max-width: 900px) {
  .footer-inner {
    grid-template-columns: 1fr;
    text-align: center;
    gap: 18px;
  }

  .footer-isms,
  .footer-policy {
    justify-content: center;
  }

  .footer-copy {
    white-space: normal;
  }

  .footer-isms img {
    width: min(260px, 90vw);
  }
}

@media(max-width: 480px) {
  .footer {
    padding: 24px 0;
  }

  .footer-policy a {
    width: 100%;
    justify-content: center;
    border-radius: 16px;
  }
}


/* final footer alignment fix */
.footer-inner{
  grid-template-columns: 260px 1fr;
}

.footer-right{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  justify-content:center;
  gap:12px;
}

.footer-policy{
  justify-content:flex-end;
}

.footer-copy{
  text-align:right;
}

@media(max-width:900px){
  .footer-inner{
    grid-template-columns:1fr;
  }

  .footer-right{
    align-items:center;
  }

  .footer-copy{
    text-align:center;
  }

  .footer-policy{
    justify-content:center;
  }
}


/* ===== SVG icons via CSS mask (2026-05-26 追加) ===== */
.ico{display:inline-block;width:1em;height:1em;background:currentColor;mask-repeat:no-repeat;mask-position:center;mask-size:contain;-webkit-mask-repeat:no-repeat;-webkit-mask-position:center;-webkit-mask-size:contain;vertical-align:-0.18em;flex-shrink:0}
.card .icon{font-size:0;color:var(--primary)}
.card .icon .ico{width:26px;height:26px}
.company-info-icon{display:inline-flex;align-items:center;justify-content:center;width:1.3em;height:1.3em;margin-right:6px;color:var(--primary)}
.company-stat-icon{display:inline-flex;align-items:center;justify-content:center;width:1.5em;height:1.5em;color:var(--primary)}

.ico-bot{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='4' y='8' width='16' height='10' rx='2'/%3E%3Cpath d='M12 8V4M9 4h6'/%3E%3Ccircle cx='9' cy='13' r='1' fill='black'/%3E%3Ccircle cx='15' cy='13' r='1' fill='black'/%3E%3Cpath d='M10 16h4M3 13v2M21 13v2'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='4' y='8' width='16' height='10' rx='2'/%3E%3Cpath d='M12 8V4M9 4h6'/%3E%3Ccircle cx='9' cy='13' r='1' fill='black'/%3E%3Ccircle cx='15' cy='13' r='1' fill='black'/%3E%3Cpath d='M10 16h4M3 13v2M21 13v2'/%3E%3C/svg%3E")}
.ico-laptop{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='5' width='18' height='11' rx='2'/%3E%3Cpath d='M2 20h20'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='5' width='18' height='11' rx='2'/%3E%3Cpath d='M2 20h20'/%3E%3C/svg%3E")}
.ico-cloud{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 17a4 4 0 0 1 0-8 5 5 0 0 1 9.6-1.5A4 4 0 1 1 18 17H7Z'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 17a4 4 0 0 1 0-8 5 5 0 0 1 9.6-1.5A4 4 0 1 1 18 17H7Z'/%3E%3C/svg%3E")}
.ico-lock{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='5' y='11' width='14' height='9' rx='2'/%3E%3Cpath d='M8 11V8a4 4 0 1 1 8 0v3'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='5' y='11' width='14' height='9' rx='2'/%3E%3Cpath d='M8 11V8a4 4 0 1 1 8 0v3'/%3E%3C/svg%3E")}
.ico-game{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 8h10a4 4 0 0 1 0 8 3 3 0 0 1-2.5-1.5l-1-1.5h-3l-1 1.5A3 3 0 0 1 7 16a4 4 0 0 1 0-8z'/%3E%3Cpath d='M9 12h2M10 11v2M15 12h.01M17 13h.01'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 8h10a4 4 0 0 1 0 8 3 3 0 0 1-2.5-1.5l-1-1.5h-3l-1 1.5A3 3 0 0 1 7 16a4 4 0 0 1 0-8z'/%3E%3Cpath d='M9 12h2M10 11v2M15 12h.01M17 13h.01'/%3E%3C/svg%3E")}
.ico-globe{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cpath d='M3 12h18M12 3a14 14 0 0 1 0 18M12 3a14 14 0 0 0 0 18'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cpath d='M3 12h18M12 3a14 14 0 0 1 0 18M12 3a14 14 0 0 0 0 18'/%3E%3C/svg%3E")}
.ico-calendar{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='5' width='18' height='16' rx='2'/%3E%3Cpath d='M3 10h18M8 3v4M16 3v4'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='5' width='18' height='16' rx='2'/%3E%3Cpath d='M3 10h18M8 3v4M16 3v4'/%3E%3C/svg%3E")}
.ico-yen{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 4l5 7 5-7M12 11v9M7 14h10M7 17h10'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 4l5 7 5-7M12 11v9M7 14h10M7 17h10'/%3E%3C/svg%3E")}
.ico-users{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='9' r='3'/%3E%3Cpath d='M3 19a6 6 0 0 1 12 0'/%3E%3Ccircle cx='17' cy='9' r='2.5'/%3E%3Cpath d='M15 19a5 5 0 0 1 6-4'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='9' r='3'/%3E%3Cpath d='M3 19a6 6 0 0 1 12 0'/%3E%3Ccircle cx='17' cy='9' r='2.5'/%3E%3Cpath d='M15 19a5 5 0 0 1 6-4'/%3E%3C/svg%3E")}
.ico-building{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='4' y='3' width='16' height='18' rx='1'/%3E%3Cpath d='M8 7h2M14 7h2M8 11h2M14 11h2M8 15h2M14 15h2M10 21v-4h4v4'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='4' y='3' width='16' height='18' rx='1'/%3E%3Cpath d='M8 7h2M14 7h2M8 11h2M14 11h2M8 15h2M14 15h2M10 21v-4h4v4'/%3E%3C/svg%3E")}
.ico-pin{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 22s-7-7-7-13a7 7 0 1 1 14 0c0 6-7 13-7 13z'/%3E%3Ccircle cx='12' cy='9' r='2.5'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 22s-7-7-7-13a7 7 0 1 1 14 0c0 6-7 13-7 13z'/%3E%3Ccircle cx='12' cy='9' r='2.5'/%3E%3C/svg%3E")}
.ico-phone{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 4h3l2 5-2 1a11 11 0 0 0 6 6l1-2 5 2v3a2 2 0 0 1-2 2A16 16 0 0 1 3 6a2 2 0 0 1 2-2z'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 4h3l2 5-2 1a11 11 0 0 0 6 6l1-2 5 2v3a2 2 0 0 1-2 2A16 16 0 0 1 3 6a2 2 0 0 1 2-2z'/%3E%3C/svg%3E")}
.ico-user{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='8' r='4'/%3E%3Cpath d='M4 21a8 8 0 0 1 16 0'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='8' r='4'/%3E%3Cpath d='M4 21a8 8 0 0 1 16 0'/%3E%3C/svg%3E")}
.ico-mail{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='5' width='18' height='14' rx='2'/%3E%3Cpath d='M3 7l9 6 9-6'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='5' width='18' height='14' rx='2'/%3E%3Cpath d='M3 7l9 6 9-6'/%3E%3C/svg%3E")}
.ico-briefcase{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='7' width='18' height='13' rx='2'/%3E%3Cpath d='M9 7V5a2 2 0 0 1 2-2h2a2 2 0 0 1 2 2v2M3 13h18'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='7' width='18' height='13' rx='2'/%3E%3Cpath d='M9 7V5a2 2 0 0 1 2-2h2a2 2 0 0 1 2 2v2M3 13h18'/%3E%3C/svg%3E")}
.ico-graduation{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M2 9l10-5 10 5-10 5L2 9z'/%3E%3Cpath d='M6 11v5c0 1.5 3 3 6 3s6-1.5 6-3v-5'/%3E%3Cpath d='M22 9v6'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M2 9l10-5 10 5-10 5L2 9z'/%3E%3Cpath d='M6 11v5c0 1.5 3 3 6 3s6-1.5 6-3v-5'/%3E%3Cpath d='M22 9v6'/%3E%3C/svg%3E")}
.ico-rocket{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14 4c4 0 6 2 6 6-2 0-4 1-5 2l-3 3-3-3 3-3c1-1 2-3 2-5z'/%3E%3Cpath d='M9 12l-3 3a3 3 0 0 0 0 4 3 3 0 0 0 4 0l3-3'/%3E%3Ccircle cx='15' cy='9' r='1.2'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14 4c4 0 6 2 6 6-2 0-4 1-5 2l-3 3-3-3 3-3c1-1 2-3 2-5z'/%3E%3Cpath d='M9 12l-3 3a3 3 0 0 0 0 4 3 3 0 0 0 4 0l3-3'/%3E%3Ccircle cx='15' cy='9' r='1.2'/%3E%3C/svg%3E")}
.ico-sprout{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 22V10'/%3E%3Cpath d='M12 14c0-3-3-5-7-5 0 4 3 7 7 7z'/%3E%3Cpath d='M12 11c0-3 3-5 7-5 0 4-3 6-7 6z'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 22V10'/%3E%3Cpath d='M12 14c0-3-3-5-7-5 0 4 3 7 7 7z'/%3E%3Cpath d='M12 11c0-3 3-5 7-5 0 4-3 6-7 6z'/%3E%3C/svg%3E")}
.ico-chart{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 17l5-5 4 4 8-9'/%3E%3Cpath d='M14 7h6v6'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 17l5-5 4 4 8-9'/%3E%3Cpath d='M14 7h6v6'/%3E%3C/svg%3E")}
.ico-handshake{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 13l4-4 3 3 4-4 4 4 3-3'/%3E%3Cpath d='M11 12l-2 2a1.5 1.5 0 0 0 0 2 1.5 1.5 0 0 0 2 0l1-1'/%3E%3Cpath d='M13 14l1 1a1.5 1.5 0 0 0 2 0 1.5 1.5 0 0 0 0-2'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 13l4-4 3 3 4-4 4 4 3-3'/%3E%3Cpath d='M11 12l-2 2a1.5 1.5 0 0 0 0 2 1.5 1.5 0 0 0 2 0l1-1'/%3E%3Cpath d='M13 14l1 1a1.5 1.5 0 0 0 2 0 1.5 1.5 0 0 0 0-2'/%3E%3C/svg%3E")}
.ico-teacher{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='7' r='3'/%3E%3Cpath d='M3 20a6 6 0 0 1 12 0'/%3E%3Crect x='15' y='5' width='6' height='9' rx='1'/%3E%3Cpath d='M16 9h4M16 12h4'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='7' r='3'/%3E%3Cpath d='M3 20a6 6 0 0 1 12 0'/%3E%3Crect x='15' y='5' width='6' height='9' rx='1'/%3E%3Cpath d='M16 9h4M16 12h4'/%3E%3C/svg%3E")}
.ico-hands{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 11V5a1.5 1.5 0 0 1 3 0v6'/%3E%3Cpath d='M12 11V4a1.5 1.5 0 0 1 3 0v7'/%3E%3Cpath d='M15 11V6a1.5 1.5 0 0 1 3 0v8a6 6 0 0 1-12 0v-4a1.5 1.5 0 0 1 3 0v1'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 11V5a1.5 1.5 0 0 1 3 0v6'/%3E%3Cpath d='M12 11V4a1.5 1.5 0 0 1 3 0v7'/%3E%3Cpath d='M15 11V6a1.5 1.5 0 0 1 3 0v8a6 6 0 0 1-12 0v-4a1.5 1.5 0 0 1 3 0v1'/%3E%3C/svg%3E")}
.ico-medal{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='15' r='5'/%3E%3Cpath d='M8 10L5 3h4l2 5M16 10l3-7h-4l-2 5'/%3E%3Cpath d='M12 12v3M10 15l2 2 2-2'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='15' r='5'/%3E%3Cpath d='M8 10L5 3h4l2 5M16 10l3-7h-4l-2 5'/%3E%3Cpath d='M12 12v3M10 15l2 2 2-2'/%3E%3C/svg%3E")}
.ico-check{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cpath d='M8 12l3 3 5-6'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cpath d='M8 12l3 3 5-6'/%3E%3C/svg%3E")}
.ico-clipboard{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='5' y='4' width='14' height='17' rx='2'/%3E%3Crect x='9' y='2' width='6' height='4' rx='1'/%3E%3Cpath d='M9 11h6M9 14h6M9 17h4'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='5' y='4' width='14' height='17' rx='2'/%3E%3Crect x='9' y='2' width='6' height='4' rx='1'/%3E%3Cpath d='M9 11h6M9 14h6M9 17h4'/%3E%3C/svg%3E")}
.ico-clock{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cpath d='M12 7v5l3 2'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cpath d='M12 7v5l3 2'/%3E%3C/svg%3E")}
.ico-heart{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 21s-7-4.5-7-10a4 4 0 0 1 7-2.5A4 4 0 0 1 19 11c0 5.5-7 10-7 10z'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 21s-7-4.5-7-10a4 4 0 0 1 7-2.5A4 4 0 0 1 19 11c0 5.5-7 10-7 10z'/%3E%3C/svg%3E")}
.ico-doc{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14 3H7a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V8z'/%3E%3Cpath d='M14 3v5h5M9 13h6M9 17h4'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14 3H7a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V8z'/%3E%3Cpath d='M14 3v5h5M9 13h6M9 17h4'/%3E%3C/svg%3E")}
.ico-chat{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 6a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v9a2 2 0 0 1-2 2H10l-4 4v-4H6a2 2 0 0 1-2-2z'/%3E%3Cpath d='M8 10h8M8 13h5'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 6a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v9a2 2 0 0 1-2 2H10l-4 4v-4H6a2 2 0 0 1-2-2z'/%3E%3Cpath d='M8 10h8M8 13h5'/%3E%3C/svg%3E")}
.ico-memo{mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 4h10l4 4v12a1 1 0 0 1-1 1H5a1 1 0 0 1-1-1V5a1 1 0 0 1 1-1z'/%3E%3Cpath d='M15 4v4h4M8 13h8M8 16h5'/%3E%3Cpath d='M14 18l2-2 2 2-2 2z' fill='black'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 4h10l4 4v12a1 1 0 0 1-1 1H5a1 1 0 0 1-1-1V5a1 1 0 0 1 1-1z'/%3E%3Cpath d='M15 4v4h4M8 13h8M8 16h5'/%3E%3Cpath d='M14 18l2-2 2 2-2 2z' fill='black'/%3E%3C/svg%3E")}

/* 採用関連の特殊スタイル */
.condition-icon .ico,
.condition-big-icon .ico,
.vp-icon .ico{font-size:1em;color:var(--primary)}
.condition-big-icon{font-size:38px}
.condition-icon{font-size:22px}
.vp-icon{font-size:18px}

/* ===== Footer with contact info (2026-05-26 追加・右寄せ2カラム化) ===== */
.footer-inner{display:grid;grid-template-columns:auto 1fr;align-items:start;gap:28px;justify-content:initial}
.footer-isms{grid-column:1;grid-row:1 / span 2;align-self:center}
.footer-contact{grid-column:2;grid-row:1;justify-self:end;display:flex;flex-direction:column;gap:6px;font-size:13px;line-height:1.6;color:var(--muted);text-align:right;max-width:520px}
.footer-contact .footer-company{color:var(--text);font-weight:700;letter-spacing:.02em;margin-bottom:4px;font-size:14px}
.footer-contact > div{display:flex;gap:8px;align-items:flex-start;justify-content:flex-end}
.footer-contact .ico{color:var(--primary);font-size:14px;margin-top:3px;flex-shrink:0}
.footer-contact a{color:var(--muted)}
.footer-contact a:hover{color:var(--primary)}
.footer-right{grid-column:2;grid-row:2;justify-self:end;margin-top:4px}
@media(max-width:900px){
  .footer-inner{grid-template-columns:1fr;justify-items:center}
  .footer-isms{grid-row:auto}
  .footer-contact{grid-column:1;justify-self:center;text-align:center;max-width:100%}
  .footer-contact > div{justify-content:center}
  .footer-right{grid-column:1;justify-self:center}
}


/* ===== Numbers section (Phase 1 / 2026-05-26) ===== */
.numbers-section{padding:64px 0}
.numbers-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:8px}
.number-card{padding:32px 22px;border-radius:20px;border:1px solid var(--line);background:linear-gradient(180deg,var(--card),rgba(9,18,35,.65));text-align:center;transition:transform .2s ease,border-color .2s ease,background .2s ease}
.number-card:hover{transform:translateY(-4px);border-color:rgba(0,229,255,.46);background:linear-gradient(180deg,var(--card2),rgba(9,18,35,.76))}
.number-value{font-size:54px;font-weight:800;line-height:1;letter-spacing:-.04em;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent;display:inline-flex;align-items:baseline}
.number-unit{font-size:22px;margin-left:4px;-webkit-text-fill-color:initial;color:var(--text);background:none;font-weight:700}
.number-label{margin-top:12px;color:var(--muted);font-size:13px;letter-spacing:.04em}
@media(max-width:900px){.numbers-grid{grid-template-columns:repeat(2,1fr)}.number-value{font-size:44px}}
@media(max-width:520px){.numbers-grid{grid-template-columns:1fr}}

/* ===== CTA actions (multi-button row) ===== */
.cta-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px}
.cta-actions .btn{padding:14px 22px}
.btn .ico{font-size:16px;margin-right:2px}
@media(max-width:520px){.cta-actions .btn{width:100%}}

/* ===== Greeting page ===== */
.greeting-grid{display:grid;grid-template-columns:1.4fr .9fr;gap:28px;margin-top:8px}
.greeting-text p{color:var(--muted);margin:0 0 14px;line-height:1.95}
.greeting-text h2{margin-top:8px}
.greeting-sign{color:var(--text)!important;font-weight:700;text-align:right;line-height:1.9;margin-top:30px!important;padding-top:20px;border-top:1px solid var(--line)}
.greeting-side{display:flex;flex-direction:column;gap:18px}
.greeting-mission h3{margin:14px 0 6px;font-size:42px;letter-spacing:.45em;text-align:center;color:var(--primary);font-weight:800;line-height:1.2}
.philosophy-statement{margin:6px 0 0;color:var(--muted);font-size:13px;line-height:1.7;text-align:center}
.greeting-value-list{list-style:none;margin:8px 0 0;padding:0;display:grid;gap:12px}
.greeting-value-list li{padding:14px;border-radius:14px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.08);display:grid;gap:4px}
.greeting-value-list b{color:var(--primary);font-size:14px;letter-spacing:.04em}
.greeting-value-list span{color:var(--muted);font-size:13px}
.breadcrumb{color:var(--muted);font-size:13px;margin-bottom:18px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{color:var(--primary)}
@media(max-width:900px){.greeting-grid{grid-template-columns:1fr}}

/* ===== company.html ↔ greeting.html リンクカード ===== */
.greeting-link-card{display:flex;align-items:center;gap:18px;padding:18px 22px;margin-top:18px;border-radius:18px;border:1px solid rgba(0,229,255,.28);background:rgba(0,229,255,.06);transition:border-color .2s ease,background .2s ease;color:inherit}
.greeting-link-card:hover{border-color:rgba(0,229,255,.55);background:rgba(0,229,255,.10)}
.greeting-link-card .ico{font-size:22px;color:var(--primary)}
.greeting-link-card .greeting-link-text{flex:1}
.greeting-link-card .greeting-link-text b{display:block;color:var(--text);margin-bottom:2px}
.greeting-link-card .greeting-link-text span{color:var(--muted);font-size:13px}
.greeting-link-card .greeting-link-arrow{color:var(--primary);font-weight:800}

/* ===== News list page (2026-05-26 Phase 3) ===== */
.news-list{display:grid;gap:18px;margin-top:8px}
.news-entry{padding:28px;border-radius:22px;border:1px solid var(--line);background:linear-gradient(180deg,var(--card),rgba(9,18,35,.65));scroll-margin-top:96px;transition:border-color .2s ease,background .2s ease}
.news-entry:target{border-color:rgba(0,229,255,.55);background:linear-gradient(180deg,var(--card2),rgba(9,18,35,.78));box-shadow:var(--shadow)}
.news-entry-meta{display:flex;gap:14px;align-items:center;margin-bottom:10px}
.news-entry-meta time{color:var(--primary);font-weight:800;font-size:14px;letter-spacing:.04em}
.news-entry-cat{padding:3px 10px;border-radius:999px;background:rgba(0,229,255,.12);border:1px solid rgba(0,229,255,.32);color:#bff7ff;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.news-entry h2{margin:6px 0 12px;font-size:clamp(20px,2.4vw,26px);line-height:1.35}
.news-entry p{margin:0 0 12px;color:var(--muted);line-height:1.85}
.news-entry-link{display:inline-flex;align-items:center;gap:4px;color:var(--primary);font-weight:700;font-size:14px}
.news-entry-link:hover{text-decoration:underline}
/* Security Policy page */
.policy-grid{display:grid;grid-template-columns:1.5fr .8fr;gap:24px;margin-top:8px;align-items:start}
.policy-main{padding:36px}
.policy-list{list-style:none;margin:14px 0 0;padding:0;display:grid;gap:18px}
.policy-list li{display:grid;grid-template-columns:64px 1fr;gap:18px;padding:22px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.04)}
.policy-no{font-size:28px;font-weight:800;line-height:1;letter-spacing:-.02em;color:var(--primary);font-family:"Inter","Helvetica Neue",sans-serif}
.policy-body h3{margin:0 0 6px;font-size:17px}
.policy-body p{margin:0;color:var(--muted);line-height:1.85;font-size:14px}
.policy-sign{margin-top:34px;padding-top:24px;border-top:1px solid var(--line);text-align:right;line-height:1.9}
.policy-sign-date{color:var(--muted);font-size:13px}
.policy-sign-org{color:var(--text);font-weight:700}
.policy-sign-name{color:var(--text);font-weight:700;font-size:18px;letter-spacing:.05em}
.policy-side{display:flex;flex-direction:column;gap:18px;position:sticky;top:96px}
.policy-cert{padding:24px;text-align:center}
.policy-cert img{max-width:120px;margin:0 auto 10px;display:block}
.policy-cert h3{margin:8px 0 6px}
.policy-cert p{color:var(--muted);font-size:13px;margin:0}
.policy-pdf{padding:24px}
.policy-pdf h3{margin:8px 0 8px}
.policy-pdf p{color:var(--muted);font-size:13px;margin:0 0 14px}
@media(max-width:900px){.policy-grid{grid-template-columns:1fr}.policy-side{position:static}.policy-main{padding:24px}.policy-list li{grid-template-columns:48px 1fr;padding:16px}}

/* Privacy page */
.privacy-article{padding:32px;margin-bottom:18px}
.privacy-article h2{margin:8px 0 14px}
.privacy-article p{color:var(--muted);margin:0 0 10px;line-height:1.85}
.privacy-article .list{margin-top:14px}
.privacy-article .row{grid-template-columns:160px 1fr}
.privacy-meta{color:var(--muted);font-size:13px;text-align:center;margin-top:24px}
.privacy-meta a{color:var(--primary)}

.news-entry-image{margin-top:18px;padding:18px;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:14px;display:flex;justify-content:center;align-items:center}
.news-entry-image img{max-width:220px;max-height:160px;height:auto;display:block}
@media(max-width:520px){.news-entry-image img{max-width:160px}}

/* ===== Access section (2026-05-26 Phase 3) ===== */
.access-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:24px;margin-top:8px}
.access-info{padding:28px}
.access-info .row{grid-template-columns:120px 1fr}
.access-map{min-height:340px;border-radius:18px;overflow:hidden;border:1px solid var(--line)}
.access-map iframe{display:block;width:100%;height:100%;min-height:340px}
@media(max-width:900px){.access-grid{grid-template-columns:1fr}}

/* ===== スマホでの折返し修正（2026-05-26 / 右端切れ対策） ===== */
@media(max-width:640px){
  h1,h2,h3,h4,p,li,
  .lead,.section-head p,.card p,.row span,.list li,.news a span,
  .cta-box h2,.cta-box p,
  .glass p,.glass h2,.glass h3,
  .footer-contact,.footer-contact span{
    word-break:break-word !important;
    overflow-wrap:break-word !important;
    line-break:auto !important;
  }
  .cta-box h2{font-size:clamp(20px,6vw,26px);line-height:1.4}
  .hero h1{font-size:clamp(28px,8vw,38px);line-height:1.22}
  .section-head h2{font-size:clamp(22px,6.5vw,30px)}
  .hero .lead{font-size:15px;line-height:1.7}
  /* コンテナはみ出し対策 */
  body,main,section{overflow-x:hidden}
}
@media(max-width:520px){
  .cta-box{padding:24px 18px}
  .cta-box h2{font-size:20px;line-height:1.45}
  .hero-actions .btn,.cta-actions .btn{width:100%}
}

/* SNS Links (2026-05-26) */
.ico-x{mask-image:url("data:image/svg+xml;charset=utf-8,<svg%20xmlns='http%3A//www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='black'><path%20d='M18.244%202.25h3.308l-7.227%208.26%208.502%2011.24H16.17l-5.214-6.817L4.99%2021.75H1.68l7.73-8.835L1.254%202.25H8.08l4.713%206.231zm-1.161%2017.52h1.833L7.084%204.126H5.117z'/></svg>");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,<svg%20xmlns='http%3A//www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='black'><path%20d='M18.244%202.25h3.308l-7.227%208.26%208.502%2011.24H16.17l-5.214-6.817L4.99%2021.75H1.68l7.73-8.835L1.254%202.25H8.08l4.713%206.231zm-1.161%2017.52h1.833L7.084%204.126H5.117z'/></svg>")}
.ico-facebook{mask-image:url("data:image/svg+xml;charset=utf-8,<svg%20xmlns='http%3A//www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='black'><path%20d='M9.101%2023.691v-7.98H6.627v-3.667h2.474v-1.58c0-4.085%201.848-5.978%205.858-5.978.401%200%20.955.042%201.468.103a8.68%208.68%200%200%201%201.141.195v3.325a8.623%208.623%200%200%200-.653-.036%2026.805%2026.805%200%200%200-.733-.009c-.707%200-1.259.096-1.675.309a1.686%201.686%200%200%200-.679.622c-.258.42-.374.995-.374%201.752v1.297h3.919l-.386%202.103-.287%201.564h-3.246v8.245C19.396%2023.238%2024%2018.179%2024%2012.044c0-6.627-5.373-12-12-12s-12%205.373-12%2012c0%205.628%203.874%2010.35%209.101%2011.647Z'/></svg>");-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,<svg%20xmlns='http%3A//www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='black'><path%20d='M9.101%2023.691v-7.98H6.627v-3.667h2.474v-1.58c0-4.085%201.848-5.978%205.858-5.978.401%200%20.955.042%201.468.103a8.68%208.68%200%200%201%201.141.195v3.325a8.623%208.623%200%200%200-.653-.036%2026.805%2026.805%200%200%200-.733-.009c-.707%200-1.259.096-1.675.309a1.686%201.686%200%200%200-.679.622c-.258.42-.374.995-.374%201.752v1.297h3.919l-.386%202.103-.287%201.564h-3.246v8.245C19.396%2023.238%2024%2018.179%2024%2012.044c0-6.627-5.373-12-12-12s-12%205.373-12%2012c0%205.628%203.874%2010.35%209.101%2011.647Z'/></svg>")}
.footer-sns{display:flex;gap:14px;margin-top:16px;font-size:22px}
.footer-sns a{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid var(--line);color:var(--muted);transition:all .25s ease;text-decoration:none}
.footer-sns a:hover{color:var(--primary);background:rgba(0,229,255,.12);border-color:rgba(0,229,255,.4);transform:translateY(-2px)}
.footer-sns .ico{font-size:18px}

/* カードはみ出し対策 (2026-05-27) */
.card,.card h3,.card p{overflow-wrap:break-word;word-break:normal}
.row,.row span,.row b{overflow-wrap:break-word;min-width:0}

/* グリッドはみ出し対策 (2026-05-27) */
html,body{overflow-x:clip;max-width:100%}
.split,.cards,.process-flow,.process-flow-item,.table{min-width:0}
.split>*,.cards>*,.card,.process-flow-item>*,.process-flow-body,.row,.row>*{min-width:0}
.glass,.glass *,.card,.card *,.process-flow-body,.process-flow-text,.row span{overflow-wrap:anywhere}
.card{overflow:hidden}

/* split-h2-fix: split内見出しを縮小してカラム内に収める (2026-05-27) */
.split h2{font-size:clamp(22px,2.6vw,30px);line-height:1.3}

/* ===== モバイル用ハンバーガーメニュー (2026-05-27) ===== */
.nav-toggle{position:absolute;opacity:0;width:1px;height:1px;pointer-events:none}
.nav-burger{display:none;cursor:pointer;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.05);color:var(--text);font-size:22px;line-height:1;-webkit-user-select:none;user-select:none;flex:0 0 auto}
.nav-burger:hover{border-color:rgba(0,229,255,.5)}
@media(max-width:900px){
  .nav-burger{display:inline-flex;order:10}
  .nav-toggle:checked ~ .menu{
    display:flex;flex-direction:column;gap:4px;
    position:absolute;top:calc(100% + 1px);right:0;
    min-width:220px;max-width:min(90vw,300px);padding:12px;
    background:rgba(5,8,22,.98);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
    border:1px solid var(--line);border-radius:14px;
    box-shadow:0 18px 44px rgba(0,0,0,.45);z-index:30;
  }
  .nav-toggle:checked ~ .menu a{padding:12px 14px;border-radius:10px;font-size:15px}
  .nav-toggle:checked ~ .menu a:hover{background:rgba(0,229,255,.10)}
}

/* ===== News アコーディオン (2026-05-27) ===== */
details.news-entry > summary{list-style:none;cursor:pointer;outline:none}
details.news-entry > summary::-webkit-details-marker{display:none}
details.news-entry > summary{position:relative;padding-right:40px}
details.news-entry > summary h2{margin:6px 0 0;font-size:20px;display:block}
details.news-entry > summary::after{content:"＋";position:absolute;right:6px;top:50%;transform:translateY(-50%);color:var(--primary);font-size:22px;font-weight:700;line-height:1}
details.news-entry[open] > summary::after{content:"−"}
details.news-entry .news-entry-body{margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.news-entry-cat.cat-x{color:var(--primary);border-color:rgba(0,229,255,.4)}

/* ===== 図解の横スクロール (スマホで縮みすぎ防止) (2026-05-27) ===== */
.fig-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
.fig-hint{display:none}
@media(max-width:680px){
  .fig-scroll svg{min-width:600px}
  .fig-hint{display:block;text-align:center;color:var(--muted);font-size:11px;margin-top:6px}
}
