:root {
  --black:  #050505;
  --gray:   #111111;
  --warm:   #1A1414;
  --red:    #C12A22;
  --white:  #EDE6E1;
  --cream:  rgba(237,230,225,0.06);
  --muted:  #8A7E7A;
  --border: #2A2422;
  --font:   'Inter', -apple-system, sans-serif;
  --disp:   'Bebas Neue', sans-serif;
  --jp:     'Noto Sans JP', sans-serif;
  --radius: 6px;
  --ease:   0.35s cubic-bezier(0.16,1,0.3,1);
  --glass:  rgba(17,17,17,0.55);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{background:#000;scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--font);color:var(--white);background:#000;overflow-x:hidden}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{max-width:100%;display:block}
.container{max-width:1120px;margin:0 auto;padding:0 24px;position:relative;z-index:1}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 32px;border-radius:var(--radius);
  font-family:var(--font);font-size:12px;font-weight:600;
  letter-spacing:2px;text-transform:uppercase;
  cursor:pointer;transition:all var(--ease);border:none;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.btn-primary{
  background:rgba(193,42,34,0.88);color:var(--white);
}
.btn-primary:hover{
  background:rgba(193,42,34,1);box-shadow:0 0 48px rgba(193,42,34,0.3);transform:translateY(-3px);
}
.btn-outline{
  background:var(--glass);color:var(--white);border:1px solid rgba(237,230,225,0.1);
}
.btn-outline:hover{
  border-color:var(--red);color:var(--red);box-shadow:0 0 32px rgba(193,42,34,0.12);transform:translateY(-3px);
}

/* ===== NAVBAR ===== */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:20px 0;transition:background var(--ease),padding var(--ease),backdrop-filter var(--ease);
}
.navbar.scrolled{
  background:rgba(5,5,5,0.78);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  padding:10px 0;border-bottom:1px solid rgba(193,42,34,0.08);
}
.progress-bar{
  position:fixed;top:0;left:0;height:2px;z-index:1001;
  background:linear-gradient(90deg,var(--red),#ff6b6b);
  width:0%;transition:width 0.1s linear;
  box-shadow:0 0 12px rgba(193,42,34,0.3);
}
.navbar .container{display:flex;align-items:center;justify-content:space-between}
.navbar-logo{display:flex;align-items:center;gap:12px}
.logo-svg{height:32px;width:auto;display:block}

.nav-links{display:flex;align-items:center;gap:32px}
.nav-links a{font-size:11px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--muted);transition:color var(--ease);position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--red);transition:width var(--ease)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a:hover,.nav-links a.active{color:var(--white)}
.nav-links .nav-cta{
  padding:8px 20px;border-radius:var(--radius);
  background:var(--red);color:var(--white);font-size:10px;letter-spacing:2px;
}
.nav-links .nav-cta::after{display:none}
.nav-links .nav-cta:hover{background:#d41a2a}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px;z-index:1001}
.hamburger span{display:block;width:24px;height:2px;background:var(--white);transition:all var(--ease);border-radius:2px}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mobile-overlay{
  position:fixed;inset:0;z-index:999;
  background:rgba(5,5,5,0.95);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;
  opacity:0;visibility:hidden;transition:opacity .5s cubic-bezier(0.16,1,0.3,1),visibility .5s ease;
}
.mobile-overlay.open{opacity:1;visibility:visible}
.mobile-overlay a{
  font-size:16px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--muted);
  transition:color var(--ease),transform var(--ease);
  display:flex;align-items:center;gap:12px;transform:translateY(20px);opacity:0;
}
.mobile-overlay.open a{transform:translateY(0);opacity:1}
.mobile-overlay.open a:nth-child(1){transition-delay:.08s}
.mobile-overlay.open a:nth-child(2){transition-delay:.14s}
.mobile-overlay.open a:nth-child(3){transition-delay:.2s}
.mobile-overlay.open a:nth-child(4){transition-delay:.26s}
.mobile-overlay.open a:nth-child(5){transition-delay:.32s}
.mobile-overlay a .micon{width:20px;height:20px;display:flex;align-items:center;justify-content:center}
.mobile-overlay a .micon svg{width:16px;height:16px;fill:var(--muted);transition:fill var(--ease)}
.mobile-overlay a:hover{color:var(--red)}
.mobile-overlay a:hover .micon svg{fill:var(--red)}
.mobile-overlay .nav-cta-mobile{
  padding:10px 24px;border-radius:var(--radius);
  background:var(--red);color:var(--white)!important;font-size:12px;
}
.mobile-overlay .nav-cta-mobile .micon svg{fill:var(--white)}

/* ===== HERO BG FIXED ===== */
.site-bg{
  position:fixed;top:0;left:0;width:100%;height:100vh;z-index:-2;
  background:url('../assets/hero-bg.png') center center / 100% no-repeat;
  animation:siteZoom 25s ease-in-out infinite alternate;
  will-change:background-size;
}
@keyframes siteZoom{
  0%{background-size:100%}
  100%{background-size:108%}
}
.site-bg::after{
  content:'';position:fixed;top:0;left:0;width:100%;height:100vh;z-index:-1;
  background:rgba(5,5,5,0.3);pointer-events:none;
}
.site-overlay{
  position:fixed;top:0;left:0;width:100%;height:100vh;z-index:-1;
  background:
    radial-gradient(ellipse at 50% 50%,transparent 40%,rgba(5,5,5,0.4) 100%);
  pointer-events:none;
}
.site-grain{
  position:fixed;top:0;left:0;width:100%;height:100vh;z-index:-1;
  opacity:0.018;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:256px;
}

/* ===== HERO SECTION ===== */
.hero{
  position:relative;z-index:1;
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  overflow:hidden;transition:min-height 0.4s ease,padding 0.4s ease;
}
.hero-bg-img{
  position:absolute;top:0;left:0;right:0;height:100vh;z-index:0;
  background:url("../assets/hero-bg.png") center center / cover no-repeat;
  filter:brightness(0.45) saturate(1.2);
}
.hero-glow{
  position:absolute;top:50%;left:50%;
  width:min(72vmin,520px);height:min(72vmin,520px);
  transform:translate(-50%,-50%);border-radius:50%;
  background:radial-gradient(circle at center,rgba(193,42,34,0.08) 0%,rgba(193,42,34,0.03) 30%,transparent 65%);
  pointer-events:none;z-index:1;animation:glowPulse 6s ease-in-out infinite;
}
@keyframes glowPulse{
  0%,100%{opacity:0.5;transform:translate(-50%,-50%) scale(1)}
  50%{opacity:1;transform:translate(-50%,-50%) scale(1.08)}
}
.hero-vignette{
  position:absolute;inset:0;
  background:radial-gradient(ellipse at center,transparent 25%,#000 100%);
  pointer-events:none;z-index:1;
}
.hero-divider{
  position:absolute;bottom:0;left:0;right:0;height:160px;
  background:linear-gradient(to top,var(--black) 20%,transparent);
  pointer-events:none;z-index:2;
}
.hero-content{display:none;position:relative;z-index:3;text-align:center;padding:0 24px;max-width:820px}
.hero-content.active{display:block}
.hero-jp{
  font-family:var(--jp);font-size:14px;color:rgba(237,230,225,0.4);
  letter-spacing:8px;margin-bottom:8px;
  opacity:0;transform:translateY(20px);animation:heroFade .9s cubic-bezier(0.16,1,0.3,1) .2s forwards;
}
.hero-title{
  font-family:var(--disp);font-size:clamp(56px,13vw,140px);
  letter-spacing:6px;line-height:0.86;color:var(--white);
  opacity:0;transform:translateY(30px);animation:heroFade .9s cubic-bezier(0.16,1,0.3,1) .4s forwards;
}
.hero-title span{color:var(--red)}
.hero-line{
  width:80px;height:3px;background:var(--red);margin:20px auto;border-radius:2px;
  opacity:0;transform:scaleX(0);transform-origin:center;
  animation:heroLine .8s cubic-bezier(0.16,1,0.3,1) .7s forwards;
  box-shadow:0 0 24px rgba(193,42,34,0.25);
}
@keyframes heroLine{
  to{opacity:1;transform:scaleX(1)}
}
.hero-sub{
  font-size:13px;color:rgba(237,230,225,0.5);letter-spacing:4px;text-transform:uppercase;font-weight:400;
  opacity:0;transform:translateY(20px);animation:heroFade .9s cubic-bezier(0.16,1,0.3,1) .9s forwards;
}
.hero-actions{
  margin-top:40px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap;
  opacity:0;transform:translateY(20px);animation:heroFade .9s cubic-bezier(0.16,1,0.3,1) 1.1s forwards;
}
@keyframes heroFade{
  to{opacity:1;transform:translateY(0)}
}

/* ===== SECTION ===== */
.page-content{display:none;opacity:0;transition:opacity 0.35s ease,transform 0.35s ease;transform:translateY(24px)}
.page-content.active{display:block;opacity:1;transform:translateY(0)}
.section{
  padding:80px 0;position:relative;z-index:1;
  overflow:hidden;
}
.section::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,rgba(193,42,34,0.06) 15%,rgba(193,42,34,0.12) 50%,rgba(193,42,34,0.06) 85%,transparent);
  mask-image:linear-gradient(90deg,transparent 0%,#000 8%,#000 92%,transparent 100%);
  -webkit-mask-image:linear-gradient(90deg,transparent 0%,#000 8%,#000 92%,transparent 100%);
}
.section-dark{
  background:linear-gradient(135deg,rgba(26,20,20,0.65) 0%,rgba(17,15,17,0.55) 100%);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.section-gray{
  background:linear-gradient(135deg,rgba(10,8,10,0.55) 0%,rgba(26,20,20,0.35) 100%);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
}
.section-dark::after,.section-gray::after{
  content:'';position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(ellipse at 20% 50%,rgba(193,42,34,0.03),transparent 60%);
}
.section-label{
  display:inline-block;font-family:var(--disp);font-size:12px;
  letter-spacing:4px;color:var(--red);margin-bottom:8px;text-transform:uppercase;
  position:relative;
}
.section-label::after{
  content:'';display:block;width:24px;height:2px;background:var(--red);
  margin:8px auto 0;border-radius:1px;
  box-shadow:0 0 12px rgba(193,42,34,0.3);
}
.section-header.center .section-label::after{margin:8px auto 0}
.section-title{
  font-family:var(--disp);font-size:clamp(30px,4vw,48px);
  letter-spacing:2px;line-height:1.04;color:var(--white);margin-bottom:8px;
  position:relative;
}
.section-desc{font-size:14px;color:var(--muted);max-width:520px;line-height:1.7}
.section-header{margin-bottom:24px}
.section-header.center{text-align:center;margin-left:auto;margin-right:auto}
.section-header.left{padding-left:20px;border-left:3px solid var(--red);box-shadow:-8px 0 24px -12px rgba(193,42,34,0.15)}
.section-header.left .section-label::after{margin:8px 0 0}
.section-header.left .section-desc{margin:0}
.section-header.left .section-title::after{display:none}

.reveal{opacity:0;transform:translateY(40px);transition:opacity .7s cubic-bezier(0.16,1,0.3,1),transform .7s cubic-bezier(0.16,1,0.3,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-scale{opacity:0;transform:scale(0.9);transition:opacity .7s cubic-bezier(0.16,1,0.3,1),transform .7s cubic-bezier(0.16,1,0.3,1)}
.reveal-scale.visible{opacity:1;transform:scale(1)}
.reveal-left{opacity:0;transform:translateX(-40px);transition:opacity .7s cubic-bezier(0.16,1,0.3,1),transform .7s cubic-bezier(0.16,1,0.3,1)}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(40px);transition:opacity .7s cubic-bezier(0.16,1,0.3,1),transform .7s cubic-bezier(0.16,1,0.3,1)}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-d1{transition-delay:.1s}
.reveal-d2{transition-delay:.2s}
.reveal-d3{transition-delay:.3s}
.reveal-d4{transition-delay:.45s}
.reveal-d5{transition-delay:.6s}

/* stagger grid children */
.stagger>*{opacity:0;transform:translateY(24px);transition:opacity .5s cubic-bezier(0.16,1,0.3,1),transform .5s cubic-bezier(0.16,1,0.3,1)}
.stagger.visible>*{opacity:1;transform:translateY(0)}
.stagger.visible>*:nth-child(1){transition-delay:.05s}
.stagger.visible>*:nth-child(2){transition-delay:.1s}
.stagger.visible>*:nth-child(3){transition-delay:.15s}
.stagger.visible>*:nth-child(4){transition-delay:.2s}
.stagger.visible>*:nth-child(5){transition-delay:.25s}
.stagger.visible>*:nth-child(6){transition-delay:.3s}
.stagger.visible>*:nth-child(7){transition-delay:.35s}
.stagger.visible>*:nth-child(8){transition-delay:.4s}

.actor-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.actor-card{
  text-align:center;padding:0 0 22px;
  background:linear-gradient(135deg,rgba(26,20,20,0.5),rgba(17,15,17,0.35));
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid var(--border);border-radius:var(--radius);
  transition:all var(--ease);cursor:pointer;
  position:relative;overflow:hidden;
}
.actor-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;z-index:2;
  background:var(--role-clr,var(--border));border-radius:var(--radius) var(--radius) 0 0;
  transition:height var(--ease);
}
.actor-card[data-role="lead"]{--role-clr:linear-gradient(90deg,#C12A22,#ff6b6b)}
.actor-card[data-role="supporting"]{--role-clr:linear-gradient(90deg,#b8860b,#ffd700)}
.actor-card[data-role="guest"]{--role-clr:linear-gradient(90deg,#2a6db5,#6bb8ff)}
.actor-card:hover::before{height:4px}
.actor-card:hover{transform:translateY(-6px) scale(1.02)}
.actor-card[data-role="lead"]:hover{border-color:rgba(193,42,34,0.25);box-shadow:0 0 48px rgba(193,42,34,0.12),0 0 0 1px rgba(193,42,34,0.15)}
.actor-card[data-role="supporting"]:hover{border-color:rgba(212,160,23,0.25);box-shadow:0 0 48px rgba(212,160,23,0.12),0 0 0 1px rgba(212,160,23,0.15)}
.actor-card[data-role="guest"]:hover{border-color:rgba(74,144,217,0.25);box-shadow:0 0 48px rgba(74,144,217,0.12),0 0 0 1px rgba(74,144,217,0.15)}
.actor-card .card-body{padding:26px 18px 0}
.actor-avatar{
  width:76px;height:76px;border-radius:50%;margin:0 auto 12px;
  overflow:hidden;border:2px solid var(--border);transition:border-color var(--ease);
  position:relative;}
.actor-card:hover .actor-avatar{border-color:rgba(193,42,34,0.3)}
.actor-avatar .initials{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  font-family:var(--jp);font-size:20px;font-weight:700;color:rgba(237,230,225,0.15);
  background:linear-gradient(135deg,rgba(26,10,10,0.5),rgba(17,15,17,0.5));
}
.actor-card h4{font-size:18px;font-weight:600;color:var(--white);margin-bottom:3px}
.actor-bio{font-size:11px;color:var(--muted);line-height:1.5;margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.actor-role{
  display:inline-block;font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;
  margin-bottom:8px;padding:3px 10px;border-radius:3px;
}
.actor-role.role-lead{color:#ff6b6b;background:rgba(193,42,34,0.1)}
.actor-role.role-supporting{color:#ffd700;background:rgba(212,160,23,0.1)}
.actor-role.role-guest{color:#6bb8ff;background:rgba(74,144,217,0.1)}
.actor-tags{display:flex;gap:5px;justify-content:center;flex-wrap:wrap}
.actor-tags span{
  padding:4px 10px;font-size:9px;font-weight:500;
  background:rgba(237,230,225,0.04);color:var(--muted);
  border:1px solid rgba(237,230,225,0.08);border-radius:3px;letter-spacing:.6px;
}

/* ===== STATS ===== */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;text-align:center;margin-top:32px}
.stat-item{
  position:relative;padding:22px 14px;transition:transform var(--ease);
  border-radius:var(--radius);border:1px solid rgba(237,230,225,0.04);
  background:rgba(255,255,255,0.02);overflow:hidden;
}
.stat-item:hover{transform:scale(1.03)}
.stat-item::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
}
.stat-item:first-child::before{background:linear-gradient(90deg,transparent,var(--red),transparent)}
.stat-item:nth-child(2)::before{background:linear-gradient(90deg,transparent,#ffd700,transparent)}
.stat-item:nth-child(3)::before{background:linear-gradient(90deg,transparent,#6bb8ff,transparent)}
.stat-item:nth-child(4)::before{background:linear-gradient(90deg,transparent,var(--red),transparent)}
.stat-item:first-child .stat-count{color:var(--red)}
.stat-item:nth-child(2) .stat-count{color:#ffd700}
.stat-item:nth-child(3) .stat-count{color:#6bb8ff}
.stat-item:nth-child(4) .stat-count{color:var(--white)}
.stat-count{
  font-family:var(--disp);font-size:clamp(34px,5vw,54px);
  letter-spacing:2px;line-height:1;
  transition:text-shadow var(--ease);
}
.stat-item:first-child:hover .stat-count{text-shadow:0 0 40px rgba(193,42,34,0.4)}
.stat-item:nth-child(2):hover .stat-count{text-shadow:0 0 40px rgba(212,160,23,0.4)}
.stat-item:nth-child(3):hover .stat-count{text-shadow:0 0 40px rgba(74,144,217,0.4)}
.stat-item:nth-child(4):hover .stat-count{text-shadow:0 0 40px rgba(237,230,225,0.3)}
.stat-label{font-size:10px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-top:4px;transition:color var(--ease)}
.stat-item:hover .stat-label{color:var(--white)}

/* ===== ABOUT ===== */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:center}
.about-grid p{font-size:14px;color:var(--muted);line-height:1.8;margin-bottom:10px}
.about-grid p:last-child{margin-bottom:0}
.about-visual{
  aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;
  background:linear-gradient(135deg,rgba(10,15,25,0.6),rgba(22,18,26,0.6));
  border:1px solid var(--border);position:relative;
  display:flex;align-items:center;justify-content:center;
}
.about-visual .big-text{
  font-family:var(--disp);font-size:clamp(52px,8vw,96px);letter-spacing:4px;
  color:rgba(193,42,34,0.08);line-height:1;user-select:none;
  position:relative;z-index:1;
}
.about-visual .big-text span{display:block;font-size:clamp(28px,4vw,48px);color:rgba(237,230,225,0.04);letter-spacing:8px;margin-top:-8px}
.about-visual .glow-dot{
  position:absolute;width:120px;height:120px;border-radius:50%;
  background:radial-gradient(circle,rgba(193,42,34,0.06),transparent 70%);
  top:50%;left:50%;transform:translate(-50%,-50%);animation:vdPulse 4s ease-in-out infinite;
}
@keyframes vdPulse{0%,100%{opacity:0.5;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.15)}}

.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.value-card{
  padding:28px 20px;
  background:linear-gradient(135deg,rgba(26,20,20,0.5),rgba(17,15,17,0.35));
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid var(--border);border-radius:var(--radius);
  transition:all var(--ease);text-align:center;
  position:relative;overflow:hidden;
}
.value-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,rgba(193,42,34,0.15),transparent);
  opacity:0;transition:opacity var(--ease);
}
.value-card:hover{border-color:rgba(193,42,34,0.25);box-shadow:0 0 48px rgba(193,42,34,0.06),inset 0 1px 0 rgba(193,42,34,0.04);transform:translateY(-6px)}
.value-card:hover::before{opacity:1}
.value-card .icon{font-size:24px;margin-bottom:8px;display:block;transition:transform var(--ease)}
.value-card:hover .icon{transform:scale(1.2)}
.value-card h4{font-size:14px;font-weight:600;color:var(--white);margin-bottom:4px}
.value-card p{font-size:11px;color:var(--muted);line-height:1.6}

.timeline{display:flex;flex-direction:column;max-width:620px;margin:0 auto;gap:16px}
.timeline-item{
  position:relative;padding:20px 20px 20px 60px;
  background:linear-gradient(135deg,rgba(26,20,20,0.5),rgba(17,15,17,0.35));
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid var(--border);border-radius:var(--radius);
  transition:all var(--ease);overflow:hidden;
}
.timeline-item:hover{border-color:rgba(193,42,34,0.2);box-shadow:0 0 32px rgba(193,42,34,0.04);transform:translateX(6px)}
.timeline-item::before{
  content:'';position:absolute;left:24px;top:0;bottom:0;
  width:1px;background:rgba(193,42,34,0.08);
}
.timeline-item:last-child::before{display:none}
.timeline-year{
  position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:50px;text-align:center;
  font-family:var(--disp);font-size:20px;color:var(--red);letter-spacing:1px;z-index:1;
}
.timeline-year .dot{
  display:block;width:10px;height:10px;border-radius:50%;background:var(--red);
  margin:4px auto 0;box-shadow:0 0 20px rgba(193,42,34,0.4);
  animation:tlPulse 2.5s ease-in-out infinite;
}
@keyframes tlPulse{0%,100%{box-shadow:0 0 12px rgba(193,42,34,0.2)}50%{box-shadow:0 0 24px rgba(193,42,34,0.5)}}
.timeline-text h4{font-size:15px;font-weight:600;color:var(--white);margin-bottom:4px}
.timeline-text p{font-size:12px;color:var(--muted);line-height:1.6}

/* ===== ACTORS ===== */
.actor-filters{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:16px}
.filter-btn{
  padding:7px 18px;border-radius:var(--radius);
  background:rgba(17,17,17,0.45);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  border:1px solid var(--border);color:var(--muted);
  font-family:var(--font);font-size:10px;font-weight:500;
  letter-spacing:2px;text-transform:uppercase;
  cursor:pointer;transition:all var(--ease);
  position:relative;
}
.filter-btn::after{
  content:'';position:absolute;inset:0;border-radius:inherit;
  box-shadow:0 0 0 0 rgba(193,42,34,0.2);transition:box-shadow var(--ease);
}
.filter-btn:hover{border-color:rgba(193,42,34,0.3);color:var(--white);transform:translateY(-2px)}
.filter-btn:active{transform:translateY(0)}
.filter-btn.active{background:rgba(193,42,34,0.8);border-color:rgba(193,42,34,0.8);color:var(--white);backdrop-filter:blur(4px);box-shadow:0 0 32px rgba(193,42,34,0.1)}
.filter-hidden{opacity:0;transform:translateY(10px);pointer-events:none;position:absolute;visibility:hidden;transition:opacity .3s ease,transform .3s ease}
.actors-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.actor-full-card{
  background:linear-gradient(135deg,rgba(26,20,20,0.5),rgba(17,15,17,0.35));
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid var(--border);border-radius:var(--radius);
  padding:24px 22px 20px;transition:all var(--ease);
  position:relative;overflow:hidden;
}
.actor-full-card:hover{transform:translateY(-6px) scale(1.01)}
.actor-full-card[data-category="lead"]:hover{border-color:rgba(193,42,34,0.25);box-shadow:0 0 48px rgba(193,42,34,0.12),0 0 0 1px rgba(193,42,34,0.15)}
.actor-full-card[data-category="supporting"]:hover{border-color:rgba(212,160,23,0.25);box-shadow:0 0 48px rgba(212,160,23,0.12),0 0 0 1px rgba(212,160,23,0.15)}
.actor-full-card[data-category="guest"]:hover{border-color:rgba(74,144,217,0.25);box-shadow:0 0 48px rgba(74,144,217,0.12),0 0 0 1px rgba(74,144,217,0.15)}
.actor-full-card .top{display:flex;gap:14px;margin-bottom:10px}
.actor-full-card .avatar{
  width:64px;height:64px;border-radius:50%;overflow:hidden;flex-shrink:0;
  border:2px solid var(--border);transition:border-color var(--ease);
}
.actor-full-card:hover .avatar{border-color:rgba(193,42,34,0.3)}
.actor-full-card .avatar .initials{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  font-family:var(--jp);font-size:16px;font-weight:700;color:rgba(237,230,225,0.15);
  background:linear-gradient(135deg,rgba(26,10,10,0.5),rgba(17,15,17,0.5));
}
.actor-full-card .info{flex:1;min-width:0}
.actor-full-card .info h4{font-size:14px;font-weight:600;color:var(--white);margin-bottom:2px}
.actor-full-card .info .jp-name{font-family:var(--jp);font-size:10px;color:rgba(237,230,225,0.3);margin-bottom:5px}
.actor-full-card .info .role-tag{
  display:inline-block;padding:4px 12px;font-size:10px;font-weight:600;
  border-radius:3px;letter-spacing:1px;
}
.actor-full-card .info .role-tag.lead{background:rgba(193,42,34,0.12);color:#ff6b6b}
.actor-full-card .info .role-tag.supporting{background:rgba(212,160,23,0.12);color:#ffd700}
.actor-full-card .info .role-tag.guest{background:rgba(74,144,217,0.12);color:#6bb8ff}
.actor-full-card .bio{font-size:12px;color:var(--muted);line-height:1.7;margin-bottom:10px}
.actor-full-card .tags{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:10px}
.actor-full-card .tags span{
  padding:3px 8px;font-size:9px;font-weight:500;
  background:rgba(237,230,225,0.03);color:var(--muted);
  border:1px solid rgba(237,230,225,0.06);border-radius:3px;
}
.actor-full-card .social{display:flex;gap:8px;padding-top:10px;border-top:1px solid rgba(237,230,225,0.04)}
.actor-full-card .social a{
  width:30px;height:30px;border-radius:var(--radius);
  border:1px solid var(--border);display:flex;align-items:center;justify-content:center;
  transition:all var(--ease);
}
.actor-full-card .social a svg{width:12px;height:12px;fill:var(--muted);transition:fill var(--ease)}
.actor-full-card .social a:hover{border-color:rgba(193,42,34,0.2)}
.actor-full-card .social a:hover svg{fill:var(--red)}

/* ===== CONTACT ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:start}
.contact-cards{display:flex;flex-direction:column;gap:10px}
.contact-card{
  display:flex;align-items:center;gap:14px;padding:18px 20px;
  background:linear-gradient(135deg,rgba(26,20,20,0.5),rgba(17,15,17,0.35));
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid var(--border);border-radius:var(--radius);
  transition:all var(--ease);
  position:relative;overflow:hidden;
}
.contact-card::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:2px;
  background:var(--red);opacity:0;
  transition:opacity var(--ease);
}
.contact-card:hover{border-color:rgba(193,42,34,0.2);transform:translateX(6px);box-shadow:0 0 32px rgba(193,42,34,0.04)}
.contact-card:hover::before{opacity:1}
.contact-card .icon{
  width:38px;height:38px;flex-shrink:0;border-radius:var(--radius);
  background:rgba(193,42,34,0.04);border:1px solid rgba(193,42,34,0.07);
  display:flex;align-items:center;justify-content:center;
  transition:all var(--ease);
}
.contact-card:hover .icon{background:rgba(193,42,34,0.1);border-color:rgba(193,42,34,0.2)}
.contact-card .icon svg{width:16px;height:16px;stroke:var(--red);fill:none;stroke-width:1.5}
.contact-card .body{flex:1;min-width:0}
.contact-card .body .label{
  font-size:9px;letter-spacing:2px;text-transform:uppercase;
  color:rgba(237,230,225,0.3);font-weight:500;display:block;margin-bottom:2px;
}
.contact-card .body .value{font-size:13px;font-weight:500;color:var(--white);display:block}
.contact-card .body .value a{color:var(--white);transition:color var(--ease)}
.contact-card .body .value a:hover{color:var(--red)}

.social-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px}
.social-card{
  display:flex;align-items:center;gap:12px;padding:14px 18px;
  background:linear-gradient(135deg,rgba(26,20,20,0.5),rgba(17,15,17,0.35));
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid var(--border);border-radius:var(--radius);
  transition:all var(--ease);
  position:relative;overflow:hidden;
}
.social-card::before{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(135deg,rgba(193,42,34,0.02),transparent);
  opacity:0;transition:opacity var(--ease);
}
.social-card:hover{border-color:rgba(193,42,34,0.25);transform:translateY(-4px);box-shadow:0 0 32px rgba(193,42,34,0.04)}
.social-card:hover::before{opacity:1}
.social-card .icon{
  width:34px;height:34px;border-radius:var(--radius);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:rgba(193,42,34,0.04);border:1px solid rgba(193,42,34,0.07);
  transition:all var(--ease);
}
.social-card:hover .icon{background:rgba(193,42,34,0.1);border-color:rgba(193,42,34,0.2)}
.social-card .icon svg{width:15px;height:15px;fill:var(--muted);transition:fill var(--ease)}
.social-card:hover .icon svg{fill:var(--red)}
.social-card .name{font-size:12px;font-weight:500;color:var(--white);letter-spacing:1px}

/* ===== FORM ===== */
.form-wrap{
  background:linear-gradient(135deg,rgba(26,20,20,0.5),rgba(17,15,17,0.35));
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid var(--border);border-radius:var(--radius);padding:32px 32px 28px;
}
.form-wrap:focus-within{border-color:rgba(193,42,34,0.15);box-shadow:0 0 32px rgba(193,42,34,0.02)}
.form-header{text-align:center;margin-bottom:18px}
.form-header h3{font-family:var(--disp);font-size:24px;letter-spacing:2px;color:var(--white);margin-bottom:4px}
.form-header p{font-size:12px;color:var(--muted)}
.form-group{margin-bottom:14px}
.form-group{
  position:relative;
}
.form-group:focus-within label{color:rgba(193,42,34,0.7)}
.form-group label{
  display:block;font-size:10px;font-weight:500;
  letter-spacing:2px;text-transform:uppercase;
  color:rgba(237,230,225,0.35);margin-bottom:5px;
  transition:color var(--ease);
}
.form-group label .req{color:var(--red);margin-left:3px}
.form-input,.form-select,.form-textarea{
  width:100%;padding:10px 12px;
  background:rgba(5,5,5,0.35);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  border:1px solid var(--border);border-radius:var(--radius);
  color:var(--white);font-family:var(--font);font-size:12px;font-weight:400;
  transition:all var(--ease);outline:none;
}
.form-input::placeholder,.form-textarea::placeholder{color:rgba(237,230,225,0.2)}
.form-input:hover,.form-select:hover,.form-textarea:hover{border-color:rgba(237,230,225,0.12)}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:rgba(193,42,34,0.25);box-shadow:0 0 32px rgba(193,42,34,0.06)}
.form-input.error,.form-select.error,.form-textarea.error{border-color:var(--red)}
.form-select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238A7E7A' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;cursor:pointer}
.form-select option{background:#000;color:var(--white)}
.form-textarea{resize:vertical;min-height:110px}
.file-upload{position:relative}
.file-upload-input{position:absolute;inset:0;opacity:0;cursor:pointer;z-index:2}
.file-upload-trigger{
  display:flex;align-items:center;gap:14px;padding:16px;
  background:rgba(5,5,5,0.35);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  border:1px dashed var(--border);border-radius:var(--radius);
  transition:all var(--ease);cursor:pointer;
}
.file-upload.dragover .file-upload-trigger{border-color:var(--red);background:rgba(193,42,34,0.02)}
.file-upload.has-file .file-upload-trigger{border-color:rgba(193,42,34,0.12);border-style:solid}
.file-upload-trigger .icon{
  width:38px;height:38px;border-radius:var(--radius);
  background:rgba(193,42,34,0.04);border:1px solid rgba(193,42,34,0.06);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.file-upload-trigger .icon svg{width:16px;height:16px;stroke:var(--muted)}
.file-upload-trigger .label{flex:1}
.file-upload-trigger .label .main{font-size:12px;color:var(--white);font-weight:500;display:block;margin-bottom:2px}
.file-upload-trigger .label .sub{font-size:10px;color:var(--muted)}
.file-name{display:none;font-size:11px;color:var(--red);font-weight:500;margin-top:4px}
.btn-submit{
  width:100%;padding:16px 28px;
  background:rgba(193,42,34,0.85);color:var(--white);border:none;border-radius:var(--radius);
  font-family:var(--font);font-size:12px;font-weight:600;
  letter-spacing:2px;text-transform:uppercase;cursor:pointer;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  transition:all var(--ease);
}
.btn-submit:hover{background:rgba(193,42,34,1);box-shadow:0 0 48px rgba(193,42,34,0.2);transform:translateY(-3px)}
.btn-submit:disabled{opacity:0.4;cursor:not-allowed;transform:none}

/* ===== TOAST ===== */
.toast{
  position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(100px);
  padding:16px 32px;background:rgba(5,5,5,0.85);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(193,42,34,0.15);border-radius:var(--radius);
  color:var(--white);font-size:13px;z-index:2000;
  opacity:0;visibility:hidden;transition:all .5s cubic-bezier(0.16,1,0.3,1);white-space:nowrap;
}
.toast.show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.toast span{color:var(--red);font-weight:600}
.toast svg{display:inline;width:18px;height:18px;margin-right:10px;vertical-align:middle;fill:var(--red)}

/* ===== CTA ===== */
.cta-section{text-align:center;padding:24px 0}
.cta-section h2{font-family:var(--disp);font-size:clamp(30px,4vw,48px);letter-spacing:2px;margin-bottom:6px;line-height:1.04}
.cta-section p{color:var(--muted);font-size:13px;margin-bottom:16px;max-width:450px;margin-left:auto;margin-right:auto}
.cta-section .btn{margin:0 8px}

/* ===== FOOTER ===== */
.footer{
  position:relative;z-index:1;
  background:linear-gradient(180deg,rgba(10,8,10,0.8) 0%,rgba(5,5,5,0.7) 100%);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-top:1px solid rgba(193,42,34,0.06);padding:64px 0 32px;
}
.footer::before{
  content:'';position:absolute;top:-1px;left:15%;right:15%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(193,42,34,0.2),transparent);
}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-brand p{font-size:12px;color:var(--muted);line-height:1.8;margin-top:12px;max-width:280px}
.footer h4{font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:rgba(237,230,225,0.6);margin-bottom:18px}
.footer-links{display:flex;flex-direction:column;gap:12px}
.footer-links.col2{column-count:2;column-gap:12px;display:block}
.footer-links.col2 a{display:block;margin-bottom:10px}
.footer-links a{font-size:12px;color:var(--muted);transition:color var(--ease)}
.footer-links a:hover{color:var(--red)}
.footer-bottom{
  border-top:1px solid rgba(237,230,225,0.04);padding-top:24px;
  display:flex;align-items:center;justify-content:space-between;
}
.footer-bottom p{font-size:10px;color:rgba(237,230,225,0.3);letter-spacing:.5px}
.footer-social{display:flex;gap:14px}
.footer-social a{
  width:42px;height:42px;border-radius:50%;
  border:1px solid var(--border);display:flex;align-items:center;justify-content:center;
  transition:all var(--ease);
}
.footer-social a svg{width:18px;height:18px;fill:var(--muted);transition:fill var(--ease)}
.footer-social a:hover{border-color:rgba(193,42,34,0.25);box-shadow:0 0 24px rgba(193,42,34,0.08)}
.footer-social a[aria-label="Telegram"]:hover svg{fill:#0088cc}
.footer-social a[aria-label="Instagram"]:hover svg{fill:#e4405f}
.footer-social a[aria-label="YouTube"]:hover svg{fill:#ff0000}
.footer-social a[aria-label="TikTok"]:hover svg{fill:#00f2ea}
.footer-social a:hover svg{fill:var(--red)}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .about-grid{grid-template-columns:1fr;gap:20px}
  .about-visual{order:-1;max-height:120px}
  .project-grid{grid-template-columns:repeat(2,1fr)}
  .actor-grid{grid-template-columns:repeat(2,1fr)}
  .values-grid{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr;gap:24px}
  .stats-row{grid-template-columns:repeat(2,1fr);gap:12px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
}

@media(max-width:768px){
  .nav-links{display:none}
  .hamburger{display:flex}
  .section{padding:60px 0}
  .page-hero{padding:140px 0 60px}
  .site-bg{background-attachment:scroll;animation:none}
  .site-grain{display:none}
  .hero{min-height:92vh}
  .hero-glow{animation:none;opacity:0.3;width:min(80vmin,360px);height:min(80vmin,360px)}
  .page-hero-bg{display:none}
  .project-grid{grid-template-columns:1fr;max-width:420px;margin:0 auto}
  .actor-grid{grid-template-columns:1fr;max-width:340px;margin:0 auto}
  .actors-grid{grid-template-columns:1fr;max-width:400px;margin:0 auto}
  .actor-full-card .top{flex-direction:column;align-items:center;text-align:center}
  .social-grid{grid-template-columns:1fr;max-width:320px;margin:16px auto 0}
  .form-wrap{padding:20px 18px}
  .values-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .footer-bottom{flex-direction:column;text-align:center;gap:16px}
  .stats-row{gap:10px}
  .stat-item{padding:16px 10px}
}

@media(max-width:480px){
  .hero-title{font-size:44px;letter-spacing:3px}
  .hero-jp{font-size:11px;letter-spacing:6px}
  .hero-sub{font-size:11px;letter-spacing:3px}
  .hero-actions{flex-direction:column;align-items:center;width:100%}
  .hero-actions .btn{width:100%;justify-content:center}
  .section{padding:40px 0}
  .section-title{font-size:clamp(26px,7vw,34px)}
  .contact-card{padding:10px 12px}
  .timeline-item{grid-template-columns:36px 1fr;gap:14px}
  .timeline-year{font-size:18px}
  .timeline-year::after{right:-12px;width:6px;height:6px}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .reveal{opacity:1;transform:none}
  .site-bg{animation:none!important}
  .hero-glow{animation:none!important}
  .hero-jp,.hero-title,.hero-sub,.hero-actions,.hero-line{opacity:1;transform:none!important}
}
