:root {
    --red: #e63329;
    --red-dark: #c0271e;
    --red-glow: rgba(230,51,41,0.25);
    --bg:  #080808;
    --bg2: #0f0f0f;
    --bg3: #161616;
    --bg4: #1d1d1d;
    --white: #ffffff;
    --gray: #888888;
    --light: #cccccc;
    --border: rgba(255,255,255,0.07);
    --nav-h: 72px;
    --r-sm: 10px;
    --r-md: 16px;
    --r-lg: 22px;
    --r-xl: 30px;
    --r-pill: 100px;
    --ease: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    --t: 0.35s var(--ease);
    --font-h: 'Oswald', sans-serif;
    --font-b: 'Open Sans', sans-serif;
    --shadow: 0 8px 32px rgba(0,0,0,0.45), 0 2px 8px rgba(0,0,0,0.3);
    --shadow-lg: 0 20px 80px rgba(0,0,0,0.6), 0 4px 16px rgba(0,0,0,0.4);
    --shadow-red: 0 8px 40px rgba(230,51,41,0.25);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--white);font-family:var(--font-b);line-height:1.65;overflow-x:hidden}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit;color:inherit}
input,select{font-family:inherit}

::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--red);border-radius:10px}

/* CURSOR */
.cursor{
    position:fixed;top:0;left:0;
    width:36px;height:36px;
    border:1.5px solid var(--red);
    border-radius:50%;
    pointer-events:none;
    z-index:9999;
    transform:translate(-50%,-50%);
    transition:width .3s,height .3s,background .3s,opacity .3s;
    transition-property:width,height,background;
    opacity:0;
}
.cursor.active{opacity:1}
.cursor.hover{width:56px;height:56px;background:rgba(230,51,41,0.1);border-color:rgba(230,51,41,0.6)}
@media(pointer:coarse){.cursor{display:none}}

/* UTILS */
.container{max-width:1140px;margin:0 auto;padding:0 28px}
.text-red{color:var(--red)}

.btn-primary{
    display:inline-flex;align-items:center;gap:10px;
    background:var(--red);color:var(--white);
    font-family:var(--font-h);font-size:13px;font-weight:500;
    letter-spacing:2px;text-transform:uppercase;
    padding:14px 36px;
    border-radius:var(--r-pill);
    border:2px solid var(--red);
    transition:var(--t);
    box-shadow:0 4px 24px rgba(230,51,41,0.35);
    position:relative;overflow:hidden;
}
.btn-primary::after{
    content:'';position:absolute;inset:0;
    background:linear-gradient(135deg,rgba(255,255,255,0.12),transparent);
    opacity:0;transition:opacity .3s;
}
.btn-primary:hover::after{opacity:1}
.btn-primary:hover{background:transparent;color:var(--red);box-shadow:0 4px 32px rgba(230,51,41,0.4)}
.btn-primary.btn-full{width:100%;justify-content:center}

.btn-ghost{
    display:inline-flex;align-items:center;gap:10px;
    background:transparent;color:var(--white);
    font-family:var(--font-h);font-size:13px;letter-spacing:2px;text-transform:uppercase;
    padding:13px 32px;
    border-radius:var(--r-pill);
    border:1.5px solid rgba(255,255,255,0.18);
    transition:var(--t);
}
.btn-ghost:hover{border-color:var(--red);color:var(--red)}

.section-label{
    display:inline-flex;align-items:center;gap:10px;
    font-family:var(--font-h);font-size:11px;letter-spacing:5px;
    color:var(--red);text-transform:uppercase;margin-bottom:16px;
}
.section-label::before{content:'';display:block;width:20px;height:1px;background:var(--red);border-radius:2px}
.section-title{
    font-family:var(--font-h);font-size:clamp(26px,4vw,48px);
    font-weight:700;letter-spacing:2px;line-height:1.1;text-transform:uppercase;
}
.section-header{text-align:center;margin-bottom:64px}
.section-sub{color:var(--gray);margin-top:16px;font-size:15px}

/* NAVBAR */
.navbar{
    position:fixed;top:0;left:0;right:0;height:var(--nav-h);
    z-index:1000;transition:background .4s,box-shadow .4s;
}
.navbar.scrolled{
    background:rgba(6,6,6,0.96);
    backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
    box-shadow:0 1px 0 var(--border),0 8px 32px rgba(0,0,0,0.5);
}
.nav-wrap{
    max-width:1240px;margin:0 auto;padding:0 32px;
    height:100%;display:flex;align-items:center;gap:40px;
}
.logo{display:flex;align-items:center;gap:10px}
.logo-img{height:38px;width:auto}
.logo-text{font-family:var(--font-h);font-size:23px;font-weight:700;letter-spacing:4px}
.logo-text em{color:var(--red);font-style:normal}

.nav-links{display:flex;align-items:center;gap:32px;margin-left:auto}
.nav-links a{
    font-family:var(--font-h);font-size:12px;letter-spacing:2px;
    text-transform:uppercase;color:rgba(255,255,255,0.75);
    position:relative;transition:color .3s;
}
.nav-links a::after{
    content:'';position:absolute;bottom:-4px;left:0;
    width:0;height:1.5px;background:var(--red);border-radius:2px;transition:width .3s;
}
.nav-links a:hover{color:var(--white)}
.nav-links a:hover::after{width:100%}
.nav-book{
    background:var(--red)!important;color:var(--white)!important;
    padding:9px 24px;border-radius:var(--r-pill);
    box-shadow:0 4px 16px rgba(230,51,41,0.35);transition:all .3s!important;
}
.nav-book:hover{background:var(--red-dark)!important;transform:translateY(-2px)}
.nav-book::after{display:none!important}

.nav-right{display:flex;align-items:center;gap:20px}
.lang-switcher{display:flex;align-items:center;gap:8px}
.lang-switcher span{color:var(--border);font-size:14px}
.lang-btn{font-family:var(--font-h);font-size:11px;letter-spacing:2px;color:var(--gray);transition:color .3s;padding:4px}
.lang-btn.active,.lang-btn:hover{color:var(--red)}

.hamburger{display:none;flex-direction:column;gap:5px;padding:4px}
.hamburger span{display:block;width:22px;height:1.5px;background:var(--white);transition:.3s;border-radius:2px}
.hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* HERO */
.hero{
    position:relative;height:100vh;min-height:680px;
    display:flex;align-items:center;overflow:hidden;
}
.hero-bg{position:absolute;inset:0}
.hero-img{width:100%;height:115%;object-fit:cover;object-position:center top;will-change:transform}
.hero-gradient{
    position:absolute;inset:0;
    background:linear-gradient(110deg,rgba(5,5,5,0.93) 0%,rgba(5,5,5,0.65) 55%,rgba(5,5,5,0.25) 100%);
}
.hero-glow{
    position:absolute;top:15%;left:-5%;z-index:1;pointer-events:none;
    width:700px;height:700px;
    background:radial-gradient(circle,rgba(230,51,41,0.1) 0%,transparent 65%);
}
.hero-content{
    position:relative;z-index:2;
    max-width:1200px;margin:0 auto;padding:0 32px;
    padding-top:var(--nav-h);
}
.hero-tag{
    display:inline-flex;align-items:center;gap:8px;
    font-family:var(--font-h);font-size:11px;letter-spacing:4px;
    text-transform:uppercase;color:var(--red);
    background:rgba(230,51,41,0.08);
    padding:8px 18px;border-radius:var(--r-pill);
    border:1px solid rgba(230,51,41,0.22);
    margin-bottom:24px;
}
.hero-title{
    font-family:var(--font-h);font-size:clamp(42px,7vw,84px);
    font-weight:700;line-height:1.04;letter-spacing:2px;
    text-transform:uppercase;margin-bottom:20px;
    text-shadow:0 4px 40px rgba(0,0,0,0.6);
}
.hero-desc{font-size:16px;color:var(--light);margin-bottom:40px;max-width:420px;line-height:1.75}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:56px}
.hero-stats{
    display:inline-flex;align-items:center;
    background:rgba(255,255,255,0.04);
    backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
    border:1px solid var(--border);
    border-radius:var(--r-lg);padding:20px 32px;
}
.hero-stat{text-align:center;padding:0 28px}
.hero-stat strong{display:block;font-family:var(--font-h);font-size:30px;font-weight:700;line-height:1;margin-bottom:4px}
.hero-stat span{font-size:11px;color:var(--gray);letter-spacing:2px;text-transform:uppercase}
.hero-stat-div{width:1px;height:32px;background:var(--border);flex-shrink:0}

.hero-scroll-indicator{
    position:absolute;bottom:36px;left:50%;transform:translateX(-50%);
    z-index:2;display:flex;flex-direction:column;align-items:center;gap:10px;
}
.hero-scroll-indicator span{font-family:var(--font-h);font-size:10px;letter-spacing:3px;color:var(--gray);text-transform:uppercase}
.scroll-mouse{width:22px;height:36px;border:1.5px solid rgba(255,255,255,0.25);border-radius:11px;display:flex;justify-content:center;padding-top:6px}
.scroll-dot{width:3px;height:7px;background:var(--red);border-radius:2px;animation:scrollDot 1.8s ease-in-out infinite}
@keyframes scrollDot{0%{transform:translateY(0);opacity:1}100%{transform:translateY(13px);opacity:0}}

/* SERVICES */
.services{padding:110px 0;background:var(--bg);position:relative}
.services::before{
    content:'';position:absolute;top:0;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent,rgba(230,51,41,0.6),transparent);
}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}

.service-card{
    position:relative;
    background:linear-gradient(150deg,var(--bg3) 0%,var(--bg2) 100%);
    border:1px solid var(--border);
    border-radius:var(--r-lg);
    padding:36px 28px 32px;
    transition:var(--t);overflow:hidden;
    box-shadow:0 4px 6px rgba(0,0,0,0.25),0 12px 36px rgba(0,0,0,0.4),inset 0 1px 0 rgba(255,255,255,0.05);
    transform-style:preserve-3d;will-change:transform;
}
.service-card::before{
    content:'';position:absolute;top:0;left:0;right:0;height:2px;
    background:linear-gradient(90deg,transparent,var(--red),transparent);
    opacity:0;transition:opacity .4s;border-radius:var(--r-lg) var(--r-lg) 0 0;
}
.service-card:hover{
    border-color:rgba(230,51,41,0.22);
    box-shadow:0 8px 12px rgba(0,0,0,0.4),0 24px 64px rgba(0,0,0,0.5),inset 0 1px 0 rgba(255,255,255,0.07),0 0 50px rgba(230,51,41,0.12);
}
.service-card:hover::before{opacity:1}

.featured-card{
    background:linear-gradient(150deg,rgba(230,51,41,0.07) 0%,var(--bg2) 100%);
    border-color:rgba(230,51,41,0.2);
}
.featured-card::before{opacity:1}

.card-badge{
    position:absolute;top:18px;right:18px;
    background:var(--red);
    font-family:var(--font-h);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;
    padding:4px 13px;border-radius:var(--r-pill);
    box-shadow:0 4px 12px rgba(230,51,41,0.4);
}
.service-icon{
    width:56px;height:56px;
    background:rgba(230,51,41,0.1);
    border:1px solid rgba(230,51,41,0.18);
    border-radius:var(--r-md);
    display:flex;align-items:center;justify-content:center;
    font-size:22px;color:var(--red);
    margin-bottom:22px;transition:var(--t);
}
.service-card:hover .service-icon{
    background:var(--red);color:var(--white);
    box-shadow:0 8px 24px rgba(230,51,41,0.35);
    transform:rotateY(180deg);
}
.service-card h3{font-family:var(--font-h);font-size:19px;letter-spacing:1px;text-transform:uppercase;margin-bottom:10px}
.service-card p{font-size:13px;color:var(--gray);line-height:1.75;margin-bottom:22px}
.service-price{font-family:var(--font-h);font-size:15px;color:var(--red);letter-spacing:1px}
.card-shine{
    position:absolute;top:0;left:-100%;width:55%;height:100%;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,0.025),transparent);
    transition:.7s;pointer-events:none;
}
.service-card:hover .card-shine{left:160%}

/* ABOUT */
.about{padding:110px 0;background:var(--bg2);position:relative;overflow:hidden}
.about::before{
    content:'';position:absolute;top:0;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent,rgba(230,51,41,0.5),transparent);
}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-visual{position:relative}
.about-img-frame{
    border-radius:var(--r-xl);overflow:hidden;
    box-shadow:var(--shadow-lg);position:relative;
}
.about-img-frame::after{
    content:'';position:absolute;inset:0;border-radius:var(--r-xl);
    border:1px solid var(--border);pointer-events:none;z-index:1;
}
.about-img{width:100%;height:560px;object-fit:cover;filter:grayscale(15%);transition:filter .5s,transform .5s}
.about-img-frame:hover .about-img{filter:grayscale(0%);transform:scale(1.03)}
.about-img-frame.no-img{min-height:560px;background:linear-gradient(135deg,var(--bg3),var(--bg4))}

.about-accent-card{
    position:absolute;bottom:-24px;right:-24px;z-index:2;
    background:var(--red);border-radius:var(--r-lg);
    padding:22px 26px;display:flex;flex-direction:column;align-items:center;gap:6px;
    box-shadow:0 12px 40px rgba(230,51,41,0.45);
    text-align:center;
}
.about-accent-card i{font-size:20px}
.about-accent-card strong{font-family:var(--font-h);font-size:18px;letter-spacing:1px}
.about-accent-card span{font-size:11px;opacity:.8;letter-spacing:1px}

.about-float-badge{
    position:absolute;top:32px;left:-28px;z-index:2;
    background:linear-gradient(135deg,var(--bg3),var(--bg4));
    border:1px solid var(--border);
    border-radius:var(--r-md);padding:16px 20px;
    display:flex;flex-direction:column;align-items:center;gap:4px;
    box-shadow:var(--shadow);
}
.about-float-badge i{color:var(--red);font-size:18px}
.about-float-badge span{font-family:var(--font-h);font-size:22px;font-weight:700;line-height:1}
.about-float-badge small{font-size:10px;color:var(--gray);letter-spacing:1px;text-transform:uppercase}

.about-text{display:flex;flex-direction:column}
.about-text .section-title{margin-bottom:22px}
.about-text p{color:var(--light);font-size:14px;line-height:1.9;margin-bottom:14px}
.about-features{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:22px 0 32px}
.feature-item{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--light)}
.feature-item i{color:var(--red);font-size:11px;background:rgba(230,51,41,0.12);width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}

.about-stats{
    display:flex;border:1px solid var(--border);border-radius:var(--r-lg);
    overflow:hidden;margin-bottom:36px;
    background:rgba(255,255,255,0.02);
}
.astat{flex:1;padding:24px 16px;text-align:center;position:relative}
.astat:not(:last-child)::after{content:'';position:absolute;top:20%;right:0;height:60%;width:1px;background:var(--border)}
.astat-num{font-family:var(--font-h);font-size:36px;font-weight:700;color:var(--red);line-height:1}
.astat-plus{font-family:var(--font-h);font-size:22px;color:var(--red)}
.astat-label{display:block;font-size:11px;color:var(--gray);text-transform:uppercase;letter-spacing:1px;margin-top:6px}

/* GALLERY */
.gallery{padding:110px 0;background:var(--bg)}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:260px 260px;gap:16px}
.gallery-item{position:relative;border-radius:var(--r-lg);overflow:hidden;cursor:pointer;background:var(--bg3)}
.gallery-item.tall{grid-row:span 2}
.gallery-item.wide{grid-column:span 2}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.gallery-item:hover img{transform:scale(1.08)}
.gallery-overlay{
    position:absolute;inset:0;
    background:linear-gradient(to top,rgba(0,0,0,0.65) 0%,rgba(230,51,41,0.25) 100%);
    display:flex;align-items:center;justify-content:center;
    opacity:0;transition:opacity .35s;
}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-overlay span{
    font-family:var(--font-h);font-size:12px;letter-spacing:3px;text-transform:uppercase;
    border:1px solid rgba(255,255,255,0.7);padding:9px 22px;border-radius:var(--r-pill);
    transform:translateY(10px);transition:transform .35s;
}
.gallery-item:hover .gallery-overlay span{transform:translateY(0)}

/* TEAM */
.team{padding:110px 0;background:var(--bg2)}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.team-card{
    border-radius:var(--r-xl);overflow:hidden;
    background:linear-gradient(150deg,var(--bg3),var(--bg2));
    border:1px solid var(--border);
    transition:var(--t);box-shadow:var(--shadow);
    transform-style:preserve-3d;will-change:transform;
}
.team-card:hover{border-color:rgba(230,51,41,0.2);box-shadow:var(--shadow-lg),var(--shadow-red)}
.team-img-wrap{position:relative;height:280px;overflow:hidden;background:var(--bg3)}
.team-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .5s;position:relative;z-index:1}
.team-card:hover .team-img-wrap img{transform:scale(1.06)}
.team-placeholder{
    position:absolute;inset:0;
    display:flex;align-items:center;justify-content:center;
    background:linear-gradient(135deg,var(--bg3),var(--bg4));
}
.team-placeholder span{font-family:var(--font-h);font-size:90px;font-weight:700;color:var(--red);opacity:.18}
.team-info{padding:28px}
.team-info h4{font-family:var(--font-h);font-size:22px;letter-spacing:2px;text-transform:uppercase;margin-bottom:4px}
.team-role{display:block;font-size:11px;color:var(--red);letter-spacing:2px;text-transform:uppercase;margin-bottom:12px}
.team-info p{font-size:13px;color:var(--gray);line-height:1.75;margin-bottom:16px}
.team-stars{color:var(--red);font-size:13px;letter-spacing:3px}

/* BOOKING */
.booking-section{
    padding:110px 0;background:var(--bg);position:relative;overflow:hidden;
}
.booking-section::before{
    content:'';position:absolute;top:0;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent,rgba(230,51,41,0.6),transparent);
}
.booking-section::after{
    content:'';position:absolute;bottom:-200px;right:-200px;pointer-events:none;
    width:600px;height:600px;
    background:radial-gradient(circle,rgba(230,51,41,0.07) 0%,transparent 70%);
}
.booking-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.hours-block .section-title{margin-bottom:32px}
.hours-list{margin-bottom:40px}
.hours-item{
    display:flex;justify-content:space-between;align-items:center;
    padding:16px 0;border-bottom:1px solid var(--border);font-size:14px;color:var(--light);
}
.hours-time{font-family:var(--font-h);font-size:15px;letter-spacing:1px;color:var(--white)}
.hours-closed{color:var(--gray)!important}
.contact-info{display:flex;flex-direction:column;gap:16px}
.contact-item{display:flex;align-items:center;gap:14px;font-size:14px;color:var(--light)}
.contact-item i{color:var(--red);width:16px;text-align:center;flex-shrink:0}
.contact-item a{transition:color .3s}.contact-item a:hover{color:var(--red)}

.booking-form-block{
    background:linear-gradient(150deg,var(--bg3) 0%,var(--bg2) 100%);
    border:1px solid var(--border);border-radius:var(--r-xl);
    padding:48px;position:relative;overflow:hidden;
    box-shadow:var(--shadow-lg);
}
.booking-form-block::before{
    content:'';position:absolute;top:0;left:0;right:0;height:2px;
    background:linear-gradient(90deg,var(--red),rgba(230,51,41,0.2));
    border-radius:var(--r-xl) var(--r-xl) 0 0;
}
.booking-form-block .section-title{margin-bottom:28px}
.form-group{display:flex;flex-direction:column;margin-bottom:20px}
.form-group label{
    font-family:var(--font-h);font-size:11px;letter-spacing:2px;
    text-transform:uppercase;color:var(--gray);margin-bottom:8px;
}
.form-group input,.form-group select{
    background:rgba(255,255,255,0.04);
    border:1px solid var(--border);
    color:var(--white);padding:14px 18px;font-size:14px;
    border-radius:var(--r-sm);outline:none;
    transition:border-color .3s,background .3s,box-shadow .3s;
    -webkit-appearance:none;appearance:none;
}
.form-group select{
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 18px center;padding-right:44px;cursor:pointer;
}
.form-group select option{background:var(--bg3)}
.form-group input:focus,.form-group select:focus{
    border-color:var(--red);background:rgba(230,51,41,0.04);
    box-shadow:0 0 0 3px rgba(230,51,41,0.12);
}
.form-group.has-error input,.form-group.has-error select{border-color:var(--red);box-shadow:0 0 0 3px rgba(230,51,41,0.1)}
.field-err{font-size:12px;color:var(--red);margin-top:6px;display:none}
.form-group.has-error .field-err{display:block}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
input[type="date"]::-webkit-calendar-picker-indicator{filter:invert(.5);cursor:pointer}
#submitBtn{margin-top:8px;font-size:13px}
.spinner{display:none;width:16px;height:16px;border:2px solid rgba(255,255,255,0.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}
.spinner.show{display:block}
@keyframes spin{to{transform:rotate(360deg)}}

/* TESTIMONIALS */
.testimonials{padding:110px 0;background:var(--bg2)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.review-card{
    background:linear-gradient(150deg,var(--bg3),var(--bg2));
    border:1px solid var(--border);border-radius:var(--r-xl);
    padding:36px;position:relative;overflow:hidden;
    box-shadow:var(--shadow);transition:var(--t);
    transform-style:preserve-3d;will-change:transform;
}
.review-card::before{
    content:'"';position:absolute;top:-10px;right:16px;
    font-size:110px;font-family:Georgia,serif;
    color:var(--red);opacity:.06;line-height:1;pointer-events:none;
}
.review-card:hover{border-color:rgba(230,51,41,0.2);box-shadow:var(--shadow-lg),var(--shadow-red);transform:translateY(-5px)}
.review-stars{color:var(--red);font-size:14px;letter-spacing:3px;margin-bottom:16px}
.review-card>p{font-size:14px;color:var(--light);line-height:1.8;margin-bottom:24px;font-style:italic}
.reviewer{display:flex;align-items:center;gap:14px}
.reviewer-avatar{
    width:44px;height:44px;background:var(--red);border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-family:var(--font-h);font-size:18px;font-weight:700;
    flex-shrink:0;box-shadow:0 4px 16px rgba(230,51,41,0.35);
}
.reviewer strong{display:block;font-size:14px;margin-bottom:3px}
.reviewer span{font-size:12px;color:var(--gray)}

/* FOOTER */
.footer{background:var(--bg);border-top:1px solid var(--border);padding:64px 0 28px}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-brand .logo-text{font-size:26px;display:block;margin-bottom:16px}
.footer-brand>p{font-size:14px;color:var(--gray);line-height:1.75;margin-bottom:24px;max-width:260px}
.social-links{display:flex;gap:12px}
.social-links a{
    width:42px;height:42px;border:1px solid var(--border);border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-size:15px;color:var(--gray);transition:var(--t);
}
.social-links a:hover{border-color:var(--red);color:var(--red);background:rgba(230,51,41,0.06);transform:translateY(-3px)}
.footer-nav,.footer-contact{display:flex;flex-direction:column;gap:14px}
.footer-nav h5,.footer-contact h5{
    font-family:var(--font-h);font-size:11px;letter-spacing:3px;
    text-transform:uppercase;color:var(--white);margin-bottom:4px;
}
.footer-nav a{font-size:14px;color:var(--gray);transition:color .3s}
.footer-nav a:hover{color:var(--red)}
.footer-contact p{font-size:14px;color:var(--gray);display:flex;align-items:center;gap:12px}
.footer-contact i{color:var(--red);width:14px;text-align:center;flex-shrink:0}
.footer-contact a{transition:color .3s}.footer-contact a:hover{color:var(--red)}
.footer-bottom{border-top:1px solid var(--border);padding-top:24px;text-align:center;font-size:13px;color:var(--gray)}

/* MODAL */
.modal-overlay{
    position:fixed;inset:0;background:rgba(0,0,0,0.88);
    backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
    z-index:2000;display:none;align-items:center;justify-content:center;padding:20px;
}
.modal-overlay.open{display:flex}
.modal{
    background:linear-gradient(150deg,var(--bg3),var(--bg2));
    border:1px solid var(--border);border-radius:var(--r-xl);
    padding:44px 40px;max-width:460px;width:100%;
    position:relative;text-align:center;
    animation:modalIn .4s cubic-bezier(0.34,1.56,0.64,1);
    box-shadow:0 30px 100px rgba(0,0,0,0.6),0 0 60px rgba(230,51,41,0.1);
}
@keyframes modalIn{from{opacity:0;transform:scale(.88) translateY(24px)}to{opacity:1;transform:scale(1) translateY(0)}}
.modal-icon{
    width:60px;height:60px;
    background:linear-gradient(135deg,var(--red),#ff5e54);
    border-radius:50%;display:flex;align-items:center;justify-content:center;
    font-size:22px;margin:0 auto 20px;
    box-shadow:0 8px 32px rgba(230,51,41,0.45);
}
.modal h3{font-family:var(--font-h);font-size:22px;letter-spacing:2px;text-transform:uppercase;margin-bottom:8px}
.modal>p{color:var(--gray);font-size:14px;margin-bottom:28px}
.modal-close{
    position:absolute;top:18px;right:20px;font-size:22px;
    color:var(--gray);line-height:1;transition:color .3s,transform .3s;
    width:32px;height:32px;display:flex;align-items:center;justify-content:center;
    border-radius:50%;background:rgba(255,255,255,0.05);
}
.modal-close:hover{color:var(--white);transform:rotate(90deg)}
#checkinCanvas{width:100%;height:auto;display:block;margin-bottom:24px;border-radius:var(--r-md)}

/* SCROLL TOP */
.scroll-top{
    position:fixed;bottom:32px;right:32px;
    width:48px;height:48px;background:var(--red);border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-size:15px;color:var(--white);z-index:900;
    opacity:0;transform:translateY(16px);
    transition:opacity .35s,transform .35s,box-shadow .35s;
    box-shadow:0 4px 20px rgba(230,51,41,0.4);pointer-events:none;
}
.scroll-top.visible{opacity:1;transform:translateY(0);pointer-events:auto}
.scroll-top:hover{transform:translateY(-4px);box-shadow:0 8px 32px rgba(230,51,41,0.55)}

/* RESPONSIVE */
@media(max-width:1024px){
    .services-grid{grid-template-columns:repeat(2,1fr)}
    .footer-top{grid-template-columns:1fr 1fr}
    .footer-contact{grid-column:span 2}
}
@media(max-width:900px){
    .about-grid,.booking-grid{grid-template-columns:1fr;gap:52px}
    .team-grid,.reviews-grid{grid-template-columns:1fr 1fr}
    .gallery-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto}
    .gallery-item.tall,.gallery-item.wide{grid-column:auto;grid-row:auto}
    .about-float-badge{left:-12px}
}
@media(max-width:768px){
    .nav-links{
        position:fixed;top:var(--nav-h);left:0;right:0;
        background:rgba(6,6,6,0.97);backdrop-filter:blur(20px);
        flex-direction:column;padding:32px 28px;gap:22px;
        transform:translateY(-120%);transition:transform .4s var(--ease);
        align-items:flex-start;border-bottom:1px solid var(--border);
    }
    .nav-links.open{transform:translateY(0)}
    .hamburger{display:flex}
    .services-grid{grid-template-columns:1fr}
    .team-grid,.reviews-grid{grid-template-columns:1fr}
    .hero-stats{padding:16px 20px}
    .hero-stat{padding:0 18px}
    .booking-form-block{padding:32px 24px}
    .modal{padding:36px 24px}
    .form-row{grid-template-columns:1fr}
    .about-img{height:320px}
    .footer-top{grid-template-columns:1fr}
    .footer-contact{grid-column:auto}
}
@media(max-width:480px){
    .hero-actions{flex-direction:column}
    .btn-primary,.btn-ghost{width:100%;justify-content:center}
    .gallery-grid{grid-template-columns:1fr}
    .hero-title{font-size:38px}
    .about-features{grid-template-columns:1fr}
    .about-float-badge{display:none}
    .scroll-top{bottom:20px;right:20px}
    .cursor{display:none}
}
