/* =========================================================
   VoiceChatLine UI System (Index + Profile)
   - Single cohesive CSS: cards, grids, flags, featured, countries, modal
   ========================================================= */

:root{
  --bg:#0b0d12;
  --card:#0f141d;
  --card2:#0c1118;
  --line:rgba(233,238,252,.10);
  --text:#e9eefc;
  --muted:rgba(233,238,252,.72);
  --muted2:rgba(233,238,252,.55);
  --shadow: 0 20px 60px rgba(0,0,0,.45);
  --accent: rgba(120,255,0,.85);
  --accent2: rgba(0,255,200,.24);
}

*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; background:var(--bg); color:var(--text); font-family: system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif; }
a{ color:inherit; }
img{ max-width:100%; }

.wrap{ width:min(1180px, calc(100vw - 28px)); margin:0 auto; }

.panel{
  background: rgba(255,255,255,0.02);
  border:1px solid var(--line);
  border-radius: 18px;
  padding: 14px;
  box-shadow: none;
}

.row{ display:flex; gap:12px; flex-wrap:wrap; }
.name{ font-weight: 900; letter-spacing: -.01em; }
.muted{ color: var(--muted); }
.muted2{ color: var(--muted2); }

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding: 10px 14px;
  border-radius: 12px;
  border:1px solid var(--line);
  background: rgba(255,255,255,0.03);
  color: var(--text);
  cursor:pointer;
  text-decoration:none;
  font-weight: 800;
}
.btn:hover{ background: rgba(255,255,255,0.06); }
.btn:disabled{ opacity:.55; cursor:not-allowed; }
.btn-sm{ padding: 8px 12px; border-radius: 11px; font-weight: 800; font-size: 13px; }

.input{
  border:1px solid var(--line);
  background: rgba(255,255,255,0.02);
  color: var(--text);
  padding: 10px 12px;
  border-radius: 12px;
  outline:none;
}
.input-sm{ padding: 8px 10px; border-radius: 11px; font-size: 13px; }

.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 7px 10px;
  border-radius: 999px;
  border:1px solid var(--line);
  background: rgba(255,255,255,0.02);
  font-size: 12px;
  color: var(--muted);
  white-space: nowrap;
}
.badge strong{ color: var(--text); }

/* =========================================================
   Topbar
   ========================================================= */
.topbar{
  position: sticky;
  top: 0;
  z-index: 30;
  background: rgba(11,13,18,.78);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(233,238,252,.08);
}
.topbar-inner{ display:flex; justify-content:space-between; align-items:center; gap: 14px; padding: 12px 0; }
.topbar-left{ display:flex; align-items:center; gap: 14px; flex-wrap:wrap; }
.brand{ font-weight: 950; letter-spacing: -.02em; text-decoration:none; }
.nav{ display:flex; gap: 8px; flex-wrap:wrap; }
.nav-link{
  text-decoration:none;
  padding: 8px 10px;
  border-radius: 12px;
  border:1px solid transparent;
  color: var(--muted);
  font-weight: 900;
  font-size: 13px;
}
.nav-link:hover{ background: rgba(255,255,255,0.03); color: var(--text); }
.nav-link.is-active{ background: rgba(255,255,255,0.05); border-color: rgba(233,238,252,.12); color: var(--text); }
.nav-sep{ width: 10px; height: 10px; border-left: 1px solid rgba(233,238,252,.12); display:inline-block; }

/* =========================================================
   Flags (FlagCDN) - SAFE everywhere
   ========================================================= */
.vcFlag{
  width: 18px;
  height: auto;
  aspect-ratio: 4 / 3;
  display: inline-block;
  vertical-align: middle;
  border-radius: 4px;
  box-shadow: 0 0 0 1px rgba(255,255,255,.08) inset;
  flex: 0 0 auto;
}
.badge .vcFlag{
  width: 16px;
  transform: translateY(-.5px);
}

/* Generic safe “flag + text” wrapper */
.vcCountryBadge{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  white-space: nowrap;
  min-width: 0;
}

/* =========================================================
   Index: Featured Models (horizontal)
   ========================================================= */
.vcFeatured{
  border:1px solid rgba(0,255,200,0.18);
  background:
    radial-gradient(1200px 500px at 30% 0%, rgba(0,255,200,0.06), transparent 60%),
    rgba(255,255,255,0.02);
  border-radius: 18px;
  padding: 14px;
}
.vcFeaturedHead{ display:flex; justify-content:space-between; gap:12px; align-items:flex-start; }
.vcFeaturedTitle{
  font-weight: 950;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: 15px;
}
.vcFeaturedSub{ margin-top: 6px; color: var(--muted); font-size: 13px; }

.vcFeaturedRow{
  margin-top: 12px;
  display:flex;
  gap: 18px;
  overflow-x:auto;
  padding-bottom: 6px;
  scroll-snap-type: x mandatory;
}
.vcFeaturedItem{
  flex: 0 0 auto;
  width: 124px;
  text-decoration:none;
  scroll-snap-align: start;
}
.vcFeaturedAvatar{
  width: 96px;
  height: 96px;
  border-radius: 999px;
  border: 3px solid rgba(120,255,0,.85);
  box-shadow: 0 0 0 2px rgba(0,0,0,.35);
  overflow:hidden;
  margin: 0 auto;
  background: rgba(255,255,255,0.03);
}
.vcFeaturedAvatar img{ width:100%; height:100%; object-fit:cover; display:block; }
.vcFeaturedName{
  margin-top: 10px;
  font-weight: 900;
  font-size: 13px;
  text-align:center;
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.vcFeaturedMeta{
  margin-top: 6px;
  text-align:center;
  color: var(--muted);
  font-size: 12px;
  display:flex;
  gap:6px;
  justify-content:center;
  align-items:center;
}

/* =========================================================
   Index: Filters bar (inline, autosubmit)
   ========================================================= */
.vcFiltersCard{
  margin-top: 12px;
}
.vcFiltersForm{
  display:grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
  align-items:end;
}
@media (max-width: 1100px){
  .vcFiltersForm{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 720px){
  .vcFiltersForm{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 520px){
  .vcFiltersForm{ grid-template-columns: 1fr; }
}
.vcField{ display:flex; flex-direction:column; gap:6px; min-width:0; }
.vcField label{ font-size: 12px; color: var(--muted); }
.vcSelect{
  appearance: none;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--line);
  color: inherit;
  border-radius: 12px;
  padding: 10px 12px;
  line-height: 1.2;
  outline: none;
}
.vcSelect:focus{ border-color: rgba(233,238,252,.18); }

/* =========================================================
   Index: Models grid
   ========================================================= */
.vcModelsGrid{
  margin-top: 12px;
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
@media (max-width:1100px){ .vcModelsGrid{ grid-template-columns: repeat(3,1fr);} }
@media (max-width:800px){ .vcModelsGrid{ grid-template-columns: repeat(2,1fr);} }
@media (max-width:520px){ .vcModelsGrid{ grid-template-columns: 1fr; } }

.vcCard{
  display:block;
  text-decoration:none;
  border:1px solid var(--line);
  border-radius: 18px;
  overflow:hidden;
  background: rgba(255,255,255,0.02);
  min-width:0;
}
.vcCard:hover{ border-color: rgba(233,238,252,.20); transform: translateY(-1px); transition: transform .12s ease, border-color .15s ease; }

.vcCardMedia{
  width:100%;
  height: 170px;
  background: rgba(255,255,255,0.03);
  border-bottom: 1px solid rgba(233,238,252,.08);
}
.vcCardMedia img{ width:100%; height:100%; object-fit:cover; display:block; }

.vcCardBody{ padding: 12px; min-width:0; }
.vcCardTitleRow{ display:flex; align-items:center; justify-content:space-between; gap:10px; min-width:0; }
.vcCardTitle{
  font-weight: 950;
  font-size: 15px;
  min-width:0;
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.vcCardBadges{ margin-top: 10px; display:flex; gap:8px; flex-wrap:wrap; }
.vcCardDesc{ margin-top: 10px; color: var(--muted); font-size: 13px; }

/* =========================================================
   Top Countries (grid pills)
   ========================================================= */
.vcCountries{ margin-top: 14px; }
.vcCountriesHead{ display:flex; justify-content:space-between; align-items:center; gap: 12px; flex-wrap:wrap; }
.vcCountriesTitle{ font-weight: 950; font-size: 28px; letter-spacing: -.02em; }
.vcCountriesTools{ display:flex; gap:10px; flex-wrap:wrap; align-items:center; }

.vcCountriesGrid{
  margin-top: 12px;
  display:grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
}
@media (max-width:1200px){ .vcCountriesGrid{ grid-template-columns: repeat(4,1fr);} }
@media (max-width:900px){ .vcCountriesGrid{ grid-template-columns: repeat(2,1fr);} }
@media (max-width:520px){ .vcCountriesGrid{ grid-template-columns: 1fr; } }

.vcCountryPill{
  border:1px solid var(--line);
  background: rgba(255,255,255,0.02);
  border-radius: 999px;
  padding: 10px 12px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap: 10px;
  min-width:0;
}
.vcCountryLeft{ display:flex; align-items:center; gap: 10px; min-width:0; }
.vcCountryName{
  font-weight: 900;
  font-size: 13px;
  min-width:0;
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.vcCountryCount{
  color: var(--muted);
  font-size: 13px;
  font-variant-numeric: tabular-nums;
  flex: 0 0 auto;
}

/* =========================================================
   Profile layout (player left, sidebar right)
   ========================================================= */
.vcProfileLayout{
  margin-top: 12px;
  display:grid;
  grid-template-columns: 1.7fr 1fr;
  gap: 14px;
}
@media (max-width: 980px){
  .vcProfileLayout{ grid-template-columns: 1fr; }
}

.vcPlayerCard .video{
  width:100%;
  height:auto;
  display:block;
  max-height: 620px;
  background:#000;
  border-radius: 16px;
}
.vcPlayerWrap{
  margin-top: 10px;
  border-radius: 18px;
  overflow:hidden;
  border:1px solid var(--line);
  background:#000;
}

.vcPlayerControls{
  margin-top: 10px;
  display:flex;
  gap: 10px;
  flex-wrap:wrap;
  align-items:center;
}
.vcKbd{
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono","Courier New", monospace;
  font-size: 12px;
  border:1px solid var(--line);
  background: rgba(255,255,255,0.02);
  padding: 2px 7px;
  border-radius: 8px;
  color: var(--muted);
}

.vcSideStack{ display:grid; gap: 14px; }

.vcProfileHero{
  display:grid;
  grid-template-columns: 1fr 180px;
  gap: 12px;
  align-items:start;
}
@media (max-width: 520px){
  .vcProfileHero{ grid-template-columns: 1fr; }
}

.vcAvatar{
  width:100%;
  height: 180px;
  border-radius: 18px;
  border:1px solid var(--line);
  background: rgba(255,255,255,0.03);
  object-fit: cover;
  display:block;
}

.vcMediaStack{
  margin-top: 14px;
  display:grid;
  gap: 14px;
}

.vcSectionHead{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap: 12px;
}
.vcSectionHead .name{ font-size: 20px; }
.vcSectionHead .muted{ margin-top: 6px; }

.vcGrid{
  margin-top: 12px;
  display:grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 10px;
}
@media (max-width:1200px){ .vcGrid{ grid-template-columns: repeat(4,1fr);} }
@media (max-width:700px){ .vcGrid{ grid-template-columns: repeat(2,1fr);} }

.vcTile{
  border:1px solid var(--line);
  border-radius: 14px;
  overflow:hidden;
  background: rgba(255,255,255,0.02);
  cursor:pointer;
  padding:0;
  text-align:left;
  min-width:0;
}
.vcTile img, .vcTile video{
  width:100%;
  height: 130px;
  object-fit:cover;
  display:block;
}
.vcTileMeta{
  padding: 8px 10px;
  font-size: 12px;
  color: var(--muted);
  border-top: 1px solid rgba(233,238,252,.08);
}

.vcRecGrid{
  margin-top: 12px;
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
@media (max-width:700px){ .vcRecGrid{ grid-template-columns: 1fr; } }

.vcRecCard{
  border:1px solid var(--line);
  border-radius: 18px;
  background: rgba(255,255,255,0.02);
  padding: 12px;
  display:flex;
  gap: 12px;
  align-items:center;
  min-width:0;
}
.vcRecThumb{
  width: 160px;
  height: 96px;
  border-radius: 14px;
  border:1px solid var(--line);
  background:#000;
  object-fit: cover;
  flex: 0 0 auto;
}
.vcRecMeta{ flex:1; min-width:0; }
.vcRecTitle{ font-weight: 950; font-size: 14px; }
.vcRecSub{ margin-top: 6px; font-size: 12px; color: var(--muted); }

/* Similar models grid */
.vcSimilarGrid{
  margin-top: 12px;
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
@media (max-width:1100px){ .vcSimilarGrid{ grid-template-columns: repeat(3,1fr);} }
@media (max-width:700px){ .vcSimilarGrid{ grid-template-columns: repeat(2,1fr);} }
@media (max-width:520px){ .vcSimilarGrid{ grid-template-columns: 1fr; } }

.vcModelCard{
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.02);
  border-radius: 14px;
  overflow:hidden;
  text-decoration:none;
  display:block;
}
.vcModelCard img{
  width:100%;
  height: 120px;
  object-fit:cover;
  display:block;
  border-bottom: 1px solid rgba(233,238,252,.08);
}
.vcModelCardBody{ padding: 10px; }
.vcModelCardName{ font-weight: 950; font-size: 14px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.vcModelCardMeta{ margin-top: 8px; display:flex; gap:8px; flex-wrap:wrap; }

/* =========================================================
   Modal (with next/prev)
   ========================================================= */
.vcModal{ position: fixed; inset: 0; z-index: 9999; display:none; }
.vcModal.is-open{ display:block; }

.vcModalBackdrop{ position:absolute; inset:0; background: rgba(0,0,0,.62); backdrop-filter: blur(6px); }

.vcModalPanel{
  position:absolute;
  left:50%;
  top:50%;
  transform: translate(-50%,-50%);
  width: min(980px, calc(100vw - 28px));
  max-height: min(86vh, 860px);
  overflow:auto;
  background: var(--card);
  border:1px solid var(--line);
  border-radius: 18px;
  box-shadow: var(--shadow);
}

.vcModalHead{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  padding: 12px 14px;
  border-bottom: 1px solid rgba(233,238,252,.10);
}
.vcModalTitle{ font-weight: 950; font-size: 15px; }
.vcModalBody{ padding: 14px; }
.vcModalImg{ width:100%; border-radius: 18px; border:1px solid rgba(233,238,252,.10); display:block; }
.vcModalActions{ display:flex; gap: 10px; flex-wrap:wrap; margin-top: 12px; }

/* Footer */
.footer{ margin-top: 22px; padding: 18px 0; border-top: 1px solid rgba(233,238,252,.08); color: var(--muted); }
.footer-inner{ display:flex; justify-content:space-between; align-items:center; gap:12px; flex-wrap:wrap; }
.footer-link{ color: var(--muted); text-decoration:none; font-weight: 800; }
.footer-link:hover{ color: var(--text); }
