/*
Theme Name: KANAE Original Template
Author: KANAE
Description: HTML/CSS/JS完全再現用テーマ
Version: 1.0
*/
/* ══════════════════════════════════════
   ROOT & RESET
══════════════════════════════════════ */
:root{
  --navy:      #0a1628;
  --navy-mid:  #142040;
  --navy-lite: #1c2f58;
  --yellow:    #e8b840;
  --yellow-d:  rgba(232,184,64,.15);
  --gold:      #a87c42;
  --cream:     #f8f7f3;
  --offwhite:  #f2f0ea;
  --white:     #ffffff;
  --gray-1:    #b8c0cc;
  --gray-2:    #7a8494;
  --text:      #2a3040;
  --text-sub:  #56606e;
  --ln:        rgba(10,22,40,.08);
  --ln-mid:    rgba(10,22,40,.14);
  --ln-dark:   rgba(10,22,40,.22);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--cream);
  color:var(--text);
  font-family:'Noto Sans JP',sans-serif;
  font-weight:300;
  font-size:15px;
  line-height:1.8;
  overflow-x:hidden;
}

/* ══════════════════════════════════════
   KEYFRAMES
══════════════════════════════════════ */
@keyframes heroKanaePulse{
  0%,100%{transform:scale(1) rotate(0deg);opacity:1}
  50%    {transform:scale(1.06) rotate(.8deg);opacity:.88}
}
@keyframes heroCellFloat{
  0%    {transform:translate(0,0) scale(1)}
  25%   {transform:translate(22px,-16px) scale(1.04)}
  50%   {transform:translate(-14px,20px) scale(.97)}
  75%   {transform:translate(18px,10px) scale(1.03)}
  100%  {transform:translate(0,0) scale(1)}
}
@keyframes archDrift{
  0%,100%{transform:translateY(0) rotate(0deg);opacity:.055}
  50%    {transform:translateY(-18px) rotate(1.2deg);opacity:.08}
}
@keyframes cellBreath{
  0%,100%{transform:scale(1);opacity:.05}
  50%    {transform:scale(1.07);opacity:.08}
}
@keyframes netDrift{
  0%,100%{transform:translate(0,0) scale(1);opacity:.045}
  50%    {transform:translate(-20px,12px) scale(1.05);opacity:.07}
}
@keyframes orbitRing{
  0%  {transform:rotate(0deg)}
  100%{transform:rotate(360deg)}
}
@keyframes fadeUp{
  from{opacity:0;transform:translateY(28px)}
  to  {opacity:1;transform:translateY(0)}
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scrollTick{
  0%  {transform:scaleY(0) translateY(0);opacity:1;transform-origin:top}
  45% {transform:scaleY(1) translateY(0);opacity:1;transform-origin:top}
  55% {transform:scaleY(1) translateY(0);opacity:1;transform-origin:bottom}
  100%{transform:scaleY(0) translateY(0);opacity:0;transform-origin:bottom}
}
@keyframes menuSlide{
  from{transform:translateX(100%)}
  to  {transform:translateX(0)}
}

/* ══════════════════════════════════════
   NAV
══════════════════════════════════════ */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:999;
  height:68px;display:flex;align-items:center;
  justify-content:space-between;padding:0 5%;
  background:rgba(10,22,40,.92);
  backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(232,184,64,.12);
  transition:background .4s;
}
.nav-logo{
  font-family:'DM Sans',sans-serif;font-weight:700;font-size:20px;
  color:var(--yellow);letter-spacing:.18em;text-decoration:none;
}
.nav-logo-sub{
  display:inline-block;margin-left:10px;
  font-family:'DM Mono',monospace;font-size:9px;font-weight:300;
  letter-spacing:.25em;color:var(--gray-1);opacity:.5;vertical-align:middle;
}
.nav-links{display:flex;gap:28px;list-style:none;align-items:center}
.nav-links a{
  font-family:'DM Mono',monospace;font-size:10px;font-weight:400;
  letter-spacing:.18em;color:var(--gray-1);text-decoration:none;
  text-transform:uppercase;transition:color .3s;
}
.nav-links a:hover{color:var(--yellow)}
.nav-cta{
  padding:9px 20px;border:1px solid rgba(232,184,64,.5);
  color:var(--yellow)!important;transition:background .3s,color .3s!important;
}
.nav-cta:hover{background:var(--yellow);color:var(--navy)!important}

/* hamburger */
.nav-hamburger{
  display:none;width:40px;height:40px;
  cursor:pointer;background:none;border:none;
  align-items:center;justify-content:center;
  position:relative;z-index:1001;
}
.nav-hamburger svg{pointer-events:none}

/* mobile menu */
.mobile-menu{
  display:none;
  position:fixed;top:0;right:0;bottom:0;width:75%;max-width:300px;z-index:1000;
  background:rgba(10,22,40,.98);
  backdrop-filter:blur(24px);
  border-left:1px solid rgba(232,184,64,.15);
  flex-direction:column;justify-content:center;padding:48px 40px;
  transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);
}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu ul{list-style:none}
.mobile-menu li{margin-bottom:28px}
.mobile-menu a{
  font-family:'DM Mono',monospace;font-size:12px;font-weight:400;
  letter-spacing:.22em;color:var(--gray-1);text-decoration:none;
  text-transform:uppercase;transition:color .3s;display:block;
}
.mobile-menu a:hover{color:var(--yellow)}
.mobile-menu-cta{
  margin-top:20px;display:block;text-align:center;
  padding:14px 24px;border:1px solid rgba(232,184,64,.4);
  font-family:'DM Mono',monospace;font-size:11px;font-weight:400;
  letter-spacing:.2em;color:var(--yellow);text-decoration:none;
  text-transform:uppercase;transition:background .3s,color .3s;
}
.mobile-menu-cta:hover{background:var(--yellow);color:var(--navy)}
.mobile-overlay{
  display:none;position:fixed;inset:0;z-index:998;
  background:rgba(0,0,0,.4);
}
.mobile-overlay.open{display:block}

@media(max-width:980px){
  .nav-links{display:none}
  .nav-hamburger{display:flex}
  .mobile-menu{display:flex}
}

/* ══════════════════════════════════════
   UTILITIES
══════════════════════════════════════ */
section{position:relative;overflow:hidden}
.wrap{width:min(1240px,90%);margin:0 auto;position:relative;z-index:2}

.lbl{
  font-family:'DM Mono',monospace;font-size:10px;font-weight:400;
  letter-spacing:.32em;text-transform:uppercase;color:var(--yellow);
  display:flex;align-items:center;gap:12px;margin-bottom:18px;
}
.lbl::before{content:'';display:block;width:24px;height:1px;background:var(--yellow);flex-shrink:0}

h2.sh{
  font-family:'Noto Sans JP',sans-serif;font-weight:700;
  font-size:clamp(26px,3.4vw,40px);line-height:1.2;
  letter-spacing:-.01em;margin-bottom:40px;
}
h2.sh em{font-style:normal;color:var(--gold)}

.reveal{
  opacity:0;transform:translateY(28px);
  transition:opacity .85s ease,transform .85s ease;
}
.reveal.vis{opacity:1;transform:translateY(0)}

/* abs SVG bg layer */
.bg-art{
  position:absolute;pointer-events:none;user-select:none;z-index:0;
  top:0;left:0;width:100%;height:100%;
}

/* ══════════════════════════════════════
   01 HERO
══════════════════════════════════════ */
#hero{
  min-height:100vh;background:var(--navy);
  display:flex;align-items:center;padding-top:68px;
}

/* ── Kanae hero line art ── */
.hero-kanae-art{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:min(900px,110vw);
  animation:heroKanaePulse 12s ease-in-out infinite;
  pointer-events:none;user-select:none;z-index:0;
}

/* cells overlay hero */
.hero-cell-art{
  position:absolute;
  top:0;right:0;
  width:55%;height:100%;
  animation:heroCellFloat 28s ease-in-out infinite;
  pointer-events:none;user-select:none;z-index:0;
  opacity:1;
}

@media(max-width:760px){
  .hero-kanae-art,.hero-cell-art{display:none}
}

.hero-inner{
  width:min(1240px,90%);margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;
  gap:40px;align-items:center;
  padding:80px 0 100px;
  position:relative;z-index:2;
}
@media(max-width:760px){
  .hero-inner{grid-template-columns:1fr;padding:60px 0 80px}
  .hero-right-space{display:none}
}

.hero-eyebrow{
  font-family:'DM Mono',monospace;font-size:10px;font-weight:400;
  letter-spacing:.32em;text-transform:uppercase;color:var(--yellow);
  display:flex;align-items:center;gap:12px;margin-bottom:24px;
  opacity:0;animation:fadeUp .8s ease .3s forwards;
}
.hero-eyebrow::before{content:'';display:block;width:24px;height:1px;background:var(--yellow)}

.hero-h1{
  font-family:'Noto Sans JP',sans-serif;font-weight:700;
  font-size:clamp(36px,5.5vw,64px);line-height:1.1;
  letter-spacing:-.02em;color:#f0ece2;
  opacity:0;animation:fadeUp 1s ease .5s forwards;
}
.hero-h1 .accent{color:var(--yellow);display:block}
.hero-h1 small{
  display:block;margin-top:14px;
  font-family:'DM Mono',monospace;font-weight:300;font-style:normal;
  font-size:clamp(10px,1.2vw,13px);letter-spacing:.28em;
  color:var(--gray-1);opacity:.5;
}

.hero-body{
  margin-top:28px;font-size:14.5px;font-weight:300;line-height:2;
  color:var(--gray-1);max-width:460px;
  opacity:0;animation:fadeUp .9s ease .8s forwards;
}

.hero-btns{
  margin-top:38px;display:flex;gap:14px;flex-wrap:wrap;
  opacity:0;animation:fadeUp .9s ease 1s forwards;
}
.btn-p{
  padding:14px 32px;background:var(--yellow);
  font-family:'Noto Sans JP',sans-serif;font-size:13px;font-weight:500;
  letter-spacing:.08em;text-decoration:none;color:var(--navy);
  transition:background .3s,transform .2s;
}
.btn-p:hover{background:#f0c84a;transform:translateY(-2px)}
.btn-g{
  padding:14px 32px;border:1px solid rgba(184,192,204,.3);
  font-family:'Noto Sans JP',sans-serif;font-size:13px;font-weight:400;
  letter-spacing:.08em;text-decoration:none;color:var(--gray-1);
  transition:border-color .3s,color .3s;
}
.btn-g:hover{border-color:var(--yellow);color:var(--yellow)}

.hero-scroll{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:6px;z-index:2;
  opacity:0;animation:fadeIn 1s ease 1.8s forwards;
}
.hero-scroll span{
  font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.28em;
  color:rgba(184,192,204,.3);text-transform:uppercase;
}
.scroll-bar{width:1px;height:38px;overflow:hidden;position:relative}
.scroll-bar::after{
  content:'';position:absolute;top:0;left:0;width:100%;height:100%;
  background:linear-gradient(to bottom,var(--yellow),transparent);
  animation:scrollTick 2.4s ease-in-out 2s infinite;
}

/* ══════════════════════════════════════
   02 MANIFESTO
══════════════════════════════════════ */
#manifesto{background:var(--navy);padding:120px 0}

/* arch / blueprint bg */
.mani-arch-art{
  position:absolute;right:-5%;top:0;width:55%;height:100%;
  animation:archDrift 20s ease-in-out infinite;opacity:.055;
}

.mani-inner{
  display:grid;grid-template-columns:1fr 1.2fr;
  gap:80px;align-items:start;
}
@media(max-width:800px){.mani-inner{grid-template-columns:1fr;gap:48px}}

.mani-quote{
  font-family:'Noto Sans JP',sans-serif;font-weight:500;
  font-size:clamp(16px,2.2vw,22px);line-height:1.75;
  color:#e8e2d4;
  border-left:2px solid var(--yellow);padding-left:26px;
}

.mani-body p{
  font-size:14px;font-weight:300;line-height:2.2;
  color:rgba(184,192,204,.82);margin-bottom:24px;
}
.mani-stamp{
  font-family:'DM Mono',monospace;font-size:9px;
  letter-spacing:.3em;color:var(--yellow);opacity:.65;
  text-transform:uppercase;margin-top:8px;
}

/* ══════════════════════════════════════
   03 WHY CLEANING
══════════════════════════════════════ */
#cleaning{background:var(--cream);padding:120px 0}

/* cell network bg */
.cleaning-cell-art{
  position:absolute;left:-5%;top:0;width:50%;height:100%;
  animation:cellBreath 18s ease-in-out infinite;
}

.cleaning-inner{
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:center;
}
@media(max-width:820px){.cleaning-inner{grid-template-columns:1fr;gap:48px}}

.cleaning-statement{
  font-family:'Noto Sans JP',sans-serif;font-weight:700;
  font-size:clamp(22px,3vw,34px);line-height:1.35;color:var(--navy);
}
.cleaning-statement em{
  font-style:normal;color:var(--gold);display:block;margin-top:8px;
}

.cleaning-right ul{list-style:none}
.cleaning-right li{
  display:flex;gap:16px;align-items:flex-start;
  padding:20px 0;border-bottom:1px solid var(--ln);
  font-size:14px;font-weight:300;line-height:1.9;color:var(--text-sub);
}
.cleaning-right li:first-child{border-top:1px solid var(--ln)}
.c-dot{
  width:7px;height:7px;background:var(--yellow);
  border-radius:50%;margin-top:8px;flex-shrink:0;
}

/* ══════════════════════════════════════
   04 PURPOSE / MVV
══════════════════════════════════════ */
#mvv{background:#fff;padding:120px 0}

/* net / mesh bg */
.mvv-net-art{
  position:absolute;right:-8%;top:5%;width:58%;height:90%;
  animation:netDrift 26s ease-in-out infinite;
}

.mvv-top{margin-bottom:60px}
.mvv-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:2px;background:var(--ln-mid);
}
@media(max-width:780px){.mvv-grid{grid-template-columns:1fr}}

.mvv-card{
  background:#fff;padding:44px 38px;
  position:relative;overflow:hidden;
  transition:background .35s;
}
.mvv-card:hover{background:var(--cream)}
.mvv-card::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:var(--yellow);transform:scaleX(0);transform-origin:left;
  transition:transform .5s ease;
}
.mvv-card:hover::after{transform:scaleX(1)}
.mvv-num{
  font-family:'DM Mono',monospace;font-size:60px;font-weight:300;
  line-height:1;color:rgba(10,22,40,.04);margin-bottom:10px;letter-spacing:-.02em;
}
.mvv-label{
  font-family:'DM Mono',monospace;font-size:9px;font-weight:400;
  letter-spacing:.3em;text-transform:uppercase;color:var(--yellow);margin-bottom:12px;
}
.mvv-title{
  font-family:'Noto Sans JP',sans-serif;font-size:17px;font-weight:700;
  color:var(--navy);margin-bottom:14px;line-height:1.4;
}
.mvv-body{font-size:13px;font-weight:300;line-height:2;color:var(--text-sub)}

/* values row */
.mvv-values{
  margin-top:2px;background:var(--navy);padding:44px 38px;
}
.mvv-values-label{
  font-family:'DM Mono',monospace;font-size:9px;font-weight:400;
  letter-spacing:.3em;text-transform:uppercase;color:var(--yellow);margin-bottom:28px;
}
.val-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:28px;
}
.val-item h4{
  font-family:'Noto Sans JP',sans-serif;font-size:14px;font-weight:700;
  color:#e8e2d4;margin-bottom:8px;
}
.val-item p{
  font-size:12.5px;font-weight:300;line-height:1.9;
  color:rgba(184,192,204,.7);
}

/* ══════════════════════════════════════
   05 ROI → VALUE CREATION
══════════════════════════════════════ */
#roi{background:var(--cream);padding:120px 0}

/* circuit / blueprint bg */
.roi-arch-art{
  position:absolute;right:0;top:10%;width:48%;height:80%;
  animation:archDrift 22s ease-in-out 4s infinite;
}

.roi-head{text-align:center;max-width:700px;margin:0 auto 60px}
.roi-sub{font-size:14px;font-weight:300;color:var(--text-sub);line-height:2}
.roi-table{
  display:grid;grid-template-columns:1fr 60px 1fr;align-items:stretch;
}
@media(max-width:760px){
  .roi-table{grid-template-columns:1fr}
  .roi-vs{padding:16px 0;font-size:16px;border:none;border-top:1px solid var(--ln);border-bottom:1px solid var(--ln)}
}
.roi-col{padding:52px 44px}
.roi-col-a{background:#fff;border:1px solid var(--ln-mid)}
.roi-col-b{background:var(--navy);border:1px solid rgba(232,184,64,.18);border-left:3px solid var(--yellow)}
.roi-vs{
  display:flex;align-items:center;justify-content:center;
  font-family:'DM Mono',monospace;font-size:13px;font-weight:400;
  color:var(--gray-2);opacity:.4;
  border-top:1px solid var(--ln);border-bottom:1px solid var(--ln);
}
.roi-tag{
  font-family:'DM Mono',monospace;font-size:9px;font-weight:400;
  letter-spacing:.28em;text-transform:uppercase;display:block;margin-bottom:20px;
}
.roi-col-a .roi-tag{color:var(--gray-2)}
.roi-col-b .roi-tag{color:var(--yellow)}
.roi-col-title{
  font-family:'Noto Sans JP',sans-serif;font-size:18px;font-weight:700;
  margin-bottom:28px;
}
.roi-col-a .roi-col-title{color:var(--navy)}
.roi-col-b .roi-col-title{color:#e8e2d4}
.roi-items{list-style:none}
.roi-items li{
  display:flex;align-items:flex-start;gap:12px;
  font-size:13px;font-weight:300;line-height:1.9;
  padding:9px 0;border-bottom:1px solid;
}
.roi-col-a .roi-items li{color:rgba(42,48,64,.65);border-color:var(--ln)}
.roi-col-b .roi-items li{color:rgba(184,192,204,.85);border-color:rgba(255,255,255,.07)}
.dot-n{
  width:14px;height:14px;border-radius:50%;flex-shrink:0;margin-top:3px;
  border:1px solid rgba(42,48,64,.18);
}
.dot-y{
  width:14px;height:14px;border-radius:50%;flex-shrink:0;margin-top:3px;
  background:var(--yellow);
}

/* ══════════════════════════════════════
   06 SERVICES
══════════════════════════════════════ */
#services{background:var(--navy);padding:120px 0}

/* blueprint arch bg */
.svc-arch-art{
  position:absolute;top:0;left:0;width:100%;height:100%;
  animation:archDrift 30s ease-in-out 6s infinite;opacity:.04;
}

.svc-head{margin-bottom:60px}
.svc-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:2px;background:rgba(255,255,255,.04);
}
@media(max-width:860px){.svc-grid{grid-template-columns:1fr}}

.svc-card{
  background:rgba(20,32,64,.72);padding:44px 38px;
  position:relative;overflow:hidden;transition:background .4s;
}
.svc-card:hover{background:rgba(28,47,88,.85)}
.svc-num{
  font-family:'DM Mono',monospace;font-size:72px;font-weight:300;
  line-height:1;color:rgba(232,184,64,.06);margin-bottom:16px;
}
.svc-en{
  font-family:'DM Mono',monospace;font-size:10px;font-weight:400;
  letter-spacing:.25em;color:var(--yellow);margin-bottom:6px;
  text-transform:uppercase;
}
.svc-ja{
  font-family:'Noto Sans JP',sans-serif;font-size:18px;font-weight:700;
  color:#e8e2d4;margin-bottom:8px;
}
.svc-tagline{
  font-family:'Noto Sans JP',sans-serif;font-size:12px;font-weight:400;
  color:var(--yellow);margin-bottom:18px;opacity:.8;letter-spacing:.05em;
}
.svc-body{
  font-size:13px;font-weight:300;line-height:2;
  color:rgba(184,192,204,.75);
}
.svc-bar{
  position:absolute;bottom:0;left:0;right:0;height:2px;
  background:var(--yellow);transform:scaleX(0);transform-origin:left;
  transition:transform .5s ease;
}
.svc-card:hover .svc-bar{transform:scaleX(1)}

/* ══════════════════════════════════════
   07 TRUST / PROCESS
══════════════════════════════════════ */
#trust{background:#fff;padding:120px 0}

/* cell network bg for trust */
.trust-cell-art{
  position:absolute;right:-5%;top:10%;width:44%;height:80%;
  animation:cellBreath 22s ease-in-out 3s infinite;
}

.trust-steps{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:2px;background:var(--ln);margin-top:56px;
}
@media(max-width:860px){.trust-steps{grid-template-columns:1fr}}

.trust-step{
  background:#fff;padding:44px 36px;position:relative;
  transition:background .35s;
}
.trust-step:hover{background:var(--cream)}
.trust-step::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--yellow);transform:scaleX(0);transform-origin:left;
  transition:transform .5s;
}
.trust-step:hover::before{transform:scaleX(1)}
.ts-circ{
  width:52px;height:52px;background:var(--navy);border-radius:50%;
  display:flex;align-items:center;justify-content:center;margin-bottom:24px;
}
.ts-circ span{
  font-family:'DM Mono',monospace;font-size:14px;font-weight:400;
  color:var(--yellow);
}
.ts-h{
  font-family:'Noto Sans JP',sans-serif;font-size:16px;font-weight:700;
  color:var(--navy);margin-bottom:12px;line-height:1.4;
}
.ts-p{font-size:13px;font-weight:300;line-height:2;color:var(--text-sub)}

/* ══════════════════════════════════════
   08 COMMONS
══════════════════════════════════════ */
#commons{background:var(--offwhite);padding:120px 0}

/* mesh / network bg */
.commons-net-art{
  position:absolute;left:-5%;bottom:-5%;width:55%;height:95%;
  animation:netDrift 24s ease-in-out 5s infinite;
}

.commons-wm{
  position:absolute;right:-10px;top:50%;transform:translateY(-50%);
  font-family:'Noto Sans JP',sans-serif;font-weight:700;
  font-size:160px;color:rgba(10,22,40,.028);
  white-space:nowrap;pointer-events:none;letter-spacing:.08em;
  user-select:none;
}

.commons-inner{
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:start;
}
@media(max-width:860px){.commons-inner{grid-template-columns:1fr;gap:48px}}

.commons-cards{display:flex;flex-direction:column;gap:2px}
.c-card{
  background:#fff;padding:32px 36px;
  border-top:1px solid var(--ln-mid);
  display:flex;gap:20px;align-items:flex-start;
  transition:box-shadow .35s;
}
.c-card:hover{box-shadow:0 8px 28px rgba(10,22,40,.07)}
.c-lbl{
  font-family:'DM Mono',monospace;font-size:11px;font-weight:400;
  color:var(--yellow);letter-spacing:.12em;flex-shrink:0;min-width:26px;
  padding-top:3px;
}
.c-body h4{
  font-family:'Noto Sans JP',sans-serif;font-size:15px;font-weight:700;
  color:var(--navy);margin-bottom:8px;
}
.c-body p{font-size:13px;font-weight:300;line-height:2;color:var(--text-sub)}

.commons-right{}
.eco-box{background:var(--navy);padding:40px 38px;margin-bottom:20px}
.eco-title{
  font-family:'Noto Sans JP',sans-serif;font-size:14px;font-weight:700;
  color:var(--yellow);margin-bottom:20px;
}
.eco-list{list-style:none}
.eco-list li{
  font-size:13px;font-weight:300;line-height:1.9;
  color:rgba(184,192,204,.82);padding:7px 0;
  border-bottom:1px solid rgba(255,255,255,.06);
  display:flex;align-items:flex-start;gap:10px;
}
.eco-list li::before{content:'→';color:var(--yellow);flex-shrink:0}
.vision-box{background:#fff;padding:32px 38px;border-left:3px solid var(--yellow)}
.vision-box h4{
  font-family:'Noto Sans JP',sans-serif;font-size:14px;font-weight:700;
  color:var(--navy);margin-bottom:10px;
}
.vision-box p{font-size:13px;font-weight:300;line-height:2;color:var(--text-sub)}

/* ══════════════════════════════════════
   09 CEO MESSAGE
══════════════════════════════════════ */
#message{background:var(--navy);padding:120px 0}

/* arch bg */
.msg-arch-art{
  position:absolute;top:0;left:0;width:100%;height:100%;
  animation:archDrift 26s ease-in-out 8s infinite;opacity:.04;
}

.msg-inner{
  display:grid;grid-template-columns:.9fr 1.2fr;
  gap:72px;align-items:center;
}
@media(max-width:820px){.msg-inner{grid-template-columns:1fr;gap:48px}}

.msg-portrait{
  aspect-ratio:3/4;background:rgba(20,32,64,.8);
  border:1px solid rgba(232,184,64,.1);
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.msg-portrait-svg{width:140px;opacity:.2}

.msg-h2{
  font-family:'Noto Sans JP',sans-serif;font-weight:700;
  font-size:clamp(22px,3vw,34px);line-height:1.4;
  color:#e8e2d4;margin-bottom:26px;
}
.msg-body{
  font-size:14px;font-weight:300;line-height:2.4;
  color:rgba(184,192,204,.82);margin-bottom:36px;
}
.msg-sign{padding-top:28px;border-top:1px solid rgba(255,255,255,.08)}
.msg-role{
  font-family:'DM Mono',monospace;font-size:9px;font-weight:400;
  letter-spacing:.3em;color:var(--yellow);text-transform:uppercase;margin-bottom:6px;
}
.msg-name{
  font-family:'Noto Sans JP',sans-serif;font-size:22px;font-weight:700;
  color:#e8e2d4;letter-spacing:.1em;
}

/* ══════════════════════════════════════
   10 FAQ
══════════════════════════════════════ */
#faq{background:#fff;padding:120px 0}

.faq-cell-art{
  position:absolute;right:0;top:0;width:40%;height:100%;
  animation:cellBreath 24s ease-in-out 2s infinite;
}

.faq-wrap{max-width:820px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--ln-mid)}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;
  padding:24px 0;cursor:pointer;
  font-family:'Noto Sans JP',sans-serif;font-size:14px;font-weight:500;
  color:var(--navy);transition:color .3s;
}
.faq-q:hover{color:var(--gold)}
.faq-icon{
  font-family:'DM Mono',monospace;font-size:20px;font-weight:300;
  color:var(--yellow);transition:transform .4s;flex-shrink:0;margin-left:16px;
}
.faq-a{
  max-height:0;overflow:hidden;
  font-size:13.5px;font-weight:300;line-height:2.1;color:var(--text-sub);
  transition:max-height .5s ease,padding .4s;
}
.faq-a.open{max-height:300px;padding-bottom:24px}
.faq-item.open .faq-icon{transform:rotate(45deg)}

/* ══════════════════════════════════════
   11 COMPANY
══════════════════════════════════════ */
#company{background:var(--cream);padding:120px 0}

.company-net-art{
  position:absolute;right:0;top:0;width:50%;height:100%;
  animation:netDrift 28s ease-in-out 7s infinite;
}

.company-inner{
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:start;
}
@media(max-width:820px){.company-inner{grid-template-columns:1fr;gap:48px}}

.co-dl dt{
  font-family:'DM Mono',monospace;font-size:9px;font-weight:400;
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--yellow);margin-top:24px;margin-bottom:5px;
}
.co-dl dt:first-child{margin-top:0}
.co-dl dd{
  font-family:'Noto Sans JP',sans-serif;font-size:14px;font-weight:400;
  color:var(--navy);line-height:1.9;
}

.co-right-h{
  font-family:'Noto Sans JP',sans-serif;font-weight:700;
  font-size:clamp(20px,2.8vw,30px);line-height:1.4;
  color:var(--navy);margin-bottom:24px;
}
.co-right-p{
  font-size:14px;font-weight:300;line-height:2.1;
  color:var(--text-sub);margin-bottom:24px;
}
.co-detail{
  background:#fff;padding:28px 32px;
  border-left:3px solid var(--yellow);
}
.co-detail h4{
  font-family:'Noto Sans JP',sans-serif;font-size:13px;font-weight:700;
  color:var(--navy);margin-bottom:12px;
}
.co-detail ul{list-style:none}
.co-detail li{
  display:flex;gap:10px;font-size:13px;font-weight:300;
  line-height:2;color:var(--text-sub);
}
.co-detail li::before{content:'—';color:var(--yellow);flex-shrink:0}

/* ══════════════════════════════════════
   12 CONTACT
══════════════════════════════════════ */
#contact{background:var(--navy);padding:120px 0}

.contact-arch-art{
  position:absolute;top:0;left:0;width:100%;height:100%;
  animation:archDrift 28s ease-in-out 4s infinite;opacity:.04;
}

.contact-head{text-align:center;max-width:620px;margin:0 auto 60px}
.contact-h{
  font-family:'Noto Sans JP',sans-serif;font-weight:700;
  font-size:clamp(24px,3.2vw,38px);line-height:1.3;
  color:#e8e2d4;margin-bottom:16px;margin-top:18px;
}
.contact-sub{
  font-size:14px;font-weight:300;line-height:2;
  color:rgba(184,192,204,.7);
}
.form-wrap{max-width:720px;margin:0 auto}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}
.fg{margin-bottom:16px}
.fg label{
  font-family:'DM Mono',monospace;font-size:9px;font-weight:400;
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--yellow);display:block;margin-bottom:8px;
}
.fg input,.fg textarea{
  width:100%;padding:16px 18px;
  background:rgba(20,32,64,.7);
  border:1px solid rgba(184,192,204,.1);
  color:#e8e2d4;
  font-family:'Noto Sans JP',sans-serif;font-size:13.5px;font-weight:300;
  transition:border-color .3s;outline:none;resize:vertical;
  line-height:1.6;
}
.fg input:focus,.fg textarea:focus{border-color:rgba(232,184,64,.5)}
.fg input::placeholder,.fg textarea::placeholder{color:rgba(184,192,204,.25)}
.submit-btn{
  width:100%;padding:20px;
  background:var(--yellow);color:var(--navy);border:none;cursor:pointer;
  font-family:'Noto Sans JP',sans-serif;font-size:13px;font-weight:700;
  letter-spacing:.18em;transition:background .3s,transform .2s;margin-top:6px;
}
.submit-btn:hover{background:#f0c84a;transform:translateY(-2px)}

/* ══════════════════════════════════════
   FOOTER
══════════════════════════════════════ */
footer{background:#060e1c;padding:80px 0 40px}
.ft{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:48px;margin-bottom:64px;
  border-bottom:1px solid rgba(255,255,255,.05);padding-bottom:60px;
}
@media(max-width:980px){.ft{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.ft{grid-template-columns:1fr}}
.ft-logo{
  font-family:'DM Sans',sans-serif;font-weight:700;font-size:24px;
  color:var(--yellow);letter-spacing:.18em;display:block;margin-bottom:16px;
  text-decoration:none;
}
.ft-brand-p{font-size:12.5px;font-weight:300;line-height:2;color:rgba(184,192,204,.45)}
.ft-col h5{
  font-family:'DM Mono',monospace;font-size:9px;font-weight:400;
  letter-spacing:.3em;text-transform:uppercase;
  color:rgba(184,192,204,.35);margin-bottom:18px;
}
.ft-col ul{list-style:none}
.ft-col li{margin-bottom:12px}
.ft-col a{
  font-family:'Noto Sans JP',sans-serif;font-size:12.5px;font-weight:300;
  color:rgba(184,192,204,.5);text-decoration:none;transition:color .3s;
}
.ft-col a:hover{color:var(--yellow)}
.ft-bottom{
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:12px;
}
.ft-copy{
  font-family:'DM Mono',monospace;font-size:9px;
  letter-spacing:.12em;color:rgba(184,192,204,.22);
}

/* ══════════════════════════════════════
   SECTION DIVIDERS (thin golden rule)
══════════════════════════════════════ */
.golden-rule{
  display:block;width:100%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(232,184,64,.25),transparent);
}


/* CF7の自動挿入タグを調整 */
.wpcf7-form-control-wrap { display: block; width: 100%; }
.wpcf7 span.wpcf7-not-valid-tip { font-size: 11px; color: #ff4b4b; } /* エラーメッセージ */

/* 送信完了メッセージのカスタマイズ */
.wpcf7-response-output {
    margin: 40px auto 0 !important;
    padding: 24px !important;
    border: 1px solid var(--yellow) !important; /* 枠線をイエローに */
    background: rgba(232, 184, 64, 0.05); /* ほんのり背景色 */
    color: var(--yellow) !important;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 0.1em;
    text-align: center;
    border-radius: 0; /* 角は丸めずシャープに */
    animation: fadeIn 0.8s ease forwards;
}

/* 送信中（くるくる回るアイコン）の非表示、または色変更 */
.wpcf7-spinner {
    background-color: var(--yellow) !important;
    margin: 20px auto !important;
    display: block !important;
}
/* reCAPTCHAバッジを非表示にする */
.grecaptcha-badge { 
    visibility: hidden; 
}