/*
Theme Name: GlamzModel Magic (No Elementor)
Theme URI: https://glamzmodel.com
Author: Hamza + ChatGPT
Description: Lightweight custom theme for GlamzModel (CPT Models, 4-col grids, hover stats overlay, single model Swiper gallery, favorites).
Version: 1.0.0
Text Domain: glamzmodel
*/

/* =========================
   LIGHT THEME VARIABLES
========================= */
/* ===============================
   Cassanat Font
=============================== */
@font-face {
  font-family: "Cassanat";
  src: url("assets/fonts/cassanat-regular.woff2") format("woff2"),
       url("assets/fonts/cassanat-regular.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}



:root{
  --bg:#ffffff;
  --fg:#000000;
  --muted: rgba(0,0,0,.62);
  --line: rgba(0,0,0,.12);
  --overlay: rgba(255,255,255,.62);
  --accent:#111111;
  --max: 1280px;

  /* card/footer sizing */
  --card-radius: 14px;
  --card-footer-h: 52px; /* IMPORTANT: hover stops above footer so name stays visible */
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--fg);
  font-family: "Cassanat", Arial, sans-serif;
  
  letter-spacing:.2px;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.container{max-width:var(--max);margin:0 auto;padding:0 18px}

/* =========================
   HEADER / NAV (LIGHT)
========================= */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,.82);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:14px 0;
  position:relative;
}
.brand{display:flex;align-items:center;gap:10px}
.brand img{height:44px;width:auto}

.nav-wrap{border-top:1px solid var(--line)}
.nav-menu{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  gap:18px;
  justify-content:center;
  align-items:center;
  flex-wrap:wrap
}
.nav-menu>li{position:relative}
.nav-menu>li>a{
  display:block;
  padding:12px 8px;
  font-weight:700;
  text-transform:uppercase;
  font-size:13px;
  color:var(--fg);
  opacity:.9;
}
.nav-menu>li>a:hover{opacity:1}

.nav-menu li ul{
  display:none;
  position:absolute;
  left:0;
  top:100%;
  background:#ffffff;
  border:1px solid var(--line);
  min-width:180px;
  padding:8px 0;
  list-style:none;
  margin:0;
  box-shadow:0 10px 30px rgba(0,0,0,.08);
}
.nav-menu li:hover>ul{display:block}
.nav-menu li ul a{
  display:block;
  padding:9px 12px;
  font-size:13px;
  opacity:.9;
}
.nav-menu li ul a:hover{
  opacity:1;
  background:rgba(0,0,0,.04)
}

/* =========================
   HERO
========================= */
.hero-video{position:relative;height:100vh;min-height:520px;overflow:hidden}
.hero-video video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-overlay{
  position:absolute;
  inset:0;
  
}
.hero-center{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:18px;
  text-align:center;
  padding:0 16px
}
.hero-center h1{
  margin:0;
  font-size:38px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--fg);
}
.hero-center p{margin:0;opacity:.85;max-width:760px;color:var(--fg)}

/* =========================
   PAGE TITLE / GRID
========================= */
.page-title{padding:22px 0 6px;text-align:center}
.page-title h1{
  margin:0;
  font-size:26px;
  text-transform:uppercase;
  letter-spacing:1.4px;
  color:var(--fg);
}
.grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  padding:22px 0 44px
}
@media (max-width: 1100px){.grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width: 820px){.grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width: 520px){.grid{grid-template-columns:1fr}}

/* =========================
   MODEL CARD (FIX NAME VISIBILITY)
========================= */
.card{
  position:relative;
  border:1px solid var(--line);
  overflow:hidden;
  border-radius:var(--card-radius);
  background:#ffffff;
  box-shadow:0 8px 24px rgba(0,0,0,.06);
}

/* image area */
.card .thumb{
  aspect-ratio: 3/4;
  overflow:hidden;
  display:block;
}
.card .thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  transform:scale(1.02);
  transition:transform .25s ease;
}
.card:hover .thumb img{transform:scale(1.06)}

/*
  IMPORTANT FIX:
  hover overlay MUST NOT cover the footer area, otherwise the model name disappears.
  So we stop overlay above the footer height.
*/
.card .hover{
  position:absolute;
  left:0;
  right:0;
  top:0;
  bottom: var(--card-footer-h);  /* <-- KEY FIX */
  background: var(--overlay);
  display:flex;
  align-items:flex-end;
  opacity:0;
  transition:opacity .18s ease;
  z-index:2;
}
.card:hover .hover{opacity:1}

/* stats area on hover */
.hover .stats{
  width:100%;
  padding:14px 14px 14px;
}
.stats-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:8px;
  text-align: center;
}
.stat{
  display:flex;
  justify-content:space-between;
  gap:10px;
  font-size:12px;
  border-bottom:1px dashed rgba(0,0,0,.16);
  padding-bottom:6px;
}
.stat span:first-child{
  opacity:.75;
  text-transform:uppercase;
  font-weight:700;
  letter-spacing:.6px;
  color:var(--fg);
}
.stat span:last-child{
  opacity:1;
  font-weight:800;
  color:var(--fg);
}

/* footer ALWAYS visible */
.card-footer{
  position:relative;
  z-index:3; /* above everything */
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 12px;
  height: var(--card-footer-h);
  background:#ffffff;
  border-top:1px solid var(--line);
}

/* model name */
.card-title{
  display:block;
  font-weight:800;
  letter-spacing:.7px;
  text-transform:uppercase;
  font-size:13px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width: calc(100% - 44px);
  color: var(--fg);
}

/* favorite button */
.fav-btn{
  border:1px solid var(--line);
  background:rgba(0,0,0,.02);
  color:var(--fg);
  cursor:pointer;
  padding:8px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  opacity:.92;
}
.fav-btn:hover{background:rgba(0,0,0,.05);opacity:1}
.fav-btn svg{width:20px;height:20px}
.fav-btn.is-fav svg{fill:var(--fg)}

/* =========================
   SINGLE MODEL
========================= */
.single-wrap{padding:26px 0 50px}
.model-top{max-width:980px;margin:0 auto;text-align:center}
.model-top h1{
  margin:0 0 10px;
  font-size:32px;
  text-transform:uppercase;
  letter-spacing:2px;
  color:var(--fg);
}
.model-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:center;
  align-items:center;
  margin:12px 0 10px
}
.btn{
  border:1px solid var(--line);
  background:rgba(0,0,0,.03);
  color:var(--fg);
  padding:10px 12px;
  border-radius:999px;
  font-weight:800;
  font-size:12px;
  letter-spacing:.7px;
  text-transform:uppercase;
  cursor:pointer
}
.btn:hover{background:rgba(0,0,0,.06)}

.model-stats{
  max-width:980px;
  margin:0 auto;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:14px 0
}
.model-stats .stats-grid{grid-template-columns:repeat(3,1fr)}
@media (max-width: 820px){.model-stats .stats-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width: 520px){.model-stats .stats-grid{grid-template-columns:1fr}}
.model-stats .stat{border-bottom:1px dashed rgba(0,0,0,.14)}

/* =========================
   GALLERY / SWIPER
========================= */
.gallery{max-width:1180px;margin:18px auto 0}
.swiper{width:100%;padding:14px 0}
.swiper-slide{width:auto}
.slide-img{
  height:680px;
  max-height:76vh;
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--line);
  background:#fff;
}
.slide-img img{height:100%;width:auto;max-width:100%;object-fit:cover}
@media (max-width: 820px){.slide-img{height:520px}}
@media (max-width: 520px){.slide-img{height:460px}}

.swiper-button-prev,.swiper-button-next{color: #ffffff;}
.swiper-pagination-bullet{background:var(--fg);opacity:.25}
.swiper-pagination-bullet-active{opacity:.75}

/* =========================
   FOOTER
========================= */
.site-footer{
  border-top:1px solid var(--line);
  padding:22px 0;
  text-align:center;
  color:var(--muted);
  font-size:13px
}
/* ======================
   HOVER STATS – NEW LAYOUT
====================== */

.stats-grid{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.stat{
  display:block;
  font-size:13px;
  font-weight:700;
  letter-spacing:.4px;
  border-bottom:1px dashed rgba(0,0,0,.15);
  padding-bottom:6px;
  color:#111;
}

.stat-label{
  text-transform:capitalize;
}

.stat-label::after{
  content:": ";
  font-weight:700;
}

.stat-value{
  font-weight:700;
}

