:root {
  --black: #000;
  --gold: #b88924;
  --gold-bright: #d9b75d;
  --text: #e5cf8e;
  --muted: #aa8c4a;
  --line: rgba(184, 137, 36, .72);
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  background: #000;
  color: var(--text);
  font-family: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  overflow-x: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 50% -10%, rgba(184,137,36,.10), transparent 28rem),
    radial-gradient(circle at 50% 110%, rgba(184,137,36,.06), transparent 32rem);
  z-index: -2;
}

.grain {
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: .05;
  z-index: 50;
  background-image:
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px);
  background-size: 3px 3px;
  mix-blend-mode: screen;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a { color: inherit; }

.site-header {
  position: fixed;
  z-index: 30;
  top: 1rem;
  left: 50%;
  transform: translateX(-50%);
  width: min(1180px, calc(100% - 1.5rem));
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: .7rem .9rem;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(0,0,0,.8);
  backdrop-filter: blur(18px);
  box-shadow: 0 20px 80px rgba(0,0,0,.55);
}

.brand,
.desktop-nav,
.header-cta {
  display: flex;
  align-items: center;
}

.brand {
  gap: .72rem;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: clamp(.08em, .45vw, .17em);
  color: var(--gold-bright);
  font-size: clamp(.7rem, 1vw, .86rem);
  font-weight: 500;
  min-width: 0;
}

.brand img {
  width: 2.05rem;
  height: 2.05rem;
  flex: 0 0 auto;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid rgba(184,137,36,.65);
}

.desktop-nav {
  gap: 1.4rem;
}

.desktop-nav a,
.header-cta {
  text-transform: uppercase;
  letter-spacing: .18em;
  text-decoration: none;
  color: var(--muted);
  font-size: .78rem;
  font-weight: 500;
  white-space: nowrap;
}

.desktop-nav a:hover,
.header-cta:hover {
  color: var(--gold-bright);
}

.header-cta {
  border: 1px solid rgba(184,137,36,.55);
  border-radius: 999px;
  padding: .65rem .9rem;
}

main {
  width: min(1220px, calc(100% - 2rem));
  margin: 0 auto;
}

.hero {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  min-height: 78svh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(5.7rem, 10vh, 8rem) 1.25rem clamp(2.5rem, 7vh, 5rem);
  position: relative;
  text-align: center;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(0,0,0,.18), #000 92%),
    #000;
}

.hero::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 1.4rem;
  width: min(1120px, calc(100% - 2rem));
  height: 1px;
  transform: translateX(-50%);
  background: linear-gradient(90deg, transparent, rgba(184,137,36,.65), transparent);
}

.hero-glow {
  position: absolute;
  width: min(54rem, 90vw);
  height: min(54rem, 90vw);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(184,137,36,.18), rgba(184,137,36,.07) 34%, transparent 68%);
  filter: blur(32px);
  opacity: .82;
  pointer-events: none;
}

.hero-content {
  position: relative;
  z-index: 2;
  width: min(820px, 100%);
  margin: 0 auto;
}

.hero-logo {
  width: clamp(7.2rem, 18vw, 12.5rem);
  aspect-ratio: 1 / 1;
  object-fit: cover;
  margin: 0 auto clamp(1.25rem, 3vh, 2rem);
  border-radius: 50%;
  filter: drop-shadow(0 0 38px rgba(184,137,36,.26));
  animation: floatLogo 7s ease-in-out infinite;
}

@keyframes floatLogo {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-7px); }
}

.kicker {
  margin: 0;
  text-transform: uppercase;
  letter-spacing: clamp(.14em, .9vw, .34em);
  color: var(--gold-bright);
  font-size: clamp(.82rem, 1.2vw, 1rem);
  font-weight: 500;
}

h1, h2, h3, p { margin-top: 0; }

h1 {
  margin: .85rem 0 .8rem;
  color: var(--gold-bright);
  text-transform: uppercase;
  letter-spacing: clamp(.07em, .8vw, .14em);
  font-size: clamp(2.35rem, 5.2vw, 4.6rem);
  line-height: .9;
  font-weight: 400;
  text-shadow: 0 0 28px rgba(184,137,36,.22);
}

.divider {
  width: min(22rem, 70%);
  height: 1px;
  margin: clamp(1.1rem, 3vh, 1.65rem) auto;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  position: relative;
}

.divider span {
  position: absolute;
  left: 50%;
  top: 50%;
  width: .72rem;
  height: .72rem;
  transform: translate(-50%, -50%) rotate(45deg);
  border: 1px solid var(--gold);
  background: #000;
}

.hero-line {
  margin-bottom: .55rem;
  color: var(--gold-bright);
  text-transform: uppercase;
  letter-spacing: clamp(.06em, .6vw, .16em);
  line-height: 1.55;
  font-size: clamp(.95rem, 1.8vw, 1.15rem);
}

.hero-subline {
  margin: 0;
  color: var(--gold-bright);
  text-transform: uppercase;
  letter-spacing: clamp(.08em, .7vw, .26em);
  font-size: clamp(.78rem, 1.1vw, .86rem);
}

.hero-actions {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: .9rem;
  margin-top: clamp(1.4rem, 4vh, 2.2rem);
}

.button {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: .45rem;
  min-width: min(12rem, 100%);
  max-width: 100%;
  padding: .9rem 1.1rem;
  border: 1px solid var(--gold);
  border-radius: 999px;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: clamp(.08em, .45vw, .16em);
  font-size: clamp(.74rem, 1vw, .82rem);
  font-weight: 600;
  line-height: 1.2;
  white-space: normal;
  text-align: center;
  overflow-wrap: anywhere;
  transition: transform .25s ease, background .25s ease, color .25s ease;
}

.button:hover { transform: translateY(-2px); }

.button.primary {
  background: var(--gold-bright);
  color: #000;
}

.button.secondary { color: var(--gold-bright); }

.button.secondary:hover {
  background: var(--gold);
  color: #000;
}

.hero-contact-icons {
  display: flex;
  justify-content: center;
  gap: .8rem;
  margin-top: 1.2rem;
}

.hero-contact-icons a {
  display: grid;
  place-items: center;
  width: 2.45rem;
  height: 2.45rem;
  border: 1px solid rgba(184,137,36,.55);
  border-radius: 50%;
  color: var(--gold-bright);
  transition: transform .25s ease, background .25s ease;
}

.hero-contact-icons a:hover {
  transform: translateY(-2px);
  background: rgba(184,137,36,.13);
}

svg {
  width: 1.08rem;
  height: 1.08rem;
  flex: 0 0 auto;
  fill: currentColor;
}

.frame {
  position: relative;
  border: 1px solid var(--line);
  outline: 1px solid rgba(184,137,36,.28);
  outline-offset: -11px;
  border-radius: 2.2rem;
  background: #000;
}

.corner {
  position: absolute;
  width: 5rem;
  height: 5rem;
  opacity: .88;
  pointer-events: none;
}

.corner::before,
.corner::after {
  content: "";
  position: absolute;
  border-color: var(--gold);
  border-style: solid;
}

.corner::before {
  inset: 0;
  border-width: 2px 0 0 2px;
  border-radius: 100% 0 0 0;
}

.corner::after {
  width: 1.35rem;
  height: 1.35rem;
  border-width: 1px;
  border-radius: 50%;
  left: .15rem;
  top: .15rem;
}

.tl { top: 1.35rem; left: 1.35rem; }
.tr { top: 1.35rem; right: 1.35rem; transform: rotate(90deg); }
.br { bottom: 1.35rem; right: 1.35rem; transform: rotate(180deg); }
.bl { bottom: 1.35rem; left: 1.35rem; transform: rotate(270deg); }

.section {
  padding: clamp(4.5rem, 8vw, 7rem) 2rem;
}

.intro {
  max-width: 1120px;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(18rem, .8fr);
  gap: clamp(1.5rem, 5vw, 4rem);
  align-items: center;
  text-align: left;
}

 .tagline-lockup {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 1rem;
  margin-bottom: 1.2rem;
}

.tagline-lockup img {
  width: clamp(3.3rem, 8vw, 4.25rem);
  height: clamp(3.3rem, 8vw, 4.25rem);
  object-fit: cover;
  border-radius: 50%;
  border: 1px solid rgba(184,137,36,.58);
  filter: drop-shadow(0 0 18px rgba(184,137,36,.22));
}

h2 {
  margin: 1.2rem auto 1.4rem;
  max-width: 980px;
  color: var(--gold-bright);
  text-transform: uppercase;
  letter-spacing: clamp(.03em, .35vw, .06em);
  font-size: clamp(2rem, 4.1vw, 3.55rem);
  line-height: 1.08;
  font-weight: 400;
}

.intro p,
.support,
.services p,
.process p,
.contact p {
  color: var(--muted);
  font-size: clamp(1rem, 1.55vw, 1.14rem);
  line-height: 1.78;
}

.section-heading {
  text-align: center;
  margin-bottom: 2.5rem;
}

.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 1rem;
}

.portfolio-item {
  grid-column: span 3;
  position: relative;
  min-height: 22rem;
  overflow: hidden;
  border: 1px solid rgba(184,137,36,.58);
  border-radius: 1.1rem;
  background: #030303;
  isolation: isolate;
}

.portfolio-item.tall {
  grid-row: span 2;
  min-height: 46rem;
}

.portfolio-item.wide {
  grid-column: span 6;
}

.portfolio-item.feature {
  grid-column: span 6;
}

.portfolio-item img {
  width: 100%;
  height: 100%;
  min-height: inherit;
  object-fit: cover;
  filter: saturate(.86) contrast(1.04);
  transition: transform .7s ease, filter .7s ease;
}

.portfolio-item::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 35%, rgba(0,0,0,.86));
  z-index: 1;
}

.portfolio-item:hover img {
  transform: scale(1.045);
  filter: saturate(1) contrast(1.08);
}

.portfolio-item div {
  position: absolute;
  z-index: 2;
  left: 1.1rem;
  right: 1.1rem;
  bottom: 1.1rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(184,137,36,.72);
}

.portfolio-item span,
.portfolio-item strong {
  display: block;
  text-transform: uppercase;
}

.portfolio-item span {
  color: var(--gold-bright);
  letter-spacing: .22em;
  font-size: .78rem;
  margin-bottom: .35rem;
}

.portfolio-item strong {
  color: var(--text);
  letter-spacing: .08em;
  font-size: 1.1rem;
  font-weight: 400;
}

.services {
  text-align: center;
  padding: clamp(4.25rem, 7vw, 5.5rem) 2rem;
}

.service-list {
  width: min(780px, 100%);
  margin: 2.5rem auto 0;
}

.service-list article {
  position: relative;
  padding: 1.5rem 0 1.8rem;
  border-bottom: 1px solid rgba(184,137,36,.5);
}

.service-list article:last-child { border-bottom: 0; }

.service-list article::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -.38rem;
  width: .65rem;
  height: .65rem;
  transform: translateX(-50%) rotate(45deg);
  background: #000;
  border: 1px solid var(--gold);
}

.service-list article:last-child::after { display: none; }

h3 {
  margin: 0 0 .7rem;
  color: var(--gold-bright);
  text-transform: uppercase;
  letter-spacing: clamp(.08em, .55vw, .22em);
  font-size: clamp(1.2rem, 2.2vw, 1.65rem);
  font-weight: 500;
}

.services p {
  max-width: 690px;
  margin: 0 auto;
}

.process {
  text-align: center;
}

.process-grid {
  margin-top: 2.5rem;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  border: 1px solid rgba(184,137,36,.58);
  border-radius: 1.4rem;
  overflow: hidden;
}

.process-grid article {
  padding: 1.6rem 1.2rem;
  background: #030303;
}

.process-grid span {
  display: block;
  color: var(--gold);
  letter-spacing: .24em;
  margin-bottom: 1rem;
  font-size: 1.25rem;
  font-family: "Cormorant Garamond", Georgia, serif;
}

.process-grid h3 {
  letter-spacing: .14em;
  font-size: 1.1rem;
}

.contact {
  margin-bottom: 4rem;
  display: grid;
  grid-template-columns: minmax(17rem, 32rem) 1fr;
  gap: 3rem;
  align-items: center;
  padding: 3rem;
}

.business-cards {
  display: grid;
  gap: 1rem;
}

.business-cards img {
  width: 100%;
  max-width: 26rem;
  margin: 0 auto;
  border-radius: 1rem;
  border: 1px solid rgba(184,137,36,.35);
  box-shadow: 0 30px 90px rgba(0,0,0,.55);
  object-fit: contain;
}

.contact-content h2 {
  margin-left: 0;
  text-align: left;
}

.contact-content { text-align: left; }

.contact-links {
  display: grid;
  grid-template-columns: 1fr;
  gap: .9rem;
  margin-top: 2rem;
  max-width: 100%;
}

.contact-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .55rem;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  padding: .95rem 1rem;
  border: 1px solid var(--gold);
  border-radius: 999px;
  color: var(--gold-bright);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: clamp(.04em, .35vw, .13em);
  font-size: clamp(.72rem, 1.15vw, .78rem);
  font-weight: 600;
  line-height: 1.25;
  text-align: center;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.contact-pill span {
  min-width: 0;
  overflow-wrap: anywhere;
}

.contact-pill:hover {
  background: var(--gold);
  color: #000;
}

footer {
  padding: 2rem;
  text-align: center;
  color: var(--muted);
  border-top: 1px solid rgba(184,137,36,.35);
}

.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .9s ease, transform .9s ease;
}

.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 950px) {
  .desktop-nav { display: none; }

  .portfolio-grid {
    grid-template-columns: 1fr 1fr;
  }

  .portfolio-item,
  .portfolio-item.wide,
  .portfolio-item.tall {
    grid-column: auto;
    min-height: 22rem;
  }

  .process-grid {
    grid-template-columns: 1fr;
  }

  .contact {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .contact-content,
  .contact-content h2 {
    text-align: center;
  }

  .business-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: start;
  }

  .business-cards img {
    max-width: 100%;
  }
}

@media (max-width: 620px) {
  main {
    width: calc(100% - .8rem);
  }

  .site-header {
    top: .5rem;
    width: calc(100% - .8rem);
    border-radius: 1rem;
    padding: .58rem .72rem;
  }

  .header-cta {
    display: none;
  }

  .brand {
    font-size: .7rem;
    letter-spacing: .08em;
  }

  .brand img {
    width: 1.85rem;
    height: 1.85rem;
  }

  .hero {
    min-height: 82svh;
    padding: 4.9rem .9rem 2.2rem;
  }

  .hero-logo {
    width: min(12.8rem, 62vw);
    margin-bottom: 1.05rem;
  }

  h1 {
    font-size: clamp(2.3rem, 11.5vw, 3.6rem);
    letter-spacing: .07em;
  }

  h2 {
    font-size: clamp(1.85rem, 9.5vw, 2.65rem);
  }

  .hero-actions,
  .contact-links {
    flex-direction: column;
  }

  .button,
  .contact-pill {
    width: 100%;
    border-radius: 1.2rem;
  }

  .section {
    padding: 4.5rem 1rem;
  }

  .tagline-lockup {
    flex-direction: column;
    gap: .8rem;
  }

  .portfolio-grid {
    grid-template-columns: 1fr;
  }

  .portfolio-item,
  .portfolio-item.wide,
  .portfolio-item.tall {
    min-height: 21rem;
  }

  .services,
  .contact {
    padding: 3.6rem 1rem;
  }

  .frame {
    border-radius: 1.4rem;
    outline-offset: -7px;
  }

  .corner {
    width: 3rem;
    height: 3rem;
  }

  .business-cards {
    grid-template-columns: 1fr;
  }

  .contact-pill {
    font-size: clamp(.62rem, 3.2vw, .76rem);
    padding: .85rem .7rem;
    letter-spacing: .035em;
  }
}

@media (max-width: 380px) {
  .hero {
    padding-top: 4.6rem;
  }

  .hero-logo {
    width: min(11.5rem, 58vw);
  }

  .hero-line {
    font-size: .88rem;
  }

  .hero-subline,
  .kicker {
    font-size: .72rem;
  }

  .button {
    font-size: .68rem;
    padding: .8rem .65rem;
  }

  .contact-pill {
    font-size: .58rem;
  }
}


/* Final contact fix: no cropping on mobile */
.contact {
  grid-template-columns: 1fr;
}

.contact-content-full {
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
}

.contact-content-full h2 {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

.contact-list-clean {
  display: grid;
  gap: 1rem;
  margin: 2rem auto 0;
  width: min(100%, 520px);
}

.contact-list-clean a {
  display: grid;
  grid-template-columns: 1.25rem minmax(0, 1fr);
  align-items: center;
  gap: .75rem;
  width: 100%;
  min-width: 0;
  padding: 1rem 1.1rem;
  border: 1px solid var(--gold);
  border-radius: 1rem;
  color: var(--gold-bright);
  text-decoration: none;
  text-transform: none;
  letter-spacing: .02em;
  font-size: clamp(.95rem, 2.8vw, 1.12rem);
  line-height: 1.2;
  overflow: hidden;
}

.contact-list-clean a span {
  display: block;
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.contact-list-clean a:hover {
  background: rgba(184,137,36,.14);
}

.contact-list-clean svg {
  width: 1.15rem;
  height: 1.15rem;
}

@media (max-width: 620px) {
  .contact-list-clean {
    width: 100%;
  }

  .contact-list-clean a {
    padding: .95rem .85rem;
    font-size: clamp(.88rem, 4vw, 1rem);
  }
}


/* Portfolio refresh */
.intro-copy h2 { margin-left: 0; }
.intro-image {
  margin: 0;
  border: 1px solid rgba(184,137,36,.58);
  border-radius: 1.2rem;
  overflow: hidden;
  box-shadow: 0 24px 80px rgba(0,0,0,.48);
}
.intro-image img {
  width: 100%;
  height: clamp(24rem, 42vw, 34rem);
  object-fit: cover;
  object-position: 52% 44%;
  filter: saturate(.9) contrast(1.04);
}
.compact-portfolio { align-items: stretch; }
.compact-portfolio .portfolio-item { min-height: clamp(18rem, 26vw, 24rem); }
.compact-portfolio .portfolio-item.feature { min-height: clamp(24rem, 36vw, 32rem); }

@media (max-width: 950px) {
  .intro {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .intro-copy h2 { margin-left: auto; }
  .intro .tagline-lockup { justify-content: center; }
  .portfolio-item.feature { grid-column: span 2; }
}

@media (max-width: 620px) {
  .hero { min-height: 78svh; }
  .hero-logo { width: min(10.5rem, 50vw); }
  .intro-image img { height: 25rem; }
  .portfolio-item.feature { grid-column: auto; }
  .compact-portfolio .portfolio-item,
  .compact-portfolio .portfolio-item.feature { min-height: 22rem; }
}


/* Mobile contact refinement */
.contact {
  overflow: hidden;
}

.contact-content-full h2 {
  max-width: 100%;
  font-size: clamp(2rem, 7vw, 3.2rem);
  letter-spacing: .08em;
  white-space: normal;
}

.contact-list-clean {
  width: min(100%, 34rem);
  max-width: 100%;
}

.contact-list-clean a {
  box-sizing: border-box;
  max-width: 100%;
}

@media (max-width: 620px) {
  .contact {
    padding: 3rem .85rem;
    margin-bottom: 2.8rem;
  }

  .contact-content-full h2 {
    font-size: clamp(2.05rem, 11vw, 2.85rem);
    line-height: 1;
    letter-spacing: .12em;
    margin-bottom: 1rem;
  }

  .contact-content-full p {
    font-size: 1rem;
    line-height: 1.55;
    max-width: 18rem;
    margin-left: auto;
    margin-right: auto;
  }

  .contact-list-clean {
    gap: .85rem;
    margin-top: 1.6rem;
  }

  .contact-list-clean a {
    grid-template-columns: 1.1rem minmax(0, 1fr);
    gap: .65rem;
    padding: .86rem .78rem;
    border-radius: .9rem;
    font-size: clamp(.78rem, 3.8vw, .95rem);
    line-height: 1.15;
  }

  .contact-list-clean svg {
    width: 1rem;
    height: 1rem;
  }
}

@media (max-width: 380px) {
  .contact-list-clean a {
    font-size: .78rem;
    padding: .8rem .66rem;
  }
}


/* Portfolio expansion: compact curated grid for many images */
.compact-portfolio {
  grid-auto-flow: dense;
  align-items: stretch;
}

.compact-portfolio .portfolio-item,
.compact-portfolio .portfolio-item.feature {
  min-height: 0 !important;
  height: clamp(13rem, 18vw, 18rem);
  aspect-ratio: 4 / 3;
}

.compact-portfolio .portfolio-item.feature {
  grid-column: span 6;
  height: clamp(17rem, 25vw, 24rem);
}

.compact-portfolio .portfolio-item:nth-child(3),
.compact-portfolio .portfolio-item:nth-child(5),
.compact-portfolio .portfolio-item:nth-child(15) {
  grid-column: span 6;
}

.compact-portfolio .portfolio-item img {
  min-height: 0 !important;
  height: 100%;
}

@media (max-width: 950px) {
  .portfolio-grid {
    grid-template-columns: repeat(6, 1fr);
  }

  .compact-portfolio .portfolio-item,
  .compact-portfolio .portfolio-item.feature,
  .compact-portfolio .portfolio-item:nth-child(3),
  .compact-portfolio .portfolio-item:nth-child(5),
  .compact-portfolio .portfolio-item:nth-child(15) {
    grid-column: span 3;
    height: clamp(12rem, 28vw, 16rem);
  }
}

@media (max-width: 620px) {
  .portfolio-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .65rem;
  }

  .compact-portfolio .portfolio-item,
  .compact-portfolio .portfolio-item.feature,
  .compact-portfolio .portfolio-item:nth-child(3),
  .compact-portfolio .portfolio-item:nth-child(5),
  .compact-portfolio .portfolio-item:nth-child(15) {
    grid-column: auto;
    height: clamp(9.6rem, 43vw, 12rem);
    min-height: 0 !important;
    border-radius: .75rem;
  }

  .portfolio-item div {
    left: .6rem;
    right: .6rem;
    bottom: .6rem;
    padding-top: .5rem;
  }

  .portfolio-item span {
    font-size: .58rem;
    letter-spacing: .15em;
    margin-bottom: .18rem;
  }

  .portfolio-item strong {
    font-size: .78rem;
    line-height: 1.05;
    letter-spacing: .04em;
  }
}


/* Floating WhatsApp contact button - mobile only */
.whatsapp-float {
  display: none;
}

@media (max-width: 768px) {
  .whatsapp-float {
    position: fixed;
    right: .9rem;
    bottom: calc(.9rem + env(safe-area-inset-bottom));
    width: 3.15rem;
    min-width: 3.15rem;
    height: 3.15rem;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: linear-gradient(135deg, #25D366, #128C7E);
    color: #fff;
    text-decoration: none;
    border: 1px solid rgba(255,255,255,.28);
    box-shadow: 0 1rem 2.2rem rgba(0,0,0,.42), 0 0 0 1px rgba(0,0,0,.15) inset;
    z-index: 1000;
    -webkit-tap-highlight-color: transparent;
  }

  .whatsapp-float:active {
    transform: scale(.96);
  }

  .whatsapp-float span {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }

  .whatsapp-float svg {
    width: 1.45rem;
    height: 1.45rem;
    flex: 0 0 auto;
    fill: currentColor;
  }
}


/* Final premium clean-up: remove decorative corner curls */
.corner,
.frame > .corner,
.corner::before,
.corner::after {
  display: none !important;
}

/* Services: remove Theatre SFX and tighten into a premium card grid */
.services.frame,
.contact.frame {
  overflow: hidden;
}

.services h2 {
  margin: 0.35rem 0 2rem;
  font-size: clamp(2.3rem, 5vw, 4.8rem);
  font-weight: 400;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gold-light);
}

.premium-service-list {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.premium-service-list article {
  border: 1px solid rgba(194, 151, 64, 0.28) !important;
  border-radius: 18px;
  padding: clamp(1.1rem, 2vw, 1.5rem) !important;
  background: linear-gradient(135deg, rgba(194,151,64,0.08), rgba(255,255,255,0.015));
  min-height: 12rem;
}

.premium-service-list article::after { display: none !important; }
.premium-service-list h3 { margin-bottom: .65rem; }
.premium-service-list p { max-width: 56ch; }

/* Portfolio: one controlled premium system */
.portfolio-grid.premium-portfolio {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(0.75rem, 1.6vw, 1.25rem);
  align-items: stretch;
}

.premium-portfolio .portfolio-item,
.premium-portfolio .portfolio-item.feature,
.premium-portfolio .portfolio-item:nth-child(3),
.premium-portfolio .portfolio-item:nth-child(5),
.premium-portfolio .portfolio-item:nth-child(15) {
  min-height: auto !important;
  height: auto !important;
  aspect-ratio: 1 / 1;
  grid-column: span 1 !important;
  border-radius: 18px;
}

.premium-portfolio .portfolio-item.feature {
  grid-column: span 2 !important;
  aspect-ratio: 16 / 10;
}

.premium-portfolio .portfolio-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.premium-portfolio .portfolio-item div {
  padding: clamp(0.8rem, 1.5vw, 1.1rem);
  background: linear-gradient(to top, rgba(0,0,0,0.86), rgba(0,0,0,0.42), rgba(0,0,0,0));
}

.premium-portfolio .portfolio-item span {
  font-size: clamp(0.55rem, 0.72vw, 0.72rem);
  letter-spacing: 0.22em;
  white-space: normal;
}

.premium-portfolio .portfolio-item strong {
  font-size: clamp(0.86rem, 1vw, 1.1rem);
  line-height: 1.08;
  max-width: 18ch;
}

@media (max-width: 900px) {
  .portfolio-grid.premium-portfolio {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
  }

  .premium-portfolio .portfolio-item,
  .premium-portfolio .portfolio-item.feature,
  .premium-portfolio .portfolio-item:nth-child(3),
  .premium-portfolio .portfolio-item:nth-child(5),
  .premium-portfolio .portfolio-item:nth-child(15) {
    grid-column: span 1 !important;
    aspect-ratio: 1 / 1 !important;
    border-radius: 14px;
  }

  .premium-portfolio .portfolio-item div {
    padding: 0.75rem;
  }

  .premium-portfolio .portfolio-item span {
    font-size: 0.52rem;
    letter-spacing: 0.18em;
  }

  .premium-portfolio .portfolio-item strong {
    font-size: 0.82rem;
    max-width: 16ch;
  }

  .premium-service-list {
    grid-template-columns: 1fr;
  }

  .premium-service-list article {
    min-height: auto;
  }
}

@media (max-width: 420px) {
  .portfolio-grid.premium-portfolio {
    gap: 0.6rem;
  }

  .premium-portfolio .portfolio-item div {
    padding: 0.62rem;
  }

  .premium-portfolio .portfolio-item strong {
    font-size: 0.74rem;
  }
}


/* FINAL PORTFOLIO RESET — tidy, labelled, no destructive cropping */
.portfolio-grid.premium-portfolio.tidy-portfolio {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: clamp(1rem, 1.8vw, 1.35rem) !important;
  align-items: stretch !important;
}

.tidy-portfolio .portfolio-item,
.tidy-portfolio .portfolio-item.feature,
.tidy-portfolio .portfolio-item:nth-child(3),
.tidy-portfolio .portfolio-item:nth-child(5),
.tidy-portfolio .portfolio-item:nth-child(15) {
  display: flex !important;
  flex-direction: column !important;
  grid-column: auto !important;
  aspect-ratio: auto !important;
  min-height: 0 !important;
  height: auto !important;
  overflow: hidden !important;
  border-radius: 18px !important;
  border: 1px solid rgba(194,151,64,.46) !important;
  background: linear-gradient(180deg, #070707 0%, #020202 100%) !important;
  box-shadow: 0 18px 60px rgba(0,0,0,.34) !important;
}

.tidy-portfolio .portfolio-item::after { display: none !important; }

.tidy-portfolio .portfolio-item figure {
  margin: 0 !important;
  width: 100% !important;
  height: clamp(13rem, 20vw, 18rem) !important;
  background:
    radial-gradient(circle at 50% 38%, rgba(194,151,64,.10), transparent 42%),
    #050505 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}

.tidy-portfolio .portfolio-item img {
  width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;
  object-fit: contain !important;
  object-position: center !important;
  display: block !important;
  filter: saturate(.94) contrast(1.03) !important;
  transform: none !important;
}

.tidy-portfolio .portfolio-item:hover img {
  transform: none !important;
  filter: saturate(1) contrast(1.05) !important;
}

.tidy-portfolio .portfolio-item div {
  position: static !important;
  inset: auto !important;
  min-height: 7rem !important;
  padding: 1rem 1rem 1.08rem !important;
  border-top: 1px solid rgba(194,151,64,.36) !important;
  background: linear-gradient(180deg, rgba(194,151,64,.08), rgba(0,0,0,0)) !important;
}

.tidy-portfolio .portfolio-item span {
  color: var(--gold-bright) !important;
  font-size: .66rem !important;
  letter-spacing: .20em !important;
  line-height: 1.2 !important;
  margin-bottom: .42rem !important;
}

.tidy-portfolio .portfolio-item strong {
  color: var(--text) !important;
  font-size: clamp(.98rem, 1.25vw, 1.18rem) !important;
  line-height: 1.08 !important;
  letter-spacing: .075em !important;
  max-width: none !important;
}

@media (max-width: 900px) {
  .portfolio-grid.premium-portfolio.tidy-portfolio {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: .8rem !important;
  }
  .tidy-portfolio .portfolio-item figure {
    height: clamp(8.8rem, 36vw, 12.5rem) !important;
  }
  .tidy-portfolio .portfolio-item div {
    min-height: 5.9rem !important;
    padding: .78rem .72rem .86rem !important;
  }
  .tidy-portfolio .portfolio-item span {
    font-size: .52rem !important;
    letter-spacing: .16em !important;
  }
  .tidy-portfolio .portfolio-item strong {
    font-size: clamp(.76rem, 3.1vw, .95rem) !important;
    line-height: 1.05 !important;
  }
}

@media (max-width: 380px) {
  .portfolio-grid.premium-portfolio.tidy-portfolio { gap: .62rem !important; }
  .tidy-portfolio .portfolio-item figure { height: 8.3rem !important; }
  .tidy-portfolio .portfolio-item div { min-height: 5.6rem !important; padding: .66rem .58rem .74rem !important; }
  .tidy-portfolio .portfolio-item strong { font-size: .72rem !important; }
}


/* === FINAL PRODUCTION CLEAN BUILD OVERRIDES === */
.site-header .brand img,
.tagline-lockup img {
  display: none !important;
}

.site-header .brand {
  padding-left: .6rem;
  font-size: clamp(.86rem, 1.6vw, 1.05rem);
  letter-spacing: .14em;
}

.tagline-lockup {
  justify-content: flex-start;
}

/* Editorial portfolio: one strong piece at a time on mobile, refined two-column desktop */
.editorial-portfolio {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1.1rem, 2.4vw, 1.8rem);
  align-items: stretch;
}

.editorial-portfolio .portfolio-item,
.editorial-portfolio .portfolio-item.wide,
.editorial-portfolio .portfolio-item.tall,
.editorial-portfolio .portfolio-item.feature {
  grid-column: auto !important;
  min-height: 0 !important;
  height: clamp(29rem, 44vw, 38rem);
  display: flex;
  flex-direction: column;
  border-radius: 1.35rem;
  border: 1px solid rgba(184,137,36,.58);
  background: #030303;
  overflow: hidden;
  isolation: isolate;
  box-shadow: 0 20px 60px rgba(0,0,0,.35);
}

.editorial-portfolio .portfolio-item::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--card-bg);
  background-size: cover;
  background-position: center;
  transform: scale(1.18);
  filter: blur(18px) brightness(.22) saturate(.78);
  opacity: .92;
  z-index: 0;
}

.editorial-portfolio .portfolio-item::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 14%, rgba(217,183,93,.10), transparent 20rem),
    linear-gradient(180deg, rgba(0,0,0,.22), rgba(0,0,0,.32));
  z-index: 1;
}

.editorial-portfolio .portfolio-item figure {
  position: relative;
  z-index: 2;
  flex: 1 1 auto;
  width: 100%;
  min-height: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(.8rem, 1.6vw, 1.25rem) clamp(.8rem, 1.6vw, 1.25rem) .45rem;
  margin: 0;
}

.editorial-portfolio .portfolio-item img {
  width: 100%;
  height: 100%;
  min-height: 0 !important;
  max-height: 100%;
  object-fit: contain;
  object-position: center;
  filter: saturate(.95) contrast(1.02);
  border-radius: .75rem;
  transition: transform .7s ease, filter .7s ease;
}

.editorial-portfolio .portfolio-item:hover img {
  transform: scale(1.018);
  filter: saturate(1.04) contrast(1.06);
}

.editorial-portfolio .portfolio-item div {
  position: relative;
  z-index: 2;
  left: auto;
  right: auto;
  bottom: auto;
  width: calc(100% - clamp(1.6rem, 3.2vw, 2.5rem));
  margin: 0 auto clamp(.85rem, 1.7vw, 1.2rem);
  padding: clamp(1rem, 2vw, 1.3rem) clamp(1rem, 2vw, 1.25rem) clamp(1.1rem, 2vw, 1.4rem);
  border-top: 1px solid rgba(184,137,36,.72);
  background: linear-gradient(180deg, rgba(0,0,0,.55), rgba(0,0,0,.82));
  backdrop-filter: blur(4px);
}

.editorial-portfolio .portfolio-item span {
  color: var(--gold-bright);
  letter-spacing: .22em;
  font-size: clamp(.66rem, .95vw, .78rem);
  margin-bottom: .45rem;
}

.editorial-portfolio .portfolio-item strong {
  color: var(--text);
  letter-spacing: .08em;
  font-size: clamp(1.18rem, 2.1vw, 1.75rem);
  line-height: 1.08;
  max-width: 18ch;
}

/* Contact + WhatsApp */
.whatsapp-float {
  display: none !important;
}

@media (max-width: 768px) {
  .whatsapp-float {
    display: inline-flex !important;
    position: fixed;
    right: 1rem;
    bottom: calc(1rem + env(safe-area-inset-bottom));
    width: 3.65rem;
    height: 3.65rem;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: linear-gradient(135deg, #25D366, #128C4A);
    color: #fff;
    z-index: 1000;
    box-shadow: 0 18px 40px rgba(0,0,0,.45), inset 0 0 0 1px rgba(255,255,255,.28);
    text-decoration: none;
  }

  .whatsapp-float svg {
    width: 1.65rem;
    height: 1.65rem;
    fill: currentColor;
  }

  .whatsapp-float span {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
  }
}

@media (max-width: 900px) {
  .editorial-portfolio {
    grid-template-columns: 1fr;
    gap: 1.35rem;
  }

  .editorial-portfolio .portfolio-item,
  .editorial-portfolio .portfolio-item.wide,
  .editorial-portfolio .portfolio-item.tall,
  .editorial-portfolio .portfolio-item.feature {
    height: clamp(28rem, 116vw, 42rem);
  }

  .editorial-portfolio .portfolio-item div {
    width: calc(100% - 1.25rem);
    margin-bottom: .65rem;
    padding: .9rem .95rem 1rem;
  }

  .editorial-portfolio .portfolio-item strong {
    font-size: clamp(1.22rem, 6vw, 1.65rem);
    max-width: 20ch;
  }

  .editorial-portfolio .portfolio-item figure {
    padding: .65rem .65rem .35rem;
  }
}

@media (max-width: 620px) {
  .site-header {
    justify-content: center;
    padding: .8rem .9rem;
  }
  .site-header .brand {
    padding-left: 0;
    font-size: .92rem;
    letter-spacing: .13em;
  }
  .section.work {
    padding-left: .65rem;
    padding-right: .65rem;
  }
  .editorial-portfolio .portfolio-item,
  .editorial-portfolio .portfolio-item.wide,
  .editorial-portfolio .portfolio-item.tall,
  .editorial-portfolio .portfolio-item.feature {
    height: clamp(28rem, 126vw, 39rem);
    border-radius: 1.15rem;
  }
}

/* === PORTFOLIO RESCUE BUILD: readable, premium, no tiny thumbnails === */
.portfolio-grid.premium-portfolio,
.portfolio-grid.premium-portfolio.editorial-portfolio {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: clamp(1.05rem, 1.7vw, 1.45rem) !important;
  max-width: 1180px !important;
  margin: 0 auto !important;
  align-items: stretch !important;
}

.premium-portfolio.editorial-portfolio .portfolio-item,
.premium-portfolio.editorial-portfolio .portfolio-item.wide,
.premium-portfolio.editorial-portfolio .portfolio-item.tall,
.premium-portfolio.editorial-portfolio .portfolio-item.feature,
.portfolio-grid.premium-portfolio .portfolio-item {
  position: relative !important;
  display: flex !important;
  flex-direction: column !important;
  grid-column: auto !important;
  height: auto !important;
  min-height: 0 !important;
  aspect-ratio: auto !important;
  overflow: hidden !important;
  border-radius: 18px !important;
  border: 1px solid rgba(194,151,64,.48) !important;
  background: linear-gradient(180deg, #060606 0%, #010101 100%) !important;
  box-shadow: 0 18px 55px rgba(0,0,0,.34) !important;
  isolation: isolate !important;
}

.premium-portfolio.editorial-portfolio .portfolio-item::before,
.portfolio-grid.premium-portfolio .portfolio-item::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background-image: var(--card-bg) !important;
  background-size: cover !important;
  background-position: center !important;
  transform: scale(1.18) !important;
  filter: blur(18px) brightness(.28) saturate(.82) !important;
  opacity: .72 !important;
  z-index: 0 !important;
}

.premium-portfolio.editorial-portfolio .portfolio-item::after,
.portfolio-grid.premium-portfolio .portfolio-item::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background:
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.08) 45%, rgba(0,0,0,.58)),
    radial-gradient(circle at 50% 10%, rgba(217,183,93,.12), transparent 42%) !important;
  z-index: 1 !important;
  pointer-events: none !important;
}

.premium-portfolio.editorial-portfolio .portfolio-item figure,
.portfolio-grid.premium-portfolio .portfolio-item figure {
  position: relative !important;
  z-index: 2 !important;
  width: 100% !important;
  height: clamp(14rem, 20vw, 17.5rem) !important;
  min-height: 0 !important;
  flex: 0 0 auto !important;
  margin: 0 !important;
  padding: .85rem .85rem .35rem !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}

.premium-portfolio.editorial-portfolio .portfolio-item figure::after,
.portfolio-grid.premium-portfolio .portfolio-item figure::after {
  content: "" !important;
  position: absolute !important;
  left: .95rem !important;
  right: .95rem !important;
  bottom: 0 !important;
  height: 1px !important;
  background: rgba(194,151,64,.55) !important;
}

.premium-portfolio.editorial-portfolio .portfolio-item img,
.portfolio-grid.premium-portfolio .portfolio-item img {
  position: relative !important;
  z-index: 2 !important;
  width: 100% !important;
  height: 100% !important;
  max-height: 100% !important;
  min-height: 0 !important;
  object-fit: contain !important;
  object-position: center !important;
  display: block !important;
  border-radius: 10px !important;
  filter: saturate(.96) contrast(1.03) !important;
  transform: none !important;
}

.premium-portfolio.editorial-portfolio .portfolio-item:hover img,
.portfolio-grid.premium-portfolio .portfolio-item:hover img {
  transform: scale(1.012) !important;
  filter: saturate(1.04) contrast(1.06) !important;
}

.premium-portfolio.editorial-portfolio .portfolio-item div,
.portfolio-grid.premium-portfolio .portfolio-item div {
  position: relative !important;
  z-index: 2 !important;
  inset: auto !important;
  left: auto !important;
  right: auto !important;
  bottom: auto !important;
  width: 100% !important;
  min-height: 8.2rem !important;
  margin: 0 !important;
  padding: 1rem 1rem 1.15rem !important;
  background: linear-gradient(180deg, rgba(0,0,0,.42), rgba(0,0,0,.82)) !important;
  border-top: 0 !important;
  backdrop-filter: none !important;
}

.premium-portfolio.editorial-portfolio .portfolio-item span,
.portfolio-grid.premium-portfolio .portfolio-item span {
  display: block !important;
  color: var(--gold-bright) !important;
  font-size: .62rem !important;
  letter-spacing: .22em !important;
  line-height: 1.2 !important;
  margin: 0 0 .55rem !important;
  text-transform: uppercase !important;
  white-space: normal !important;
}

.premium-portfolio.editorial-portfolio .portfolio-item strong,
.portfolio-grid.premium-portfolio .portfolio-item strong {
  display: block !important;
  color: var(--text) !important;
  font-size: clamp(1rem, 1.25vw, 1.22rem) !important;
  line-height: 1.08 !important;
  letter-spacing: .07em !important;
  max-width: 18ch !important;
  text-transform: uppercase !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
  hyphens: none !important;
}

@media (max-width: 980px) {
  .portfolio-grid.premium-portfolio,
  .portfolio-grid.premium-portfolio.editorial-portfolio {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: .9rem !important;
  }
}

@media (max-width: 768px) {
  .work.section { padding-left: 1.25rem !important; padding-right: 1.25rem !important; }
  .portfolio-grid.premium-portfolio,
  .portfolio-grid.premium-portfolio.editorial-portfolio {
    grid-template-columns: 1fr !important;
    gap: 1.15rem !important;
    max-width: 30rem !important;
  }

  .premium-portfolio.editorial-portfolio .portfolio-item,
  .portfolio-grid.premium-portfolio .portfolio-item {
    border-radius: 20px !important;
  }

  .premium-portfolio.editorial-portfolio .portfolio-item figure,
  .portfolio-grid.premium-portfolio .portfolio-item figure {
    height: clamp(17rem, 70vw, 24rem) !important;
    padding: 1rem 1rem .4rem !important;
  }

  .premium-portfolio.editorial-portfolio .portfolio-item div,
  .portfolio-grid.premium-portfolio .portfolio-item div {
    min-height: auto !important;
    padding: 1.05rem 1.05rem 1.2rem !important;
  }

  .premium-portfolio.editorial-portfolio .portfolio-item span,
  .portfolio-grid.premium-portfolio .portfolio-item span {
    font-size: .64rem !important;
    letter-spacing: .22em !important;
  }

  .premium-portfolio.editorial-portfolio .portfolio-item strong,
  .portfolio-grid.premium-portfolio .portfolio-item strong {
    font-size: clamp(1.15rem, 5vw, 1.55rem) !important;
    max-width: 20ch !important;
  }
}

@media (max-width: 390px) {
  .work.section { padding-left: 1rem !important; padding-right: 1rem !important; }
  .premium-portfolio.editorial-portfolio .portfolio-item figure,
  .portfolio-grid.premium-portfolio .portfolio-item figure {
    height: 16.5rem !important;
  }
}
