@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&display=swap');

:root{
  --bg:#0b0b0b;
  --paper:#fff;
  --muted:#9b9b9b;
  --accent:#ffffff;
  --max-width:1100px;
  --gap:28px;
  --brand-font: 'Bebas Neue', 'Helvetica Neue', Arial, sans-serif;
}

*{box-sizing:border-box}
html,body{height:100%;margin:0;background:var(--bg);color:var(--accent);font-family:var(--brand-font);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}
a{color:inherit;text-decoration:none}

.container{max-width:var(--max-width);margin:0 auto;padding:48px 20px; position: relative; z-index: 1;}

/* Header */
.header{display:flex;align-items:flex-start;gap:20px;padding:40px 0;}
.brand{font-weight:800;letter-spacing:1px;font-size:28px}
.tag{color:var(--muted);font-size:13px;margin-top:6px}

/* Navigation */
.nav{margin-left:auto;display:flex;gap:18px;align-items:center}
.nav a{font-size:14px;color:var(--muted);padding:6px 8px;border-radius:3px}
.nav a.active{color:var(--accent);font-weight:700}

/* Masthead section */
.mast {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  align-items: stretch;
  margin-top: 20px;
  background: rgba(0, 0, 0, 0.8);
  border-radius: 24px;
  padding: 28px;
}

.mast-left{
  background: transparent;
  padding: 20px;
  border: none;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.mast-left h1{
  font-size:72px;
  line-height:0.95;
  margin:0 0 12px;
  letter-spacing:2px;
}
.mast-left .meta{
  color:var(--muted);
  margin-bottom:20px;
  text-align: center;
}
.mast-right{
  display: flex;
  align-items: stretch;
  background: #000000;
  border-radius: 16px;
  overflow: hidden;
}
.hero-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(100%);
  transition: filter 0.5s ease;
  border-radius: 16px;
}

.btn{display:inline-block;padding:12px 20px;border:1px solid #fff;color:#fff;border-radius:4px;font-weight:700}
.btn.ghost{background:transparent}


/* Portfolio cards */
.card{background:#0d0d0d;border:1px solid rgba(255,255,255,0.04);overflow:hidden}
.card img{width:100%;height:220px;object-fit:cover;display:block}

/* Two-column editorial section */
.row{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);margin-top:40px}
.col-left{background:#0d0d0d;padding:28px;border:1px solid rgba(255,255,255,0.04)}
.col-right{background:var(--paper);color:#000;padding:28px}

/* Projects list (work page) */
.project{display:grid;grid-template-columns:45% 1fr;gap:24px;margin-bottom:30px}
.project:nth-child(even){grid-template-columns:1fr 45%}
.project .thumb{background:#111;border:1px solid rgba(255,255,255,0.04)}

/* Contact card */
.contact-card{
  background: rgba(0, 0, 0, 0.8);
  color: #ffffff;
  padding: 28px;
  border-radius: 24px;
}
.contact-card * {
  color: #ffffff !important;
}
.contact-card a {
  text-decoration: underline;
}
.contact-card img {
  filter: invert(1);
}


/* Footer */
.footer{border-top:1px solid rgba(255,255,255,0.04);padding:28px 0;margin-top:48px;color:var(--muted);display:flex;justify-content:space-between;align-items:center}

/* Responsive */
@media (max-width:900px){
  .mast{grid-template-columns:1fr; }
  .mast-left h1{font-size:44px}
  .mast-right{grid-auto-rows: 350px;}
  main > div[style*="display:grid"] { grid-template-columns: 1fr !important; gap: 28px !important; }
  .row{grid-template-columns:1fr}
  .project{grid-template-columns:1fr}
}


h1,h2,h3,h4,.brand {
  font-family: 'Bebas Neue', 'Helvetica Neue', Arial, sans-serif;
  letter-spacing: 1px;
}
body, p, li, a, .tag {
  font-family: 'Helvetica Neue', Arial, sans-serif;
}


/* Hover Effects */
.nav a:hover {
  color: #fff;
  text-decoration: underline;
}

.btn:hover {
  background:#fff;
  color:#000;
  transition: all 0.3s ease;
}

.card img:hover, .thumb img:hover {
  transform: scale(1.05);
  transition: transform 0.3s ease;
}

a:hover {
  opacity:0.85;
}


/* Fade-in animation */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}
.fade-in {
  opacity: 0;
  animation: fadeInUp 0.8s ease forwards;
}
.fade-in.delay1 { animation-delay: 0.2s; }
.fade-in.delay2 { animation-delay: 0.4s; }
.fade-in.delay3 { animation-delay: 0.6s; }

.hero-img:hover {
  filter: grayscale(0%);
}

.trusted-logos {
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  gap:40px;
}
.trusted-logo {
  width:160px;
  height:100px;
  object-fit:contain;
  filter: grayscale(100%);
  transition: filter 0.5s ease, transform 0.5s ease;
  opacity:0;
}
.trusted-logo:hover {
  filter: grayscale(0%);
  transform: scale(1.08);
}
.standalone-block img {
  filter: grayscale(100%);
  transition: filter 0.5s ease, transform 0.5s ease;
}
.standalone-block img:hover {
  filter: grayscale(0%);
  transform: scale(1.02);
}


.delay-0 { animation-delay: 0.2s !important; }
.delay-1 { animation-delay: 0.6s !important; }
.delay-2 { animation-delay: 1.0s !important; }

/* --- About section --- */
.about h2 { text-align: center; margin-bottom: 20px; }
.about p { text-align: center; font-style: italic; max-width: 800px; margin: 0 auto; }


/* --- Standalone + Contact section --- */
.standalone-contact {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  margin: 60px auto;
  max-width: var(--max-width);
  padding: 28px;
  background: rgba(0, 0, 0, 0.8);
  border-radius: 24px;
  align-items: stretch;
}

.standalone-block {
  background: #000000;
  border-radius: 16px;
  overflow: hidden;
  display: flex;
}
.standalone-block img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 16px;
}

.contact-block {
  background: transparent;
  padding: 20px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.contact-block h1 {
  font-size: 32px;
  margin-bottom: 20px;
  color: #ffffff;
}
.contact-block p {
  color: #ffffff;
}
.contact-block a {
  color: #ffffff;
  text-decoration: underline;
}


@media (max-width: 900px) {
  .standalone-contact {
    grid-template-columns: 1fr;
    height: auto;
  }
  .standalone-block, .contact-block {
    height: auto;
  }
  .standalone-block {
    height: 400px;
  }
}

.about { border: 0 !important; }
.standalone-contact { margin-bottom: 80px !important; }


/* Worked With section */
.worked-with {
  text-align: center;
  margin: 60px auto;
}

.logo-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 40px;
  align-items: center;
  justify-items: center;
  margin-top: 30px;
}

.logo-grid a {
  display: block;
  line-height: 0;
}

.logo-grid img {
  max-height: 150px;
  width: auto;
  filter: grayscale(100%) !important;
  transition: transform 0.3s ease, filter 0.3s ease !important;
  object-fit: contain;
}

.logo-grid img:hover {
  transform: scale(1.1) !important;
  filter: grayscale(0%) !important;
}


/* v112-v122: Various overlay and border removals */
.mast::before, .hero::before, .mast .content::before,
.mast-left::before, .mast-right::before, .standalone::before,
.trusted::before, .logo-grid::before, .row::before,
.col-left::before, .col-right::before, .card::before,
section::before {
  border: 0 !important;
  box-shadow: none !important;
  content: none !important;
  display: none !important;
}


/* v145-v147: Final background and text color scheme */
html, body {
  background: #000000 !important;
}
section, .section, .container, main, header, footer {
  background: transparent !important;
}

/* v150-152: Sizing and Centering for About & Worked With */
.about, .worked-with {
  padding-block: 64px !important;
  text-align: center !important;
}
.about .masthead-title, .worked-with .masthead-title,
.about h1, .worked-with h1 {
  font-size: clamp(28px, 4.5vw, 56px) !important;
  text-align: center !important;
  margin: 0 auto 24px auto !important;
}
.worked-with .logo-grid {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 24px !important;
}

/* v157: Services cards */
.services-cards .cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}
@media (max-width: 980px) {
  .services-cards .cards { grid-template-columns: 1fr; }
}
.card.service {
  background: #ffffff !important;
  color: #000000 !important;
  border-radius: 18px;
  padding: 24px 24px 20px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.25);
  border: 1px solid rgba(0,0,0,0.08);
}
.card.service h3 {
  text-align: center;
  font-size: clamp(20px, 3vw, 28px);
  color: #000000 !important;
}
.card.service .bullets li, .card.service a {
  color: #000000 !important;
}
.card.service .bullets {
  margin: 0; padding-left: 18px; display: grid; gap: 8px;
}

/* v161: Services Hero section */
.services-hero * {
  color: #ffffff !important;
}
.services-hero h1, .services-hero p {
  text-align: center !important;
  max-width: 1000px;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Other fixes */
.socials img, .contact-card img {
  height: 18px;
  width: 18px;
  vertical-align: middle;
  margin: 0 2px;
}

/* Mobile Fixes */
@media (max-width: 768px) {
  .header {
    flex-direction: column;
    align-items: center;
    padding: 30px 0 20px 0;
    text-align: center;
  }
  .nav {
    margin-top: 15px;
    margin-left: 0;
    justify-content: center;
    flex-wrap: nowrap;
  }
  .standalone-contact {
    gap: 20px;
    padding: 0 10px;
  }
  .contact-block {
    padding: 40px;
  }
}

/* --- 3D Bouncy Balloon Background --- */
.bouncy-balloon {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 0; 
  overflow: hidden;
}

/* --- Transparency Fixes --- */
.mast-left *, .mast-left h1, .mast-left p, .mast-left .meta, .mast-left a, .mast-left .btn {
  color: #ffffff !important;
  border-color: #ffffff !important;
}

.about {
  background: transparent !important;
}


.contact-block * {
  color: #ffffff !important;
}
.contact-block a {
   border-bottom-color: rgba(255, 255, 255, 0.5) !important;
}

.worked-with {
  background: transparent !important;
}

.services-hero {
  background: transparent !important;
}

.calendar-embed {
  position: relative;
  width: 100%;
  background: transparent;
  border-radius: 24px;
  padding: 0;
  border: none;
  box-sizing: border-box;
  overflow: hidden;
}

.calendar-embed iframe {
  display: block;
  width: 100%;
  height: 80vh;
  min-height: 700px;
  border-radius: 16px;
}

.services-video .container {
  background: rgba(0, 0, 0, 0.8);
  border-radius: 24px;
  padding: 28px;
  margin: 32px auto !important;
}

.services-video .container > div {
  box-shadow: none !important;
}