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

:root{
  --bg: hsl(30,10%,8%);
  --fg: hsl(40,20%,88%);
  --card: hsl(30,8%,12%);
  --primary: hsl(0,72%,50%);
  --primary-fg: hsl(30,10%,8%);
  --muted: hsl(30,10%,50%);
  --border: hsl(30,8%,18%);
  --font-display:'Trajan Pro',Cinzel,'Times New Roman',serif;
  --font-heading:var(--font-display);
  --font-body:'DM Sans',sans-serif;
}

html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--fg);font-family:var(--font-body);-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4,h5,h6,.section-title,.label{font-family:var(--font-display)}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

.container{max-width:80rem;margin:0 auto;padding:0 1.5rem}

/* Nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;background:hsla(30,10%,8%,.8);backdrop-filter:blur(12px);border-bottom:1px solid hsla(30,8%,18%,.5)}
.nav-inner{max-width:80rem;margin:0 auto;padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:inline-flex;align-items:center;line-height:0}
.nav-logo img{height:2.9rem;width:auto;object-fit:contain}
.footer .nav-logo img{height:2.25rem}
.nav-links{display:flex;gap:2rem}
.nav-links a{font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);transition:color .3s}
.nav-links a:hover{color:var(--primary)}
.nav-toggle{display:none;background:none;border:none;color:var(--fg);cursor:pointer}
.mobile-menu{display:none;flex-direction:column;gap:1rem;padding:1.5rem;border-top:1px solid hsla(30,8%,18%,.5);background:hsla(30,10%,8%,.95);backdrop-filter:blur(12px)}
.mobile-menu a{font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);transition:color .3s}
.mobile-menu a:hover{color:var(--primary)}
.mobile-menu.open{display:flex}

@media(max-width:768px){
  .nav-links{display:none}
  .nav-toggle{display:block}
}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 2rem;font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;cursor:pointer;transition:all .3s cubic-bezier(.16,1,.3,1);border:none;font-family:var(--font-body);text-align:center;justify-content:center}
.btn:active{transform:scale(.95)}
.btn-primary{background:var(--primary);color:var(--primary-fg)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 20px hsla(0,72%,50%,.2);opacity:.95}
.btn-outline{background:transparent;border:1px solid var(--primary);color:var(--primary)}
.btn-outline:hover{background:var(--primary);color:var(--primary-fg);transform:translateY(-3px);box-shadow:0 8px 20px hsla(0,72%,50%,.15)}
.btn-nav{display:inline-flex;align-items:center;background:var(--primary);color:var(--primary-fg);padding:.65rem 1.25rem;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;font-family:var(--font-body);font-weight:600;border:none;border-radius:2px;transition:all .3s cubic-bezier(.16,1,.3,1)}
.btn-nav:hover{transform:translateY(-3px);box-shadow:0 8px 15px hsla(0,72%,50%,.25);opacity:.95;color:#fff}
@media(max-width:640px){
  .btn-nav{padding:.5rem .8rem;font-size:.65rem;letter-spacing:.1em;gap:0;}
  .nav-right{gap:1rem !important;}
}

/* Hero */
.hero{position:relative;min-height:calc(100vh - 300px);display:flex;align-items:center;padding-bottom:8rem;padding-top:6.5rem}
@media(max-width:991px){.hero{align-items:flex-start;padding-top:7.5rem}}
.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:hsla(30,10%,8%,.6)}
.hero-content{position:relative;z-index:1;width:100%}
.hero h1{font-size:clamp(1.75rem,3vw,2.75rem);font-weight:400;line-height:1.15;letter-spacing:.02em}
.hero-text-side h1{max-width:24ch}
.hero-sub{margin-top:1.5rem;color:#ffffff;font-size:clamp(1rem,2vw,1.25rem);max-width:100%;line-height:1.6}
.hero-ctas{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem}
.review-badge{display:inline-flex;align-items:center;gap:.9rem;margin-top:1.75rem;padding:.65rem 1.15rem;border:1px solid hsla(30,8%,18%,.65);background:hsla(30,10%,8%,.5);backdrop-filter:blur(8px);border-radius:999px;max-width:100%}
.review-score{font-family:var(--font-display);font-size:1.05rem;line-height:1;color:var(--fg)}
.review-stars{color:#f7c948;letter-spacing:.12em;font-size:.95rem;line-height:1}
.review-count{color:var(--muted);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;line-height:1}
.hero-grid{display:grid;gap:2rem;align-items:center}
@media(min-width:992px){.hero-grid{grid-template-columns:1fr 400px; gap:3rem;}}
@media(max-width:480px){
  .review-badge{gap:.55rem;margin-top:1.25rem;padding:.55rem .75rem}
  .review-score{font-size:.92rem}
  .review-stars{font-size:.8rem;letter-spacing:.08em}
  .review-count{font-size:.64rem;letter-spacing:.03em}
}
.hero-form{background:hsla(30,10%,8%,.8);backdrop-filter:blur(12px);padding:1.5rem 1.5rem;border-radius:16px;border:1px solid hsla(30,8%,18%,.5);box-shadow:0 10px 40px rgba(0,0,0,0.5);}
.hero-form .form-header { margin-bottom: 0.25rem; }
.hero-form .form-header h3 { font-family: var(--font-display); font-size: 1.6rem; font-weight: 400; margin-bottom: 0; color: #fff; line-height: 1.1; }
.hero-form .form-header p { color: var(--muted); font-size: 0.85rem; line-height: 1.4; margin-top: 0.4rem; }
.hero-form .form-group { margin-top: 0.5rem; }
.hero-form .form-group label { font-size: 0.75rem; margin-bottom: 0.2rem; }
.hero-form .form-group input, .hero-form .form-group textarea { background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1); border-radius: 6px; padding: 0.75rem 0.9rem; font-size: 0.95rem; }
.hero-form .form-group input:focus, .hero-form .form-group textarea:focus { border-color: var(--primary); }
.hero-form #contactStatus { margin: 0; min-height: 0.5rem; }
.hero-form button[type="submit"] { width: 100%; justify-content: center; border-radius: 6px; margin-top: 0.5rem; }
@media(max-width:768px){
  .hero-form { padding: 1.75rem; }
  .hero-form .form-header h3 { font-size: 1.75rem; }
  .hero-form .form-header p { font-size: 0.9rem; }
  .hero-form .form-group input, .hero-form .form-group textarea { padding: 0.75rem 1rem; font-size: 1rem; }
}

/* Sections */
.section{padding:6rem 0}
.section-alt{background:var(--card)}
.label{font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--primary)}
.section-title{font-size:clamp(2rem,4vw,3rem);font-weight:400;margin-top:.75rem;line-height:1.1}
.text-muted{color:var(--muted);line-height:1.7;margin-top:1rem;max-width:32rem}
.text-xs{font-size:.75rem}
.link{color:var(--primary);transition:opacity .3s}
.link:hover{text-decoration:underline}

/* Gallery */
.gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4px;margin-top:4rem;width:100%}
@media(min-width:768px){.gallery-grid{grid-template-columns:repeat(3,1fr)}}
.gallery-item{position:relative;overflow:hidden;display:block;border-radius:0;transition:transform .4s cubic-bezier(.16,1,.3,1)}
.gallery-item img{width:100%;aspect-ratio:3/4;object-fit:cover;transition:transform .5s}
.gallery-item:hover img{transform:scale(1.05)}
.gallery-overlay{position:absolute;inset:0;background:transparent;transition:background .3s;display:flex;align-items:flex-end;padding:1rem}
.gallery-item:hover .gallery-overlay{background:hsla(30,10%,8%,.4)}
.gallery-overlay span{font-family:var(--font-display);font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;opacity:0;transform:translateY(.5rem);transition:all .3s}
.gallery-item:hover .gallery-overlay span{opacity:1;transform:translateY(0)}

/* About */
.about-grid{display:grid;gap:4rem;align-items:center}
@media(min-width:768px){.about-grid{grid-template-columns:1fr 1fr}}
.about-stats{display:flex;align-items:center;justify-content:center}
.stats-box{border:1px solid hsla(30,8%,18%,.5);padding:3rem;text-align:center;width:100%;max-width:20rem;aspect-ratio:1}
.stat-number{font-family:var(--font-display);font-size:clamp(3rem,5vw,4.5rem);font-weight:400;color:var(--primary);line-height:1}
.stat-label{font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-top:.5rem}
.stat-divider{width:3rem;height:1px;background:var(--border);margin:1.5rem auto}

/* Styles */
.styles-grid{display:grid;gap:2rem;margin-top:4rem}
@media(min-width:768px){.styles-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.styles-grid{grid-template-columns:repeat(3,1fr)}}
.style-card{border:1px solid hsla(30,8%,18%,.5);padding:2rem;transition:border-color .3s}
.style-card:hover{border-color:hsla(0,72%,50%,.3)}
.style-card h3{font-size:1.5rem;font-weight:400}
.style-card p{color:var(--muted);font-size:.875rem;margin-top:1rem;line-height:1.6}



/* Contact */
.contact-grid{display:grid;gap:2rem;grid-template-columns:1fr;justify-items:center}
.contact-copy{max-width:40rem;margin:0 auto}
.contact-info{margin-top:2rem;display:flex;flex-direction:column;gap:1rem}
.contact-info p{font-size:.875rem}
.contact-form{display:flex;flex-direction:column;gap:0.75rem}
.form-group{position:relative}
.form-group label{display:block;font-size:.75rem;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem;font-weight:500}
.form-group input,.form-group textarea{width:100%;background:rgba(255,255,255,0.03);border:1px solid hsla(30,8%,18%,.8);border-radius:8px;padding:1rem 1.2rem;color:var(--fg);font-family:var(--font-body);font-size:1rem;outline:none;transition:all .3s ease}
.form-group input::placeholder,.form-group textarea::placeholder{color:hsla(30,10%,50%,.5)}
.form-group input:focus,.form-group textarea:focus{border-color:var(--primary);background:rgba(255,255,255,0.06);box-shadow:0 0 0 4px hsla(0,72%,50%,.1)}

/* Checkboxes */
.form-options{display:flex;flex-direction:column;gap:0.5rem;margin-top:0.25rem}
.checkbox-container{display:flex;align-items:flex-start;gap:0.85rem;cursor:pointer;position:relative;user-select:none;padding:0.25rem 0}
.checkbox-container input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}
.checkmark{height:1.2rem;width:1.2rem;background-color:rgba(255,255,255,0.05);border:1px solid hsla(30,8%,18%,.8);border-radius:4px;flex-shrink:0;transition:all .2s ease;margin-top:0.1rem}
.checkbox-container:hover input ~ .checkmark{background-color:rgba(255,255,255,0.08)}
.checkbox-container input:checked ~ .checkmark{background-color:var(--primary);border-color:var(--primary)}
.checkmark:after{content:"";position:absolute;display:none}
.checkbox-container input:checked ~ .checkmark:after{display:block}
.checkbox-container .checkmark:after{left:7px;top:3px;width:5px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}
.checkbox-text{font-size:0.85rem;color:var(--muted);line-height:1.4;transition:color .2s}
.checkbox-container:hover .checkbox-text{color:var(--fg)}

/* Error Messages */
.error-msg{display:block;color:var(--primary);font-size:0.75rem;margin-top:0.4rem;min-height:1em;opacity:0;transition:opacity .2s}
.error-msg:not(:empty){opacity:1}
.form-group.has-error input{border-color:var(--primary)}

/* CAPTCHA */
.captcha-wrapper{margin-top:0.5rem}
.g-recaptcha{transform:scale(0.85);transform-origin:0 0}

/* Submit Button & Loader */
.btn-primary{position:relative;overflow:hidden}
.loader{display:none;width:1.2rem;height:1.2rem;border:2px solid rgba(255,255,255,0.3);border-radius:50%;border-top-color:#fff;animation:spin 0.8s linear infinite;position:absolute}
@keyframes spin{to{transform:rotate(360deg)}}
.btn.loading .btn-text{visibility:hidden;opacity:0}
.btn.loading .loader{display:block}

.form-status{min-height:1.25rem;font-size:.85rem;line-height:1.4;color:var(--muted);margin-top:0.5rem;text-align:center}
.form-status.error{color:var(--primary)}
.form-status.success{color:hsl(130,45%,65%);background:hsla(130,45%,65%,0.1);padding:0.75rem;border-radius:6px}

/* FAQ Accordion */
.faq-accordion{margin-top:3rem;display:flex;flex-direction:column;gap:1rem}
.faq-item{border:1px solid hsla(30,8%,18%,.5);background:var(--card);border-radius:8px;overflow:hidden;transition:border-color .3s}
.faq-item:hover{border-color:hsla(0,72%,50%,.3)}
.faq-question{width:100%;text-align:left;background:none;border:none;padding:1.5rem;color:var(--fg);font-size:1.1rem;font-family:var(--font-heading);cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.faq-icon{color:var(--primary);font-size:1.5rem;line-height:1;transition:transform .3s}
.faq-answer{padding:0 1.5rem;max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease,opacity .3s ease;opacity:0}
.faq-item.active .faq-answer{padding:0 1.5rem 1.5rem;opacity:1;max-height:500px}
.faq-item.active .faq-icon{transform:rotate(45deg)}
.faq-answer p{color:var(--muted);font-size:.95rem;line-height:1.7;margin-bottom:1rem}
.faq-answer ul{padding-left:1.5rem;color:var(--muted);font-size:.95rem;margin-bottom:.5rem;list-style:disc;}
.faq-answer li{margin-bottom:.5rem;line-height:1.5}

/* Footer */
.footer{padding:3rem 0;border-top:1px solid hsla(30,8%,18%,.5)}
.footer-inner{display:flex;flex-direction:column;align-items:center;gap:1rem}
@media(min-width:768px){.footer-inner{flex-direction:row;justify-content:space-between}}
.footer-links{display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap;justify-content:center}
@media(min-width:768px){.footer-links{justify-content:flex-end}}
.footer-link{font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);transition:color .3s}
.footer-link:hover{color:var(--primary)}

/* Animations */
@keyframes reveal-up{
  from{opacity:0;transform:translateY(20px);filter:blur(4px)}
  to{opacity:1;transform:translateY(0);filter:blur(0)}
}
.reveal{opacity:0;animation:reveal-up .7s cubic-bezier(.16,1,.3,1) forwards}
.reveal-delay-1{animation-delay:.1s}
.reveal-delay-2{animation-delay:.2s}
.reveal-delay-3{animation-delay:.3s}

.scroll-reveal, .prose p, .prose h2, .prose h3, .prose ul, .prose blockquote, .policy-content p, .policy-content h2, .policy-content h3{opacity:0;transform:translateY(20px);filter:blur(4px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1),filter .7s cubic-bezier(.16,1,.3,1)}
.scroll-reveal.visible, .prose p.visible, .prose h2.visible, .prose h3.visible, .prose ul.visible, .prose blockquote.visible, .policy-content p.visible, .policy-content h2.visible, .policy-content h3.visible{opacity:1;transform:translateY(0);filter:blur(0)}
