@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@300;400;500;600;700;800&display=swap');

:root{
  --bg:#0D0D0D;
  --black:#000000;
  --graphite:#1A1A1A;
  --gray:#53565A;
  --light-gray:#2a2a2a;
  --off-white:#F2F2F2;
  --bordeaux:#7A2E34;
  --copper:#B8735A;
  --red-accent:#9F3640;
  --text:#E8E8E8;
  --muted:rgba(255,255,255,.5);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Manrope',sans-serif;
  background:var(--bg);color:var(--text);line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{max-width:100%;display:block}
a{color:inherit}
button{font-family:inherit}

.display{font-family:'Manrope',sans-serif;font-weight:800;letter-spacing:-.01em}
.container{max-width:1400px;margin:0 auto;padding:0 56px}

/* === REVEAL === */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s ease, transform .9s ease}
.reveal.is-in, .reveal.active{opacity:1;transform:translateY(0)}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}
.reveal[data-delay="4"]{transition-delay:.32s}
.reveal[data-delay="5"]{transition-delay:.40s}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
  .reveal{opacity:1;transform:none}
}

/* === BRUSH STREAKS (clean SVG approach) === */
.brush-layer{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:1}
.brush-layer svg{position:absolute;width:140%;height:auto}
.brush-svg path{stroke-dasharray:1000;stroke-dashoffset:1000;animation:brushDraw 2.6s ease-out forwards}
.brush-svg path.b2{animation-delay:.4s}
.brush-svg path.b3{animation-delay:.8s}
@keyframes brushDraw{to{stroke-dashoffset:0}}

/* === NAV === */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(13,13,13,.82);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(255,255,255,.06);
  padding:18px 0;transition:padding .3s, background .3s;
}
.nav.is-scrolled{padding:12px 0;background:rgba(8,8,8,.94)}
.nav .container{display:flex;justify-content:space-between;align-items:center;gap:24px}
.logo-link{
  display:inline-flex;align-items:center;gap:12px;text-decoration:none;
  font-family:'Manrope',sans-serif;font-size:22px;font-weight:800;letter-spacing:.02em;color:#fff;
  position:relative;
}
.logo-link .logo-mark{width:50px;height:34px;flex-shrink:0}
.logo-link::after{
  content:"";position:absolute;left:-8px;right:-8px;top:60%;height:2px;
  background:linear-gradient(90deg,transparent,var(--red-accent),transparent);
  transform:rotate(-6deg);opacity:.5;
}
.nav-menu{display:flex;gap:40px;list-style:none}
.nav-menu a{
  color:rgba(255,255,255,.6);text-decoration:none;font-size:12px;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;transition:color .25s;position:relative;
}
.nav-menu a::after{
  content:"";position:absolute;left:0;right:0;bottom:-7px;height:1.5px;
  background:var(--copper);transform:scaleX(0);transform-origin:left;transition:transform .3s;
}
.nav-menu a:hover{color:#fff}
.nav-menu a:hover::after{transform:scaleX(1)}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;color:#fff;padding:8px}
.nav-toggle svg{width:24px;height:24px}

/* === HERO === */
.hero{
  min-height:100vh;padding:160px 0 100px;
  position:relative;overflow:hidden;
  background:
    radial-gradient(ellipse at 20% 30%, rgba(122,46,52,.20) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 70%, rgba(184,115,90,.10) 0%, transparent 50%),
    var(--bg);
}
.hero::before{
  content:"";position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 15% 25%, rgba(255,255,255,.4) 0.5px, transparent 1px),
    radial-gradient(circle at 75% 65%, rgba(255,255,255,.3) 0.5px, transparent 1px),
    radial-gradient(circle at 45% 85%, rgba(184,115,90,.4) 0.5px, transparent 1px),
    radial-gradient(circle at 85% 15%, rgba(255,255,255,.3) 0.5px, transparent 1px);
  background-size:120px 120px,180px 180px,200px 200px,160px 160px;
  opacity:.5;pointer-events:none;
}

.hero .container{position:relative;z-index:3}
.hero-eyebrow{
  font-size:11px;letter-spacing:.4em;font-weight:700;
  color:var(--copper);text-transform:uppercase;
  margin-bottom:32px;display:inline-flex;align-items:center;gap:14px;
}
.hero-eyebrow::before{content:"";width:40px;height:1px;background:var(--copper)}

.hero h1{
  font-family:'Manrope',sans-serif;
  font-size:clamp(56px,10vw,168px);
  font-weight:800;line-height:.9;letter-spacing:-.04em;
  color:#fff;margin-bottom:44px;text-transform:uppercase;
  position:relative;
}
.hero h1 .red{color:var(--red-accent);font-style:italic}
.hero h1 .stroke{
  -webkit-text-stroke:2px #fff;color:transparent;font-style:italic;
}
.hero h1::after{
  content:"";position:absolute;left:-20px;top:35%;width:240px;height:80px;
  background:linear-gradient(90deg,transparent,rgba(159,54,64,.5),transparent);
  filter:blur(28px);transform:rotate(-6deg);z-index:-1;
}

.hero-tagline{
  font-size:14px;letter-spacing:.4em;text-transform:uppercase;
  color:rgba(255,255,255,.55);font-weight:600;margin-bottom:30px;
}
.hero-tagline span{color:var(--copper)}
.hero-sub{
  font-size:17px;color:rgba(255,255,255,.7);max-width:580px;
  margin-bottom:54px;line-height:1.7;
}
.hero-cta{display:flex;gap:16px;align-items:center;flex-wrap:wrap}

.btn{
  display:inline-flex;align-items:center;gap:12px;
  padding:20px 38px;font-family:inherit;font-size:12px;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;text-decoration:none;
  cursor:pointer;transition:all .3s;border:none;position:relative;overflow:hidden;
  will-change:transform;
}
.btn-primary{background:var(--red-accent);color:#fff}
.btn-primary::before{
  content:"";position:absolute;inset:0;background:#fff;
  transform:translateX(-101%);transition:transform .4s cubic-bezier(.4,.0,.2,1);
}
.btn-primary:hover{color:var(--red-accent)}
.btn-primary:hover::before{transform:translateX(0)}
.btn-primary > *{position:relative;z-index:2}
.btn-ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.3)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.06)}

.scroll-ind{
  position:absolute;bottom:50px;right:56px;z-index:3;
  font-size:10px;letter-spacing:.4em;color:rgba(255,255,255,.4);
  text-transform:uppercase;writing-mode:vertical-rl;
  display:flex;align-items:center;gap:14px;
}
.scroll-ind::after{
  content:"";display:block;width:1px;height:60px;
  background:linear-gradient(180deg,rgba(255,255,255,.5),transparent);
  animation:scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse{
  0%,100%{transform:scaleY(.4);transform-origin:top}
  50%{transform:scaleY(1)}
}

/* === STATS === */
.stats-bar{
  background:var(--black);padding:72px 0;position:relative;overflow:hidden;
  border-top:1px solid rgba(255,255,255,.05);
  border-bottom:1px solid rgba(255,255,255,.05);
}
.stats-bar::before{
  content:"";position:absolute;top:50%;left:-200px;right:-200px;height:200px;
  background:linear-gradient(90deg,transparent,rgba(184,115,90,.12),transparent);
  transform:translateY(-50%) rotate(-3deg);pointer-events:none;
}
.stats-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;position:relative;z-index:2;
  max-width:980px;margin:0 auto;
}
.stat{padding:0 32px;border-right:1px solid rgba(255,255,255,.1);position:relative}
.stat:last-child{border-right:none}
.stat-num{
  font-family:'Manrope',sans-serif;
  font-size:clamp(48px,5.5vw,80px);font-weight:800;color:#fff;line-height:1;
  letter-spacing:-.04em;margin-bottom:10px;
  background:linear-gradient(180deg,#fff 0%,#888 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.stat-num .plus{color:var(--copper);-webkit-text-fill-color:var(--copper)}
.stat-lbl{font-size:11px;letter-spacing:.22em;color:rgba(255,255,255,.5);text-transform:uppercase;font-weight:600}

/* === SECTIONS === */
section{padding:120px 0;position:relative}
.section-label{
  font-size:11px;letter-spacing:.4em;font-weight:700;
  color:var(--copper);text-transform:uppercase;margin-bottom:22px;
  display:inline-flex;align-items:center;gap:14px;
}
.section-label::before{content:"";width:32px;height:1px;background:var(--copper)}
.section-title{
  font-family:'Manrope',sans-serif;
  font-size:clamp(36px,5.5vw,76px);font-weight:800;
  color:#fff;letter-spacing:-.03em;line-height:1.02;
  margin-bottom:56px;text-transform:uppercase;
}
.section-title .red{color:var(--red-accent);font-style:italic}
.section-title .stroke{-webkit-text-stroke:2px #fff;color:transparent;font-style:italic}

/* === ABOUT === */
.about{background:var(--graphite);position:relative;overflow:hidden}
.about::before{
  content:"";position:absolute;right:-20%;top:0;width:60%;height:100%;
  background:radial-gradient(circle at 30% 50%,rgba(122,46,52,.22) 0%,transparent 60%);
  pointer-events:none;
}
.about-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
  position:relative;z-index:2;
}
.about-text p{
  font-size:17px;color:rgba(255,255,255,.78);margin-bottom:22px;line-height:1.75;
}
.about-quote{
  font-family:'Manrope',sans-serif;
  font-size:clamp(28px,3.5vw,46px);font-weight:800;color:#fff;
  letter-spacing:-.02em;line-height:1.1;text-transform:uppercase;
  position:relative;padding-left:30px;border-left:3px solid var(--red-accent);
}
.about-quote .accent{color:var(--copper);font-style:italic}

/* === VALUES === */
.values{background:var(--bg)}
.values-grid{
  display:grid;grid-template-columns:repeat(5,1fr);gap:1px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.06);
}
.value-card{
  background:var(--bg);padding:42px 28px;
  position:relative;transition:all .3s;cursor:default;
}
.value-card:hover{background:var(--graphite)}
.value-card:hover .value-icon-wrap{background:var(--red-accent)}
.value-card:hover .value-icon{color:#fff}
.value-num{
  font-family:'Manrope',sans-serif;font-size:11px;
  letter-spacing:.18em;color:var(--copper);font-weight:700;margin-bottom:28px;
}
.value-icon-wrap{
  width:52px;height:52px;background:var(--light-gray);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:26px;transition:background .3s;
}
.value-icon{width:22px;height:22px;color:var(--copper);transition:color .3s}
.value-card h3{
  font-family:'Manrope',sans-serif;
  font-size:18px;font-weight:700;color:#fff;
  margin-bottom:10px;text-transform:uppercase;letter-spacing:-.01em;
}
.value-card p{font-size:13px;color:rgba(255,255,255,.6);line-height:1.6}

/* === HIGHLIGHTS === */
.highlights{background:var(--bg);position:relative;overflow:hidden}
.highlights::before{
  content:"";position:absolute;top:30%;left:-15%;width:60%;height:8px;
  background:linear-gradient(90deg,transparent,rgba(159,54,64,.3),transparent);
  transform:rotate(-8deg);filter:blur(2px);
}
.rt-showcase{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:22px;
  position:relative;
  z-index:2;
}
.rt-feature{
  border:1px solid rgba(255,255,255,.1);
  background:#111;
  min-height:460px;
  position:relative;
  overflow:hidden;
  cursor:pointer;
}
.rt-feature-media{
  position:absolute;inset:0;
  background:#111;
}
.rt-feature-media img{
  width:100%;height:100%;object-fit:cover;
  object-position:center;
  transition:transform .6s cubic-bezier(.16, 1, .3, 1), filter .6s;
}
.rt-feature:hover .rt-feature-media img{
  transform:scale(1.05);
  filter:brightness(0.7);
}
.rt-feature-media::after{
  content:"";
  position:absolute;left:-10%;top:35%;width:70%;height:8px;
  background:linear-gradient(90deg,transparent,rgba(159,54,64,.6),transparent);
  transform:rotate(-8deg);
}
.rt-feature-content{
  position:absolute;left:0;right:0;bottom:0;
  padding:34px;
  background:linear-gradient(180deg, transparent 20%, rgba(0,0,0,.88) 100%);
}
.rt-chip{
  display:inline-block;
  font-size:10px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--copper);
  margin-bottom:14px;
  font-weight:700;
}
.rt-feature-content h3{
  font-size:clamp(24px,2.8vw,38px);
  color:#fff;
  line-height:1.08;
  letter-spacing:-.01em;
  margin-bottom:14px;
  text-transform:uppercase;
}
.rt-feature-content p{font-size:14px;color:rgba(255,255,255,.72);line-height:1.6;max-width:580px}
.rt-cases{
  border:1px solid rgba(255,255,255,.1);
  background:#090909;
  padding:8px 0;
}
.rt-case-item{
  padding:22px 24px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.rt-case-item:last-child{border-bottom:none}
.rt-case-year{
  color:var(--red-accent);
  letter-spacing:.2em;
  font-size:10px;
  text-transform:uppercase;
  font-weight:700;
}
.rt-case-item h4{
  margin:10px 0 8px;
  color:#fff;
  font-size:20px;
  line-height:1.2;
  letter-spacing:-.01em;
  text-transform:uppercase;
}
.rt-case-item p{
  color:rgba(255,255,255,.63);
  font-size:13px;
  line-height:1.55;
}

/* === ALL PROJECTS — editorial === */
.all-projects{background:#080808;position:relative;overflow:hidden}
.all-projects::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--red-accent),transparent);
}
.year-row{
  display:grid;grid-template-columns:220px 1fr;
  align-items:start;padding:44px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
  transition:background .3s;
}
.year-row.hidden{display:none}
.year-row:hover{background:rgba(122,46,52,.05)}
.year-label{
  font-family:'Manrope',sans-serif;
  font-size:60px;font-weight:800;color:#fff;line-height:1;
  letter-spacing:-.03em;
}
.year-label .accent{color:var(--red-accent);font-style:italic}
.proj-cells{display:flex;flex-direction:column;gap:12px}
.proj-cell{
  display:flex;gap:18px;align-items:flex-start;
  padding:12px 0;border-bottom:1px solid rgba(255,255,255,.04);
}
.proj-cell:last-child{border-bottom:none}
.proj-marker{
  flex-shrink:0;width:32px;height:32px;background:var(--graphite);
  display:flex;align-items:center;justify-content:center;
  font-family:'Manrope';font-size:10px;color:var(--copper);font-weight:700;
}
.proj-text{font-size:15px;color:rgba(255,255,255,.82);line-height:1.5;padding-top:4px}
/* === TEAM === */
.team{background:var(--graphite)}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.team-card{
  background:var(--bg);padding:32px 28px 28px;
  border:1px solid rgba(255,255,255,.08);
  transition:all .35s;position:relative;overflow:hidden;
}
.team-card::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:2px;
  background:var(--red-accent);transform:scaleX(0);transform-origin:left;
  transition:transform .35s;
}
.team-card:hover{background:#161616;transform:translateY(-4px);border-color:var(--copper)}
.team-card:hover::after{transform:scaleX(1)}
.avatar{
  width:96px;height:96px;border-radius:50%;
  background:linear-gradient(135deg,var(--red-accent) 0%,var(--bordeaux) 100%);
  display:flex;align-items:center;justify-content:center;color:#fff;
  font-family:'Manrope',sans-serif;font-size:28px;font-weight:700;letter-spacing:.04em;
  margin-bottom:22px;
}
.team-name{font-family:'Manrope';font-size:17px;font-weight:700;color:#fff;margin-bottom:6px;letter-spacing:-.01em}
.team-role{font-size:11px;color:var(--copper);font-weight:700;letter-spacing:.18em;text-transform:uppercase}
.team-desc{font-size:13px;color:rgba(255,255,255,.6);line-height:1.6;margin-top:14px}
.team-card.head{background:linear-gradient(135deg,#1a1a1a 0%,#0d0d0d 100%);border-color:var(--red-accent)}
.team-card.head .avatar{background:#fff;color:var(--red-accent)}

/* === PARTNERS === */
.partners{background:var(--graphite)}
.partners-wall{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08);
}
.partner{
  background:var(--graphite);padding:54px 30px;
  display:flex;align-items:center;justify-content:center;
  min-height:160px;text-align:center;
  font-family:'Manrope',sans-serif;
  font-size:14px;font-weight:700;color:#fff;letter-spacing:.04em;
  text-transform:uppercase;line-height:1.3;
  transition:background .3s,color .3s;position:relative;overflow:hidden;
}
.partner img{max-height:60px;width:auto;max-width:160px;object-fit:contain;filter:grayscale(1) brightness(2) opacity(.7);transition:filter .35s}
.partner:hover{background:#0d0d0d;color:var(--copper)}
.partner:hover img{filter:grayscale(0) brightness(1.05) opacity(1)}

/* === CONTACT === */
.contact{background:#080808}
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:80px;align-items:start}
.info-line{
  display:flex;align-items:flex-start;gap:14px;padding:16px 0;
  border-bottom:1px solid rgba(255,255,255,.08);font-size:14px;color:rgba(255,255,255,.85);
}
.info-line strong{font-weight:700;min-width:130px;color:var(--copper);font-size:10px;letter-spacing:.18em;text-transform:uppercase;padding-top:3px}
.info-line a{color:#fff;text-decoration:none;transition:color .25s}
.info-line a:hover{color:var(--copper)}

.contact-form{background:var(--graphite);padding:40px 36px;border:1px solid rgba(255,255,255,.08)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.form-row.single{grid-template-columns:1fr}
.form-field label{display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:8px;font-weight:700}
.form-field input,.form-field textarea{
  width:100%;font-family:inherit;font-size:14px;color:#fff;
  background:transparent;border:none;border-bottom:1.5px solid rgba(255,255,255,.15);
  padding:10px 0;transition:border-color .25s;
}
.form-field input:focus,.form-field textarea:focus{outline:none;border-bottom-color:var(--copper)}
.form-field textarea{resize:vertical;min-height:90px;font-family:inherit}
.form-consent{display:flex;align-items:flex-start;gap:10px;font-size:12px;color:rgba(255,255,255,.6);line-height:1.5;margin:22px 0}
.form-consent input{margin-top:3px;accent-color:var(--red-accent);flex-shrink:0}
.form-consent a{color:var(--copper);text-decoration:underline}
.contact-form .btn{width:100%;justify-content:center}

/* === CTA === */
.cta{
  background:var(--bg);text-align:center;padding:160px 0;
  position:relative;overflow:hidden;
}
.cta::before{
  content:"";position:absolute;left:50%;top:50%;
  width:1400px;height:600px;transform:translate(-50%,-50%) rotate(-8deg);
  background:linear-gradient(90deg,transparent,rgba(122,46,52,.3),transparent);
  filter:blur(60px);
}
.cta::after{
  content:"";position:absolute;left:50%;top:50%;
  width:600px;height:2px;transform:translate(-50%,-50%) rotate(-8deg);
  background:linear-gradient(90deg,transparent,var(--red-accent),transparent);
}
.cta .container{position:relative;z-index:2}
.cta h2{
  font-family:'Manrope',sans-serif;
  font-size:clamp(40px,7vw,108px);font-weight:800;
  color:#fff;letter-spacing:-.04em;line-height:.95;
  margin-bottom:36px;text-transform:uppercase;
}
.cta h2 .red{color:var(--red-accent);font-style:italic}
.cta p{font-size:17px;color:rgba(255,255,255,.65);margin-bottom:48px;max-width:560px;margin-left:auto;margin-right:auto}

/* === FOOTER === */
footer{background:#000;color:rgba(255,255,255,.5);padding:72px 0 28px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-brand{
  font-family:'Manrope',sans-serif;font-size:22px;font-weight:800;
  color:#fff;margin-bottom:18px;letter-spacing:.02em;
  display:inline-flex;align-items:center;gap:12px;
}
.footer-brand .logo-mark{width:48px;height:32px}
.footer-tag{font-size:13px;line-height:1.6;max-width:300px}
.footer-tag-accent{
  display:block;margin-top:16px;font-size:11px;letter-spacing:.4em;
  color:var(--copper);text-transform:uppercase;font-weight:700;
}
.footer-grid h4{color:#fff;font-size:11px;letter-spacing:.22em;text-transform:uppercase;margin-bottom:18px;font-weight:700}
.footer-grid a{display:block;color:rgba(255,255,255,.5);text-decoration:none;font-size:13px;margin-bottom:10px;transition:color .25s}
.footer-grid a:hover{color:var(--copper)}
.footer-legal{
  border-top:1px solid rgba(255,255,255,.08);padding-top:28px;font-size:11px;color:rgba(255,255,255,.4);line-height:1.7
}
.footer-legal p{margin-bottom:8px}
.footer-legal strong{color:rgba(255,255,255,.7);font-weight:700}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);padding-top:20px;margin-top:24px;
  display:flex;justify-content:space-between;font-size:11px;letter-spacing:.06em;gap:16px;flex-wrap:wrap;
}

/* === LEGAL PAGE === */
.page-legal{padding:140px 0 80px;background:#080808;min-height:100vh}
.legal-title{font-family:'Manrope';font-size:clamp(36px,5vw,68px);font-weight:800;color:#fff;margin-bottom:18px;letter-spacing:-.03em;text-transform:uppercase;line-height:1}
.legal-title .red{color:var(--red-accent);font-style:italic}
.legal-sub{font-size:16px;color:rgba(255,255,255,.7);max-width:780px;margin-bottom:56px;line-height:1.65}
.legal-card{background:var(--graphite);border:1px solid rgba(255,255,255,.08);padding:36px 40px;margin-bottom:22px}
.legal-card h2{font-family:'Manrope';font-size:20px;font-weight:800;color:#fff;margin-bottom:6px;letter-spacing:-.01em;text-transform:uppercase}
.legal-card .legal-sub2{font-size:11px;color:var(--copper);letter-spacing:.22em;text-transform:uppercase;font-weight:700;margin-bottom:24px}
.legal-table{display:grid;grid-template-columns:280px 1fr;gap:14px 28px}
.legal-table dt{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.5);font-weight:700;padding-top:3px}
.legal-table dd{font-size:14px;color:#fff;line-height:1.55;word-break:break-word}
.legal-back{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:var(--copper);text-decoration:none;font-weight:700;letter-spacing:.18em;text-transform:uppercase;margin-bottom:30px}
.legal-back:hover{color:#fff}

.privacy-content{background:var(--graphite);padding:44px 50px;border:1px solid rgba(255,255,255,.08);font-size:15px;color:rgba(255,255,255,.78);line-height:1.75;max-width:880px}
.privacy-content h2{font-family:'Manrope';font-size:20px;color:#fff;margin:30px 0 12px;font-weight:800;text-transform:uppercase;letter-spacing:-.01em}
.privacy-content h2:first-child{margin-top:0}
.privacy-content h3{font-size:15px;color:#fff;margin:20px 0 10px;font-weight:700}
.privacy-content p{margin-bottom:14px}
.privacy-content ul{margin:0 0 14px 24px}
.privacy-content li{margin-bottom:8px}
.privacy-content a{color:var(--copper)}

/* === COOKIE === */
.cookie{
  position:fixed;left:20px;right:20px;bottom:20px;z-index:200;
  background:var(--graphite);color:#fff;padding:18px 24px;
  display:flex;align-items:center;gap:20px;flex-wrap:wrap;
  border:1px solid rgba(255,255,255,.1);
  box-shadow:0 24px 60px -20px rgba(0,0,0,.6);
  transform:translateY(140%);transition:transform .5s;font-size:13px;line-height:1.5;
  max-width:880px;margin:0 auto;
}
.cookie.is-show{transform:translateY(0)}
.cookie p{margin:0;flex:1;min-width:240px;color:rgba(255,255,255,.85)}
.cookie a{color:var(--copper);text-decoration:underline}
.cookie button{
  background:var(--red-accent);color:#fff;border:none;
  padding:12px 24px;font-size:11px;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;cursor:pointer;transition:background .25s;font-family:inherit;
}
.cookie button:hover{background:var(--bordeaux)}

@media(max-width:1024px){
  .container{padding:0 24px}
  .nav-menu{display:none}
  .nav-menu.is-open, .nav-menu.active{display:flex;position:absolute;top:100%;left:0;right:0;background:var(--bg);flex-direction:column;padding:24px 28px;border-bottom:1px solid rgba(255,255,255,.08);gap:18px}
  .nav-toggle{display:block}
  .hero{padding:130px 0 80px}
  .hero h1{font-size:64px}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:1px;background:rgba(255,255,255,.08)}
  .stat{background:var(--black);padding:32px 24px;border-right:none}
  .stat-num{font-size:48px}
  .about-grid{grid-template-columns:1fr;gap:48px}
  .values-grid{grid-template-columns:repeat(2,1fr)}
  .rt-showcase{grid-template-columns:1fr;gap:16px}
  .rt-feature{min-height:360px}
  .year-row{grid-template-columns:1fr;gap:24px}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .partners-wall{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr;gap:40px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .scroll-ind{display:none}
  .legal-table{grid-template-columns:1fr;gap:4px}
  .legal-table dt{margin-top:18px}
  .legal-table dt:first-child{margin-top:0}
  .privacy-content{padding:28px 22px}
  .legal-card{padding:26px 24px}
}
@media(max-width:560px){
  .container{padding:0 18px}
  .hero{padding:112px 0 64px}
  .hero h1{font-size:clamp(38px,12vw,48px);line-height:.92}
  .hero-sub{font-size:16px}
  .stats-grid{grid-template-columns:1fr}
  .values-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .partners-wall{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .form-field input,.form-field textarea{font-size:16px}
  .cookie{flex-direction:column;align-items:stretch}
  .cookie button{width:100%}
}


/* === PREMIUM CASES + POLISH === */
body.has-open-modal{overflow:hidden}
.case-more{
  display:inline-flex;align-items:center;gap:8px;margin-top:16px;padding:10px 14px;
  border:1px solid currentColor;background:rgba(255,255,255,.08);color:inherit;
  font:inherit;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  cursor:pointer;transition:transform .25s, background .25s, border-color .25s;
}
.case-more:hover{transform:translateY(-2px);background:rgba(255,255,255,.16)}
.case-modal{position:fixed;inset:0;z-index:500;display:none;align-items:center;justify-content:center;padding:28px;}
.case-modal.is-open{display:flex}
.case-modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.68);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.case-modal__dialog{position:relative;z-index:2;width:min(1040px,100%);max-height:min(760px,92vh);display:grid;grid-template-columns:.92fr 1.08fr;overflow:hidden;box-shadow:0 40px 120px rgba(0,0,0,.35);outline:none}
.case-modal__close{position:absolute;top:18px;right:18px;z-index:5;width:42px;height:42px;border:1px solid rgba(255,255,255,.25);background:rgba(0,0,0,.25);color:#fff;font-size:26px;line-height:1;cursor:pointer;transition:background .25s, transform .25s}
.case-modal__close:hover{background:rgba(255,255,255,.14);transform:rotate(90deg)}
.case-modal__visual{min-height:520px;position:relative;overflow:hidden;background:#111}
.case-modal__visual::before{content:"";position:absolute;inset:0;background:var(--case-visual,linear-gradient(135deg,#1b1f26,#6f8faf));}
.case-modal__visual::after{content:"";position:absolute;inset:28px;border:1px solid rgba(255,255,255,.22);background:repeating-linear-gradient(90deg,transparent 0,transparent 54px,rgba(255,255,255,.06) 55px),repeating-linear-gradient(0deg,transparent 0,transparent 54px,rgba(255,255,255,.05) 55px)}
.case-modal__body{padding:50px;overflow:auto}
.case-modal__meta{font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px;opacity:.72}
.case-modal__body h3{font-size:clamp(28px,3.5vw,46px);line-height:1.05;margin:0 0 18px;letter-spacing:-.02em}
.case-modal__lead{font-size:17px;line-height:1.7;margin-bottom:28px;opacity:.82}
.case-modal__grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:28px}
.case-modal__grid div{padding:18px;border:1px solid currentColor;background:rgba(255,255,255,.04)}
.case-modal__grid strong{display:block;font-size:10px;letter-spacing:.16em;text-transform:uppercase;margin-bottom:8px;opacity:.6}
.case-modal__grid span{font-size:13px;line-height:1.55;opacity:.88}
.case-modal__cta{width:max-content;max-width:100%}
.avatar{overflow:hidden;flex-shrink:0}
.avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}
@media (max-width:760px){.case-modal{padding:12px}.case-modal__dialog{grid-template-columns:1fr;max-height:94vh}.case-modal__visual{min-height:220px}.case-modal__body{padding:28px 22px}.case-modal__grid{grid-template-columns:1fr}.case-modal__close{top:12px;right:12px}}

.logo-link-text{font-size:24px;letter-spacing:.08em;text-transform:uppercase}.logo-link .logo-mark,.footer-brand .logo-mark{display:none}.logo-link::after,.footer-brand.logo-link-text::after{background:linear-gradient(90deg,transparent,var(--copper),transparent);opacity:.72}.footer-brand.logo-link-text{position:relative;display:inline-flex;color:#fff;font-weight:800;letter-spacing:.08em}.footer-brand.logo-link-text::after{content:"";position:absolute;left:-6px;right:-6px;top:62%;height:2px;transform:rotate(-5deg)}
.hero{min-height:100svh;padding:128px 0 74px;display:flex;align-items:center}.hero .container{text-align:center;max-width:1120px}.hero-eyebrow{justify-content:center}.hero-eyebrow::after{content:"";width:40px;height:1px;background:var(--copper)}.hero h1{font-size:clamp(44px,7vw,110px);margin-left:auto;margin-right:auto;margin-bottom:28px}.hero h1::after{left:50%;transform:translateX(-50%) rotate(-6deg);background:linear-gradient(90deg,transparent,rgba(184,115,90,.46),transparent)}.hero-sub{margin-left:auto;margin-right:auto;margin-bottom:34px;max-width:720px}.hero-cta{justify-content:center}.scroll-ind{display:none}.btn-primary{background:var(--copper)}.btn-primary:hover{color:var(--bg)}
.hero h1 .red{color:var(--copper)}
.rt-feature-media{background:linear-gradient(135deg,#121212,#7a2e34)}
.rt-feature-media img{display:block;width:100%;height:100%;object-fit:cover;filter:saturate(.95) contrast(1.05)}
.rt-feature-media::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 70% 20%,rgba(184,115,90,.20),transparent 34%),linear-gradient(180deg,rgba(0,0,0,.08),rgba(0,0,0,.34));z-index:1;pointer-events:none}
.case-more{color:#fff;border-color:rgba(184,115,90,.65);background:rgba(184,115,90,.14)}
.rt-case-item{cursor:pointer}
.case-modal__dialog{background:#111;color:#fff;border:1px solid rgba(184,115,90,.42)}
.case-modal__meta{color:var(--copper)}
.case-modal__grid div{border-color:rgba(184,115,90,.26);background:rgba(184,115,90,.07)}
.case-modal__visual{--case-visual:radial-gradient(circle at 72% 18%,rgba(184,115,90,.58),transparent 32%),linear-gradient(135deg,#0D0D0D,#7A2E34)}

/* === FOLLOW-UP PREMIUM POLISH === */
:root{
  --bordeaux:#5E2028;
  --copper:#C47C55;
  --gold:#D9A85E;
  --red-accent:#C47C55;
}
.brush-layer{
  inset:-8% 0;
  z-index:1;
  opacity:.9;
  mix-blend-mode:screen;
}
.brush-layer svg{
  left:50%;
  top:50%;
  width:130vw;
  height:105vh;
  min-width:1600px;
  transform:translate(-50%,-50%);
}
.brush-layer::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse at center,rgba(216,168,95,.13),transparent 58%);
}
.brush-svg path{
  stroke-dasharray:1800;
  stroke-dashoffset:1800;
  filter:drop-shadow(0 0 14px rgba(216,168,95,.22));
}
.hero{
  background:
    radial-gradient(ellipse at 50% 42%,rgba(196,124,85,.18) 0%,transparent 48%),
    radial-gradient(ellipse at 18% 28%,rgba(94,32,40,.34) 0%,transparent 48%),
    radial-gradient(ellipse at 82% 70%,rgba(216,168,95,.13) 0%,transparent 50%),
    var(--bg);
}
.hero .container{z-index:4}
.hero h1{
  color:#fff;
  text-shadow:0 18px 70px rgba(0,0,0,.68);
}
.hero h1 .red{
  color:transparent;
  background:linear-gradient(115deg,#EAC67E 0%,#C47C55 42%,#7A2E34 100%);
  -webkit-background-clip:text;
  background-clip:text;
  display:inline-block;
  padding-right:.16em;
  margin-right:-.06em;
  -webkit-box-decoration-break:clone;
  box-decoration-break:clone;
}
.hero h1 .stroke{
  -webkit-text-stroke:1.6px rgba(234,198,126,.76);
}
.hero h1 .stroke{
  color:#f6efe7;
  -webkit-text-stroke:0;
  text-stroke:0;
  font-style:italic;
  text-shadow:0 18px 70px rgba(0,0,0,.68);
}
.hero-eyebrow,.section-label,.hero-tagline span,.footer-tag-accent{color:var(--gold)}
.hero-eyebrow::before,.hero-eyebrow::after,.section-label::before{background:linear-gradient(90deg,var(--copper),var(--gold))}
.btn-primary{
  background:linear-gradient(135deg,var(--gold),var(--copper) 52%,var(--bordeaux));
  color:#090909;
}
.btn-primary:hover{color:#090909;box-shadow:0 18px 52px -18px rgba(216,168,95,.62)}
.stats-bar::before,.cta::before{
  background:linear-gradient(90deg,transparent,rgba(216,168,95,.18),rgba(196,124,85,.20),transparent);
}
.rt-team-grid{grid-template-columns:minmax(320px,1.35fr) minmax(260px,.65fr);align-items:stretch}
.rt-team-grid .team-card.head{
  display:grid;
  grid-template-columns:minmax(220px,310px) 1fr;
  gap:0;
  padding:0;
  border-color:rgba(216,168,95,.30);
  background:linear-gradient(135deg,#171717,#090909);
}
.leader-portrait{
  min-height:430px;
  display:flex;
  align-items:stretch;
  justify-content:center;
  padding:0;
  background:
    radial-gradient(circle at 72% 20%,rgba(216,168,95,.28),transparent 24%),
    linear-gradient(140deg,#2a1715 0%,#0d0d0d 52%,#4e2026 100%);
  position:relative;
  overflow:hidden;
  border-right:1px solid rgba(216,168,95,.18);
}
.leader-portrait img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center top;
  filter:saturate(.94) contrast(1.03);
}
.leader-portrait::before{
  content:"";
  position:absolute;
  inset:18px;
  border:1px solid rgba(216,168,95,.26);
  z-index:2;
  pointer-events:none;
}
.leader-portrait::after{
  content:"";
  position:absolute;
  left:-50px;
  bottom:58px;
  width:250px;
  height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  transform:rotate(-13deg);
  z-index:3;
}
.team-copy{
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:44px 44px 42px;
  min-height:430px;
}
.rt-team-grid .team-card.head .team-name{
  font-size:24px;
  line-height:1.16;
  margin-bottom:10px;
  max-width:560px;
}
.rt-team-grid .team-card.head .team-role{
  margin-bottom:26px;
}
.rt-team-grid .team-card.head .team-desc{
  font-size:14px;
  max-width:560px;
  margin-top:0;
}
.capability-card{
  background:
    linear-gradient(180deg,rgba(216,168,95,.08),rgba(255,255,255,0)),
    #101010;
  border-style:dashed;
}
.capability-card::after{background:linear-gradient(90deg,var(--copper),var(--gold))}
.capability-mark{
  width:100%;
  min-height:152px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:24px;
  color:var(--gold);
  border:1px solid rgba(216,168,95,.24);
  background:rgba(216,168,95,.06);
  font-size:28px;
  font-weight:800;
  letter-spacing:.08em;
}
.partners-rail{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(216,168,95,.18);
  background:
    linear-gradient(90deg,#0d0d0d,rgba(196,124,85,.10),#0d0d0d);
  padding:22px 0;
}
.partners-rail::before,.partners-rail::after{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  width:120px;
  z-index:2;
  pointer-events:none;
}
.partners-rail::before{left:0;background:linear-gradient(90deg,var(--graphite),transparent)}
.partners-rail::after{right:0;background:linear-gradient(270deg,var(--graphite),transparent)}
.partners-track{
  display:flex;
  width:max-content;
  gap:16px;
  animation:partnerRail 34s linear infinite;
}
.partners-rail:hover .partners-track{animation-play-state:paused}
.partners-track .partner{
  flex:0 0 250px;
  min-height:120px;
  padding:24px;
  background:#101010;
  border:1px solid rgba(255,255,255,.08);
  color:#f5eee4;
}
.partners-track .partner img{max-height:50px}
@keyframes partnerRail{
  from{transform:translateX(0)}
  to{transform:translateX(calc(-50% - 8px))}
}
@media (prefers-reduced-motion: reduce){
  .partners-track{animation:none;flex-wrap:wrap;width:auto;justify-content:center}
}
@media(max-width:560px){
  .partners-rail{padding:16px;overflow:hidden}
  .partners-rail::before,.partners-rail::after{display:none}
  .partners-track{width:auto;animation:none;display:grid;grid-template-columns:1fr;gap:10px}
  .partners-track .partner{flex:auto;min-height:92px;padding:18px}
}
.case-modal{
  align-items:center;
  justify-content:center;
  padding:28px;
}
.case-modal__backdrop{
  background:rgba(0,0,0,.72);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
}
.case-modal__dialog{
  width:min(1080px,100%);
  height:min(660px,90vh);
  max-height:90vh;
  grid-template-columns:.95fr 1.05fr;
  border:1px solid rgba(216,168,95,.30);
  background:
    linear-gradient(180deg,rgba(216,168,95,.10),rgba(255,255,255,0) 34%),
    #0b0b0b;
  box-shadow:0 34px 120px rgba(0,0,0,.56);
}
.case-modal__visual{
  min-height:0;
  --case-visual:
    radial-gradient(circle at 70% 16%,rgba(216,168,95,.46),transparent 26%),
    linear-gradient(180deg,#2b1714,#0d0d0d 54%,#5e2028);
}
.case-modal__img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  z-index:1;
  display:none;
}
.case-modal__visual::after{
  inset:18px;
  z-index:2;
  border-color:rgba(216,168,95,.32);
  background:
    linear-gradient(180deg,transparent 40%,rgba(0,0,0,.30)),
    linear-gradient(0deg,transparent,rgba(216,168,95,.10),transparent);
}
.case-modal__body{padding:48px 50px;display:flex;flex-direction:column;overflow-y:auto;min-height:0}
.case-modal__meta{color:var(--gold)}
.case-modal__body h3{text-transform:uppercase}
.case-modal__lead{margin-bottom:22px}
.case-modal__grid{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}
.case-modal__cta{margin-top:auto}
.case-modal__grid div{border-color:rgba(216,168,95,.22);background:rgba(216,168,95,.06)}
.case-modal__close{
  background:rgba(216,168,95,.10);
  border-color:rgba(216,168,95,.28);
}
@media(max-width:760px){
  .brush-layer svg{min-width:980px;width:180vw}
  .rt-team-grid,.rt-team-grid .team-card.head{grid-template-columns:1fr}
  .leader-portrait{min-height:250px}
  .team-copy{min-height:auto;padding:28px 26px 32px}
  .case-modal{padding:12px}
  .case-modal__dialog{grid-template-columns:1fr;height:auto;max-height:94vh;overflow:auto}
  .case-modal__visual{min-height:200px}
  .case-modal__body{overflow-y:visible;padding:32px 26px}
  .case-modal__grid{grid-template-columns:1fr}
}

.rt-case-thumb{
  position:relative;
  width:100%;
  aspect-ratio:16/8;
  margin:0 0 18px;
  overflow:hidden;
  border:1px solid rgba(216,168,95,.18);
  background:#090909;
}
.rt-case-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
  transition:transform .45s ease, filter .45s ease;
}
.rt-case-item:hover .rt-case-thumb img{
  transform:scale(1.04);
  filter:saturate(1.08) contrast(1.05);
}
.rt-case-thumb::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.18));
  pointer-events:none;
}

/* The stats band should feel like it cuts through the page, not like a boxed row. */
.stats-bar{
  margin:-58px 0 -64px;
  padding:104px 0;
  background:transparent;
  border:0;
  overflow:visible;
  isolation:isolate;
  z-index:6;
}
.stats-bar::after{
  content:"";
  position:absolute;
  inset:18px -8vw;
  z-index:0;
  background:
    radial-gradient(ellipse at 18% 52%,rgba(216,168,95,.18),transparent 38%),
    radial-gradient(ellipse at 78% 48%,rgba(196,124,85,.16),transparent 42%),
    linear-gradient(97deg,#050505 0%,#100d0b 38%,#1b100b 58%,#080808 100%);
  transform:skewY(-2.4deg);
  box-shadow:
    0 -30px 70px rgba(0,0,0,.32),
    0 34px 90px rgba(0,0,0,.46),
    inset 0 1px rgba(255,255,255,.06),
    inset 0 -1px rgba(216,168,95,.14);
}
.stats-bar::before{
  top:50%;
  left:-12vw;
  right:-12vw;
  height:260px;
  z-index:1;
  background:
    linear-gradient(100deg,transparent 4%,rgba(216,168,95,.10) 24%,rgba(196,124,85,.20) 50%,rgba(234,198,126,.12) 70%,transparent 96%),
    repeating-linear-gradient(100deg,transparent 0,transparent 92px,rgba(255,255,255,.045) 93px);
  transform:translateY(-50%) skewY(-2.4deg);
  filter:blur(.2px);
}
.stats-grid{
  position:relative;
  z-index:2;
}
.stat{
  padding-top:8px;
  padding-bottom:8px;
}
.about{
  padding-top:168px;
}
@media (max-width:1024px){
  .stats-bar{
    margin:-34px 0 -42px;
    padding:82px 0;
  }
  .stats-bar::after{
    inset:14px -12vw;
    transform:skewY(-1.8deg);
  }
  .stats-bar::before{
    transform:translateY(-50%) skewY(-1.8deg);
  }
  .about{
    padding-top:144px;
  }
}
@media (max-width:560px){
  .stats-bar{
    margin:-24px 0 -28px;
    padding:64px 0;
  }
  .stats-bar::after{
    inset:8px -6vw;
  }
  .about{
    padding-top:126px;
  }
}
