
/*
Theme Name: Eterna Complete Luxury Website
Theme URI: https://eternajewelrybar.com
Author: ChatGPT
Description: Complete custom WordPress theme for Eterna Permanent Jewelry & Engraving.
Version: 1.0
*/

:root{
  --cream:#fbf6ef;
  --soft:#f1e4d4;
  --white:#ffffff;
  --gold:#c8a04d;
  --gold2:#b98b2f;
  --dark:#3b2d26;
  --muted:#6f5d52;
  --line:rgba(200,160,77,.28);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Helvetica Neue",Arial,sans-serif;
  background:var(--cream);
  color:var(--dark);
  line-height:1.7;
}
body.no-scroll{overflow:hidden}
h1,h2,h3{
  font-family:Georgia,"Times New Roman",serif;
  font-weight:400;
  line-height:1.08;
  color:var(--dark);
}
p{color:var(--muted)}
img{max-width:100%}
a{color:inherit}

.site-header{
  position:sticky;
  top:0;
  z-index:999;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(10px);
  box-shadow:0 2px 18px rgba(0,0,0,.05);
  padding:14px 6%;
  display:grid;
  grid-template-columns:220px 1fr auto;
  align-items:center;
  gap:24px;
}
.logo img{width:205px;display:block}
.nav{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:25px;
}
.nav a{
  color:var(--dark);
  text-decoration:none;
  text-transform:uppercase;
  font-size:13px;
  letter-spacing:1.1px;
  font-weight:700;
  white-space:nowrap;
}
.nav a:hover{color:var(--gold2)}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  min-width:155px;
  padding:14px 28px;
  border-radius:999px;
  background:var(--gold);
  color:white!important;
  text-decoration:none;
  font-weight:700;
  letter-spacing:.4px;
  border:1px solid var(--gold);
  cursor:pointer;
  transition:.2s ease;
}
.btn:hover{transform:translateY(-1px);background:var(--gold2)}
.btn.secondary{
  background:transparent;
  color:var(--dark)!important;
  border-color:var(--gold);
}
.btn.secondary:hover{background:var(--gold);color:white!important}
.hero{
  min-height:88vh;
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:center;
  gap:60px;
  padding:78px 8%;
}
.hero h1{
  font-size:70px;
  margin:0 0 20px;
}
.hero p{
  font-size:21px;
  max-width:650px;
  margin-bottom:30px;
}
.kicker{
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--gold2);
  font-weight:700;
  font-size:13px;
  margin-bottom:16px;
}
.hero-buttons{display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.hero-image img{
  width:100%;
  height:680px;
  object-fit:cover;
  border-radius:34px;
  box-shadow:0 20px 50px rgba(0,0,0,.09);
}
.section{padding:95px 8%}
.section.soft{background:var(--soft)}
.section-title{
  text-align:center;
  font-size:52px;
  margin:0 0 18px;
}
.section-subtitle{
  max-width:850px;
  margin:0 auto 58px;
  text-align:center;
  font-size:18px;
}
.services{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:30px;
  align-items:stretch;
}
.service-card{
  background:white;
  border-radius:28px;
  box-shadow:0 10px 35px rgba(0,0,0,.055);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  height:100%;
  text-align:center;
}
.service-card img{
  width:100%;
  height:330px;
  object-fit:cover;
  display:block;
}
.service-content{
  padding:30px 28px 34px;
  min-height:275px;
  display:flex;
  flex-direction:column;
  align-items:center;
}
.service-icon{
  width:54px;
  height:54px;
  border-radius:50%;
  border:1px solid rgba(200,160,77,.5);
  color:var(--gold);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:25px;
  margin:-58px auto 18px;
  background:white;
  box-shadow:0 8px 20px rgba(0,0,0,.04);
}
.service-content h3{
  font-size:28px;
  margin:0 0 12px;
  min-height:62px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
}
.service-content p{margin:0 0 24px;flex:1}
.split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:55px;
  align-items:center;
}
.split img{
  width:100%;
  height:610px;
  object-fit:cover;
  border-radius:32px;
  box-shadow:0 16px 45px rgba(0,0,0,.07);
}
.split h2{font-size:54px;margin:0 0 22px}
.info-graphic{
  display:block;
  width:100%;
  border-radius:28px;
  box-shadow:0 14px 38px rgba(0,0,0,.07);
  border:1px solid var(--line);
  background:white;
}
.info-block{
  max-width:1060px;
  margin:0 auto;
}
.page-hero{
  padding:85px 8% 65px;
  text-align:center;
  background:linear-gradient(180deg,#fffaf5,var(--cream));
}
.page-hero img{
  width:250px;
  margin-bottom:24px;
}
.page-hero h1{
  font-size:64px;
  margin:0 0 16px;
}
.page-hero p{
  max-width:830px;
  margin:0 auto 24px;
  font-size:20px;
}
.feature-list{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
  margin:28px 0 32px;
}
.feature{
  background:white;
  border-radius:16px;
  padding:16px 18px;
  color:var(--dark);
  display:flex;
  align-items:center;
  gap:10px;
}
.feature span{color:var(--gold);font-size:20px;line-height:1}
.event-page{
  background:var(--soft);
  padding:110px 8%;
}
.event-intro{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:55px;
  align-items:center;
  margin-bottom:70px;
}
.event-intro h2{
  font-size:62px;
  margin:0 0 18px;
}
.event-intro p{font-size:19px}
.event-intro img{
  width:100%;
  height:620px;
  object-fit:cover;
  border-radius:34px;
  box-shadow:0 18px 48px rgba(0,0,0,.08);
}
.event-options{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-bottom:70px;
}
.event-option{
  background:white;
  border-radius:24px;
  padding:34px 28px;
  text-align:center;
  border:1px solid var(--line);
  min-height:230px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.event-option h3{
  font-size:28px;
  margin:0 0 12px;
}
.service-area-banner{
  background:#fffaf5;
  border:1px solid var(--line);
  border-radius:26px;
  padding:30px;
  margin:0 0 42px;
  text-align:center;
}
.service-area-banner h3{font-size:32px;margin:0 0 10px}
.city-list{
  max-width:980px;
  margin:20px auto 0;
  color:var(--dark);
  font-weight:700;
  line-height:2;
}
.event-form-wrap{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:42px;
  background:white;
  padding:46px;
  border-radius:34px;
  box-shadow:0 15px 45px rgba(0,0,0,.07);
}
.event-form-copy h2{
  font-size:46px;
  margin:0 0 18px;
}
.event-form{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
.form-field.full{grid-column:1/-1}
.event-form label{
  display:block;
  font-size:13px;
  letter-spacing:.7px;
  text-transform:uppercase;
  font-weight:700;
  color:var(--dark);
  margin-bottom:6px;
}
.event-form input,
.event-form select,
.event-form textarea{
  width:100%;
  border:1px solid rgba(59,45,38,.16);
  border-radius:16px;
  padding:14px 16px;
  background:#fffaf5;
  color:var(--dark);
  font:inherit;
}
.event-form textarea{min-height:125px;resize:vertical}
.form-note{
  grid-column:1/-1;
  font-size:13px;
  margin:0;
}
.gallery{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
}
.gallery img{
  width:100%;
  height:420px;
  object-fit:cover;
  border-radius:24px;
  box-shadow:0 10px 28px rgba(0,0,0,.055);
}
.cta{
  background:linear-gradient(rgba(248,243,237,.72),rgba(248,243,237,.72)),url('assets/images/event-main.jpeg');
  background-size:cover;
  background-position:center;
  padding:125px 8%;
  text-align:center;
}
.cta-box{
  background:rgba(255,255,255,.9);
  max-width:850px;
  margin:auto;
  padding:55px 45px;
  border-radius:32px;
  box-shadow:0 12px 35px rgba(0,0,0,.08);
}
.cta h2{font-size:58px;margin:0 0 18px}
.footer{
  background:#2d241e;
  color:white;
  text-align:center;
  padding:65px 8%;
}
.footer img{
  width:190px;
  background:white;
  border-radius:16px;
  padding:10px;
}
.footer p{color:#eadfce}
.footer-nav{margin:20px 0}
.footer-nav a{
  color:#eadfce;
  margin:0 10px;
  text-decoration:none;
}
.thank-you-body{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--cream);
  padding:24px;
}
.thank-you-box{
  max-width:720px;
  width:100%;
  background:white;
  text-align:center;
  padding:55px 35px;
  border-radius:32px;
  box-shadow:0 18px 45px rgba(0,0,0,.08);
  border:1px solid var(--line);
}
.thank-you-box h1{font-size:52px;margin:0 0 18px}
.thank-you-box p{font-size:19px}
.mobile-toggle{display:none}
@media(max-width:1100px){
  .site-header{grid-template-columns:1fr;justify-items:center}
  .nav{flex-wrap:wrap}
  .hero,.split,.event-intro,.event-form-wrap{grid-template-columns:1fr}
  .hero-image img,.split img,.event-intro img{height:auto;max-height:680px}
  .services,.gallery,.event-options{grid-template-columns:1fr}
}
@media(max-width:700px){
  .hero,.section,.event-page{padding:58px 6%}
  .hero h1,.page-hero h1{font-size:44px}
  .section-title,.split h2,.cta h2,.event-intro h2,.event-form-copy h2{font-size:38px}
  .hero-buttons{justify-content:center}
  .hero{text-align:center}
  .feature-list,.event-form{grid-template-columns:1fr}
  .nav{gap:13px}
  .nav a{font-size:12px}
  .logo img{width:170px}
  .service-content h3{min-height:unset}
  .event-form-wrap{padding:28px}
  .gallery img{height:auto}
  .page-hero img{width:190px}
}


.mobile-toggle{display:none;background:none;border:none;font-size:32px;color:var(--dark)}

@media(max-width:768px){
.site-header{
display:flex;
justify-content:space-between;
padding:10px 15px;
gap:10px;
}
.logo img{width:120px!important}
.mobile-toggle{display:block}
.nav{
position:fixed;
top:80px;
left:0;right:0;
background:#fff;
display:none;
flex-direction:column;
padding:20px;
box-shadow:0 10px 20px rgba(0,0,0,.1);
}
body.menu-open .nav{display:flex}
.btn{display:none}
}


/* Floating booking button */
.floating-book-btn{
position:fixed;
right:20px;
bottom:20px;
z-index:9999;
background:#c8a04d;
color:#fff !important;
padding:14px 20px;
border-radius:999px;
text-decoration:none;
font-weight:700;
box-shadow:0 8px 25px rgba(0,0,0,.2);
}
@media(max-width:768px){
.floating-book-btn{bottom:15px;right:15px;padding:12px 16px;font-size:14px;}
}
