/* Fonts */
@import url("https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600&family=Open+Sans:wght@300;400;600&display=swap");

:root{
  --bg: #ffffff;
  --text: #111111;
  --muted: #555555;
  --border: rgba(0,0,0,.10);

  --max: 1180px;

  /* This is the horizontal padding used by the main content column */
  --gutter: 18px;

  /* Old site orange */
  --orange: #ff5a01;

  /* Thumbnail overlays */
  --overlay: rgba(0,0,0,.18);
  --overlayHover: rgba(0,0,0,.26);
}

*{ box-sizing: border-box; }
html, body { height: 100%; }

body{
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: "Open Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height: 1.5;
}

a{ color: inherit; text-decoration: none; }

/* =====================================================
   HEADER
===================================================== */

.site-header{
  background: transparent;
}

.site-header-inner{
  max-width: calc(var(--max) - (var(--gutter) * 2));
  margin: 0 auto;
  background: #262626;
}

.nav{
  padding: 18px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.brand{
  display: flex;
  flex-direction: column;
  padding-left: 50px;
}

.brand-name{
  font-family: "Open Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 400;
  font-size: 30px;
  line-height: 30px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--orange);
  margin: 0;
}

.brand-role{
  font-family: "Open Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 400;
  font-size: 18px;
  line-height: 18px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #ffffff;
  margin: 0;
}

.nav-links{
  display: flex;
  gap: 22px;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 500;
  font-size: 14px;
  line-height: 14px;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding-right: 50px;
}

.nav-links a{ color: var(--orange); }
.nav-links a[aria-current="page"]{ color: #ffffff; }

@media (max-width: 760px){
  .site-header-inner{ max-width: 100%; }
  .nav{ padding: 16px 14px; }
  .brand{ padding-left: 0; }
  .nav-links{ padding-right: 0; }

  .brand-name{
    font-size: 22px;
    line-height: 22px;
    letter-spacing: 2px;
  }

  .brand-role{
    font-size: 13px;
    line-height: 13px;
    letter-spacing: 2px;
  }

  .nav-links{
    font-size: 12px;
    line-height: 12px;
    gap: 16px;
  }
}

/* =====================================================
   LAYOUT
===================================================== */

.site-main{
  max-width: var(--max);
  margin: 0 auto;
  padding: 8px var(--gutter) 6px;
}

/* =====================================================
   ABOUT
===================================================== */

.about-inner{
  max-width: calc(var(--max) - (var(--gutter) * 2));
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.about-grid{
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 26px;
  align-items: start;
  margin-top: 6px; /* keeps page tight under header */
}

.about-prose{
  max-width: 760px;
  margin: 0;
  text-align: left;
}

.about-prose p{
  margin: 0 0 14px;
  line-height: 1.6;
}

.about-prose p:first-child{
  margin-top: 0;
}

.about-form{
  border: 1px solid rgba(0,0,0,0.10);
  background: #fff;
  padding: 16px 16px 14px;
}

.about-form-head{
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(0,0,0,0.10);
}

.about-form-title{
  font-family: var(--mont, Montserrat, system-ui);
  font-size: 13px;
  letter-spacing: 1px;
  text-transform: uppercase;
  font-weight: 600;
}

.about-form-meta{
  font-family: var(--mont, Montserrat, system-ui);
  font-size: 11px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 500;
}

/* Honeypot visually hidden but present in DOM */
.hp-field{
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.contact-form{
  margin: 0;
}

.form-row{
  margin: 0 0 12px;
}

.form-actions{
  margin-top: 14px;
}

.form-label{
  display: block;
  font-family: var(--mont, Montserrat, system-ui);
  font-size: 12px;
  letter-spacing: 1px;
  text-transform: uppercase;
  font-weight: 600;
  color: #111;
}

.form-field{
  display: block;
  width: 100%;
  margin-top: 7px;
  padding: 11px 12px;
  border: 1px solid rgba(0,0,0,0.18);
  border-radius: 6px;
  background: #fff;
  color: #111;
  font: 400 14px/1.35 var(--sans, "Open Sans", system-ui);
}

.form-textarea{
  min-height: 140px;
  resize: vertical;
}

.form-field:focus,
.form-field:focus-visible{
  outline: none;
  border-color: rgba(255,90,1,0.75);
  box-shadow: 0 0 0 3px rgba(255,90,1,0.18);
}

.form-field::placeholder{
  color: rgba(0,0,0,0.45);
}

.form-button{
  display: inline-block;
  padding: 11px 16px;
  border: 0;
  border-radius: 6px;
  background: #262626;
  color: #fff;
  font-family: var(--mont, Montserrat, system-ui);
  font-size: 13px;
  letter-spacing: 1px;
  text-transform: uppercase;
  font-weight: 600;
  cursor: pointer;
}

.form-button:hover{
  background: #111;
}

.form-button:focus,
.form-button:focus-visible{
  outline: none;
  box-shadow: 0 0 0 3px rgba(255,90,1,0.22);
}

/* Responsive: collapse to one column (match header breakpoint philosophy) */
@media (max-width: 760px){
  .about-grid{
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .about-form{
    padding: 14px 14px 12px;
  }
}

/* =====================================================
   ABOUT — POLISH TWEAKS
   (panel softening + orange hover + borderless form)
===================================================== */

/* Soften form panel background */
.about-form{
  background: #fafafa;
  border: none;
}

/* Orange hover for brand alignment */
.form-button:hover{
  background: var(--orange);
  color: #111;
}

/* Optional: slightly tighten visual weight now that border is gone */
.about-form{
  box-shadow: 0 0 0 1px rgba(0,0,0,0.06);
}

/* =====================================================
   ABOUT — LEAD PARAGRAPH
===================================================== */

.about-lead{
  font-size: 16px;
  line-height: 1.65;
  margin-bottom: 16px;
}

.about-lead strong{
  font-weight: 700;
}

/* =====================================================
   ABOUT — SUBTLE UPGRADES
   (column balance + lead rhythm + top tightening)
===================================================== */

.about-grid{
  grid-template-columns: 1.2fr 0.8fr;
}

/* Lead paragraph rhythm refinement */
.about-lead{
  margin-bottom: 18px;
}

.about-lead + p{
  margin-top: -2px;
}

/* Slightly tighter relationship to header */
.about-page{
  margin-top: -6px;
}

/* =====================================================
   THANKS
===================================================== */

.thanks-inner{
  max-width: calc(var(--max) - (var(--gutter) * 2));
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.thanks-box{
  max-width: 520px;
  margin: 80px auto 90px;
  text-align: center;
}

.thanks-title{
  font-family: var(--mont, Montserrat, system-ui);
  font-size: 20px;
  letter-spacing: 3px;
  text-transform: uppercase;
  font-weight: 600;
  margin: 0 0 14px;
}

.thanks-message{
  font-family: var(--sans, "Open Sans", system-ui);
  font-size: 15px;
  line-height: 1.55;
  color: #222;
  margin: 0 0 24px;
}

.thanks-action{
  margin: 0;
}

.thanks-link{
  font-family: var(--mont, Montserrat, system-ui);
  font-size: 13px;
  letter-spacing: 1px;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--orange);
  text-decoration: none;
}

.thanks-link:hover{
  text-decoration: underline;
}

/* Tighten on small screens */
@media (max-width: 760px){
  .thanks-box{
    margin: 60px auto 70px;
  }
}

/* =====================================================
   FOOTER
===================================================== */

.site-footer{
  background: transparent;
  max-width: none;
  margin: 0;
  padding: 0;
  border-top: 0;
}

.site-footer-inner{
  max-width: calc(var(--max) - (var(--gutter) * 2));
  margin: 0 auto;
  background: #262626;
  padding: 40px 14px;
  text-align: center;
  color: #ffffff;
}

.rep-title{
  margin: 0 0 10px;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 500;
  font-size: 20px;
  line-height: 20px;
  letter-spacing: 1px;
  text-transform: uppercase;
}

.rep-list{
  list-style: none;
  margin: 0;
  padding: 0;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 500;
  font-size: 14px;
  line-height: 14px;
  letter-spacing: 1px;
  text-transform: uppercase;
}

.rep-list li + li{ margin-top: 8px; }
.rep-list a{ color: var(--orange); }

@media (max-width: 760px){
  .site-footer-inner{ max-width: 100%; }
}

/* =====================================================
   GRID
===================================================== */

.grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:10px;
  padding: 0;
}

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

@media (max-width: 560px){
  .grid{ grid-template-columns: 1fr; }
}

/* =====================================================
   THUMBNAILS
===================================================== */

.card{
  display:block;
  color:inherit;
}

.card-media{
  position:relative;
  aspect-ratio: 10 / 7;
  overflow:hidden;
  background:#111;
}

.card-media img{
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center;
  display:block;
}

.card.is-outlier .card-media img{
  object-fit:cover;
}

.card-media::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(
    to top,
    rgba(0,0,0,0.45) 0%,
    rgba(0,0,0,0.22) 28%,
    rgba(0,0,0,0.10) 48%,
    rgba(0,0,0,0.00) 68%
  );
  z-index: 1;
  pointer-events:none;
}

.card-meta{
  position:absolute;
  inset: 0;
  display:flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 18px;
  z-index: 2;
  pointer-events:none;
}

.card-head{
  margin:0;
  font-family:"Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 20px;
  line-height: 1.05;
  letter-spacing: .02em;
  text-transform: uppercase;
  color: #ffffff;
  text-shadow: 0 1px 14px rgba(0,0,0,.35);
}

.card-brand,
.card-title-text{
  display:block;
}

.card-subhed{
  margin: 8px 0 0;
  font-family:"Open Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 400;
  font-size: 15px;
  line-height: 1.2;
  color: rgba(255,255,255,0.92);
  text-shadow: 0 1px 14px rgba(0,0,0,.35);
}

.card-overlay{
  position:absolute;
  inset:0;
  background: var(--overlayHover);
  opacity: 0;
  transition: opacity 160ms ease;
  z-index: 3;
  pointer-events:none;
}

.card:hover .card-overlay,
.card:focus-within .card-overlay{
  opacity: 1;
}

/* =====================================================
   PROJECT PAGES
===================================================== */

/* Title: centered, two-line, all-caps */
.project-title{
  margin: 26px 0 18px;
  text-align: center;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 600;
  letter-spacing: .02em;
  text-transform: uppercase;
}

.project-title-brand,
.project-title-spot{
  display: block;
}

.project-title-brand,
.project-title-spot{
  font-size: 26px;
  line-height: 1.08;
}

.project-title-brand{
  margin-bottom: 6px;
}

/* Responsive video embed (fixes tiny iframe) */
.video{
  position: relative;
  width: 100%;
  max-width: 980px;
  margin: 0 auto;
  aspect-ratio: 16 / 9;
  background: #000;
}

.video iframe{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

/* Credits under video */
.project-credits{
  max-width: 980px;
  margin: 14px auto 0;
  text-align: left;
}

.project-agency{
  font-family: "Open Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 400;
  color: #111;
  margin: 0 0 4px;
}

.project-subline{
  font-family: "Open Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 400;
  color: var(--muted);
}

/* Featured strip header row */
.featured-strip{
  margin-top: 26px;
}

.section-head{
  max-width: var(--max);
  margin: 0 auto 10px;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}

.section-title{
  margin: 0;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 14px;
  line-height: 14px;
  letter-spacing: 1px;
  text-transform: uppercase;
}

.section-more{
  color: inherit;
}

.section-more:hover{
  text-decoration: underline;
}

/* Featured thumbnails: force 4-up (fixes 3+1 wrap) */
.featured-grid{
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

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

@media (max-width: 560px){
  .featured-grid{
    grid-template-columns: 1fr;
  }
}

/* =====================================================
   CONTACT FORM
===================================================== */

.contact-form{
  max-width: 760px;
  margin: 40px auto 0;
}

.contact-form p{
  margin: 0 0 16px;
}

.contact-form label{
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 14px;
  letter-spacing: 1px;
  text-transform: uppercase;
}

.contact-form input,
.contact-form textarea{
  width: 100%;
  margin-top: 6px;
  padding: 10px 12px;
  font-family: "Open Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 15px;
  border: 1px solid var(--border);
  border-radius: 0;
  background: #ffffff;
  color: var(--text);
}

.contact-form textarea{
  resize: vertical;
}

.contact-form button{
  background: #262626;
  color: #ffffff;
  border: none;
  padding: 12px 24px;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 14px;
  letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
}

.contact-form button:hover{
  opacity: 0.85;
}

/* =====================================================
   Honeypot (anti-spam)
   ===================================================== */

.hp-field{
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
}