/* ── Base ──────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --primary:  #D02657;
  --btn:      #a30000;
  --bg:       #131313;
  --surface:  #1a1a1a;
  --surface2: #222;
  --border:   rgba(208,38,87,.25);
  --glow:     rgba(208,38,87,.55);
  --text:     #f0f0f0;
  --muted:    #888;
}

body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Segoe UI', system-ui, sans-serif;
  min-height: 100vh;
  overflow-x: hidden;
}

body::before {
  content: '';
  position: fixed; inset: 0;
  background:
    radial-gradient(ellipse 80% 50% at 20% 10%, rgba(208,38,87,.12) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 80% 80%, rgba(163,0,0,.10) 0%, transparent 55%);
  pointer-events: none; z-index: 0;
  animation: bgPulse 8s ease-in-out infinite alternate;
}
@keyframes bgPulse { from{opacity:.6} to{opacity:1} }

body::after {
  content: '';
  position: fixed; inset: 0;
  background-image: radial-gradient(rgba(208,38,87,.08) 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none; z-index: 0;
}

.container { position: relative; z-index: 1; }

/* ── Page title ────────────────────────────────────────── */
.page-title {
  font-size: clamp(1.8rem,4vw,3rem);
  font-weight: 800; letter-spacing: -1px;
  background: linear-gradient(135deg,#fff 30%,var(--primary));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: fadeDown .7s ease both;
}
.page-sub { color:var(--muted); font-size:.95rem; margin-top:.4rem; animation: fadeDown .7s .15s ease both; }
@keyframes fadeDown { from{opacity:0;transform:translateY(-18px)} to{opacity:1;transform:translateY(0)} }

/* ── Search bar ────────────────────────────────────────── */
.search-wrap { animation: fadeDown .7s .25s ease both; }
.search-group {
  display: flex; border-radius: 14px; overflow: hidden;
  border: 1.5px solid var(--border); background: var(--surface);
  transition: box-shadow .3s, border-color .3s;
}
.search-group:focus-within { border-color:var(--primary); box-shadow:0 0 22px var(--glow); }
.search-group input {
  flex:1; background:transparent; border:none; outline:none;
  color:var(--text); padding:14px 20px; font-size:1rem;
}
.search-group input::placeholder { color:var(--muted); }
.search-group button {
  background: linear-gradient(135deg,var(--primary),var(--btn));
  border:none; color:#fff; padding:0 28px;
  font-weight:700; font-size:.95rem; letter-spacing:.5px;
  cursor:pointer; position:relative; overflow:hidden; transition:filter .2s;
}
.search-group button::after {
  content:''; position:absolute; inset:0;
  background:rgba(255,255,255,.12);
  transform:translateX(-100%) skewX(-15deg); transition:transform .35s;
}
.search-group button:hover::after { transform:translateX(110%) skewX(-15deg); }
.search-group button:hover { filter:brightness(1.15); }

/* ── Loader ────────────────────────────────────────────── */
#loader { display:none; margin:40px auto 0; max-width:480px; }
#loader.active { display:block; }
.loader-label { font-size:.8rem; color:var(--muted); letter-spacing:1px; text-transform:uppercase; margin-bottom:10px; display:flex; justify-content:space-between; }
.loader-label span { color:var(--primary); font-weight:700; }
.bar-track { height:10px; border-radius:99px; background:var(--surface2); box-shadow:inset 0 3px 6px rgba(0,0,0,.6); overflow:hidden; }
.bar-fill { height:100%; width:0%; border-radius:99px; background:linear-gradient(90deg,var(--btn),var(--primary),#ff6fa3); box-shadow:0 0 14px var(--glow); transition:width .05s linear; position:relative; overflow:hidden; }
.bar-fill::after { content:''; position:absolute; top:0;left:-60%;width:50%;height:100%; background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent); animation:shimmer 1.4s infinite; }
@keyframes shimmer { to{left:160%} }
.particles { position:relative;height:30px;margin-top:6px;overflow:hidden; }
.particle { position:absolute;border-radius:50%;background:var(--primary);opacity:0;animation:floatUp 1.4s ease-in infinite; }
@keyframes floatUp { 0%{opacity:.8;transform:translateY(30px) scale(1)} 100%{opacity:0;transform:translateY(-10px) scale(.4)} }

/* ── Employee card ─────────────────────────────────────── */
#employeeCard { margin-top:32px; }

.emp-card {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: 20px; overflow:hidden;
  animation: cardIn .6s cubic-bezier(.22,1,.36,1) both;
  box-shadow: 0 8px 40px rgba(0,0,0,.5);
  transition: box-shadow .4s;
}
.emp-card:hover { box-shadow:0 8px 40px rgba(0,0,0,.5),0 0 30px var(--glow); }
@keyframes cardIn { from{opacity:0;transform:translateY(30px) scale(.97)} to{opacity:1;transform:none} }

.card-banner {
  height:110px;
  background:linear-gradient(135deg,var(--btn) 0%,var(--primary) 60%,#ff6fa3 100%);
  position:relative; overflow:hidden;
}
.card-banner::before {
  content:''; position:absolute; inset:0;
  background:repeating-linear-gradient(-45deg,rgba(255,255,255,.04) 0px,rgba(255,255,255,.04) 2px,transparent 2px,transparent 14px);
}
.ring { position:absolute;border-radius:50%;border:2px solid rgba(255,255,255,.15);animation:spinRing linear infinite; }
.ring1{width:120px;height:120px;top:-30px;right:40px;animation-duration:9s}
.ring2{width:80px;height:80px;top:10px;right:90px;animation-duration:6s;animation-direction:reverse}
@keyframes spinRing { to{transform:rotate(360deg)} }

.card-body-inner { padding:0 28px 28px; }

/* ── Profile header layout (FIXED OVERLAP) ──────────────── */
.profile-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end; /* Align elements to bottom baseline on desktop */
  gap: 30px;
  margin-top: 0px; /* Removed negative gap that pulled everything up */
  margin-bottom: 25px;
  flex-wrap: wrap;
}

.profile-left {
  display: flex;
  align-items: flex-end; /* Keep avatar and details anchored properly */
  gap: 20px;
  flex: 1;
  min-width: 280px;
}

.profile-name-block {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 8px; /* Safe padding from layout line */
}

.emp-avatar {
  width: 88px; height: 88px; border-radius: 50%;
  border: 4px solid var(--surface);
  box-shadow: 0 0 0 3px var(--primary), 0 6px 24px rgba(208,38,87,.4);
  object-fit: cover; background: var(--surface2);
  flex-shrink: 0;
  margin-top: -80px; /* ONLY push the picture into the gradient banner */
  z-index: 2;
  animation: avatarPop .5s .3s cubic-bezier(.22,1,.36,1) both;
  transition: transform .2s, box-shadow .2s;
}
.emp-avatar:hover { transform: scale(1.08); box-shadow: 0 0 0 3px var(--primary), 0 0 28px var(--glow); }
@keyframes avatarPop { from{transform:scale(.5);opacity:0} to{transform:scale(1);opacity:1} }

.emp-name { font-size: 1.4rem; font-weight: 800; letter-spacing: -.5px; animation: fadeIn .4s .35s ease both; }
.emp-role { color: var(--primary); font-size: .9rem; font-weight: 600; animation: fadeIn .4s .4s ease both; }

/* Right side: verified badge + large ID + copy btn */
.profile-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: center;
  gap: 8px;
  min-width: 240px;
  margin: 10px 0 0 0
}

.verified-badge {
  display: flex; align-items: center; gap: 6px;
  background: rgba(208,38,87,.12); border: 1px solid rgba(208,38,87,.35);
  border-radius: 99px; padding: 5px 14px;
  font-size: .75rem; font-weight: 700; letter-spacing: .5px; color: #ff8ab0;
  animation: fadeIn .5s .5s ease both;
}
.verified-dot { width: 7px; height: 7px; border-radius: 50%; background: #4ade80; box-shadow: 0 0 6px #4ade80; animation: dotPulse 1.5s infinite; }
@keyframes dotPulse { 0%,100%{transform:scale(1);opacity:1} 50%{transform:scale(1.5);opacity:.6} }

.profile-id-label {
  font-size: .65rem; letter-spacing: 2px; text-transform: uppercase;
  color: var(--muted); font-weight: 600;
}

.profile-id-value {
  font-size: 1.6rem; font-weight: 800; letter-spacing: 1px;
  color: #fff; line-height: 1.1;
  animation: fadeIn .4s .45s ease both;
}

.card-divider { height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent);margin:20px 0; }

/* ── 3×2 info grid (6 items, 3 columns × 2 rows) ──────── */
.info-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.info-item {
  background:var(--surface2);
  border:1px solid rgba(255,255,255,.06);
  border-radius:12px;padding:14px 16px;
  animation:fadeIn .4s ease both;
  transition:border-color .2s,transform .2s;
  position:relative;overflow:hidden;
}
.info-item::before {
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--btn),var(--primary));
  opacity:0;transition:opacity .2s;
}
.info-item:hover { border-color:var(--border);transform:translateY(-2px); }
.info-item:hover::before { opacity:1; }
.info-label { font-size:.7rem;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:5px; }
.info-value { font-size:.95rem;font-weight:600;color:var(--text);word-break:break-all; }
.status-active  { color:#4ade80; }
.status-inactive{ color:#f87171; }

/* stagger */
.info-item:nth-child(1){animation-delay:.08s}
.info-item:nth-child(2){animation-delay:.14s}
.info-item:nth-child(3){animation-delay:.20s}
.info-item:nth-child(4){animation-delay:.26s}
.info-item:nth-child(5){animation-delay:.32s}
.info-item:nth-child(6){animation-delay:.38s}

/* clickable email */
.email-link {
  color: var(--primary);
  text-decoration: none;
  font-weight: 600;
  display: inline-flex; align-items: center; gap: 5px;
  transition: color .2s, text-shadow .2s;
}
.email-link::before { content:'✉'; font-size:.9em; }
.email-link:hover { color:#ff8ab0; text-shadow:0 0 10px var(--glow); text-decoration:underline; }

@keyframes fadeIn { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:none} }

/* ── Error box ─────────────────────────────────────────── */
.error-box {
  background:rgba(163,0,0,.12);border:1.5px solid rgba(163,0,0,.4);
  border-radius:14px;padding:28px;text-align:center;color:#f87171;
  font-weight:600;animation:cardIn .4s ease both;
}

/* ═══════════════════════════════════════════════════════
   FULL-SCREEN FLIP LIGHTBOX
   ═══════════════════════════════════════════════════════ */
.img-lightbox {
  position: fixed; inset: 0; z-index: 2000;
  display: flex; align-items: center; justify-content: center;
  background: rgba(0,0,0,0);
  backdrop-filter: blur(0px);
  -webkit-backdrop-filter: blur(0px);
  transition: background .35s, backdrop-filter .35s;
  pointer-events: none; opacity: 0;
}
.img-lightbox.open {
  background: rgba(0,0,0,.92);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  pointer-events: all; opacity: 1;
}

/* Full-screen scene wrapper */
.lb-fullscreen-wrap {
  width: 100vw; height: 100vh;
  display: flex; align-items: center; justify-content: center;
  perspective: 1200px;
}

/* flip scene = full viewport minus safe padding */
.flip-scene {
  width: min(90vw, 90vh);
  height: min(90vw, 90vh);
}

.flip-card {
  width: 100%; height: 100%;
  position: relative;
  transform-style: preserve-3d;
  transition: transform .75s cubic-bezier(.4,0,.2,1);
  transform: rotateY(90deg) scale(.7);
}
.img-lightbox.open .flip-card {
  transform: rotateY(0deg) scale(1);
}
.flip-scene.flipped .flip-card {
  transform: rotateY(180deg) scale(1) !important;
}

/* ── Front face ── */
.flip-front, .flip-back {
  position: absolute; inset: 0;
  border-radius: 20px;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  overflow: hidden;
  box-shadow: 0 30px 80px rgba(0,0,0,.8), 0 0 0 1.5px var(--border);
}

.flip-front { background: #000; }
.flip-front img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
.lb-photo-hint {
  position: absolute; bottom: 18px; left: 50%; transform: translateX(-50%);
  background: rgba(0,0,0,.6); backdrop-filter: blur(6px);
  color: rgba(255,255,255,.7); font-size: .75rem; letter-spacing: 1px;
  padding: 6px 18px; border-radius: 99px; pointer-events: none;
  animation: hintBlink 2.5s ease infinite;
}
@keyframes hintBlink { 0%,100%{opacity:.5} 50%{opacity:1} }

/* ── Back face ── */
.flip-back {
  background: linear-gradient(145deg, #180810 0%, var(--surface) 50%, #1e0814 100%);
  transform: rotateY(180deg);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 12px; padding: 40px 32px; text-align: center;
  border: 1.5px solid var(--border);
}

.fb-glow-ring {
  position: absolute; width: 260px; height: 260px; border-radius: 50%;
  border: 1.5px solid rgba(208,38,87,.2);
  animation: spinRing 12s linear infinite;
  pointer-events: none;
}

.fb-avatar-wrap {
  width: 100px; height: 100px; border-radius: 50%;
  border: 3px solid var(--primary);
  box-shadow: 0 0 0 6px rgba(208,38,87,.15), 0 0 30px var(--glow);
  overflow: hidden; flex-shrink: 0;
}
.fb-thumb { width: 100%; height: 100%; object-fit: cover; }

.fb-id   { font-size: .7rem; letter-spacing: 3px; text-transform: uppercase; color: var(--primary); }
.fb-name { font-size: clamp(1.2rem,3vw,1.8rem); font-weight: 800; color: #fff; }
.fb-divider { width: 60px; height: 1px; background: var(--border); }

.fb-row  { display: flex; gap: 10px; align-items: center; }
.fb-key  { font-size: .72rem; text-transform: uppercase; letter-spacing: 1px; color: var(--muted); min-width: 52px; text-align: right; }
.fb-val  { font-size: .9rem; font-weight: 600; color: var(--text); }

.fb-badge {
  margin-top: 6px;
  background: rgba(208,38,87,.15); border: 1px solid rgba(208,38,87,.4);
  border-radius: 99px; padding: 6px 20px;
  font-size: .7rem; font-weight: 700; letter-spacing: 1px; color: #ff8ab0;
}
.fb-tap-hint { font-size: .7rem; color: rgba(255,255,255,.25); letter-spacing: .5px; margin-top: 4px; }

/* ── Close button ── */
.lightbox-close {
  position: fixed; top: 20px; right: 24px; z-index: 2100;
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.18);
  color: #fff; border-radius: 50%;
  width: 44px; height: 44px; font-size: 1.1rem;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  opacity: 0; pointer-events: none;
  transition: opacity .3s, background .2s, transform .2s;
}
.lightbox-close.open { opacity: 1; pointer-events: all; }
.lightbox-close:hover { background: var(--primary); transform: rotate(90deg); }

/* ── Bottom hint ── */
.lightbox-hint {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%);
  font-size: .75rem; color: rgba(255,255,255,.35);
  letter-spacing: 1px; white-space: nowrap;
  opacity: 0; pointer-events: none; transition: opacity .4s; z-index: 2100;
}
.lightbox-hint.open { opacity: 1; }

/* ── Copy ID button ────────────────────────────────────── */
.copy-id-btn {
  min-width: 120px;
  height: 40px;
  font-size: .9rem;
  background: linear-gradient(135deg, var(--surface2), #2a2a2a);
  border: 1px solid var(--border);
  color: var(--text);
  border-radius: 8px;
  cursor: pointer;
  transition: all .2s ease;
}
.copy-id-btn:hover { filter: brightness(1.2); transform: scale(1.03); border-color: var(--primary); box-shadow: 0 0 10px var(--border); }
.copy-id-btn.copied { background: rgba(74,222,128,.2); border-color: rgba(74,222,128,.5); color: #4ade80; }

/* ── Responsive ────────────────────────────────────────── */
@media (max-width:768px){
  .profile-header {
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-top: 0px;
  }

  .profile-left {
    flex-direction: column;
    align-items: center;
    text-align: center;
    min-width: 100%;
  }

  .profile-name-block {
    margin-bottom: 0px;
  }

  .emp-avatar {
    margin-top: -44px; /* Slightly adjusted push for tablet sizes */
  }

  .profile-right {
    align-items: center;
    min-width: 100%;
  }

  .profile-id-value {
    font-size: 1.6rem;
    text-align: center;
  }

  .verified-badge {
    justify-content: center;
  }

  .copy-id-btn {
    width: 160px;
  }

  .info-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 540px) {
  .card-body-inner { padding: 0 12px 18px; }
  .emp-avatar  { margin-top: -40px; width: 80px; height: 80px; }
  .emp-name    { font-size: 1.1rem; }
  .emp-role    { font-size: .8rem; }
  .info-grid   { gap: 8px; grid-template-columns: 1fr 1fr; }
  .info-label  { font-size: .62rem; }
  .info-value  { font-size: .82rem; }
  .verified-badge { font-size: .68rem; padding: 4px 10px; }
  .fb-back     { padding: 24px 16px; }
  .fb-name     { font-size: 1.1rem; }
  .flip-scene  { width: min(94vw, 94vh); height: min(94vw, 94vh); }
  .lightbox-close { top: 12px; right: 12px; width: 38px; height: 38px; font-size: 1rem; }
}

@media (max-width: 380px) {
  .info-grid { grid-template-columns: 1fr; }
  .search-group { border-radius: 10px; }
}