
:root{
  --bg:#070709;
  --bg2:#111116;
  --panel:rgba(255,255,255,.06);
  --panel2:rgba(255,255,255,.04);
  --line:rgba(255,255,255,.10);
  --text:#f6f1f4;
  --muted:#cdbcc4;
  --accent:#c44d76;
  --accent2:#8b2448;
  --shadow:0 18px 60px rgba(0,0,0,.45);
  --glow:0 0 30px rgba(196,77,118,.18);
  --radius:22px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:
    radial-gradient(circle at top, rgba(196,77,118,.16), transparent 30%),
    linear-gradient(180deg, #0b0b10 0%, #070709 100%);
  color:var(--text);
  font:16px/1.6 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:radial-gradient(circle at 20% 20%, rgba(255,255,255,.03), transparent 32%), radial-gradient(circle at 80% 10%, rgba(196,77,118,.06), transparent 28%);
  mix-blend-mode:screen;
  z-index:0;
}
main, footer, .site-header{position:relative; z-index:1}

.hero-cinematic{
  position:relative;
  overflow:hidden;
  min-height:calc(100vh - 78px);
  display:flex;
  align-items:center;
  isolation:isolate;
}
.hero-grid-cinematic{position:relative; z-index:3}
.hero-bg{
  position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(7,7,9,.88) 0%, rgba(7,7,9,.58) 42%, rgba(7,7,9,.72) 100%),
    url('assets/decor-silk-bg.jpeg') center/cover no-repeat;
  transform:scale(1.06);
  filter:saturate(.9) contrast(1.05);
}
.hero-bg::after{
  content:"";
  position:absolute; inset:0;
  background:radial-gradient(circle at 68% 40%, rgba(255,255,255,.08), transparent 18%), radial-gradient(circle at 28% 70%, rgba(196,77,118,.16), transparent 26%);
}
.hero-glow{
  position:absolute; border-radius:50%; filter:blur(55px); opacity:.45; pointer-events:none; z-index:1;
}
.hero-glow-1{width:420px; height:420px; right:8%; top:8%; background:rgba(196,77,118,.22)}
.hero-glow-2{width:300px; height:300px; left:8%; bottom:8%; background:rgba(255,255,255,.12)}
.hero-orb,.hero-smoke,.hero-stones{
  position:absolute; z-index:2; pointer-events:none; will-change:transform;
}
.hero-orb img,.hero-smoke img,.hero-stones img{display:block; width:100%; height:auto}
.hero-orb-main{width:min(34vw, 430px); right:8%; top:15%; opacity:.96; filter:drop-shadow(0 25px 40px rgba(0,0,0,.5));}
.hero-orb-accent{width:min(18vw, 220px); right:28%; bottom:15%; opacity:.7; filter:drop-shadow(0 18px 26px rgba(0,0,0,.4));}
.hero-smoke{width:min(28vw, 320px); left:45%; top:0; opacity:.34; mix-blend-mode:screen;}
.hero-stones{width:min(28vw, 340px); left:52%; bottom:4%; opacity:.75; filter:drop-shadow(0 18px 28px rgba(0,0,0,.45));}
.hero-copy,.hero-visual{position:relative; z-index:4}
.hero-copy{
  background:linear-gradient(180deg, rgba(11,11,16,.72), rgba(11,11,16,.42));
}
.hero-visual{backdrop-filter: blur(8px);}
.hero-visual img{box-shadow:0 22px 60px rgba(0,0,0,.35)}

.reveal{
  opacity:0;
  transform:translateY(34px) scale(.985);
  transition:transform .9s cubic-bezier(.2,.65,.2,1), opacity .9s ease;
}
.reveal-delay{transition-delay:.14s}
.reveal.show{opacity:1; transform:translateY(0) scale(1)}

.card,.btn,.gallery-grid a,.rate-row{transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease, background .35s ease}
.card:hover{transform:translateY(-4px); box-shadow:0 22px 68px rgba(0,0,0,.5), 0 0 30px rgba(196,77,118,.15)}
.btn:hover{transform:translateY(-2px)}
.gallery-grid a:hover{transform:translateY(-4px) scale(1.01)}
.gallery-grid a:hover img{transform:scale(1.04)}
.gallery-grid img{transition:transform .6s ease}
.rate-row:hover{transform:translateX(4px); border-color:rgba(255,255,255,.18)}

.hero-float{animation:floatOrb 7.8s ease-in-out infinite}
.hero-float-delayed{animation:floatOrb 9.4s ease-in-out infinite reverse}
.hero-float-soft{animation:floatSoft 8.6s ease-in-out infinite}
.hero-float-slow{animation:smokeDrift 14s ease-in-out infinite}

@keyframes floatOrb{
  0%,100%{transform:translate3d(0,0,0) rotate(0deg)}
  50%{transform:translate3d(0,-18px,0) rotate(4deg)}
}
@keyframes floatSoft{
  0%,100%{transform:translate3d(0,0,0)}
  50%{transform:translate3d(0,-12px,0)}
}
@keyframes smokeDrift{
  0%,100%{transform:translate3d(0,0,0) scale(1)}
  50%{transform:translate3d(14px,10px,0) scale(1.05)}
}

.container{width:min(var(--max), calc(100% - 32px)); margin:0 auto}

.site-header{
  position:sticky; top:0; z-index:1000;
  backdrop-filter: blur(18px);
  background:rgba(7,7,9,.78);
  border-bottom:1px solid var(--line);
}
.nav-wrap{
  min-height:78px; display:flex; align-items:center; justify-content:space-between; gap:20px; position:relative;
}
.brand{display:flex; align-items:center; gap:14px}
.brand img{width:220px; max-width:54vw; height:auto}
.menu-btn{
  display:none; align-items:center; justify-content:center;
  width:46px; height:46px; border-radius:14px; border:1px solid var(--line);
  background:var(--panel); color:var(--text); cursor:pointer; box-shadow:var(--glow);
}
.nav-links{display:flex; gap:10px; flex-wrap:wrap; align-items:center}
.nav-links a{padding:10px 14px; border-radius:12px; color:var(--muted)}
.nav-links a:hover,.nav-links a.active{color:var(--text); background:var(--panel)}

.hero{padding:72px 0 46px}
.hero-grid{display:grid; grid-template-columns:1.08fr .92fr; gap:26px; align-items:center}
.card{
  background:var(--panel);
  border:1px solid var(--line);
  backdrop-filter: blur(18px);
  border-radius:var(--radius);
  box-shadow:var(--shadow), var(--glow);
}
.hero-copy{padding:34px}
.eyebrow{
  display:inline-block; letter-spacing:.22em; text-transform:uppercase;
  color:#ddb0c2; font-size:.75rem; margin-bottom:12px;
}
h1,h2,h3{margin:0 0 12px; line-height:1.12}
h1{font-size:clamp(2rem,4vw,4rem)}
h2{font-size:clamp(1.5rem,2.4vw,2.35rem)}
h3{font-size:1.05rem}
p{margin:0 0 14px; color:var(--muted)}
.btn-row{display:flex; gap:14px; flex-wrap:wrap; margin-top:24px}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  min-height:48px; padding:0 18px; border-radius:14px;
  border:1px solid transparent;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#fff; font-weight:600; box-shadow:var(--glow);
}
.btn.secondary{background:transparent; border-color:var(--line); color:var(--text)}
.media-frame{padding:12px}
.media-frame img{
  width:100%; height:min(72vh, 620px); object-fit:cover; border-radius:18px;
}
.section{padding:26px 0}
.split{display:grid; grid-template-columns:.95fr 1.05fr; gap:26px; align-items:center}
.split.reverse{grid-template-columns:1.05fr .95fr}
.panel{padding:26px}
.list{display:grid; gap:14px}
.service-list{display:grid; grid-template-columns:1fr 1fr; gap:16px}
.service-item{padding:20px}
.rate-list{display:grid; gap:12px}
.rate-row{
  display:flex; justify-content:space-between; gap:16px; align-items:center;
  padding:14px 16px; border-radius:16px; background:var(--panel2); border:1px solid var(--line);
}
.gallery-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:14px}
.gallery-grid a{
  border-radius:18px; overflow:hidden; border:1px solid var(--line); background:var(--panel);
}
.gallery-grid img{width:100%; aspect-ratio:4/5; object-fit:cover}
.contact-grid{display:grid; grid-template-columns:.9fr 1.1fr; gap:22px}
.form-grid{display:grid; gap:14px}
input,select,textarea{
  width:100%; padding:14px 16px; border-radius:14px;
  border:1px solid var(--line); background:rgba(255,255,255,.04); color:var(--text);
}
textarea{min-height:140px; resize:vertical}
footer{border-top:1px solid var(--line); margin-top:32px; background:rgba(255,255,255,.02)}
.footer-wrap{
  padding:26px 0 40px; display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap;
}
.cert-wrap{padding:18px}
.cert-wrap img{width:100%; border-radius:18px}
.note{font-size:.95rem; color:#d8c0c9}
.lightbox{
  position:fixed; inset:0; background:rgba(0,0,0,.86); display:none;
  align-items:center; justify-content:center; padding:20px; z-index:1200;
}
.lightbox.open{display:flex}
.lightbox img{max-width:min(100%,1100px); max-height:88vh; border-radius:18px}
.lightbox-close{
  position:absolute; top:18px; right:18px; width:44px; height:44px; border-radius:50%;
  border:1px solid var(--line); background:var(--panel); color:#fff; cursor:pointer;
}

@media (max-width: 920px){
  .hero-cinematic{min-height:auto; padding:88px 0 42px}
  .hero-orb-main{width:250px; right:-24px; top:20px; opacity:.35}
  .hero-orb-accent{width:130px; right:24%; bottom:10px; opacity:.45}
  .hero-smoke{width:190px; left:auto; right:0; top:0; opacity:.22}
  .hero-stones{width:220px; left:auto; right:0; bottom:0; opacity:.24}
  .hero-bg{background-position:center top}

  .hero-grid,.split,.split.reverse,.contact-grid,.service-list{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .menu-btn{display:inline-flex}
  .nav-links{
    position:absolute; left:0; right:0; top:78px; display:none; flex-direction:column;
    padding:12px; background:rgba(9,9,12,.98); border:1px solid var(--line); border-radius:18px;
  }
  .nav-links.open{display:flex}
}
@media (max-width: 560px){
  .hero{padding-top:30px}
  .hero-orb-main{width:200px; right:-38px; top:36px}
  .hero-orb-accent{width:110px; right:22%; bottom:6px}
  .hero-copy,.hero-visual{backdrop-filter:blur(14px)}

  .container{width:min(var(--max), calc(100% - 20px))}
  .hero-copy,.panel{padding:20px}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .brand img{width:180px}
}
