*{box-sizing:border-box}html{scroll-behavior:smooth}
:root{
  --bg:#ffffff;
  --panel:#fafafa;
  --muted:#555555;
  --text:#1a1a1a;
  --brand:#CC2B1D;    /* deep red */
  --brand-2:#E9B500;  /* warm gold */
  --line:#e4e4e4;
  --glow:0 10px 40px rgba(204,43,29,.18);
}
@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.001ms !important;animation-iteration-count:1 !important;transition-duration:0.001ms !important;scroll-behavior:auto !important}
}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;
  background:linear-gradient(180deg,#f9fbff,#ffffff);
  color:var(--text);
}
.container{width:min(1100px,92vw);margin-inline:auto}
.site-header{position:sticky;top:0;backdrop-filter:saturate(160%) blur(8px);background:rgba(255,255,255,.75);border-bottom:1px solid var(--line);z-index:50}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;gap:10px;align-items:center;color:var(--text);text-decoration:none;font-weight:700}
.wordmark{height:110px;width:auto}
nav a{color:var(--text);text-decoration:none;margin-left:18px;font-weight:500;opacity:.9;position:relative}
nav a.cta{padding:.5rem .9rem;border:1px solid var(--line);border-radius:10px}
nav a:after{content:'';position:absolute;left:0;right:100%;bottom:-6px;height:2px;background:linear-gradient(90deg,var(--brand),var(--brand-2));transition:all .3s}
nav a:hover:after{right:0}

.hero{padding:76px 0 24px;border-bottom:1px solid var(--line)}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:32px;align-items:center}
.hero-copy h1{font-size:clamp(28px,4.5vw,42px);line-height:1.1;margin:0 0 12px}
.grad{background:linear-gradient(90deg,var(--brand),var(--brand-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-copy p{color:var(--muted);max-width:60ch}
.badges{list-style:none;display:flex;gap:14px;padding:0;margin:18px 0 16px}
.badges li{display:flex;align-items:center;gap:8px;border:1px dashed var(--line);padding:.4rem .65rem;border-radius:999px;color:var(--muted);font-size:.95rem}
.hero-actions{display:flex;gap:12px}
.btn{display:inline-block;border:1px solid var(--line);padding:.7rem 1rem;border-radius:12px;text-decoration:none;color:var(--text);transition:transform .2s, box-shadow .2s, background .2s}
.btn:hover{transform:translateY(-2px);box-shadow:var(--glow)}
.btn.primary{background:linear-gradient(90deg,var(--brand),var(--brand-2));border:none;color:#fff}
.hero-media{border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:0 12px 30px rgba(0,0,0,.06);transform:translateZ(0);background:#fff}
.hero-media img{display:block;width:100%;height:auto;transform:scale(1.01);transition:transform 3s ease}
.hero-media:hover img{transform:scale(1.05)}
.hero-media figcaption{padding:10px 12px;color:var(--muted);font-size:.9rem;background:#fff}

.logo-strip{border-top:2px solid var(--brand-2);border-bottom:1px solid var(--line);margin-top:60px;background:#fff}
.marquee{display:flex;gap:70px;align-items:center;overflow:auto;padding:24px 0;mask-image:linear-gradient(90deg,transparent,black 8%,black 92%,transparent);}
.marquee img{height:80px;opacity:1;filter:none;transition:opacity .2s, filter .2s}
.marquee img:hover{opacity:1;filter:none}

.section{padding:56px 0;border-bottom:1px solid var(--line)}
.section.alt{background:#f8fafc}
.two-col{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:start}
.card{border:1px solid var(--line);background:#ffffff;padding:18px;border-radius:16px;transition:transform .2s, box-shadow .2s}
.checklist{padding-left:18px;color:var(--text)}
.list{padding-left:16px;color:var(--muted)}
.pill-row{display:flex;flex-wrap:wrap;gap:10px}
.pill{border:1px solid var(--line);border-radius:999px;padding:.45rem .8rem;color:var(--text);background:#fff}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:18px}
.gallery .card{padding:0;overflow:hidden}
.gallery img{display:block;width:100%;height:180px;object-fit:cover;transform:scale(1.02);transition:transform 2.5s ease}
.gallery .card:hover img{transform:scale(1.07)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.cap h4{margin:.3rem 0}
.hover-raise:hover{transform:translateY(-3px);box-shadow:0 8px 30px rgba(0,0,0,.08)}
.aside{position:relative}
.contact{display:grid;gap:14px}
.contact-card{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.contact-item h4{margin:.3rem 0 .2rem}
.hint{color:var(--muted);font-size:.85rem}
.site-footer{padding:24px 0;color:var(--muted)}

.work-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.work img{width:100%;height:140px;object-fit:cover;border-bottom:1px solid var(--line);margin:-18px -18px 12px -18px;border-top-left-radius:16px;border-top-right-radius:16px;background:#fff}

.reveal-up{opacity:0;transform:translateY(18px);transition:opacity .6s ease, transform .6s ease}
.reveal-up.is-visible{opacity:1;transform:translateY(0)}
.fade-in{opacity:0;transition:opacity .8s ease}
.fade-in.is-visible{opacity:1}
.float-in{opacity:0;transform:translateY(12px) scale(.98);transition:opacity .6s ease, transform .6s ease}
.float-in.is-visible{opacity:1;transform:translateY(0) scale(1)}

@media (max-width: 900px){
  .hero-grid,.two-col{grid-template-columns:1fr}
  .contact-card{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr 1fr}
  .work-cards{grid-template-columns:1fr}
}
