/* --- Variables --- */
:root {
    --color-purple: #4b0082;    /* Royal Purple */
    --color-purple-dark: #320057;
    --color-gold: #d4af37;      /* Luxury Gold */
    --color-gold-light: #f3e5ab;
    --color-white: #ffffff;
    --color-grey: #f8f8f8;
    --color-text: #333333;
    
    --font-serif: 'Playfair Display', serif;
    --font-sans: 'Montserrat', sans-serif;
    
    --radius: 0px; /* Sharp edges for luxury feel */
}

* { margin: 0; padding: 0; box-sizing: border-box; }

body {
    font-family: var(--font-sans);
    background-color: var(--color-white);
    color: var(--color-text);
    line-height: 1.8;
    font-weight: 300;
}

a { text-decoration: none; color: inherit; transition: 0.4s; }
ul { list-style: none; }
img { max-width: 100%; display: block; }

.container { width: 90%; max-width: 1100px; margin: 0 auto; }

/* --- Top Bar --- */
.top-bar { background-color: var(--color-purple-dark); color: #ccc; padding: 10px 0; font-size: 0.8rem; letter-spacing: 1px; }
.flex-end { display: flex; justify-content: flex-end; align-items: center; gap: 20px; }
.socials a { color: var(--color-gold); margin-left: 10px; font-weight: bold; }

/* --- Header --- */
.lux-header {
    padding: 25px 0;
    position: absolute; width: 100%; top: 40px; z-index: 1000;
    background: linear-gradient(to bottom, rgba(0,0,0,0.8), transparent);
}

.header-flex { display: flex; justify-content: space-between; align-items: center; }

.logo { font-family: var(--font-serif); font-size: 1.8rem; color: var(--color-white); letter-spacing: 2px; }
.gold-text { color: var(--color-gold); font-style: italic; }

.lux-nav ul { display: flex; gap: 30px; align-items: center; }
.lux-nav a { color: var(--color-white); text-transform: uppercase; font-size: 0.85rem; letter-spacing: 1px; }
.lux-nav a:hover, .lux-nav a.active { color: var(--color-gold); }

.btn-gold { border: 1px solid var(--color-gold); color: var(--color-gold) !important; padding: 10px 25px; transition: 0.3s; }
.btn-gold:hover { background-color: var(--color-gold); color: #000 !important; }

.mobile-toggle { display: none; background: none; border: none; cursor: pointer; flex-direction: column; gap: 6px; }
.mobile-toggle span { width: 30px; height: 1px; background-color: var(--color-gold); display: block; }

/* --- Mobile Menu --- */
.mobile-menu {
    position: fixed; top: 0; right: -100%; width: 100%; height: 100%;
    background-color: var(--color-purple-dark); z-index: 2000;
    display: flex; flex-direction: column; justify-content: center; align-items: center;
    transition: 0.5s ease;
}
.mobile-menu.active { right: 0; }
.close-menu { position: absolute; top: 30px; right: 30px; font-size: 2rem; color: var(--color-gold); background: none; border: none; cursor: pointer; }
.mobile-menu a { font-family: var(--font-serif); font-size: 2rem; color: var(--color-white); margin: 15px 0; font-style: italic; }

/* --- Hero --- */
.hero-lux {
    height: 100vh;
    background-size: cover; background-position: center;
    display: flex; align-items: center; justify-content: center; text-align: center;
    position: relative;
}
.hero-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgba(50, 0, 87, 0.3); z-index: 1; }

.hero-content { position: relative; z-index: 2; color: var(--color-white); max-width: 800px; padding: 20px; }
.subtitle { font-family: var(--font-sans); letter-spacing: 5px; color: var(--color-gold); font-size: 0.9rem; margin-bottom: 20px; display: block; }
.hero-content h1 { font-family: var(--font-serif); font-size: 4.5rem; line-height: 1.1; margin-bottom: 30px; }
.hero-content p { font-size: 1.3rem; margin-bottom: 40px; font-weight: 300; }
.btn-hero { background-color: var(--color-gold); color: #000; padding: 15px 40px; font-weight: 600; letter-spacing: 2px; font-size: 0.9rem; transition: 0.3s; }
.btn-hero:hover { background-color: var(--color-white); }

/* --- Services Grid --- */
.section-padding { padding: 100px 0; }
.section-head { text-align: center; margin-bottom: 80px; }
.section-head h2 { font-family: var(--font-serif); font-size: 3rem; color: var(--color-purple); margin-bottom: 10px; }
.ornament { font-size: 2rem; color: var(--color-gold); }

.service-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 40px; }
.service-card { background-color: var(--color-white); box-shadow: 0 10px 30px rgba(0,0,0,0.05); transition: 0.4s; border-bottom: 3px solid transparent; }
.service-card:hover { transform: translateY(-10px); border-bottom-color: var(--color-gold); }

.img-box { height: 250px; overflow: hidden; }
.img-box img { width: 100%; height: 100%; object-fit: cover; transition: 0.5s; }
.service-card:hover img { transform: scale(1.1); }

.text-box { padding: 30px; text-align: center; }
.text-box h3 { font-family: var(--font-serif); font-size: 1.5rem; margin-bottom: 15px; color: var(--color-purple); }
.text-box p { color: #666; margin-bottom: 20px; font-size: 0.95rem; }
.text-box a { color: var(--color-gold); font-weight: 600; font-size: 0.9rem; text-transform: uppercase; letter-spacing: 1px; }

/* --- About --- */
.about-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.about-text h1 { font-family: var(--font-serif); font-size: 3rem; color: var(--color-purple); margin-bottom: 30px; line-height: 1.2; }
.about-text p { margin-bottom: 20px; color: #555; }
.signature { margin-top: 30px; font-family: var(--font-serif); font-size: 1.5rem; color: var(--color-purple); }
.signature span { display: block; font-family: var(--font-sans); font-size: 0.8rem; color: #999; margin-top: 5px; letter-spacing: 1px; text-transform: uppercase; }

.about-img { position: relative; padding: 20px; }
.about-img img { position: relative; z-index: 2; }
.img-border { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: 2px solid var(--color-gold); z-index: 1; transform: translate(-20px, -20px); }

/* --- Reviews --- */
.reviews-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.review-card { background-color: var(--color-grey); padding: 40px; text-align: center; font-style: italic; }
.review-card.highlight { background-color: var(--color-purple); color: var(--color-white); }
.review-card.highlight .author span { color: var(--color-gold); }
.author { margin-top: 20px; display: block; font-style: normal; }
.author strong { display: block; font-family: var(--font-serif); font-size: 1.1rem; margin-bottom: 5px; }
.author span { font-size: 0.85rem; color: #888; text-transform: uppercase; letter-spacing: 1px; }

/* --- Contact & Form --- */
.booking-wrapper { display: grid; grid-template-columns: 1fr 1.5fr; gap: 60px; }
.booking-text h2 { font-family: var(--font-serif); font-size: 2.5rem; color: var(--color-purple); margin-bottom: 20px; }
.contact-list { margin-top: 40px; }
.contact-list li { margin-bottom: 15px; font-size: 1.1rem; color: var(--color-text); }

.gold-form .form-group { margin-bottom: 25px; }
.gold-form label { display: block; margin-bottom: 10px; font-family: var(--font-serif); color: var(--color-purple); font-weight: bold; }
.gold-form input, .gold-form select, .gold-form textarea { width: 100%; padding: 15px; border: 1px solid #ccc; background-color: #fcfcfc; font-family: var(--font-sans); }
.gold-form input:focus { border-color: var(--color-gold); outline: none; }
.btn-submit { background-color: var(--color-purple); color: var(--color-white); width: 100%; padding: 15px; border: none; font-weight: 600; letter-spacing: 2px; cursor: pointer; transition: 0.3s; }
.btn-submit:hover { background-color: var(--color-gold); color: #000; }

/* --- Legal --- */
.legal-doc { max-width: 800px; margin: 0 auto; background: var(--color-grey); padding: 60px; }
.legal-doc h1 { font-family: var(--font-serif); text-align: center; color: var(--color-purple); }
.divider-gold { width: 50px; height: 2px; background: var(--color-gold); margin: 20px auto 40px; }
.legal-doc h3 { color: var(--color-purple); margin-top: 30px; margin-bottom: 10px; font-family: var(--font-serif); }

/* --- Footer --- */
.lux-footer { background-color: var(--color-purple-dark); color: var(--color-white); padding: 60px 0; margin-top: auto; text-align: center; border-top: 5px solid var(--color-gold); }
.f-brand { font-family: var(--font-serif); font-size: 2rem; margin-bottom: 20px; letter-spacing: 3px; }
.f-links a { color: #ccc; margin: 0 15px; font-size: 0.9rem; text-transform: uppercase; }
.f-links a:hover { color: var(--color-gold); }
.copyright { margin-top: 30px; font-size: 0.8rem; opacity: 0.5; }

@media (max-width: 992px) {
    .lux-nav { display: none; }
    .mobile-toggle { display: flex; }
    .hero-content h1 { font-size: 3rem; }
    .lux-header { background-color: var(--color-purple-dark); top: 0; }
    .about-layout, .booking-wrapper, .reviews-grid { grid-template-columns: 1fr; }
    .top-bar { display: none; }
}