/* =========================================================
   CRE8TIVE STUDIO — styles
   ========================================================= */
:root{
  --black:#0a0a0a;
  --ink:#111111;
  --yellow:#D4FF3A;        /* vivid yellow — use on dark bg only */
  --yellow-2:#DFFF4B;
  --yellow-ink:#8FB800;    /* darker chartreuse — use for TEXT on light bg */
  --yellow-stroke:#B8E600; /* brush/underline on light bg — still punchy but visible */
  --bone:#f3f2ee;
  --bone-2:#e9e8e3;
  --muted:#6b6b6b;
  --line:#2a2a2a;
  --line-light:#d9d7d0;

  --font-display:"Anton", Impact, "Arial Narrow", sans-serif;
  --font-body:"Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --font-script:"Permanent Marker", "Caveat Brush", cursive;

  --container: 1240px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-body);
  background:var(--black);
  color:#fff;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 44px;
  position:relative;
}

/* ---------------- Buttons ---------------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;
  font-weight:700;font-size:13px;letter-spacing:1px;
  border-radius:2px;
  transition:transform .15s ease, background .15s ease;
  text-transform:uppercase;
}
.btn:hover{transform:translateY(-1px)}
.btn-outline{
  border:2px solid var(--yellow);
  color:var(--yellow);
}
.btn-outline:hover{background:var(--yellow);color:#000}
.btn-solid{
  background:var(--yellow);
  color:#000;
  border:2px solid var(--yellow);
}
.btn-solid:hover{background:var(--yellow-2);border-color:var(--yellow-2)}

.link-arrow{
  display:inline-flex;align-items:center;gap:10px;
  font-weight:700;font-size:12px;letter-spacing:2px;
  border-bottom:1px solid currentColor;
  padding-bottom:6px;
}
.link-arrow.dark{color:#0a0a0a}
.link-arrow.light{color:#fff}

/* ---------------- Rail labels ---------------- */
.rail-label{
  position:absolute;
  left:14px;top:50%;
  transform:translateY(-50%) rotate(-90deg);
  transform-origin:left center;
  font-size:10.5px;font-weight:700;letter-spacing:3px;
  color:#9a9a9a;
  white-space:nowrap;
  padding-left:40px;
}
.rail-label::before{
  content:"";
  position:absolute;left:0;top:50%;
  width:32px;height:1.5px;background:var(--yellow);
}
.rail-label.dark{color:#333}
.rail-label.dark::before{background:#0a0a0a}
.rail-label.yellow-rail{color:#8a8a8a}
.rail-label.yellow-rail::before{background:var(--yellow)}

/* =========================================================
   HEADER
   ========================================================= */
.site-header{
  background:var(--black);
  border-bottom:1px solid rgba(255,255,255,.04);
  position:relative;z-index:50;
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:22px;padding-bottom:22px;
}
.logo{
  display:flex;flex-direction:column;line-height:.9;color:#fff;
}
.logo-lg{
  font-family:var(--font-display);
  font-size:30px;letter-spacing:1px;
}
.logo-accent{color:var(--yellow)}
.logo-sm{
  font-size:11px;letter-spacing:6px;font-weight:600;margin-top:4px;color:#fff;
}
.nav{display:flex;gap:46px}
.nav a{
  font-size:12px;font-weight:600;letter-spacing:2px;color:#fff;
  transition:color .15s;
}
.nav a:hover{color:var(--yellow)}

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;
  background:var(--black);
  padding:40px 0 70px;
  overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1fr 1.05fr;
  gap:40px;
  align-items:flex-start;
}
.hero-copy{padding-top:20px}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  color:var(--yellow);
  font-weight:800;letter-spacing:2.5px;font-size:13px;
  margin-bottom:18px;
  padding-top:14px;
  position:relative;
}
.eyebrow::before{
  content:"";position:absolute;top:0;left:0;width:80px;height:2px;background:var(--yellow);
}
.eyebrow-caret{color:var(--yellow)}

.hero-title{
  margin:0 0 24px;
  font-family:var(--font-display);
  line-height:.88;
  letter-spacing:1px;
}
.hero-title .display{
  display:block;
  font-size:clamp(56px, 8.5vw, 128px);
  color:#fff;
}
.hero-title .script{
  display:inline-block;
  position:relative;
  font-family:var(--font-script);
  color:var(--yellow);
  font-size:clamp(28px, 3.4vw, 48px);
  letter-spacing:1px;
  line-height:1.05;
  margin-top:14px;
  text-transform:uppercase;
  transform:rotate(-2deg);
}
.brush-underline{
  position:absolute;
  left:-6px;right:-6px;bottom:-14px;
  width:calc(100% + 12px);height:22px;
}
.brush-underline.small{height:18px;bottom:-10px}

.hero-desc{
  max-width:460px;
  color:#c6c6c6;
  font-size:15px;line-height:1.65;
  margin:30px 0 34px;
}
.hero-ctas{display:flex;align-items:center;gap:32px}
.watch-reel{
  display:inline-flex;align-items:center;gap:14px;
  font-weight:800;letter-spacing:2px;font-size:13px;color:#fff;
}
.watch-reel .play{
  width:34px;height:34px;border-radius:50%;
  border:1.5px solid #fff;
  display:inline-flex;align-items:center;justify-content:center;
}
.watch-reel .play svg{margin-left:2px}

/* Hero media (right side) */
.hero-media{
  position:relative;
  min-height:620px;
}
.hero-image{
  position:absolute;
  inset:0 90px 60px 0;
  overflow:hidden;
  filter:grayscale(1) contrast(1.05);
}
.hero-image img{
  width:100%;height:100%;object-fit:cover;object-position:center top;
}
.hero-image::after{
  /* dark vignette for cohesion */
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.1), rgba(0,0,0,.55));
  mix-blend-mode:multiply;pointer-events:none;
}

.paint-splatter{
  position:absolute;
  background:var(--yellow);
  pointer-events:none;
  filter:blur(.2px);
}
.paint-splatter.p1{
  width:140px;height:380px;
  left:40%;top:18%;
  clip-path: polygon(30% 0, 55% 3%, 48% 30%, 62% 55%, 40% 80%, 55% 100%, 12% 96%, 28% 70%, 8% 44%, 22% 18%);
  transform:rotate(-8deg);
  opacity:.92;
}
.paint-splatter.p2{
  width:80px;height:220px;
  left:60%;top:40%;
  clip-path: polygon(30% 0, 70% 10%, 45% 40%, 65% 65%, 35% 100%, 0 70%, 25% 35%);
  transform:rotate(6deg);
  opacity:.85;
}
.paint-slash{
  position:absolute;
  top:62%;left:8%;
  width:72%;height:10px;
  background:var(--yellow);
  transform:rotate(-8deg) skewX(-18deg);
  opacity:.8;
  clip-path:polygon(0 40%, 100% 0, 100% 60%, 0 100%);
}

.hero-d-letter{
  position:absolute;
  right:0;top:50px;
  width:240px;height:300px;
  border-radius:50%;
  overflow:hidden;
  filter:grayscale(1) contrast(1.1);
  clip-path: path("M 0 0 L 180 0 Q 240 150 180 300 L 0 300 Z");
}
.hero-d-letter img{width:100%;height:100%;object-fit:cover}

.circle-badge{
  position:absolute;
  right:10px;bottom:-10px;
  width:150px;height:150px;
  display:flex;align-items:center;justify-content:center;
  animation:spin 22s linear infinite;
}
.circle-text{width:100%;height:100%;position:absolute;inset:0}
.circle-arrow{position:relative;z-index:2}
@keyframes spin{to{transform:rotate(360deg)}}

/* =========================================================
   WORK
   ========================================================= */
.work{
  background:var(--bone);
  color:#0a0a0a;
  padding:80px 0 90px;
  position:relative;
}
.work-grid{display:grid;grid-template-columns:300px minmax(0,1fr);gap:40px;align-items:start}
.work-intro{padding-top:8px}

.section-title{
  margin:0;
  font-family:var(--font-display);
  font-size:0;
  line-height:.9;
  letter-spacing:1px;
  color:#0a0a0a;
}
.section-title .display{
  display:block;
  font-size:clamp(40px, 4.8vw, 62px);
}
.section-title .yellow{
  color:var(--yellow-ink);
  position:relative;
  display:inline-block;
}
.section-title .yellow.on-dark{color:var(--yellow)}
.section-title .script{
  display:inline-block;
  font-family:var(--font-script);
  color:var(--yellow-ink);
  font-size:clamp(26px, 3vw, 44px);
  text-transform:uppercase;
  letter-spacing:1px;
  position:relative;
  transform:rotate(-2deg);
}
.section-title .script.dark-script{color:var(--yellow-ink)}
/* Wrapper to let a brush underline sit under just one word */
.underline-word{position:relative;display:inline-block}
.underline-word > .brush-underline{
  position:absolute;
  left:-6px;right:-6px;bottom:-12px;
  width:calc(100% + 12px);height:18px;
  pointer-events:none;
}

.work-intro .muted{color:#333;font-size:14px;margin:20px 0 30px}

.work-cards{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:18px;
  position:relative;
}
.principles{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:2px;
  background:#d6d4cd; /* acts as divider */
  border-top:1px solid #d6d4cd;
  border-bottom:1px solid #d6d4cd;
}
.principle{
  background:var(--bone);
  padding:28px 24px 32px;
  display:flex;flex-direction:column;gap:14px;
  transition:background .2s ease;
}
.principle:hover{background:#fff}
.principle-num{
  font-family:var(--font-display);
  font-size:38px;line-height:1;
  color:var(--yellow-ink);
  letter-spacing:1px;
}
.principle h4{
  margin:0;
  font-family:var(--font-display);
  font-size:22px;letter-spacing:1.5px;
  color:#0a0a0a;line-height:1;
}
.principle p{
  margin:0;
  font-size:13.5px;line-height:1.6;color:#2a2a2a;
}
.carousel-nav{
  position:absolute;top:-60px;right:0;
  display:flex;gap:10px;
}
.cnav{
  width:38px;height:38px;border-radius:50%;
  border:1.5px solid #b9b7b0;background:transparent;color:#0a0a0a;
  display:inline-flex;align-items:center;justify-content:center;cursor:pointer;
  transition:border-color .15s, background .15s;
}
.cnav:hover{border-color:#0a0a0a;background:#0a0a0a;color:#fff}

.work-card h4{
  margin:14px 0 4px;
  font-size:13px;letter-spacing:2px;font-weight:800;
}
.work-card .meta{
  margin:0;font-size:11px;letter-spacing:2px;color:#555;font-weight:600;
}
.work-thumb{
  aspect-ratio:1/1;
  background:#0a0a0a;
  overflow:hidden;
  position:relative;
}
.work-thumb img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(1) contrast(1.1);
  transition:transform .4s ease;
}
.work-thumb:hover img{transform:scale(1.04)}
.work-thumb.yellow-bg{background:var(--yellow)}
.work-thumb.yellow-bg img{mix-blend-mode:multiply;filter:grayscale(1) contrast(1.3)}

/* =========================================================
   SERVICES
   ========================================================= */
.services{
  background:var(--black);
  color:#fff;
  padding:90px 0 100px;
  position:relative;
}
.services .section-title{color:#fff}
.services-grid{
  display:grid;
  grid-template-columns:minmax(280px, 380px) 1fr;
  column-gap:60px;
  row-gap:40px;
  align-items:start;
}
.services-intro{display:flex;flex-direction:column;gap:16px}
.tag-label{
  display:inline-flex;align-items:center;
  font-size:11px;letter-spacing:3px;font-weight:800;
  color:var(--yellow);
  padding-top:12px;
  position:relative;
  width:fit-content;
}
.tag-label::before{
  content:"";position:absolute;top:0;left:0;width:60px;height:2px;background:var(--yellow);
}
.services-copy{
  display:flex;flex-direction:column;gap:18px;
  max-width:620px;padding-top:10px;
}
.services-lede{
  margin:0;
  font-family:var(--font-body);
  font-size:clamp(20px, 1.6vw, 24px);
  line-height:1.35;
  color:#fff;
  font-weight:500;
  letter-spacing:-.2px;
}
.services-sub{
  margin:0;
  font-size:14.5px;line-height:1.65;
  color:#a8a8a8;
  max-width:540px;
}

.service-items{
  grid-column:1 / -1;
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:32px;
  margin-top:44px;
  border-top:1px solid #262626;
  padding-top:38px;
  position:relative;
}
.service-items::before{
  content:"";position:absolute;inset:0;pointer-events:none;
}
.service-item{
  padding-left:18px;
  border-left:1px solid #262626;
  position:relative;
}
.service-item:first-child{border-left:none;padding-left:0}
.service-icon{color:var(--yellow);margin-bottom:16px}
.service-item h5{
  color:var(--yellow);
  font-size:13px;letter-spacing:2px;margin:0 0 12px;font-weight:800;
}
.service-item p{margin:0;font-size:13px;line-height:1.55;color:#c6c6c6}

/* =========================================================
   PROCESS
   ========================================================= */
.process{
  background:var(--bone);
  color:#0a0a0a;
  padding:80px 0 70px;
  position:relative;
  overflow:hidden;
}
.process-grid{
  display:grid;
  grid-template-columns:320px 1fr 240px;
  gap:40px;
  align-items:start;
}
.process .section-title{color:#0a0a0a}
.process .section-title .script{color:#0a0a0a}
.process .section-title .script::after{}

/* Process-specific: "impact" is yellow script */
.process .section-title .dark-script{
  color:var(--yellow-ink);
  font-size:clamp(38px, 4.6vw, 64px);
  text-transform:lowercase;
  font-weight:400;
  margin-top:6px;
}

.steps{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:20px;
  padding-top:10px;
}
.step{position:relative;padding-right:10px}
.step-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.step-num{
  font-family:var(--font-display);
  font-size:40px;letter-spacing:1px;color:#0a0a0a;
}
.step-arrow{margin-left:6px}
.step h5{
  margin:0 0 10px;
  font-size:13px;letter-spacing:2px;font-weight:800;color:#0a0a0a;
}
.step p{margin:0;font-size:13px;line-height:1.55;color:#262626;max-width:170px}

.skater{
  position:relative;
  width:240px;height:220px;
  align-self:end;
  margin-top:-20px;
}
.skater img{
  width:100%;height:100%;object-fit:cover;object-position:center;
  filter:grayscale(1) contrast(1.1);
}
.paint-sweep{
  position:absolute;
  left:-70px;top:20px;
  width:300px;height:28px;
  background:var(--yellow);
  clip-path: polygon(0 45%, 100% 0, 98% 55%, 2% 100%);
  transform:rotate(-12deg);
  z-index:3;
  pointer-events:none;
  box-shadow:0 0 0 1px rgba(0,0,0,0);
}

/* =========================================================
   TRUSTED BY
   ========================================================= */
.trusted{
  background:var(--black);
  color:#fff;
  padding:80px 0 90px;
  position:relative;
}
.trusted-grid{
  display:grid;grid-template-columns: minmax(280px, 380px) 1fr;
  gap:60px;
  align-items:start;
}
.trusted .section-title{color:#fff}
.trusted-lede{
  margin:26px 0 0;
  font-size:15px;line-height:1.6;
  color:#b6b6b6;
  max-width:360px;
}

.compare{
  display:flex;flex-direction:column;
  padding-top:6px;
}
.compare-head{
  display:grid;
  grid-template-columns: 1fr 40px 1fr;
  align-items:center;
  padding:0 0 14px;
  border-bottom:1px solid #1f1f1f;
}
.compare-col-label{
  font-size:10.5px;letter-spacing:3px;font-weight:800;
  color:#6a6a6a;
}
.compare-col-label.compare-left{grid-column:1}
.compare-col-label.compare-right{grid-column:3;color:var(--yellow)}
.compare-row{
  display:grid;
  grid-template-columns: 1fr 40px 1fr;
  align-items:center;
  padding:18px 0;
  border-bottom:1px solid #1a1a1a;
  transition:background .2s ease;
}
.compare-row:last-child{border-bottom:none}
.compare-row:hover{background:#0f0f0f}
.compare-row .compare-left{
  color:#8a8a8a;
  font-size:14.5px;line-height:1.45;
  text-decoration:line-through;
  text-decoration-color:#3a3a3a;
}
.compare-row .compare-right{
  color:#fff;
  font-size:15.5px;line-height:1.45;
  font-weight:500;
}
.compare-arrow{
  color:var(--yellow);
  display:flex;justify-content:center;
}

/* =========================================================
   CTA / CONTACT
   ========================================================= */
.cta{
  background:var(--bone);
  color:#0a0a0a;
  padding:70px 0 80px;
  position:relative;
  overflow:hidden;
}
.cta-grid{
  display:grid;
  grid-template-columns: 1.1fr 1fr 1.1fr;
  gap:40px;
  align-items:center;
}
.cta .section-title{color:#0a0a0a}
.cta .dark-script{
  color:var(--yellow-ink);
  font-family:var(--font-script);
  font-size:clamp(32px, 3.6vw, 52px);
  text-transform:lowercase;
  font-weight:400;
  letter-spacing:1px;
  margin-top:6px;
}

.cta-mid p{
  margin:0 0 26px;color:#262626;font-size:14px;line-height:1.6;
}
.email-cta{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--font-display);
  font-size:clamp(20px, 2.2vw, 28px);
  letter-spacing:1.5px;
  color:#0a0a0a;
  border-bottom:2px solid #0a0a0a;
  padding-bottom:8px;
  transition:color .15s, border-color .15s, transform .15s;
}
.email-cta:hover{
  color:var(--yellow-ink);
  border-color:var(--yellow-ink);
  transform:translateX(2px);
}

.cta-right{
  position:relative;
  height:210px;
}
.skyline{
  position:absolute;inset:0;
  filter:grayscale(1) contrast(1.1);
  overflow:hidden;
}
.skyline img{
  width:100%;height:100%;object-fit:cover;object-position:center;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 15%, #000 100%);
          mask-image: linear-gradient(90deg, transparent 0%, #000 15%, #000 100%);
}
.paint-ribbon{
  position:absolute;
  left:-10px;top:-10px;
  width:360px;height:160px;
  background:
    radial-gradient(ellipse at 30% 40%, transparent 60px, var(--yellow) 60px, var(--yellow) 66px, transparent 66px),
    radial-gradient(ellipse at 70% 70%, transparent 40px, var(--yellow) 40px, var(--yellow) 46px, transparent 46px);
  opacity:.9;
  transform:rotate(-6deg);
  mix-blend-mode:normal;
  pointer-events:none;
  mask-image: conic-gradient(from 0deg, #000 0deg, transparent 320deg);
}
.stamp{
  position:absolute;
  right:20px;top:50%;
  transform:translateY(-50%);
  width:150px;height:150px;
  border-radius:50%;
  background:#0a0a0a;
  color:#fff;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:6px;
  z-index:2;
}
.stamp-lg{
  font-family:var(--font-display);
  font-size:28px;letter-spacing:1px;line-height:.9;
}
.stamp-accent{color:var(--yellow)}
.stamp-sm{font-size:10px;letter-spacing:5px;font-weight:700}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{
  background:var(--black);
  color:#c8c8c8;
  padding:70px 0 28px;
  border-top:1px solid #1a1a1a;
}
.footer-inner{
  display:grid;
  grid-template-columns:1.2fr 1fr 1fr;
  gap:60px;
  padding-bottom:50px;
  border-bottom:1px solid #1a1a1a;
}
.footer-brand{display:flex;flex-direction:column;gap:22px}
.footer-tagline{
  margin:0;
  font-size:14px;line-height:1.6;
  color:#a0a0a0;
}
.footer-tagline .heart{color:var(--yellow)}

.footer-label{
  display:block;
  font-size:11px;letter-spacing:3px;font-weight:800;
  color:var(--yellow);
  margin-bottom:14px;
  padding-top:12px;
  position:relative;
  width:fit-content;
}
.footer-label::before{
  content:"";position:absolute;top:0;left:0;width:32px;height:2px;background:var(--yellow);
}

.footer-address{
  font-style:normal;
  font-size:14px;line-height:1.7;
  color:#c8c8c8;
}
.footer-contact a{
  font-size:15px;
  color:#fff;
  border-bottom:1px solid #2a2a2a;
  padding-bottom:4px;
  transition:border-color .15s, color .15s;
}
.footer-contact a:hover{color:var(--yellow);border-color:var(--yellow)}

.footer-bottom{
  padding-top:22px;
  font-size:12px;letter-spacing:.3px;color:#6a6a6a;
}
.footer-bottom p{margin:0}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width: 1100px){
  .container{padding:0 32px}
  .hero-grid{grid-template-columns:1fr}
  .hero-media{min-height:520px;margin-top:30px}
  .work-grid,.services-grid,.process-grid,.trusted-grid,.cta-grid{
    grid-template-columns:1fr;gap:40px;
  }
  .work-cards,.service-items,.steps,.principles{
    grid-template-columns:repeat(2,1fr);
  }
  .footer-inner{grid-template-columns:1fr;gap:36px}
  .compare-head,.compare-row{grid-template-columns: 1fr 28px 1fr}
  .service-item{border-left:none;padding-left:0}
  .skater{width:100%;max-width:320px}
  .cta-right{height:240px}
  .nav{display:none}
}
@media (max-width: 640px){
  .work-cards,.service-items,.steps,.principles{
    grid-template-columns:1fr;
  }
  .hero-title .display{font-size:64px}
  .header-inner .btn{padding:10px 16px;font-size:11px}
}
