/* ============================================================
   MY MEDIA AFRICA — HOMEPAGE REDESIGN
   Core theme: red / black / white
============================================================ */

:root{
    --red:        #C41E3A;
    --red-dark:   #8B0000;
    --black:      #111111;
    --off-black:  #1a1a1a;
    --white:      #ffffff;
    --off-white:  #F7F5F0;
    --pink:       #FBE9E7;
    --gray-mid:   #6c6c6c;
    --gray-light: #e6e3dd;
    --font-display: 'Poppins', 'Segoe UI', sans-serif;
    --font-body: 'Segoe UI', Tahoma, Verdana, sans-serif;
}

*{ box-sizing: border-box; }

body{
    font-family: var(--font-body);
    color: var(--black);
    margin: 0;
    padding-top: 84px; /* fixed header offset */
}

a{ text-decoration:none; }
img{ max-width:100%; display:block; }

.eyebrow-red{
    display:inline-block;
    font-size:12px;
    font-weight:700;
    letter-spacing:.14em;
    text-transform:uppercase;
    color: var(--red);
    margin-bottom: 10px;
}

.btn-primary-red{
    display:inline-flex;
    align-items:center;
    gap:8px;
    background: var(--red);
    color: var(--white);
    padding: 14px 28px;
    font-weight:600;
    border:none;
    transition: background .25s ease, transform .25s ease;
}
.btn-primary-red:hover{
    background: var(--red-dark);
    color: var(--white);
    transform: translateY(-2px);
}

.btn-text-link{
    color: var(--black);
    font-weight:600;
    font-size:14px;
    display:inline-flex;
    align-items:center;
    gap:6px;
}
.btn-text-link:hover{ color: var(--red); }
.btn-text-link.light{ color:#fff; }
.btn-text-link.light:hover{ color: var(--red); }

/* ============================================================
   HEADER
============================================================ */
.site-header{
    position: fixed;
    top:0; left:0; right:0;
    background: var(--white);
    box-shadow: 0 2px 12px rgba(0,0,0,.06);
    z-index: 1000;
    height: 84px;
    display:flex;
    align-items:center;
}

.site-header-inner{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap: 24px;
}

.site-logo img{ width: 170px; }

.main-nav ul{
    display:flex;
    align-items:center;
    gap: 26px;
    list-style:none;
    margin:0; padding:0;
}

.main-nav a{
    color: var(--black);
    font-size: 14.5px;
    font-weight:500;
}

.main-nav a:hover{ color: var(--red); }

.main-nav .has-dropdown{ position:relative; }
.main-nav .has-dropdown > a i{ font-size:10px; margin-left:4px; }

.dropdown-menu-simple{
    position:absolute;
    top: 100%;
    left:0;
    background: var(--white);
    box-shadow: 0 10px 30px rgba(0,0,0,.12);
    min-width: 220px;
    list-style:none;
    padding: 10px 0;
    margin:0;
    opacity:0;
    visibility:hidden;
    transform: translateY(8px);
    transition: all .2s ease;
}
.main-nav .has-dropdown:hover .dropdown-menu-simple{
    opacity:1; visibility:visible; transform: translateY(0);
}
.dropdown-menu-simple li a{
    display:block;
    padding: 8px 20px;
    font-size:13.5px;
}
.dropdown-menu-simple li a:hover{ background: var(--off-white); }

.btn-lets-talk{
    background: var(--red);
    color: var(--white);
    padding: 10px 22px;
    font-weight:600;
    font-size: 14px;
}
.btn-lets-talk:hover{ background: var(--red-dark); color:#fff; }

.nav-toggle{
    display:none;
    background:none;
    border:none;
    font-size: 22px;
    color: var(--black);
    cursor:pointer;
}

@media(max-width: 991px){
    .main-nav{
        position:fixed;
        top:84px; left:0; right:0;
        background:var(--white);
        max-height:0;
        overflow:hidden;
        transition: max-height .3s ease;
        box-shadow: 0 10px 20px rgba(0,0,0,.08);
    }
    .main-nav.open{ max-height: 520px; }
    .main-nav ul{ flex-direction:column; align-items:flex-start; gap:0; padding: 10px 24px 20px; }
    .main-nav ul li{ width:100%; border-bottom:1px solid var(--gray-light); }
    .main-nav ul li a{ display:block; padding: 12px 0; }
    .dropdown-menu-simple{ position:static; box-shadow:none; opacity:1; visibility:visible; transform:none; display:none; padding-left: 12px;}
    .main-nav .has-dropdown:hover .dropdown-menu-simple{ display:block; }
    .nav-toggle{ display:block; }
    .btn-lets-talk{ display:none !important; }
}

/* ============================================================
   HERO
============================================================ */
.hero2{
    position:relative;
    background-size:cover;
    background-position:center;
    padding: 90px 0 130px;
    color:#fff;
}
.hero2-overlay{
    position:absolute; inset:0;
    background: linear-gradient(120deg, rgba(10,10,10,.88) 30%, rgba(139,0,0,.55) 100%);
}
.hero2 .container{ position:relative; z-index:2; }

.hero2-content{ max-width: 640px; }

.hero2-title{
    font-size: clamp(2.4rem, 5vw, 4rem);
    font-weight:800;
    line-height:1.1;
    margin-bottom: 18px;
}
.hero2-title span{ color: var(--red); display:block; }

.hero2-subtitle{
    font-size: 1.05rem;
    color: rgba(255,255,255,.85);
    max-width: 480px;
    margin-bottom: 32px;
}

.hero2-actions{ display:flex; align-items:center; gap: 26px; flex-wrap:wrap; }

.btn-watch{
    display:flex; align-items:center; gap:12px;
    color:#fff; font-weight:600;
}
.play-circle{
    width:42px; height:42px; border-radius:50%;
    border: 2px solid #fff;
    display:flex; align-items:center; justify-content:center;
    font-size: 13px;
}
.btn-watch:hover{ color: var(--red); }
.btn-watch:hover .play-circle{ border-color: var(--red); color: var(--red); }

/* Services strip overlapping hero bottom */
.services-strip{
    position:relative;
    z-index:3;
    margin-top: -70px;
}
.services-strip-grid{
    background:#fff;
    box-shadow: 0 20px 50px rgba(0,0,0,.15);
    display:grid;
    grid-template-columns: repeat(6, 1fr);
}
.service-strip-item{
    padding: 26px 18px;
    text-align:center;
    border-right: 1px solid var(--gray-light);
}
.service-strip-item:last-child{ border-right:none; }
.service-strip-icon{
    width:46px; height:46px;
    margin: 0 auto 12px;
    border-radius:50%;
    background: var(--pink);
    color: var(--red);
    display:flex; align-items:center; justify-content:center;
    font-size:18px;
}
.service-strip-item h6{ font-size:13.5px; font-weight:700; margin-bottom:6px; }
.service-strip-item p{ font-size:11.5px; color: var(--gray-mid); line-height:1.5; margin:0; }

@media(max-width: 991px){
    .services-strip-grid{ grid-template-columns: repeat(3, 1fr); }
    .service-strip-item:nth-child(3){ border-right:none; }
}
@media(max-width: 576px){
    .services-strip{ margin-top: 20px; }
    .services-strip-grid{ grid-template-columns: repeat(1, 1fr); }
    .service-strip-item{ border-right:none; border-bottom:1px solid var(--gray-light); }
}

/* ============================================================
   WHO WE ARE
============================================================ */
.who-we-are{ padding: 120px 0 90px; background: var(--white); }
@media(max-width: 576px){ .who-we-are{ padding-top: 60px; } }

.wwa-grid{
    display:grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items:center;
}
.wwa-text h2{ font-size: 2.2rem; font-weight:800; margin-bottom:18px; }
.wwa-text p{ color: var(--gray-mid); line-height:1.7; margin-bottom: 16px; }
.wwa-actions{ display:flex; align-items:center; gap:26px; margin-top:20px; }

.wwa-collage{
    display:grid;
    grid-template-columns: 1fr 1fr 1fr;
    grid-template-rows: 140px 140px;
    gap: 12px;
}
.wwa-img{ overflow:hidden; }
.wwa-img img{ width:100%; height:100%; object-fit:cover; }
.wwa-img-1{ grid-column: 1/2; grid-row: 1/2; }
.wwa-img-2{ grid-column: 2/3; grid-row: 1/2; }
.wwa-img-3{ grid-column: 1/3; grid-row: 2/3; }
.wwa-img-4{ grid-column: 3/4; grid-row: 1/3; }
.wwa-stat{
    grid-column: 3/4; grid-row: 1/2;
    background: var(--red);
    color:#fff;
    display:flex; flex-direction:column; align-items:center; justify-content:center;
    text-align:center; padding: 10px;
}
.wwa-stat-number{ font-size:2rem; font-weight:800; }
.wwa-stat-label{ font-size:11px; text-transform:uppercase; letter-spacing:.05em; }

@media(max-width: 860px){
    .wwa-grid{ grid-template-columns:1fr; }
    .wwa-collage{ order:-1; }
}

/* ============================================================
   SUCCESS STORIES
============================================================ */
.success-stories2{ padding: 90px 0; background: var(--off-white); }

.sec-head-flex{
    display:flex; align-items:flex-end; justify-content:space-between;
    margin-bottom: 40px; flex-wrap:wrap; gap:16px;
}
.sec-head-flex h2{ font-size:2rem; font-weight:800; margin:0; }

.story-cards-grid{
    display:grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}
.story-card2{
    background:#fff;
    color: var(--black);
    display:block;
    transition: transform .3s ease, box-shadow .3s ease;
}
.story-card2:hover{
    transform: translateY(-6px);
    box-shadow: 0 15px 35px rgba(0,0,0,.1);
    color: var(--black);
}
.story-card2-img{ position:relative; height: 170px; overflow:hidden; background:#ddd; }
.story-card2-img img{ width:100%; height:100%; object-fit:cover; }
.story-card2-badge{
    position:absolute; top:12px; left:12px;
    background: var(--red); color:#fff;
    font-size:10px; text-transform:uppercase; letter-spacing:.08em;
    padding: 5px 10px; font-weight:700;
}
.story-card2-body{ padding: 18px; }
.story-card2-body h5{ font-size:15px; font-weight:700; margin-bottom:8px; line-height:1.35; }
.story-card2-body p{ font-size:12.5px; color:var(--gray-mid); line-height:1.6; margin-bottom:14px; }
.read-story{ font-size:12.5px; font-weight:700; color: var(--red); }

@media(max-width: 991px){ .story-cards-grid{ grid-template-columns: repeat(2, 1fr); } }
@media(max-width: 576px){ .story-cards-grid{ grid-template-columns: 1fr; } }

/* ============================================================
   PODCAST
============================================================ */
.podcast-section{ background: var(--black); padding: 90px 0; color:#fff; }

.podcast-grid{
    display:grid;
    grid-template-columns: 1fr 1.4fr;
    gap: 50px;
    align-items:center;
}
.podcast-text h2{ font-size: 2rem; font-weight:800; margin-bottom: 16px; }
.podcast-text h2 span{ color: var(--red); }
.podcast-text p{ color: rgba(255,255,255,.7); margin-bottom: 28px; line-height:1.7; }
.podcast-actions{ display:flex; align-items:center; gap:26px; flex-wrap:wrap; }

.podcast-episodes{
    display:grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}
.podcast-card{ display:block; color:#fff; }
.podcast-card-img{
    position:relative; height: 150px; overflow:hidden; background:#333;
}
.podcast-card-img img{ width:100%; height:100%; object-fit:cover; opacity:.75; transition: opacity .3s ease; }
.podcast-card:hover .podcast-card-img img{ opacity:1; }
.podcast-play{
    position:absolute; top:50%; left:50%; transform: translate(-50%,-50%);
    width:46px; height:46px; border-radius:50%;
    background: rgba(196,30,58,.9);
    display:flex; align-items:center; justify-content:center;
    color:#fff; font-size:14px;
}
.podcast-duration{
    position:absolute; bottom:8px; right:8px;
    background: rgba(0,0,0,.65);
    font-size:11px; padding: 3px 8px;
}
.podcast-card-body{ padding: 12px 4px 0; }
.podcast-card-body h6{ font-size:13px; font-weight:700; margin-bottom:4px; line-height:1.4; }
.podcast-card-body p{ font-size:11.5px; color: rgba(255,255,255,.55); margin:0; }

@media(max-width: 860px){
    .podcast-grid{ grid-template-columns: 1fr; }
    .podcast-episodes{ grid-template-columns: repeat(3, 1fr); }
}
@media(max-width: 576px){ .podcast-episodes{ grid-template-columns: 1fr; } }

/* ============================================================
   STATS BAR
============================================================ */
.stats-bar2{ background: var(--red); padding: 46px 0; color:#fff; }
.stats-bar2 .stat-number2{ font-size: 2.4rem; font-weight:800; }
.stats-bar2 p{ font-size:12.5px; text-transform:uppercase; letter-spacing:.06em; margin-top:6px; }

/* ============================================================
   PARTNERS
============================================================ */
.partners-strip{ padding: 70px 0; text-align:center; background:#fff; }
.partners-strip h3{ font-size: 1.7rem; font-weight:800; margin-bottom: 34px; }
.partners-row{
    display:flex; flex-wrap:wrap; align-items:center; justify-content:center;
    gap: 46px;
}
.partner-logo{
    max-height: 34px; width:auto;
    filter: grayscale(100%) contrast(0.5); opacity:.7;
    transition: all .3s ease;
}
.partner-logo:hover{ filter:none; opacity:1; }

/* ============================================================
   NEWSLETTER
============================================================ */
.newsletter2{ background: var(--pink); padding: 60px 0; }
.newsletter2-inner{
    display:grid;
    grid-template-columns: 1.4fr 1fr;
    align-items:center;
    gap: 30px;
}
.newsletter2-text h3{ font-size:1.9rem; font-weight:800; margin-bottom:12px; }
.newsletter2-text h3 span{ color: var(--red); }
.newsletter2-text p{ color: var(--gray-mid); margin-bottom: 22px; max-width: 480px; }

.newsletter2-form{ display:flex; max-width: 440px; }
.newsletter2-form input{
    flex:1; padding: 14px 18px; border: 1px solid var(--gray-light); border-right:none;
    font-size:14px;
}
.newsletter2-form button{
    background: var(--red); color:#fff; border:none; padding: 0 26px; font-weight:600;
    cursor:pointer;
}
.newsletter2-form button:hover{ background: var(--red-dark); }

.newsletter2-img img{ max-width: 260px; margin: 0 auto; }

@media(max-width: 860px){
    .newsletter2-inner{ grid-template-columns: 1fr; text-align:center; }
    .newsletter2-form{ margin: 0 auto; }
    .newsletter2-img{ order:-1; }
}

/* ============================================================
   FOOTER
============================================================ */
.site-footer{ background: var(--off-black); color: rgba(255,255,255,.75); padding: 70px 0 0; }
.footer-grid{
    display:grid;
    grid-template-columns: 1.6fr 1fr 1fr 1fr 1.2fr;
    gap: 30px;
    padding-bottom: 40px;
    border-bottom: 1px solid rgba(255,255,255,.1);
}
.footer-brand .site-logo img{ width:150px; margin-bottom: 16px; }
.footer-brand p{ font-size: 13.5px; line-height:1.7; margin-bottom: 20px; }
.footer-social{ display:flex; gap:12px; }
.footer-social a{
    width:36px; height:36px; border-radius:50%;
    background: rgba(255,255,255,.08);
    display:flex; align-items:center; justify-content:center;
    color:#fff; transition: all .25s ease;
}
.footer-social a:hover{ background: var(--red); }

.footer-col h5{ color:#fff; font-size:15px; font-weight:700; margin-bottom: 18px; }
.footer-col ul{ list-style:none; padding:0; margin:0; }
.footer-col ul li{ margin-bottom: 12px; font-size: 13.5px; }
.footer-col ul li a{ color: rgba(255,255,255,.7); }
.footer-col ul li a:hover{ color: var(--red); }
.footer-contact li{ display:flex; align-items:flex-start; gap:10px; }
.footer-contact i{ color: var(--red); margin-top:3px; }

.footer-bottom{
    display:flex; align-items:center; justify-content:space-between;
    padding: 22px 0; font-size: 12.5px; flex-wrap:wrap; gap:10px;
}
.footer-legal{ display:flex; gap:20px; }
.footer-legal a{ color: rgba(255,255,255,.6); }
.footer-legal a:hover{ color:#fff; }

@media(max-width: 991px){
    .footer-grid{ grid-template-columns: 1fr 1fr; }
}
@media(max-width: 576px){
    .footer-grid{ grid-template-columns: 1fr; }
    .footer-bottom{ flex-direction:column; text-align:center; }
}

/* ============================================================
   FLOATING BUTTONS
============================================================ */
.whatsapp-float{
    position:fixed; bottom:24px; left:24px;
    background:#25D366; color:#fff;
    width:56px; height:56px; border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-size:26px; box-shadow: 0 6px 16px rgba(0,0,0,.3);
    z-index: 999;
}

.scroll-top{
    position:fixed; bottom:24px; right:24px;
    width:48px; height:48px; border-radius:50%;
    background: var(--red); color:#fff; border:none;
    display:flex; align-items:center; justify-content:center;
    opacity:0; visibility:hidden; transform: translateY(10px);
    transition: all .3s ease;
    z-index: 999; cursor:pointer;
}
.scroll-top.visible{ opacity:1; visibility:visible; transform:translateY(0); }
.scroll-top:hover{ background: var(--red-dark); }

/* ============================================================
   SCROLL REVEAL (simple, no library)
============================================================ */
.reveal{ opacity:0; transform: translateY(24px); transition: all .6s ease; }
.reveal.in-view{ opacity:1; transform: translateY(0); }