*{margin:0;padding:0;box-sizing:border-box}
:root{--gold:#D4AF37;--gold2:#F5C842;--dark:#0a0a0a;--dark2:#111;--dark3:#1a1a1a;--text:#e8e8e8;--muted:#888}
html{scroll-behavior:smooth}
body{background:var(--dark);color:var(--text);font-family:'Segoe UI',system-ui,sans-serif;overflow-x:hidden}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--dark)}
::-webkit-scrollbar-thumb{background:var(--gold);border-radius:3px}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:18px 5%;display:flex;align-items:center;justify-content:space-between;background:rgba(10,10,10,.92);backdrop-filter:blur(12px);border-bottom:1px solid rgba(212,175,55,.15)}
.logo{font-size:1.4rem;font-weight:800;letter-spacing:.08em;color:var(--gold);text-decoration:none}
.logo span{color:var(--text)}
.nav-links{display:flex;gap:2rem;list-style:none;align-items:center}
.nav-links a{color:var(--muted);text-decoration:none;font-size:.9rem;letter-spacing:.05em;transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--gold)}
.nav-links a.book-link{color:var(--gold);border:1px solid rgba(212,175,55,.4);padding:.3rem .9rem;border-radius:50px;font-size:.85rem}
.nav-links a.book-link:hover{background:rgba(212,175,55,.1)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.hamburger span{width:24px;height:2px;background:var(--gold);display:block;transition:.3s}
@media(max-width:768px){.nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:rgba(10,10,10,.98);flex-direction:column;padding:2rem 5%;gap:1.5rem;border-bottom:1px solid rgba(212,175,55,.2)}.nav-links.open{display:flex}.hamburger{display:flex}}

/* PAGE HERO (subpages) */
.page-hero{padding:140px 5% 80px;text-align:center;background:radial-gradient(ellipse 80% 60% at 50% 40%,rgba(212,175,55,.07) 0%,transparent 70%);border-bottom:1px solid rgba(212,175,55,.1)}
.page-hero .page-tag{font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem}
.page-hero h1{font-size:clamp(2.5rem,6vw,5rem);font-weight:900;line-height:1.05;margin-bottom:1rem}
.page-hero h1 .accent{color:var(--gold)}
.page-hero p{color:var(--muted);font-size:1.05rem;max-width:560px;margin:0 auto;line-height:1.8}
.breadcrumb{font-size:.8rem;color:var(--muted);margin-bottom:1rem}
.breadcrumb a{color:var(--gold);text-decoration:none}
.breadcrumb a:hover{text-decoration:underline}

/* SECTIONS */
section{padding:100px 5%}
.container{max-width:1200px;margin:0 auto}
.section-tag{font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.75rem}
.section-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:800;margin-bottom:1rem;line-height:1.1}
.section-title .accent{color:var(--gold)}
.section-desc{color:var(--muted);font-size:1.05rem;line-height:1.8;max-width:600px;margin-bottom:3.5rem}

/* BUTTONS */
.btn{padding:.85rem 2.2rem;border-radius:4px;font-size:.95rem;font-weight:600;letter-spacing:.05em;cursor:pointer;transition:.25s;text-decoration:none;display:inline-block}
.btn-gold{background:var(--gold);color:#000}
.btn-gold:hover{background:var(--gold2);transform:translateY(-2px);box-shadow:0 8px 30px rgba(212,175,55,.35)}
.btn-outline{background:transparent;color:var(--gold);border:1.5px solid var(--gold)}
.btn-outline:hover{background:rgba(212,175,55,.1);transform:translateY(-2px)}

/* WAVE */
.wave-divider{height:80px;overflow:hidden;background:var(--dark)}
.wave-divider svg{width:100%;height:100%;display:block}

/* ABOUT */
#about,section.about-section{background:var(--dark2)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
@media(max-width:768px){.about-grid{grid-template-columns:1fr}}
.about-stats{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:2rem}
.stat-card{background:var(--dark3);border:1px solid rgba(212,175,55,.15);border-radius:8px;padding:1.5rem;transition:.2s}
.stat-card:hover{border-color:rgba(212,175,55,.4);transform:translateY(-3px)}
.stat-num{font-size:2.5rem;font-weight:900;color:var(--gold);line-height:1}
.stat-label{font-size:.85rem;color:var(--muted);margin-top:.4rem}
.about-visual{background:var(--dark3);border:1px solid rgba(212,175,55,.2);border-radius:12px;padding:3rem;text-align:center;position:relative;overflow:hidden}
.about-visual::before{content:'Z.I.G';position:absolute;font-size:8rem;font-weight:900;color:rgba(212,175,55,.05);top:50%;left:50%;transform:translate(-50%,-50%);white-space:nowrap;pointer-events:none}
.about-visual-inner{position:relative;z-index:1}
.ab-tag{display:inline-block;padding:.35rem .9rem;background:rgba(212,175,55,.1);border:1px solid rgba(212,175,55,.3);border-radius:50px;color:var(--gold);font-size:.8rem;margin:.3rem}

/* SERVICES */
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}
.service-card{background:var(--dark2);border:1px solid rgba(212,175,55,.1);border-radius:10px;padding:2rem;transition:.25s;position:relative;overflow:hidden}
.service-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(212,175,55,.05),transparent);opacity:0;transition:.3s;pointer-events:none}
.service-card:hover{border-color:rgba(212,175,55,.4);transform:translateY(-5px)}
.service-card:hover::before{opacity:1}
.service-icon{font-size:2rem;margin-bottom:1rem}
.service-card h3{font-size:1.2rem;font-weight:700;color:var(--text);margin-bottom:.75rem}
.service-card p{color:var(--muted);font-size:.9rem;line-height:1.7}

/* TEAM */
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2rem}
.team-card{text-align:center;transition:.2s}
.team-card:hover .team-img{border-color:var(--gold);box-shadow:0 0 30px rgba(212,175,55,.25)}
.team-img{width:120px;height:120px;border-radius:50%;border:2px solid rgba(212,175,55,.3);margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:900;background:var(--dark2);color:var(--gold);transition:.25s}
.team-card h3{font-weight:700;margin-bottom:.3rem}
.team-card .role{color:var(--gold);font-size:.85rem;margin-bottom:.5rem}
.team-card .bio{color:var(--muted);font-size:.85rem;line-height:1.6}

/* TESTIMONIALS */
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}
.testimonial-card{background:var(--dark3);border:1px solid rgba(212,175,55,.15);border-radius:10px;padding:2rem;transition:.2s}
.testimonial-card:hover{border-color:rgba(212,175,55,.35)}
.stars{color:var(--gold);font-size:1.1rem;margin-bottom:1rem;letter-spacing:.1em}
.testimonial-card blockquote{color:var(--text);font-size:.95rem;line-height:1.7;font-style:italic;margin-bottom:1.2rem}
.t-author{display:flex;align-items:center;gap:.75rem}
.t-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--gold),#8B6914);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;color:#000;flex-shrink:0}
.t-name{font-weight:600;font-size:.9rem}
.t-role{color:var(--muted);font-size:.8rem}

/* FAQ */
.faq-list{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:1rem}
.faq-item{background:var(--dark3);border:1px solid rgba(212,175,55,.1);border-radius:8px;overflow:hidden}
.faq-q{width:100%;background:none;border:none;color:var(--text);font-size:1rem;font-weight:600;padding:1.2rem 1.5rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;text-align:left;transition:.2s}
.faq-q:hover{color:var(--gold)}
.faq-q .arrow{color:var(--gold);font-size:1.2rem;transition:.3s;flex-shrink:0}
.faq-q.open .arrow{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:.35s ease}
.faq-a.open{max-height:300px}
.faq-a p{padding:0 1.5rem 1.2rem;color:var(--muted);font-size:.9rem;line-height:1.7}

/* BOOKING CARDS */
.booking-section{background:var(--dark);position:relative;overflow:hidden;padding:100px 5%}
.booking-section::before{content:'';position:absolute;top:-200px;left:-200px;width:700px;height:700px;background:radial-gradient(circle,rgba(212,175,55,.06) 0%,transparent 65%);pointer-events:none;animation:floatGlow 8s ease-in-out infinite}
.booking-section::after{content:'';position:absolute;bottom:-200px;right:-200px;width:600px;height:600px;background:radial-gradient(circle,rgba(212,175,55,.04) 0%,transparent 65%);pointer-events:none;animation:floatGlow 10s ease-in-out infinite reverse}
@keyframes floatGlow{0%,100%{transform:translate(0,0)}50%{transform:translate(30px,30px)}}
.booking-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;position:relative;z-index:1}
.booking-card{background:rgba(17,17,17,.8);border:1px solid rgba(212,175,55,.15);border-radius:16px;padding:2.5rem;position:relative;overflow:hidden;transition:.35s cubic-bezier(.25,.46,.45,.94);backdrop-filter:blur(8px)}
.booking-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(212,175,55,.08) 0%,transparent 60%);opacity:0;transition:.35s;pointer-events:none}
.booking-card:hover{border-color:rgba(212,175,55,.5);transform:translateY(-8px);box-shadow:0 20px 60px rgba(212,175,55,.12)}
.booking-card:hover::before{opacity:1}
.bk-icon{font-size:3rem;margin-bottom:1.25rem;display:block;filter:drop-shadow(0 0 12px rgba(212,175,55,.4))}
.bk-badge{display:inline-block;padding:.25rem .75rem;background:rgba(212,175,55,.1);border:1px solid rgba(212,175,55,.25);border-radius:50px;font-size:.72rem;letter-spacing:.12em;color:var(--gold);text-transform:uppercase;margin-bottom:1rem}
.booking-card h3{font-size:1.5rem;font-weight:800;color:var(--text);margin-bottom:.75rem;line-height:1.2}
.booking-card p{color:var(--muted);font-size:.9rem;line-height:1.7;margin-bottom:1.5rem}
.bk-features{list-style:none;margin-bottom:2rem}
.bk-features li{color:var(--muted);font-size:.875rem;padding:.4rem 0;display:flex;align-items:center;gap:.6rem;border-bottom:1px solid rgba(255,255,255,.04)}
.bk-features li::before{content:'✓';color:var(--gold);font-weight:700;font-size:.85rem;flex-shrink:0}
.bk-price{font-size:1.75rem;font-weight:900;color:var(--gold);margin-bottom:1.5rem;line-height:1}
.bk-price span{font-size:.9rem;font-weight:400;color:var(--muted)}
.btn-book{width:100%;padding:1rem;background:linear-gradient(135deg,var(--gold),#b8962e);color:#000;border:none;border-radius:8px;font-size:1rem;font-weight:700;letter-spacing:.06em;cursor:pointer;transition:.25s;position:relative;overflow:hidden}
.btn-book:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(212,175,55,.35)}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:.3s ease;backdrop-filter:blur(6px)}
.modal-overlay.active{opacity:1;visibility:visible}
.modal{background:linear-gradient(160deg,rgba(22,22,22,.98) 0%,rgba(14,14,14,.98) 100%);border:1px solid rgba(212,175,55,.2);border-radius:20px;width:100%;max-width:680px;max-height:92vh;overflow-y:auto;position:relative;transform:translateY(30px) scale(.96);transition:.35s cubic-bezier(.34,1.56,.64,1);box-shadow:0 40px 100px rgba(0,0,0,.7)}
.modal-overlay.active .modal{transform:translateY(0) scale(1)}
.modal::-webkit-scrollbar{width:4px}
.modal::-webkit-scrollbar-thumb{background:rgba(212,175,55,.3);border-radius:2px}
.modal-close{position:absolute;top:1.2rem;right:1.2rem;width:36px;height:36px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:50%;color:var(--muted);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s;z-index:10}
.modal-close:hover{background:rgba(212,175,55,.15);color:var(--gold);border-color:rgba(212,175,55,.3)}
.modal-header{padding:2rem 2rem 1.25rem;border-bottom:1px solid rgba(212,175,55,.1)}
.modal-header .modal-icon{font-size:2.5rem;display:block;margin-bottom:.75rem}
.modal-header h2{font-size:1.7rem;font-weight:800;color:var(--text);margin-bottom:.3rem}
.modal-header p{color:var(--muted);font-size:.9rem}
.step-indicator{display:flex;align-items:center;gap:.5rem;padding:1.25rem 2rem;border-bottom:1px solid rgba(212,175,55,.08)}
.step-dot{width:28px;height:28px;border-radius:50%;border:2px solid rgba(212,175,55,.25);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:var(--muted);transition:.3s;flex-shrink:0}
.step-dot.active{border-color:var(--gold);color:var(--gold);background:rgba(212,175,55,.1);box-shadow:0 0 12px rgba(212,175,55,.25)}
.step-dot.done{border-color:var(--gold);background:var(--gold);color:#000}
.step-line{flex:1;height:1px;background:rgba(212,175,55,.15)}
.step-line.done{background:var(--gold)}
.modal-body{padding:2rem}
.modal-step{display:none}
.modal-step.active{display:block}
.datepicker-label{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:.75rem;display:block}
.calendar{background:rgba(255,255,255,.03);border:1px solid rgba(212,175,55,.12);border-radius:12px;overflow:hidden;margin-bottom:1.5rem}
.cal-header{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1rem;background:rgba(212,175,55,.06);border-bottom:1px solid rgba(212,175,55,.1)}
.cal-header h4{font-size:1rem;font-weight:700;color:var(--text)}
.cal-nav{background:none;border:1px solid rgba(212,175,55,.2);border-radius:6px;color:var(--gold);width:30px;height:30px;cursor:pointer;font-size:.9rem;transition:.2s;display:flex;align-items:center;justify-content:center}
.cal-nav:hover{background:rgba(212,175,55,.1)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);padding:.5rem;gap:.25rem}
.cal-day-header{text-align:center;font-size:.72rem;font-weight:700;color:var(--muted);padding:.4rem 0;text-transform:uppercase;letter-spacing:.05em}
.cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:8px;font-size:.85rem;cursor:pointer;transition:.2s;border:1px solid transparent;position:relative}
.cal-day:not(.empty):not(.past):hover{background:rgba(212,175,55,.12);border-color:rgba(212,175,55,.3);color:var(--gold)}
.cal-day.selected{background:var(--gold);color:#000;font-weight:700;box-shadow:0 4px 14px rgba(212,175,55,.4)}
.cal-day.today{color:var(--gold);font-weight:700}
.cal-day.today::after{content:'';position:absolute;bottom:4px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--gold)}
.cal-day.past{color:rgba(255,255,255,.2);cursor:not-allowed}
.cal-day.empty{cursor:default}
.time-slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:.6rem;margin-bottom:1.5rem}
.time-slot{padding:.65rem .5rem;border:1px solid rgba(212,175,55,.15);border-radius:8px;text-align:center;font-size:.85rem;color:var(--muted);cursor:pointer;transition:.2s;background:rgba(255,255,255,.02)}
.time-slot:hover:not(.unavailable){border-color:rgba(212,175,55,.4);color:var(--gold);background:rgba(212,175,55,.06)}
.time-slot.selected{background:rgba(212,175,55,.15);border-color:var(--gold);color:var(--gold);font-weight:700}
.time-slot.unavailable{opacity:.3;cursor:not-allowed;text-decoration:line-through}
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem}
.form-group input,.form-group textarea,.form-group select{width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(212,175,55,.2);border-radius:8px;padding:.85rem 1rem;color:var(--text);font-size:.95rem;font-family:inherit;transition:.2s;outline:none}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--gold);background:rgba(212,175,55,.04);box-shadow:0 0 0 3px rgba(212,175,55,.1)}
.form-group textarea{min-height:90px;resize:vertical}
.form-group select option{background:var(--dark2);color:var(--text)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:500px){.form-row{grid-template-columns:1fr}}
.session-options{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem;margin-bottom:1.5rem}
.session-option{border:1px solid rgba(212,175,55,.15);border-radius:10px;padding:1rem .75rem;text-align:center;cursor:pointer;transition:.25s;background:rgba(255,255,255,.02)}
.session-option:hover{border-color:rgba(212,175,55,.4);background:rgba(212,175,55,.06)}
.session-option.selected{border-color:var(--gold);background:rgba(212,175,55,.12);box-shadow:0 0 20px rgba(212,175,55,.15)}
.session-option .so-icon{font-size:1.75rem;display:block;margin-bottom:.5rem}
.session-option .so-label{font-size:.82rem;font-weight:600;color:var(--text)}
.session-option .so-price{font-size:.75rem;color:var(--gold);margin-top:.25rem}
.booking-summary{background:rgba(212,175,55,.04);border:1px solid rgba(212,175,55,.15);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}
.booking-summary h4{color:var(--gold);font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:1rem}
.summary-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.05);font-size:.9rem}
.summary-row:last-child{border-bottom:none;font-weight:700;color:var(--gold)}
.summary-row .sr-label{color:var(--muted)}
.modal-footer{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-top:1px solid rgba(212,175,55,.1);gap:1rem}
.btn-modal-prev{padding:.8rem 1.5rem;background:none;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:var(--muted);font-size:.9rem;cursor:pointer;transition:.2s}
.btn-modal-prev:hover{border-color:rgba(255,255,255,.3);color:var(--text)}
.btn-modal-next{padding:.8rem 2rem;background:linear-gradient(135deg,var(--gold),#b8962e);color:#000;border:none;border-radius:8px;font-size:.9rem;font-weight:700;cursor:pointer;transition:.25s;flex:1;max-width:220px}
.btn-modal-next:hover{box-shadow:0 8px 25px rgba(212,175,55,.35);transform:translateY(-1px)}
.success-screen{text-align:center;padding:3rem 2rem}
.success-anim{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,rgba(212,175,55,.2),rgba(212,175,55,.05));border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;font-size:2.5rem;animation:successPop .5s cubic-bezier(.34,1.56,.64,1) both;box-shadow:0 0 40px rgba(212,175,55,.3)}
@keyframes successPop{0%{transform:scale(0);opacity:0}100%{transform:scale(1);opacity:1}}
.success-screen h3{font-size:1.8rem;font-weight:800;color:var(--text);margin-bottom:.75rem}
.success-screen p{color:var(--muted);font-size:.95rem;line-height:1.7;max-width:400px;margin:0 auto 1.5rem}
.success-details{background:rgba(212,175,55,.05);border:1px solid rgba(212,175,55,.15);border-radius:12px;padding:1.25rem;display:inline-block;min-width:280px;text-align:left;margin-bottom:2rem}
.sd-row{display:flex;justify-content:space-between;padding:.4rem 0;font-size:.875rem;border-bottom:1px solid rgba(255,255,255,.05)}
.sd-row:last-child{border-bottom:none}
.sd-row .sd-label{color:var(--muted)}
.sd-row .sd-val{color:var(--text);font-weight:600}

/* CONTACT */
.contact-inner{background:linear-gradient(135deg,var(--dark2),var(--dark3));border:1px solid rgba(212,175,55,.2);border-radius:16px;padding:4rem;text-align:center;max-width:700px;margin:0 auto;position:relative;overflow:hidden}
.contact-inner::before{content:'';position:absolute;top:-100px;left:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(212,175,55,.08),transparent 70%);pointer-events:none}
.contact-email{font-size:1.3rem;color:var(--gold);margin:2rem 0;font-weight:600}
.contact-email a{color:inherit;text-decoration:none;border-bottom:1px solid rgba(212,175,55,.3);padding-bottom:2px}
.contact-email a:hover{border-bottom-color:var(--gold)}
.social-links{display:flex;gap:1rem;justify-content:center;margin-top:2rem;flex-wrap:wrap}
.social-link{padding:.65rem 1.5rem;border:1px solid rgba(212,175,55,.3);border-radius:50px;color:var(--muted);font-size:.85rem;text-decoration:none;transition:.2s}
.social-link:hover{border-color:var(--gold);color:var(--gold);background:rgba(212,175,55,.08)}

/* CONTACT FORM */
.contact-form{max-width:700px;margin:3rem auto 0}
.contact-form .form-group input,.contact-form .form-group textarea,.contact-form .form-group select{background:rgba(255,255,255,.04);border:1px solid rgba(212,175,55,.2);border-radius:8px;padding:.85rem 1rem;color:var(--text);font-size:.95rem;font-family:inherit;transition:.2s;outline:none;width:100%}
.contact-form .form-group input:focus,.contact-form .form-group textarea:focus{border-color:var(--gold);background:rgba(212,175,55,.04);box-shadow:0 0 0 3px rgba(212,175,55,.1)}
.contact-form .form-group label{display:block;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem}

/* FOOTER */
footer{background:var(--dark2);border-top:1px solid rgba(212,175,55,.1);padding:3rem 5%;text-align:center}
.footer-logo{font-size:1.5rem;font-weight:900;color:var(--gold);margin-bottom:.75rem;letter-spacing:.08em}
.footer-copy{color:var(--muted);font-size:.85rem}
.footer-links{display:flex;gap:1.5rem;justify-content:center;margin:1rem 0;flex-wrap:wrap}
.footer-links a{color:var(--muted);text-decoration:none;font-size:.85rem;transition:.2s}
.footer-links a:hover{color:var(--gold)}

/* COOKIE */
.cookie-banner{position:fixed;bottom:20px;left:20px;max-width:500px;background:rgba(17,17,17,.97);border:1px solid rgba(212,175,55,.25);border-radius:12px;padding:1.5rem;z-index:999;display:flex;gap:1rem;align-items:center;flex-wrap:wrap;backdrop-filter:blur(10px)}
.cookie-banner p{flex:1;font-size:.85rem;color:var(--muted);min-width:200px}
.cookie-banner p a{color:var(--gold)}
.cookie-btns{display:flex;gap:.75rem}
.cookie-btn{padding:.55rem 1.2rem;border-radius:4px;font-size:.85rem;cursor:pointer;border:none;font-weight:600}
.cookie-accept{background:var(--gold);color:#000}
.cookie-accept:hover{background:var(--gold2)}
.cookie-decline{background:transparent;color:var(--muted);border:1px solid rgba(255,255,255,.15)}

/* SCROLL REVEAL */
.rv,.rl,.rr{opacity:0;transition:opacity .7s ease,transform .7s ease}
.rv{transform:translateY(40px)}
.rl{transform:translateX(-40px)}
.rr{transform:translateX(40px)}
.rv.visible,.rl.visible,.rr.visible{opacity:1;transform:none}

/* CTA BANNER */
.cta-banner{background:linear-gradient(135deg,rgba(212,175,55,.12),rgba(212,175,55,.04));border:1px solid rgba(212,175,55,.2);border-radius:16px;padding:4rem;text-align:center;margin-top:4rem}
.cta-banner h3{font-size:2rem;font-weight:800;margin-bottom:1rem}
.cta-banner p{color:var(--muted);margin-bottom:2rem;font-size:1.05rem}

/* CANVAS */
#particleCanvas{position:absolute;inset:0;pointer-events:none;z-index:0}
#home>*:not(canvas){position:relative;z-index:1}

/* LEGAL PAGES */
.legal-content{max-width:800px;margin:0 auto;line-height:1.8}
.legal-content h2{font-size:1.5rem;font-weight:700;color:var(--gold);margin:2.5rem 0 1rem}
.legal-content h3{font-size:1.1rem;font-weight:600;margin:1.5rem 0 .5rem}
.legal-content p{color:var(--muted);margin-bottom:1rem}
.legal-content a{color:var(--gold)}

/* ===== LOGO IN NAV ===== */
.logo img { height: 44px; width: auto; display: block; filter: drop-shadow(0 0 8px rgba(212,175,55,.35)); transition: filter .3s; }
.logo img:hover { filter: drop-shadow(0 0 14px rgba(212,175,55,.6)); }
.logo { display: flex; align-items: center; }

/* ===== CURSOR GLOW ===== */
#cursor-glow {
  position: fixed; pointer-events: none; z-index: 9999;
  width: 260px; height: 260px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(212,175,55,.09) 0%, transparent 70%);
  transform: translate(-50%, -50%);
  transition: opacity .3s;
  mix-blend-mode: screen;
}

/* ===== MAGNETIC BUTTONS ===== */
.btn-gold, .btn-outline, .btn-book, .book-link {
  transition: background .2s, color .2s, transform .2s, box-shadow .2s !important;
}

/* ===== PAGE TRANSITIONS ===== */
body { animation: fadeIn .45s ease; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }

/* ===== HERO GLITCH TEXT ===== */
.hero-title .gold::after {
  content: attr(data-text);
  position: absolute; left: 2px; top: 2px;
  color: rgba(212,175,55,.3);
  animation: glitch 3s infinite;
}

/* ===== FLOATING PARTICLES GLOBAL ===== */
.float-particle {
  position: fixed; pointer-events: none; z-index: 0;
  width: 3px; height: 3px; border-radius: 50%;
  background: rgba(212,175,55, .45);
  animation: floatUp linear infinite;
}
@keyframes floatUp {
  0%   { transform: translateY(0) translateX(0); opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: .4; }
  100% { transform: translateY(-100vh) translateX(var(--dx)); opacity: 0; }
}

/* ===== CARD SHIMMER ===== */
.service-card::after, .booking-card::after, .stat-card::after, .service-card::before, .booking-card::before {
  content: '';
  position: absolute; top: 0; left: -100%;
  width: 60%; height: 100%;
  background: linear-gradient(110deg, transparent, rgba(212,175,55,.07), transparent);
  transition: left .55s ease;
  pointer-events: none;
}
.service-card, .booking-card, .stat-card { overflow: hidden; position: relative; }
.service-card:hover::after, .booking-card:hover::after, .stat-card:hover::after { left: 160%; }

/* ===== NAV LINK UNDERLINE SLIDE ===== */
.nav-links a:not(.book-link) { position: relative; }
.nav-links a:not(.book-link)::after {
  content: ''; position: absolute; left: 0; bottom: -3px;
  width: 0; height: 1px; background: var(--gold); transition: width .25s;
}
.nav-links a:not(.book-link):hover::after,
.nav-links a:not(.book-link).active::after { width: 100%; }

/* ===== COUNT-UP NUMBERS ===== */
.stat-num { transition: color .3s; }

/* ===== TEAM CARDS GLOW ===== */
.team-card:hover .team-img {
  box-shadow: 0 0 30px rgba(212,175,55,.4), 0 0 60px rgba(212,175,55,.15);
  border-color: var(--gold);
}
.team-img { transition: box-shadow .3s, border-color .3s; }

/* ===== SECTION DIVIDER GOLD LINE ===== */
.gold-divider {
  height: 1px;
  background: linear-gradient(to right, transparent, rgba(212,175,55,.5), transparent);
  margin: 0;
}

/* ===== PARALLAX HERO ===== */
.parallax-bg {
  position: absolute; inset: -40px;
  background: radial-gradient(ellipse 80% 60% at 50% 40%, rgba(212,175,55,.08) 0%, transparent 70%);
  will-change: transform;
}

/* ===================================================
   MOBILE RESPONSIVE  – max-width: 768px
   =================================================== */
@media(max-width:768px){

  /* Sections */
  section { padding: 60px 5%; }
  .booking-section { padding: 60px 5%; }

  /* Page hero (subpages) */
  .page-hero { padding: 110px 5% 50px; }
  .page-hero h1 { font-size: clamp(2rem,9vw,3rem); }

  /* CTA banner */
  .cta-banner { padding: 2.5rem 1.5rem; }
  .cta-banner h3 { font-size: 1.5rem; }

  /* About */
  .about-stats { grid-template-columns: 1fr 1fr; gap: 1rem; }
  .about-visual { padding: 2rem 1.5rem; }

  /* Contact section */
  .contact-inner { padding: 2.5rem 1.5rem; border-radius: 12px; }
  .contact-email { font-size: 1.05rem; }

  /* Modal */
  .modal { border-radius: 16px 16px 0 0; max-height: 96vh; }
  .modal-overlay { align-items: flex-end; padding: 0; }
  .modal-header { padding: 1.5rem 1.25rem 1rem; }
  .modal-header h2 { font-size: 1.35rem; }
  .modal-body { padding: 1.25rem; }
  .modal-footer { padding: 1rem 1.25rem; gap: .75rem; }
  .step-indicator { padding: 1rem 1.25rem; }
  .step-dot { width: 24px; height: 24px; font-size: .7rem; }
  .session-options { grid-template-columns: repeat(auto-fill, minmax(120px,1fr)); gap: .5rem; }
  .time-slots { grid-template-columns: repeat(auto-fill, minmax(78px,1fr)); }
  .booking-summary { padding: 1.1rem; }

  /* Cookie banner */
  .cookie-banner {
    left: 0; right: 0; bottom: 0;
    border-radius: 12px 12px 0 0;
    max-width: 100%;
    padding: 1.25rem;
    border-left: none; border-right: none; border-bottom: none;
  }

  /* Footer */
  .footer-links { gap: 1rem; }

  /* Services & team grids — single column */
  .services-grid { grid-template-columns: 1fr; }
  .team-grid { grid-template-columns: repeat(auto-fit, minmax(160px,1fr)); gap: 1.5rem; }
  .testimonials-grid { grid-template-columns: 1fr; }
  .booking-grid { grid-template-columns: 1fr; }
}

/* ===================================================
   SMALL PHONES – max-width: 430px
   =================================================== */
@media(max-width:430px){

  /* Nav logo smaller */
  .logo img { height: 36px; }

  /* Hero */
  #home { padding: 90px 5% 50px; }
  .hero-badge { font-size: .72rem; padding: .35rem .9rem; }

  /* About stats stacked */
  .about-stats { grid-template-columns: 1fr; }

  /* Booking card padding */
  .booking-card { padding: 1.75rem 1.25rem; }

  /* Modal full height */
  .modal { max-height: 100vh; border-radius: 0; }

  /* Contact inner */
  .contact-inner { padding: 2rem 1.25rem; }

  /* Section title */
  .section-title { font-size: clamp(1.6rem,7vw,2.5rem); }

  /* CTA */
  .hero-cta { flex-direction: column; align-items: center; }
  .hero-cta .btn { width: 100%; max-width: 280px; text-align: center; }

  /* Cookie */
  .cookie-btns { flex-direction: column; width: 100%; }
  .cookie-btn { width: 100%; text-align: center; padding: .7rem; }
}
