/* ===========================
   👉  css/style.css  👈
   MOBILE‑FRIENDLY FULL CSS
   Palette refresh · 19 July 2025
   =========================== */

/*****  0. Base & Tokens  *****/
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}

:root{
  /* refreshed palette */
  --clr-accent:#F05C4E;           /* rich coral‑red  */
  --clr-accent-2:#FFC857;         /* warm amber      */
  --clr-bg:#121214;               /* deep charcoal   */
  --clr-text:#FFFFFF;
  --clr-muted:#B7B7BB;            /* softer neutral  */
  --clr-bg-light:rgba(18,18,20,.95);
  --spacing:4rem;
  --container-max:1200px;
}
body{font-family:'Inter',sans-serif;line-height:1.6;background:var(--clr-bg);color:var(--clr-text)}

/*****  1. Typography  *****/
.lead{font-size:1rem;color:var(--clr-muted);margin-bottom:1.5rem}
.text-center{text-align:center}.fw-bold{font-weight:600}

h1{font-family:'Bebas Neue',cursive;font-size:clamp(3rem,8vw,6.5rem);line-height:1.1;margin-bottom:1rem}
h2.section-heading{font-family:'Bebas Neue',cursive;font-size:clamp(2.5rem,6vw,4.5rem);letter-spacing:.05em;margin-bottom:2rem}
h3{font-size:clamp(1.5rem,4vw,2rem);margin-bottom:1rem}

/*****  2. Layout helpers  *****/
section{padding:var(--spacing) 0}
.container{width:90%;max-width:var(--container-max);margin-inline:auto}

/*****  3. Navigation  *****/
.nav{position:fixed;top:0;width:100%;z-index:1000;transition:background .3s ease,padding-block .3s ease;background:transparent;padding-block:clamp(1rem,2vh+.5rem,2.5rem)}
.nav--scrolled{background:rgba(0,0,0,.8);backdrop-filter:blur(8px)}
.nav--shrink{padding-block:clamp(.25rem,.6vh,.75rem);background:rgba(0,0,0,.8)}

.nav__inner{display:flex;align-items:center;justify-content:space-between;height:auto;padding-inline:1rem}
.nav__brand img{height:50px;margin-top:clamp(.25rem,.8vh,.75rem);filter:drop-shadow(0 0 12px rgba(240,92,78,.8));transition:height .3s ease,margin-top .3s ease}
.nav--shrink .nav__brand img{height:36px;margin-top:0}

.nav__toggle-checkbox{display:none}
.nav__toggle-label{display:flex;cursor:pointer;width:48px;height:48px;flex-direction:column;justify-content:space-around}
.nav__toggle-label span,
.nav__toggle-label span::before,
.nav__toggle-label span::after{content:"";display:block;height:3px;background:#fff;border-radius:3px}

.nav__links{display:none}
@media(min-width:768px){
  .nav__toggle-label{display:none}
  .nav__links{display:flex;gap:1.5rem;font-size:.85rem;text-transform:uppercase;align-items:center}
}
.nav__links a{color:var(--clr-text);text-decoration:none;position:relative;font-weight:500;font-size:.85rem;letter-spacing:.06em}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-5px;height:2px;width:0;background:var(--clr-accent);transition:width .3s ease}
.nav__links a:hover::after,
.nav__links a[aria-current="page"]::after{width:100%}
.nav__links a[aria-current="page"]{color:var(--clr-accent)}

@media(max-width:767px){
  .nav__links{
    position:fixed;inset:0;top:64px;flex-direction:column;align-items:center;
    background:rgba(0,0,0,.95);padding-top:1rem;display:none
  }
  .nav__toggle-checkbox:checked + .nav__toggle-label + .nav__links{display:flex}
}

/*****  4. Hero  *****/
.hero{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;text-align:center;padding:0;overflow:hidden}
.hero__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;pointer-events:none}
.hero__overlay--gradient{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.85) 100%)}
.hero__overlay--grain{position:absolute;inset:0;z-index:1}
.hero__content{position:relative;z-index:2;padding-inline:1rem}

/*****  5. Buttons  *****/
.btn{display:inline-block;border:none;border-radius:50px;text-decoration:none;font-weight:600;transition:background .2s ease,color .2s ease;box-shadow:0 2px 6px rgba(0,0,0,.25)}
.btn:active{transform:translateY(2px)}
.btn--large{padding:1rem 2rem;font-size:1rem}

.btn--accent{background:var(--clr-accent);color:#FFF}
.btn--accent:hover{background:var(--clr-accent-2);color:#000}

.btn--outline{background:transparent;border:2px solid var(--clr-accent);color:var(--clr-accent)}
.btn--outline:hover{background:var(--clr-accent-2);border-color:var(--clr-accent-2);color:#000}

/*****  6. Featured & Case‑studies  *****/
.featured-work__wrap{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding-inline:1rem}
.featured-work__media img{width:100%;border-radius:8px}
.featured-work__content{max-width:100%}

@media(min-width:768px){
  .featured-work__wrap:nth-of-type(even){flex-direction:row-reverse}
  .featured-work__media{flex:1;max-width:600px}
  .featured-work__content{flex:1}
}

/* DIFF highlight block */
.case-study--highlight{background:rgba(240,92,78,.15);padding-block:2.5rem}
.case-study--highlight .section-heading{font-size:clamp(1.8rem,5vw,3rem);color:var(--clr-accent);margin-bottom:1.25rem}
.case-study--highlight .featured-work__content h3{font-size:1.35rem;margin-bottom:.5rem}
.case-study--highlight .featured-work__content .lead{font-size:.95rem;line-height:1.55;color:var(--clr-text)}
.diff-img{width:100%;max-width:420px;margin-inline:auto;border-radius:8px}

/*****  7. Showreel  *****/
.showreel__video{max-width:800px;margin-inline:auto}
.showreel__video iframe{width:100%;aspect-ratio:16/9;border:none;border-radius:8px}

/*****  8. Clients  *****/
.clients__grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));
  gap:1.5rem;align-items:center;justify-items:center;padding-inline:1rem
}
.clients__item img{max-height:80px;filter:grayscale(100%) opacity(.7);transition:filter .3s ease}
.clients__item img:hover{filter:grayscale(0) opacity(1) drop-shadow(0 0 6px var(--clr-accent-2))}
@media(min-width:992px){.clients__grid{grid-template-columns:repeat(4,1fr)}}

/*****  9. CTA band  *****/
.cta-section{background:var(--clr-bg-light);padding-block:2rem;text-align:center}
.cta-text{font-family:'Bebas Neue',cursive;font-size:clamp(1.8rem,5vw,3rem);line-height:1.2;color:var(--clr-accent-2);margin-bottom:1.5rem}
.cta-section .btn--accent{background:var(--clr-accent-2);color:#000}

/***** 10. WhatsApp bubble  *****/
.wa-bubble{position:fixed;bottom:1rem;right:1rem;z-index:1200;width:56px;height:56px;border-radius:50%;background:#25D366;color:#fff;display:grid;place-items:center;box-shadow:0 4px 12px rgba(0,0,0,.35);transition:transform .25s ease}
.wa-bubble:hover{transform:scale(1.08)}
.wa-bubble i{font-size:24px;line-height:1}

/***** 11. Accessibility & motion  *****/
:where(a,button).btn:focus-visible,
.nav__links a:focus-visible{outline:2px solid var(--clr-accent);outline-offset:2px}
@media(prefers-reduced-motion:reduce){
  .hero__bg{animation:none!important;filter:brightness(.8)}
}

/***** 12. Footer  *****/
.footer{padding-block:1.5rem;background:#000;color:var(--clr-muted);text-align:center;font-size:.875rem}

/* ————— Hero reel ————— */
.video-hero{position:relative;padding-block:3rem 2rem;background:var(--clr-bg);}
.reel-wrapper{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.4);}
.reel-wrapper iframe{position:absolute;inset:0;width:100%;height:100%;}
.video-heading{text-align:center;font-family:'Bebas Neue',cursive;font-size:clamp(2.2rem,6vw,4rem);margin-top:1.25rem;color:var(--clr-accent-2);}

/* ————— Grid ————— */
.video-grid{background:var(--clr-bg);}
.grid-wrap{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));}
.video-card{position:relative;overflow:hidden;border-radius:8px;cursor:pointer;}
.video-card img{width:100%;aspect-ratio:16/9;object-fit:cover;transition:transform .4s ease;}
.video-card:hover img{transform:scale(1.05);}
.card-meta{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.75) 95%);display:flex;flex-direction:column;justify-content:flex-end;padding:1rem;color:#fff;}
.card-title{font-size:1.1rem;margin:0;}
.card-type{font-size:.85rem;margin:0;opacity:.8;}
.video-card iframe{width:100%;aspect-ratio:16/9;border:none;border-radius:8px;}

/* ————— minor tweaks ————— */
@media(prefers-reduced-motion:reduce){.video-card img{transition:none}}

/* ——— Hero ——— */
.video-hero{padding-block:3rem 2rem;background:var(--clr-bg);}
.reel-wrapper{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.4);}
.reel-wrapper iframe{position:absolute;inset:0;width:100%;height:100%;}
.video-heading{text-align:center;font-family:'Bebas Neue',cursive;font-size:clamp(2.2rem,6vw,4rem);margin-top:1.25rem;color:var(--clr-accent-2);}

/* ——— Filter bar ——— */
.filter-bar{display:flex;gap:.75rem;padding-block:1.5rem 0;}
.filter-btn{padding:.5rem 1rem;border:2px solid var(--clr-accent);background:transparent;color:var(--clr-accent);border-radius:30px;font-size:.85rem;cursor:pointer;transition:.2s;}
.filter-btn.active,.filter-btn:hover{background:var(--clr-accent);color:#000;border-color:var(--clr-accent);}
@media(max-width:480px){.filter-bar{flex-wrap:wrap;}}

/* ——— Grid ——— */
.video-grid{background:var(--clr-bg);}
.grid-wrap{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));}
.video-card{position:relative;overflow:hidden;border-radius:8px;}
.video-card img{width:100%;aspect-ratio:16/9;object-fit:cover;transition:transform .4s ease;}
.video-card:hover img{transform:scale(1.04);}
.play-icon{position:absolute;inset:0;display:grid;place-items:center;font-size:2.5rem;color:#fff;opacity:0;transition:.3s;}
.video-card:hover .play-icon{opacity:.9;background:rgba(0,0,0,.35);}
.card-meta{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.75) 95%);display:flex;flex-direction:column;justify-content:flex-end;padding:1rem;color:#fff;}
.card-meta h3{font-size:1.1rem;margin:0;}
.card-meta p{font-size:.8rem;margin:0;opacity:.8;}
.video-card iframe{width:100%;aspect-ratio:16/9;border:none;border-radius:8px;}

/* ——— Testimonials ——— */
.micro-testimonials{background:var(--clr-bg-light);padding-block:1.75rem;}
.micro-testimonials blockquote{margin:0 0 1rem;font-size:.95rem;color:var(--clr-muted);font-style:italic;}
.micro-testimonials cite{font-style:normal;color:var(--clr-accent-2);}

/* ——— Sticky CTA ——— */
.sticky-cta{position:fixed;bottom:1rem;left:50%;transform:translateX(-50%) scale(.9);background:var(--clr-accent);color:#000;padding:.75rem 1.25rem;border-radius:40px;font-weight:600;box-shadow:0 4px 10px rgba(0,0,0,.3);transition:.3s;opacity:0;pointer-events:none;z-index:1200;}
.sticky-cta.show{opacity:1;pointer-events:auto;transform:translateX(-50%) scale(1);}

.video-hero{
  padding-block: calc(var(--nav-h) + 1.5rem) 2rem;   /* pushes video down */
}

@media (max-width:600px){
  .video-hero{padding-block:calc(var(--nav-h) + 1rem) 1.5rem;}
}



/* ─────────────────────────────────────────────
   QUICK PATCH  •  fixes hero overlap + duplicates
   place at very end of style.css
────────────────────────────────────────────── */
:root{
  /* nav height token (used by hero padding) */
  --nav-h: 72px;
}

/* ensure hero pushes down below fixed nav */
.video-hero{
  padding-block: calc(var(--nav-h) + 1.5rem) 2rem;
}
@media(max-width:600px){
  .video-hero{padding-block:calc(var(--nav-h) + 1rem) 1.5rem;}
}

/* clean‑up: if earlier duplicates exist, this wins */
.video-hero .reel-wrapper{aspect-ratio:16/9;}
.video-grid .grid-wrap{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));}

/*  more obvious “tap for sound”  */
.reel-wrapper::after{
  content:"🔊  Tap for sound";
  position:absolute;
  left:50%; bottom:1.25rem;        /* centred near bottom */
  transform:translateX(-50%);
  font-size:.9rem; font-weight:600;
  padding:.4rem .9rem;
  border-radius:28px;
  background:rgba(0,0,0,.75);
  color:#fff;
  pointer-events:none;
  opacity:.92;
  animation:pulse 3s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{opacity:.92;}
  50%   {opacity:.55;}
}

/* ─── Case‑study teaser band ───────────────────── */
.case-teasers{background:var(--clr-bg-light);padding-block:3rem 2rem;}
.case-teasers .teaser{
  display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2.5rem;
}
.case-teasers .teaser img{
  width:100%;max-width:560px;border-radius:8px;object-fit:cover;flex:1;
}
.case-teasers .teaser-content{flex:1;display:flex;flex-direction:column;justify-content:center}
.case-teasers h3{font-size:clamp(1.6rem,4vw,2.2rem);margin-bottom:.75rem;color:var(--clr-accent);}
.case-teasers p{font-size:.95rem;color:var(--clr-text);margin-bottom:1.25rem;line-height:1.55}
.case-teasers .btn{align-self:flex-start;}

@media(min-width:768px){
  .case-teasers .teaser{flex-direction:row;align-items:center;}
  .case-teasers .teaser.reverse{flex-direction:row-reverse;}
}

/* ─── Feature Documentary block ───────────────── */
.feature-doc{background:var(--clr-bg);padding-block:3rem 2rem;}
.feature-doc .container{display:flex;flex-direction:column;gap:2rem;}
.doc-thumb{position:relative;flex:1;max-width:720px;margin-inline:auto;}
.doc-thumb img{width:100%;border-radius:8px;object-fit:cover;box-shadow:0 4px 16px rgba(0,0,0,.35);}
.doc-thumb .play-icon{
  position:absolute;inset:0;display:grid;place-items:center;
  font-size:3rem;color:#fff;background:rgba(0,0,0,.35);border-radius:8px;
  opacity:0;transition:.3s;
}
.doc-thumb:hover .play-icon{opacity:1;}

.doc-copy{flex:1;max-width:720px;margin-inline:auto;text-align:center;}
.doc-copy h3{font-size:clamp(1.6rem,4vw,2.3rem);margin-bottom:.75rem;color:var(--clr-accent);}
.doc-copy p{font-size:1rem;color:var(--clr-text);margin-bottom:1.5rem;line-height:1.55;}

@media(min-width:768px){
  .feature-doc .container{flex-direction:row;align-items:center;}
  .doc-copy{text-align:left;}
  .doc-copy h2.section-heading{text-align:left;}
}

/* ─── Section background tints ───────────────── */
.bg-tint-red   { background:rgba(240,92,78,.07); }  /* light coral wash  */
.bg-tint-amber { background:rgba(255,200,87,.06); } /* warm amber wash   */

/* keep section spacing consistent */
.bg-tint-red,
.bg-tint-amber { padding-block:var(--spacing); }




.divider{
  height:4px;
  background:linear-gradient(90deg,var(--clr-accent) 0%,var(--clr-accent-2) 100%);
  border-radius:2px;
}

/* extra gap below the showreel */
.video-heading{
  margin-top:2.25rem;   /* was 1.25rem */
}

/* ── One‑off DIFF teaser sizing ─────────────────────────────────────────── */
.teaser--diff {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 2rem;
  margin-bottom: 4rem;
}

/* DEBUG: force DIFF teaser image very small so you can confirm it’s working */
.teaser--diff img {
  max-width: 150px !important;
  width: 100% !important;
  height: auto !important;
}


.teaser--diff .teaser-content {
  flex: 1 1 100%;
}

@media (min-width: 768px) {
  .teaser--diff img {
    flex: 0 0 40%;
  }
  .teaser--diff .teaser-content {
    flex: 0 0 55%;
  }
}

/* Center DIFF teaser image + copy */
.teaser--diff {
  justify-content: center;   /* horizontally center flex items */
  text-align: left;        /* center the text inside the container */
}

.teaser--diff .teaser-content {
  text-align: left;        /* ensure the headings & paragraphs are centered */
}

/* ── Prevent play-icon from intercepting clicks ── */
.play-icon {
  pointer-events: none;
}

/* ───────── Contact page overrides ───────── */
.contact-hero{
  padding-block:calc(var(--nav-h) + 3rem) 2rem;
  text-align:center;
  background:linear-gradient(135deg,var(--clr-accent) 0%,var(--clr-accent-2) 100%);
}
.contact-hero h1{
  font-family:'Bebas Neue',cursive;
  font-size:clamp(2.8rem,6vw,4.5rem);
  margin:0;
  color:#000;
}
.contact-hero .lead{color:#000;font-size:1.1rem;margin-top:.5rem;}

.contact-section{padding-block:3rem 4rem;background:var(--clr-bg-light);}
.contact-form{
  display:flex;flex-direction:column;gap:1.75rem;
}
.form-row{
  display:flex;flex-wrap:wrap;gap:1.75rem;
}
.form-row .form-group{flex:1 1 240px;}
.form-group{display:flex;flex-direction:column;gap:.5rem;}
.form-group label{font-size:.9rem;font-weight:600;letter-spacing:.04em;color:var(--clr-text);}
.form-group input,
.form-group select,
.form-group textarea{
  background:#1d1d21;border:2px solid #2b2b30;border-radius:6px;
  padding:.75rem 1rem;font-size:.95rem;color:#fff;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  outline:none;border-color:var(--clr-accent);
}
.form-group textarea{resize:vertical;min-height:180px;}

.form-submit{align-self:flex-start;}

.form-feedback{
  margin-top:1rem;font-size:.9rem;font-weight:600;padding:.75rem 1rem;border-radius:6px;
}
.form-feedback.success{background:rgba(0,255,120,.15);color:#00d464;}
.form-feedback.error  {background:rgba(255,90,90,.18);color:#ff6b6b;}

.alt-contact{margin-top:2.5rem;font-size:.95rem;color:var(--clr-muted);}
.alt-contact a{color:var(--clr-accent);text-decoration:none;}
.alt-contact a:hover{text-decoration:underline;}

/* ─────────────────────────────────────────────
   ONE‑OFF LAYOUT • DIFF highlight on home page
   (forces 2‑column at ≥768 px, stacks on mobile)
───────────────────────────────────────────────*/

.case-study--highlight .featured-work__wrap{
  flex-direction:row;       /* image + copy side‑by‑side        */
  gap:2rem;
  align-items:center;
}

.case-study--highlight .featured-work__media{
  flex:0 0 40%;             /* image ~40 % of row               */
  max-width:300px;          /* override your global 600px cap   */
}

.case-study--highlight .featured-work__content{
  flex:1 1 55%;             /* text gets remaining width        */
}

/* keep it stacked when screen < 768 px */
@media (max-width:767px){
  .case-study--highlight .featured-work__wrap{
    flex-direction:column;
  }
}









