:root{
  --bg:#fff8fd;
  --white:#ffffff;
  --ink:#263044;
  --text:#526071;
  --muted:#748094;
  --purple:#8e45bc;
  --purple-dark:#64328b;
  --pink:#ee4d9c;
  --blue:#0fa9d8;
  --cyan:#67d8ee;
  --yellow:#ffd44f;
  --line:rgba(142,69,188,.16);
  --shadow:0 22px 60px rgba(72,48,107,.14);
  --soft-shadow:0 14px 34px rgba(72,48,107,.10);
  --radius:30px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Arial, Helvetica, sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at top left, rgba(238,77,156,.20), transparent 32%),
    radial-gradient(circle at top right, rgba(15,169,216,.18), transparent 30%),
    linear-gradient(180deg,#fff,var(--bg) 45%,#fff);
  overflow-x:hidden;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background-image:
    linear-gradient(rgba(142,69,188,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(142,69,188,.045) 1px, transparent 1px);
  background-size:42px 42px;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.5),transparent 75%);
  z-index:-1;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
button,input,textarea{font:inherit}
.container{width:min(1180px,92%);margin-inline:auto}
.section{padding:88px 0}
.section-soft{position:relative}

.site-header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line);
}
.navbar{
  width:min(1220px,94%);
  min-height:82px;
  margin:auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}
.brand{display:flex;align-items:center;gap:13px;font-weight:900;color:var(--purple);letter-spacing:-.02em}
.brand img{
  width:78px;
  height:58px;
  object-fit:contain;
  background:#fff;
  border-radius:20px;
  box-shadow:0 10px 26px rgba(142,69,188,.18);
  border:1px solid rgba(255,255,255,.7);
}
.brand span{font-size:1.06rem}
.nav-links{display:flex;align-items:center;gap:8px}
.nav-links a{
  padding:11px 16px;
  border-radius:999px;
  color:#4b5568;
  font-weight:800;
  transition:transform .25s ease, background .25s ease, color .25s ease;
}
.nav-links a:hover{background:#f7e8ff;color:var(--purple);transform:translateY(-2px)}
.menu-toggle{
  display:none;
  width:46px;
  height:46px;
  border:0;
  border-radius:16px;
  background:#f7e8ff;
  cursor:pointer;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:5px;
}
.menu-toggle span{width:24px;height:3px;border-radius:99px;background:var(--purple)}

.hero{
  min-height:calc(100vh - 82px);
  display:flex;
  align-items:center;
  padding:90px 0;
  overflow:hidden;
}
.hero-bg{position:absolute;border-radius:999px;pointer-events:none;opacity:.62;filter:blur(.2px)}
.hero-bg-one{width:390px;height:390px;background:linear-gradient(135deg,rgba(255,212,79,.75),rgba(238,77,156,.58));left:-145px;top:10%}
.hero-bg-two{width:470px;height:470px;background:linear-gradient(135deg,rgba(15,169,216,.46),rgba(142,69,188,.32));right:-165px;bottom:3%}
.hero-grid{position:relative;display:grid;grid-template-columns:1.04fr .96fr;align-items:center;gap:54px}
.kicker{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin:0 0 14px;
  color:var(--pink);
  font-size:.78rem;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.09em;
}
.kicker::before{content:"";width:26px;height:3px;border-radius:99px;background:linear-gradient(90deg,var(--pink),var(--blue))}
h1,h2,h3,p{margin-top:0}
h1{
  margin-bottom:22px;
  max-width:770px;
  color:#28293f;
  font-size:clamp(2.5rem,6.2vw,5.5rem);
  line-height:.94;
  letter-spacing:-.065em;
}
h2{font-size:clamp(2rem,4.4vw,3.55rem);line-height:1.02;letter-spacing:-.045em;margin-bottom:14px;color:#2b2f42}
h3{font-size:1.24rem;margin-bottom:12px;color:#2f3449}
.hero-text{font-size:clamp(1.12rem,2vw,1.36rem);line-height:1.7;color:var(--text);font-weight:800;margin-bottom:0}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:54px;
  padding:0 25px;
  border-radius:999px;
  border:2px solid transparent;
  font-weight:900;
  box-shadow:var(--soft-shadow);
  transition:transform .25s ease, box-shadow .25s ease;
}
.btn:hover{transform:translateY(-3px);box-shadow:0 20px 42px rgba(72,48,107,.16)}
.btn-primary{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff}
.btn-secondary,.btn-small{background:#fff;color:var(--purple);border-color:#efdafa}
.btn-small{min-height:48px;padding-inline:20px}

.hero-card{position:relative;min-height:500px;display:grid;place-items:center}
.logo-frame{
  width:min(470px,100%);
  padding:26px;
  border-radius:44px;
  background:rgba(255,255,255,.76);
  box-shadow:var(--shadow);
  border:1px solid rgba(255,255,255,.82);
  transform:rotate(1deg);
}
.logo-frame img{width:100%;object-fit:contain;background:#fff;border-radius:30px}
.mini-tag{
  position:absolute;
  padding:13px 18px;
  border-radius:999px;
  background:#fff;
  box-shadow:0 16px 38px rgba(49,42,84,.14);
  border:1px solid rgba(142,69,188,.12);
  font-weight:900;
  white-space:nowrap;
}
.tag-purple{left:2%;top:34px;color:var(--purple)}
.tag-blue{right:0;top:38%;color:var(--blue)}
.tag-pink{left:12%;bottom:40px;color:var(--pink)}

.section-heading{max-width:780px;margin-bottom:40px}
.section-heading.center{text-align:center;margin-inline:auto}
.section-heading.center .kicker{justify-content:center}
.section-heading p:not(.kicker),.gallery-heading p{color:var(--text);line-height:1.72;font-size:1.06rem;margin-bottom:0}
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.info-card{
  position:relative;
  padding:30px;
  border-radius:var(--radius);
  background:rgba(255,255,255,.86);
  border:1px solid rgba(255,255,255,.85);
  box-shadow:var(--soft-shadow);
  overflow:hidden;
}
.info-card::after{content:"";position:absolute;right:-55px;bottom:-70px;width:170px;height:170px;background:radial-gradient(circle,rgba(15,169,216,.17),transparent 68%)}
.icon{width:58px;height:58px;border-radius:20px;background:linear-gradient(135deg,#fff1fa,#eafaff);display:grid;place-items:center;margin-bottom:18px;color:var(--purple);font-size:1.85rem}
.info-card p{color:var(--text);line-height:1.7;margin-bottom:0}

.gallery-section{background:linear-gradient(180deg,rgba(255,255,255,.36),rgba(255,255,255,.86))}
.gallery-heading{max-width:none;display:flex;align-items:end;justify-content:space-between;gap:24px}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;align-items:start}
.gallery-item{
  border:0;
  min-height:275px;
  padding:11px;
  border-radius:26px;
  background:#fff;
  box-shadow:0 18px 40px rgba(55,47,91,.11);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:transform .25s ease, box-shadow .25s ease;
}
.gallery-item:hover{transform:translateY(-5px);box-shadow:0 25px 58px rgba(55,47,91,.17)}
.gallery-item img{width:100%;height:100%;max-height:380px;object-fit:contain;border-radius:19px;background:#fff}

.location-card{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:28px;
  padding:44px;
  border-radius:36px;
  background:linear-gradient(135deg,#fff,#fff1fa 58%,#eafaff);
  box-shadow:var(--shadow);
  border:1px solid rgba(255,255,255,.9);
}
.location-card h2{margin-bottom:0}
.contact-section{padding-top:70px}
.contact-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:34px;align-items:start}
.contact-title{position:sticky;top:112px}
.contact-list{display:grid;gap:16px}
.contact-link{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:22px;
  border-radius:25px;
  background:#fff;
  border:1px solid var(--line);
  box-shadow:var(--soft-shadow);
  transition:transform .25s ease, border-color .25s ease;
}
.contact-link:hover{transform:translateY(-3px);border-color:rgba(238,77,156,.35)}
.contact-link span{font-weight:900;color:var(--pink)}
.contact-link strong{text-align:right;color:#334155;overflow-wrap:anywhere}
.contact-link.whatsapp{border-color:rgba(37,211,102,.25)}

.footer{background:#27243a;color:#fff;padding:36px 0}
.footer-inner{display:flex;align-items:center;justify-content:center;gap:16px;text-align:center;flex-wrap:wrap}
.footer img{width:76px;height:56px;object-fit:contain;border-radius:18px;background:#fff}
.footer p{font-weight:900;margin:0}
.floating-whatsapp{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:99;
  background:#25d366;
  color:#fff;
  font-weight:900;
  padding:15px 20px;
  border-radius:999px;
  box-shadow:0 16px 38px rgba(37,211,102,.35);
}
.lightbox{
  position:fixed;
  inset:0;
  z-index:300;
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:rgba(22,22,32,.88);
}
.lightbox.open{display:flex}
.lightbox img{max-width:min(1040px,94vw);max-height:86vh;object-fit:contain;border-radius:22px;background:#fff;box-shadow:0 20px 70px rgba(0,0,0,.35)}
.lightbox-close{position:absolute;top:18px;right:22px;width:48px;height:48px;border:0;border-radius:50%;background:#fff;color:#25283a;font-size:34px;line-height:1;cursor:pointer}

@media (max-width:980px){
  .menu-toggle{display:flex}
  .nav-links{
    position:absolute;
    top:82px;
    left:3%;
    right:3%;
    display:none;
    flex-direction:column;
    padding:16px;
    background:#fff;
    border:1px solid var(--line);
    border-radius:24px;
    box-shadow:var(--shadow);
  }
  .nav-links.open{display:flex}
  .nav-links a{width:100%;text-align:center}
  .hero{padding:68px 0;min-height:auto}
  .hero-grid,.contact-grid{grid-template-columns:1fr}
  .hero-card{min-height:380px;order:-1}
  .info-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .location-card{align-items:flex-start;flex-direction:column}
  .contact-title{position:static}
}

@media (max-width:580px){
  .container{width:min(94%,460px)}
  .section{padding:66px 0}
  .navbar{min-height:76px}
  .brand img{width:64px;height:48px;border-radius:16px}
  .brand span{max-width:170px;line-height:1.1;font-size:.98rem}
  .nav-links{top:76px}
  h1{font-size:2.48rem}
  h2{font-size:2.08rem}
  .hero-actions .btn,.gallery-heading .btn,.location-card .btn{width:100%}
  .hero-card{display:block;min-height:auto;text-align:center}
  .logo-frame{padding:15px;border-radius:30px;margin-inline:auto}
  .mini-tag{position:static;display:inline-flex;margin:8px 4px 0}
  .gallery-heading{display:block}
  .gallery-heading .btn{margin-top:22px}
  .gallery-grid{grid-template-columns:1fr;gap:16px}
  .gallery-item{min-height:235px;padding:9px}
  .location-card{padding:30px}
  .contact-link{align-items:flex-start;flex-direction:column}
  .contact-link strong{text-align:left}
  .floating-whatsapp{left:16px;right:16px;text-align:center}
}
