/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --gold:#c9a961;
  --gold-light:#e0c789;
  --gold-dark:#a8893f;
  --dark:#0a0a0a;
  --dark-2:#161616;
  --dark-3:#1f1f1f;
  --light:#f5f1ea;
  --beige:#e8dfd1;
  --text:#e8e8e8;
  --text-dim:#a8a8a8;
  --border:rgba(201,169,97,0.2);
  --glass:rgba(255,255,255,0.05);
  --glass-border:rgba(255,255,255,0.1);
  --shadow:0 25px 60px rgba(0,0,0,0.5);
}
html{scroll-behavior:smooth}
body{
  font-family:'Inter','Helvetica Neue',sans-serif;
  background:var(--dark);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  position:relative;
}
/* Grain texture */
body::before{
  content:"";
  position:fixed;
  top:0;left:0;right:0;bottom:0;
  pointer-events:none;
  z-index:1000;
  opacity:0.05;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' /%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

h1,h2,h3,h4{font-family:'Playfair Display','Cormorant Garamond',serif;font-weight:400;letter-spacing:0.02em;line-height:1.2;color:var(--light)}
a{color:inherit;text-decoration:none;transition:all 0.3s ease}
img{max-width:100%;display:block}
.container{max-width:1300px;margin:0 auto;padding:0 5%}

/* ===== NAVBAR TRANSPARENT ===== */
.navbar{
  position:fixed;
  top:0;left:0;right:0;
  z-index:100;
  padding:25px 5%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  background:transparent;
  transition:all 0.4s cubic-bezier(.4,0,.2,1);
}
.navbar.scrolled{
  background:rgba(10,10,10,0.85);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  padding:15px 5%;
  border-bottom:1px solid var(--border);
}
.logo{
  font-family:'Playfair Display',serif;
  font-size:24px;
  font-weight:500;
  letter-spacing:0.15em;
  text-transform:uppercase;
  color:var(--gold);
}
.logo span{color:var(--light);font-weight:300}
.nav-links{display:flex;gap:40px;list-style:none}
.nav-links a{
  font-size:13px;
  letter-spacing:0.15em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--text);
  position:relative;
  padding:5px 0;
}
.nav-links a::after{
  content:"";
  position:absolute;
  bottom:0;left:0;
  width:0;height:1px;
  background:var(--gold);
  transition:width 0.3s ease;
}
.nav-links a:hover,.nav-links a.active{color:var(--gold)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}

.hamburger{display:none;flex-direction:column;justify-content:space-between;width:28px;height:20px;cursor:pointer;z-index:101}
.hamburger span{display:block;height:2px;width:100%;background:var(--gold);transition:all 0.3s ease}
.hamburger.open span:nth-child(1){transform:translateY(9px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}

/* ===== HERO ===== */
.hero{
  min-height:100vh;
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  text-align:center;
}
.hero-bg{
  position:absolute;
  inset:0;
  background:url("https://images.unsplash.com/photo-1564501049412-61c2a3083791?w=1920&q=80") center/cover;
  filter:brightness(0.4);
  transform:scale(1.1);
  animation:slowZoom 20s ease-out infinite alternate;
}
@keyframes slowZoom{from{transform:scale(1)}to{transform:scale(1.15)}}
.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(10,10,10,0.4) 0%,rgba(10,10,10,0.6) 50%,rgba(10,10,10,0.95) 100%);
  z-index:1;
}
.hero-content{
  position:relative;
  z-index:2;
  max-width:900px;
  padding:0 5%;
  animation:fadeUp 1.5s ease;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
.hero-tag{
  display:inline-block;
  font-size:11px;
  letter-spacing:0.4em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:30px;
  padding-bottom:10px;
  border-bottom:1px solid var(--gold);
}
.hero h1{
  font-size:clamp(2.5rem,6vw,5rem);
  font-weight:300;
  margin-bottom:30px;
  line-height:1.1;
}
.hero h1 em{font-style:italic;color:var(--gold);font-weight:400}
.hero p{
  font-size:clamp(1rem,1.5vw,1.2rem);
  color:var(--text-dim);
  max-width:600px;
  margin:0 auto 50px;
  font-weight:300;
  letter-spacing:0.03em;
}
.hero-cta{display:flex;gap:20px;justify-content:center;flex-wrap:wrap}

.btn{
  display:inline-block;
  padding:18px 45px;
  font-size:12px;
  letter-spacing:0.25em;
  text-transform:uppercase;
  font-weight:600;
  cursor:pointer;
  border:none;
  transition:all 0.4s cubic-bezier(.4,0,.2,1);
  position:relative;
  overflow:hidden;
}
.btn-gold{
  background:var(--gold);
  color:var(--dark);
}
.btn-gold:hover{background:var(--gold-light);transform:translateY(-2px);box-shadow:0 10px 30px rgba(201,169,97,0.3)}
.btn-outline{
  background:transparent;
  color:var(--light);
  border:1px solid var(--gold);
}
.btn-outline:hover{background:var(--gold);color:var(--dark);transform:translateY(-2px)}

/* Scroll indicator */
.scroll-ind{
  position:absolute;
  bottom:40px;
  left:50%;
  transform:translateX(-50%);
  z-index:3;
  color:var(--gold);
  font-size:10px;
  letter-spacing:0.3em;
  text-transform:uppercase;
  animation:bounce 2s infinite;
}
.scroll-ind::after{content:"";display:block;width:1px;height:40px;background:var(--gold);margin:10px auto 0}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-10px)}}

/* ===== SECTIONS ===== */
section{padding:120px 0;position:relative}
.section-tag{
  display:block;
  text-align:center;
  font-size:11px;
  letter-spacing:0.4em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:20px;
}
.section-title{
  text-align:center;
  font-size:clamp(2rem,4vw,3.5rem);
  font-weight:300;
  margin-bottom:20px;
}
.section-title em{font-style:italic;color:var(--gold)}
.section-sub{
  text-align:center;
  max-width:600px;
  margin:0 auto 80px;
  color:var(--text-dim);
  font-size:15px;
  line-height:1.8;
}

/* ===== REVEAL ANIMATIONS ===== */
.reveal{opacity:0;transform:translateY(40px);transition:all 1s cubic-bezier(.4,0,.2,1);animation:revealFallback 0.8s ease 0.3s forwards}
.reveal.visible{opacity:1;transform:translateY(0)}
@keyframes revealFallback{to{opacity:1;transform:translateY(0)}}

/* ===== ABOUT / INTRO ===== */
.intro{background:var(--dark-2);position:relative}
.intro-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
}
.intro-img{
  position:relative;
  height:600px;
  overflow:hidden;
}
.intro-img img{width:100%;height:100%;object-fit:cover;transition:transform 1s ease}
.intro-img:hover img{transform:scale(1.05)}
.intro-img::before{
  content:"";
  position:absolute;
  top:-20px;left:-20px;right:20px;bottom:20px;
  border:1px solid var(--gold);
  z-index:-1;
}
.intro-text h2{font-size:clamp(2rem,3.5vw,3rem);margin-bottom:30px}
.intro-text p{color:var(--text-dim);margin-bottom:20px;line-height:1.9}
.intro-signature{
  margin-top:40px;
  font-family:'Playfair Display',serif;
  font-style:italic;
  color:var(--gold);
  font-size:18px;
}

/* ===== SERVICES — GLASS CARDS HOVER 3D ===== */
.services{
  background:linear-gradient(180deg,var(--dark) 0%,var(--dark-2) 100%);
  position:relative;
}
.services-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:30px;
  perspective:1500px;
}
.service-card{
  background:var(--glass);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);
  padding:50px 35px;
  position:relative;
  overflow:hidden;
  transition:all 0.5s cubic-bezier(.4,0,.2,1);
  transform-style:preserve-3d;
  cursor:pointer;
}
.service-card::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  transform:scaleX(0);
  transition:transform 0.5s ease;
}
.service-card:hover{
  transform:translateY(-15px) rotateX(5deg) rotateY(-3deg);
  background:rgba(201,169,97,0.05);
  border-color:var(--gold);
  box-shadow:0 30px 60px rgba(0,0,0,0.5),0 0 40px rgba(201,169,97,0.1);
}
.service-card:hover::before{transform:scaleX(1)}
.service-icon{
  width:60px;height:60px;
  margin-bottom:30px;
  color:var(--gold);
  display:flex;
  align-items:center;
  justify-content:center;
}
.service-icon svg{width:48px;height:48px}
.service-card h3{
  font-size:22px;
  margin-bottom:18px;
  letter-spacing:0.05em;
}
.service-card p{color:var(--text-dim);font-size:14px;line-height:1.8;margin-bottom:25px}
.service-link{
  font-size:11px;
  letter-spacing:0.3em;
  text-transform:uppercase;
  color:var(--gold);
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.service-link svg{width:16px;height:16px;transition:transform 0.3s ease}
.service-card:hover .service-link svg{transform:translateX(8px)}

/* ===== EXPERIENCE / EXPERTISE ===== */
.expertise{
  position:relative;
  background:var(--dark);
  overflow:hidden;
}
.expertise-bg{
  position:absolute;
  inset:0;
  background:url("https://images.unsplash.com/photo-1542315192-1f61a1792f33?w=1920&q=80") center/cover;
  opacity:0.15;
  filter:blur(2px);
}
.expertise-content{position:relative;z-index:2;text-align:center;max-width:800px;margin:0 auto}
.expertise-content h2{font-size:clamp(2rem,4vw,3.5rem);margin-bottom:40px}
.expertise-content p{color:var(--text-dim);font-size:17px;line-height:1.9;margin-bottom:30px}
.stats{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:30px;
  margin-top:80px;
}
.stat{text-align:center}
.stat-num{
  font-family:'Playfair Display',serif;
  font-size:48px;
  color:var(--gold);
  font-weight:300;
  margin-bottom:10px;
}
.stat-label{font-size:11px;letter-spacing:0.3em;text-transform:uppercase;color:var(--text-dim)}

/* ===== CTA SECTION ===== */
.cta{
  background:url("https://images.unsplash.com/photo-1571896349842-33c89424de2d?w=1920&q=80") center/cover fixed;
  position:relative;
  text-align:center;
  padding:140px 0;
}
.cta::before{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(10,10,10,0.85);
}
.cta-content{position:relative;z-index:2;max-width:700px;margin:0 auto}
.cta h2{font-size:clamp(2rem,4vw,3.5rem);margin-bottom:25px}
.cta p{color:var(--text-dim);margin-bottom:40px;font-size:16px}

/* ===== FOOTER ===== */
footer{
  background:#050505;
  padding:80px 0 30px;
  border-top:1px solid var(--border);
}
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:60px;
  margin-bottom:60px;
}
.footer-brand .logo{margin-bottom:20px;display:inline-block}
.footer-brand p{color:var(--text-dim);font-size:14px;line-height:1.8}
.footer-col h4{
  font-family:'Inter',sans-serif;
  font-size:11px;
  letter-spacing:0.3em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:25px;
}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:12px}
.footer-col a{font-size:14px;color:var(--text-dim)}
.footer-col a:hover{color:var(--gold)}
.footer-col p{font-size:14px;color:var(--text-dim);margin-bottom:10px;line-height:1.8}
.footer-bottom{
  border-top:1px solid var(--border);
  padding-top:30px;
  text-align:center;
  font-size:12px;
  color:var(--text-dim);
  letter-spacing:0.05em;
}
.footer-bottom a{color:var(--gold)}

/* ===== GALERIE ===== */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.gallery-item{
  position:relative;
  overflow:hidden;
  aspect-ratio:1;
  cursor:pointer;
  border:1px solid var(--glass-border);
}
.gallery-item img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform 0.8s ease, filter 0.5s ease;
  filter:brightness(0.85);
}
.gallery-item:hover img{transform:scale(1.1);filter:brightness(1)}
.gallery-item::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(10,10,10,0.9));
  opacity:0;
  transition:opacity 0.4s ease;
}
.gallery-item:hover::after{opacity:1}
.gallery-item .caption{
  position:absolute;
  bottom:30px;
  left:30px;
  color:var(--gold);
  font-family:'Playfair Display',serif;
  font-size:18px;
  letter-spacing:0.05em;
  z-index:2;
  opacity:0;
  transform:translateY(20px);
  transition:all 0.4s ease;
}
.gallery-item:hover .caption{opacity:1;transform:translateY(0)}

/* Lightbox */
.lightbox{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.95);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:9999;
  opacity:0;
  transition:opacity 0.3s ease;
  cursor:zoom-out;
}
.lightbox.active{opacity:1}
.lightbox img{max-width:90%;max-height:90%;object-fit:contain}
.lightbox-close{
  position:absolute;
  top:30px;right:30px;
  color:#fff;font-size:36px;
  cursor:pointer;
  background:none;border:none;
  font-family:serif;
}

/* ===== CONTACT PAGE ===== */
.contact-section{padding:160px 0 120px}
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:80px;
  align-items:start;
}
.contact-info-card{
  background:var(--glass);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);
  padding:50px;
}
.contact-info-card h3{font-size:28px;margin-bottom:30px;color:var(--gold)}
.contact-info-item{
  display:flex;
  align-items:flex-start;
  gap:20px;
  margin-bottom:30px;
  padding-bottom:30px;
  border-bottom:1px solid var(--border);
}
.contact-info-item:last-of-type{border-bottom:none}
.contact-info-item svg{width:24px;height:24px;color:var(--gold);flex-shrink:0;margin-top:4px}
.contact-info-item .label{
  font-size:11px;
  letter-spacing:0.25em;
  text-transform:uppercase;
  color:var(--text-dim);
  margin-bottom:6px;
}
.contact-info-item .value{font-size:15px;color:var(--text);line-height:1.6}

/* Form */
.contact-form{
  background:var(--glass);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);
  padding:50px;
}
.contact-form h3{font-size:28px;margin-bottom:30px;color:var(--gold)}
.form-group{margin-bottom:25px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form-group label{
  display:block;
  font-size:11px;
  letter-spacing:0.25em;
  text-transform:uppercase;
  color:var(--text-dim);
  margin-bottom:10px;
}
.form-group input,.form-group textarea,.form-group select{
  width:100%;
  padding:15px 0;
  background:transparent;
  border:none;
  border-bottom:1px solid var(--glass-border);
  color:var(--light);
  font-size:15px;
  font-family:inherit;
  transition:border-color 0.3s ease;
  outline:none;
}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-bottom-color:var(--gold)}
.form-group textarea{resize:vertical;min-height:120px}
.form-msg{
  padding:15px;
  margin-bottom:20px;
  border-radius:4px;
  font-size:14px;
  display:none;
}
.form-msg.success{background:rgba(76,175,80,0.1);border:1px solid #4caf50;color:#a5d6a7;display:block}
.form-msg.error{background:rgba(244,67,54,0.1);border:1px solid #f44336;color:#ef9a9a;display:block}

.map-container{
  margin-top:60px;
  height:400px;
  border:1px solid var(--glass-border);
  overflow:hidden;
}
.map-container iframe{width:100%;height:100%;border:0;filter:grayscale(0.3) contrast(0.95)}

/* ===== ADMIN ===== */
.admin-body{
  background:var(--dark);
  min-height:100vh;
  font-family:'Inter',sans-serif;
}
.admin-login-wrap{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:40px 20px;
}
.admin-login-card{
  background:var(--glass);
  backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);
  padding:60px 50px;
  max-width:440px;
  width:100%;
}
.admin-login-card h1{
  font-size:32px;
  text-align:center;
  margin-bottom:10px;
  color:var(--gold);
}
.admin-login-card p{
  text-align:center;
  color:var(--text-dim);
  font-size:13px;
  margin-bottom:40px;
}
.admin-panel{padding:40px 5%;max-width:1300px;margin:0 auto}
.admin-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding-bottom:30px;
  margin-bottom:40px;
  border-bottom:1px solid var(--border);
  flex-wrap:wrap;
  gap:20px;
}
.admin-header h1{font-size:28px;color:var(--gold)}
.admin-actions{display:flex;gap:15px;flex-wrap:wrap}
.admin-actions .btn{padding:12px 25px;font-size:11px}
.messages-list{display:grid;gap:20px}
.message-card{
  background:var(--glass);
  backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);
  padding:30px;
  transition:all 0.3s ease;
}
.message-card.unread{border-left:3px solid var(--gold)}
.message-card:hover{border-color:var(--gold)}
.message-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  flex-wrap:wrap;
  gap:15px;
  margin-bottom:20px;
  padding-bottom:20px;
  border-bottom:1px solid var(--border);
}
.message-info h3{font-size:18px;color:var(--light);margin-bottom:8px}
.message-info .meta{font-size:13px;color:var(--text-dim)}
.message-info .meta a{color:var(--gold)}
.message-date{font-size:12px;color:var(--text-dim);letter-spacing:0.1em}
.message-body{color:var(--text);line-height:1.8;font-size:14px;white-space:pre-wrap}
.message-actions{display:flex;gap:10px;margin-top:20px}
.btn-small{padding:8px 16px;font-size:10px;letter-spacing:0.2em;text-transform:uppercase;cursor:pointer;border:1px solid var(--border);background:transparent;color:var(--text);transition:all 0.3s ease}
.btn-small:hover{border-color:var(--gold);color:var(--gold)}
.btn-small.danger:hover{border-color:#f44336;color:#f44336}
.empty{text-align:center;padding:60px;color:var(--text-dim);font-style:italic}
.admin-tabs{display:flex;gap:30px;margin-bottom:30px;border-bottom:1px solid var(--border);overflow-x:auto;white-space:nowrap}
.admin-tabs::-webkit-scrollbar{display:none}
.admin-tab-btn{
  background:none;border:none;color:var(--text-dim);
  padding:15px 0;
  font-size:13px;letter-spacing:0.2em;text-transform:uppercase;
  cursor:pointer;
  border-bottom:2px solid transparent;
  flex-shrink:0;
  font-family:inherit;
}
.admin-tab-btn.active,.admin-tab-btn:hover{color:var(--gold);border-bottom-color:var(--gold)}
.admin-tab{display:none}
.admin-tab.active{display:block}
.domain-card{
  background:var(--glass);
  backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);
  padding:50px;
  text-align:center;
  max-width:600px;
  margin:0 auto;
}
.domain-card h2{color:var(--gold);margin-bottom:20px}
.domain-card p{color:var(--text-dim);margin-bottom:30px;line-height:1.8}
.domain-card .form-group{text-align:left;margin-bottom:30px}

/* ===== LEGAL PAGE ===== */
.legal-page{padding:160px 0 100px;max-width:900px;margin:0 auto}
.legal-page h1{font-size:42px;margin-bottom:50px;color:var(--gold)}
.legal-page h2{font-size:24px;margin:40px 0 20px;color:var(--gold)}
.legal-page p{margin-bottom:15px;color:var(--text-dim);line-height:1.9}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .nav-links{display:none;position:fixed;top:0;right:0;width:70%;height:100vh;background:rgba(10,10,10,0.98);backdrop-filter:blur(20px);flex-direction:column;justify-content:center;align-items:center;gap:30px;z-index:99;transition:transform 0.4s ease;transform:translateX(100%)}
  .nav-links.open{display:flex;transform:translateX(0)}
  .nav-links a{font-size:16px}
  .hamburger{display:flex}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .intro-grid{grid-template-columns:1fr;gap:60px}
  .intro-img{height:400px}
  .contact-grid{grid-template-columns:1fr;gap:40px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .stats{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  section{padding:80px 0}
  .services-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:40px}
  .stats{grid-template-columns:1fr 1fr;gap:20px}
  .form-row{grid-template-columns:1fr}
  .hero{min-height:90vh}
  .contact-info-card,.contact-form{padding:30px 25px}
  .admin-login-card{padding:40px 30px}
  .btn{padding:15px 30px;font-size:11px}
  .navbar{padding:20px 5%}
  .logo{font-size:18px}
}
