/* ======================
BUTTON
====================== */

.btn-primary,
.btn-secondary{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:54px;
  padding:15px 30px;
  border-radius:999px;
  text-decoration:none;
  font-weight:700;
  transition:all 0.25s ease;
}

.btn-primary{
  background:var(--main-navy);
  color:#ffffff;
  border:1px solid var(--main-navy);
}

.btn-primary:hover{
  background:var(--navy-soft);
  border-color:var(--navy-soft);
  transform:translateY(-2px);
}

.btn-secondary{
  background:rgba(255,255,255,0.86);
  color:var(--main-navy);
  border:1px solid rgba(11,37,69,0.15);
}

.btn-secondary:hover{
  background:var(--main-navy);
  color:#ffffff;
  border-color:var(--main-navy);
  transform:translateY(-2px);
}

.badge{
  display:inline-flex;
  align-items:center;
  padding:10px 14px;
  border-radius:999px;
  background:#eaf1fb;
  color:var(--accent);
  font-weight:700;
  font-size:0.95rem;
}

/* ======================
ALBUM GRID
====================== */

.album-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:34px;
}

.album-card{
  overflow:hidden;
}

.album-thumb{
  aspect-ratio:1 / 1;
  overflow:hidden;
  background:#f2f5fa;
}

.album-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.album-body{
  padding:24px;
}

.album-body h3{
  font-size:1.16rem;
  color:var(--main-navy);
  margin-bottom:6px;
}

.album-body p{
  color:var(--subtext);
  margin-bottom:18px;
}

.album-card audio{
  width:100%;
}

/* ======================
SEIHI
====================== */

.seihi-showcase{
  overflow:hidden;
}

.seihi-preview{
  width:100%;
  aspect-ratio:16 / 9;
  object-fit:cover;
  background:#edf2f9;
}

.seihi-meta{
  padding:28px 28px 30px;
}

.seihi-meta p{
  color:var(--subtext);
  margin-top:16px;
}

/* ======================
TEAM GRID
====================== */

.team-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:34px;
}

.team-card{
  overflow:hidden;
  cursor:pointer;
  position:relative;
}

.team-card::after{
  content:"View Profile";
  position:absolute;
  left:20px;
  bottom:20px;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(11,37,69,0.82);
  color:#fff;
  font-size:0.82rem;
  font-weight:700;
  letter-spacing:0.04em;
  opacity:0;
  transform:translateY(10px);
  transition:opacity 0.28s ease, transform 0.28s ease;
}

.team-card:hover::after{
  opacity:1;
  transform:translateY(0);
}

.team-card img{
  width:100%;
  aspect-ratio:4 / 4.8;
  object-fit:cover;
  background:#f2f5fa;
  transition:transform 0.5s ease;
}

.team-card:hover img{
  transform:scale(1.04);
}

.team-card-body{
  padding:22px 20px 24px;
}

.team-card-body h3{
  font-size:1.14rem;
  color:var(--main-navy);
  margin-bottom:6px;
}

.team-card-body p{
  color:var(--subtext);
  font-size:0.97rem;
}

/* ======================
TEAM MODAL
====================== */

.team-modal{
  position:fixed;
  inset:0;
  z-index:2000;
  display:flex;
  align-items:stretch;
  justify-content:center;
  pointer-events:none;
}

.team-modal.active{
  pointer-events:auto;
}

.modal-overlay{
  position:absolute;
  inset:0;
  background:rgba(7, 16, 30, 0.72);
  backdrop-filter:blur(10px);
  opacity:0;
  transition:opacity 0.45s ease;
}

.team-modal.active .modal-overlay{
  opacity:1;
}

.modal-content{
  position:relative;
  z-index:1;
  width:100%;
  height:100vh;
  display:grid;
  grid-template-columns:minmax(320px, 0.95fr) minmax(420px, 1.05fr);
  background:
    linear-gradient(135deg, rgba(255,255,255,0.98) 0%, rgba(244,248,255,0.98) 100%);
  transform:translateY(34px) scale(0.985);
  opacity:0;
  transition:
    transform 0.55s cubic-bezier(0.22, 1, 0.36, 1),
    opacity 0.45s ease;
  overflow:hidden;
}

.team-modal.active .modal-content{
  transform:translateY(0) scale(1);
  opacity:1;
}

.modal-close{
  position:absolute;
  top:28px;
  right:28px;
  width:52px;
  height:52px;
  border:none;
  border-radius:999px;
  background:rgba(11,37,69,0.08);
  backdrop-filter:blur(10px);
  cursor:pointer;
  z-index:20;
  transition:transform 0.25s ease, background 0.25s ease;
}

.modal-close:hover{
  transform:rotate(90deg);
  background:rgba(11,37,69,0.14);
}

.modal-close span{
  position:absolute;
  left:50%;
  top:50%;
  width:20px;
  height:2px;
  background:var(--main-navy);
  border-radius:999px;
}

.modal-close span:first-child{
  transform:translate(-50%, -50%) rotate(45deg);
}

.modal-close span:last-child{
  transform:translate(-50%, -50%) rotate(-45deg);
}

.modal-image-panel{
  position:relative;
  min-height:100vh;
  background:
    radial-gradient(circle at 35% 30%, rgba(27,60,115,0.25), transparent 32%),
    linear-gradient(180deg, #10233f 0%, #0b2545 100%);
  padding:42px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.modal-image-wrap{
  width:min(100%, 620px);
  height:min(84vh, 860px);
  border-radius:32px;
  overflow:hidden;
  box-shadow:0 24px 60px rgba(0,0,0,0.28);
  border:1px solid rgba(255,255,255,0.14);
  transform:translateY(30px);
  opacity:0;
  transition:
    transform 0.65s cubic-bezier(0.22, 1, 0.36, 1) 0.08s,
    opacity 0.55s ease 0.08s;
}

.team-modal.active .modal-image-wrap{
  transform:translateY(0);
  opacity:1;
}

.modal-image-wrap img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.modal-info-panel{
  min-height:100vh;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  padding:0;
}

.modal-info-inner{
  max-width:760px;
  padding:88px 72px 72px;
  transform:translateY(34px);
  opacity:0;
  transition:
    transform 0.65s cubic-bezier(0.22, 1, 0.36, 1) 0.14s,
    opacity 0.55s ease 0.14s;
}

.team-modal.active .modal-info-inner{
  transform:translateY(0);
  opacity:1;
}

.modal-kicker{
  display:inline-flex;
  align-items:center;
  margin-bottom:18px;
  color:var(--accent);
  font-weight:800;
  letter-spacing:0.18em;
  font-size:0.9rem;
}

.modal-info-panel h2{
  font-size:clamp(2.4rem, 4vw, 4.2rem);
  line-height:1.04;
  color:var(--main-navy);
  margin-bottom:14px;
  letter-spacing:-0.04em;
}

.modal-role{
  font-size:1.08rem;
  font-weight:700;
  color:var(--accent);
  margin-bottom:24px;
}

.modal-desc{
  font-size:1.08rem;
  color:var(--text);
  margin-bottom:14px;
}

.modal-summary{
  color:var(--subtext);
  font-size:1rem;
  margin-bottom:34px;
  max-width:640px;
}

.modal-section{
  padding-top:28px;
  margin-top:28px;
  border-top:1px solid rgba(11,37,69,0.08);
}

.modal-section h3{
  font-size:1rem;
  color:var(--main-navy);
  margin-bottom:16px;
  font-weight:800;
  letter-spacing:-0.02em;
}

.modal-career-list{
  list-style:none;
  display:grid;
  gap:14px;
}

.modal-career-list li{
  position:relative;
  padding:16px 18px 16px 44px;
  border:1px solid rgba(11,37,69,0.07);
  border-radius:18px;
  background:rgba(255,255,255,0.78);
  color:var(--text);
  box-shadow:0 10px 24px rgba(11,37,69,0.04);
}

.modal-career-list li::before{
  content:"";
  position:absolute;
  left:18px;
  top:22px;
  width:10px;
  height:10px;
  border-radius:50%;
  background:linear-gradient(135deg, var(--accent), var(--main-navy));
  box-shadow:0 0 0 6px rgba(27,60,115,0.08);
}

.modal-tags{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}

.modal-tags span{
  display:inline-flex;
  align-items:center;
  min-height:42px;
  padding:0 16px;
  border-radius:999px;
  background:#eaf1fb;
  color:var(--main-navy);
  font-weight:700;
  font-size:0.95rem;
  border:1px solid rgba(27,60,115,0.08);
}

@media (max-width:1024px){
  .modal-content{
    grid-template-columns:1fr;
    height:100vh;
  }

  .modal-image-panel{
    min-height:46vh;
    padding:34px 24px 18px;
  }

  .modal-image-wrap{
    width:min(100%, 720px);
    height:min(44vh, 520px);
  }

  .modal-info-panel{
    min-height:auto;
  }

  .modal-info-inner{
    max-width:none;
    padding:38px 28px 40px;
  }
}

@media (max-width:768px){
  .modal-close{
    top:18px;
    right:18px;
    width:46px;
    height:46px;
  }

  .modal-image-panel{
    min-height:38vh;
    padding:22px 16px 10px;
  }

  .modal-image-wrap{
    height:min(34vh, 360px);
    border-radius:24px;
  }

  .modal-info-inner{
    padding:26px 18px 34px;
  }

  .modal-desc,
  .modal-summary{
    font-size:0.98rem;
  }

  .modal-career-list li{
    padding:14px 16px 14px 40px;
    border-radius:16px;
  }
}

/* ======================
RESPONSIVE
====================== */

@media (max-width:1024px){
  .album-grid,
  .team-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:26px;
  }
}

@media (max-width:768px){
  .album-grid,
  .team-grid{
    grid-template-columns:1fr;
    gap:22px;
  }

  .album-body{
    padding:20px;
  }

  .modal-content{
    grid-template-columns:1fr;
  }
}

@media (max-width:480px){
  .btn-primary,
  .btn-secondary{
    width:100%;
  }

  .modal-close{
    top:10px;
    right:10px;
  }
}

/* ======================
TEAM SOCIAL
====================== */

.modal-social{
  display:flex;
  gap:14px;
  margin-top:10px;
}

.modal-social a{
  width:44px;
  height:44px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:12px;

  background:#eef3fb;
  color:var(--main-navy);

  font-size:20px;

  transition:all .25s ease;
}

.modal-social a:hover{
  transform:translateY(-3px);
  background:var(--main-navy);
  color:white;
}