/* ============================================
   経営者コミュニティ i — Premium v3 Styles
   ============================================ */

:root {
  /* ─── 背景色：漆黒→深みのある濃紺に変更 ─── */
  --black:   #06080f;
  --deep:    #080c18;
  --dark:    #0d1225;
  --surface: #111830;
  --surface2:#162038;
  --navy:    #0a1020;

  /* ─── ゴールド ─── */
  --gold:        #d4a843;
  --gold-light:  #f0c965;
  --gold-dark:   #9b7420;
  --gold-pale:   rgba(212,168,67,0.14);

  /* ─── アクセント：エレクトリックブルー ─── */
  --accent:      #4a90e2;
  --accent-light:#7ab3f0;
  --accent-pale: rgba(74,144,226,0.12);

  /* ─── テキスト ─── */
  --silver:  #c0c8dc;
  --white:   #f4f2ee;
  --white70: rgba(244,242,238,0.75);
  --white40: rgba(244,242,238,0.42);
  --white10: rgba(244,242,238,0.09);

  /* ─── グロー・ボーダー ─── */
  --glow:    rgba(212,168,67,0.40);
  --glow2:   rgba(74,144,226,0.30);
  --border:  rgba(212,168,67,0.22);
  --border2: rgba(212,168,67,0.09);
  --border-b:rgba(74,144,226,0.22);

  --ease:    cubic-bezier(0.16,1,0.3,1);
  --trans:   all 0.5s var(--ease);
  --serif:   'Cormorant Garamond','Noto Serif JP',serif;
  --cursive: 'Dancing Script',cursive;
}
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; font-size:18px; }
body{
  background:var(--black);
  color:var(--white);
  font-family:var(--serif);
  overflow-x:hidden;
  line-height:1.85;
}
a{ text-decoration:none; color:inherit; }
::-webkit-scrollbar{ width:4px; }
::-webkit-scrollbar-track{ background:var(--navy); }
::-webkit-scrollbar-thumb{ background:var(--gold); border-radius:2px; }

/* ============================================
   PRELOADER
   ============================================ */
#preloader{
  position:fixed; inset:0;
  background:var(--black);
  z-index:9999;
  display:flex; align-items:center; justify-content:center;
  transition:opacity 1.2s ease, visibility 1.2s ease;
}
#preloader.hidden{ opacity:0; visibility:hidden; }
.preloader-inner{ text-align:center; }
.preloader-logo{
  font-family:var(--cursive);
  font-size:10rem;
  color:var(--gold);
  animation:preloaderPulse 1.5s ease-in-out infinite;
  text-shadow:0 0 60px var(--glow), 0 0 120px rgba(201,168,76,0.1);
  line-height:1;
}
.preloader-tagline{
  font-size:1rem;
  letter-spacing:0.45em;
  color:var(--silver);
  opacity:0.5;
  margin-top:8px;
}
.preloader-bar{
  width:200px; height:1px;
  background:rgba(201,168,76,0.15);
  margin:24px auto 0;
  overflow:hidden;
  border-radius:1px;
}
.preloader-bar-fill{
  height:100%;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  animation:barFill 1.6s ease-in-out infinite;
}
@keyframes preloaderPulse{
  0%,100%{ opacity:0.5; transform:scale(0.96); }
  50%{ opacity:1; transform:scale(1.04); }
}
@keyframes barFill{
  0%{ transform:translateX(-100%); }
  100%{ transform:translateX(200%); }
}

/* ============================================
   NAVBAR
   ============================================ */
#navbar{
  position:fixed; top:0; left:0; right:0;
  z-index:1000; padding:22px 0;
  transition:var(--trans);
}
#navbar.scrolled{
  background:rgba(5,5,8,0.92);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border);
  padding:14px 0;
}
.nav-inner{
  max-width:1360px; margin:0 auto; padding:0 48px;
  display:flex; align-items:center; justify-content:space-between;
}
.nav-logo{
  font-family:var(--cursive);
  font-size:3.2rem; color:var(--gold);
  text-shadow:0 0 24px var(--glow);
  line-height:1;
}
.nav-links{ list-style:none; display:flex; gap:40px; align-items:center; }
.nav-links a{
  font-size:0.78rem; letter-spacing:0.22em;
  color:var(--silver); transition:var(--trans);
  position:relative; padding-bottom:4px;
}
.nav-links a::after{
  content:''; position:absolute; bottom:0; left:0;
  width:0; height:1px; background:var(--gold);
  transition:width 0.35s ease;
}
.nav-links a:hover{ color:var(--gold); }
.nav-links a:hover::after{ width:100%; }
.nav-cta{
  border:1px solid var(--gold) !important;
  color:var(--gold) !important;
  padding:10px 28px !important;
  border-radius:2px; transition:var(--trans) !important;
}
.nav-cta:hover{
  background:var(--gold) !important;
  color:var(--black) !important;
}
.nav-cta::after{ display:none !important; }
.nav-hamburger{ display:none; flex-direction:column; gap:6px; cursor:pointer; }
.nav-hamburger span{ display:block; width:26px; height:1px; background:var(--gold); transition:var(--trans); }

/* Mobile Menu */
.mobile-menu{
  position:fixed; inset:0;
  background:rgba(5,5,8,0.98);
  backdrop-filter:blur(24px);
  z-index:999;
  display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transition:var(--trans);
}
.mobile-menu.open{ opacity:1; visibility:visible; }
.mobile-menu ul{ list-style:none; text-align:center; }
.mobile-menu li{ margin:22px 0; }
.mobile-menu a{
  font-size:2rem; letter-spacing:0.2em;
  color:var(--silver); transition:var(--trans);
}
.mobile-menu a:hover{ color:var(--gold); }

/* ============================================
   HERO
   ============================================ */
#hero{
  position:relative; min-height:100vh;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
  background:var(--black);
}

/* YouTube動画背景 */
.hero-video-wrap{
  position:absolute; inset:0; z-index:0;
  overflow:hidden;
  background:var(--black);
}
.hero-video-wrap iframe{
  position:absolute;
  top:50%; left:50%;
  transform:translate(-50%,-50%);
  width:177.78vh; /* 16:9 ratio */
  height:100vh;
  min-width:100%;
  min-height:56.25vw; /* 16:9 ratio */
  pointer-events:none;
  border:none;
}
.hero-video-overlay{
  position:absolute; inset:0;
  background:linear-gradient(
    to bottom,
    rgba(6,8,15,0.55) 0%,
    rgba(6,8,15,0.20) 25%,
    rgba(6,8,15,0.25) 60%,
    rgba(6,8,15,0.80) 100%
  );
  z-index:1;
}
/* フォールバック背景（動画が読み込まれる前） */
.yt-fallback-bg{
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 30% 40%, rgba(74,144,226,0.18) 0%, transparent 60%),
    radial-gradient(ellipse 60% 80% at 70% 60%, rgba(212,168,67,0.12) 0%, transparent 60%),
    linear-gradient(135deg, #06080f 0%, #0d1225 50%, #06080f 100%);
}
.hero-video-grain{
  position:absolute; inset:0; z-index:2;
  opacity:0.025;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");
  background-size:128px 128px;
  pointer-events:none;
}

#heroBgCanvas{
  position:absolute; inset:0; z-index:0;
  width:100%; height:100%;
}
#particleCanvas{
  position:absolute; inset:0; z-index:3;
  width:100%; height:100%; opacity:0.45;
  pointer-events:none;
}
.hero-grid{
  position:absolute; inset:0; z-index:4;
  background-image:
    linear-gradient(rgba(201,168,76,0.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(201,168,76,0.04) 1px,transparent 1px);
  background-size:90px 90px;
  animation:gridMove 22s linear infinite;
  pointer-events:none;
}
@keyframes gridMove{ 0%{transform:translateY(0)} 100%{transform:translateY(90px)} }
.hero-orb{
  position:absolute; border-radius:50%;
  filter:blur(100px); z-index:4; pointer-events:none;
  animation:orbFloat 10s ease-in-out infinite;
}
.orb1{
  width:900px; height:900px;
  background:radial-gradient(circle,rgba(212,168,67,0.10) 0%,transparent 65%);
  top:-250px; right:-200px;
}
.orb2{
  width:700px; height:700px;
  background:radial-gradient(circle,rgba(74,144,226,0.10) 0%,transparent 65%);
  bottom:-200px; left:-150px; animation-delay:-5s;
}
.orb3{
  position:absolute; border-radius:50%;
  filter:blur(80px); z-index:4; pointer-events:none;
  animation:orbFloat 14s ease-in-out infinite;
  width:500px; height:500px;
  background:radial-gradient(circle,rgba(74,144,226,0.07) 0%,transparent 65%);
  top:30%; left:20%; animation-delay:-8s;
}
@keyframes orbFloat{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(20px,-20px) scale(1.06)}
}
.hero-content{
  position:relative; z-index:5;
  text-align:center;
  padding:140px 24px 80px;
  max-width:960px; width:100%; margin:0 auto;
}
.hero-eyebrow{
  font-size:0.82rem; letter-spacing:0.42em;
  color:var(--gold); margin-bottom:28px;
  animation:fadeUp 1s ease 0.4s both;
}
.hero-title{
  line-height:0.9; margin-bottom:8px;
  animation:fadeUp 1s ease 0.6s both;
}
.hero-i-mark{
  font-family:var(--cursive);
  font-size:clamp(10rem,22vw,20rem);
  color:transparent;
  background:linear-gradient(145deg,var(--gold-light),var(--gold) 40%,var(--gold-dark));
  -webkit-background-clip:text; background-clip:text;
  display:inline-block;
  filter:drop-shadow(0 0 70px rgba(201,168,76,0.5));
  animation:iGlow 3.5s ease-in-out infinite;
}
@keyframes iGlow{
  0%,100%{filter:drop-shadow(0 0 50px rgba(201,168,76,0.4))}
  50%{filter:drop-shadow(0 0 100px rgba(201,168,76,0.7))}
}
.hero-sub-title{
  font-size:clamp(1.4rem,3vw,2.2rem);
  font-weight:300; letter-spacing:0.35em;
  color:var(--white70); margin-bottom:20px;
  animation:fadeUp 1s ease 0.75s both;
}
.hero-divider{
  display:flex; justify-content:center; margin-bottom:24px;
  animation:fadeUp 1s ease 0.85s both;
}
.hero-divider span{
  display:block; width:80px; height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.hero-subtitle{
  font-size:clamp(1.2rem,2.4vw,1.8rem);
  font-weight:300; color:var(--white70);
  line-height:2; margin-bottom:20px;
  animation:fadeUp 1s ease 0.95s both;
}
.hero-subtitle strong{ color:var(--white); font-weight:400; }
.hero-tagline{
  font-size:0.82rem; letter-spacing:0.4em;
  color:var(--gold); opacity:0.65; margin-bottom:48px;
  animation:fadeUp 1s ease 1.1s both;
}
.hero-cta-wrap{
  display:flex; gap:20px; justify-content:center; flex-wrap:wrap;
  margin-bottom:72px;
  animation:fadeUp 1s ease 1.25s both;
}
/* Buttons */
.btn-primary{
  display:inline-flex; align-items:center; gap:12px;
  background:linear-gradient(135deg,var(--gold),var(--gold-dark));
  color:var(--black);
  padding:20px 44px;
  font-size:0.9rem; letter-spacing:0.18em;
  border:none; cursor:pointer; border-radius:2px;
  transition:var(--trans); position:relative; overflow:hidden;
  font-family:var(--serif); font-weight:600;
}
.btn-primary::before{
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,var(--gold-light),var(--gold));
  opacity:0; transition:opacity 0.35s;
}
.btn-primary:hover::before{ opacity:1; }
.btn-primary:hover{ transform:translateY(-3px); box-shadow:0 16px 50px rgba(201,168,76,0.45); }
.btn-primary span,.btn-primary i{ position:relative; z-index:1; }
.btn-secondary{
  display:inline-flex; align-items:center; gap:10px;
  background:transparent; color:var(--gold);
  padding:20px 44px;
  font-size:0.9rem; letter-spacing:0.18em;
  border:1px solid rgba(201,168,76,0.4); border-radius:2px;
  transition:var(--trans); font-family:var(--serif);
}
.btn-secondary:hover{
  background:rgba(201,168,76,0.08);
  border-color:var(--gold); transform:translateY(-3px);
}
.hero-stats{
  display:flex; align-items:center; justify-content:center; gap:60px;
  animation:fadeUp 1s ease 1.4s both;
}
.stat-item{ text-align:center; }
.stat-num{
  font-size:clamp(2.4rem,5vw,3.6rem);
  font-weight:300; color:var(--gold); display:inline;
}
.stat-unit{ font-size:1.1rem; color:var(--gold); opacity:0.7; }
.stat-label{
  display:block; font-size:0.72rem;
  letter-spacing:0.22em; color:var(--silver); margin-top:6px;
}
.stat-divider{
  width:1px; height:50px;
  background:linear-gradient(to bottom,transparent,var(--border),transparent);
}
.hero-scroll{
  position:absolute; bottom:44px; left:50%;
  transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:10px;
  z-index:5; animation:fadeUp 1s ease 1.8s both;
}
.scroll-line{
  width:1px; height:64px;
  background:linear-gradient(to bottom,var(--gold),transparent);
  animation:scrollDown 2.5s ease-in-out infinite;
}
@keyframes scrollDown{
  0%{transform:scaleY(0); transform-origin:top}
  50%{transform:scaleY(1); transform-origin:top}
  50.01%{transform:scaleY(1); transform-origin:bottom}
  100%{transform:scaleY(0); transform-origin:bottom}
}
.hero-scroll span{
  font-size:0.65rem; letter-spacing:0.32em;
  color:var(--silver); opacity:0.45;
}
@keyframes fadeUp{
  from{ opacity:0; transform:translateY(36px); }
  to{ opacity:1; transform:translateY(0); }
}

/* ============================================
   SECTION COMMONS
   ============================================ */
.section-inner{
  max-width:1360px; margin:0 auto;
  padding:130px 48px;
  position:relative; z-index:1;
}
.section-label{
  font-size:0.72rem; letter-spacing:0.52em; color:var(--gold);
  margin-bottom:20px;
  display:inline-flex; align-items:center; gap:14px;
}
.section-label::after{
  content:''; display:inline-block;
  width:44px; height:1px; background:var(--gold); opacity:0.45;
}
.section-label.light{ color:var(--gold-light); }
/* BIG title */
.section-title-xl{
  font-size:clamp(2.4rem,5.5vw,4.2rem);
  font-weight:300; line-height:1.3;
  color:#ffffff; margin-bottom:40px;
  letter-spacing:0.06em;
  text-shadow:0 2px 20px rgba(0,0,0,0.3);
}
.section-title-xl.light{ color:var(--white); }
.section-title-xl.centered{ text-align:center; }
.section-title-xl em.italic-title{
  font-family:var(--cursive); font-style:normal;
  color:var(--gold); font-size:1.3em; line-height:0.8;
  vertical-align:middle; text-shadow:0 0 24px var(--glow);
}
/* Legacy title (smaller contexts) */
.section-title{
  font-size:clamp(1.8rem,3.5vw,2.8rem);
  font-weight:300; line-height:1.4; color:var(--white);
  margin-bottom:36px; letter-spacing:0.06em;
}
.section-sub{
  text-align:center; color:var(--silver);
  font-size:1.15rem; font-weight:300;
  margin-bottom:70px; line-height:2;
}
.section-sub.light{ color:var(--white40); }

/* AOS */
[data-aos]{
  opacity:0; transform:translateY(44px);
  transition:opacity 0.85s ease, transform 0.85s ease;
}
[data-aos].visible{ opacity:1; transform:translateY(0); }

/* ============================================
   ABOUT
   ============================================ */
#about{ background:var(--deep);
  background-image:radial-gradient(ellipse 90% 60% at 80% 20%, rgba(74,144,226,0.05) 0%, transparent 60%),
    radial-gradient(ellipse 60% 80% at 10% 80%, rgba(212,168,67,0.04) 0%, transparent 50%);
}
/* Cinema canvas */
.about-cinema-section{ margin-bottom:60px; }
.cinema-wrap{
  position:relative; border-radius:6px; overflow:hidden;
  border:1px solid var(--border);
  box-shadow:0 0 80px rgba(201,168,76,0.08);
  min-height:500px;
  display:flex; align-items:center; justify-content:center;
}
.cinema-label{
  position:absolute; top:20px; left:24px; z-index:5;
  font-size:0.7rem; letter-spacing:0.4em;
  color:var(--gold); background:rgba(5,5,8,0.7);
  padding:6px 16px; border:1px solid var(--border);
  border-radius:2px; backdrop-filter:blur(8px);
}
#cinemaCanvas{
  position:absolute; inset:0;
  width:100%; height:100%; display:block; z-index:1;
}
.cinema-overlay{
  position:absolute; inset:0;
  background:rgba(5,5,8,0.45);
  z-index:3;
}
.cinema-text-overlay{
  position:relative; z-index:4;
  text-align:center; padding:80px 24px;
}
.cinema-big-text{
  font-size:clamp(1.6rem,4vw,3rem);
  font-weight:300; color:var(--white);
  line-height:1.5; margin-bottom:16px;
  letter-spacing:0.06em;
  text-shadow:0 2px 20px rgba(0,0,0,0.8);
}
.cinema-big-text em{
  font-style:italic; color:var(--gold);
  font-family:var(--cursive); font-size:1.2em;
  text-shadow:0 0 20px var(--glow);
}
.cinema-small-text{
  font-size:1rem; letter-spacing:0.4em;
  color:var(--gold); opacity:0.7;
}
.about-label-row{ margin-bottom:16px; }
.about-headline{ margin-bottom:48px; }
.about-lead{
  font-size:clamp(1.15rem,2vw,1.55rem);
  font-weight:300; color:var(--white); line-height:2;
  margin-bottom:28px;
}
.about-lead strong{ color:var(--gold-light); font-weight:500; }
.about-lead em{ font-style:italic; color:var(--gold); }
.about-body-text{
  font-size:clamp(1rem,1.6vw,1.25rem);
  color:var(--silver); line-height:2.1; margin-bottom:60px;
}
.about-body-text strong{ color:var(--gold-light); font-weight:500; }

/* About Video */
.about-video-section{ margin-bottom:60px; }
.about-video-wrap{
  position:relative; border-radius:6px; overflow:hidden;
  border:1px solid var(--border);
  box-shadow:0 0 80px rgba(201,168,76,0.08);
}
.video-label{
  position:absolute; top:20px; left:24px; z-index:3;
  font-size:0.7rem; letter-spacing:0.4em;
  color:var(--gold); background:rgba(5,5,8,0.7);
  padding:6px 16px; border:1px solid var(--border);
  border-radius:2px; backdrop-filter:blur(8px);
}
.about-video{
  width:100%; display:block;
  max-height:520px; object-fit:cover;
}
.about-video-overlay{
  position:absolute; inset:0;
  background:linear-gradient(
    to bottom,
    rgba(5,5,8,0.1) 0%,
    rgba(5,5,8,0.05) 50%,
    rgba(5,5,8,0.55) 100%
  );
}
.about-video-caption{
  position:absolute; bottom:24px; left:28px; z-index:3;
}
.about-video-caption p{
  font-size:1.1rem; color:var(--white70); line-height:1.7;
}
.about-video-caption strong{ color:var(--gold-light); }

/* YouTube背景ラッパー（cinemaの中）*/
.yt-bg-wrap{
  position:absolute; inset:0; z-index:0; overflow:hidden;
}
.yt-bg-wrap iframe{
  position:absolute;
  top:50%; left:50%;
  transform:translate(-50%,-50%);
  width:177.78%; /* 16:9 */
  height:100%;
  min-width:100%;
  min-height:56.25vw;
  pointer-events:none;
  border:none;
}
.about-tags-row{
  display:flex; flex-wrap:wrap; gap:12px; margin-top:8px;
}
.tag{
  font-size:0.88rem; letter-spacing:0.08em;
  padding:10px 22px;
  border:1px solid var(--border); color:var(--gold);
  border-radius:2px; transition:var(--trans);
  background:rgba(201,168,76,0.04);
  display:flex; align-items:center; gap:8px;
}
.tag i{ opacity:0.7; }
.tag:hover{ background:rgba(201,168,76,0.12); border-color:var(--gold); }

/* ============================================
   OWNER
   ============================================ */
#owner{ position:relative; overflow:hidden; background:var(--deep); }
.owner-bg{ position:absolute; inset:0; z-index:0; }
.owner-bg canvas{
  position:absolute; inset:0;
  width:100%; height:100%; display:block;
}
.owner-bg-overlay{
  position:absolute; inset:0;
  background:linear-gradient(
    135deg,
    rgba(5,5,8,0.93) 0%,
    rgba(8,8,15,0.88) 50%,
    rgba(5,5,8,0.94) 100%
  );
}
.owner-grid{
  display:grid; grid-template-columns:380px 1fr;
  gap:90px; align-items:start;
  padding:60px 0;
}
.owner-photo-col{ display:flex; justify-content:center; }
.owner-photo-frame{
  position:relative; text-align:center;
}
.owner-photo-inner{
  width:320px; height:320px;
  border-radius:50%; position:relative;
  border:2px solid var(--border);
  overflow:hidden;
  box-shadow:0 0 80px rgba(201,168,76,0.2), 0 0 160px rgba(201,168,76,0.07), 0 30px 80px rgba(0,0,0,0.5);
}
.owner-photo-placeholder{
  width:100%; height:100%;
  background:linear-gradient(135deg,var(--surface),var(--surface2));
  display:flex; align-items:center; justify-content:center;
  font-size:6rem; color:var(--gold); opacity:0.4;
}
.owner-photo-glow{
  position:absolute; inset:-30px;
  background:radial-gradient(circle,rgba(201,168,76,0.14) 0%,transparent 65%);
  border-radius:50%;
  animation:orbPulse 4s ease-in-out infinite;
}
@keyframes orbPulse{
  0%,100%{transform:scale(1); opacity:0.5}
  50%{transform:scale(1.18); opacity:1}
}
.owner-photo-badge{
  position:absolute; bottom:-16px; left:50%;
  transform:translateX(-50%);
  background:linear-gradient(135deg,var(--gold),var(--gold-dark));
  color:var(--black);
  font-size:0.78rem; letter-spacing:0.2em;
  padding:10px 32px; border-radius:24px;
  display:flex; align-items:center; gap:6px;
  white-space:nowrap;
  box-shadow:0 8px 30px rgba(201,168,76,0.5);
  font-weight:600;
}
.italic-i-sm{
  font-family:var(--cursive); font-size:1.4rem;
  line-height:1; color:var(--black);
}
.owner-title{
  display:flex; flex-direction:column; gap:4px;
  margin-bottom:36px;
}
.owner-name-en{
  font-size:clamp(1.5rem,2.8vw,2.2rem);
  font-weight:300; letter-spacing:0.15em;
  color:var(--gold); font-style:italic;
  font-family:var(--cursive);
}
.owner-name-ja{
  font-size:clamp(1rem,1.8vw,1.35rem);
  letter-spacing:0.3em; color:var(--silver);
  margin-top:4px;
}
.owner-career{ margin-bottom:36px; }
.owner-career-item{
  display:grid; grid-template-columns:90px 1fr;
  gap:20px; padding:18px 0;
  border-bottom:1px solid var(--border2);
}
.owner-career-item:last-child{ border-bottom:none; }
.career-year{
  font-size:0.78rem; letter-spacing:0.18em;
  color:var(--gold); opacity:0.75;
  padding-top:4px; white-space:nowrap;
}
.career-text{
  font-size:clamp(0.98rem,1.5vw,1.12rem);
  color:var(--white70); line-height:1.95;
}
.owner-message{
  background:rgba(201,168,76,0.04);
  border-left:3px solid var(--gold);
  border-radius:0 4px 4px 0;
  padding:32px 36px;
  margin-bottom:32px;
  position:relative;
}
.owner-message::before{
  content:'\201C';
  position:absolute; top:-8px; left:20px;
  font-family:var(--cursive); font-size:5rem;
  color:var(--gold); opacity:0.15; line-height:1;
}
.owner-message p{
  font-size:clamp(1.05rem,1.6vw,1.28rem);
  color:var(--white70); line-height:2.15;
  font-style:italic;
}
.owner-message em.italic-title{
  font-family:var(--cursive); font-style:normal;
  color:var(--gold); font-size:1.4em;
  vertical-align:middle; text-shadow:0 0 16px var(--glow);
}
.owner-tags{
  display:flex; flex-direction:column; gap:12px;
}
.owner-tag{
  font-size:0.95rem; color:var(--silver);
  display:flex; align-items:center; gap:10px;
}
.owner-tag i{ color:var(--gold); }

/* ---- 2人対応 追加スタイル ---- */
.owners-heading{ margin-bottom:70px; }

/* 実際の顔写真 */
.owner-photo-img{
  width:100%; height:100%;
  object-fit:cover; object-position:center top;
  display:block;
  transition:transform 0.6s ease;
}
.owner-photo-inner:hover .owner-photo-img{
  transform:scale(1.04);
}
.owner-photo-inner--landscape{
  width:320px; height:400px;
  border-radius:14px;
}
.owner-photo-img--landscape{
  object-position:center center;
}

/* 名前・役職 */
.owner-name-role{
  font-size:clamp(0.82rem,1.2vw,0.98rem);
  letter-spacing:0.15em; color:var(--gold);
  opacity:0.8; margin-top:6px;
}

/* 資格バッジ */
.owner-credentials{
  display:flex; flex-wrap:wrap; gap:10px;
  margin-bottom:32px;
}
.cred-badge{
  font-size:0.8rem; letter-spacing:0.1em;
  padding:8px 18px;
  border:1px solid var(--border);
  color:var(--gold-light); background:rgba(201,168,76,0.06);
  border-radius:24px;
  display:flex; align-items:center; gap:8px;
  transition:var(--trans);
}
.cred-badge:hover{ background:rgba(201,168,76,0.12); }
.cred-fire{ border-color:rgba(255,120,40,0.3); color:#ff8c40; background:rgba(255,120,40,0.06); }
.cred-restart{ border-color:rgba(0,200,150,0.3); color:#00c896; background:rgba(0,200,150,0.06); }

/* Owner2: レイアウト反転 */
.owner-grid--2{
  grid-template-columns:1fr 380px;
  margin-top:0;
}
.owner-text-col--left{ order:1; }
.owner-photo-col--right{ order:2; }

/* fire テーマ */
.owner-photo-glow--fire{
  background:radial-gradient(circle,rgba(255,120,40,0.18) 0%,transparent 65%);
}
.owner-photo-badge--fire{
  background:linear-gradient(135deg,#ff8c40,#c94a00);
  box-shadow:0 8px 30px rgba(255,120,40,0.5);
}
.owner-message--fire{
  border-left-color:#ff8c40;
  background:rgba(255,120,40,0.04);
}
.owner-message--fire::before{ color:#ff8c40; }
.owner-tag--fire i{ color:#ff8c40; }

/* 区切り線 */
.owner-divider{
  display:flex; align-items:center; gap:20px;
  margin:80px 0;
}
.od-line{
  flex:1; height:1px;
  background:linear-gradient(90deg,transparent,var(--border),transparent);
}
.od-icon{
  font-family:var(--cursive); font-size:2rem;
  color:var(--gold); opacity:0.5;
  text-shadow:0 0 16px var(--glow);
  line-height:1;
}


/* ============================================
   VISION
   ============================================ */
#vision{ position:relative; background:var(--dark); overflow:hidden; }
.vision-bg-anim{
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 100% 60% at 50% 0%, rgba(212,168,67,0.08) 0%,transparent 55%),
    radial-gradient(ellipse 70% 70% at 100% 100%, rgba(74,144,226,0.07) 0%,transparent 50%),
    radial-gradient(ellipse 60% 60% at 0% 60%, rgba(74,144,226,0.05) 0%,transparent 50%);
  background-image:
    linear-gradient(rgba(212,168,67,0.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(212,168,67,0.05) 1px,transparent 1px);
  background-size:70px 70px;
}
.vision-big-cards{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:28px; margin-top:12px;
}
.vbc{
  position:relative; border-radius:10px; overflow:hidden;
  border:1px solid rgba(255,255,255,0.08);
  min-height:400px;
  display:flex; align-items:flex-end;
  cursor:default;
  transition:var(--trans);
  box-shadow:0 10px 40px rgba(0,0,0,0.4);
}
.vbc:hover{
  border-color:rgba(212,168,67,0.5);
  box-shadow:0 28px 90px rgba(212,168,67,0.18), 0 0 0 1px rgba(212,168,67,0.15);
  transform:translateY(-8px);
}
.vbc-canvas{
  position:absolute; inset:0;
  width:100%; height:100%; display:block;
}
.vbc-overlay{
  position:absolute; inset:0;
  background:linear-gradient(
    to bottom,
    rgba(5,5,8,0.35) 0%,
    rgba(5,5,8,0.75) 60%,
    rgba(5,5,8,0.92) 100%
  );
}
.vbc::before{
  content:attr(data-num);
  position:absolute; top:22px; right:24px; z-index:3;
  font-size:0.7rem; letter-spacing:0.3em;
  color:var(--gold); opacity:0.55;
}
.vbc-content{
  position:relative; z-index:3;
  padding:36px; width:100%;
}
.vbc-icon{
  font-size:2.2rem; color:var(--gold);
  margin-bottom:16px;
  text-shadow:0 0 20px var(--glow);
}
.vbc-content h3{
  font-size:clamp(1.4rem,2.5vw,1.9rem);
  font-weight:400; color:var(--white);
  line-height:1.45; margin-bottom:14px;
  letter-spacing:0.05em;
}
.vbc-content p{
  font-size:clamp(0.92rem,1.3vw,1.05rem);
  color:var(--white70); line-height:2; font-weight:300;
}

/* ============================================
   SERVICES
   ============================================ */
#services{ background:var(--navy);
  background-image:radial-gradient(ellipse 80% 50% at 50% 50%, rgba(74,144,226,0.04) 0%, transparent 70%);
}
.services-list{
  display:flex; flex-direction:column;
  border:1px solid var(--border); border-radius:10px; overflow:hidden;
  margin-top:12px;
  background:rgba(255,255,255,0.015);
  box-shadow:0 0 80px rgba(74,144,226,0.06), 0 0 40px rgba(212,168,67,0.05);
}
.service-item{
  display:flex; align-items:center;
  border-bottom:1px solid var(--border2);
  transition:var(--trans); padding:36px 40px; gap:32px;
  position:relative; overflow:hidden;
}
.service-item::before{
  content:''; position:absolute; left:0; top:0; bottom:0;
  width:0; background:linear-gradient(90deg,rgba(201,168,76,0.06),transparent);
  transition:width 0.5s ease;
}
.service-item:hover::before{ width:100%; }
.service-item:last-child{ border-bottom:none; }
.si-num-col{
  font-size:0.72rem; letter-spacing:0.25em;
  color:var(--gold); opacity:0.5; min-width:36px;
}
.si-icon-col{
  font-size:2rem; color:var(--gold);
  min-width:44px; text-align:center;
  opacity:0.85; text-shadow:0 0 16px var(--glow);
}
.si-content{ flex:1; }
.si-content h3{
  font-size:clamp(1.1rem,2vw,1.5rem);
  font-weight:400; color:var(--white);
  margin-bottom:10px; letter-spacing:0.05em;
}
.si-content p{
  font-size:clamp(0.92rem,1.3vw,1.05rem);
  color:var(--silver); line-height:2; font-weight:300;
}
.si-arrow{
  color:var(--gold); opacity:0;
  transition:opacity 0.3s ease, transform 0.3s ease;
  font-size:1rem;
}
.service-item:hover .si-arrow{ opacity:1; transform:translateX(4px); }

/* ============================================
   QUOTE BAND (ticker)
   ============================================ */
.quote-band{
  background:linear-gradient(135deg, rgba(212,168,67,0.10) 0%, rgba(74,144,226,0.08) 50%, rgba(212,168,67,0.10) 100%);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:24px 0; overflow:hidden;
}
.qb-track{
  display:flex; gap:48px; width:max-content;
  animation:ticker 28s linear infinite;
  white-space:nowrap;
}
.qb-track span{
  font-size:1.05rem; letter-spacing:0.12em;
  color:var(--gold); font-weight:300;
}
.qb-dot{ color:var(--gold-dark); opacity:0.6; }
@keyframes ticker{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

/* ============================================
   MEMBERS
   ============================================ */
#members{ position:relative; overflow:hidden; }
.members-bg{
  position:absolute; inset:0; z-index:0;
}
.members-bg canvas{
  position:absolute; inset:0;
  width:100%; height:100%; display:block;
}
.members-bg-overlay{
  position:absolute; inset:0;
  background:linear-gradient(
    to bottom,
    rgba(5,5,8,0.88) 0%,
    rgba(8,8,15,0.82) 50%,
    rgba(5,5,8,0.92) 100%
  );
}
.members-grid{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:22px; margin-bottom:88px;
}
.member-card{
  background:rgba(255,255,255,0.03);
  border:1px solid var(--border);
  border-radius:6px; padding:40px 32px;
  text-align:center; transition:var(--trans);
  position:relative; overflow:hidden;
}
.member-card::after{
  content:''; position:absolute; inset:0;
  background:radial-gradient(circle at 50% 0%,rgba(201,168,76,0.07),transparent 60%);
  opacity:0; transition:opacity 0.4s;
}
.member-card:hover{
  border-color:rgba(201,168,76,0.45);
  transform:translateY(-6px);
  box-shadow:0 20px 60px rgba(201,168,76,0.1);
}
.member-card:hover::after{ opacity:1; }
.mc-icon{
  font-size:2.4rem; color:var(--gold);
  margin-bottom:22px; text-shadow:0 0 24px var(--glow);
}
.member-card h3{
  font-size:clamp(1.05rem,1.8vw,1.3rem);
  font-weight:400; color:var(--white);
  margin-bottom:14px; letter-spacing:0.05em;
}
.member-card p{
  font-size:clamp(0.9rem,1.3vw,1.05rem);
  color:var(--silver); line-height:2; font-weight:300;
}
/* Voice */
.voice-section{ margin-top:80px; }
.voice-title{
  font-family:var(--cursive); font-size:2.6rem;
  color:var(--gold); text-align:center;
  margin-bottom:48px; opacity:0.85;
}
.voice-cards{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.voice-card{
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(201,168,76,0.1);
  border-radius:6px; padding:36px;
  position:relative;
  transition:var(--trans);
}
.voice-card:hover{
  border-color:var(--border);
  background:rgba(201,168,76,0.03);
}
.voice-stars{
  color:var(--gold); font-size:1rem;
  letter-spacing:3px; margin-bottom:18px;
}
.voice-text{
  font-size:clamp(0.95rem,1.4vw,1.1rem);
  color:var(--white70); line-height:2.1;
  font-style:italic; margin-bottom:24px; font-weight:300;
}
.voice-author{
  display:flex; align-items:center; gap:14px;
}
.va-avatar{
  width:44px; height:44px; border-radius:50%;
  background:linear-gradient(135deg,var(--surface),var(--surface2));
  border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  color:var(--gold); font-size:1.1rem;
}
.va-name{
  font-size:0.95rem; color:var(--gold); letter-spacing:0.1em;
}
.va-role{
  font-size:0.8rem; color:var(--silver); opacity:0.7;
  letter-spacing:0.08em; margin-top:3px;
}

/* ============================================
   CONTACT
   ============================================ */
#contact{ position:relative; background:var(--deep); overflow:hidden; }
.contact-bg{
  position:absolute; inset:0;
  background:radial-gradient(ellipse 80% 70% at 50% 50%,rgba(201,168,76,0.03) 0%,transparent 70%);
}
.contact-orb{
  position:absolute; top:50%; left:50%;
  transform:translate(-50%,-50%);
  width:900px; height:900px;
  background:radial-gradient(circle,rgba(201,168,76,0.025) 0%,transparent 70%);
  border-radius:50%;
  animation:orbPulse 8s ease-in-out infinite;
}
.contact-wrap{ max-width:860px; margin:0 auto; }
.contact-form{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:8px; padding:56px;
}
.form-row{
  display:grid; grid-template-columns:1fr 1fr;
  gap:24px; margin-bottom:24px;
}
.form-group{ display:flex; flex-direction:column; gap:10px; }
.form-group.full{ margin-bottom:24px; }
.form-group label{
  font-size:0.82rem; letter-spacing:0.12em; color:var(--silver);
}
.req{ color:var(--gold); }
.form-group input,
.form-group select,
.form-group textarea{
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(201,168,76,0.15);
  border-radius:3px;
  padding:16px 20px;
  color:var(--white); font-size:1rem;
  font-family:var(--serif); outline:none;
  transition:var(--trans);
}
.form-group input::placeholder,
.form-group textarea::placeholder{ color:rgba(168,176,192,0.35); }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  border-color:var(--gold);
  background:rgba(201,168,76,0.04);
  box-shadow:0 0 0 3px rgba(201,168,76,0.09);
}
.form-group select option{ background:var(--dark); color:var(--white); }
.form-group textarea{ resize:vertical; min-height:140px; }
.form-submit{ text-align:center; margin-top:36px; }
.submit-btn{ min-width:220px; justify-content:center; }
.contact-note{ max-width:860px; margin:28px auto 0; text-align:center; }
.contact-note p{
  font-size:0.8rem; color:rgba(168,176,192,0.35); line-height:2;
}

/* ============================================
   FOOTER
   ============================================ */
footer{
  background:var(--navy);
  border-top:1px solid var(--border);
  padding:52px 0;
}
.footer-inner{
  max-width:1360px; margin:0 auto; padding:0 48px;
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:28px;
}
.footer-logo{ display:flex; align-items:center; gap:14px; }
.italic-i-footer{
  font-family:var(--cursive); font-size:3rem;
  color:var(--gold); text-shadow:0 0 24px var(--glow);
}
.footer-name{ font-size:0.82rem; letter-spacing:0.18em; color:var(--silver); }
.footer-links{ display:flex; gap:36px; }
.footer-links a{
  font-size:0.75rem; letter-spacing:0.18em;
  color:rgba(168,176,192,0.45); transition:color 0.3s;
}
.footer-links a:hover{ color:var(--gold); }
.footer-copy p{
  font-size:0.7rem; letter-spacing:0.1em;
  color:rgba(168,176,192,0.28);
}

/* ============================================
   MODAL
   ============================================ */
.modal-overlay{
  position:fixed; inset:0;
  background:rgba(0,0,0,0.85);
  backdrop-filter:blur(12px);
  z-index:9000;
  display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transition:var(--trans);
}
.modal-overlay.active{ opacity:1; visibility:visible; }
.modal-box{
  background:var(--surface2);
  border:1px solid var(--border);
  border-radius:8px; padding:56px;
  text-align:center; max-width:440px; width:92%;
  transform:scale(0.94); transition:var(--trans);
}
.modal-overlay.active .modal-box{ transform:scale(1); }
.modal-icon{
  font-size:3.4rem; color:var(--gold);
  margin-bottom:24px; text-shadow:0 0 24px var(--glow);
}
.modal-box h3{
  font-size:1.5rem; font-weight:400;
  margin-bottom:16px; color:var(--white);
}
.modal-box p{
  font-size:1rem; color:var(--silver);
  margin-bottom:36px; line-height:2;
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1100px){
  .vision-big-cards{ grid-template-columns:repeat(2,1fr); }
  .owner-grid{ grid-template-columns:300px 1fr; gap:60px; }
  .owner-grid--2{ grid-template-columns:1fr 300px; }
  .owner-photo-inner{ width:280px; height:280px; }
  .owner-photo-inner--landscape{ width:280px; height:350px; }
}
@media(max-width:900px){
  .section-inner{ padding:100px 32px; }
  .owner-grid{ grid-template-columns:1fr; text-align:center; }
  .owner-grid--2{ grid-template-columns:1fr; }
  .owner-text-col--left{ order:2; }
  .owner-photo-col--right{ order:1; }
  .owner-photo-col{ margin-bottom:20px; }
  .owner-career-item{ grid-template-columns:70px 1fr; }
  .owner-message{ text-align:left; }
  .owner-tags{ align-items:center; }
  .owner-credentials{ justify-content:center; }
  .members-grid{ grid-template-columns:repeat(2,1fr); }
  .voice-cards{ grid-template-columns:1fr; }
}
@media(max-width:768px){
  html{ font-size:16px; }
  .nav-links{ display:none; }
  .nav-hamburger{ display:flex; }
  .hero-stats{ gap:32px; }
  .vision-big-cards{ grid-template-columns:1fr; }
  .form-row{ grid-template-columns:1fr; }
  .contact-form{ padding:32px 24px; }
  .footer-inner{ flex-direction:column; align-items:flex-start; }
  .footer-links{ flex-wrap:wrap; gap:18px; }
  .service-item{ padding:24px 28px; gap:20px; }
  .members-grid{ grid-template-columns:1fr; }
  .vbc{ min-height:300px; }
}
@media(max-width:480px){
  .hero-stats{ flex-direction:column; gap:20px; }
  .stat-divider{ width:44px; height:1px; }
  .hero-cta-wrap{ flex-direction:column; align-items:center; }
}

/* ============================================
   ABOUT — 画像ギャラリー
   ============================================ */
.about-gallery{
  display:grid;
  grid-template-columns:1.6fr 1fr;
  gap:16px;
  margin:48px 0 60px;
  border-radius:12px; overflow:hidden;
}
.ag-large{ grid-row:span 2; }
.ag-col{ display:flex; flex-direction:column; gap:16px; }
.ag-item{
  position:relative; overflow:hidden;
  border-radius:8px;
  aspect-ratio:16/10;
}
.ag-large{ aspect-ratio:auto; }
.ag-item img{
  width:100%; height:100%;
  object-fit:cover; display:block;
  transition:transform 0.7s ease;
  filter:brightness(0.88) saturate(1.1);
}
.ag-item:hover img{ transform:scale(1.05); filter:brightness(0.95) saturate(1.2); }
.ag-caption{
  position:absolute; bottom:0; left:0; right:0;
  background:linear-gradient(transparent,rgba(6,8,15,0.8));
  color:var(--gold); font-size:0.72rem;
  letter-spacing:0.3em; padding:20px 18px 12px;
  opacity:0; transition:opacity 0.35s;
}
.ag-item:hover .ag-caption{ opacity:1; }

/* ============================================
   VISION — 背景画像レイヤー
   ============================================ */
.vbc-bg-img{
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  z-index:0;
  transition:transform 0.7s ease;
  filter:brightness(0.55) saturate(0.9);
}
.vbc:hover .vbc-bg-img{
  transform:scale(1.06);
  filter:brightness(0.65) saturate(1.1);
}
/* canvasをvbc-bg-imgの上に重ねてブレンド */
.vbc-canvas{ z-index:1; mix-blend-mode:multiply; opacity:0.5; }
.vbc-overlay{
  position:absolute; inset:0;
  background:linear-gradient(
    to bottom,
    rgba(6,8,15,0.15) 0%,
    rgba(6,8,15,0.55) 55%,
    rgba(6,8,15,0.88) 100%
  );
  z-index:2;
}
.vbc-content{ z-index:3; }
.vbc::before{ z-index:4; }

/* ============================================
   MEMBERS — 画像ストリップ
   ============================================ */
.members-image-strip{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  margin:0 0 72px;
  border-radius:10px; overflow:hidden;
}
.mis-item{
  aspect-ratio:4/3; overflow:hidden;
  border-radius:8px;
  position:relative;
}
.mis-item img{
  width:100%; height:100%; object-fit:cover;
  transition:transform 0.6s ease, filter 0.6s ease;
  filter:brightness(0.75) saturate(0.9);
}
.mis-item:hover img{
  transform:scale(1.07);
  filter:brightness(0.9) saturate(1.15);
}

/* ============================================
   OWNER — portrait photo (山田健太)
   ============================================ */
.owner-photo-inner--portrait{
  width:320px; height:400px;
  border-radius:14px;
}
.owner-photo-img--portrait{
  object-position:center 20%;
}
.owner-photo-glow--blue{
  background:radial-gradient(circle,rgba(58,111,255,0.18) 0%,transparent 65%);
}
.owner-photo-badge--blue{
  background:linear-gradient(135deg,#3a6fff,#1a3fa0);
  box-shadow:0 8px 30px rgba(58,111,255,0.45);
}

/* ============================================
   EVENT SECTION
   ============================================ */
#event{
  position:relative; overflow:hidden;
  background:var(--black);
}
.event-bg{
  position:absolute; inset:0; z-index:0;
}
.event-bg canvas{
  position:absolute; inset:0;
  width:100%; height:100%; display:block;
}
.event-bg-overlay{
  position:absolute; inset:0;
  background:linear-gradient(
    to bottom,
    rgba(5,5,8,0.88) 0%,
    rgba(8,8,15,0.80) 50%,
    rgba(5,5,8,0.92) 100%
  );
}

/* イベント詳細グリッド */
.event-detail-grid{
  display:grid; grid-template-columns:1fr 1fr;
  gap:32px; margin-bottom:80px;
}
.event-info-card{
  background:rgba(201,168,76,0.04);
  border:1px solid var(--border);
  border-radius:8px; overflow:hidden;
  display:flex; flex-direction:column;
  transition:var(--trans);
}
.event-info-card:hover{
  border-color:rgba(201,168,76,0.4);
  box-shadow:0 20px 60px rgba(201,168,76,0.1);
  transform:translateY(-4px);
}
.event-info-card--expert{
  background:rgba(58,111,255,0.04);
  border-color:rgba(58,111,255,0.2);
}
.event-info-card--expert:hover{
  border-color:rgba(58,111,255,0.45);
  box-shadow:0 20px 60px rgba(58,111,255,0.1);
}
.eic-header{
  padding:36px 40px 28px;
  border-bottom:1px solid var(--border2);
}
.eic-badge{
  display:inline-flex; align-items:center;
  font-size:0.72rem; letter-spacing:0.25em;
  color:var(--gold); background:rgba(201,168,76,0.1);
  border:1px solid rgba(201,168,76,0.3);
  padding:6px 18px; border-radius:20px;
  margin-bottom:16px;
}
.eic-badge--expert{
  color:#6a9fff; background:rgba(58,111,255,0.1);
  border-color:rgba(58,111,255,0.3);
}
.eic-title{
  font-size:clamp(1.3rem,2.2vw,1.7rem);
  font-weight:400; color:var(--white);
  margin-bottom:8px; letter-spacing:0.05em;
}
.eic-sub{
  font-size:0.88rem; color:var(--silver); opacity:0.7;
  letter-spacing:0.1em;
}
.eic-body{
  padding:28px 40px; flex:1;
  display:flex; flex-direction:column; gap:16px;
}
.eic-row{
  display:flex; align-items:flex-start; gap:16px;
}
.eic-row i{
  color:var(--gold); font-size:1.1rem;
  min-width:20px; margin-top:3px;
}
.event-info-card--expert .eic-row i{ color:#6a9fff; }
.eic-row > div{
  display:flex; flex-direction:column; gap:4px;
}
.eic-label{
  font-size:0.72rem; letter-spacing:0.2em;
  color:var(--silver); opacity:0.6;
}
.eic-val{
  font-size:1.05rem; color:var(--white); font-weight:300;
  letter-spacing:0.05em;
}
.eic-btn{
  margin:24px 40px 40px;
  justify-content:center;
}
.eic-btn--expert{
  background:linear-gradient(135deg,#3a6fff,#1a3fa0);
}
.eic-btn--expert:hover{
  box-shadow:0 16px 50px rgba(58,111,255,0.4);
}

/* ポスターダウンロード */
.poster-download-section{
  text-align:center;
  padding:60px 0 20px;
  border-top:1px solid var(--border);
}
.poster-dl-title{
  font-size:clamp(1.4rem,2.5vw,2rem);
  font-weight:300; color:var(--white);
  margin-bottom:12px; letter-spacing:0.1em;
}
.poster-dl-sub{
  font-size:1rem; color:var(--silver); opacity:0.7;
  margin-bottom:48px; letter-spacing:0.06em;
}
.poster-grid{
  display:grid;
  grid-template-columns:repeat(2,340px);
  justify-content:center;
  align-items:start;
  gap:48px;
  margin:0 auto;
}
.poster-card{
  width:340px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:10px; overflow:hidden;
  transition:var(--trans);
  box-shadow:0 8px 40px rgba(0,0,0,0.3);
  margin:0 auto;
}
.poster-card:hover{
  border-color:rgba(212,168,67,0.50);
  box-shadow:0 24px 70px rgba(212,168,67,0.15);
  transform:translateY(-8px);
}
.poster-img-wrap{
  position:relative; overflow:hidden;
  aspect-ratio:9/16; max-height:420px;
}
.poster-img{
  width:100%; height:100%;
  object-fit:cover; object-position:center top;
  display:block;
  transition:transform 0.6s ease;
}
.poster-card:hover .poster-img{ transform:scale(1.04); }
.poster-img-overlay{
  position:absolute; inset:0;
  background:rgba(5,5,8,0.45);
  display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity 0.35s;
  font-size:2rem; color:var(--gold);
}
.poster-card:hover .poster-img-overlay{ opacity:1; }
.poster-card-body{
  padding:28px 32px;
}
.poster-card-tag{
  display:inline-flex;
  font-size:0.72rem; letter-spacing:0.2em;
  color:var(--gold); background:rgba(201,168,76,0.1);
  border:1px solid rgba(201,168,76,0.25);
  padding:5px 16px; border-radius:20px;
  margin-bottom:14px;
}
.poster-card-tag--expert{
  color:#6a9fff; background:rgba(58,111,255,0.1);
  border-color:rgba(58,111,255,0.25);
}
.poster-card-body h4{
  font-size:1.15rem; font-weight:400;
  color:var(--white); margin-bottom:10px;
  letter-spacing:0.06em;
}
.poster-card-body p{
  font-size:0.9rem; color:var(--silver);
  line-height:1.9; margin-bottom:22px; font-weight:300;
}
.btn-dl{
  display:inline-flex; align-items:center; gap:10px;
  background:linear-gradient(135deg,var(--gold),var(--gold-dark));
  color:var(--black); padding:14px 32px;
  font-size:0.88rem; letter-spacing:0.14em;
  border-radius:2px; transition:var(--trans);
  font-family:var(--serif); font-weight:600;
  text-decoration:none;
}
.btn-dl:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 40px rgba(201,168,76,0.4);
  filter:brightness(1.08);
}
.btn-dl--expert{
  background:linear-gradient(135deg,#3a6fff,#1a3fa0);
  color:#fff;
}
.btn-dl--expert:hover{
  box-shadow:0 12px 40px rgba(58,111,255,0.4);
}

/* ============================================
   CONTACT — Googleフォーム（シングル）
   ============================================ */
.gform-outer{
  max-width:860px; margin:0 auto;
}
.gform-wrap{
  background:#ffffff;
  border:2px solid var(--border);
  border-radius:12px; overflow:hidden;
  padding:0;
  box-shadow:0 0 80px rgba(212,168,67,0.10), 0 30px 80px rgba(0,0,0,0.4);
}
.gform-wrap iframe{
  display:block; border:none;
  background:#fff;
  min-height:960px;
  width:100%;
}
.gform-alt-link{
  text-align:center; margin-top:20px;
}
.gform-alt-link p{
  font-size:0.88rem; color:var(--silver); opacity:0.65;
}
.gform-alt-link a{
  color:var(--gold); text-decoration:underline;
  text-underline-offset:3px; transition:color 0.3s;
}
.gform-alt-link a:hover{ color:var(--gold-light); }

/* ============================================
   ABOUT NUMBERS — 数字で見るコミュニティ
   ============================================ */
.about-numbers{
  display:flex; align-items:center; justify-content:center;
  gap:0; margin:64px auto 0;
  border:1px solid var(--border);
  border-radius:8px;
  overflow:hidden;
  max-width:900px;
  background:rgba(212,168,67,0.04);
}
.an-item{
  flex:1; text-align:center;
  padding:44px 20px;
}
.an-num{
  font-family:var(--cursive);
  font-size:clamp(2.8rem,5vw,4.2rem);
  color:var(--gold);
  text-shadow:0 0 40px rgba(212,168,67,0.5);
  line-height:1;
  margin-bottom:12px;
}
.an-num span{
  font-size:0.6em; letter-spacing:0.05em;
  color:var(--gold-light);
}
.an-label{
  font-size:0.82rem; letter-spacing:0.18em;
  color:var(--silver); opacity:0.75;
}
.an-divider{
  width:1px; height:80px;
  background:var(--border);
  flex-shrink:0;
}

/* ============================================
   VISION IMAGE ROW
   ============================================ */
.vision-image-row{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:20px; margin-bottom:60px;
}
.vir-item{
  position:relative; overflow:hidden;
  border-radius:6px;
  aspect-ratio:4/3;
}
.vir-item img{
  width:100%; height:100%;
  object-fit:cover;
  transition:transform 0.7s ease;
}
.vir-item:hover img{ transform:scale(1.07); }
.vir-overlay{
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(6,8,15,0.75) 0%, rgba(6,8,15,0.15) 60%);
  display:flex; align-items:flex-end;
  padding:20px 24px;
  border:1px solid var(--border);
  border-radius:6px;
  transition:background 0.4s;
}
.vir-item:hover .vir-overlay{
  background:linear-gradient(to top, rgba(6,8,15,0.85) 0%, rgba(212,168,67,0.08) 100%);
}
.vir-overlay span{
  font-size:0.82rem; letter-spacing:0.28em;
  color:var(--gold); font-family:var(--serif);
}

/* ============================================
   MEMBERS IMAGE STRIP — ラベル追加
   ============================================ */
.mis-item{
  position:relative;
}
.mis-label{
  position:absolute; bottom:0; left:0; right:0;
  background:linear-gradient(to top, rgba(6,8,15,0.85), transparent);
  color:var(--gold);
  font-size:0.72rem; letter-spacing:0.22em;
  padding:14px 12px 10px;
  text-align:center;
}

/* ============================================
   RESPONSIVE — イベント・ポスター追加
   ============================================ */
@media(max-width:900px){
  .event-detail-grid{ grid-template-columns:1fr; }
  .poster-grid{ grid-template-columns:1fr; max-width:380px; }
  .poster-card{ width:100%; }
  .contact-tabs{ flex-direction:column; align-items:center; }
  .owner-photo-inner--portrait{ width:280px; height:350px; }
  .about-numbers{ flex-wrap:wrap; }
  .an-item{ min-width:160px; }
  .vision-image-row{ grid-template-columns:1fr; }
}
@media(max-width:768px){
  .eic-header{ padding:28px 28px 20px; }
  .eic-body{ padding:20px 28px; }
  .eic-btn{ margin:20px 28px 28px; }
  .poster-card-body{ padding:20px 24px; }
  .gform-wrap iframe{ min-height:700px; }
  .about-numbers{ border-radius:6px; }
  .an-item{ padding:32px 16px; }
  .vision-image-row{ gap:12px; }
}

