/* ===========================================
   Mad Tabby Films — Shared Stylesheet
   Linked from: index.html, narrative.html,
                commercial.html, voice-over.html
   =========================================== */

/* RESET & BASE */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --red:#c41e1e;
  --red-hover:#e63636;
  --dark:#0a0a0a;
  --card:#141414;
  --gray:#888;
  --light:#e8e8e8;
}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',sans-serif;
  background:var(--dark);
  color:var(--light);
  line-height:1.6;
}
h1,h2,h3,h4{
  font-family:'Montserrat',sans-serif;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.02em;
}
a{color:var(--red);text-decoration:none}
a:hover{color:var(--red-hover)}
.container{max-width:1100px;margin:0 auto;padding:0 24px}
section{padding:100px 0}
section[id]{scroll-margin-top:80px}

/* NAV */
nav{
  position:fixed;
  top:0;
  width:100%;
  z-index:100;
  background:rgba(10,10,10,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid #1a1a1a;
}
nav .container{
  display:flex;
  justify-content:space-between;
  align-items:center;
  height:64px;
}
nav .logo{
  font-family:'Montserrat',sans-serif;
  font-weight:900;
  font-size:1.1rem;
  color:#fff;
  letter-spacing:.08em;
}
nav .logo span{color:var(--red)}
nav ul{list-style:none;display:flex;gap:28px}
nav ul a{
  color:var(--gray);
  font-size:.85rem;
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:.06em;
  transition:color .2s;
}
nav ul a:hover{color:#fff}
.menu-toggle{
  display:none;
  background:none;
  border:none;
  color:#fff;
  font-size:1.4rem;
  cursor:pointer;
}

/* HERO (home page only) */
#home{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  background:linear-gradient(160deg,#0a0a0a 0%,#1a0a0a 40%,#0a0a0a 100%);
  position:relative;
  overflow:hidden;
}
#home::before{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse at 50% 40%,rgba(196,30,30,.12) 0%,transparent 70%);
}
.hero-content{
  position:relative;
  z-index:1;
  padding:0 24px;
  max-width:840px;
}
.hero-logo-wrap{
  margin:0 auto 32px;
  line-height:0;
  font-size:0;
}
.hero-logo{
  max-width:min(620px,90vw);
  width:100%;
  height:auto;
  display:block;
  margin:0 auto;
}
.hero-content p.tagline{
  font-size:clamp(1.05rem,2.5vw,1.4rem);
  color:#bbb;
  font-weight:300;
  margin-bottom:40px;
  letter-spacing:.04em;
}

/* CTA BUTTON (used on hero + sub-page CTAs) */
.cta{
  display:inline-block;
  padding:14px 36px;
  border:2px solid var(--red);
  color:#fff;
  font-weight:600;
  font-size:.9rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  transition:all .25s;
}
.cta:hover{background:var(--red);color:#fff}

/* SECTION HEADERS */
.section-title{
  font-size:clamp(1.6rem,4vw,2.4rem);
  margin-bottom:12px;
  color:#fff;
}
.section-title span{color:var(--red)}
.section-sub{
  color:var(--gray);
  font-size:1rem;
  margin-bottom:48px;
  max-width:600px;
}
.divider{
  width:60px;
  height:3px;
  background:var(--red);
  margin:16px 0 24px;
}

/* WHAT WE DO — clickable cards linking to sub-pages */
.work-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:24px;
  margin-top:8px;
}
.work-card{
  background:var(--card);
  border:1px solid #222;
  border-radius:8px;
  padding:36px 28px;
  display:block;
  color:inherit;
  transition:border-color .3s,transform .3s;
  position:relative;
}
.work-card:hover{
  border-color:var(--red);
  transform:translateY(-4px);
  color:inherit;
}
.work-card i{
  font-size:1.6rem;
  color:var(--red);
  margin-bottom:18px;
  display:block;
}
.work-card h3{
  font-size:1rem;
  color:#fff;
  margin-bottom:10px;
  text-transform:none;
  font-weight:700;
}
.work-card p{
  font-size:.88rem;
  color:var(--gray);
  margin-bottom:20px;
  line-height:1.6;
}
.work-card .arrow{
  font-size:.78rem;
  color:var(--red);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.08em;
}

/* ABOUT */
.about-intro{
  font-size:1.05rem;
  color:#ccc;
  max-width:720px;
  margin-bottom:56px;
  line-height:1.8;
}
.bios{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  gap:36px;
}
.bio{
  background:var(--card);
  border:1px solid #222;
  border-radius:8px;
  padding:36px;
  position:relative;
  overflow:hidden;
}
.bio::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:3px;
  background:var(--red);
}
.bio h3{
  font-size:1.1rem;
  color:#fff;
  margin-bottom:4px;
}
.bio .role{
  color:var(--red);
  font-size:.82rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.05em;
  margin-bottom:16px;
  display:block;
}
.bio p{
  font-size:.9rem;
  color:#aaa;
  line-height:1.7;
}
.bio-link{margin-top:14px}
.bio-link a{
  font-size:.78rem;
  color:var(--red);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.bio-link a:hover{color:var(--red-hover)}
/* Bio headshot placeholder — Replace with actual headshots */
.bio-photo{
  float:right;
  width:100px;
  height:100px;
  background:#222;
  border:1px solid #333;
  border-radius:6px;
  margin:0 0 12px 16px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#555;
  font-family:'Montserrat',sans-serif;
  font-weight:700;
  font-size:1.4rem;
  flex-shrink:0;
}

/* SERVICES — free-form, center-justified, no cards */
.services-list{
  text-align:center;
  max-width:840px;
  margin:8px auto 0;
  line-height:2.6;
}
.services-list .service{
  display:inline-block;
  margin:0 18px;
  font-size:.95rem;
  color:#ddd;
  font-weight:500;
  white-space:nowrap;
}
.services-list .service i{
  color:var(--red);
  margin-right:8px;
  font-size:.95rem;
}
.callout{
  background:linear-gradient(135deg,#1a0a0a,var(--card));
  border:1px solid #331111;
  border-left:4px solid var(--red);
  border-radius:8px;
  padding:32px 36px;
  font-size:1.05rem;
  color:#ccc;
  font-style:italic;
  line-height:1.7;
  margin-top:56px;
}

/* CONTACT */
.contact-wrap{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:start;
}
.contact-form input,
.contact-form textarea{
  width:100%;
  padding:14px 16px;
  background:#111;
  border:1px solid #222;
  border-radius:6px;
  color:#fff;
  font-family:'Inter',sans-serif;
  font-size:.9rem;
  margin-bottom:16px;
  transition:border-color .2s;
}
.contact-form input:focus,
.contact-form textarea:focus{
  outline:none;
  border-color:var(--red);
}
.contact-form textarea{
  height:140px;
  resize:vertical;
}
.contact-form button{
  padding:14px 36px;
  background:var(--red);
  color:#fff;
  border:none;
  border-radius:6px;
  font-family:'Montserrat',sans-serif;
  font-weight:700;
  font-size:.9rem;
  text-transform:uppercase;
  letter-spacing:.06em;
  cursor:pointer;
  transition:background .2s;
}
.contact-form button:hover{background:#a01818}
.contact-info h3{
  font-size:1.1rem;
  color:#fff;
  margin-bottom:16px;
}
.contact-info p{
  color:var(--gray);
  font-size:.92rem;
  margin-bottom:24px;
}
.contact-info a.email{
  font-size:1rem;
  color:var(--red);
  font-weight:600;
}
.honeypot{position:absolute;left:-9999px}

/* SOCIAL ICONS */
.social-links{margin-top:32px}
.social-links a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  border:1px solid #333;
  border-radius:50%;
  color:var(--gray);
  font-size:1.1rem;
  margin-right:12px;
  transition:all .2s;
}
.social-links a:hover{
  border-color:var(--red);
  color:var(--red);
}

/* FOOTER */
footer{
  border-top:1px solid #1a1a1a;
  padding:36px 0;
  text-align:center;
}
footer p{color:#555;font-size:.82rem}
footer .social-links{margin-top:16px}
footer .social-links a{
  width:36px;
  height:36px;
  font-size:.9rem;
}

/* ============================================
   SUB-PAGE STYLES (narrative, commercial, voice-over)
   ============================================ */
body.subpage{padding-top:64px}

.subpage-hero{
  padding:80px 0 60px;
  text-align:center;
  background:linear-gradient(160deg,#0a0a0a 0%,#1a0a0a 60%,#0a0a0a 100%);
  border-bottom:1px solid #1a1a1a;
  position:relative;
  overflow:hidden;
}
.subpage-hero::before{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse at 50% 30%,rgba(196,30,30,.08) 0%,transparent 70%);
}
.subpage-hero > .container{position:relative;z-index:1}
.subpage-hero h1{
  font-size:clamp(2rem,5vw,3.2rem);
  color:#fff;
  margin-bottom:20px;
  letter-spacing:.04em;
}
.subpage-hero h1 span{color:var(--red)}
.subpage-hero p.intro{
  font-size:1.05rem;
  color:#bbb;
  max-width:720px;
  margin:0 auto;
  line-height:1.8;
  font-weight:300;
}

/* REEL EMBED SLOT */
.reel-wrap{
  margin:0 auto;
  max-width:1000px;
  padding:0 24px;
}
.reel-frame{
  position:relative;
  aspect-ratio:16/9;
  background:#0e0e0e;
  border:1px solid #222;
  border-radius:8px;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
}
.reel-frame .placeholder{
  color:#555;
  font-family:'Montserrat',sans-serif;
  font-weight:700;
  font-size:1rem;
  text-transform:uppercase;
  letter-spacing:.1em;
  text-align:center;
  padding:24px;
  line-height:1.6;
}
.reel-frame .placeholder small{
  display:block;
  margin-top:10px;
  font-size:.7rem;
  color:#444;
  letter-spacing:.06em;
  text-transform:none;
  font-weight:400;
}
.reel-frame iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
}
.reel-caption{
  text-align:center;
  color:var(--gray);
  font-size:.85rem;
  margin-top:14px;
  text-transform:uppercase;
  letter-spacing:.08em;
}

/* BTS GALLERY */
.bts-section{padding:40px 0 80px}
.bts-section h2.section-title{
  text-align:center;
  font-size:1.4rem;
}
.bts-section .divider{margin:8px auto 36px}
.bts-gallery{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:12px;
  max-width:1100px;
  margin:0 auto;
  padding:0 24px;
}
.bts-tile{
  aspect-ratio:1/1;
  background:linear-gradient(135deg,#1a1a1a,#111);
  border-radius:6px;
  border:1px solid #1a1a1a;
  overflow:hidden;
  position:relative;
}
.bts-tile img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.bts-tile.placeholder{
  display:flex;
  align-items:center;
  justify-content:center;
  color:#3a3a3a;
  font-family:'Montserrat',sans-serif;
  font-weight:700;
  font-size:.74rem;
  text-transform:uppercase;
  letter-spacing:.1em;
}
.bts-tile.wide{
  aspect-ratio:2/1;
  grid-column:span 2;
}

/* PROJECT CREDITS ROW */
.project-credits{
  text-align:center;
  margin-top:56px;
  padding:0 24px;
}
.project-credits .label{
  display:block;
  color:#555;
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.16em;
  font-weight:600;
  margin-bottom:10px;
}
.project-credits .list{
  font-style:italic;
  color:#aaa;
  line-height:1.8;
  font-size:.95rem;
}

/* SUB-PAGE FOOTER CTA */
.subpage-cta{
  text-align:center;
  padding:80px 24px;
  border-top:1px solid #1a1a1a;
  background:#0c0c0c;
}
.subpage-cta h2{
  font-size:clamp(1.4rem,3vw,2rem);
  color:#fff;
  margin-bottom:14px;
}
.subpage-cta h2 span{color:var(--red)}
.subpage-cta p{
  color:var(--gray);
  margin-bottom:32px;
  max-width:560px;
  margin-left:auto;
  margin-right:auto;
  line-height:1.7;
}

/* RESPONSIVE */
@media(max-width:768px){
  nav ul{
    display:none;
    position:absolute;
    top:64px;
    left:0;
    width:100%;
    background:rgba(10,10,10,.98);
    flex-direction:column;
    padding:24px;
    gap:20px;
    border-bottom:1px solid #222;
  }
  nav ul.open{display:flex}
  .menu-toggle{display:block}
  .contact-wrap{grid-template-columns:1fr}
  section{padding:72px 0}
  .services-list{line-height:2.4}
  .services-list .service{display:block;margin:6px 0}
  .bts-tile.wide{grid-column:span 1;aspect-ratio:1/1}
}
