
:root{
  --black:#08080a;
  --ink:#111217;
  --dark:#15161b;
  --muted:#62636b;
  --soft:#f4f4f5;
  --white:#ffffff;
  --line:rgba(0,0,0,.08);
  --glass:rgba(255,255,255,.08);
  --silver:#d8d8dc;
  --max:1200px;
  --radius:28px;
  --shadow:0 24px 80px rgba(0,0,0,.16);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:Arial,Helvetica,sans-serif;
  background:#f5f5f6;
  color:var(--ink);
  line-height:1.65;
  overflow-x:hidden;
}
h1,h2,h3,h4,.brand-name{font-family:Georgia,"Times New Roman",serif;font-weight:500;line-height:1.1}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.container{width:min(92%,var(--max));margin:auto}
.topbar{
  position:fixed;top:0;left:0;width:100%;z-index:1000;
  background:rgba(8,8,10,.78);backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(255,255,255,.10);
}
.nav{min-height:84px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:13px;color:#fff}
.brand img{width:58px;height:58px;object-fit:contain}
.brand-name{font-size:1.2rem;letter-spacing:5px}
.brand-sub{font-size:.68rem;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.72)}
.menu{display:flex;align-items:center;gap:30px;color:#fff}
.menu a{font-size:.92rem;color:rgba(255,255,255,.82);transition:.3s}
.menu a:hover,.menu a.active{color:#fff}
.nav-cta,.btn{
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:999px;padding:14px 23px;font-weight:700;font-size:.92rem;
  transition:.35s ease;border:1px solid transparent;cursor:pointer;
}
.nav-cta{color:#fff;border-color:rgba(255,255,255,.22)}
.nav-cta:hover{background:#fff;color:#000}
.hamburger{display:none;background:none;border:0;color:#fff;font-size:1.8rem}
.hero{position:relative;min-height:100vh;background:#050507;color:#fff;overflow:hidden}
.slide{position:absolute;inset:0;opacity:0;visibility:hidden;transition:.9s ease}
.slide.active{opacity:1;visibility:visible}
.slide-bg{position:absolute;inset:0;background-size:cover;background-position:center;animation:heroZoom 9s ease-in-out infinite alternate}
@keyframes heroZoom{from{transform:scale(1.02)}to{transform:scale(1.10)}}
.slide::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(105deg,rgba(0,0,0,.82) 0%,rgba(0,0,0,.62) 44%,rgba(0,0,0,.20) 100%);
}
.hero-inner{
  position:relative;z-index:2;min-height:100vh;padding-top:125px;
  display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:54px;
}
.eyebrow{display:inline-block;text-transform:uppercase;letter-spacing:4px;font-size:.78rem;color:rgba(255,255,255,.72);margin-bottom:20px}
.hero h1{font-size:clamp(2.25rem,4.6vw,4.9rem);max-width:760px;letter-spacing:-1.1px;margin-bottom:20px}
.hero p{font-size:1.02rem;max-width:640px;color:rgba(255,255,255,.82);margin-bottom:30px}
.hero-actions{display:flex;gap:15px;flex-wrap:wrap}
.btn-light{background:#fff;color:#000;border-color:#fff}
.btn-light:hover{background:transparent;color:#fff}
.btn-dark{background:#0b0b0d;color:#fff;border-color:#0b0b0d}
.btn-dark:hover{background:#fff;color:#000}
.btn-outline{border-color:rgba(255,255,255,.26);color:#fff;background:rgba(255,255,255,.04)}
.btn-outline:hover{background:#fff;color:#000}
.hero-panel{
  justify-self:end;width:min(390px,100%);padding:30px;border-radius:32px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);
  box-shadow:0 30px 90px rgba(0,0,0,.35);backdrop-filter:blur(18px)
}
.hero-panel img{width:100%;border-radius:22px;margin-bottom:26px;background:#fff;padding:14px}
.hero-panel h3{font-size:1.45rem;margin-bottom:18px}
.hero-panel ul{list-style:none;display:grid;gap:14px;color:rgba(255,255,255,.80)}
.hero-panel li{border-bottom:1px solid rgba(255,255,255,.11);padding-bottom:14px}
.hero-panel li:last-child{border-bottom:0;padding-bottom:0}
.dots{position:absolute;z-index:5;bottom:34px;left:50%;transform:translateX(-50%);display:flex;gap:10px}
.dot{width:12px;height:12px;border-radius:50%;background:transparent;border:1px solid rgba(255,255,255,.62)}
.dot.active{background:#fff}
.page-hero{
  min-height:58vh;background:#08080a;color:#fff;display:flex;align-items:center;padding-top:120px;position:relative;overflow:hidden
}
.page-hero::before{
  content:"";position:absolute;inset:0;background:linear-gradient(110deg,rgba(0,0,0,.80),rgba(0,0,0,.25)),url('../assets/images/hero-02.jpg') center/cover no-repeat;transform:scale(1.05)
}
.page-hero .container{position:relative;z-index:1}
.page-hero h1{font-size:clamp(2.5rem,5vw,5rem);max-width:850px;margin-bottom:18px}
.page-hero p{color:rgba(255,255,255,.82);font-size:1.08rem;max-width:700px}
section{padding:100px 0}
.section-title{max-width:820px;margin-bottom:48px}
.section-title span{display:inline-block;text-transform:uppercase;letter-spacing:4px;font-size:.78rem;color:var(--muted);margin-bottom:14px}
.section-title h2{font-size:clamp(2.1rem,4vw,3.7rem);margin-bottom:16px;letter-spacing:-.7px}
.section-title p{color:#565963;font-size:1.02rem}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:stretch}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:38px;
  box-shadow:0 16px 45px rgba(0,0,0,.055)
}
.card.dark{background:linear-gradient(180deg,#15161b,#08080a);color:#fff;border:0;box-shadow:var(--shadow)}
.card h3{font-size:1.55rem;margin-bottom:18px}
.card p{color:#555862;margin-bottom:18px}
.card.dark p{color:rgba(255,255,255,.82)}
.visual-card{overflow:hidden;padding:0;background:#fff}
.visual-card img{height:100%;width:100%;object-fit:cover}
.service-card{position:relative;overflow:hidden;transition:.35s ease}
.service-card:hover{transform:translateY(-8px);box-shadow:0 30px 70px rgba(0,0,0,.12)}
.service-num{width:58px;height:58px;border-radius:18px;background:#0b0b0d;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;margin-bottom:22px}
.service-card p{font-size:.98rem}
.feature-list{list-style:none;display:grid;gap:14px}
.feature-list li{padding:15px 0;border-bottom:1px solid rgba(0,0,0,.08);color:#555862}
.dark .feature-list li{border-bottom-color:rgba(255,255,255,.12);color:rgba(255,255,255,.82)}
.cta-band{padding:0 0 100px}
.cta-box{
  background:linear-gradient(130deg,#08080a,#171820);color:#fff;border-radius:38px;
  padding:64px;display:flex;align-items:center;justify-content:space-between;gap:30px;box-shadow:var(--shadow)
}
.cta-box h2{font-size:clamp(2rem,4vw,3.2rem);margin-bottom:12px}
.cta-box p{color:rgba(255,255,255,.80);max-width:680px}
.contact-list{list-style:none;display:grid;gap:19px}
.contact-list strong{display:block;color:#111;margin-bottom:4px}
.contact-list span,.contact-list a{color:#555862}
.contact-form{display:grid;gap:16px}
.input-group{display:grid;grid-template-columns:1fr 1fr;gap:16px}
input,textarea,select{
  width:100%;border:1px solid rgba(0,0,0,.11);background:#fafafa;border-radius:18px;padding:16px 17px;
  font:inherit;outline:none;transition:.3s
}
textarea{min-height:150px;resize:vertical}
input:focus,textarea:focus,select:focus{border-color:#111;background:#fff}
.submit{border:0;background:#0b0b0d;color:#fff;border-radius:999px;padding:16px 24px;font-weight:800;cursor:pointer}
.notice{padding:15px 18px;border-radius:16px;margin-bottom:18px;font-weight:700}
.notice.success{background:#e9f8ee;color:#126b31}
.notice.error{background:#fdeeee;color:#912020}
.footer{background:#08080a;color:#fff;padding:48px 0 26px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px;padding-bottom:34px;border-bottom:1px solid rgba(255,255,255,.10)}
.footer p,.footer a{color:rgba(255,255,255,.72);font-size:.95rem}
.footer h4{font-family:Arial,Helvetica,sans-serif;margin-bottom:14px}
.footer-logo{width:210px;background:#fff;border-radius:18px;padding:10px;margin-bottom:14px}
.footer-bottom{padding-top:22px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap}

@media(max-width:1100px){
  .hero-inner{grid-template-columns:1.05fr .75fr;gap:34px}
  .hero h1{font-size:clamp(2.15rem,4.3vw,4.2rem)}
}

@media(max-width:760px){
  .hero{min-height:92vh}
  .slide{position:absolute}
  .hero-inner{min-height:92vh;padding-top:118px;display:flex;align-items:center}
  .hero h1{font-size:clamp(2rem,10vw,3.25rem);max-width:100%;letter-spacing:-.5px}
  .hero p{font-size:.98rem;max-width:100%}
  .eyebrow{font-size:.68rem;letter-spacing:3px}
  .btn{width:100%;padding:14px 20px}
  .hero-actions{width:100%}
}

@media(max-width:430px){
  .brand-name{font-size:1rem;letter-spacing:4px}
  .brand-sub{font-size:.58rem;letter-spacing:2px}
  .brand img{width:48px;height:48px}
  .nav{min-height:76px}
  .menu{top:76px}
  .hero-inner{padding-top:104px}
  .hero h1{font-size:2.15rem}
  .page-hero h1{font-size:2.15rem}
  .card{padding:28px 22px}
}

@media(max-width:980px){
  .hero-inner,.grid-2,.footer-grid{grid-template-columns:1fr}
  .hero-panel{justify-self:start}
  .grid-3{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  .hamburger{display:block}
  .menu{
    position:absolute;top:84px;left:0;width:100%;background:#08080a;display:none;
    flex-direction:column;align-items:flex-start;padding:24px;border-top:1px solid rgba(255,255,255,.10)
  }
  .menu.open{display:flex}
  .nav-cta{display:none}
  .grid-3,.input-group{grid-template-columns:1fr}
  .hero-inner{padding-top:118px}
  .hero-panel{display:none}
  section{padding:76px 0}
  .cta-box{padding:38px 26px;display:block}
  .cta-box .btn{margin-top:24px}
}


/* Final official logo integration */
.official-logo-card{
  background:#000;
  border-radius:26px;
  padding:18px;
  box-shadow:0 20px 70px rgba(0,0,0,.25);
}
.official-logo-card img{
  width:100%;
  max-width:360px;
  margin:auto;
}
.footer-logo.official{
  background:#000;
  padding:14px;
  width:240px;
  border-radius:20px;
}
@media(max-width:760px){
  .slide::after{
    background:linear-gradient(105deg,rgba(0,0,0,.86) 0%,rgba(0,0,0,.68) 58%,rgba(0,0,0,.38) 100%);
  }
}


/* Updated logo background styling */
.brand-logo-box{
  width:62px;
  height:62px;
  border-radius:18px;
  background:linear-gradient(180deg,#fafafb 0%, #e6e7eb 100%);
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 12px 28px rgba(0,0,0,.10);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  flex-shrink:0;
}
.brand-logo-box img{
  width:100%;
  height:100%;
  object-fit:contain;
}
.footer-logo-wrap{
  background:linear-gradient(180deg,#fafafb 0%, #e6e7eb 100%);
  border:1px solid rgba(0,0,0,.08);
  border-radius:22px;
  padding:14px;
  display:inline-flex;
  box-shadow:0 14px 36px rgba(0,0,0,.10);
}
.official-logo-card{
  background:linear-gradient(180deg,#fafafb 0%, #e6e7eb 100%);
  border:1px solid rgba(255,255,255,.06);
}
@media(max-width:430px){
  .brand-logo-box{
    width:52px;
    height:52px;
    border-radius:16px;
  }
}


.official-logo-card{
  color:#111217;
}
.footer-logo.official{
  background:transparent;
}


/* Final readable logo styling */
.brand-logo-box{
  width:62px;
  height:62px;
  border-radius:18px;
  background:linear-gradient(180deg,#fbfbfc 0%, #e8e9ed 100%);
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 12px 28px rgba(0,0,0,.10);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  flex-shrink:0;
}
.brand-logo-box img{
  width:100%;
  height:100%;
  object-fit:contain;
}
.footer-logo-wrap{
  background:linear-gradient(180deg,#fbfbfc 0%, #e8e9ed 100%);
  border:1px solid rgba(0,0,0,.08);
  border-radius:22px;
  padding:14px;
  display:inline-flex;
  box-shadow:0 14px 36px rgba(0,0,0,.10);
}
.footer-logo.official{
  background:transparent;
  padding:0;
  width:240px;
  border-radius:0;
}
.official-logo-card{
  background:linear-gradient(180deg,#fbfbfc 0%, #e8e9ed 100%);
  border:1px solid rgba(0,0,0,.08);
  color:#111217;
}
.official-logo-card img{
  width:100%;
  max-width:360px;
  margin:auto;
}
@media(max-width:430px){
  .brand-logo-box{
    width:52px;
    height:52px;
    border-radius:16px;
  }
}


/* Exact logo update: no extra background, keep logo as provided */
.brand-logo-box{
  width:62px !important;
  height:62px !important;
  border-radius:0 !important;
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
  padding:0 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  overflow:visible !important;
  flex-shrink:0 !important;
}
.brand-logo-box img{
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  display:block !important;
}
.footer-logo-wrap{
  background:transparent !important;
  border:none !important;
  border-radius:0 !important;
  padding:0 !important;
  display:inline-flex !important;
  box-shadow:none !important;
}
.footer-logo.official{
  background:transparent !important;
  padding:0 !important;
  width:240px !important;
  border-radius:0 !important;
}
.official-logo-card{
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
}
.official-logo-card img{
  width:100% !important;
  max-width:380px !important;
  margin:auto !important;
  display:block !important;
}
@media(max-width:430px){
  .brand-logo-box{
    width:50px !important;
    height:50px !important;
  }
  .footer-logo.official{
    width:190px !important;
  }
}


/* Final update: larger responsive logo */
.brand-logo-box{
  width:82px !important;
  height:82px !important;
}
.brand-logo-box img{
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
}
.brand{
  gap:16px !important;
}
.brand-name{
  font-size:1.28rem !important;
}
.brand-sub{
  font-size:.72rem !important;
}
.footer-logo.official{
  width:300px !important;
}
.official-logo-card img{
  max-width:460px !important;
}

/* Luxury service inquiry form */
.service-form-section{
  padding-top:0;
}
.service-form-wrap{
  position:relative;
  overflow:hidden;
  border-radius:38px;
  background:
    radial-gradient(circle at 18% 18%, rgba(255,255,255,.14), transparent 32%),
    linear-gradient(135deg, #08080a 0%, #14151a 58%, #22242a 100%);
  box-shadow:0 30px 90px rgba(0,0,0,.18);
  color:#fff;
  border:1px solid rgba(255,255,255,.10);
}
.service-form-wrap::before{
  content:"";
  position:absolute;
  inset:0;
  background:url('../assets/images/hero-03.jpg') center/cover no-repeat;
  opacity:.16;
  filter:grayscale(100%);
}
.service-form-wrap::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(0,0,0,.72), rgba(0,0,0,.48), rgba(0,0,0,.78));
}
.service-form-inner{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:38px;
  padding:58px;
  align-items:start;
}
.service-form-copy .eyebrow{
  color:rgba(255,255,255,.72);
}
.service-form-copy h2{
  font-size:clamp(2rem,4vw,3.45rem);
  margin-bottom:18px;
}
.service-form-copy p{
  color:rgba(255,255,255,.80);
  max-width:520px;
  margin-bottom:24px;
}
.service-form-points{
  list-style:none;
  display:grid;
  gap:14px;
  margin-top:28px;
}
.service-form-points li{
  color:rgba(255,255,255,.82);
  padding:15px 0;
  border-bottom:1px solid rgba(255,255,255,.12);
}
.service-form-points li strong{
  display:block;
  color:#fff;
  margin-bottom:3px;
}
.luxury-service-form{
  background:rgba(255,255,255,.09);
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 24px 70px rgba(0,0,0,.28);
  border-radius:30px;
  padding:30px;
  backdrop-filter:blur(18px);
}
.luxury-service-form .form-title{
  margin-bottom:22px;
}
.luxury-service-form .form-title h3{
  color:#fff;
  font-size:1.55rem;
  margin-bottom:7px;
}
.luxury-service-form .form-title p{
  color:rgba(255,255,255,.72);
  font-size:.95rem;
}
.luxury-service-form input,
.luxury-service-form textarea,
.luxury-service-form select{
  background:rgba(255,255,255,.94);
  border:1px solid rgba(255,255,255,.24);
  color:#111217;
  border-radius:18px;
}
.luxury-service-form input:focus,
.luxury-service-form textarea:focus,
.luxury-service-form select:focus{
  border-color:#fff;
  box-shadow:0 0 0 4px rgba(255,255,255,.13);
}
.luxury-service-form .submit{
  width:100%;
  background:#fff;
  color:#050507;
  margin-top:4px;
}
.luxury-service-form .submit:hover{
  transform:translateY(-2px);
  box-shadow:0 16px 36px rgba(255,255,255,.12);
}
.form-note{
  color:rgba(255,255,255,.68);
  font-size:.82rem;
  margin-top:14px;
  text-align:center;
}

@media(max-width:980px){
  .service-form-inner{
    grid-template-columns:1fr;
    padding:42px 30px;
  }
}
@media(max-width:760px){
  .brand-logo-box{
    width:68px !important;
    height:68px !important;
  }
  .brand-name{
    font-size:1.08rem !important;
    letter-spacing:4px !important;
  }
  .brand-sub{
    font-size:.62rem !important;
    letter-spacing:2.4px !important;
  }
  .footer-logo.official{
    width:240px !important;
  }
  .official-logo-card img{
    max-width:330px !important;
  }
  .service-form-inner{
    padding:34px 20px;
  }
  .luxury-service-form{
    padding:22px;
    border-radius:24px;
  }
}
@media(max-width:430px){
  .brand-logo-box{
    width:58px !important;
    height:58px !important;
  }
  .brand{
    gap:10px !important;
  }
  .brand-name{
    font-size:.96rem !important;
    letter-spacing:3px !important;
  }
  .brand-sub{
    font-size:.54rem !important;
    letter-spacing:1.8px !important;
  }
  .footer-logo.official{
    width:210px !important;
  }
}


/* Final header logo size fix */
.topbar .nav{
  min-height:96px !important;
}
.topbar .brand{
  gap:18px !important;
}
.topbar .brand-logo-box{
  width:96px !important;
  height:96px !important;
}
.topbar .brand-logo-box img{
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
}
.topbar .brand-name{
  font-size:1.34rem !important;
  letter-spacing:5px !important;
}
.topbar .brand-sub{
  font-size:.76rem !important;
  letter-spacing:3px !important;
}

@media(max-width:760px){
  .topbar .nav{
    min-height:84px !important;
  }
  .topbar .brand{
    gap:12px !important;
  }
  .topbar .brand-logo-box{
    width:74px !important;
    height:74px !important;
  }
  .topbar .brand-name{
    font-size:1.06rem !important;
    letter-spacing:4px !important;
  }
  .topbar .brand-sub{
    font-size:.60rem !important;
    letter-spacing:2.3px !important;
  }
  .menu{
    top:84px !important;
  }
}

@media(max-width:430px){
  .topbar .nav{
    min-height:78px !important;
  }
  .topbar .brand-logo-box{
    width:64px !important;
    height:64px !important;
  }
  .topbar .brand-name{
    font-size:.94rem !important;
    letter-spacing:3px !important;
  }
  .topbar .brand-sub{
    font-size:.52rem !important;
    letter-spacing:1.7px !important;
  }
  .menu{
    top:78px !important;
  }
}
