/* Being Gorgeous — Standalone CSS */
:root{
  --background:#F1EAD3; --foreground:#1A1535;
  --card:#F7F1DE; --card-foreground:#1A1535;
  --primary:#C7A95B; --primary-foreground:#1A1535; --primary-glow:#E0C77F;
  --secondary:#3D3373; --secondary-foreground:#F7F1DE;
  --muted:#E5DCC0; --muted-foreground:#3F3960;
  --accent:#1A1535; --accent-foreground:#F7F1DE;
  --border:#D4C7A3; --hairline:#7C7592;
  --sand:#F1EAD3; --sand-light:#F7F1DE; --cream:#F7F1DE;
}
[data-theme="dark"]{
  --background:#120D21; --foreground:#FBE9EA;
  --card:#1f1934; --card-foreground:#FBE9EA;
  --primary:#E59FAA; --primary-foreground:#1F242C; --primary-glow:#F0BFC7;
  --secondary:#4B5363; --secondary-foreground:#FBE9EA;
  --muted:#2D333D; --muted-foreground:#D4C0C2;
  --accent:#E59FAA; --accent-foreground:#1F242C;
  --border:#3A4250; --hairline:#444C5A;
  --sand:#1f1934; --sand-light:#1f1934; --cream:#1f1934;
}
*,*::before,*::after{box-sizing:border-box;border-color:var(--border)}
html{scroll-behavior:smooth}
body{margin:0;background:var(--background);color:var(--foreground);font-family:'Inter',system-ui,sans-serif;-webkit-font-smoothing:antialiased;line-height:1.5}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
h1,h2,h3,.font-display{font-family:'EB Garamond','Cormorant Garamond',serif;font-weight:500;letter-spacing:-0.01em;margin:0}
.font-script{font-family:'Great Vibes','EB Garamond',cursive;font-weight:400;letter-spacing:.01em}
.font-serif-italic{font-family:'EB Garamond',serif;font-style:italic}
.container{max-width:1280px;margin:0 auto;padding:0 1.5rem}
@media(min-width:768px){.container{padding:0 2.5rem}}
.text-primary{color:var(--primary)} .text-foreground{color:var(--foreground)}
.text-muted{color:var(--muted-foreground)} .text-accent-fg{color:var(--accent-foreground)}
.text-pf{color:var(--primary-foreground)}
.eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.3em;color:var(--primary);margin:0 0 1rem}
.h-script{font-family:'Great Vibes',cursive;color:var(--primary);font-size:42px;line-height:1.1}
@media(min-width:768px){.h-script{font-size:56px}}
.section{padding:8rem 0}
@media(min-width:768px){.section{padding:10rem 0}}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:1rem 2.5rem;font-size:12px;letter-spacing:.2em;text-transform:uppercase;transition:all .3s;cursor:pointer}
.btn-primary{background:var(--primary);color:var(--primary-foreground)}
.btn-primary:hover{background:var(--accent);color:var(--accent-foreground)}
.btn-outline{border:1px solid var(--primary);color:var(--primary);background:transparent}
.btn-outline:hover{background:var(--primary);color:var(--primary-foreground)}
.btn-sm{padding:.625rem 1.5rem;font-size:11px}

/* Header */
.header{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--background) 95%,transparent);backdrop-filter:blur(8px);border-bottom:1px solid color-mix(in srgb,var(--primary) 20%,transparent)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;max-width:1280px;margin:0 auto;padding:1rem 1.5rem}
@media(min-width:768px){.nav{padding:1rem 2.5rem}}
.logo-img{height:130px;width:auto;object-fit:contain}
@media(min-width:768px){.logo-img{height:150px}}
[data-theme="dark"] .logo-img{filter:invert(1) hue-rotate(180deg)}
.nav-links{display:none;list-style:none;margin:0;padding:0;gap:1.75rem;align-items:center}
.nav-link{position:relative;font-size:14px;letter-spacing:.025em;color:color-mix(in srgb,var(--foreground) 80%,transparent);transition:color .2s}
.nav-link:hover{color:var(--primary)}
.nav-link::after{content:"";position:absolute;left:0;bottom:-4px;height:1px;width:0;background:var(--primary);transition:width .3s}
.nav-link:hover::after{width:100%}
.nav-actions{display:none;align-items:center;gap:1rem}
.nav-mobile{display:flex;align-items:center;gap:.5rem}
@media(min-width:1280px){
  .nav-links{display:flex}
  .nav-actions{display:flex}
  .nav-mobile{display:none}
}
.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:9999px;border:1px solid var(--border);color:var(--foreground)}
.theme-toggle:hover{background:var(--muted)}
.menu-btn{color:var(--foreground)}
.mobile-menu{display:none;border-top:1px solid var(--hairline);background:var(--background)}
.mobile-menu.open{display:block}
.mobile-menu ul{list-style:none;margin:0;padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}
@media(min-width:1280px){.mobile-menu{display:none!important}}

/* Hero */
.hero{position:relative;overflow:hidden;background:var(--background)}
.hero-grid{position:relative;display:grid;align-items:center;gap:3rem;max-width:1280px;margin:0 auto;padding:5rem 1.5rem;min-height:calc(100vh - 72px)}
@media(min-width:768px){.hero-grid{padding:6rem 2.5rem}}
@media(min-width:1024px){.hero-grid{grid-template-columns:repeat(12,1fr)}}
.hero-text{text-align:center}
@media(min-width:1024px){.hero-text{grid-column:span 6;text-align:left}}
.hero-h1{font-family:'Great Vibes',cursive;font-size:56px;line-height:1;color:var(--foreground)}
@media(min-width:768px){.hero-h1{font-size:80px}}
.hero-h1 span{color:var(--primary)}
.hero-sub{margin:2rem auto 0;max-width:560px;font-size:1rem;color:var(--muted-foreground);font-weight:300}
@media(min-width:768px){.hero-sub{font-size:1.125rem}}
@media(min-width:1024px){.hero-sub{margin-left:0}}
.hero-cta{margin-top:3rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}
@media(min-width:640px){.hero-cta{flex-direction:row}}
@media(min-width:1024px){.hero-cta{justify-content:flex-start}}
.hero-img-wrap{position:relative}
@media(min-width:1024px){.hero-img-wrap{grid-column:span 6}}
.hero-img{width:100%;height:420px;object-fit:cover;position:relative}
@media(min-width:768px){.hero-img{height:560px}}
.hero-img-frame{position:absolute;inset:-1rem;border:1px solid color-mix(in srgb,var(--primary) 30%,transparent);transform:translate(1rem,1rem);display:none}
@media(min-width:768px){.hero-img-frame{display:block}}
.hero-svg{position:absolute;right:-5rem;top:2.5rem;opacity:.4;display:none}
@media(min-width:768px){.hero-svg{display:block}}

/* Social proof */
.social{background:var(--sand);padding:3rem 0}
@media(min-width:768px){.social{padding:4rem 0}}
.social-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0}
@media(min-width:768px){.social-grid{grid-template-columns:repeat(4,1fr)}}
.stat{padding:1.5rem 1rem;text-align:center;border-top:1px solid color-mix(in srgb,var(--primary) 20%,transparent)}
.stat:nth-child(-n+2){border-top:0}
@media(min-width:768px){
  .stat{border-top:0;border-left:1px solid color-mix(in srgb,var(--primary) 20%,transparent)}
  .stat:first-child{border-left:0}
}
.stat-val{font-size:1.875rem;font-weight:600;color:var(--primary)}
@media(min-width:768px){.stat-val{font-size:2.25rem}}
.stat-lab{margin-top:.5rem;font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--muted-foreground)}
@media(min-width:768px){.stat-lab{font-size:13px}}

/* Services */
.bg-sand-light{background:var(--sand-light)}
.section-head{text-align:center;max-width:640px;margin:0 auto}
.section-head p.intro{margin-top:1rem;color:var(--muted-foreground);font-weight:300}
.grid-3{margin-top:4rem;display:grid;gap:2rem}
@media(min-width:768px){.grid-3{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.grid-3{grid-template-columns:repeat(3,1fr)}}
.card{background:var(--card);border:1px solid color-mix(in srgb,var(--primary) 15%,transparent);border-top:3px solid var(--primary);border-radius:.75rem;overflow:hidden;transition:all .3s}
.card:hover{transform:translateY(-6px);box-shadow:0 20px 40px -20px color-mix(in srgb,var(--primary) 25%,transparent)}
.card-img{aspect-ratio:4/3;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.card:hover .card-img img{transform:scale(1.05)}
.card-body{padding:1.75rem}
.card-title{font-family:'Great Vibes',cursive;color:var(--primary);font-size:26px;line-height:1}
.card-desc{margin-top:.75rem;font-size:.875rem;color:var(--muted-foreground);font-weight:300}

/* About */
.about-grid{margin-top:4rem;display:grid;gap:4rem}
@media(min-width:768px){.about-grid{grid-template-columns:repeat(2,1fr);align-items:start}}
.about-text p{font-size:1rem;line-height:1.7;color:color-mix(in srgb,var(--foreground) 80%,transparent);font-weight:300;margin:0 0 1.5rem}
@media(min-width:768px){.about-text p{font-size:1.125rem}}
.about-stat{background:var(--background);border:1px solid var(--hairline);padding:1.75rem;display:flex;align-items:baseline;justify-content:space-between;border-radius:.125rem;margin-bottom:1.25rem}
.about-stat-val{font-size:2.25rem;font-weight:600;color:var(--primary)}
.about-stat-lab{font-size:13px;text-transform:uppercase;letter-spacing:.18em;color:var(--muted-foreground)}
.about-quote{margin-top:5rem;border-top:1px solid color-mix(in srgb,var(--primary) 30%,transparent);padding-top:2.5rem;text-align:center;font-family:'EB Garamond',serif;font-style:italic;font-size:1.25rem;color:color-mix(in srgb,var(--foreground) 70%,transparent);max-width:768px;margin-left:auto;margin-right:auto}
@media(min-width:768px){.about-quote{font-size:1.5rem}}

/* Process */
.process-top{display:grid;gap:4rem}
@media(min-width:1024px){.process-top{grid-template-columns:5fr 7fr;align-items:end}}
.process-img{width:100%;height:16rem;object-fit:cover}
@media(min-width:768px){.process-img{height:20rem}}
.process-steps{margin-top:5rem;display:grid;gap:1px;background:var(--hairline);border:1px solid var(--hairline)}
@media(min-width:768px){.process-steps{grid-template-columns:repeat(5,1fr)}}
.step{background:var(--background);padding:2rem;transition:background .3s}
.step:hover{background:var(--sand-light)}
.step-num{display:flex;height:3rem;width:3rem;align-items:center;justify-content:center;border:1px solid var(--primary);color:var(--primary);font-size:14px;letter-spacing:.15em}
.step-title{margin-top:1.5rem;font-size:1rem;font-weight:500;color:var(--foreground)}
.step-desc{margin-top:.75rem;font-size:.875rem;color:var(--muted-foreground);font-weight:300;line-height:1.7}

/* Why Choose Us */
.why-grid{margin-top:4rem;display:grid;gap:1px;background:var(--hairline);border:1px solid var(--hairline)}
@media(min-width:768px){.why-grid{grid-template-columns:repeat(2,1fr)}}
.why-cell{background:var(--background);padding:2.5rem;transition:background .3s}
@media(min-width:768px){.why-cell{padding:3rem}}
.why-cell:hover{background:var(--cream)}
.why-title{font-family:'Great Vibes',cursive;color:var(--primary);font-size:1.875rem;line-height:1}
@media(min-width:768px){.why-title{font-size:2.25rem}}
.why-desc{margin-top:1.25rem;color:color-mix(in srgb,var(--foreground) 70%,transparent);font-weight:300;line-height:1.7}

/* Gallery */
.gallery-cols{margin-top:4rem;column-count:1;column-gap:2rem}
@media(min-width:640px){.gallery-cols{column-count:2}}
@media(min-width:1024px){.gallery-cols{column-count:3}}
.gallery-item{margin:0 0 2rem;break-inside:avoid}
.gallery-item .frame{overflow:hidden}
.gallery-item img{width:100%;object-fit:cover;transition:transform .7s}
.gallery-item:hover img{transform:scale(1.05)}
.gallery-item figcaption{margin-top:.75rem;font-family:'EB Garamond',serif;font-style:italic;font-size:.875rem;color:var(--muted-foreground)}

/* Events */
.event-card{background:var(--card);border:1px solid color-mix(in srgb,var(--primary) 15%,transparent);border-radius:.75rem;overflow:hidden;transition:transform .3s}
.event-card:hover{transform:translateY(-6px)}
.event-card .img{height:12rem;overflow:hidden}
.event-card .img img{width:100%;height:100%;object-fit:cover}
.event-card .body{padding:1.5rem}
.event-card .title{font-size:1rem;font-weight:500;color:var(--foreground);margin:0}
.event-card .meta{margin-top:.25rem;font-size:13px;color:var(--muted-foreground)}

/* Packages */
.pkg-grid{margin-top:4rem;display:grid;gap:2rem}
@media(min-width:768px){.pkg-grid{grid-template-columns:repeat(3,1fr)}}
.pkg{position:relative;background:var(--background);border-radius:.75rem;padding:2rem;display:flex;flex-direction:column;border:1px solid var(--hairline)}
@media(min-width:768px){.pkg{padding:2.5rem}}
.pkg.highlight{border:2px solid var(--primary)}
@media(min-width:768px){.pkg.highlight{transform:translateY(-1rem)}}
.pkg-badge{position:absolute;top:-.75rem;left:50%;transform:translateX(-50%);background:var(--primary);color:var(--primary-foreground);font-size:10px;letter-spacing:.2em;text-transform:uppercase;padding:.375rem 1rem}
.pkg-title{font-family:'Great Vibes',cursive;color:var(--primary);font-size:32px;line-height:1}
.pkg-tag{margin-top:.5rem;font-size:11px;text-transform:uppercase;letter-spacing:.2em;color:var(--muted-foreground);min-height:1em}
.pkg-price-wrap{margin-top:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--hairline)}
.pkg-price-lab{font-size:.75rem;color:var(--muted-foreground)}
.pkg-price{margin-top:.25rem;font-size:1.5rem;font-weight:500;color:var(--foreground)}
.pkg-feats{list-style:none;margin:1.5rem 0 0;padding:0;flex:1;display:flex;flex-direction:column;gap:.75rem}
.pkg-feats li{display:flex;align-items:flex-start;gap:.75rem;font-size:.875rem;color:color-mix(in srgb,var(--foreground) 80%,transparent);font-weight:300}
.check{width:1rem;height:1rem;color:var(--primary);margin-top:.125rem;flex-shrink:0}
.pkg .btn{margin-top:2rem}

/* Testimonials */
.test-card{position:relative;background:var(--card);border:1px solid var(--hairline);border-radius:.75rem;padding:2rem;display:flex;flex-direction:column}
.stars{color:var(--primary);font-size:1.125rem;letter-spacing:.2em}
.test-quote{margin:1.25rem 0 0;font-family:'EB Garamond',serif;font-style:italic;font-size:15px;color:color-mix(in srgb,var(--foreground) 80%,transparent);line-height:1.7;flex:1}
.test-fig{margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid var(--hairline)}
.test-name{font-size:.875rem;font-weight:500;color:var(--foreground)}
.test-meta{font-size:12px;color:var(--muted-foreground);margin-top:.25rem}
.test-bar{position:absolute;bottom:0;left:0;right:0;height:4px;background:var(--sand);border-bottom-left-radius:.75rem;border-bottom-right-radius:.75rem}

/* Press */
.press-grid{margin-top:3rem;display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
@media(min-width:640px){.press-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:768px){.press-grid{grid-template-columns:repeat(5,1fr)}}
.press-item{border:1px solid var(--hairline);background:color-mix(in srgb,var(--background) 50%,transparent);padding:1.5rem 1.25rem;text-align:center;font-size:12px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted-foreground);border-radius:.125rem}

/* FAQ */
.faq-wrap{max-width:48rem;margin:3rem auto 0;border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline)}
.faq-item{border-bottom:1px solid var(--hairline)}
.faq-item:last-child{border-bottom:0}
.faq-q{display:flex;width:100%;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.25rem 0;text-align:left;transition:color .2s}
.faq-q:hover{color:var(--primary)}
.faq-q span:first-child{font-size:15px;font-weight:500;color:var(--foreground)}
.faq-q .icon{color:var(--primary);flex-shrink:0}
.faq-a{display:grid;grid-template-rows:0fr;opacity:0;transition:all .3s}
.faq-a > div{overflow:hidden}
.faq-item.open .faq-a{grid-template-rows:1fr;opacity:1;padding-bottom:1.25rem}
.faq-a p{margin:0;font-size:.875rem;color:var(--muted-foreground);font-weight:300;line-height:1.7}

/* Instagram */
.ig-grid{margin-top:3rem;display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}
@media(min-width:640px){.ig-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.ig-grid{grid-template-columns:repeat(6,1fr);gap:1rem}}
.ig-tile{position:relative;aspect-ratio:1/1;overflow:hidden;display:block}
.ig-tile img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.ig-tile:hover img{transform:scale(1.1)}
.ig-tile::after{content:"";position:absolute;inset:0;background:transparent;transition:background .3s}
.ig-tile:hover::after{background:color-mix(in srgb,var(--primary) 20%,transparent)}

/* Newsletter */
.newsletter{background:var(--accent);color:var(--accent-foreground);padding:6rem 0}
@media(min-width:768px){.newsletter{padding:8rem 0}}
.newsletter .container{max-width:1024px;text-align:center}
.newsletter .eyebrow{color:var(--primary-foreground)}
.newsletter h2{font-family:'Great Vibes',cursive;font-size:40px;line-height:1.1}
@media(min-width:768px){.newsletter h2{font-size:56px}}
.newsletter h2 span{color:var(--primary-foreground)}
.newsletter p{margin-top:1rem;color:color-mix(in srgb,var(--accent-foreground) 70%,transparent);font-weight:300;max-width:36rem;margin-left:auto;margin-right:auto}
.newsletter form{margin-top:2.5rem;display:flex;flex-direction:column;gap:.75rem;max-width:36rem;margin-left:auto;margin-right:auto}
@media(min-width:640px){.newsletter form{flex-direction:row}}
.newsletter input{flex:1;background:transparent;border:1px solid color-mix(in srgb,var(--accent-foreground) 30%,transparent);padding:1rem 1.25rem;font-size:.875rem;color:var(--accent-foreground)}
.newsletter input::placeholder{color:color-mix(in srgb,var(--accent-foreground) 50%,transparent)}
.newsletter input:focus{outline:none;border-color:var(--primary-glow)}
.newsletter button{background:var(--primary);padding:1rem 2.5rem;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--primary-foreground);transition:all .3s}
.newsletter button:hover{background:var(--primary-glow);color:var(--accent)}

/* Contact */
.contact-grid{margin-top:4rem;display:grid;gap:4rem}
@media(min-width:1024px){.contact-grid{grid-template-columns:7fr 5fr}}
.contact-form{display:grid;gap:1.5rem}
@media(min-width:640px){.contact-form{grid-template-columns:1fr 1fr}}
.contact-form .full{grid-column:1/-1}
.field-label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.2em;color:var(--muted-foreground);margin-bottom:.5rem}
.input{width:100%;background:transparent;border:1px solid var(--hairline);padding:.75rem 1rem;font-size:.875rem;color:var(--foreground);transition:border-color .2s}
.input::placeholder{color:color-mix(in srgb,var(--muted-foreground) 60%,transparent)}
.input:focus{outline:none;border-color:var(--primary)}
.contact-aside{position:relative;padding-left:1.5rem;border-left:1px solid color-mix(in srgb,var(--primary) 30%,transparent)}
.contact-aside .row{margin-bottom:1.5rem}
.contact-aside .row:last-child{margin-bottom:0}
.contact-aside .label{font-size:11px;text-transform:uppercase;letter-spacing:.2em;color:var(--muted-foreground);margin-bottom:.5rem}
.contact-aside a{color:var(--primary)}
.contact-aside a:hover{text-decoration:underline}
.contact-note{font-family:'EB Garamond',serif;font-style:italic;color:color-mix(in srgb,var(--foreground) 70%,transparent);line-height:1.7;padding-top:1rem;border-top:1px solid var(--hairline);margin-top:1.5rem}

/* Footer */
.footer{background:var(--background);border-top:1px solid color-mix(in srgb,var(--primary) 20%,transparent)}
.footer-inner{max-width:1280px;margin:0 auto;padding:4rem 1.5rem}
@media(min-width:768px){.footer-inner{padding:4rem 2.5rem}}
.footer-cols{display:grid;gap:3rem}
@media(min-width:768px){.footer-cols{grid-template-columns:repeat(3,1fr)}}
.footer-logo{height:150px;width:auto;object-fit:contain}
@media(min-width:768px){.footer-logo{height:170px}}
[data-theme="dark"] .footer-logo{filter:invert(1) hue-rotate(180deg)}
.footer-tag{margin-top:1rem;font-size:13px;color:var(--muted-foreground);font-weight:300;max-width:20rem}
.footer-h{font-size:11px;text-transform:uppercase;letter-spacing:.2em;color:var(--muted-foreground);margin-bottom:1.25rem}
.footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.625rem;font-size:13px}
.footer ul a{color:color-mix(in srgb,var(--foreground) 70%,transparent);transition:color .2s}
.footer ul a:hover{color:var(--primary)}
.socials{display:flex;gap:.75rem}
.socials a{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:9999px;border:1px solid var(--primary);color:var(--primary);transition:all .3s}
.socials a:hover{background:var(--primary);color:var(--primary-foreground)}
.footer-email{margin-top:1.25rem;display:inline-block;font-size:13px;color:var(--primary)}
.footer-email:hover{text-decoration:underline}
.footer-bottom{border-top:1px solid var(--hairline)}
.footer-bottom p{max-width:1280px;margin:0 auto;padding:1.5rem;text-align:center;font-size:12px;color:var(--muted-foreground)}

/* Toast */
.toast{position:fixed;bottom:1.5rem;right:1.5rem;background:var(--card);color:var(--foreground);border:1px solid var(--border);padding:1rem 1.25rem;border-radius:.5rem;box-shadow:0 10px 30px -10px rgba(0,0,0,.2);font-size:.875rem;opacity:0;transform:translateY(20px);transition:all .3s;z-index:100;pointer-events:none}
.toast.show{opacity:1;transform:translateY(0)}

/* utilities */
.text-center{text-align:center}
.mt-12{margin-top:3rem}.mt-16{margin-top:4rem}
.divider-cream{border-top:1px solid color-mix(in srgb,var(--primary) 30%,transparent)}
