:root{
  --navy-deep:#0a1428;
  --navy-mid:#101f38;
  --navy-panel:#142844;
  --navy-line:#28406b;
  --gold:#c9a544;
  --gold-bright:#e7c878;
  --gold-dim:#8a7232;
  --ivory:#f3efe6;
  --ivory-dim:#cdd2dc;
  --silver:#b8bdc7;
}

*{margin:0;padding:0;box-sizing:border-box;}

html{scroll-behavior:smooth;}

body{
  background:var(--navy-deep);
  color:var(--ivory);
  font-family:'Jost', sans-serif;
  font-weight:300;
  line-height:1.6;
  overflow-x:hidden;
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *{animation-duration:0.01ms !important; transition-duration:0.01ms !important;}
}

h1,h2,h3,h4{
  font-family:'Playfair Display', serif;
  font-weight:600;
  letter-spacing:0.01em;
}

a{color:inherit; text-decoration:none;}

img{display:block; max-width:100%;}

.eyebrow{
  font-size:0.72rem;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:500;
}

/* ===== Top bar ===== */
.topbar{
  position:fixed;
  top:0; left:0; right:0;
  z-index:100;
  background:rgba(10,20,40,0.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--navy-line);
}
.topbar-inner{
  max-width:1180px;
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 28px;
}
.brandmark{
  display:flex;
  align-items:center;
  gap:12px;
}
.brandmark img{
  width:38px; height:38px;
  border-radius:50%;
}
.brandmark-text{
  font-family:'Playfair Display', serif;
  font-size:1rem;
  font-weight:600;
  letter-spacing:0.03em;
  color:var(--ivory);
}
.brandmark-text span{
  display:block;
  font-family:'Jost', sans-serif;
  font-size:0.6rem;
  letter-spacing:0.18em;
  color:var(--gold);
  font-weight:400;
  margin-top:2px;
}
nav.primary{
  display:flex;
  gap:34px;
}
nav.primary a{
  font-size:0.78rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--ivory-dim);
  position:relative;
  padding-bottom:4px;
}
nav.primary a::after{
  content:'';
  position:absolute;
  left:0; bottom:0;
  width:0%; height:1px;
  background:var(--gold);
  transition:width 0.3s ease;
}
nav.primary a:hover{color:var(--gold-bright);}
nav.primary a:hover::after{width:100%;}
.nav-cta{
  background:var(--gold);
  color:var(--navy-deep) !important;
  padding:9px 20px;
  border-radius:2px;
  font-size:0.74rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  font-weight:500;
  transition:background 0.25s;
}
.nav-cta:hover{background:var(--gold-bright);}

.menu-toggle{
  display:none;
  background:none;
  border:1px solid var(--navy-line);
  color:var(--ivory);
  width:40px; height:40px;
  font-size:1.1rem;
  cursor:pointer;
}

/* ===== Hero ===== */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:140px 24px 80px;
  background:
    radial-gradient(ellipse 60% 50% at 50% 28%, rgba(201,165,68,0.16), transparent 70%),
    linear-gradient(180deg, #0a1428 0%, #0c1a30 55%, #0a1428 100%);
  overflow:hidden;
}
.hero::before{
  content:'';
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(var(--navy-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--navy-line) 1px, transparent 1px);
  background-size:64px 64px;
  opacity:0.07;
  mask-image:radial-gradient(ellipse 70% 60% at 50% 35%, black 0%, transparent 75%);
}
.hero-content{
  position:relative;
  z-index:2;
  max-width:720px;
}
.hero-crest{
  width:118px;
  height:118px;
  border-radius:50%;
  margin:0 auto 30px;
  box-shadow:0 0 0 1px rgba(201,165,68,0.35), 0 30px 60px -20px rgba(201,165,68,0.25);
  animation:fadeUp 0.9s ease both;
}
.hero-eyebrow{
  animation:fadeUp 0.9s ease 0.1s both;
}
h1.hero-title{
  font-size:clamp(2.4rem, 6vw, 4.2rem);
  color:var(--ivory);
  margin:18px 0 6px;
  line-height:1.08;
  animation:fadeUp 0.9s ease 0.2s both;
}
h1.hero-title em{
  font-style:italic;
  color:var(--gold-bright);
}
.hero-sub{
  font-size:1.02rem;
  color:var(--silver);
  letter-spacing:0.03em;
  margin-top:16px;
  animation:fadeUp 0.9s ease 0.32s both;
}
.hero-actions{
  display:flex;
  gap:16px;
  justify-content:center;
  margin-top:38px;
  flex-wrap:wrap;
  animation:fadeUp 0.9s ease 0.44s both;
}
.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:14px 30px;
  font-size:0.8rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  font-weight:500;
  border-radius:2px;
  transition:transform 0.25s ease, background 0.25s, color 0.25s, border-color 0.25s;
}
.btn-gold{
  background:var(--gold);
  color:var(--navy-deep);
}
.btn-gold:hover{background:var(--gold-bright); transform:translateY(-2px);}
.btn-outline{
  border:1px solid var(--navy-line);
  color:var(--ivory-dim);
}
.btn-outline:hover{border-color:var(--gold); color:var(--gold-bright); transform:translateY(-2px);}

@keyframes fadeUp{
  from{opacity:0; transform:translateY(16px);}
  to{opacity:1; transform:translateY(0);}
}

.hero-scroll{
  position:absolute;
  bottom:34px;
  left:50%;
  transform:translateX(-50%);
  z-index:2;
  color:var(--silver);
  font-size:0.65rem;
  letter-spacing:0.2em;
  text-transform:uppercase;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  opacity:0.7;
}
.hero-scroll .line{
  width:1px;
  height:30px;
  background:linear-gradient(180deg, var(--gold), transparent);
  animation:scrollPulse 1.8s ease-in-out infinite;
}
@keyframes scrollPulse{
  0%,100%{opacity:0.3;}
  50%{opacity:1;}
}

/* ===== Section shell ===== */
section{
  padding:96px 24px;
  max-width:1180px;
  margin:0 auto;
}
.section-head{
  text-align:center;
  max-width:560px;
  margin:0 auto 56px;
}
.section-head h2{
  font-size:clamp(1.8rem, 3.6vw, 2.6rem);
  color:var(--ivory);
  margin-top:14px;
}
.section-head p{
  color:var(--silver);
  margin-top:16px;
  font-size:0.96rem;
}

/* ===== Category strip ===== */
.cat-strip{
  display:flex;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
  margin-bottom:64px;
}
.cat-chip{
  border:1px solid var(--navy-line);
  padding:10px 22px;
  font-size:0.76rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--ivory-dim);
  border-radius:30px;
  transition:all 0.25s ease;
  cursor:pointer;
  background:transparent;
  font-family:'Jost', sans-serif;
}
.cat-chip:hover, .cat-chip.active{
  border-color:var(--gold);
  color:var(--navy-deep);
  background:var(--gold);
}

/* ===== Product grid ===== */
.grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:28px;
}
.card{
  background:var(--navy-panel);
  border:1px solid var(--navy-line);
  position:relative;
  transition:transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
}
.card:hover{
  transform:translateY(-6px);
  border-color:var(--gold-dim);
  box-shadow:0 20px 40px -20px rgba(0,0,0,0.6);
}
.card-frame{
  position:relative;
  aspect-ratio:4/5;
  overflow:hidden;
}
.card-frame img{
  width:100%; height:100%;
  object-fit:cover;
  transition:transform 0.6s ease;
}
.card:hover .card-frame img{transform:scale(1.06);}
.card-frame::after{
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 60%, rgba(10,20,40,0.78) 100%);
  pointer-events:none;
}
.card-tag{
  position:absolute;
  top:12px; left:12px;
  background:rgba(10,20,40,0.78);
  border:1px solid var(--gold-dim);
  color:var(--gold-bright);
  font-size:0.62rem;
  letter-spacing:0.12em;
  text-transform:uppercase;
  padding:5px 10px;
  z-index:2;
}
.card-body{
  padding:18px 18px 20px;
}
.card-cat{
  font-size:0.66rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--gold);
}
.card-title{
  font-family:'Playfair Display', serif;
  font-size:1.04rem;
  color:var(--ivory);
  margin-top:6px;
  font-weight:500;
}
.card-foot{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-top:14px;
}
.card-price{
  color:var(--silver);
  font-size:0.84rem;
}
.card-order{
  font-size:0.68rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--gold-bright);
  border-bottom:1px solid var(--gold-dim);
  padding-bottom:2px;
  transition:color 0.25s, border-color 0.25s;
}
.card-order:hover{color:var(--ivory); border-color:var(--gold-bright);}

/* ===== About / brand band ===== */
.band{
  background:var(--navy-mid);
  border-top:1px solid var(--navy-line);
  border-bottom:1px solid var(--navy-line);
}
.band-inner{
  max-width:1180px;
  margin:0 auto;
  padding:96px 24px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:center;
}
.band-crest{
  display:flex;
  justify-content:center;
}
.band-crest img{
  width:240px;
  height:240px;
  border-radius:50%;
  box-shadow:0 0 0 1px rgba(201,165,68,0.3), 0 40px 80px -30px rgba(201,165,68,0.25);
}
.band-copy h3{
  font-size:clamp(1.6rem, 3vw, 2.2rem);
  color:var(--ivory);
}
.band-copy p{
  color:var(--silver);
  margin-top:18px;
  font-size:0.96rem;
}
.band-stats{
  display:flex;
  gap:40px;
  margin-top:34px;
}
.stat-num{
  font-family:'Playfair Display', serif;
  font-size:1.8rem;
  color:var(--gold-bright);
}
.stat-label{
  font-size:0.7rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--silver);
  margin-top:4px;
}

/* ===== Contact / order section ===== */
.contact-wrap{
  background:linear-gradient(180deg, var(--navy-deep), #081021);
}
.contact-card{
  background:var(--navy-panel);
  border:1px solid var(--navy-line);
  padding:64px 48px;
  text-align:center;
  position:relative;
}
.contact-card::before, .contact-card::after{
  content:'';
  position:absolute;
  width:34px; height:34px;
  border:1px solid var(--gold);
}
.contact-card::before{top:14px; left:14px; border-right:none; border-bottom:none;}
.contact-card::after{bottom:14px; right:14px; border-left:none; border-top:none;}
.contact-card h2{
  font-size:clamp(1.7rem, 3.4vw, 2.4rem);
  color:var(--ivory);
}
.contact-card p{
  color:var(--silver);
  margin-top:14px;
  max-width:460px;
  margin-left:auto;
  margin-right:auto;
}
.contact-methods{
  display:flex;
  gap:18px;
  justify-content:center;
  margin-top:40px;
  flex-wrap:wrap;
}
.contact-pill{
  display:flex;
  align-items:center;
  gap:10px;
  border:1px solid var(--navy-line);
  padding:14px 24px;
  border-radius:2px;
  transition:border-color 0.25s, transform 0.25s;
  font-size:0.86rem;
  color:var(--ivory-dim);
}
.contact-pill:hover{border-color:var(--gold); transform:translateY(-2px); color:var(--gold-bright);}
.contact-pill svg{width:18px; height:18px; flex-shrink:0;}

/* ===== Footer ===== */
footer{
  border-top:1px solid var(--navy-line);
  padding:54px 24px 36px;
}
.footer-inner{
  max-width:1180px;
  margin:0 auto;
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  flex-wrap:wrap;
  gap:32px;
}
.footer-brand{
  display:flex;
  align-items:center;
  gap:12px;
}
.footer-brand img{
  width:34px; height:34px;
  border-radius:50%;
}
.footer-brand-text{
  font-family:'Playfair Display', serif;
  font-size:0.96rem;
  color:var(--ivory);
}
.footer-brand-text span{
  display:block;
  font-family:'Jost', sans-serif;
  font-size:0.62rem;
  letter-spacing:0.16em;
  color:var(--gold);
  margin-top:3px;
}
.footer-meta{
  color:var(--silver);
  font-size:0.78rem;
  text-align:right;
}
.footer-meta a{color:var(--ivory-dim); transition:color 0.2s;}
.footer-meta a:hover{color:var(--gold-bright);}
.footer-bottom{
  max-width:1180px;
  margin:34px auto 0;
  padding-top:24px;
  border-top:1px solid var(--navy-line);
  text-align:center;
  font-size:0.72rem;
  color:var(--silver);
  letter-spacing:0.04em;
}

/* ===== Floating WhatsApp ===== */
.float-wa{
  position:fixed;
  bottom:26px;
  right:26px;
  z-index:90;
  display:flex;
  align-items:center;
  gap:10px;
  background:var(--gold);
  color:var(--navy-deep);
  padding:14px 20px;
  border-radius:30px;
  font-size:0.78rem;
  letter-spacing:0.06em;
  text-transform:uppercase;
  font-weight:500;
  box-shadow:0 14px 30px -10px rgba(201,165,68,0.5);
  transition:transform 0.25s, background 0.25s;
}
.float-wa:hover{transform:translateY(-3px); background:var(--gold-bright);}
.float-wa svg{width:18px; height:18px;}

/* ===== Responsive ===== */
@media (max-width:980px){
  .grid{grid-template-columns:repeat(2, 1fr);}
  .band-inner{grid-template-columns:1fr; text-align:center;}
  .band-stats{justify-content:center;}
}

@media (max-width:760px){
  nav.primary{
    position:fixed;
    top:67px; left:0; right:0;
    background:var(--navy-deep);
    border-bottom:1px solid var(--navy-line);
    flex-direction:column;
    gap:0;
    max-height:0;
    overflow:hidden;
    transition:max-height 0.3s ease;
  }
  nav.primary.open{max-height:340px;}
  nav.primary a{
    padding:16px 28px;
    width:100%;
    border-bottom:1px solid var(--navy-line);
  }
  .nav-cta{margin:16px 28px; text-align:center; display:block;}
  .menu-toggle{display:block;}
  .footer-inner{flex-direction:column;}
  .footer-meta{text-align:left;}
}

@media (max-width:560px){
  .grid{grid-template-columns:repeat(2, 1fr); gap:16px;}
  section{padding:72px 18px;}
  .contact-card{padding:44px 22px;}
  .float-wa span{display:none;}
  .float-wa{padding:14px; border-radius:50%;}
}

/* ===== Lightbox ===== */
.zoomable{
  cursor:zoom-in;
}

.lightbox{
  display:none;
  position:fixed;
  inset:0;
  z-index:200;
  background:rgba(8,14,28,0.94);
  align-items:center;
  justify-content:center;
  padding:40px 20px;
}

.lightbox.open{
  display:flex;
}

.lightbox img{
  max-width:100%;
  max-height:90vh;
  border:1px solid var(--gold-dim);
  box-shadow:0 30px 60px -20px rgba(0,0,0,0.6);
  cursor:default;
}

.lightbox-close{
  position:absolute;
  top:24px;
  right:28px;
  color:var(--ivory);
  font-size:2.2rem;
  line-height:1;
  cursor:pointer;
  font-family:'Jost', sans-serif;
  font-weight:300;
  transition:color 0.2s;
}

.lightbox-close:hover{
  color:var(--gold-bright);
}