/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --gold:#d4af37;
  --gold-light:#e6c659;
  --gold-dark:#b8941f;
  --black:#0a0a0a;
  --dark:#141414;
  --dark-2:#1a1a1a;
  --gray:#888;
  --light:#f8f8f5;
  --white:#fff;
  --border:rgba(212,175,55,0.2);
}
html{scroll-behavior:smooth}
body{
  font-family:'Georgia',serif;
  color:var(--black);
  background:var(--light);
  line-height:1.7;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:'Georgia',serif;font-weight:400;letter-spacing:0.5px}
a{color:inherit;text-decoration:none;transition:all 0.3s ease}
img{max-width:100%;display:block;height:auto}
.container{max-width:1280px;margin:0 auto;padding:0 5%}
.gold{color:var(--gold)}

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

@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(0.95)}to{opacity:1;transform:scale(1)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}

/* ===== NAVBAR ===== */
.navbar{
  position:fixed;top:0;left:0;right:0;
  z-index:1000;
  padding:20px 0;
  background:transparent;
  transition:all 0.4s ease;
}
.navbar.scrolled{
  background:rgba(10,10,10,0.95);
  backdrop-filter:blur(10px);
  padding:14px 0;
  box-shadow:0 4px 20px rgba(0,0,0,0.3);
}
.nav-container{
  display:flex;align-items:center;justify-content:space-between;
  max-width:1280px;margin:0 auto;padding:0 5%;
}
.logo{
  display:flex;align-items:center;gap:10px;
  color:var(--white);
}
.logo-icon{display:inline-flex}
.logo-text{
  font-size:22px;letter-spacing:4px;font-weight:300;
  font-family:'Georgia',serif;
}
.nav-menu{
  display:flex;list-style:none;gap:36px;align-items:center;
}
.nav-menu a{
  color:var(--white);
  font-size:13px;letter-spacing:2px;text-transform:uppercase;
  position:relative;padding:6px 0;
  font-family:'Helvetica Neue',sans-serif;font-weight:400;
}
.nav-menu a::after{
  content:'';position:absolute;bottom:0;left:50%;
  width:0;height:1px;background:var(--gold);
  transition:all 0.3s ease;transform:translateX(-50%);
}
.nav-menu a:hover::after,.nav-menu a.active::after{width:100%}
.nav-menu a:hover{color:var(--gold)}
.nav-menu a.active{color:var(--gold)}

.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
.hamburger span{width:26px;height:2px;background:var(--white);transition:0.3s}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== HERO ===== */
.hero{
  position:relative;
  height:100vh;min-height:680px;
  display:flex;align-items:center;justify-content:center;
  color:var(--white);text-align:center;
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;
  background-image:url('https://images.unsplash.com/photo-1513104890138-7c749659a591?w=1920');
  background-size:cover;background-position:center;
  animation:slowZoom 20s ease-out infinite alternate;
}
@keyframes slowZoom{from{transform:scale(1)}to{transform:scale(1.1)}}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,10,10,0.5) 0%,rgba(10,10,10,0.75) 100%);
}
.hero-content{
  position:relative;z-index:2;
  max-width:900px;padding:0 5%;
}
.hero-tag{
  display:inline-block;
  color:var(--gold);
  letter-spacing:6px;font-size:13px;
  font-family:'Helvetica Neue',sans-serif;font-weight:400;
  margin-bottom:24px;text-transform:uppercase;
}
.hero h1{
  font-size:clamp(42px,7vw,82px);
  line-height:1.05;margin-bottom:30px;
  font-weight:300;letter-spacing:1px;
}
.hero p{
  font-size:clamp(15px,1.4vw,18px);
  max-width:560px;margin:0 auto 44px;
  font-family:'Helvetica Neue',sans-serif;
  font-weight:300;line-height:1.7;
  color:rgba(255,255,255,0.85);
}
.hero-buttons{display:flex;gap:18px;justify-content:center;flex-wrap:wrap}

/* ===== BUTTONS ===== */
.btn{
  display:inline-block;
  padding:16px 38px;
  font-size:12px;letter-spacing:3px;text-transform:uppercase;
  font-family:'Helvetica Neue',sans-serif;font-weight:500;
  cursor:pointer;border:1px solid transparent;
  transition:all 0.4s ease;
  position:relative;overflow:hidden;
}
.btn-gold{
  background:var(--gold);color:var(--black);
  border-color:var(--gold);
}
.btn-gold:hover{
  background:transparent;color:var(--gold);
  transform:translateY(-2px);
  box-shadow:0 10px 30px rgba(212,175,55,0.3);
}
.btn-outline{
  background:transparent;color:var(--white);
  border-color:var(--white);
}
.btn-outline:hover{
  background:var(--white);color:var(--black);
  transform:translateY(-2px);
}
.btn-dark{
  background:var(--black);color:var(--white);
  border-color:var(--black);
}
.btn-dark:hover{
  background:var(--gold);color:var(--black);
  border-color:var(--gold);
}

/* ===== SCROLL INDICATOR ===== */
.scroll-indicator{
  position:absolute;bottom:40px;left:50%;
  transform:translateX(-50%);z-index:2;
  width:24px;height:40px;
  border:1px solid rgba(255,255,255,0.5);
  border-radius:20px;
}
.scroll-indicator span{
  display:block;width:3px;height:8px;
  background:var(--gold);border-radius:2px;
  margin:8px auto;
  animation:scrollDot 1.8s ease infinite;
}
@keyframes scrollDot{0%{transform:translateY(0);opacity:1}100%{transform:translateY(15px);opacity:0}}

/* ===== SECTIONS ===== */
.section{padding:120px 0;background:var(--light)}
.section-dark{background:var(--dark);color:var(--white)}
.section-dark .section-tag{color:var(--gold)}
.section-tag{
  display:block;
  color:var(--gold);
  letter-spacing:5px;font-size:12px;
  font-family:'Helvetica Neue',sans-serif;font-weight:400;
  margin-bottom:18px;text-transform:uppercase;
}
.section-header{text-align:center;max-width:700px;margin:0 auto 80px}
.section-header h2{
  font-size:clamp(34px,4.5vw,56px);
  font-weight:300;line-height:1.2;margin-bottom:18px;
}
.section-sub{
  font-family:'Helvetica Neue',sans-serif;font-weight:300;
  color:var(--gray);font-size:16px;
}

/* ===== INTRO SECTION ===== */
.intro-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
}
.intro-grid h2{
  font-size:clamp(34px,4vw,52px);
  font-weight:300;line-height:1.15;margin-bottom:28px;
}
.intro-grid .lead{
  font-size:17px;margin-bottom:20px;
  font-family:'Helvetica Neue',sans-serif;font-weight:300;
}
.intro-grid p{
  font-family:'Helvetica Neue',sans-serif;font-weight:300;
  color:#444;line-height:1.8;
}
.intro-stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:30px;margin-top:50px;padding-top:40px;
  border-top:1px solid #e5e5e5;
}
.stat-num{
  display:block;
  font-size:38px;color:var(--gold);
  font-family:'Georgia',serif;font-weight:300;
  margin-bottom:6px;
}
.stat-label{
  font-size:11px;letter-spacing:2px;text-transform:uppercase;
  font-family:'Helvetica Neue',sans-serif;color:var(--gray);
}
.intro-img{position:relative;overflow:hidden}
.intro-img img{
  width:100%;height:560px;object-fit:cover;
  transition:transform 0.8s ease;
}
.intro-img:hover img{transform:scale(1.05)}
.intro-img::after{
  content:'';position:absolute;
  top:20px;left:20px;right:-20px;bottom:-20px;
  border:1px solid var(--gold);z-index:-1;
}

/* ===== SIGNATURES GRID ===== */
.signatures-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:36px;margin-bottom:60px;
}
.signature-card{
  background:var(--dark-2);
  overflow:hidden;
  transition:transform 0.5s ease,box-shadow 0.5s ease;
  border:1px solid var(--border);
}
.signature-card:hover{
  transform:translateY(-8px);
  box-shadow:0 20px 50px rgba(212,175,55,0.15);
}
.signature-img{overflow:hidden;height:300px}
.signature-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 0.7s ease;
}
.signature-card:hover .signature-img img{transform:scale(1.08)}
.signature-info{padding:30px}
.signature-info h3{
  font-size:24px;color:var(--white);
  margin-bottom:10px;font-weight:400;
}
.signature-info p{
  font-family:'Helvetica Neue',sans-serif;font-weight:300;
  color:#aaa;font-size:14px;line-height:1.6;margin-bottom:18px;
}
.price{
  color:var(--gold);font-size:22px;
  font-family:'Georgia',serif;
}
.center-cta{text-align:center}

/* ===== FEATURES ===== */
.features-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:40px;
}
.feature{
  text-align:center;padding:40px 20px;
  transition:all 0.4s ease;
  border:1px solid transparent;
}
.feature:hover{
  border-color:var(--border);
  transform:translateY(-4px);
}
.feature-icon{
  width:80px;height:80px;
  margin:0 auto 24px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--gold);
  border-radius:50%;
  transition:all 0.4s ease;
}
.feature:hover .feature-icon{
  background:var(--gold);
}
.feature:hover .feature-icon svg{stroke:var(--black)}
.feature-icon svg{transition:stroke 0.4s ease}
.feature h3{
  font-size:18px;margin-bottom:12px;font-weight:400;
}
.feature p{
  font-family:'Helvetica Neue',sans-serif;font-weight:300;
  color:var(--gray);font-size:14px;
}

/* ===== CTA SECTION ===== */
.cta-section{
  position:relative;
  padding:160px 0;
  color:var(--white);text-align:center;
  overflow:hidden;
}
.cta-bg{
  position:absolute;inset:0;
  background-image:url('https://images.unsplash.com/photo-1593504049359-74330189a345?w=1920');
  background-size:cover;background-position:center;
  filter:brightness(0.35);
}
.cta-content{position:relative;z-index:2;max-width:700px;margin:0 auto}
.cta-content h2{
  font-size:clamp(34px,4.5vw,56px);
  font-weight:300;line-height:1.2;margin-bottom:24px;
}
.cta-content p{
  font-family:'Helvetica Neue',sans-serif;font-weight:300;
  margin-bottom:36px;color:rgba(255,255,255,0.85);
  font-size:16px;
}

/* ===== FOOTER ===== */
.footer{
  background:var(--black);color:var(--white);
  padding:80px 0 30px;
}
.footer-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1.2fr 1.2fr;
  gap:50px;margin-bottom:50px;
}
.logo-footer{margin-bottom:18px}
.footer-desc{
  font-family:'Helvetica Neue',sans-serif;font-weight:300;
  color:#999;font-size:14px;line-height:1.7;
}
.footer-col h4{
  font-size:13px;letter-spacing:3px;text-transform:uppercase;
  color:var(--gold);margin-bottom:22px;font-weight:400;
  font-family:'Helvetica Neue',sans-serif;
}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:10px}
.footer-col a,.footer-col p{
  font-family:'Helvetica Neue',sans-serif;font-weight:300;
  color:#aaa;font-size:14px;line-height:1.8;
}
.footer-col a:hover{color:var(--gold)}
.footer-bottom{
  padding-top:30px;border-top:1px solid #222;
  text-align:center;
}
.footer-bottom p{
  font-family:'Helvetica Neue',sans-serif;font-weight:300;
  color:#666;font-size:13px;
}

/* ===== MENU PAGE ===== */
.page-header{
  position:relative;
  padding:200px 0 100px;
  background:linear-gradient(rgba(10,10,10,0.85),rgba(10,10,10,0.85)),url('https://images.unsplash.com/photo-1513104890138-7c749659a591?w=1920');
  background-size:cover;background-position:center;
  color:var(--white);text-align:center;
}
.page-header h1{
  font-size:clamp(40px,6vw,72px);
  font-weight:300;margin-bottom:18px;
}
.page-header p{
  font-family:'Helvetica Neue',sans-serif;font-weight:300;
  font-size:17px;color:rgba(255,255,255,0.8);
  max-width:600px;margin:0 auto;
}
.menu-category{margin-bottom:80px}
.menu-category-title{
  text-align:center;margin-bottom:50px;
  font-size:36px;font-weight:300;
  position:relative;padding-bottom:20px;
}
.menu-category-title::after{
  content:'';position:absolute;bottom:0;left:50%;
  transform:translateX(-50%);
  width:60px;height:2px;background:var(--gold);
}
.menu-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:40px;
}
.menu-item{
  display:grid;grid-template-columns:140px 1fr;
  gap:24px;align-items:center;
  padding:20px;border:1px solid transparent;
  transition:all 0.4s ease;background:var(--white);
}
.menu-item:hover{
  border-color:var(--border);
  box-shadow:0 8px 30px rgba(0,0,0,0.06);
  transform:translateY(-3px);
}
.menu-item-img{
  width:140px;height:140px;
  overflow:hidden;border-radius:50%;
  border:2px solid var(--gold);
}
.menu-item-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 0.6s ease;
}
.menu-item:hover .menu-item-img img{transform:scale(1.1)}
.menu-item-info h3{
  font-size:22px;margin-bottom:8px;font-weight:400;
  display:flex;justify-content:space-between;align-items:center;gap:10px;
}
.menu-item-info .item-price{
  color:var(--gold);font-size:20px;white-space:nowrap;
}
.menu-item-info p{
  font-family:'Helvetica Neue',sans-serif;font-weight:300;
  color:var(--gray);font-size:14px;line-height:1.6;
}

/* ===== APROPOS PAGE ===== */
.apropos-section{
  padding:120px 0;
}
.apropos-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:center;margin-bottom:100px;
}
.apropos-grid.reverse > div:first-child{order:2}
.apropos-img{
  position:relative;height:520px;overflow:hidden;
}
.apropos-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 0.8s ease;
}
.apropos-img:hover img{transform:scale(1.05)}
.apropos-text h2{
  font-size:clamp(30px,3.5vw,46px);
  font-weight:300;line-height:1.2;margin-bottom:24px;
}
.apropos-text p{
  font-family:'Helvetica Neue',sans-serif;font-weight:300;
  color:#444;font-size:16px;line-height:1.8;margin-bottom:18px;
}

.values-section{
  background:var(--dark);color:var(--white);
  padding:120px 0;
}
.values-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:40px;margin-top:60px;
}
.value-card{
  text-align:center;padding:40px 30px;
  background:rgba(255,255,255,0.03);
  border:1px solid var(--border);
  transition:all 0.4s ease;
}
.value-card:hover{
  background:rgba(212,175,55,0.05);
  transform:translateY(-6px);
}
.value-num{
  color:var(--gold);font-size:48px;
  font-family:'Georgia',serif;font-weight:300;
  display:block;margin-bottom:10px;
}
.value-card h3{
  font-size:20px;margin-bottom:14px;color:var(--white);font-weight:400;
}
.value-card p{
  font-family:'Helvetica Neue',sans-serif;font-weight:300;
  color:#aaa;font-size:14px;line-height:1.7;
}

/* ===== CONTACT PAGE ===== */
.contact-section{padding:120px 0}
.contact-grid{
  display:grid;grid-template-columns:1fr 1.5fr;
  gap:60px;align-items:start;
}
.contact-info-card{
  background:var(--dark);color:var(--white);
  padding:50px 40px;
}
.contact-info-card h2{
  font-size:32px;margin-bottom:30px;font-weight:300;
}
.contact-info-item{
  display:flex;gap:18px;margin-bottom:30px;
  padding-bottom:24px;border-bottom:1px solid #2a2a2a;
}
.contact-info-item:last-child{border-bottom:none}
.contact-info-icon{
  flex-shrink:0;width:48px;height:48px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--gold);border-radius:50%;
}
.contact-info-text h4{
  font-size:13px;letter-spacing:2px;text-transform:uppercase;
  color:var(--gold);margin-bottom:8px;font-weight:400;
  font-family:'Helvetica Neue',sans-serif;
}
.contact-info-text p{
  font-family:'Helvetica Neue',sans-serif;font-weight:300;
  color:#ccc;font-size:15px;line-height:1.6;
}
.map-wrapper{
  width:100%;height:520px;overflow:hidden;
  border:1px solid var(--border);
}
.map-wrapper iframe{width:100%;height:100%;border:0;filter:grayscale(0.2) contrast(1.1)}

/* ===== ADMIN PAGE ===== */
.admin-body{
  background:var(--light);min-height:100vh;
  font-family:'Helvetica Neue',sans-serif;
}
.admin-login{
  max-width:420px;margin:0 auto;padding:60px 40px;
  background:var(--white);
  margin-top:120px;
  border:1px solid #eee;
  box-shadow:0 10px 40px rgba(0,0,0,0.05);
}
.admin-login h1{
  text-align:center;font-size:28px;
  font-family:'Georgia',serif;font-weight:300;margin-bottom:8px;
}
.admin-login p{
  text-align:center;color:var(--gray);font-size:14px;margin-bottom:30px;
}
.admin-login input{
  width:100%;padding:14px 16px;margin-bottom:14px;
  border:1px solid #ddd;font-size:14px;
  font-family:'Helvetica Neue',sans-serif;
  transition:border-color 0.3s ease;
}
.admin-login input:focus{
  outline:none;border-color:var(--gold);
}
.admin-login button{
  width:100%;padding:14px;
  background:var(--black);color:var(--white);
  border:none;cursor:pointer;
  font-size:13px;letter-spacing:2px;text-transform:uppercase;
  transition:background 0.3s ease;
}
.admin-login button:hover{background:var(--gold);color:var(--black)}
.admin-panel{
  max-width:800px;margin:0 auto;padding:60px 40px;
}
.admin-panel h1{
  font-family:'Georgia',serif;font-weight:300;
  font-size:36px;margin-bottom:8px;text-align:center;
}
.admin-panel .subtitle{
  text-align:center;color:var(--gray);margin-bottom:40px;
}
.admin-card{
  background:var(--white);
  padding:40px;margin-bottom:24px;
  border:1px solid #eee;
}
.admin-card h2{
  font-family:'Georgia',serif;font-weight:400;
  font-size:22px;margin-bottom:14px;
}
.admin-card p{
  color:var(--gray);font-size:14px;margin-bottom:20px;line-height:1.7;
}
.admin-card input{
  width:100%;padding:14px;margin-bottom:14px;
  border:1px solid #ddd;font-size:14px;
}
.admin-card input:focus{outline:none;border-color:var(--gold)}
.admin-card button{
  padding:14px 28px;background:var(--gold);color:var(--black);
  border:none;cursor:pointer;font-size:12px;letter-spacing:2px;
  text-transform:uppercase;font-weight:600;transition:all 0.3s ease;
}
.admin-card button:hover{background:var(--black);color:var(--gold)}
.logout-btn{
  display:block;margin:0 auto;
  background:transparent !important;color:var(--gray) !important;
  font-size:12px !important;text-decoration:underline;
  padding:8px 16px !important;
}
.error-msg{color:#c00;font-size:13px;margin-top:10px;text-align:center}
.hidden{display:none !important}

/* ===== RESPONSIVE ===== */
@media (max-width:1024px){
  .features-grid{grid-template-columns:repeat(2,1fr)}
  .signatures-grid{grid-template-columns:1fr;max-width:500px;margin:0 auto 60px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .intro-grid,.apropos-grid{grid-template-columns:1fr;gap:50px}
  .apropos-grid.reverse > div:first-child{order:0}
  .intro-img img,.apropos-img{height:420px}
  .values-grid{grid-template-columns:1fr;max-width:500px;margin:60px auto 0}
  .contact-grid{grid-template-columns:1fr;gap:40px}
  .menu-grid{grid-template-columns:1fr}
}
@media (max-width:768px){
  .nav-menu{
    position:fixed;top:0;right:-100%;
    width:75%;max-width:320px;height:100vh;
    background:var(--black);
    flex-direction:column;justify-content:center;
    gap:30px;padding:40px;
    transition:right 0.4s ease;
    z-index:999;
  }
  .nav-menu.active{right:0}
  .hamburger{display:flex;z-index:1001}
  .navbar.scrolled{padding:12px 0}
  .logo-text{font-size:18px;letter-spacing:3px}
  .hero{min-height:580px}
  .hero h1{font-size:42px}
  .hero p{font-size:14px}
  .hero-buttons{flex-direction:column;width:100%;max-width:280px;margin:0 auto;gap:12px}
  .btn{width:100%;padding:14px 30px}
  .section{padding:80px 0}
  .section-header{margin-bottom:50px}
  .intro-stats{gap:15px}
  .stat-num{font-size:30px}
  .stat-label{font-size:10px;letter-spacing:1px}
  .features-grid{grid-template-columns:1fr;gap:30px}
  .footer-grid{grid-template-columns:1fr;gap:40px;text-align:center}
  .logo-footer{justify-content:center}
  .footer-col p{justify-content:center;display:flex;align-items:center;flex-wrap:wrap}
  .cta-section{padding:100px 0}
  .menu-item{grid-template-columns:100px 1fr;gap:18px;padding:14px}
  .menu-item-img{width:100px;height:100px}
  .menu-item-info h3{font-size:18px;flex-wrap:wrap}
  .page-header{padding:140px 0 70px}
  .contact-info-card{padding:35px 25px}
  .map-wrapper{height:380px}
}
