/*
Theme Name: TMA Agency — Dark (Complete)
Theme URI: https://tma.co.ke
Author: Thera Modeling Agency (TMA) 
Description: Dark, premium modeling agency theme.
Version: 1.1
Text Domain: tma-agency
*/

/* ==================== ROOT ==================== */
:root{
--brand-blue:#00aeef;
--brand-gold:#d4af37;
--bg:#050709;
--card:#0c1117;
--text:#eaf2f9;
--muted:#8e9aa6;
}
body{
font-family:"Inter","Poppins","Segoe UI",sans-serif;
letter-spacing:.3px;
background:#02070b;
color:var(--text);
}

h1,h2,h3,h4{
font-family:'Poppins','Segoe UI',sans-serif;
font-weight:600;
letter-spacing:.5px;
}

p{
line-height:1.75;
color:var(--muted);
font-size:16px;
}

/* ==================== RESET ==================== */
*{box-sizing:border-box}
html,body{margin:0;background:linear-gradient(180deg,#050607,#0b0f12);color:var(--text);font-family:Inter,system-ui,Arial}

/* ==================== CONTAINER ==================== */
.container{max-width:1200px;margin:auto;padding:26px}

/* ==================== PRO HEADER ==================== */
.site-header{
    position:sticky;
    top:0;
    z-index:9999;
    background:rgba(2,7,11,.92);
    backdrop-filter:blur(12px);
    border-bottom:1px solid rgba(255,255,255,.05);
    transition:.3s ease;
}

/* HEADER LAYOUT */
.header-wrap{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:20px;
    min-height:78px;
}

/* BRAND */
.site-brand{
    display:flex;
    align-items:center;
    gap:12px;
    text-decoration:none;
}

.logo{
    background:linear-gradient(135deg,#00aeef,#3fd5ff);
    color:#001;
    font-weight:900;
    padding:12px 16px;
    border-radius:10px;
    letter-spacing:1px;
    font-size:15px;
    box-shadow:0 5px 18px rgba(0,174,239,.4);
    transition:.3s;
}

.logo:hover{
    transform:translateY(-2px) scale(1.05);
    box-shadow:0 10px 28px rgba(0,174,239,.6);
}

.brand-text{
    display:flex;
    flex-direction:column;
}

.brand-text strong{
    color:white;
    font-size:17px;
    font-weight:700;
    letter-spacing:.6px;
}

.tagline{
    font-size:12px;
    font-weight:500;
    color:rgba(255,255,255,.6);
    letter-spacing:.8px;
}

/* NAV BAR */
.site-nav{
    position:relative;
}

.nav{
    display:flex;
    gap:28px;
    list-style:none;
    margin:0;
    padding:0;
}

/* NAV LINKS */
.nav a{
    color:#fff;
    text-decoration:none;
    font-weight:600;
    letter-spacing:.3px;
    position:relative;
    padding:8px 6px;
    transition:.3s;
}

/* Animated underline */
.nav a::after{
    content:"";
    position:absolute;
    left:0;
    bottom:-4px;
    width:0;
    height:2px;
    background:linear-gradient(90deg,#00aeef,#64d8ff);
    transition:.3s;
}

.nav a:hover{
    color:#64d8ff;
}

.nav a:hover::after{
    width:100%;
}

/* ACTIVE LINK */
.nav .current-menu-item a{
    color:#00aeef;
}

.nav .current-menu-item a::after{
    width:100%;
}

/* HAMBURGER */
.menu-toggle{
    display:none;
    background:none;
    border:0;
    color:white;
    font-size:28px;
    cursor:pointer;
    transition:.3s;
}

.menu-toggle:hover{
    color:#64d8ff;
}

/* MOBILE MENU */
@media(max-width:860px){

    .menu-toggle{
        display:block;
    }

    .site-nav{
        position:absolute;
        top:100%;
        right:0;
        width:260px;
        background:linear-gradient(180deg,#04090d,#000);
        border-left:1px solid rgba(255,255,255,.08);
        transform:translateX(100%);
        transition:.3s;
        padding:22px;
    }

    .site-nav.active{
        transform:translateX(0);
    }

    .nav{
        flex-direction:column;
        gap:18px;
    }

    .nav a{
        padding:12px;
        border-radius:10px;
        background:rgba(255,255,255,.02);
    }

    .nav a:hover{
        background:rgba(0,174,239,.1);
    }

}

/* ==================== HERO ==================== */

.hero{
position:relative;
min-height:92vh;
display:flex;
align-items:center;
justify-content:center;
border-radius:var(--radius);
overflow:hidden;
}

.hero-image{
position:absolute;
inset:0;
z-index:1;
}

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

.hero-image::after{
content:"";
position:absolute;
inset:0;
background:
linear-gradient(to bottom,rgba(0,0,0,.85),rgba(0,0,0,.5));
z-index:2;
}

.hero-content{
position:relative;
z-index:3;
max-width:820px;
text-align:center;
padding:40px;
backdrop-filter:blur(3px);
animation:fadeUp 1s ease;
}

.hero-content h1{
font-size:52px;
line-height:1.15;
margin-bottom:18px;
color:white;
}

.hero-content h1 span{
color:var(--brand);
}

.hero-content p{
max-width:600px;
margin:0 auto 26px;
}

.hero .btn{
margin:10px;
}

/* ===================================================
   ABOUT SECTION
=================================================== */

.about{
display:grid;
grid-template-columns:1fr 1fr;
gap:50px;
align-items:center;
padding:90px 0;
}

.about-text{
animation:fadeUp .9s ease;
}

.about-text h2{
font-size:38px;
margin-bottom:16px;
}

.about-text p{
color:#b8c7d4;
line-height:1.65;
font-size:16px;
margin-bottom:22px;
}

.about-text ul{
margin:0;
padding:0;
list-style:none;
}

.about-text li{
padding-left:22px;
margin-bottom:12px;
position:relative;
color:#cfe8f6;
}

.about-text li::before{
content:"✦";
position:absolute;
left:0;
color:gold;
}

/* ABOUT IMAGE */
.about-image{
position:relative;
border-radius:22px;
overflow:hidden;
box-shadow:0 35px 70px rgba(0,0,0,.5);
}

.about-image img{
width:100%;
display:block;
transition:.5s;
border-radius:22px;
}

.about-image:hover img{
transform:scale(1.05);
}

.about-image::before{
content:"";
position:absolute;
top:-30px;
right:-30px;
width:140px;
height:140px;
background:radial-gradient(circle,var(--brand),transparent);
opacity:.3;
border-radius:50%;
}


/* ===================================================
   WHY CHOOSE US
=================================================== */

.why-grid{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
gap:28px;
margin-top:45px;
}

.why-item{
background:#0a1016;
border-radius:18px;
padding:28px;
border:1px solid rgba(255,255,255,.05);
transition:.3s;
position:relative;
}

.why-item:hover{
transform:translateY(-8px) scale(1.02);
box-shadow:0 0 25px rgba(0,174,239,.2);
}

.why-item h4{
margin-bottom:8px;
color:white;
font-size:17px;
}

.why-item p{
font-size:14px;
color:#9bb0c2;
}


/* ===================================================
   CTA BANNER
=================================================== */

.cta-banner{
margin:90px 0;
border-radius:26px;
background:linear-gradient(135deg, #002b3b, #000);
padding:50px 40px;
display:flex;
justify-content:space-between;
align-items:center;
gap:30px;
border:1px solid rgba(0,174,239,.15);
box-shadow:0 30px 70px rgba(0,0,0,.6);
}

.cta-banner h2{
margin:0;
font-size:30px;
color:white;
}

.cta-banner p{
margin-top:6px;
color:#bcd6e7;
}

.cta-banner .btn{
font-size:15px;
padding:14px 26px;
}


/* ===================================================
   ANIMATIONS
=================================================== */

@keyframes fadeUp{
from{
opacity:0;
transform:translateY(30px);
}
to{
opacity:1;
transform:none;
}
}


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

@media(max-width:900px){

.hero,
.about{
grid-template-columns:1fr;
padding:60px 0;
}

.hero-content h1{
font-size:34px;
}

.about-text h2{
font-size:28px;
}

.cta-banner{
flex-direction:column;
text-align:center;
}

}


/* =================== CARDS =================== */
.card{
background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));
border-radius:18px;
padding:22px;
border:1px solid rgba(255,255,255,.08);
box-shadow:0 14px 30px rgba(0,0,0,.5)
}

/* =================== BUTTON =================== */
.btn,
.book-btn,
.whatsapp-btn,
.hero-cta,
.download-btn gold,
.download-btn{
display:inline-flex;
align-items:center;
justify-content:center;
gap:8px;
padding:12px 22px;
border-radius:40px;
font-weight:700;
text-decoration:none;
border:none;
cursor:pointer;
transition:.25s;
font-size:15px
}
.btn,.book-btn,.hero-cta{background:linear-gradient(135deg,#00aeef,#6ddcff);color:#001}
.whatsapp-btn{background:var(--gold);color:black}
.download-btn{background:#111;border:1px solid #00aeef;color:var(--brand)}
.download-btn gold{background:var(--gold);color:#111;border:0}
.btn:hover,
.book-btn:hover,
.hero-cta:hover,
.whatsapp-link:hover,
.whatsapp-btn:hover,
.download-btn gold,
.download-btn:hover{transform:translateY(-2px);filter:brightness(1.1)}
.whatsapp-link {
  margin-top:14px;
  display:block;
  text-align:center;
  background:#25D366;
  color:black !important;
  padding:12px;
  border-radius:12px;
  font-weight:800;
}

/* ===========================
   FEATURED MODELS — PRO UPGRADE
=========================== */

.featured-carousel{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:26px;
  padding:32px 0;
  align-items:stretch;
}

/* Card */
.carousel-item{
  position:relative;
  background:#05080b;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 14px 40px rgba(0,0,0,.5);
  transition:transform .35s ease, box-shadow .35s ease;
}

/* ADD GLOW BORDER EFFECT */
.carousel-item::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(120deg,transparent,rgba(0,174,239,.15),transparent);
  opacity:0;
  transition:.4s ease;
  z-index:1;
  pointer-events:none;
}

.carousel-item:hover::before{
  opacity:1;
}

/* Lift Hover */
.carousel-item:hover{
  transform:translateY(-10px) scale(1.01);
  box-shadow:0 26px 60px rgba(0,0,0,.7);
}

/* IMAGE */
.carousel-item img{
  width:100%;
  height:340px;
  object-fit:cover;
  object-position:top center;
  filter:contrast(1.05) saturate(1.05);
  transition:transform .6s ease;
}

.carousel-item:hover img{
  transform:scale(1.05);
}


/* OVERLAY INFO BAR */
.carousel-item .model-meta{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  padding:18px 14px 14px;
  background:linear-gradient(to top,rgba(0,0,0,.9),rgba(0,0,0,.2),transparent);
  z-index:2;
  text-align:center;
}

/* MODEL NAME */
.carousel-item h4{
  margin:0;
  font-size:16px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:1.1px;
  color:#fff;
}

/* LOCATION */
.carousel-item .location{
  display:block;
  margin-top:4px;
  font-size:11px;
  letter-spacing:.4px;
  opacity:.7;
  color:#e8f8ff;
}

/* STATUS BADGE */
.carousel-item .status{
  display:inline-block;
  margin-top:8px;
  font-size:10px;
  padding:4px 12px;
  border-radius:50px;
  letter-spacing:.6px;
  font-weight:700;
  text-transform:uppercase;
}

/* STATUS COLORS */
.status.available{
  background:linear-gradient(120deg,#16a34a,#22c55e);
}
.status.hold{
  background:linear-gradient(120deg,#f59e0b,#fbbf24);
}
.status.unavailable{
  background:linear-gradient(120deg,#dc2626,#ef4444);
}


/* CLICK EFFECT */
.carousel-item a{
  display:block;
  height:100%;
  color:inherit;
  text-decoration:none;
}

/* Focus Outline for accessibility */
.carousel-item a:focus{
  outline:2px solid #00aeef;
  outline-offset:-4px;
}


/* EMPTY IMAGE FALLBACK */
.carousel-item img[src=""]{
  background:#111;
}


/* MOBILE TUNING */
@media(max-width:820px){
  .carousel-item img{
    height:260px;
  }
}

@media(max-width:520px){
  .featured-carousel{
    gap:18px;
  }

  .carousel-item img{
    height:220px;
  }

  .carousel-item h4{
    font-size:14px;
  }
}


/* ==================== MODELS GRID ==================== */
.model-grid{
display:grid;
grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
gap:22px
}

.model-item{
background:#080d12;
border-radius:14px;
overflow:hidden;
transition:.35s;
box-shadow:0 10px 24px rgba(0,0,0,.4)
}

.model-item:hover{transform:translateY(-6px)}

.model-item img{
width:100%;
height:320px;
object-fit:cover
}

.model-item .meta{
padding:14px;
text-align:center
}

/* FIX NAME LOOK — NOT A LINK */
.model-item h3{
margin:10px 0 4px;
font-size:17px;
font-weight:800;
text-transform:uppercase;
letter-spacing:.8px;
color:#fff;
text-decoration:none
}
/* REMOVE LINK UNDERLINE FROM MODEL NAMES */
.model-item a {
    text-decoration: none;
    color: inherit;
}

/* ENSURE NAME STAYS CLEAN */
.model-item h3 {
    text-decoration: none !important;
    color: #fff;
}
/* REMOVE UNDERLINE FROM MODEL ARCHIVE CARDS */
.model-grid a.model-item {
    text-decoration: none;
    color: inherit;
    display: block;
}

/* ENSURE NAME NEVER UNDERLINES */
.model-item h3{
    text-decoration: none !important;
}

/* PREMIUM HOVER FEEL */
.model-item:hover h3 {
    color:#00aeef;
    transition:.25s ease;
}

/* ================= GENDER FILTER ================= */
.model-filters{
display:flex;
gap:16px;
justify-content:center;
margin-bottom:30px
}
.model-filters a{
padding:10px 18px;
border-radius:24px;
background:#081018;
color:white;
text-decoration:none;
border:1px solid rgba(255,255,255,.1);
font-weight:600
}
.model-filters a:hover,
.model-filters .active{background:var(--brand);color:#00aeef}

/* HOVER EFFECT */
.model-filters a:hover{
background:var(--brand);
color:#00aeef;
transform:translateY(-2px) scale(1.05);
box-shadow:0 0 15px rgba(0,174,239,.6)
}

/* ================= PAGINATION ================= */
.pagination{
display:flex;
gap:14px;
justify-content:center;
margin:50px 0 20px;
flex-wrap:wrap
}

.pagination a,
.pagination span{
padding:10px 18px;
border-radius:999px;
background:#0a1016;
color:#dce7f3;
font-weight:600;
font-size:14px;
letter-spacing:.4px;
text-decoration:none;
border:1px solid rgba(255,255,255,.08);
transition:.3s;
box-shadow:0 4px 10px rgba(0,0,0,.4);
cursor:pointer
}

/* HOVER EFFECT */
.pagination a:hover{
background:var(--brand);
color:#00aeef;
transform:translateY(-2px) scale(1.05);
box-shadow:0 0 15px rgba(0,174,239,.6)
}

/* CURRENT PAGE */
.pagination .current{
background:linear-gradient(135deg,var(--brand),#64d8ff);
color:#00aeef;
font-weight:800;
box-shadow:0 0 16px rgba(0,174,239,.7);
border:none;
pointer-events:none
}

/* DISABLED STATE */
.pagination .dots,
.pagination .disabled{
opacity:.4;
pointer-events:none
}

/* ==================== PROFILE LAYOUT ==================== */
.profile-layout{display:grid;grid-template-columns:1fr 1.3fr;gap:50px}
@media(max-width:900px){.profile-layout{grid-template-columns:1fr}}

/* gallery main */
.gallery img{width:100%;border-radius:18px}
.gallery>img:first-child{object-fit:contain;max-height:680px}

/* ===================== PORTFOLIO GRID – PRO ===================== */

.portfolio-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(160px,1fr));
  gap:16px;
  margin-top:22px;
}

/* Individual Image Card */
.portfolio-grid img{
  width:100%;
  height:220px;
  object-fit:cover;
  border-radius:14px;
  cursor:pointer;
  transition:.35s ease;
  box-shadow:0 10px 22px rgba(0,0,0,.45);
  background:#000;
}

/* Hover Effect */
.portfolio-grid img:hover{
  transform:translateY(-6px) scale(1.05);
  box-shadow:
    0 18px 45px rgba(0,0,0,.8),
    0 0 20px rgba(0,174,239,.35);
}

/* Soft glass layer via pseudo */
.portfolio-grid img::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.75),transparent);
  opacity:0;
}

/* Mobile Optimization */
@media(max-width:768px){
  .portfolio-grid{
    grid-template-columns:repeat(auto-fill,minmax(130px,1fr));
    gap:12px;
  }

  .portfolio-grid img{
    height:180px;
  }
}

/* POLAROIDS */
.polaroids-grid{
display:grid;
grid-template-columns:repeat(auto-fill,minmax(120px,1fr));
gap:12px
}
.polaroids-grid img{
height:200px;
border-radius:10px;
object-fit:cover;
transition:.3s
}
.polaroids-grid img:hover{transform:scale(1.05)}

/* LIGHTBOX PRO UI */
#lightbox{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.94);
  display:none;
  justify-content:center;
  align-items:center;
  z-index:9999;
}

/* IMAGE */
#lightbox img{
  max-width:90%;
  max-height:88%;
  border-radius:18px;
  box-shadow:0 25px 80px rgba(0,0,0,.7);
}

/* ARROWS */
#lightbox .nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  font-size:38px;
  cursor:pointer;
  color:white;
  padding:12px 18px;
  background:rgba(0,0,0,.45);
  border-radius:50%;
  user-select:none;
  transition:.2s;
}

#lightbox .next{right:20px;}
#lightbox .prev{left:20px;}

#lightbox .nav:hover{
  background:var(--brand-blue);
  color:black;
}

/* CLOSE */
#lightbox .close{
  position:absolute;
  top:20px;
  right:26px;
  font-size:32px;
  cursor:pointer;
  color:white;
  transition:.2s;
}

#lightbox .close:hover{
  color:var(--brand-blue);
}

/* COUNTER */
#lightbox .counter{
  position:absolute;
  bottom:28px;
  color:#ccc;
  font-size:15px;
  font-weight:700;
}

/* MOBILE */
@media(max-width:768px){
  #lightbox .nav{font-size:30px}
  #lightbox img{max-width:94%}
}
/* ======================
   FASHION SHOW GALLERY
====================== */

.fashion-show-section{margin:40px 0}
.fashion-grid{
display:grid;
grid-template-columns:repeat(auto-fill,minmax(160px,1fr));
gap:14px
}
.fashion-grid img{
height:220px;
width:100%;
object-fit:cover;
border-radius:12px;
transition:.35s;
}
.fashion-grid img:hover{transform:scale(1.05)}

/* ===================== META ===================== */
.profile-details h1{font-size:2.3rem}
.profile-meta{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
gap:14px;
margin:24px 0
}
.profile-meta .kv{
background:#02070b;
padding:14px;
border-left:4px solid #00aeef;
border-radius:12px;
display:flex;
justify-content:space-between
}
.kv span{font-size:12px;color:#98a5af}
.kv strong{color:white}

/* measurements label */
.kv.measurements span{letter-spacing:2px;text-transform:uppercase}
/* REMOVE UNDERLINE FROM SOCIAL LINKS */
.profile-meta a {
    text-decoration: none;
    color: white;
    font-weight: 700;
}

/* PREMIUM HOVER */
.profile-meta a:hover {
    color: #00aeef;
}

/* ===================== STICKY PANEL ===================== */
.sticky-panel{
background:#050b10;
border:1px solid rgba(0,174,239,.25);
border-radius:18px;
padding:20px;
margin-top:20px
}
.stats{list-style:none;padding:0}
.stats li{padding:6px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.book-btn,.whatsapp-btn{
display:block;
padding:14px;
text-align:center;
border-radius:40px;
font-weight:bold;
text-decoration:none
}
.book-btn{background:#00aeef;color:black}
.whatsapp-btn{background:gold;color:black}
/* =====================
   MODEL STATUS BADGES
===================== */

.model-badges{
  margin:10px 0 16px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.badge{
  padding:6px 14px;
  font-size:12px;
  border-radius:20px;
  font-weight:700;
  letter-spacing:.4px;
  display:inline-flex;
  align-items:center;
  gap:6px;
}

.badge-available{
  background:rgba(0,200,120,.15);
  border:1px solid rgba(0,200,120,.5);
  color:#6affc9;
}

.badge-hold{
  background:rgba(255,170,0,.14);
  border:1px solid rgba(255,170,0,.5);
  color:#ffd480;
}

.badge-unavailable{
  background:rgba(200,50,50,.2);
  border:1px solid rgba(200,50,50,.6);
  color:#ffb3b3;
}

.badge-location{
  background:rgba(0,174,239,.15);
  border:1px solid rgba(0,174,239,.5);
  color:#8ee4ff;
}

/* ================= DOWNLOADS ================= */
.download-section{
margin-top:24px;
padding:18px;
border-radius:14px;
background:linear-gradient(145deg,#05090d,#000)
}
.download-section h3{margin-bottom:12px}
.download-btn{margin-right:10px;margin-bottom:10px}

/* ===================== VIDEO ===================== */
.video-embed{position:relative;padding-bottom:56.25%;height:0;border-radius:14px;overflow:hidden}
.video-embed iframe{
position:absolute;
width:100%;
height:100%;
border:0;
inset:0
}
/* =======================
   FILM CREDITS
======================= */
.credits-section{
margin:40px 0;
padding:24px;
border-left:4px solid #00aeef;
background:#030b12;
border-radius:14px;
}

.credits-section h3{
color:white;
margin-bottom:14px;
}

.credits-list{
list-style:disc;
padding-left:20px;
color:#ccc;
}

.credits-list li{
margin-bottom:6px;
line-height:1.5;
}

/* ===================== FAQ ===================== */
.faq-hero{
min-height:60vh;
display:flex;
align-items:center;
justify-content:center;
background-size:cover
}
.faq-overlay{
background:rgba(0,0,0,.75);
padding:60px;
border-left:5px solid #00aeef;
text-align:center
}
.faq-overlay h1{color:#00aeef}
.faq-overlay p{color:gold}
.faq-content details{
background:black;
margin:14px 0;
padding:16px;
border-left:4px solid #00aeef
}
.faq-content summary{cursor:pointer;font-weight:bold}
.faq-content p{color:#ddd}

/* ================= FORMS ================= */
.booking-form,
.contact-form,
.become-form{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
gap:18px;
margin-top:20px
}
.booking-form input,
.booking-form textarea,
.contact-form input,
.become-form input,
select,textarea{
background:#050c11;
color:white;
border:1px solid rgba(255,255,255,.15);
padding:12px;
border-radius:10px;
width:100%
}
textarea{min-height:120px}
label{font-weight:600}
button,.btn{grid-column:1/-1}

/* ===================== PRO FOOTER ===================== */

.site-footer{
    position:relative;
    background:linear-gradient(180deg,#02070b,#000);
    color:#9aa9b5;
    padding:70px 0 30px;
    border-top:1px solid rgba(255,255,255,.05);
    overflow:hidden;
}

/* glow */
.site-footer::before{
    content:"";
    position:absolute;
    top:-120px;
    right:-120px;
    width:300px;
    height:300px;
    background:radial-gradient(circle,#00aeef,transparent);
    opacity:.08;
}

/* GRID */
.footer-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:40px;
    position:relative;
    z-index:1;
}

/* FOOTER TITLES */
.footer-grid h4{
    color:white;
    margin-bottom:14px;
    font-size:15px;
    letter-spacing:.8px;
    text-transform:uppercase;
}

/* TEXT */
.site-footer p{
    font-size:14px;
    color:#98a8b4;
    line-height:1.7;
}

/* LOGO BLOCK (auto works if class exists) */
.footer-logo,
.site-footer .logo,
.site-footer .brand,
.site-footer .footer-brand{
    display:flex;
    align-items:center;
    gap:12px;
    margin-bottom:14px;
}

.footer-logo img{
    max-height:50px;
    width:auto;
}

.footer-logo .brand-name{
    font-size:18px;
    font-weight:800;
    color:white;
    letter-spacing:.6px;
}

.footer-logo .brand-tagline{
    font-size:12px;
    color:#7b8a97;
}

/* nav */
.footer-nav{
    list-style:none;
    padding:0;
    margin:0;
}

.footer-nav a{
    display:inline-block;
    margin-bottom:10px;
    color:#9aa9b5;
    text-decoration:none;
    font-weight:500;
    transition:.3s;
}

.footer-nav a:hover{
    color:#64d8ff;
    transform:translateX(6px);
}

/* hide newsletter */
.footer-newsletter,
.newsletter,
#newsletter,
.subscribe,
footer form{
    display:none !important;
}

/* social (if any) */
.footer-social{
    margin-top:15px;
    display:flex;
    gap:12px;
    flex-wrap:wrap;
}

.footer-social a{
    background:#02070b;
    color:white;
    padding:10px 16px;
    border-radius:40px;
    font-size:13px;
    text-decoration:none;
    border:1px solid rgba(255,255,255,.08);
    transition:.3s;
}

.footer-social a:hover{
    background:linear-gradient(135deg,#00aeef,#64d8ff);
    color:#001;
}

/* copyright */
.footer-bottom{
    margin-top:50px;
    padding-top:20px;
    text-align:center;
    border-top:1px solid rgba(255,255,255,.05);
    font-size:13px;
    color:#6f7e89;
}

.footer-bottom a{
    color:#00aeef;
    text-decoration:none;
}

.footer-bottom a:hover{
    text-decoration:underline;
}

@media(max-width:768px){
    .footer-grid{
        text-align:center;
    }
    .footer-social{
        justify-content:center;
    }
}

/* ===================== SOCIAL ===================== */
.social-links{display:flex;gap:12px;flex-wrap:wrap}
.social-item{
background:white;
border:2px solid #00aeef;
color:black;
padding:12px 20px;
border-radius:40px;
text-decoration:none;
font-weight:700;
transition:.3s
}
.social-item:hover{background:#00aeef;color:white}

/* ===================== MOBILE ===================== */
@media(max-width:768px){
.footer-grid{grid-template-columns:1fr}
}
/* ==============================
   CLEAN HOME PAGE OVERRIDE
   Safe: overrides only home layout
============================== */

/* -------- HOME HERO FIX -------- */
.home-hero{
    position:relative;
    width:100%;
    min-height:95vh;
    display:flex;
    align-items:center;
    justify-content:center;
    overflow:hidden;
    background:#000;
}

.home-hero .hero-image{
    position:absolute;
    inset:0;
    z-index:0;
}

.home-hero .hero-image img{
    width:100%;
    height:100%;
    object-fit:cover;
}

/* Overlay */
.home-hero::after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(
        to bottom,
        rgba(0,0,0,.75),
        rgba(0,0,0,.9)
		opacity:0.5
    );
    z-index:1;
}

/* CONTENT */
.home-hero .hero-content{
    position:relative;
    z-index:3;
    max-width:900px;
    margin:auto;
    text-align:center;
    padding:60px 30px;
}

.home-hero .hero-content h1{
    font-size:52px;
    margin-bottom:16px;
}

.home-hero .hero-content p{
    max-width:640px;
    margin:0 auto 26px;
}

/* Prevent hero blocking next section */
.home-hero{margin-bottom:100px}


/* -------- FEATURED MODELS FIX -------- */
.featured-carousel{
    display:grid;
    grid-template-columns:repeat(auto-fill, minmax(220px,1fr));
    gap:26px;
    justify-content:center;
    margin-top:30px;
}

.section{
    position:relative;
    z-index:2;
}

/* -------- ABOUT BLOCK FIX -------- */
.about-block{
    position:relative;
    min-height:80vh;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:80px 28px;
    text-align:center;
    overflow:hidden;
}

/* Background image */
.about-block .about-image{
    position:absolute;
    inset:0;
    z-index:0;
    opacity:0.35;
}

.about-block .about-image img{
    width:100%;
    height:100%;
    object-fit:cover;
}

/* Overlay */
.about-block::before{
    content:"";
    position:absolute;
    inset:0;
    background:rgba(0,0,0,.75);
    z-index:1;
}

/* Text content */
.about-block .about-text{
    position:relative;
    z-index:3;
    max-width:780px;
    margin:auto;
}

/* Remove grid behavior */
.about-block{
    grid-template-columns:none !important;
}


/* -------- WHY GRID FIX -------- */
.why{
    padding-top:60px;
    text-align:center;
}

.why-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
    gap:30px;
    justify-content:center;
    max-width:1100px;
    margin:50px auto 0;
}

.why-item{
    background:#0a1016;
    padding:28px;
    border-radius:18px;
    border:1px solid rgba(255,255,255,.05);
    position:relative;
}

.why-item h3{
    color:white;

}

/* -------- CTA FIX -------- */
.cta-banner{
    max-width:1150px;
    margin:100px auto;
    align-items:center;
    justify-content:center;
    text-align:center;
}

.cta-banner h2{
    max-width:600px;
}

/* -------- TITLES CENTER -------- */
.section-title{
    text-align:center;
    margin-bottom:20px;
}


/* -------- MOBILE FIX -------- */
@media(max-width:900px){

    .home-hero{
        min-height:90vh;
        text-align:center;
    }

    .home-hero .hero-content h1{
        font-size:34px;
    }

    .about-block{
        padding:60px 20px;
    }

    .featured-carousel{
        grid-template-columns:repeat(auto-fill, minmax(160px,1fr));
    }
}
/* =========================================
   BECOME A BUTTERFLY PAGE STYLING
========================================= */

.apply-hero {
  min-height: 100vh;
  background-size: cover;
  background-position: center;
  position: relative;
  display: flex;
  align-items: center;
  padding: 80px 0;
}

.apply-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(10,10,10,.85), rgba(10,10,10,.7));
  z-index: 1;
}

.become-page {
  position: relative;
  z-index: 2;
}

.apply-header {
  text-align: center;
  max-width: 700px;
  margin: 0 auto 50px;
}

.apply-header h1 {
  font-size: clamp(2.5rem,5vw,3.5rem);
  font-weight: 800;
  color: #fff;
  letter-spacing: .05em;
}

.apply-header p {
  font-size: 1.2rem;
  color: rgba(255,255,255,.7);
  margin-top: 10px;
}

/* GRID LAYOUT */
.become-grid {
  display: grid;
  grid-template-columns: 1.3fr 0.7fr;
  gap: 40px;
}

/* LEFT COLUMN */
.become-left {
  background: rgba(0,0,0,.65);
  backdrop-filter: blur(6px);
  padding: 35px;
  border-radius: 16px;
}

/* ELIGIBILITY */
.eligibility-card {
  background: rgba(255,255,255,.04);
  border-left: 4px solid gold;
  padding: 20px;
  margin-bottom: 25px;
  border-radius: 10px;
}

.eligibility-card h3 {
  margin-bottom: 10px;
  font-weight: 700;
  color: gold;
}

.eligibility-card li {
  color: #ddd;
  padding: 6px 0;
  font-size: .95rem;
}

/* FORM */
.become-form {
  display: grid;
  gap: 15px;
}

.become-form label {
  display: flex;
  flex-direction: column;
  color: #ccc;
  font-size: .9rem;
}

.become-form input,
.become-form textarea {
  background: rgba(255,255,255,.08);
  border: none;
  padding: 12px;
  border-radius: 6px;
  color: #fff;
  outline: none;
}

.become-form input:focus,
.become-form textarea:focus {
  background: rgba(255,255,255,.15);
}

.become-form input[type="file"] {
  padding: 6px;
  font-size: .85rem;
}

/* BUTTONS */
.become-form .btn {
  background: gold;
  color: #000;
  font-weight: 700;
  padding: 13px;
  border: none;
  border-radius: 40px;
  text-align: center;
  cursor: pointer;
  transition: .3s;
}

.become-form .btn:hover {
  opacity: .8;
}

.whatsapp-btn {
  background: #25d366;
  color: #fff;
  text-align: center;
}


/* NOTICES */
.notice {
  padding: 12px;
  margin-bottom: 15px;
  border-radius: 6px;
  font-weight: 600;
}

.notice.success {
  background: #2ecc71;
  color: #000;
}

.notice.error {
  background: #c0392b;
  color: #fff;
}

/* RIGHT COLUMN */
.become-right {
  display: grid;
  gap: 20px;
}

.become-right .card {
  background: rgba(0,0,0,.7);
  padding: 25px;
  border-radius: 16px;
  color: #fff;
}

.become-right .highlight {
  border: 1px solid gold;
}

.become-right h3, 
.become-right h4 {
  color: gold;
  font-weight: 700;
}

.steps li {
  padding: 7px 0;
  border-bottom: 1px solid rgba(255,255,255,.1);
}

/* MOBILE */
@media (max-width:900px){
  .become-grid {
    grid-template-columns: 1fr;
  }
}
/* ==========================
   BOOK A MODEL – PRO STYLING
   ========================== */

/* page base */
.booking-full{
    background:#02070b;
    min-height:100vh;
    color:white;
    overflow:hidden;
}

/* ---------------------------
   HERO
---------------------------- */

.booking-hero{
    position:relative;
    min-height:55vh;
    display:flex;
    align-items:center;
    background-size:cover;
    background-position:center;
    background-attachment:fixed;
}

.booking-hero::before{
    content:"";
    position:absolute;
    inset:0;
    background:
      linear-gradient(180deg,rgba(0,0,0,.65),rgba(3,10,15,.95));
    z-index:1;
}

.booking-hero .container{
    position:relative;
    z-index:2;
    max-width:850px;
    text-align:left;
}

.booking-hero h1{
    font-size:clamp(40px,6vw,64px);
    font-weight:900;
    letter-spacing:1px;
}

.booking-hero .muted{
    font-size:18px;
    color:#aab8c5;
    max-width:600px;
}



/* ---------------------------
   MAIN GRID
---------------------------- */

.booking-wrap{
    padding:80px 0;
}

.booking-grid{
    display:grid;
    grid-template-columns:1.4fr .9fr;
    gap:40px;
    align-items:flex-start;
}


/* ---------------------------
   GLASS CARDS
---------------------------- */

.card{
    background:rgba(10,18,25,.85);
    backdrop-filter:blur(16px);
    border-radius:20px;
    border:1px solid rgba(255,255,255,.05);
    padding:30px;
    box-shadow:0 14px 40px rgba(0,0,0,.6);
}


/* ---------------------------
   FORM UPGRADE
---------------------------- */

.booking-left form{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:18px;
}

/* full width fields */
.booking-left textarea,
.booking-left button,
.booking-left .full,
.booking-left input[type="file"]{
    grid-column:1/ -1;
}

/* labels */
.booking-left label{
    font-size:13px;
    color:#8fa1af;
    display:block;
    margin-bottom:6px;
    letter-spacing:.4px;
}

/* inputs */
.booking-left input,
.booking-left select,
.booking-left textarea{
    width:100%;
    padding:14px 14px;
    border-radius:10px;
    background:#02070c;
    border:1px solid rgba(255,255,255,.08);
    color:white;
    font-size:15px;
    outline:none;
    transition:.25s;
}

.booking-left textarea{
    min-height:120px;
    resize:vertical;
}

.booking-left input:focus,
.booking-left textarea:focus,
.booking-left select:focus{
    border-color:#00aeef;
    box-shadow:0 0 0 2px rgba(0,174,239,.2);
}

/* button */
.booking-left button{
    background:linear-gradient(135deg,#00aeef,#5fd9ff);
    border:0;
    padding:15px;
    font-size:16px;
    border-radius:30px;
    font-weight:800;
    margin-top:10px;
    cursor:pointer;
    color:#001;
    transition:.3s;
}

.booking-left button:hover{
    transform:translateY(-2px);
    box-shadow:0 10px 25px rgba(0,174,239,.4);
}


/* ---------------------------
   NOTICE BOX
---------------------------- */

.notice{
    padding:14px 18px;
    border-radius:10px;
    margin-bottom:18px;
    font-size:14px;
}

.notice.success{
    background:rgba(0,200,120,.1);
    border:1px solid rgba(0,200,120,.4);
}

.notice.error{
    background:rgba(200,0,50,.12);
    border:1px solid rgba(200,0,50,.4);
}


/* ---------------------------
   RIGHT COLUMN
---------------------------- */

.booking-right .card{
    position:sticky;
    top:100px;
}

.booking-right h4{
    font-size:15px;
    letter-spacing:1px;
    text-transform:uppercase;
    margin-bottom:10px;
    color:white;
}

.booking-right a{
    color:#64d8ff;
    text-decoration:none;
    font-weight:600;
}

.booking-right a:hover{
    text-decoration:underline;
}


/* ---------------------------
   MOBILE
---------------------------- */

@media(max-width:900px){

.booking-grid{
    grid-template-columns:1fr;
}

.booking-right .card{
    position:relative;
    top:0;
}

.booking-left form{
    grid-template-columns:1fr;
}

.booking-hero{
    min-height:45vh;
    text-align:center;
}

.booking-hero .container{
    text-align:center;
}

}
/* ======================
   CLIENT PRO SECTION
====================== */

.client-pro{
padding:90px 20px 20px;
background:linear-gradient(180deg,#02070b,#000)
}

.client-head{text-align:center;margin-bottom:40px}
.client-head h2{font-size:32px}
.client-head p{color:#aaa}

.client-proof{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
gap:18px;
margin-top:35px
}

.client-proof div{
background:#02070b;
padding:24px;
border-radius:16px;
border-left:4px solid #00aeef
}

.client-proof strong{font-size:22px;display:block}

/* FEATURES */

.client-features{padding:90px 20px}
.feature-grid{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
gap:22px
}
.feature{
background:#050c11;
padding:26px;
border-radius:16px;
transition:.3s
}
.feature:hover{transform:translateY(-5px)}
.feature h4{color:#00aeef}

/* PROCESS */

.client-process{padding:90px 20px;background:#000}
.process-grid{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
gap:22px
}
.process-grid div{
background:#02070b;
padding:22px;
border-radius:14px;
text-align:center
}
.process-grid span{
font-size:22px;
color:#00aeef;
display:block;
margin-bottom:8px;
font-weight:800
}

/* CTA */

.booking-cta{
padding:80px 20px;
text-align:center;
background:linear-gradient(180deg,#000,#02070b)
}
.booking-cta h2{margin-bottom:10px}

/*------------Client Portal------------*/

.client-hero{
background:linear-gradient(rgba(0,0,0,.7),rgba(0,0,0,.8)),url('/wp-content/uploads/client-bg.jpg') center/cover;
padding:120px 20px;
color:#fff
}
.client-wrap{display:grid;grid-template-columns:1.4fr .6fr;gap:50px}
.client-actions .btn{margin-right:12px}

.client-proof{
display:grid;
grid-template-columns:repeat(2,1fr);
gap:18px
}
.client-proof div{
background:#02070b;
padding:20px;
border-radius:12px;
border-left:4px solid #00aeef
}
.client-proof strong{font-size:22px}

.client-features,.client-types,.client-process{padding:90px 20px}
.feature-grid,.type-grid,.process-grid{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
gap:22px
}
.feature,.process-grid div{
background:#050c11;
padding:24px;
border-radius:16px
}

.type-grid div{
background:#02070b;
padding:20px;
text-align:center;
font-weight:600;
border-radius:12px
}

.process-grid span{
font-size:22px;
color:#00aeef;
font-weight:800
}

.client-cta{
background:#000;
padding:90px 20px;
text-align:center
}
/* PORTFOLIO FILTERS */
.portfolio-filters{
display:flex;
flex-wrap:wrap;
gap:12px;
margin:16px 0 20px;
}

.portfolio-filters a{
padding:8px 16px;
border-radius:20px;
font-weight:700;
background:#050b10;
color:white;
border:1px solid rgba(0,174,239,.3);
text-decoration:none;
transition:.25s;
}

.portfolio-filters a:hover,
.portfolio-filters a.active{
background:#00aeef;
color:black;
}

/*-------NEW HEADER-------*/
.site-brand{
  display:flex;
  align-items:center;
  gap:14px;
}

.logo-link{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  color:inherit;
}

.site-logo img{
  max-height:50px;
  width:auto;
  display:block;
}

.logo-text{
  font-size:26px;
  font-weight:900;
  letter-spacing:2px;
}

.brand-text{
  display:flex;
  flex-direction:column;
  line-height:1.2;
}

.brand-text strong{
  font-size:15px;
  letter-spacing:.5px;
}

.tagline{
  font-size:11px;
  opacity:.7;
}
/*----NEW FOOTER LOGO------*/
.footer-logo-link{
  display:inline-flex;
  align-items:center;
  margin-bottom:12px;
  text-decoration:none;
}

.footer-logo img{
  max-height:45px;
  width:auto;
  display:block;
}

.footer-logo-text{
  font-size:24px;
  font-weight:900;
  letter-spacing:2px;
}

.footer-brand p{
  margin:6px 0 0;
  font-size:12px;
  opacity:.7;
}
