:root{
  --ink:#0b1630;
  --ink-2:#12234a;
  --blue:#12306e;
  --blue-2:#1a3f8e;
  --red:#ef2f4f;
  --red-2:#d7263d;
  --text:#e9f1ff;
  --muted:#a8b7d6;
  --line:rgba(255,255,255,.12);
  --glass:rgba(255,255,255,.06);
  --radius:16px;
  --shadow:0 12px 32px rgba(0,0,0,.35);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; font-family: Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  color:var(--text);
  background:
    linear-gradient(180deg, #070c18, #0a1226 58%, #070c18),
    radial-gradient(900px 420px at 12% -8%, rgba(239,47,79,.10), transparent 60%),
    radial-gradient(900px 420px at 88% -10%, rgba(24,86,200,.12), transparent 62%);
  line-height:1.65; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{max-width:100%; height:auto; display:block}
a{color:#cfe0ff; text-decoration:none}
a:hover{text-decoration:underline}
.wrap{width:min(1180px, 92%); margin-inline:auto}
.skip{position:absolute; left:-9999px}
.skip:focus{left:16px; top:16px; background:#fff; color:#111; padding:10px 12px; border-radius:10px}

/* Buttons */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:12px 18px; border-radius:999px; border:1px solid transparent; cursor:pointer; transition:.2s}
.btn-primary{background:linear-gradient(90deg, var(--red-2), var(--red)); color:#fff; box-shadow:0 10px 24px rgba(239,47,79,.25)}
.btn-ghost{background:var(--glass); color:#e8f0ff}
.btn-outline{border-color:#6e84ac; color:#e8f0ff}
.btn-sm{padding:10px 14px; font-size:.95rem}

/* Header */
.hdr{position:sticky; top:0; z-index:50; backdrop-filter:saturate(180%) blur(12px); background:rgba(10,18,40,.65); border-bottom:1px solid var(--line)}
.hdr-row{display:flex; align-items:center; justify-content:space-between; padding:14px 0}
.brand{display:flex; align-items:center; gap:10px; font-weight:700}
.brand img {height: 70px; width: auto;}
.nav ul{display:flex; gap:min(4vw,28px); list-style:none; margin:0; padding:0}
.nav a{padding:20px 12px; border-radius:10px}
.nav a.active,.nav a:hover{background:var(--glass)}
.nav-toggle{display:none; background:none; border:0; padding:10px}
.nav-toggle span{display:block; width:24px; height:2px; background:#e6eeff; margin:5px 0}
@media (max-width: 900px){
  .nav-toggle{display:block}
  .nav{position:fixed; inset:64px 0 auto 0; transform:translateY(-130%); transition:.25s ease; background:rgba(7,12,24,.98); border-top:1px solid var(--line)}
  .nav.open{transform:translateY(0)}
  .nav ul{flex-direction:column; padding:16px}
  body.no-scroll{overflow:hidden}
}

/* Hero */
.hero{padding:clamp(52px,6vw,96px) 0}
.hero-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:min(6vw,48px); align-items:center}
@media (max-width: 980px){ .hero-grid{grid-template-columns:1fr} }
.eyebrow{letter-spacing:.18em; color:#a9b7d6; text-transform:uppercase; font-size:.82rem; margin:0 0 6px}
.hero h1{font-size:clamp(2rem,4.2vw,3.6rem); line-height:1.12; margin:.2rem 0 .6rem}
.lead{color:#cbd9f8; max-width:60ch}
.cta-row{display:flex; gap:12px; flex-wrap:wrap; margin-top:12px}
.stats{display:flex; gap:22px; padding:0; margin:18px 0 0; list-style:none; color:#cfe0ff}
.stats span{display:block; font-weight:700; font-size:1.3rem; color:#fff}
.hero-visual{position:relative}
.hero-visual img{border-radius:18px; border:1px solid var(--line); box-shadow:var(--shadow)}
.hero-visual .angle{position:absolute; right:-26px; top:12%; width:8px; height:76%; background:linear-gradient(180deg, var(--red-2), var(--red)); border-radius:8px}

/* Section base */
.section{padding:44px 0}
.row-head{display:flex; align-items:end; justify-content:space-between; gap:12px}
.link{color:#cfe0ff}

/* Cards */
.card{
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border:1px solid var(--line); border-radius:var(--radius); padding:18px; box-shadow:var(--shadow)
}
.card h2,.card h3{margin:.3rem 0 .4rem}

/* Why / Offer / Service pills — staggered, not 3-col */
.why-offer{
  display:grid; grid-template-columns:2fr 1.3fr; grid-template-rows:auto auto; gap:18px;
  grid-template-areas:
    "why offer"
    "pills offer";
}
.why-main{grid-area:why}
.offer{grid-area:offer; position:relative}
.offer .badge{
  position:absolute; top:12px; right:12px; background:linear-gradient(90deg, var(--red-2), var(--red));
  color:#fff; padding:6px 10px; border-radius:999px; font-size:.8rem; box-shadow:0 8px 16px rgba(239,47,79,.28)
}
.service-pills{grid-area:pills; display:flex; gap:10px; flex-wrap:wrap; align-content:start}
.pill{
  display:inline-flex; gap:10px; align-items:center; padding:10px 14px; border-radius:999px; border:1px solid var(--line);
  background:rgba(255,255,255,.04)
}
.pill img{width:40px; height:auto}
.why-list{margin:10px 0 0; padding-left:18px}
@media (max-width: 980px){
  .why-offer{
    grid-template-columns:1fr; grid-template-areas:
    "why" "offer" "pills";
  }
}

/* Services alt — editorial two-up with cut-in images */
.svc-alt{background:linear-gradient(180deg, #0b1730, #0a162c); border-block:1px solid var(--line)}
.svc-grid{display:grid; gap:28px}
.svc-item{display:grid; grid-template-columns:1.1fr .9fr; gap:22px; align-items:center}
.svc-item.reverse{grid-template-columns:.9fr 1.1fr}
.svc-copy h2{margin:0 0 2px}
.svc-copy h3{margin:.3rem 0 .2rem}
.ticks{margin:10px 0 12px; padding-left:18px}
.ticks li{margin:6px 0}
.cut-in img{border-radius:16px; border:1px solid var(--line); box-shadow:var(--shadow)}
@media (max-width: 980px){ .svc-item,.svc-item.reverse{grid-template-columns:1fr} }

/* Projects — masonry (mixed sizes) */
.projects .masonry{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:16px;
}
.tile{grid-column: span 4; position:relative; border-radius:16px; overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow)}
.tile.wide{grid-column: span 8}
.tile.tall{grid-row: span 2}
.tile img {
  width: 100%;
  height: auto;
  object-fit: contain;   /* show the whole image */
  aspect-ratio: auto;    /* let it use natural proportions */
  transition: transform .4s;
  background: #000;      /* optional: adds background if there are blank sides */
}

.tile:hover img{transform:scale(1.04)}
.tile .meta{position:absolute; inset:auto 0 0 0; padding:12px 14px; background:linear-gradient(180deg, transparent, rgba(7,10,18,.92))}
@media (max-width: 1100px){
  .tile{grid-column: span 6}
  .tile.wide{grid-column: span 12}
}
@media (max-width: 720px){ .tile,.tile.wide{grid-column: span 12} }

/* Process strip — horizontal counter cards */
.process{background:#0a1528; border-block:1px solid var(--line); padding:22px 0}
.process-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:16px}
.process .step{
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border:1px solid var(--line); border-radius:14px; padding:16px; position:relative
}
.process .step span{
  position:absolute; inset:auto 12px 12px auto; width:28px; height:28px; display:grid; place-items:center;
  border-radius:50%; background:linear-gradient(90deg, var(--red-2), var(--red)); color:#fff; font-weight:700; font-size:.9rem
}
@media (max-width: 900px){ .process-grid{grid-template-columns:1fr 1fr} }
@media (max-width: 540px){ .process-grid{grid-template-columns:1fr} }

/* Testimonials — hero + list */
.test-grid{display:grid; grid-template-columns:1.2fr .8fr; gap:18px; align-items:start}
.test-hero{display:grid; grid-template-columns:120px 1fr; gap:14px}
.test-hero img{width:120px; height:120px; object-fit:cover; border-radius:12px; border:1px solid var(--line)}
.test-hero blockquote{margin:0}
.test-hero p{font-size:1.15rem}
.test-list{display:grid; gap:12px}
.test-item{display:grid; grid-template-columns:56px 1fr; gap:12px}
.test-item img{width:56px; height:56px; border-radius:999px; border:1px solid var(--line)}
.stars{color:#ffd166; letter-spacing:.2rem; margin:2px 0 6px}
@media (max-width: 980px){ .test-grid{grid-template-columns:1fr} }

/* FAQ */
.faq details{border:1px solid var(--line); border-radius:12px; padding:12px 14px; background:rgba(255,255,255,.03); margin:10px 0}
.faq summary{cursor:pointer}
.faq summary::-webkit-details-marker{display:none}

/* Contact */
.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:28px}
@media (max-width: 980px){ .contact-grid{grid-template-columns:1fr} }
.form .f{display:flex; flex-direction:column; gap:6px; margin:10px 0}
.form .f input,.form .f select{
  padding:12px 14px; border-radius:12px; border:1px solid #2c3e64; background:#0d1a33; color:#e7efff
}
.chk{display:flex; align-items:center; gap:10px; margin:10px 0}
.chk i{width:16px; height:16px; border-radius:4px; border:1px solid #2c3e64; display:inline-block; position:relative}
.chk input{appearance:none; position:absolute}
.chk input:checked + i::after{content:""; position:absolute; inset:2px; background:linear-gradient(90deg, var(--red-2), var(--red)); border-radius:3px}
.form-note{color:#9eb0cf; font-size:.9rem}

/* Footer */
.ftr{background:#0a1428; border-top:1px solid var(--line); margin-top:28px}
.ftr-grid{display:grid; grid-template-columns:2fr 1fr 1fr 2fr; gap:18px; padding:22px 0}
@media (max-width: 980px){ .ftr-grid{grid-template-columns:1fr 1fr} }
@media (max-width: 560px){ .ftr-grid{grid-template-columns:1fr} }
.legal{display:flex; align-items:center; justify-content:space-between; padding:14px 0 22px}
.legal ul{display:flex; gap:12px; list-style:none; margin:0; padding:0}

/* Reveal motion */
@media (prefers-reduced-motion:no-preference){
  [data-reveal]{opacity:0; transform:translateY(14px); transition:opacity .55s ease, transform .55s ease}
  [data-reveal].in{opacity:1; transform:none}
}


/* Background */

/* ===== Universal background scaffold ===== */
.site-bg{position:fixed; inset:0; z-index:-1; overflow:hidden}
.site-bg .layer{position:absolute; inset:0}
.site-bg .vignette{
  background: radial-gradient(1200px 600px at 50% 110%, rgba(0,0,0,.42), transparent 62%),
              radial-gradient(800px 360px at 8% 10%, rgba(0,0,0,.10), transparent 60%),
              radial-gradient(800px 360px at 92% 8%, rgba(0,0,0,.10), transparent 60%);
  pointer-events:none
}

/* Base palette (red + deep blue) */
:root{
  --red:#ef2f4f; --red-2:#d7263d;
  --blue:#11306d; --blue-2:#1a3f8e;
  --ink:#070c18; --ink-2:#0a1226;
}

/* ===== THEME A: Aurora Silk (soft ribbon gradients, premium) ===== */
/* body.bg-aurora .site-bg -> three silky aurora bands with subtle motion */
body.bg-aurora .site-bg .l1{
  background:
    radial-gradient(900px 420px at 10% -12%, rgba(239,47,79,.18), transparent 62%),
    radial-gradient(900px 420px at 90% -16%, rgba(26,63,142,.22), transparent 64%),
    linear-gradient(180deg, var(--ink-2), var(--ink) 58%, #060a14)
}
body.bg-aurora .site-bg .l2{
  background:
    conic-gradient(from 220deg at 30% 15%, rgba(239,47,79,.22), rgba(239,47,79,.06) 22%, transparent 40%, rgba(26,63,142,.22) 60%, rgba(26,63,142,.05) 78%, transparent 100%);
  filter: blur(22px) saturate(115%);
  animation: auroraShift 26s ease-in-out infinite alternate
}
body.bg-aurora .site-bg .l3{
  background:
    conic-gradient(from -20deg at 70% 12%, rgba(26,63,142,.22), rgba(26,63,142,.06) 28%, transparent 46%, rgba(239,47,79,.22) 74%, rgba(239,47,79,.06) 92%, transparent 100%);
  filter: blur(28px) saturate(120%);
  mix-blend-mode: screen;
  animation: auroraShift2 32s ease-in-out infinite alternate-reverse
}
@keyframes auroraShift{0%{transform:translateY(0)}100%{transform:translateY(-4%)}}
@keyframes auroraShift2{0%{transform:translateX(0)}100%{transform:translateX(3%)}}

/* Micro-grid, masked to edges (adds structure, not noise) */
body.bg-aurora .site-bg::before{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(to right, rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 28px 28px;
  -webkit-mask: radial-gradient(800px 520px at 50% 35%, rgba(0,0,0,0) 0%, #000 75%);
  mask: radial-gradient(800px 520px at 50% 35%, rgba(0,0,0,0) 0%, #000 75%);
  opacity:.35; pointer-events:none
}

/* ===== THEME B: Luxe Spotlight (subtle interactive spotlight + glass beams) ===== */
body.bg-spotlight .site-bg .l1{
  background: linear-gradient(180deg, var(--ink-2), var(--ink) 60%, #060a14),
              radial-gradient(900px 420px at 8% -10%, rgba(239,47,79,.16), transparent 60%),
              radial-gradient(900px 420px at 92% -12%, rgba(26,63,142,.20), transparent 62%)
}
/* diagonal beams */
body.bg-spotlight .site-bg .l2{
  background: repeating-linear-gradient(14deg, rgba(255,255,255,.05) 0 2px, transparent 2px 18px);
  -webkit-mask: linear-gradient(180deg, rgba(0,0,0,.0) 0, rgba(0,0,0,.8) 40%, #000 70%);
  mask: linear-gradient(180deg, rgba(0,0,0,.0) 0, rgba(0,0,0,.8) 40%, #000 70%);
  opacity:.7
}
/* spotlight circle follows cursor (CSS var set via tiny JS below) */
body.bg-spotlight .site-bg .l3{
  background:
    radial-gradient(280px 280px at var(--sx,50%) var(--sy,30%), rgba(255,255,255,.12), rgba(255,255,255,0) 60%),
    radial-gradient(420px 420px at calc(var(--sx,50%) + 10%) calc(var(--sy,30%) + 6%), rgba(239,47,79,.18), transparent 70%);
  mix-blend-mode: screen
}

/* ===== THEME C: Sculpted Waves (elegant layered wave shapes) ===== */
body.bg-waves .site-bg .l1{
  background: linear-gradient(180deg, var(--ink-2), var(--ink) 58%, #060a14)
}
body.bg-waves .site-bg .l2{
  --c1: rgba(239,47,79,.18); --c2: rgba(26,63,142,.18);
  background:
    radial-gradient(1200px 200px at 50% 12%, var(--c2), transparent 70%),
    radial-gradient(1200px 220px at 48% 8%, var(--c1), transparent 72%);
  -webkit-mask:
    conic-gradient(from 180deg at 50% 8%, #000 0 45%, transparent 45% 55%, #000 55% 100%);
  mask:
    conic-gradient(from 180deg at 50% 8%, #000 0 45%, transparent 45% 55%, #000 55% 100%);
  filter: blur(8px) saturate(115%)
}
body.bg-waves .site-bg .l3{
  --c3: rgba(26,63,142,.20); --c4: rgba(239,47,79,.16);
  background:
    radial-gradient(1200px 220px at 50% 20%, var(--c3), transparent 70%),
    radial-gradient(1200px 220px at 52% 16%, var(--c4), transparent 72%);
  -webkit-mask:
    conic-gradient(from 180deg at 50% 16%, #000 0 40%, transparent 40% 60%, #000 60% 100%);
  mask:
    conic-gradient(from 180deg at 50% 16%, #000 0 40%, transparent 40% 60%, #000 60% 100%);
  filter: blur(10px)
}

/* Motion-safe */
@media (prefers-reduced-motion: reduce){
  body.bg-aurora .site-bg .l2,
  body.bg-aurora .site-bg .l3{ animation:none }
}
