/* ===================== FASHIONTV AFRICA — SHARED STYLES ===================== */
:root{
  --paper:#ffffff;--paper-soft:#f4f2ee;--ink:#0e0e0e;--ink-dim:#6b6660;
  --accent:#2742cf;--accent-bright:#5570ff;--navy:#0a1628;
  --line:rgba(14,14,14,.14);--maxw:1280px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:'Jost',sans-serif;font-weight:300;line-height:1.7;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Bodoni Moda',serif;font-weight:500;line-height:1.05}
a{color:inherit;text-decoration:none}
img,video{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 34px}
.eyebrow{font-weight:500;letter-spacing:.42em;text-transform:uppercase;font-size:.72rem;color:var(--accent);margin-bottom:22px}
.divider{width:54px;height:1px;background:var(--accent);margin-bottom:26px}
.center{text-align:center}.center .divider{margin-left:auto;margin-right:auto}

/* logos: transparent PNGs. Farazzo darkened so it reads on white. */
.logo-ftv{height:46px}
.logo-frz{height:30px;filter:brightness(0)}

/* ---------- HEADER ---------- */
header{position:fixed;top:0;left:0;width:100%;z-index:1000;padding:18px 0;background:rgba(255,255,255,.96);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:padding .3s,border-color .3s}
header.scrolled{padding:10px 0;border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:14px}
.brand .tag{font-family:'Bodoni Moda',serif;font-style:italic;font-size:1.1rem;color:var(--accent);border-left:1px solid var(--line);padding-left:14px}
.menu{display:flex;align-items:center;gap:32px;list-style:none}
.menu a{font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;position:relative;padding:4px 0;transition:color .3s}
.menu a:hover,.menu a.active{color:var(--accent)}
.menu a::after{content:'';position:absolute;left:0;bottom:-2px;height:1px;width:0;background:var(--accent);transition:width .35s}
.menu a:hover::after,.menu a.active::after{width:100%}
.nav-cta{border:1px solid var(--accent);color:var(--accent)!important;padding:10px 22px!important;border-radius:2px;transition:.3s!important}
.nav-cta:hover{background:var(--accent);color:#fff!important}
.nav-cta::after{display:none!important}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none}
.burger span{width:26px;height:2px;background:var(--ink);transition:.3s}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:12px;padding:16px 38px;font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;font-weight:500;border-radius:2px;transition:.3s;cursor:pointer}
.btn-fill{background:var(--accent);color:#fff;border:1px solid var(--accent)}
.btn-fill:hover{background:var(--accent-bright);border-color:var(--accent-bright);transform:translateY(-2px)}
.btn-ghost{border:1px solid rgba(14,14,14,.3);color:var(--ink)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn-light{border:1px solid rgba(255,255,255,.6);color:#fff}
.btn-light:hover{background:#fff;color:var(--ink)}
.play-dot{width:8px;height:8px;border-radius:50%;background:currentColor;animation:blink 1.6s infinite}
@keyframes blink{50%{opacity:.3}}

/* ---------- HOME HERO (full-bleed video) ---------- */
.vhero{position:relative;height:100vh;min-height:620px;display:flex;align-items:center;overflow:hidden}
.vhero video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.vhero .scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(8,8,10,.82),rgba(8,8,10,.45) 55%,rgba(8,8,10,.25))}
.vhero .wrap{position:relative;z-index:2;color:#fff}
.vhero .eyebrow{color:#fff}
.vhero h1{font-size:clamp(3rem,7.5vw,6.6rem);letter-spacing:-.02em;color:#fff;margin:6px 0 24px}
.vhero h1 em{font-style:italic;color:var(--accent-bright)}
.vhero p{max-width:600px;color:rgba(255,255,255,.85);font-size:clamp(1.05rem,1.5vw,1.3rem);margin-bottom:40px}
.vhero .acts{display:flex;gap:16px;flex-wrap:wrap}
.vhero .powered{position:absolute;bottom:34px;left:34px;z-index:2;display:flex;align-items:center;gap:12px}
.vhero .powered span{font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.vhero .powered .logo-frz{filter:none;height:28px} /* on dark hero keep original colours */

/* ---------- PAGE HEADER (sub-pages) ---------- */
.phead{padding:160px 0 70px;border-bottom:1px solid var(--line);position:relative}
.phead h1{font-size:clamp(2.6rem,6vw,4.6rem);letter-spacing:-.01em;margin-bottom:18px}
.phead h1 em{font-style:italic;color:var(--accent)}
.phead p{max-width:620px;color:var(--ink-dim);font-size:1.1rem}

/* ---------- MARQUEE ---------- */
.marquee{background:var(--accent);color:#fff;padding:16px 0;overflow:hidden;white-space:nowrap}
.mtrack{display:inline-flex;gap:46px;animation:scroll 26s linear infinite;font-family:'Bodoni Moda',serif;font-style:italic;font-size:1.4rem}
.mtrack span{display:inline-flex;align-items:center;gap:46px}
.mtrack span::after{content:'\2726';font-style:normal;font-size:.8rem}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- SECTIONS ---------- */
section{padding:110px 0;position:relative}
.shead{max-width:680px;margin-bottom:56px}
.shead h2{font-size:clamp(2.2rem,4.2vw,3.4rem);margin-bottom:18px}
.shead p{color:var(--ink-dim);font-size:1.05rem}
.soft{background:var(--paper-soft)}

/* ---------- EXPLORE HUB CARDS (home) ---------- */
.hub{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.hub-card{position:relative;height:340px;overflow:hidden;border:1px solid var(--line);display:flex;align-items:flex-end;color:#fff}
.hub-card video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;transition:transform 1.1s ease}
.hub-card .ov{position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(8,8,10,.85),rgba(8,8,10,.15) 65%)}
.hub-card .c{position:relative;z-index:2;padding:34px}
.hub-card .num{font-family:'Bodoni Moda',serif;color:var(--accent-bright);font-size:.9rem;letter-spacing:.1em}
.hub-card h3{font-size:1.9rem;margin:8px 0 8px}
.hub-card p{font-size:.95rem;color:rgba(255,255,255,.82);max-width:90%}
.hub-card .go{margin-top:14px;font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:#fff}
.hub-card:hover video{transform:scale(1.06)}
.hub-card:hover{border-color:var(--accent)}

/* ---------- SHOWREEL GRID ---------- */
.reel-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:180px;gap:14px}
.reel{position:relative;overflow:hidden;border:1px solid var(--line);background:#0a0a0a}
.reel video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.1s}
.reel:hover video{transform:scale(1.05)}
.reel .tag{position:absolute;left:20px;bottom:18px;z-index:2;font-family:'Bodoni Moda',serif;font-style:italic;font-size:1.15rem;color:#fff}
.reel .ov{position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(8,8,10,.7),transparent 55%)}
.reel:hover{border-color:var(--accent)}

/* ---------- FEATURE SPLITS ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;align-items:stretch}
.split.flip .media{order:2}
.media{position:relative;min-height:480px;overflow:hidden;background:#0a0a0a}
.media video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.stext{padding:80px 64px;display:flex;flex-direction:column;justify-content:center;background:var(--paper-soft)}
.stext h2{font-size:clamp(2rem,3.4vw,2.9rem);margin-bottom:20px}
.stext p{color:var(--ink-dim);margin-bottom:16px}
.tick{list-style:none;margin:12px 0 28px}
.tick li{position:relative;padding-left:26px;margin-bottom:11px}
.tick li::before{content:'\25C6';position:absolute;left:0;top:5px;color:var(--accent);font-size:.65rem}

/* ---------- OFFERINGS CARDS ---------- */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line)}
.ocard{background:var(--paper);padding:46px 36px;min-height:300px;display:flex;flex-direction:column;transition:background .3s}
.ocard:hover{background:var(--paper-soft)}
.ocard .idx{font-family:'Bodoni Moda',serif;color:var(--accent);letter-spacing:.1em;margin-bottom:auto}
.ocard h3{font-size:1.6rem;margin:26px 0 14px}
.ocard p{color:var(--ink-dim);font-size:.95rem}

/* ---------- STATS ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
.stat .num{font-family:'Bodoni Moda',serif;font-size:3rem;color:var(--accent);line-height:1}
.stat .lbl{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-dim);margin-top:10px}

/* ---------- PARTNERS LOCKUP ---------- */
.lockup{display:flex;align-items:center;justify-content:center;gap:64px;flex-wrap:wrap;margin-top:46px}
.lockup .logo-ftv{height:80px}
.lockup .logo-frz{height:60px}
.lockup .x{font-family:'Bodoni Moda',serif;font-size:2rem;color:var(--accent)}

/* ---------- CONTACT ---------- */
.cform label{display:block;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim);margin:0 0 8px}
.cform input,.cform select,.cform textarea{width:100%;background:#fff;border:1px solid var(--line);color:var(--ink);padding:14px 16px;font-family:'Jost',sans-serif;font-size:.95rem;margin-bottom:20px;border-radius:2px;transition:border .3s}
.cform input:focus,.cform select:focus,.cform textarea:focus{outline:none;border-color:var(--accent)}
.cgrid{display:grid;grid-template-columns:1fr 1fr;gap:64px}
.cline{display:flex;gap:14px;margin-bottom:16px}
.cline .k{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);width:80px}

/* ---------- FOOTER ---------- */
footer{background:#fff;padding:60px 0 36px;border-top:1px solid var(--line)}
.ftop{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:26px;margin-bottom:34px}
.ftop .logo-ftv{height:52px}
.flinks{display:flex;gap:26px;flex-wrap:wrap}
.flinks a{font-size:.8rem;letter-spacing:.1em;color:var(--ink-dim);transition:color .3s}
.flinks a:hover{color:var(--accent)}
.fbottom{border-top:1px solid var(--line);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px}
.fbottom p{font-size:.76rem;color:var(--ink-dim)}

/* ---------- RESPONSIVE ---------- */
@media(max-width:980px){
  .split,.cgrid{grid-template-columns:1fr}
  .split.flip .media{order:0}
  .grid3{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .stext{padding:56px 34px}
  .reel-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:200px}
  .reel,[class^=r-]{grid-column:span 1!important;grid-row:span 1!important}
}
@media(max-width:680px){
  .wrap{padding:0 22px}.burger{display:flex}
  .menu{position:fixed;top:0;right:0;height:100vh;width:80%;max-width:320px;background:var(--paper-soft);flex-direction:column;justify-content:center;gap:28px;transform:translateX(100%);transition:transform .4s;border-left:1px solid var(--line)}
  .menu.open{transform:none}
  .hub,.grid3,.reel-grid{grid-template-columns:1fr}
  .brand .tag{display:none}
  section{padding:72px 0}
}

/* showreel tile spans */
.r-a{grid-column:span 7;grid-row:span 2}.r-b{grid-column:span 5}
.r-c{grid-column:span 5}.r-d{grid-column:span 4;grid-row:span 2}
.r-e{grid-column:span 4}.r-f{grid-column:span 4}.r-g{grid-column:span 8}
.r-h{grid-column:span 6}.r-i{grid-column:span 6}

/* ===================== LATEST STORIES (home) ===================== */
.stories-sec{background:var(--paper-soft);color:var(--ink);padding:90px 0}
.stories-sec .shead h2{color:var(--ink)}
.stories-sec .eyebrow{color:var(--accent)}
.stories{display:flex;gap:16px;overflow-x:auto;padding:4px 4px 22px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.stories::-webkit-scrollbar{height:8px}
.stories::-webkit-scrollbar-thumb{background:#cfc9bf;border-radius:8px}
.story{position:relative;flex:0 0 248px;height:360px;border-radius:8px;overflow:hidden;scroll-snap-align:start;background:#141414;cursor:pointer}
.story video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.2s ease}
.story:hover video{transform:scale(1.07)}
.story .ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.9),transparent 55%);z-index:1}
.story .badge{position:absolute;top:12px;right:12px;z-index:2;background:rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.35);color:#fff;font-size:.6rem;font-weight:600;letter-spacing:.05em;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.story .live{position:absolute;top:12px;left:12px;z-index:2;background:#e1142d;color:#fff;font-size:.62rem;font-weight:600;letter-spacing:.08em;padding:5px 9px;border-radius:3px;display:flex;align-items:center;gap:6px}
.story .live::before{content:'';width:7px;height:7px;border-radius:50%;background:#fff;animation:blink 1.4s infinite}
.story .cap{position:absolute;left:16px;right:16px;bottom:16px;z-index:2}
.story .cap h4{font-family:'Bodoni Moda',serif;font-size:1.15rem;color:#fff;line-height:1.15;font-weight:600}
.story .cap span{display:block;margin-top:6px;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.stories-hint{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim);margin-top:8px}

/* ===================== OFFER CARDS AS LINKS (clearer/visual) ===================== */
.ogrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.ocard2{display:block;position:relative;overflow:hidden;border:1px solid var(--line);background:var(--paper);min-height:430px;transition:transform .4s,box-shadow .4s,border-color .4s}
.ocard2:hover{transform:translateY(-6px);box-shadow:0 24px 50px -28px rgba(14,14,14,.4);border-color:var(--accent)}
.ocard2 .thumb{position:relative;height:230px;overflow:hidden;background:#0a0a0a}
.ocard2 .thumb video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.1s ease}
.ocard2:hover .thumb video{transform:scale(1.07)}
.ocard2 .thumb .num{position:absolute;top:16px;left:18px;z-index:2;font-family:'Bodoni Moda',serif;color:#fff;font-size:1rem;letter-spacing:.06em}
.ocard2 .body{padding:30px 28px}
.ocard2 .body h3{font-size:1.55rem;margin-bottom:12px}
.ocard2 .body p{color:var(--ink-dim);font-size:.94rem;margin-bottom:18px}
.ocard2 .go{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);font-weight:500}
@media(max-width:980px){.ogrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.ogrid{grid-template-columns:1fr}.story{flex-basis:210px;height:320px}}

/* gallery row for dedicated offer pages */
.vgallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.vgallery .g{position:relative;height:220px;overflow:hidden;border:1px solid var(--line);background:#0a0a0a}
.vgallery .g video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
@media(max-width:680px){.vgallery{grid-template-columns:1fr}}

/* row headings inside the stories section */
.srow-head{font-family:'Bodoni Moda',serif;font-size:1.5rem;color:var(--ink);margin:38px 0 18px;display:flex;align-items:center;gap:14px}
.srow-head::before{content:'';width:26px;height:1px;background:var(--accent)}

/* ===================== PRICING TIERS (offer pages) ===================== */
.pricing{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;align-items:stretch}
.tier{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);padding:36px 26px;transition:transform .35s,box-shadow .35s,border-color .35s}
.tier:hover{transform:translateY(-6px);box-shadow:0 26px 54px -30px rgba(14,14,14,.45)}
.tier.pop{border-color:var(--accent);box-shadow:0 26px 54px -30px rgba(39,66,207,.5)}
.tier .pop-tag{position:absolute;top:0;right:0;background:var(--accent);color:#fff;font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;padding:6px 12px;font-weight:600}
.tier .tname{font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);font-weight:500;margin-bottom:18px}
.tier .price{font-family:'Bodoni Moda',serif;font-size:2.5rem;line-height:1;color:var(--ink)}
.tier .price small{font-family:'Jost',sans-serif;font-size:.8rem;font-weight:400;color:var(--ink-dim);letter-spacing:.04em;margin-left:4px}
.tier .psub{font-size:.82rem;color:var(--ink-dim);margin:10px 0 22px;min-height:34px}
.tier ul{list-style:none;margin:0 0 26px;flex:1;border-top:1px solid var(--line);padding-top:22px}
.tier li{position:relative;padding-left:24px;margin-bottom:12px;font-size:.9rem;color:var(--ink)}
.tier li::before{content:'\25C6';position:absolute;left:0;top:3px;color:var(--accent);font-size:.6rem}
.tier .btn{margin-top:auto}
.price-note{text-align:center;font-size:.82rem;color:var(--ink-dim);margin-top:34px;max-width:760px;margin-left:auto;margin-right:auto}
@media(max-width:1080px){.pricing{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.pricing{grid-template-columns:1fr}}
