@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@500;600;700&family=Inter:wght@300;400;500;600;700&family=Sora:wght@400;500;600;700&display=swap');

:root{
  --dark:#070A12;
  --dark2:#090D19;
  --text:#EAF0FF;
  --gold:#c6a96a;
  --violet:#7c5cff;
  --cyan:#32d6ff;
  --radius:22px;
  --radius2:14px;
  --shadow:0 18px 60px rgba(0,0,0,.45);
  --max:1200px;
  --ease:cubic-bezier(.2,.9,.2,1);
  --line:rgba(255,255,255,.10);
  --panel:rgba(255,255,255,.045);
}

html{scroll-behavior:smooth}

html, body {
  margin: 0;
  padding: 0;
  overflow-x: hidden;
  overflow-y: auto;
}

.nav-mobile,
.portfolio-modal {
  overflow: hidden;
}

*{margin:0;padding:0;box-sizing:border-box}
html,body{overflow-x:hidden}
body{
  font-family:'Inter',sans-serif;
  background:
    radial-gradient(1200px 650px at 15% 10%, rgba(124,92,255,.22), transparent 55%),
    radial-gradient(1100px 650px at 85% 15%, rgba(50,214,255,.16), transparent 55%),
    radial-gradient(900px 650px at 55% 95%, rgba(56,230,166,.10), transparent 55%),
    linear-gradient(180deg,var(--dark),var(--dark2));
  color:var(--text);
  line-height:1.6;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.progress-line{
  position:fixed;top:0;left:0;height:3px;width:0%;z-index:1200;
  background:linear-gradient(90deg,var(--violet),var(--cyan),var(--gold));
  box-shadow:0 0 22px rgba(124,92,255,.45);
}

.ambient{
  position:fixed;inset:auto;z-index:0;pointer-events:none;filter:blur(24px);opacity:.65;
  animation:floatBlob 18s ease-in-out infinite;
}
.ambient-1{width:280px;height:280px;left:-70px;top:12vh;border-radius:50%;background:radial-gradient(circle, rgba(124,92,255,.34), transparent 68%)}
.ambient-2{width:380px;height:380px;right:-110px;top:18vh;border-radius:50%;background:radial-gradient(circle, rgba(50,214,255,.22), transparent 68%);animation-delay:-6s}
.ambient-3{width:300px;height:300px;left:38%;bottom:-120px;border-radius:50%;background:radial-gradient(circle, rgba(198,169,106,.16), transparent 68%);animation-delay:-12s}
@keyframes floatBlob{
  0%,100%{transform:translate3d(0,0,0) scale(1)}
  50%{transform:translate3d(0,-24px,0) scale(1.06)}
}

/* grain */
.grain{
  pointer-events:none;
  position:fixed;inset:0;z-index:1;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='260' height='260'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='260' height='260' filter='url(%23n)' opacity='.18'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;opacity:.22;
  animation:grain 10s steps(10) infinite;
}
@keyframes grain{
  0%{transform:translate(0,0)}
  20%{transform:translate(-6%,2%)}
  40%{transform:translate(-4%,6%)}
  60%{transform:translate(4%,5%)}
  80%{transform:translate(-3%,-2%)}
  100%{transform:translate(0,0)}
}

/* navbar */
.navbar{
  position:sticky;top:0;z-index:50;
  background:rgba(5,7,12,.35);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(255,255,255,.06);
  box-shadow:0 8px 30px rgba(0,0,0,.14);
  transition:all .4s var(--ease);
}
.navbar.scrolled{background:rgba(5,7,12,.72);box-shadow:0 12px 45px rgba(0,0,0,.35)}
.nav-inner{
  max-width:var(--max);margin:auto;
  padding:14px 20px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
}
.nav-left,.nav-right{display:flex;gap:24px;list-style:none}
.nav-left a,.nav-right a{
  color:rgba(234,240,255,.68);
  font-size:12px;letter-spacing:1.8px;text-transform:uppercase;
  transition:color .25s var(--ease),opacity .25s var(--ease);
  position:relative;padding-bottom:8px;
}
.nav-left a::after,.nav-right a::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:0;
  background:linear-gradient(90deg,var(--gold),transparent);
  transition:width .25s var(--ease);
}
.nav-left a:hover,.nav-right a:hover{color:#fff}
.nav-left a:hover::after,.nav-right a:hover::after{width:100%}
.nav-logo a{
  font-family:'Cormorant Garamond',serif;
  font-size:34px;letter-spacing:4px;color:#fff;position:relative;line-height:1;
}
.nav-logo a::after{
  content:"";position:absolute;left:50%;bottom:-10px;
  width:28px;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  transform:translateX(-50%);opacity:.55;
}

/* hamburger */
.hamburger{
  display:none;
  background:transparent;
  border:1px solid rgba(255,255,255,.12);
  width:44px;height:44px;border-radius:14px;
  cursor:pointer;align-items:center;justify-content:center;gap:5px;padding:0;
}
.hamburger span{width:20px;height:2px;background:rgba(255,255,255,.85);display:block;transition:transform .25s var(--ease),opacity .25s var(--ease)}
.hamburger.active span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* mobile menu */
.nav-mobile{
  position:fixed;top:72px;left:0;width:100%;height:calc(100vh - 72px);
  background:rgba(0,0,0,.94);
  display:flex;justify-content:center;align-items:center;
  transform:translateY(-120%);transition:.4s var(--ease);
  z-index:999;
}
.nav-mobile.open{transform:translateY(0)}
.nav-mobile ul{list-style:none;text-align:center;display:flex;flex-direction:column;gap:22px}
.nav-mobile a{color:#fff;font-size:18px;letter-spacing:2px}

/* hero */
.hero{
  min-height:100svh;
  position:relative;
  overflow:hidden;
  z-index:2;
  display:flex;
  align-items:center;
  justify-content:center;
}

.hero-video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  transform:scale(1.02);
  filter:saturate(1.05) contrast(1.05);
  z-index:0;
}

.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(800px 600px at 50% 45%, rgba(0,0,0,.08), rgba(0,0,0,.58)),
    linear-gradient(180deg, rgba(0,0,0,.28), rgba(0,0,0,.72));
  z-index:1;
}


.hero-badge,
.hero-title,
.hero-sub,
.hero-cta,
.hero-stats,
.scroll-hint{
  position:relative;
  z-index:4;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:10px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  padding:10px 14px;border-radius:999px;
  box-shadow:var(--shadow);backdrop-filter:blur(10px);
}
.hero-badge .dot{
  width:10px;height:10px;border-radius:999px;
  background:linear-gradient(135deg,var(--violet),var(--cyan));
  box-shadow:0 0 0 6px rgba(124,92,255,.14);
}
.hero-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(54px,7vw,102px);
  letter-spacing:2px;margin-top:16px;
  text-shadow:0 18px 55px rgba(0,0,0,.55);
  line-height:.95;
}
.hero-title span,.hero-title em{display:inline-block}
.hero-title em{
  font-style:normal;
  background:linear-gradient(135deg,#fff,var(--gold),#fff);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 20px rgba(198,169,106,.18));
}
.hero-sub{margin-top:14px;max-width:860px;font-size:clamp(14px,1.6vw,18px);color:rgba(234,240,255,.78)}
.hero-trust{
  display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:16px
}
.hero-trust span{
  padding:9px 12px;border-radius:999px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.09);
  font-size:11px;letter-spacing:1.8px;text-transform:uppercase;color:rgba(234,240,255,.74)
}
.hero-cta{display:flex;gap:12px;margin-top:22px;flex-wrap:wrap;justify-content:center}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:15px 20px;border-radius:18px;
  font-size:12px;font-family:'Sora',sans-serif;font-weight:600;letter-spacing:2px;text-transform:uppercase;
  border:1px solid rgba(255,255,255,.16);
  transition:transform .25s var(--ease),border-color .25s var(--ease),background .25s var(--ease),box-shadow .25s var(--ease);
  user-select:none;
  position:relative;overflow:hidden;
}
.btn::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(115deg,transparent 20%,rgba(255,255,255,.18) 50%,transparent 80%);
  transform:translateX(-120%);transition:transform .6s var(--ease);
}
.btn:hover{transform:translateY(-3px);box-shadow:0 14px 34px rgba(0,0,0,.18)}
.btn:hover::before{transform:translateX(120%)}
.btn-primary{
  background:linear-gradient(135deg, rgba(124,92,255,.95), rgba(50,214,255,.90));
  border-color:rgba(255,255,255,.22);
  box-shadow:0 18px 50px rgba(124,92,255,.22);
}
.btn-ghost{background:rgba(255,255,255,.06)}
.hero-stats{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;margin-top:28px;width:min(980px,100%);
}
.stat{
  padding:16px 14px;border-radius:var(--radius);
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.10);
  backdrop-filter:blur(10px);
}
.stat-top{font-size:12px;letter-spacing:2px;color:rgba(234,240,255,.62);text-transform:uppercase}
.stat-big{font-size:28px;margin-top:8px}
.stat-sub{font-size:13px;color:rgba(234,240,255,.68);margin-top:6px}
.scroll-hint{
  position:absolute;bottom:18px;display:flex;align-items:center;gap:10px;
  color:rgba(234,240,255,.65);font-size:12px;letter-spacing:2px;text-transform:uppercase;
}
.scroll-hint i{
  width:20px;height:30px;border-radius:999px;border:1px solid rgba(255,255,255,.18);
  position:relative;overflow:hidden;
}
.scroll-hint i::after{
  content:"";position:absolute;left:50%;top:6px;width:4px;height:4px;border-radius:999px;
  background:rgba(255,255,255,.8);transform:translateX(-50%);
  animation:wheel 1.6s var(--ease) infinite;
}
@keyframes wheel{
  0%{transform:translate(-50%,0);opacity:1}
  70%{transform:translate(-50%,14px);opacity:.2}
  100%{transform:translate(-50%,0);opacity:1}
}

/* reveal */
[data-reveal]{opacity:0;transform:translateY(14px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.revealed{opacity:1!important;transform:translateY(0)!important}

/* sections */
.section{padding:110px 20px;text-align:center;position:relative;z-index:2}
.section-head{max-width:860px;margin:0 auto 56px}
.section-kicker{
  display:inline-flex;align-items:center;gap:10px;margin-bottom:14px;
  font-size:11px;letter-spacing:3px;text-transform:uppercase;color:rgba(234,240,255,.62)
}
.section-kicker::before,.section-kicker::after{
  content:"";display:block;width:34px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent)
}
.section h2{font-family:'Cormorant Garamond',serif;font-size:46px;letter-spacing:1px;line-height:1.05}
.section-sub{margin-top:12px;color:rgba(234,240,255,.70);letter-spacing:.4px}

/* portfolio */
.portfolio-wrapper{max-width:1100px;margin:auto}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.portfolio-page{display:none}
.portfolio-page.active{display:grid}
.portfolio-item{
  position:relative;border-radius:18px;overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  box-shadow:0 18px 60px rgba(0,0,0,.25);
  transform:translateZ(0);
}
.portfolio-item img{
  width:100%;aspect-ratio:16/10;object-fit:cover;
  transition:transform .45s var(--ease),filter .45s var(--ease);
}
.portfolio-overlay{
  position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:space-between;
  padding:16px;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.75));
  opacity:0;transition:opacity .35s var(--ease);
}
.po-title{font-family:'Playfair Display',serif;letter-spacing:1px;font-size:18px;text-align:left}
.po-chip{
  font-size:12px;letter-spacing:2px;padding:8px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.07);
}
.portfolio-item:hover img,
.portfolio-item:hover video{transform:scale(1.06);filter:brightness(.82)}
.portfolio-item:hover .portfolio-overlay{opacity:1}
.portfolio-item::after{
  content:"";position:absolute;inset:-2px;
  background:
    radial-gradient(600px 240px at 30% 10%, rgba(124,92,255,.25), transparent 55%),
    radial-gradient(600px 240px at 70% 90%, rgba(50,214,255,.20), transparent 55%);
  opacity:0;transition:opacity .35s var(--ease);pointer-events:none;
}
.portfolio-item:hover::after{opacity:1}

.portfolio-nav{margin-top:46px;display:flex;justify-content:center;align-items:center;gap:18px}
.lux-nav-btn{
  width:50px;height:50px;border-radius:50%;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.18);
  color:#fff;font-size:18px;cursor:pointer;
  transition:transform .25s var(--ease),background .25s var(--ease);
}
.lux-nav-btn:hover{transform:translateY(-2px);background:rgba(255,255,255,.10)}
.lux-nav-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}
#pageIndicator{font-size:12px;letter-spacing:2px;color:rgba(234,240,255,.60)}

/* about */
.about-inner{max-width:1100px;margin:auto;display:flex;gap:60px;align-items:center;justify-content:center}
.about-media{position:relative;width:min(460px,100%)}
.about-media img{
  width:100%;border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:var(--shadow);
}
.about-glow{
  position:absolute;inset:-18px;
  background:
    radial-gradient(350px 250px at 30% 30%, rgba(124,92,255,.25), transparent 60%),
    radial-gradient(350px 250px at 70% 70%, rgba(50,214,255,.18), transparent 60%);
  filter:blur(10px);z-index:-1;
}
.about-text{text-align:left;max-width:560px}
.about-btn{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(198,169,106,.55);
  color:var(--gold);
  padding:14px 18px;border-radius:16px;
  cursor:pointer;letter-spacing:2px;text-transform:uppercase;
  transition:transform .25s var(--ease),background .25s var(--ease);
}
.about-btn:hover{transform:translateY(-2px);background:rgba(255,255,255,.08)}
.about-btn .chev{display:inline-block;transition:transform .25s var(--ease)}
.about-btn[aria-expanded="true"] .chev{transform:rotate(180deg)}
.about-hidden{
  margin-top:18px;max-height:0;overflow:hidden;opacity:0;transform:translateY(-6px);
  transition:max-height .55s var(--ease),opacity .45s var(--ease),transform .45s var(--ease);
}
.about-hidden.open{max-height:700px;opacity:1;transform:translateY(0)}
.about-hidden p{color:rgba(234,240,255,.74)}

/* services */
.services-grid{max-width:1100px;margin:auto;display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.service-card{
  position:relative;padding:44px 28px;
  background:rgba(255,255,255,.04);
  border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.10);
  backdrop-filter:blur(10px);
  transition:transform .35s var(--ease),border-color .35s var(--ease);
  overflow:hidden;
}
.service-card::before{
  content:"";position:absolute;inset:-2px;
  background:
    radial-gradient(420px 160px at 30% 10%, rgba(124,92,255,.22), transparent 58%),
    radial-gradient(420px 160px at 70% 90%, rgba(50,214,255,.18), transparent 58%);
  opacity:0;transition:opacity .35s var(--ease);pointer-events:none;
}
.service-card:hover{transform:translateY(-10px);border-color:rgba(198,169,106,.55)}
.service-card:hover::before{opacity:1}
.service-icon{font-size:34px;margin-bottom:18px}
.service-card h3{font-family:'Playfair Display',serif;font-size:20px;margin-bottom:10px;letter-spacing:1px}
.service-card p{font-size:14px;color:rgba(234,240,255,.65)}
.service-line{
  position:absolute;bottom:0;left:50%;width:0%;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  transition:width .35s var(--ease);transform:translateX(-50%);
}
.service-card:hover .service-line{width:100%}

/* marquee brands */
.marquee{
  width:min(1100px,100%);margin:0 auto;overflow:hidden;
  border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03);
  position:relative;
}
.marquee::before,.marquee::after{
  content:"";position:absolute;top:0;bottom:0;width:90px;pointer-events:none;z-index:2;
}
.marquee::before{left:0;background:linear-gradient(90deg,rgba(7,10,18,1),rgba(7,10,18,0))}
.marquee::after{right:0;background:linear-gradient(270deg,rgba(7,10,18,1),rgba(7,10,18,0))}
.marquee-track{
  display:flex;gap:70px;width:max-content;padding:24px 28px;
  animation:marquee 22s linear infinite;
}
.marquee-track span{
  font-family:'Playfair Display',serif;
  font-size:28px;letter-spacing:3px;
  color:rgba(234,240,255,.62);
  white-space:nowrap;transition:color .25s var(--ease);
}
.marquee-track span:hover{color:var(--gold)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* reviews marquee */
.reviews-marquee{width:min(1100px,100%);margin:0 auto;overflow:hidden;position:relative}
.reviews-track{display:flex;gap:18px;width:max-content;animation:reviews 32s linear infinite;padding:6px 0}
.review{
  min-width:320px;padding:22px;border-radius:var(--radius);
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 18px 60px rgba(0,0,0,.22);
  flex-shrink:0;text-align:left;
}
.review .stars{font-size:12px;letter-spacing:1px;color:var(--gold)}
.review p{margin-top:10px;color:rgba(234,240,255,.74)}
.review .by{display:block;margin-top:12px;font-size:12px;letter-spacing:2px;color:rgba(234,240,255,.55);text-transform:uppercase}
@keyframes reviews{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* contact */
.contact-lux{padding:120px 20px;text-align:center}
.contact-grid{
  max-width:1100px;margin:auto;
  display:grid;grid-template-columns:2fr 1fr;gap:50px;align-items:start;
}
.lux-form{
  background:rgba(255,255,255,.03);
  padding:44px;border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.10);
  display:grid;grid-template-columns:1fr 1fr;gap:26px;
}
.lux-input{position:relative}
.lux-input.full{grid-column:1 / -1}
.lux-input input,.lux-input textarea{
  width:100%;background:transparent;border:none;
  border-bottom:1px solid rgba(255,255,255,.20);
  padding:12px 0;color:#fff;font-size:15px;outline:none;
}
.lux-input textarea{min-height:120px;resize:none}
.lux-input label{
  position:absolute;top:12px;left:0;
  font-size:12px;color:rgba(234,240,255,.55);letter-spacing:2px;
  transition:.25s var(--ease);pointer-events:none;text-transform:uppercase;
}
.lux-input input:focus + label,.lux-input textarea:focus + label,
.lux-input input:valid + label,.lux-input textarea:valid + label{
  top:-10px;font-size:11px;color:var(--gold)
}
.lux-btn{
  grid-column:1 / -1;margin-top:8px;
  padding:15px 40px;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.18);
  color:#fff;letter-spacing:3px;cursor:pointer;border-radius:16px;
  transition:transform .25s var(--ease),background .25s var(--ease);
}
.lux-btn:hover{transform:translateY(-2px);background:rgba(255,255,255,.10)}
.contact-info-lux{display:flex;flex-direction:column;gap:16px}
.info-card{
  padding:22px;border-radius:var(--radius);
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.10);
  text-align:left;
}
.info-card.subtle{opacity:.85}
.info-card span{font-size:11px;letter-spacing:3px;color:rgba(234,240,255,.55)}
.info-card p{margin-top:8px;font-size:15px;color:rgba(234,240,255,.78)}

/* modal */
.portfolio-modal{
  position:fixed;inset:0;
  background:rgba(0,0,0,.60);
  backdrop-filter:blur(10px);
  display:none;align-items:center;justify-content:center;
  z-index:9999;padding:18px;
}
.portfolio-modal.show{display:flex}
.portfolio-modal-content{
  width:100%;max-width:1040px;
  background:rgba(12,14,22,.92);
  border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:var(--shadow);
  position:relative;
  animation:modalIn .25s var(--ease);
}
@keyframes modalIn{
  from{opacity:0;transform:translateY(8px) scale(.985)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.modal-close{
  position:absolute;top:12px;right:12px;
  width:44px;height:44px;border-radius:14px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  color:#fff;cursor:pointer;
}
.modal-grid{display:grid;grid-template-columns:1.35fr 1fr;gap:18px;padding:18px}
.modal-media{padding:6px}
.modal-main{
  position:relative;border-radius:var(--radius2);
  overflow:hidden;border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03);
}
.modal-main img{width:100%;height:min(56vh,520px);object-fit:cover}
.modal-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.35);color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-size:26px;
}
.modal-nav.prev{left:10px}
.modal-nav.next{right:10px}
.modal-nav:disabled{opacity:.35;cursor:not-allowed}
.modal-thumbs{
  display:flex;gap:10px;overflow:auto;padding:12px 2px 4px 2px;
}
.thumb{
  width:86px;height:56px;border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  overflow:hidden;flex:0 0 auto;cursor:pointer;
  opacity:.78;transition:opacity .2s var(--ease),transform .2s var(--ease),border-color .2s var(--ease);
  background:rgba(255,255,255,.04);
}
.thumb img{width:100%;height:100%;object-fit:cover}
.thumb.active{opacity:1;transform:translateY(-1px);border-color:rgba(198,169,106,.55)}

.modal-info{padding:10px 10px 14px;text-align:left}
.modal-info h3{font-family:'Playfair Display',serif;letter-spacing:1px;font-size:26px}
.modal-info p{margin-top:10px;color:rgba(234,240,255,.72)}
.modal-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.modal-tags span{
  padding:8px 10px;border-radius:999px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  font-size:12px;letter-spacing:1px;
}
.modal-rich{margin-top:16px;display:grid;gap:10px}
.rich-card{
  padding:12px 14px;border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
}
.rich-card b{
  display:block;font-size:12px;letter-spacing:2px;text-transform:uppercase;
  color:rgba(234,240,255,.78);
}
.rich-card p{margin-top:6px;font-size:13px;color:rgba(234,240,255,.68)}

/* scroll reveal */
.hidden{opacity:0;transform:translateY(18px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.show{opacity:1;transform:translateY(0)}

/* responsive */
@media (max-width:1024px){
  .portfolio-grid{grid-template-columns:repeat(2,1fr)}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .about-inner{flex-direction:column}
  .about-text{text-align:center}
  .contact-grid{grid-template-columns:1fr}
  .modal-grid{grid-template-columns:1fr}
  .modal-main img{height:min(50vh,520px)}
}
@media (max-width:768px){
  .nav-left,.nav-right{display:none}
  .hamburger{display:flex}
  .section{padding:86px 20px}
  .portfolio-grid{grid-template-columns:1fr}
  .services-grid{grid-template-columns:1fr}
  .hero-stats{grid-template-columns:1fr}
  .review{min-width:260px}
  .lux-form{grid-template-columns:1fr;padding:34px}
  .footer-inner{flex-direction:column;text-align:center;align-items:center}
  .footer-links{justify-content:center}
  .modal-nav{display:none}
  .portfolio-modal{align-items:flex-end}
  .portfolio-modal-content{border-radius:22px 22px 0 0}
  .modal-main img{height:44vh}
}
@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
}


.portfolio-item,.service-card,.review,.info-card,.lux-form,.stat,.marquee,.portfolio-modal-content{
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    0 18px 60px rgba(0,0,0,.24);
}
.portfolio-item::before,.service-card::after,.review::before,.info-card::before{
  content:"";
  position:absolute;left:16px;right:16px;top:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.24),transparent);
  pointer-events:none;
}
.service-card h3,.footer-brand h3,.modal-info h3,.po-title{
  font-family:'Cormorant Garamond',serif;
}
.tilt-card{
  transform-style:preserve-3d;
  will-change:transform;
}
.lux-input input,.lux-input textarea{
  transition:border-color .25s var(--ease),transform .25s var(--ease),background .25s var(--ease);
}
.lux-input input:focus,.lux-input textarea:focus{
  border-bottom-color:rgba(198,169,106,.9);
}
.footer-modern{
  position:relative;overflow:hidden;
}
.footer-modern::before{
  content:"";position:absolute;inset:auto 0 100% 0;height:160px;
  background:linear-gradient(180deg,transparent,rgba(255,255,255,.02));
}


/* ultra pack */
.page-loader{
  position:fixed; inset:0; z-index:1400; display:grid; place-items:center;
  background:radial-gradient(1000px 500px at 50% 25%, rgba(124,92,255,.18), transparent 60%), #060913;
  transition:opacity .7s var(--ease), visibility .7s var(--ease);
}
.page-loader.hide{opacity:0; visibility:hidden}
.loader-mark{
  font-family:'Cormorant Garamond',serif; font-size:clamp(32px,6vw,76px); letter-spacing:6px;
  color:#fff; position:relative; text-transform:none;
}
.loader-mark::after{
  content:''; display:block; width:120px; height:2px; margin:18px auto 0;
  background:linear-gradient(90deg, transparent, var(--gold), var(--cyan), transparent);
  animation:loaderSweep 1.6s var(--ease) infinite;
}
@keyframes loaderSweep{0%{opacity:.3;transform:scaleX(.45)}50%{opacity:1;transform:scaleX(1)}100%{opacity:.3;transform:scaleX(.45)}}
.cursor-glow{
  position:fixed; left:0; top:0; width:28px; height:28px; border-radius:50%; pointer-events:none; z-index:1300;
  background:radial-gradient(circle, rgba(255,255,255,.75), rgba(50,214,255,.22) 40%, transparent 68%);
  mix-blend-mode:screen; transform:translate(-50%,-50%); opacity:.8; filter:blur(2px);
  transition:width .2s var(--ease), height .2s var(--ease), opacity .2s var(--ease);
}
.cursor-glow.active{width:60px; height:60px; opacity:.95}
.hero{min-height:100svh}
.hero-grid{
  position:relative; z-index:2; display:grid; grid-template-columns:minmax(0,1.15fr) minmax(280px,.85fr);
  align-items:center; gap:28px; width:min(1280px, calc(100% - 40px)); margin:0 auto; min-height:calc(100svh - 72px);
}
.hero-overlay{
  position:relative; inset:auto; padding:88px 18px 52px; min-height:calc(100svh - 72px); justify-content:center;
  align-items:flex-start; text-align:left; background:
    radial-gradient(900px 620px at 24% 40%, rgba(0,0,0,.16), rgba(0,0,0,.32)),
    linear-gradient(180deg, rgba(0,0,0,.28), rgba(0,0,0,.68));
}
.hero-badge{margin-top:12px}
.hero-title{
  margin-top:18px; font-family:'Cormorant Garamond',serif; font-size:clamp(60px,10vw,124px); line-height:.92;
  letter-spacing:2px; display:flex; flex-wrap:wrap; gap:.14em; align-items:flex-end;
}
.hero-title em{
  font-style:normal; color:transparent; -webkit-text-stroke:1px rgba(255,255,255,.52);
  text-shadow:none;
}
.hero-sub{max-width:700px; font-size:clamp(15px,1.45vw,19px)}
.hero-cta{margin-top:26px}
.hero-trust{display:flex; gap:10px; flex-wrap:wrap; margin-top:18px}
.hero-trust span{
  font-size:11px; letter-spacing:2px; text-transform:uppercase; color:rgba(234,240,255,.8);
  padding:10px 12px; border-radius:999px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12);
}
.glass-card{
  background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.16); box-shadow:0 24px 80px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter:blur(16px);
}
.hero-side{position:relative; z-index:3; display:grid; gap:18px; padding-top:72px}
.hero-float-card{padding:26px; border-radius:26px; transform:translateY(-8px) rotate(-2deg)}
.float-label{display:inline-block; margin-bottom:12px; font-size:11px; letter-spacing:3px; text-transform:uppercase; color:var(--gold)}
.hero-float-card strong{display:block; font-size:30px; line-height:1.05; font-family:'Sora',sans-serif}
.hero-float-card p{margin-top:12px; color:rgba(234,240,255,.72)}
.hero-mini-stack{display:grid; gap:14px}
.mini-card{display:grid; grid-template-columns:auto 1fr; gap:8px 12px; align-items:center; padding:18px 20px; border-radius:22px}
.mini-card span{grid-row:1 / span 2; font-family:'Cormorant Garamond',serif; font-size:34px; color:rgba(255,255,255,.38)}
.mini-card b{font-size:15px; letter-spacing:.5px}
.mini-card small{color:rgba(234,240,255,.62); font-size:12px; letter-spacing:1.5px; text-transform:uppercase}
.hero-orbits{position:absolute; inset:0; z-index:1; pointer-events:none}
.orbit{position:absolute; border:1px solid rgba(255,255,255,.1); border-radius:50%; animation:spinOrbit linear infinite}
.orbit-a{width:540px; height:540px; right:8%; top:18%; animation-duration:22s}
.orbit-b{width:720px; height:720px; right:-2%; top:8%; animation-duration:34s; border-style:dashed}
.orbit-c{width:260px; height:260px; right:18%; top:34%; animation-duration:14s}
@keyframes spinOrbit{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.section{overflow:hidden}
.section-shell{
  position:absolute; inset:26px 20px auto; height:calc(100% - 52px); border-radius:34px;
  border:1px solid rgba(255,255,255,.05); background:linear-gradient(180deg, rgba(255,255,255,.018), rgba(255,255,255,.01));
  pointer-events:none; z-index:0;
}
.section-head{position:relative; z-index:1}
.section h2{font-size:clamp(34px,4vw,54px); line-height:1.05}
.section-sub{font-size:15px}
.portfolio-item,.service-card,.review,.info-card{position:relative; overflow:hidden}
.portfolio-item::before,.service-card::after,.review::after,.info-card::after{
  content:''; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(115deg, transparent 12%, rgba(255,255,255,.16) 24%, transparent 35%);
  transform:translateX(-140%); transition:transform .9s var(--ease);
}
.portfolio-item:hover::before,.service-card:hover::after,.review:hover::after,.info-card:hover::after{transform:translateX(140%)}
.portfolio-overlay{padding:18px}
.po-chip{background:rgba(255,255,255,.1); backdrop-filter:blur(10px)}
.service-card{padding-top:54px}
.service-card h3{font-family:'Sora',sans-serif; font-size:18px; text-transform:uppercase; letter-spacing:1.2px}
.service-icon{position:relative}
.service-icon::after{content:''; position:absolute; left:50%; top:50%; width:54px; height:54px; border-radius:50%; background:radial-gradient(circle, rgba(124,92,255,.25), transparent 65%); transform:translate(-50%,-50%); z-index:-1}
.review{background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03))}
.review .stars{font-size:13px}
.reviews-track:hover,.marquee-track:hover{animation-play-state:paused}
.lux-form,.info-card,.modal-main,.portfolio-item,.service-card,.review,.marquee{box-shadow:0 25px 80px rgba(0,0,0,.20)}
.footer-modern{position:relative; overflow:hidden}
.footer-modern::before{content:''; position:absolute; inset:0 0 auto; height:1px; background:linear-gradient(90deg, transparent, rgba(255,255,255,.3), transparent)}
.footer-seo-links{margin-top:18px; opacity:.9}
.back-to-top{
  position:fixed; right:24px; bottom:24px; width:52px; height:52px; border:none; border-radius:18px; z-index:999;
  background:linear-gradient(135deg, rgba(124,92,255,.9), rgba(50,214,255,.9)); color:#fff; font-size:22px; cursor:pointer;
  box-shadow:0 18px 42px rgba(0,0,0,.35); opacity:0; pointer-events:none; transform:translateY(16px);
  transition:opacity .3s var(--ease), transform .3s var(--ease);
}
.back-to-top.show{opacity:1; pointer-events:auto; transform:translateY(0)}
.tilt-card{transform-style:preserve-3d; will-change:transform}
@media (max-width:1100px){
  .hero-grid{grid-template-columns:1fr; min-height:auto}
  .hero-overlay{min-height:auto; align-items:center; text-align:center; padding:84px 18px 28px}
  .hero-sub{margin-inline:auto}
  .hero-trust,.hero-cta{justify-content:center}
  .hero-side{padding:0 18px 64px; max-width:720px; margin:0 auto}
  .hero-float-card{transform:none}
  .orbit-a{right:50%; transform:translateX(50%)}
  .orbit-b{right:50%; transform:translateX(50%)}
  .orbit-c{display:none}
}
@media (max-width:768px){
  .page-loader{display:none}
  .cursor-glow{display:none}
  .hero{min-height:auto}
  .hero-grid{width:min(100% - 24px, 100%); gap:16px}
  .hero-overlay{padding:76px 12px 20px}
  .hero-title{font-size:clamp(44px,15vw,72px); justify-content:center; white-space:normal; word-break:keep-all}
  .hero-title em{-webkit-text-stroke:.7px rgba(255,255,255,.45)}
  .hero-sub{font-size:15px; max-width:34ch}
  .hero-trust{gap:8px; margin-top:14px}
  .hero-trust span{font-size:10px; letter-spacing:1.4px; padding:8px 10px}
  .hero-stats{grid-template-columns:1fr; gap:10px; max-width:320px; margin:24px auto 0}
  .hero-side{padding:0 0 70px}
  .hero-float-card{padding:22px}
  .hero-float-card strong{font-size:24px}
  .section-shell{inset:16px 10px auto}
  .hero-mini-stack{grid-template-columns:1fr}
  .mini-card{padding:16px 18px}
  .mini-card small{font-size:11px; letter-spacing:1px}
  .scroll-hint{display:none}
}


/* premium motion layer */
body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  background:
    radial-gradient(700px 320px at 50% -5%, rgba(255,255,255,.05), transparent 72%),
    radial-gradient(520px 260px at 18% 18%, rgba(198,169,106,.08), transparent 68%),
    radial-gradient(580px 280px at 82% 22%, rgba(50,214,255,.07), transparent 68%);
  opacity:.95;
}

.starfield,
.shooting-stars,
.premium-vignette{
  position:fixed;
  inset:0;
  pointer-events:none;
}
.starfield{z-index:0; overflow:hidden; opacity:.95;}
.shooting-stars{z-index:0; overflow:hidden;}
.premium-vignette{
  z-index:1;
  background:
    radial-gradient(800px 420px at 50% 0%, rgba(255,255,255,.04), transparent 72%),
    radial-gradient(1200px 700px at 50% 110%, rgba(0,0,0,.18), transparent 72%),
    linear-gradient(180deg, rgba(255,255,255,.025), transparent 18%, transparent 82%, rgba(255,255,255,.02));
  mix-blend-mode:screen;
  opacity:.55;
}
.starfield .star{
  position:absolute;
  display:block;
  border-radius:999px;
  background:radial-gradient(circle, rgba(255,255,255,.95) 0%, rgba(255,255,255,.75) 38%, rgba(50,214,255,.16) 72%, transparent 100%);
  box-shadow:0 0 8px rgba(255,255,255,.18), 0 0 22px rgba(50,214,255,.1);
  opacity:var(--star-opacity, .75);
  animation:starPulse var(--pulse-duration, 5.8s) ease-in-out infinite;
  animation-delay:var(--pulse-delay, 0s);
}
.starfield .star.depth-soft{filter:blur(.35px); opacity:calc(var(--star-opacity, .75) * .72)}
.starfield .star.depth-sharp{box-shadow:0 0 10px rgba(255,255,255,.24), 0 0 28px rgba(124,92,255,.14)}
.starfield .star::after{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  width:220%;
  height:1px;
  transform:translate(-50%,-50%) scaleX(var(--trail-scale, .2));
  transform-origin:left center;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.55), transparent);
  opacity:.35;
}
.shooting-stars .shooting-star{
  position:absolute;
  width:180px;
  height:2px;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,.95), rgba(50,214,255,.6), rgba(255,255,255,0));
  filter:drop-shadow(0 0 10px rgba(255,255,255,.25));
  opacity:0;
  transform:rotate(-18deg) translate3d(0,0,0);
  animation:shootingStar 10s linear infinite;
}
.shooting-stars .shooting-star::before{
  content:"";
  position:absolute;
  right:8px;
  top:50%;
  width:7px;
  height:7px;
  border-radius:50%;
  transform:translateY(-50%);
  background:radial-gradient(circle, #fff, rgba(255,255,255,.15) 70%, transparent 100%);
}
@keyframes starPulse{
  0%,100%{transform:translate3d(0,0,0) scale(.92); opacity:var(--star-opacity, .75)}
  50%{transform:translate3d(0,-2px,0) scale(1.18); opacity:min(1, calc(var(--star-opacity, .75) + .18))}
}
@keyframes shootingStar{
  0%, 78%{opacity:0; transform:rotate(-18deg) translate3d(0,0,0) scaleX(.45)}
  80%{opacity:.0}
  81%{opacity:.95}
  92%{opacity:.95; transform:rotate(-18deg) translate3d(200px, 110px, 0) scaleX(1)}
  100%{opacity:0; transform:rotate(-18deg) translate3d(420px, 250px, 0) scaleX(.65)}
}

.navbar::before{
  content:"";
  position:absolute;
  inset:auto 0 0;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(198,169,106,.42), rgba(50,214,255,.32), transparent);
  opacity:.65;
}
.nav-logo a{
  text-shadow:0 0 18px rgba(255,255,255,.08), 0 0 34px rgba(198,169,106,.12);
}
.nav-left a,.nav-right a{transition:color .25s var(--ease),opacity .25s var(--ease), text-shadow .25s var(--ease)}
.nav-left a:hover,.nav-right a:hover{color:#fff; text-shadow:0 0 18px rgba(255,255,255,.16)}

.hero::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:1;
  background:
    linear-gradient(120deg, transparent 20%, rgba(255,255,255,.06) 34%, transparent 45%),
    radial-gradient(560px 220px at 50% 6%, rgba(255,255,255,.055), transparent 72%);
  mix-blend-mode:screen;
  opacity:.6;
}
.hero-overlay::before,
.hero-side::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:32px;
  pointer-events:none;
  background:linear-gradient(180deg, rgba(255,255,255,.06), transparent 18%, transparent 84%, rgba(255,255,255,.03));
  opacity:.7;
}
.hero-title,
.section h2,
.hero-float-card strong{
  text-wrap:balance;
}
.hero-title span:first-child,
.hero-title span:last-child{
  background:linear-gradient(180deg, rgba(255,255,255,1), rgba(255,255,255,.76));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.hero-badge,
.hero-trust span,
.stat,
.glass-card,
.portfolio-item,
.service-card,
.review,
.info-card,
.lux-form,
.portfolio-modal-content,
.marquee{
  position:relative;
}
.hero-badge::after,
.hero-trust span::after,
.stat::after,
.glass-card::after,
.portfolio-item::after,
.service-card::after,
.review::after,
.info-card::after,
.lux-form::after,
.portfolio-modal-content::after,
.marquee::after{
  content:"";
  position:absolute;
  inset:1px;
  border-radius:inherit;
  pointer-events:none;
  border:1px solid rgba(255,255,255,.04);
  mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask-composite:exclude;
  -webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  padding:1px;
}
.hero-badge{
  box-shadow:0 10px 30px rgba(0,0,0,.16), inset 0 1px 0 rgba(255,255,255,.08);
}
.btn{
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08), 0 14px 36px rgba(0,0,0,.14);
}
.btn-ghost{
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
}
.btn:hover{
  border-color:rgba(255,255,255,.3);
}
.portfolio-item,
.service-card,
.review,
.info-card,
.lux-form,
.portfolio-modal-content,
.marquee,
.stat,
.glass-card{
  backdrop-filter:blur(14px);
}
.portfolio-item:hover,
.service-card:hover,
.review:hover,
.info-card:hover{
  box-shadow:0 28px 90px rgba(0,0,0,.26), 0 0 0 1px rgba(255,255,255,.03);
}
.section-shell{
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
.scroll-hint{
  padding:10px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 14px 36px rgba(0,0,0,.16);
}
.back-to-top:hover{transform:translateY(-4px) scale(1.02)}

@media (prefers-reduced-motion: reduce){
  .starfield,.shooting-stars,.premium-vignette{display:none}
}
@media (max-width:768px){
  .starfield .star::after{display:none}
  .shooting-stars .shooting-star{width:120px}
  .premium-vignette{opacity:.35}
}

.empty-state-card{
  grid-column:1 / -1;padding:42px;border-radius:var(--radius);background:rgba(255,255,255,.04);border:1px dashed rgba(255,255,255,.16);text-align:center
}
.contact-feedback{grid-column:1 / -1;padding:14px 16px;border-radius:16px;font-size:14px}
.contact-feedback.success{background:rgba(73,209,143,.12);border:1px solid rgba(73,209,143,.22);color:#dff7ea}
.contact-feedback.error{background:rgba(255,95,116,.12);border:1px solid rgba(255,95,116,.22);color:#ffd9df}
.modal-main-media{width:100%;height:100%;display:block;object-fit:contain;background:#05070d}
.modal-main video.modal-main-media{background:#000}
.modal-thumbs .thumb video,.modal-thumbs .thumb img{width:100%;height:100%;object-fit:cover;border-radius:14px;display:block}

.nav-tools{display:flex;align-items:center;gap:20px;margin-left:5px}
.lang-chip,.client-link{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border:1px solid rgba(255,255,255,.18);border-radius:999px;background:rgba(255,255,255,.04);color:#fff;text-decoration:none;font-size:13px;backdrop-filter:blur(12px)}
.lang-chip:hover,.client-link:hover{transform:translateY(-1px);background:rgba(255,255,255,.08)}
.ai-offer-grid .info-card.full{grid-column:1/-1}
.review-empty{max-width:860px;margin:0 auto}
.client-cta-section .section-head{max-width:900px;margin:0 auto;text-align:center}
@media (max-width: 980px){.nav-tools{display:none}}


/* SEO landing links */
.seo-links-wrap{max-width:1100px;margin:28px auto 0}
.seo-links-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-end;margin-bottom:16px;flex-wrap:wrap}
.seo-links-head p{max-width:700px;color:rgba(234,240,255,.68);font-size:14px}
.seo-links-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.seo-link-card{padding:22px 22px 20px;border-radius:20px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.1);box-shadow:0 14px 40px rgba(0,0,0,.16)}
.seo-link-card h3{font-family:'Playfair Display',serif;font-size:22px;margin-bottom:8px}
.seo-link-card p{color:rgba(234,240,255,.68);font-size:14px;min-height:62px}
.seo-link-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}
.seo-mini-btn{display:inline-flex;align-items:center;justify-content:center;padding:11px 16px;border-radius:999px;border:1px solid rgba(198,169,106,.35);background:rgba(255,255,255,.04);color:#fff;text-decoration:none;font-size:13px;font-weight:600;transition:transform .25s var(--ease),border-color .25s var(--ease),background .25s var(--ease)}
.seo-mini-btn:hover{transform:translateY(-2px);border-color:rgba(198,169,106,.7);background:rgba(255,255,255,.08)}
@media (max-width: 900px){.seo-links-grid{grid-template-columns:1fr}}


.footer-modern {
  position: relative;
  padding: 48px 32px 70px;
  overflow: hidden;
}

.footer-inner {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 40px;
  width: 100%;
}

.footer-brand {
  flex: 0 0 auto;
  max-width: 320px;
  text-align: left;
}

.footer-brand h3 {
  margin: 0 0 10px;
}

.footer-brand p {
  margin: 0;
}

.footer-middle {
  flex: 1 1 auto;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  padding-top: 6px;
}

.footer-seo-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 14px 22px;
  max-width: 720px;
}

.footer-seo-links a {
  text-decoration: none;
  white-space: nowrap;
}

.footer-social-grid {
  flex: 0 0 auto;
  display: grid;
  grid-template-columns: repeat(2, 52px);
  gap: 14px;
  justify-content: end;
}

.footer-social-grid a {
  width: 52px;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  text-decoration: none;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.footer-social-grid a:hover {
  transform: translateY(-2px);
}

.footer-social-grid img {
  width: 24px;
  height: 24px;
  object-fit: contain;
  display: block;
}

.footer-powered {
  position: absolute;
  left: 50%;
  bottom: 24px;
  transform: translateX(-50%);
  text-align: center;
  width: max-content;
}

.footer-powered a {
  text-decoration: none;
}

@media (max-width: 900px) {
  .footer-inner {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .footer-brand {
    max-width: 100%;
    text-align: center;
  }

  .footer-middle {
    justify-content: center;
    width: 100%;
  }

  .footer-seo-links {
    justify-content: center;
  }

  .footer-social-grid {
    justify-content: center;
  }

  .footer-powered {
    position: static;
    transform: none;
    margin-top: 26px;
    width: 100%;
  }

  .footer-modern {
    padding-bottom: 36px;
  }
}
