:root {
    --ink: #111315;
    --charcoal: #1e2126;
    --steel: #2a2f38;
    --flame: #e04e1f;
    --ember: #f06535;
    --cream: #f4efe6;
    --smoke: #e8ecf0;
    --mist: #f0f2f5;
    --white: #ffffff;
    --gold: #c8a96e;
    --ff-display: 'Bebas Neue', sans-serif;
    --ff-editorial: 'Playfair Display', serif;
    --ff-body: 'DM Sans', sans-serif;
  }

  *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

  html { scroll-behavior: smooth; }

  body {
    background: var(--ink);
    color: var(--cream);
    font-family: var(--ff-body);
    font-weight: 300;
    overflow-x: hidden;
    cursor: none;
  }

  /* ── CURSOR ── */
  .cursor {
    position: fixed;
    width: 14px; height: 14px;
    background: #e04e1f;
    border-radius: 50%;
    pointer-events: none;
    z-index: 9999;
    transform: translate(-50%,-50%);
    transition: width 0.15s ease, height 0.15s ease, background 0.15s ease;
    box-shadow: 0 0 12px rgba(224,78,31,0.8), 0 0 4px rgba(224,78,31,1);
  }
  .cursor-ring {
    position: fixed;
    width: 44px; height: 44px;
    border: 2px solid rgba(224,78,31,0.75);
    border-radius: 50%;
    pointer-events: none;
    z-index: 9998;
    transform: translate(-50%,-50%);
    transition: width 0.25s ease, height 0.25s ease, opacity 0.2s ease, border-color 0.2s ease;
    box-shadow: 0 0 8px rgba(224,78,31,0.3);
  }
  body:hover .cursor { opacity: 1; }

  /* ── GRAIN OVERLAY ── */
  body::before {
    content: '';
    position: fixed;
    inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");
    opacity: 0.025;
    pointer-events: none;
    z-index: 9997;
    animation: grain 0.5s steps(1) infinite;
  }
  @keyframes grain {
    0%,100%{transform:translate(0,0)}
    10%{transform:translate(-2%,-3%)}
    20%{transform:translate(3%,2%)}
    30%{transform:translate(-1%,4%)}
    40%{transform:translate(2%,-1%)}
    50%{transform:translate(-3%,3%)}
    60%{transform:translate(1%,-2%)}
    70%{transform:translate(-2%,1%)}
    80%{transform:translate(3%,-3%)}
    90%{transform:translate(-1%,2%)}
  }

  /* ── NAV ── */
  .nav-stripe-orange { position:fixed;top:0;left:0;right:0;height:36px;background:#e04e1f;z-index:1001; }
  .nav-stripe-silver { position:fixed;top:48px;left:0;right:0;height:36px;background:#b0b7c3;z-index:1001; }
  nav {
    position: fixed;
    top: 72px; left: 0; right: 0;
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 48px;
    height: 80px;
    background: rgba(17,19,21,0.0);
    transition: background 0.4s ease;
  }
  nav.scrolled {
    background: rgba(17,19,21,0.97);
    backdrop-filter: blur(20px);
  }
  .nav-logo {
    display: flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
  }
  .nav-logo-mark {
    width: 42px; height: 42px;
    position: relative;
  }
  .nav-logo-mark svg { width: 100%; height: 100%; }
  .nav-logo-text {
    display: flex;
    flex-direction: column;
    line-height: 1;
  }
  .nav-logo-text span:first-child {
    font-family: var(--ff-display);
    font-size: 18px;
    letter-spacing: 0.1em;
    color: var(--white);
  }
  .nav-logo-text span:last-child {
    font-size: 9px;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: #e0e4ea;
    margin-top: 2px;
  }
  .nav-links {
    display: flex;
    align-items: center;
    gap: 36px;
    list-style: none;
  }
  .nav-links a {
    color: #f0f2f5;
    text-decoration: none;
    font-size: 11px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    transition: color 0.2s;
  }
  .nav-links a:hover { color: var(--flame); }
  .nav-cta {
    background: var(--flame);
    color: var(--white) !important;
    padding: 10px 24px !important;
    border-radius: 2px;
    letter-spacing: 0.15em !important;
    transition: background 0.2s !important;
  }
  .nav-cta:hover { background: var(--ember) !important; color: var(--white) !important; }

  /* ── HERO ── */
  #hero {
    position: relative;
    height: 100vh;
    min-height: 700px;
    padding-top: 152px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    overflow: hidden;
    background: var(--ink);
  }
  .hero-bg {
    position: absolute;
    inset: 0;
    background:
      radial-gradient(ellipse 60% 50% at 70% 40%, rgba(224,78,31,0.12) 0%, transparent 70%),
      radial-gradient(ellipse 40% 60% at 20% 80%, rgba(200,169,110,0.06) 0%, transparent 60%),
      linear-gradient(180deg, rgba(17,19,21,0) 60%, rgba(17,19,21,1) 100%);
    z-index: 1;
  }
  .hero-grid-lines {
    position: absolute;
    inset: 0;
    background-image:
      linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
      linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);
    background-size: 80px 80px;
    z-index: 0;
  }
  .hero-content {
    position: relative;
    z-index: 2;
    padding: 0 48px 80px;
    max-width: 1400px;
    width: 100%;
  }
  .hero-est {
    font-size: 10px;
    letter-spacing: 0.35em;
    text-transform: uppercase;
    color: var(--flame);
    margin-bottom: 24px;
    opacity: 0;
    transform: translateY(20px);
    animation: fadeUp 0.8s 0.3s forwards;
  }
  .hero-h1 {
    font-family: var(--ff-display);
    font-size: clamp(80px, 10vw, 160px);
    line-height: 0.9;
    letter-spacing: 0.02em;
    color: var(--white);
    margin-bottom: 8px;
    opacity: 0;
    transform: translateY(40px);
    animation: fadeUp 0.9s 0.5s forwards;
  }
  .hero-h1 .accent { color: var(--flame); }
  .hero-sub {
    font-family: var(--ff-editorial);
    font-style: italic;
    font-size: clamp(18px, 2.5vw, 32px);
    color: #eceef2;
    margin-bottom: 48px;
    opacity: 0;
    transform: translateY(20px);
    animation: fadeUp 0.8s 0.7s forwards;
  }
  .hero-actions {
    display: flex;
    align-items: center;
    gap: 32px;
    opacity: 0;
    animation: fadeUp 0.8s 0.9s forwards;
  }
  .btn-primary {
    background: var(--flame);
    color: var(--white);
    padding: 16px 40px;
    font-family: var(--ff-body);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    text-decoration: none;
    border-radius: 2px;
    transition: background 0.2s, transform 0.2s;
    display: inline-block;
  }
  .btn-primary:hover { background: var(--ember); transform: translateY(-2px); }
  .btn-ghost {
    color: #edf0f4;
    font-size: 11px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 10px;
    transition: color 0.2s;
  }
  .btn-ghost:hover { color: var(--white); }
  .btn-ghost::before {
    content: '';
    width: 32px; height: 1px;
    background: currentColor;
    transition: width 0.2s;
  }
  .btn-ghost:hover::before { width: 48px; }
  .hero-stats {
    position: absolute;
    right: 48px;
    bottom: 80px;
    z-index: 2;
    display: flex;
    flex-direction: column;
    gap: 28px;
    opacity: 0;
    animation: fadeIn 1s 1.2s forwards;
  }
  .hero-stat {
    text-align: right;
  }
  .hero-stat-num {
    font-family: var(--ff-display);
    font-size: 36px;
    color: var(--white);
    letter-spacing: 0.05em;
    line-height: 1;
  }
  .hero-stat-num span { color: var(--flame); }
  .hero-stat-label {
    font-size: 9px;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: #dde1e8;
    margin-top: 2px;
  }
  .hero-scroll-hint {
    position: absolute;
    bottom: 32px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    opacity: 0;
    animation: fadeIn 1s 1.5s forwards;
  }
  .hero-scroll-hint span {
    font-size: 9px;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: #e0e4ea;
  }
  .scroll-line {
    width: 1px; height: 48px;
    background: linear-gradient(to bottom, var(--flame), transparent);
    animation: scrollPulse 2s infinite;
  }
  @keyframes scrollPulse {
    0%,100%{opacity:0.3;transform:scaleY(1)}
    50%{opacity:1;transform:scaleY(1.1)}
  }

  @keyframes fadeUp {
    to { opacity:1; transform:translateY(0); }
  }
  @keyframes fadeIn {
    to { opacity:1; }
  }

  /* ── MARQUEE ── */
  .marquee-section {
    background: var(--charcoal);
    border-top: 1px solid rgba(255,255,255,0.05);
    border-bottom: 1px solid rgba(255,255,255,0.05);
    padding: 16px 0;
    overflow: hidden;
  }
  .marquee-track {
    display: flex;
    gap: 0;
    animation: marqueeScroll 30s linear infinite;
    width: max-content;
  }
  .marquee-track:hover { animation-play-state: paused; }
  @keyframes marqueeScroll {
    from { transform: translateX(0); }
    to { transform: translateX(-50%); }
  }
  .marquee-item {
    white-space: nowrap;
    padding: 0 40px;
    font-size: 10px;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: #e0e4ea;
    display: flex;
    align-items: center;
    gap: 40px;
    transition: color 0.2s;
  }
  .marquee-item::after {
    content: '✦';
    color: var(--flame);
    font-size: 8px;
  }

  /* ── SECTIONS SHARED ── */
  section { position: relative; }

  .container {
    max-width: 1320px;
    margin: 0 auto;
    padding: 0 48px;
  }

  .section-label {
    font-size: 10px;
    letter-spacing: 0.35em;
    text-transform: uppercase;
    color: var(--flame);
    margin-bottom: 20px;
    display: flex;
    align-items: center;
    gap: 16px;
  }
  .section-label::before {
    content: '';
    width: 24px; height: 1px;
    background: var(--flame);
  }

  .section-h2 {
    font-family: var(--ff-display);
    font-size: clamp(48px, 5vw, 80px);
    letter-spacing: 0.03em;
    color: var(--white);
    line-height: 1;
    margin-bottom: 24px;
  }

  .section-h2 em {
    font-style: normal;
    color: var(--flame);
  }

  .section-body {
    font-size: 16px;
    line-height: 1.8;
    color: #eceef2;
    max-width: 560px;
  }

  /* ── ABOUT / INTRO ── */
  #about {
    padding: 140px 0;
  }
  .about-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
  }
  .about-quote {
    font-family: var(--ff-editorial);
    font-style: italic;
    font-size: clamp(24px, 2.5vw, 36px);
    line-height: 1.5;
    color: #ffffff;
    border-left: 2px solid var(--flame);
    padding-left: 32px;
  }
  .about-body {
    color: #eceef2;
    font-size: 16px;
    line-height: 1.9;
    margin-bottom: 32px;
  }
  .about-values {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    margin-top: 48px;
  }
  .value-card {
    padding: 28px;
    background: var(--charcoal);
    border: 1px solid rgba(255,255,255,0.06);
    border-top: 2px solid var(--flame);
    border-radius: 2px;
    transition: transform 0.3s, border-color 0.3s;
  }
  .value-card:hover {
    transform: translateY(-4px);
    border-top-color: var(--ember);
  }
  .value-card h4 {
    font-family: var(--ff-display);
    font-size: 20px;
    letter-spacing: 0.1em;
    color: var(--white);
    margin-bottom: 10px;
  }
  .value-card p {
    font-size: 13px;
    line-height: 1.7;
    color: #eceef2;
  }

  /* ── VIDEO ── */
  #showreel {
    padding: 80px 0 140px;
  }
  .video-wrapper {
    position: relative;
    border-radius: 4px;
    overflow: hidden;
    background: var(--charcoal);
    border: 1px solid rgba(255,255,255,0.06);
    aspect-ratio: 16/9;
    max-height: 640px;
  }
  .video-wrapper iframe {
    width: 100%;
    height: 100%;
    border: none;
  }
  .video-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(17,19,21,0.6);
    cursor: pointer;
    transition: background 0.3s;
  }
  .video-overlay:hover { background: rgba(17,19,21,0.3); }
  .video-overlay.hidden { display: none; }
  .play-btn {
    width: 80px; height: 80px;
    border: 2px solid rgba(255,255,255,0.8);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.3s, border-color 0.3s;
  }
  .video-overlay:hover .play-btn {
    transform: scale(1.1);
    border-color: var(--flame);
  }
  .play-btn::after {
    content: '';
    width: 0; height: 0;
    border-style: solid;
    border-width: 12px 0 12px 20px;
    border-color: transparent transparent transparent var(--white);
    margin-left: 4px;
  }
  .video-label {
    position: absolute;
    bottom: 24px;
    left: 32px;
    font-size: 10px;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.9);
  }

  /* ── CAPABILITIES ── */
  #capabilities {
    padding: 140px 0;
    background: var(--charcoal);
    border-top: 1px solid rgba(255,255,255,0.04);
  }
  .capabilities-header {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: end;
    margin-bottom: 80px;
  }
  .cap-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1px;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.05);
  }
  .cap-item {
    background: var(--charcoal);
    padding: 36px 28px;
    transition: background 0.3s;
    cursor: default;
  }
  .cap-item:hover { background: var(--steel); }
  .cap-item:hover .cap-num { color: var(--flame); }
  .cap-num {
    font-family: var(--ff-display);
    font-size: 13px;
    letter-spacing: 0.2em;
    color: #e0e4ea;
    margin-bottom: 16px;
    transition: color 0.3s;
  }
  .cap-name {
    font-size: 15px;
    font-weight: 500;
    color: var(--white);
    margin-bottom: 10px;
    line-height: 1.3;
  }
  .cap-desc {
    font-size: 12px;
    line-height: 1.7;
    color: #eceef2;
  }

  /* ── PROJECTS ── */
  #projects {
    padding: 140px 0;
  }
  .projects-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 60px;
  }
  .projects-scroll {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2px;
  }
  .project-card {
    position: relative;
    overflow: hidden;
    background: var(--charcoal);
    aspect-ratio: 4/5;
    cursor: pointer;
    group: true;
  }
  .project-card-bg {
    position: absolute;
    inset: 0;
    transition: transform 0.6s cubic-bezier(0.25,0.46,0.45,0.94);
  }
  .project-card:hover .project-card-bg {
    transform: scale(1.06);
  }
  /* Project color backgrounds since we don't have images */
  .pc-1 .project-card-bg { background: linear-gradient(135deg, #1a2a1a 0%, #2a3a2a 100%); }
  .pc-2 .project-card-bg { background: linear-gradient(135deg, #1a1a2a 0%, #2a2a3a 100%); }
  .pc-3 .project-card-bg { background: linear-gradient(135deg, #2a1a1a 0%, #3a2a2a 100%); }
  .pc-4 .project-card-bg { background: linear-gradient(135deg, #1a2a2a 0%, #2a3a3a 100%); }
  .pc-5 .project-card-bg { background: linear-gradient(135deg, #2a2a1a 0%, #3a3a2a 100%); }
  .pc-6 .project-card-bg { background: linear-gradient(135deg, #2a1a2a 0%, #3a2a3a 100%); }
  .pc-7 .project-card-bg { background: linear-gradient(135deg, #1a2a1a 0%, #2a3a2a 100%); }
  .project-card-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(17,19,21,0.9) 0%, rgba(17,19,21,0.2) 60%, transparent 100%);
    z-index: 1;
  }
  .project-card-body {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    padding: 32px;
    z-index: 2;
    transform: translateY(8px);
    transition: transform 0.4s ease;
  }
  .project-card:hover .project-card-body { transform: translateY(0); }
  .project-card-num {
    font-family: var(--ff-display);
    font-size: 11px;
    letter-spacing: 0.3em;
    color: var(--flame);
    margin-bottom: 8px;
  }
  .project-card-location {
    font-family: var(--ff-display);
    font-size: 28px;
    letter-spacing: 0.05em;
    color: var(--white);
    line-height: 1;
    margin-bottom: 6px;
  }
  .project-card-attendees {
    font-size: 11px;
    color: #e0e4ea;
    letter-spacing: 0.15em;
  }
  .project-card-deliverables {
    font-size: 12px;
    color: #edf0f4;
    margin-top: 12px;
    line-height: 1.6;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease;
  }
  .project-card:hover .project-card-deliverables {
    max-height: 100px;
  }
  /* Project icon indicators */
  .project-icon {
    position: absolute;
    top: 28px; right: 28px;
    z-index: 2;
    font-size: 32px;
    opacity: 0.6;
    transition: opacity 0.3s, transform 0.3s;
  }
  .project-card:hover .project-icon {
    opacity: 1;
    transform: scale(1.1);
  }

  /* ── COMMANDCENTER ── */
  #commandcenter {
    padding: 140px 0;
    background: var(--charcoal);
    overflow: hidden;
    border-top: 1px solid rgba(255,255,255,0.04);
  }
  .cc-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 100px;
    align-items: center;
  }
  .cc-screen {
    position: relative;
    background: var(--ink);
    border: 1px solid rgba(224,78,31,0.2);
    border-radius: 8px;
    overflow: hidden;
    box-shadow:
      0 0 80px rgba(224,78,31,0.08),
      0 0 0 1px rgba(255,255,255,0.04),
      inset 0 1px 0 rgba(255,255,255,0.06);
  }
  .cc-screen-header {
    background: var(--steel);
    padding: 12px 20px;
    display: flex;
    align-items: center;
    gap: 8px;
    border-bottom: 1px solid rgba(255,255,255,0.06);
  }
  .cc-dot { width: 10px; height: 10px; border-radius: 50%; }
  .cc-dot-1 { background: #ff5f57; }
  .cc-dot-2 { background: #febc2e; }
  .cc-dot-3 { background: #28c840; }
  .cc-screen-title {
    margin-left: 8px;
    font-size: 11px;
    color: #e0e4ea;
    letter-spacing: 0.15em;
  }
  .cc-screen-body {
    padding: 24px;
    font-family: 'Courier New', monospace;
    font-size: 12px;
    line-height: 1.8;
  }
  .cc-line { color: #edf0f4; }
  .cc-line .cmd { color: var(--flame); }
  .cc-line .val { color: #7dd3b0; }
  .cc-line .key { color: #93c5fd; }
  .cc-line .str { color: #fbbf24; }
  .cc-cursor-blink {
    display: inline-block;
    width: 8px; height: 14px;
    background: var(--flame);
    animation: blink 1s infinite;
    vertical-align: middle;
  }
  @keyframes blink { 0%,49%{opacity:1} 50%,100%{opacity:0} }
  .cc-stats-row {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 1px;
    background: rgba(255,255,255,0.04);
    margin: 0 24px 24px;
    border-radius: 4px;
    overflow: hidden;
  }
  .cc-stat {
    background: var(--steel);
    padding: 16px;
    text-align: center;
  }
  .cc-stat-n {
    font-family: var(--ff-display);
    font-size: 22px;
    color: var(--flame);
    letter-spacing: 0.05em;
  }
  .cc-stat-l {
    font-size: 9px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: #e0e4ea;
    margin-top: 2px;
  }
  .cc-features {
    margin-top: 48px;
    display: flex;
    flex-direction: column;
    gap: 20px;
  }
  .cc-feature {
    display: flex;
    gap: 20px;
    align-items: flex-start;
    padding: 20px 24px;
    background: rgba(255,255,255,0.02);
    border: 1px solid rgba(255,255,255,0.04);
    border-left: 2px solid var(--flame);
    border-radius: 2px;
    transition: background 0.3s;
  }
  .cc-feature:hover { background: rgba(255,255,255,0.04); }
  .cc-feature-icon {
    font-size: 20px;
    flex-shrink: 0;
    margin-top: 2px;
  }
  .cc-feature h4 {
    font-size: 14px;
    font-weight: 500;
    color: var(--white);
    margin-bottom: 4px;
  }
  .cc-feature p {
    font-size: 12px;
    line-height: 1.7;
    color: #eceef2;
  }

  /* ── NUMBERS ── */
  #numbers {
    padding: 120px 0;
    background: var(--flame);
  }
  .numbers-grid {
    display: grid;
    grid-template-columns: repeat(4,1fr);
    gap: 1px;
    background: rgba(0,0,0,0.15);
  }
  .number-item {
    background: var(--flame);
    padding: 60px 40px;
    text-align: center;
    transition: background 0.3s;
  }
  .number-item:hover { background: var(--ember); }
  .number-n {
    font-family: var(--ff-display);
    font-size: clamp(52px, 5vw, 80px);
    color: var(--white);
    letter-spacing: 0.03em;
    line-height: 1;
    margin-bottom: 12px;
  }
  .number-l {
    font-size: 10px;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.92);
  }

  /* ── SERVICES / FULFILLMENT ── */
  #services {
    padding: 140px 0;
  }
  .services-header {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    margin-bottom: 80px;
    align-items: end;
  }
  .pricing-grid {
    display: grid;
    grid-template-columns: repeat(2,1fr);
    gap: 2px;
    background: rgba(255,255,255,0.04);
  }
  .pricing-card {
    background: var(--charcoal);
    padding: 40px 36px;
    transition: background 0.3s;
  }
  .pricing-card:hover { background: var(--steel); }
  .pricing-card-icon {
    font-size: 28px;
    margin-bottom: 20px;
  }
  .pricing-card h3 {
    font-family: var(--ff-display);
    font-size: 22px;
    letter-spacing: 0.08em;
    color: var(--white);
    margin-bottom: 12px;
  }
  .pricing-card p {
    font-size: 13px;
    line-height: 1.8;
    color: #eceef2;
    margin-bottom: 20px;
  }
  .pricing-card .price-highlight {
    font-family: var(--ff-display);
    font-size: 18px;
    letter-spacing: 0.08em;
    color: var(--flame);
  }

  /* ── PROCESS ── */
  #process {
    padding: 140px 0;
    background: var(--charcoal);
    border-top: 1px solid rgba(255,255,255,0.04);
  }
  .process-steps {
    display: grid;
    grid-template-columns: repeat(4,1fr);
    gap: 0;
    margin-top: 80px;
    position: relative;
  }
  .process-steps::before {
    content: '';
    position: absolute;
    top: 24px;
    left: 12.5%;
    right: 12.5%;
    height: 1px;
    background: linear-gradient(to right, var(--flame) 0%, rgba(224,78,31,0.2) 100%);
    z-index: 0;
  }
  .process-step {
    padding: 0 24px;
    position: relative;
    z-index: 1;
  }
  .step-dot {
    width: 48px; height: 48px;
    border-radius: 50%;
    background: var(--charcoal);
    border: 2px solid var(--flame);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--ff-display);
    font-size: 18px;
    color: var(--flame);
    letter-spacing: 0.05em;
    margin-bottom: 28px;
    transition: background 0.3s, color 0.3s;
  }
  .process-step:hover .step-dot {
    background: var(--flame);
    color: var(--white);
  }
  .process-step h4 {
    font-family: var(--ff-display);
    font-size: 20px;
    letter-spacing: 0.08em;
    color: var(--white);
    margin-bottom: 12px;
  }
  .process-step p {
    font-size: 13px;
    line-height: 1.8;
    color: #eceef2;
  }

  /* ── CLIENTS ── */
  #clients {
    padding: 140px 0;
  }
  .clients-intro {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 80px;
    align-items: center;
    margin-bottom: 60px;
  }
  .clients-list {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.04);
  }
  .client-item {
    background: var(--charcoal);
    padding: 28px 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.3s;
  }
  .client-item:hover { background: var(--steel); }
  .client-item span {
    font-size: 13px;
    font-weight: 500;
    color: #e0e4ea;
    letter-spacing: 0.08em;
    text-align: center;
    transition: color 0.3s;
  }
  .client-item:hover span { color: var(--white); }

  /* ── CTA ── */
  #cta {
    padding: 160px 0;
    background: var(--ink);
    text-align: center;
    position: relative;
    overflow: hidden;
  }
  #cta::before {
    content: '';
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%,-50%);
    width: 600px; height: 600px;
    background: radial-gradient(circle, rgba(224,78,31,0.12) 0%, transparent 70%);
  }
  .cta-content {
    position: relative;
    z-index: 1;
  }
  .cta-h2 {
    font-family: var(--ff-display);
    font-size: clamp(56px, 7vw, 110px);
    line-height: 0.95;
    letter-spacing: 0.02em;
    color: var(--white);
    margin-bottom: 32px;
  }
  .cta-sub {
    font-family: var(--ff-editorial);
    font-style: italic;
    font-size: 20px;
    color: #eceef2;
    margin-bottom: 48px;
  }
  .cta-actions {
    display: flex;
    justify-content: center;
    gap: 24px;
    flex-wrap: wrap;
  }
  .btn-outline {
    background: transparent;
    border: 1px solid rgba(255,255,255,0.2);
    color: #edf0f4;
    padding: 16px 40px;
    font-family: var(--ff-body);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    text-decoration: none;
    border-radius: 2px;
    transition: border-color 0.2s, color 0.2s;
    display: inline-block;
  }
  .btn-outline:hover { border-color: var(--flame); color: var(--flame); }

  /* ── CONTACT ── */
  #contact {
    padding: 120px 0;
    background: var(--charcoal);
    border-top: 1px solid rgba(255,255,255,0.04);
  }
  .contact-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
  }
  .contact-info h3 {
    font-family: var(--ff-display);
    font-size: 36px;
    letter-spacing: 0.05em;
    color: var(--white);
    margin-bottom: 24px;
  }
  .contact-info p {
    font-size: 15px;
    line-height: 1.9;
    color: #eceef2;
    margin-bottom: 40px;
  }
  .contact-detail {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 16px 0;
    border-bottom: 1px solid rgba(255,255,255,0.05);
  }
  .contact-detail-icon { font-size: 16px; color: var(--flame); }
  .contact-detail a {
    color: #edf0f4;
    text-decoration: none;
    font-size: 14px;
    transition: color 0.2s;
  }
  .contact-detail a:hover { color: var(--flame); }
  .contact-form { display: flex; flex-direction: column; gap: 16px; }
  .form-group { display: flex; flex-direction: column; gap: 8px; }
  .form-group label {
    font-size: 10px;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: #e0e4ea;
  }
  .form-group input,
  .form-group textarea,
  .form-group select {
    background: var(--ink);
    border: 1px solid rgba(255,255,255,0.08);
    color: var(--cream);
    padding: 14px 18px;
    font-family: var(--ff-body);
    font-size: 14px;
    outline: none;
    border-radius: 2px;
    transition: border-color 0.2s;
    appearance: none;
  }
  .form-group input:focus,
  .form-group textarea:focus,
  .form-group select:focus {
    border-color: var(--flame);
  }
  .form-group textarea { resize: vertical; min-height: 120px; }
  .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
  .form-submit {
    background: var(--flame);
    color: var(--white);
    border: none;
    padding: 18px 40px;
    font-family: var(--ff-body);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    cursor: pointer;
    border-radius: 2px;
    transition: background 0.2s;
    width: 100%;
  }
  .form-submit:hover { background: var(--ember); }

  /* ── FOOTER ── */
  footer {
    background: var(--ink);
    padding: 60px 0 0;
  }
  .footer-stripe-silver { height:36px;background:#b0b7c3;width:100%; }
  .footer-stripe-orange { height:36px;background:#e04e1f;width:100%; }
  .footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 60px;
    margin-bottom: 60px;
  }
  .footer-brand p {
    font-size: 13px;
    line-height: 1.8;
    color: #eceef2;
    margin-top: 20px;
    max-width: 280px;
  }
  .footer-col h5 {
    font-size: 10px;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: var(--flame);
    margin-bottom: 20px;
  }
  .footer-col ul { list-style: none; }
  .footer-col li { margin-bottom: 10px; }
  .footer-col a {
    color: #e8ecf0;
    text-decoration: none;
    font-size: 13px;
    transition: color 0.2s;
  }
  .footer-col a:hover { color: var(--white); }
  .footer-bottom {
    padding-top: 28px;
    border-top: 1px solid rgba(255,255,255,0.05);
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .footer-bottom p {
    font-size: 11px;
    color: #c8cdd6;
    letter-spacing: 0.1em;
  }
  .footer-bottom a {
    color: var(--flame);
    text-decoration: none;
  }

  /* ── REVEAL ANIMATIONS ── */
  .reveal {
    opacity: 0;
    transform: translateY(32px);
    transition: opacity 0.8s ease, transform 0.8s ease;
  }
  .reveal.visible {
    opacity: 1;
    transform: translateY(0);
  }
  .reveal-delay-1 { transition-delay: 0.1s; }
  .reveal-delay-2 { transition-delay: 0.2s; }
  .reveal-delay-3 { transition-delay: 0.3s; }
  .reveal-delay-4 { transition-delay: 0.4s; }

  /* ── MOBILE MENU TOGGLE (simplified) ── */
  .menu-toggle {
    display: none;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    padding: 4px;
  }
  .menu-toggle span {
    width: 24px; height: 1.5px;
    background: var(--white);
    transition: transform 0.3s;
  }

  @media (max-width: 1024px) {
    .nav-links { display: none; }
    .menu-toggle { display: flex; }
    .about-grid,
    .cc-grid,
    .services-header,
    .capabilities-header,
    .contact-grid { grid-template-columns: 1fr; gap: 48px; }
    .cap-grid { grid-template-columns: repeat(2,1fr); }
    .projects-scroll { grid-template-columns: repeat(2,1fr); }
    .numbers-grid { grid-template-columns: repeat(2,1fr); }
    .clients-list { grid-template-columns: repeat(3,1fr); }
    .footer-grid { grid-template-columns: 1fr 1fr; gap: 40px; }
    .process-steps { grid-template-columns: repeat(2,1fr); gap: 32px; }
    .process-steps::before { display: none; }
    .container { padding: 0 24px; }
    nav { padding: 20px 24px; }
  }

  @media (max-width: 640px) {
    .hero-stats { display: none; }
    .pricing-grid,
    .clients-list { grid-template-columns: 1fr; }
    .projects-scroll { grid-template-columns: 1fr; }
    .cap-grid { grid-template-columns: 1fr; }
    .numbers-grid { grid-template-columns: repeat(2,1fr); }
    .footer-grid { grid-template-columns: 1fr; }
    .form-row { grid-template-columns: 1fr; }
    .hero-content { padding: 0 24px 60px; }
    .clients-intro { grid-template-columns: 1fr; }
    .about-values { grid-template-columns: 1fr; }
    .process-steps { grid-template-columns: 1fr; }
  }

  /* ── PROJECTS REDESIGN ── */
  .proj-ticker {
    background: var(--flame);
    overflow: hidden;
    padding: 0;
  }
  .proj-ticker-inner {
    display: flex;
    align-items: stretch;
  }
  .pt-item {
    flex: 1;
    padding: 28px 32px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    transition: background 0.2s;
  }
  .pt-item:hover { background: rgba(0,0,0,0.15); }
  .pt-n {
    font-family: var(--ff-display);
    font-size: clamp(28px,3vw,42px);
    color: var(--white);
    letter-spacing: 0.03em;
    line-height: 1;
  }
  .pt-n span { font-size: 0.7em; }
  .pt-l {
    font-size: 10px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.95);
  }
  .pt-div {
    display: flex;
    align-items: center;
    color: rgba(255,255,255,0.25);
    font-size: 10px;
    padding: 0 4px;
  }

  /* Hero projects */
  .proj-hero {
    position: relative;
    overflow: hidden;
    padding: 80px 80px;
    min-height: 480px;
    display: flex;
    align-items: center;
  }
  .proj-hero-watermark {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%,-50%);
    font-family: var(--ff-display);
    font-size: clamp(200px,22vw,340px);
    color: rgba(255,255,255,0.16);
    letter-spacing: -0.02em;
    pointer-events: none;
    white-space: nowrap;
    z-index: 0;
    line-height: 1;
  }
  .proj-hero-content {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    gap: 80px;
    width: 100%;
  }
  .proj-hero-left { flex: 1.4; }
  .proj-hero-right {
    flex: 0.6;
    text-align: right;
  }
  .proj-tag-row {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 20px;
  }
  .proj-tag {
    font-size: 9px;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: #edf0f4;
    border: 1px solid rgba(255,255,255,0.1);
    padding: 5px 12px;
    border-radius: 2px;
  }
  .proj-tag-fire {
    color: var(--flame);
    border-color: rgba(224,78,31,0.3);
    background: rgba(224,78,31,0.08);
  }
  .proj-client {
    font-size: 11px;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: var(--flame);
    margin-bottom: 12px;
  }
  .proj-title {
    font-family: var(--ff-display);
    font-size: clamp(48px,6vw,90px);
    letter-spacing: 0.02em;
    color: var(--white);
    line-height: 0.92;
    margin-bottom: 24px;
  }
  .proj-copy {
    font-size: 15px;
    line-height: 1.85;
    color: #f0f2f5;
    margin-bottom: 28px;
    max-width: 560px;
  }
  .proj-copy strong { color: var(--cream); font-weight: 500; }
  .proj-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }
  .proj-pill {
    font-size: 10px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #f0f2f5;
    background: rgba(255,255,255,0.07);
    border: 1px solid rgba(255,255,255,0.15);
    padding: 6px 14px;
    border-radius: 20px;
    transition: background 0.2s, color 0.2s;
  }
  .proj-pill:hover { background: rgba(224,78,31,0.12); color: var(--flame); }
  .proj-hero-stat-big {
    font-family: var(--ff-display);
    font-size: clamp(52px,6vw,88px);
    color: var(--white);
    letter-spacing: 0.02em;
    line-height: 1;
    margin-bottom: 8px;
  }
  .proj-hero-stat-label {
    font-size: 11px;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: #f0f2f5;
    margin-bottom: 16px;
  }
  .proj-hero-location {
    font-family: var(--ff-editorial);
    font-style: italic;
    font-size: 18px;
    color: #f06535;
  }

  /* 3-up grid */
  .proj-3up {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 4px;
  }
  .proj-block {
    padding: 48px 40px;
    display: flex;
    flex-direction: column;
    min-height: 420px;
    position: relative;
    overflow: hidden;
    transition: transform 0.3s;
  }
  .proj-block:hover { transform: translateY(-4px); }
  .proj-block-num {
    font-family: var(--ff-display);
    font-size: clamp(80px,8vw,120px);
    color: rgba(255,255,255,0.18);
    letter-spacing: 0.02em;
    line-height: 1;
    margin-bottom: 24px;
    transition: color 0.4s;
  }
  .proj-block:hover .proj-block-num { color: rgba(224,78,31,0.35); }
  .proj-block-client {
    font-size: 10px;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: var(--flame);
    margin-bottom: 10px;
  }
  .proj-block-title {
    font-family: var(--ff-display);
    font-size: clamp(22px,2.5vw,34px);
    letter-spacing: 0.05em;
    color: #ffffff;
    margin-bottom: 16px;
    line-height: 1.1;
    text-shadow: 0 1px 20px rgba(0,0,0,0.8);
  }
  .proj-block-copy {
    font-size: 13px;
    line-height: 1.8;
    color: #f0f2f5;
  }
  .proj-block-copy strong { color: var(--cream); font-weight: 500; }

  /* Split panels */
  .proj-split {
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    min-height: 480px;
  }
  .proj-split-rev {
    grid-template-columns: 1.4fr 1fr;
  }
  .proj-split-data {
    padding: 60px 48px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    position: relative;
    overflow: hidden;
    min-height: 420px;
  }
  .proj-split-data > div { position: relative; z-index: 2; }
  .proj-split-giant {
    font-family: var(--ff-display);
    font-size: clamp(100px,12vw,180px);
    color: rgba(255,255,255,0.18);
    letter-spacing: -0.02em;
    line-height: 0.85;
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%,-50%);
    white-space: nowrap;
    transition: color 0.4s;
    z-index: 1;
  }
  .proj-split:hover .proj-split-giant { color: rgba(224,78,31,0.30); }
  .proj-split-body {
    padding: 60px 56px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    color: var(--cream);
  }
  .proj-split-body .proj-client { color: var(--flame); }
  .proj-split-body .proj-title { color: #ffffff; }
  .proj-split-body .proj-copy { color: #f0f2f5; }
  .proj-split-stats {
    display: flex;
    gap: 0;
    margin: 28px 0;
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: 2px;
    overflow: hidden;
  }
  .proj-ss {
    flex: 1;
    padding: 16px 20px;
    text-align: center;
    border-right: 1px solid rgba(255,255,255,0.06);
    font-size: 11px;
    letter-spacing: 0.1em;
    color: #edf0f4;
    text-transform: uppercase;
  }
  .proj-ss:last-child { border-right: none; }
  .proj-ss span {
    display: block;
    font-family: var(--ff-display);
    font-size: 28px;
    color: var(--flame);
    letter-spacing: 0.05em;
    margin-bottom: 4px;
  }

  /* More brands */
  .proj-more-list {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin-top: 24px;
    flex: 1;
  }
  .proj-more-item {
    padding: 18px 0;
    border-bottom: 1px solid rgba(255,255,255,0.05);
  }
  .proj-more-item:last-child { border-bottom: none; }
  .proj-more-brand {
    font-family: var(--ff-display);
    font-size: 20px;
    letter-spacing: 0.1em;
    color: var(--white);
    margin-bottom: 4px;
  }
  .proj-more-desc {
    font-size: 12px;
    color: #edf0f4;
    line-height: 1.5;
  }

  /* International strip */
  .proj-intl {
    display: grid;
    grid-template-columns: 220px 1fr;
    background: var(--charcoal);
    border-top: 4px;
    margin-top: 4px;
  }
  .proj-intl-label {
    padding: 48px 40px;
    border-right: 1px solid rgba(255,255,255,0.05);
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .proj-intl-grid {
    display: grid;
    grid-template-columns: repeat(4,1fr);
    gap: 0;
  }
  .proj-intl-item {
    padding: 32px 28px;
    border-left: 1px solid rgba(255,255,255,0.05);
    display: flex;
    flex-direction: column;
    gap: 6px;
    transition: background 0.2s;
  }
  .proj-intl-item:hover { background: var(--steel); }
  .pif { font-size: 24px; }
  .pil {
    font-size: 12px;
    color: #edf0f4;
    letter-spacing: 0.1em;
    text-transform: uppercase;
  }
  .pin {
    font-family: var(--ff-display);
    font-size: 28px;
    color: var(--flame);
    letter-spacing: 0.05em;
  }

  @media (max-width:1024px) {
    .proj-hero { padding: 48px 32px; }
    .proj-hero-content { flex-direction: column !important; gap: 32px; }
    .proj-hero-right { text-align: left !important; }
    .proj-3up { grid-template-columns: 1fr; }
    .proj-split, .proj-split-rev { grid-template-columns: 1fr; }
    .proj-intl { grid-template-columns: 1fr; }
    .proj-intl-grid { grid-template-columns: repeat(2,1fr); }
    .pt-item { padding: 20px 16px; }
  }


  /* ── CLIENT LOGOS ── */
  .client-logo-wrap {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 12px;
  }
  .client-logo {
    height: 32px;
    width: auto;
    max-width: 120px;
    object-fit: contain;
    
    opacity: 0.85;
    flex-shrink: 0;
    transition: opacity 0.2s;
  }
  .client-logo:hover { opacity: 1; }
  .client-logo-lg {
    height: 40px;
    max-width: 160px;
  }
  /* In the clients grid */
  .client-item .client-logo {
    height: 28px;
    max-width: 100px;
    display: block;
    margin: 0 auto 8px;
  }
  /* marquee logos */
  .marquee-logo {
    height: 20px;
    width: auto;
    max-width: 80px;
    object-fit: contain;
    
    opacity: 0.5;
    vertical-align: middle;
    margin-right: 8px;
    transition: opacity 0.2s;
  }


  .cap-item { cursor: pointer; }
  .cap-item:hover .cap-num { color: var(--flame); }
  .cap-item::after { content: 'Click to explore'; display: block; font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--flame); opacity: 0; margin-top: 12px; transition: opacity 0.2s; }
  .cap-item:hover::after { opacity: 1; }
  .modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.88); backdrop-filter: blur(16px); z-index: 9000; display: flex; align-items: center; justify-content: center; padding: 24px; opacity: 0; pointer-events: none; transition: opacity 0.3s ease; }
  .modal-overlay.open { opacity: 1; pointer-events: all; }
  .modal-box { background: var(--charcoal); border: 1px solid rgba(255,255,255,0.08); border-top: 4px solid var(--flame); border-bottom: 3px solid #b0b7c3; border-radius: 4px; max-width: 720px; width: 100%; max-height: 85vh; overflow-y: auto; transform: translateY(24px) scale(0.98); transition: transform 0.3s ease; position: relative; }
  .modal-overlay.open .modal-box { transform: translateY(0) scale(1); }
  .modal-header { padding: 36px 40px 24px; border-bottom: 1px solid rgba(255,255,255,0.06); display: flex; align-items: flex-start; justify-content: space-between; gap: 20px; position: sticky; top: 0; background: var(--charcoal); z-index: 1; }
  .modal-num { font-family: var(--ff-display); font-size: 11px; letter-spacing: 0.3em; color: var(--flame); margin-bottom: 8px; }
  .modal-title { font-family: var(--ff-display); font-size: clamp(28px, 4vw, 44px); letter-spacing: 0.04em; color: var(--white); line-height: 1; }
  .modal-close { background: none; border: 1px solid rgba(255,255,255,0.15); color: #edf0f4; width: 40px; height: 40px; border-radius: 2px; cursor: pointer; font-size: 18px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: background 0.2s; }
  .modal-close:hover { background: var(--flame); border-color: var(--flame); }
  .modal-body { padding: 32px 40px 40px; }
  .modal-body h4 { font-family: var(--ff-display); font-size: 14px; letter-spacing: 0.2em; color: var(--flame); margin: 28px 0 12px; text-transform: uppercase; }
  .modal-body h4:first-child { margin-top: 0; }
  .modal-body p { font-size: 15px; line-height: 1.85; color: #f0f2f5; margin-bottom: 16px; }
  .modal-body ul { list-style: none; padding: 0; margin: 0 0 20px; }
  .modal-body ul li { font-size: 13px; line-height: 1.8; color: #eceef2; padding: 9px 0 9px 22px; border-bottom: 1px solid rgba(255,255,255,0.05); position: relative; }
  .modal-body ul li::before { content: '->'; color: var(--flame); position: absolute; left: 0; font-size: 11px; top: 11px; }
  .modal-stats-row { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: rgba(255,255,255,0.05); margin: 24px 0; border-radius: 2px; overflow: hidden; }
  .modal-stat { background: var(--steel); padding: 20px; text-align: center; }
  .modal-stat-n { font-family: var(--ff-display); font-size: 28px; color: var(--flame); letter-spacing: 0.05em; display: block; }
  .modal-stat-l { font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase; color: #dde1e8; margin-top: 4px; display: block; }
  .modal-cta-row { margin-top: 32px; padding-top: 24px; border-top: 1px solid rgba(255,255,255,0.06); display: flex; gap: 16px; align-items: center; flex-wrap: wrap; }