@font-face{
  font-family: "bwgradualmedium";
  font-style: normal;
  font-weight: 400;
  src: url("assets/fonts/BwGradual-Medium.woff2") format("woff2"),
       url("assets/fonts/BwGradual-Medium.woff") format("woff");
  font-display: swap;
}

:root{
  --bg:#000;
  --white:#fff;
  --card:#2f2f2f;
  --cardEdge:#1f1f1f;
  --primary:#f30530;
  --muted: rgba(255,255,255,.78);
  --muted2: rgba(255,255,255,.6);
  --shadow: 0 18px 60px rgba(0,0,0,.55);
  --radius: 14px;
  --maxw: 420px;
  --padX: clamp(16px, 5vw, 22px);
  --padTop: clamp(18px, 4vh, 28px);
  --padBottom: clamp(18px, 4vh, 28px);
  --h1: clamp(52px, 11vw, 70px);
  --h1Gap: clamp(18px, 3.2vh, 28px);
  --stackH: clamp(210px, 30vh, 250px);
  --ctaPadY: clamp(10px, 2vh, 14px);
  --ctaFont: clamp(18px, 3.8vw, 22px);
}

*{box-sizing:border-box}
html,body{height:100%; overflow:hidden;}
body{
  margin:0;
  background: var(--bg);
  color: var(--white);
  font-family: bwgradualmedium, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  overflow-x:hidden;
  overscroll-behavior:none;
}

a{color:inherit; text-decoration:none;}

.screen{
  min-height:100dvh;
  display:flex;
  flex-direction:column;
  padding: calc(var(--padTop) + env(safe-area-inset-top)) var(--padX) calc(var(--padBottom) + env(safe-area-inset-bottom));
  max-width: var(--maxw);
  margin: 0 auto;
}

.top{
  display:flex;
  align-items:center;
  justify-content:flex-start;
}

.brand{
  display:flex;
  align-items:center;
  gap: 12px;
}

.hero{
  flex:1 1 auto;
  min-height:0;
  padding-top: 0;
  display:flex;
  flex-direction:column;
  gap: var(--h1Gap);
}

.headline{
  font-size: var(--h1);
  line-height: 1.05;
  margin: 0;
}

.stackWrap{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap: 18px;
  margin-top: 8px;
}

.cardStack{
  position: relative;
  width: 100%;
  max-width: 360px;
  height: var(--stackH);
  touch-action: none;
}

.card{
  position:absolute;
  inset: 0;
  border-radius: 0;
  background: var(--card);
  box-shadow: var(--shadow);
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  will-change: transform;
  user-select:none;
  -webkit-tap-highlight-color: transparent;
  transition: transform 280ms cubic-bezier(.2,.9,.2,1), opacity 280ms cubic-bezier(.2,.9,.2,1);
}

.card::before{
  content:"";
  position:absolute;
  inset: 0;
  border: 1px solid rgba(0,0,0,.35);
  pointer-events:none;
}

.cardInner{
  width: 100%;
  height: 100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap: 10px;
  padding: 24px 18px;
  text-align:center;
}

.cardLogoCircle{
  width: 116px;
  height: 116px;
  border-radius: 999px;
  background: rgba(0,0,0,.25);
  display:flex;
  align-items:center;
  justify-content:center;
}
.cardLogoCircle img{width:64%;height:64%;object-fit:contain;display:block;}
.cardLogoCircle.isAvatar img{width:100%;height:100%;object-fit:cover;border-radius:999px;}
.cardLogoCircle.isMark img{width:100%;height:100%;object-fit:contain;}

.cardTitle{
  font-size: clamp(34px, 10vw, 44px);
  line-height:1.05;
}

.cardSub{
  font-size: clamp(18px, 5vw, 22px);
  color: var(--muted);
}

.plus{
  position:absolute;
  right: 18px;
  top: 18px;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  background: var(--primary);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size: 30px;
  line-height: 1;
  border: none;
  color: var(--white);
  cursor:pointer;
  box-shadow: 0 12px 26px rgba(243,5,48,.35);
}

.progress{
  position: relative;
  width: 150px;
  height: 4px;
}
.progressTrack{
  position:absolute; inset:0;
  background: rgba(255,255,255,.38);
}
.progressFill{
  position:absolute;
  left:0; top:0; bottom:0;
  width: 28px;
  background: var(--primary);
  transition: left 340ms cubic-bezier(0.16, 1, 0.3, 1), width 340ms cubic-bezier(0.16, 1, 0.3, 1);
}

.ctaWrap{margin-top:auto; padding-top:18px;}
.cta{
  display:block;
  align-self:center;
  background: var(--white);
  color: #000;
  padding: var(--ctaPadY) 18px;
  min-width: min(320px, 88vw);
  text-align:center;
  border-radius: 0;
  font-size: var(--ctaFont);
  letter-spacing: .1px;
}
.ctaArrow{display:inline-block; margin-left:10px; transform: translateY(1px);}

.overlay{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(6px);
  opacity: 0;
  pointer-events:none;
  transition: opacity 220ms ease;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 18px;
  z-index: 9998;
}
.overlay.open{
  opacity: 1;
  pointer-events:auto;
}

.sheet{
  width: min(420px, 100%);
  background: #3a3a3a;
  border-radius: 0;
  padding: clamp(18px, 3.5vh, 28px) var(--padX) clamp(18px, 3vh, 26px);
  position: relative;
  box-shadow: 0 30px 90px rgba(0,0,0,.6);
  transform: translateY(12px);
  transition: transform 220ms ease;
  max-height: calc(100dvh - 24px - env(safe-area-inset-top) - env(safe-area-inset-bottom));
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  touch-action: pan-y;
}
.overlay.open .sheet{ transform: translateY(0); }

.closeBtn{
  position:absolute;
  top: 18px;
  right: 18px;
  width: 56px;
  height: 56px;
  border-radius: 999px;
  background:#fff;
  color:#000;
  border:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
}
.icon-arrow{width:28px; height:28px;}

.portraitWrap{
  display:flex;
  justify-content:center;
  margin-top: 8px;
}
.portrait{
  width: clamp(140px, 38vw, 220px);
  height: clamp(140px, 38vw, 220px);
  border-radius: 999px;
  object-fit: cover;
  background:#111;
}

.detailText{ margin-top: 20px; }
.detailName{
  font-size: clamp(40px, 10vw, 54px);
  line-height: .95;
  margin-bottom: 8px;
}
.detailRole{
  font-size: clamp(22px, 5vw, 28px);
  color: var(--muted);
  margin-bottom: 22px;
}

.detailList{
  display:flex;
  flex-direction:column;
  gap: 16px;
  margin-bottom: 18px;
}
.fieldLabel{
  font-size: 16px;
  color: var(--primary);
  margin-bottom: 4px;
}
.fieldValue{
  font-size: clamp(18px, 4.7vw, 22px);
  color: var(--white);
  letter-spacing: .2px;
  line-height: 1.25;
}
.fieldLink{
  color: var(--white);
  text-decoration:none;
  border-bottom: 1px solid rgba(255,255,255,.22);
  padding-bottom: 1px;
}
.fieldLinkRoute{
  display:inline-flex;
  align-items:center;
  gap:10px;
  border-bottom: 0;
  color: rgba(255,255,255,.9);
}
.routeIcon{
  width: 15px;
  height: 15px;
  color: rgba(255,255,255,.78);
  flex: 0 0 auto;
  transform: translateY(1px);
}

.profileBlock{
  margin-top: 2px;
  margin-bottom: 20px;
}
.profileLabel{
  font-size: 16px;
  color: var(--primary);
  margin-bottom: 8px;
}
.profileChips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.profileChip{
  display:inline-flex;
  align-items:center;
  min-height: 30px;
  padding: 6px 10px;
  font-size: 14px;
  line-height: 1.15;
  color: rgba(255,255,255,.88);
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.08);
}

.socialRow{
  display:flex;
  gap: 14px;
  margin-top: 4px;
}
.socialBtn{
  width: 56px;
  height: 56px;
  background: #fff;
  border:none;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  border-radius: 0;
}
.socialBtn svg{ width: 28px; height: 28px; }

.saveBtn{
  margin-top: 22px;
  width: 100%;
  background: #fff;
  border:none;
  padding: 16px 14px;
  font-size: clamp(18px, 4vw, 20px);
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 12px;
  cursor:pointer;
  color:#000;
}
.savePlus{
  color: var(--primary);
  font-size: 28px;
  transform: translateY(-1px);
}

.ufmark img{width:100%;height:100%;object-fit:cover;display:block;}
.expanderCard{
  position: fixed;
  z-index: 9999;
  background: rgba(48,48,48,0.92);
  box-shadow: 0 24px 60px rgba(0,0,0,0.55);
  border: 1px solid rgba(0,0,0,0.45);
  border-radius: 0;
  overflow: hidden;
  will-change: transform, opacity;
}
.expanderCard .plus{display:none;}

@media (max-width: 390px){
  .detailRole{max-width: 90%;}
  .profileChip{font-size:13px; padding:5px 9px;}
  .saveBtn{padding:14px 12px;}
}

@media (prefers-reduced-motion: reduce){
  .card, .progressFill, .overlay, .sheet{ transition:none !important; }
}
