@charset "UTF-8";

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

html{scroll-behavior:smooth;font-size:16px}
body{
    background:#080f0a;
    color:#fff;
    font-family:'Roboto Condensed', sans-serif;
    font-weight:300;
    line-height:1.6;
    overflow-x:hidden;
    -webkit-font-smoothing:antialiased;
}
body.nav-open{overflow:hidden}

a{color:#fff;text-decoration:none;transition:opacity .25s}
a:hover{opacity:.78}
img{max-width:100%;height:auto;display:block}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip{position:absolute;top:-100%;left:0;background:#193223;color:#fff;padding:8px 16px;z-index:9999;font-size:14px}
.skip:focus{top:0}

.container{width:100%;max-width:1200px;margin:0 auto;padding:0 20px}

.site-notifications{display:none}

/* ===== HEADER ===== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;width:100%}
.site-header-desktop{display:block}
.site-header-desktop-primary{transition:background .35s, padding .3s;padding:18px 0}
.site-header-desktop-primary--floatable{background:transparent}
.site-header-desktop-primary--floatable.is-sticky,
.site-header-desktop-primary.is-sticky-always{background:rgba(8,15,10,.95);padding:10px 0;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.site-header-desktop-primary .container{display:flex;align-items:center;justify-content:space-between}

.site-logo__btn{display:inline-block}
.site-logo__expanded{height:52px;width:auto;transition:height .3s}
.is-sticky .site-logo__expanded{height:38px}

.site-nav-menu{list-style:none;display:flex;align-items:center;gap:32px;padding:0;margin:0}
.site-nav-link{
    font-family:'Roboto Condensed', sans-serif;font-weight:400;font-size:14px;
    letter-spacing:1.8px;text-transform:uppercase;color:rgba(255,255,255,.88);
    padding:6px 0;position:relative;transition:color .2s;
}
.site-nav-link:hover{color:#fff;opacity:1}
.site-nav-link::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:#d4a054;transition:width .3s}
.site-nav-link:hover::after{width:100%}

/* ===== BUTTONS ===== */
.btn{display:inline-block;font-family:'Roboto Condensed',sans-serif;font-weight:400;font-size:13px;letter-spacing:2px;text-transform:uppercase;border:none;cursor:pointer;transition:background .25s,color .25s,transform .15s;text-align:center}
.btn-brand{background:#d4a054;color:#080f0a;padding:12px 28px}
.btn-brand:hover{background:#c28f43;color:#080f0a;opacity:1;transform:translateY(-1px)}
.btn-brand-alt{background:transparent;border:1px solid rgba(255,255,255,.5);color:#fff;padding:11px 28px}
.btn-brand-alt:hover{border-color:#d4a054;color:#d4a054;opacity:1}
.btn-block{display:block;width:100%}

/* ===== MOBILE HEADER ===== */
.site-header-mobi{display:none}
@media(max-width:768px){
    .site-header-desktop{display:none}
    .site-header-mobi{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:rgba(8,15,10,.92);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}
    .site-header-mobi .site-logo__btn img{height:40px;width:auto}
    .nav-toggle-btn{background:none;border:none;cursor:pointer;display:flex;flex-direction:column;gap:5px;padding:8px}
    .nav-toggle-btn__line{display:block;width:24px;height:2px;background:#fff;transition:transform .3s,opacity .2s}
    .nav-toggle-btn[aria-expanded="true"] .nav-toggle-btn__line:nth-child(2){opacity:0}
    .nav-toggle-btn[aria-expanded="true"] .nav-toggle-btn__line:nth-child(1){transform:translateY(7px) rotate(45deg)}
    .nav-toggle-btn[aria-expanded="true"] .nav-toggle-btn__line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
    .site-header-mobi-panel{position:fixed;top:0;left:0;right:0;bottom:0;background:#080f0a;z-index:998;display:flex;flex-direction:column;justify-content:center;align-items:center;opacity:0;pointer-events:none;transition:opacity .35s}
    .site-header-mobi-panel.is-open{opacity:1;pointer-events:auto}
    .site-header-mobi-panel .site-nav-menu{flex-direction:column;gap:24px;text-align:center}
    .site-header-mobi-panel .site-nav-link{font-size:18px;letter-spacing:3px}
}

/* ===== HERO ===== */
.hero{position:relative;width:100%;overflow:hidden}
.hero--fullheight{height:100vh;min-height:580px}
.hero__content{position:absolute;bottom:50px;left:0;right:0;z-index:3;text-align:center}
.hero__content h2{font-family:'Noto Serif JP',serif;font-weight:400;font-size:22px;letter-spacing:4px;text-transform:uppercase;color:rgba(255,255,255,.92);text-shadow:0 2px 20px rgba(0,0,0,.6)}
@media(min-width:769px){.hero__content h2{font-size:28px;letter-spacing:6px}.hero__content{bottom:70px}}
.gallery--fit{position:absolute;top:0;left:0;width:100%;height:100%}
.gallery__item-enhancement{width:100%;height:100%}
.gallery__item-enhancement picture,.gallery__item-enhancement img{width:100%;height:100%;object-fit:cover}
.gallery__item-fallback{display:none}
.hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:45%;background:linear-gradient(to top,rgba(8,15,10,.85) 0%,transparent 100%);z-index:2;pointer-events:none}
.hero::before{content:'';position:absolute;top:0;left:0;right:0;height:30%;background:linear-gradient(to bottom,rgba(8,15,10,.5) 0%,transparent 100%);z-index:2;pointer-events:none}

/* ===== QUOTE ===== */
.c-two-col--text{padding:80px 0}
.c-two-col--text .row{display:flex;flex-wrap:wrap;align-items:center}
.col-md-6{width:100%;padding:0 15px}
@media(min-width:768px){.col-md-6{width:50%}}
.c-two-col--text h2{font-family:'Noto Serif JP',serif;font-weight:400;line-height:1.3;color:#e8dcc8}
@media(max-width:767px){.c-two-col--text h2 span{font-size:36px !important}.c-two-col--text{padding:50px 0}}
.fr-fic.fr-dib{display:block;margin:0 auto}

/* ===== SPLIT ===== */
.c-split{display:flex;flex-wrap:wrap}
.c-split--vcenter{align-items:center}
.c-split__col{width:100%;min-height:400px}
@media(min-width:768px){.c-split__col{width:50%}}
.c-split__col-inner{height:100%}
.c-split__content{padding:50px 40px}
.c-split__content p{color:rgba(255,255,255,.8);font-size:15px;line-height:1.85;margin-bottom:18px}
.c-split__heading{font-family:'Noto Serif JP',serif;font-weight:400;font-size:32px;margin-bottom:20px;letter-spacing:2px;text-transform:uppercase}
.c-split__image{width:100%;height:100%;min-height:400px;background-size:cover;background-repeat:no-repeat}

/* ===== MENU ===== */
.c-menu-section{padding:90px 0 70px;background:#0d1a10}
.menu-subtitle{text-align:center;font-size:13px;color:rgba(255,255,255,.45);margin-top:-20px;margin-bottom:50px;letter-spacing:.5px}
.menu-category{margin-bottom:60px}
.menu-cat-title{font-family:'Noto Serif JP',serif;font-weight:400;font-size:20px;letter-spacing:3px;text-transform:uppercase;text-align:center;margin-bottom:35px;color:#d4a054}
.menu-grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:600px){.menu-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:992px){.menu-grid{grid-template-columns:repeat(4,1fr)}}
.menu-item{background:#193223;overflow:hidden;transition:transform .25s}
.menu-item:hover{transform:translateY(-3px)}
.menu-item__img{width:100%;padding-top:70%;background-size:cover;background-repeat:no-repeat}
.menu-item__info{padding:16px 18px 20px}
.menu-item__name{font-family:'Noto Serif JP',serif;font-weight:400;font-size:15px;margin-bottom:6px;letter-spacing:.5px}
.menu-item__desc{font-size:12px;color:rgba(255,255,255,.55);line-height:1.6;margin-bottom:10px}
.menu-item__price{font-family:'Roboto Condensed',sans-serif;font-weight:700;font-size:18px;color:#d4a054;letter-spacing:1px}
.menu-grid--sides{grid-template-columns:1fr}
@media(min-width:600px){.menu-grid--sides{grid-template-columns:repeat(2,1fr)}}
@media(min-width:992px){.menu-grid--sides{grid-template-columns:repeat(3,1fr)}}
.menu-item--side{background:#193223}
.menu-item--side .menu-item__info{padding:18px 20px}
.menu-item--side .menu-item__name{font-size:14px}
.menu-item--side .menu-item__price{font-size:16px}

/* ===== CARDS ===== */
.c-featured--team,.c-featured--news{padding:80px 0;text-align:center}
.card-listing-heading{font-family:'Noto Serif JP',serif;font-weight:400;font-size:28px;letter-spacing:3px;text-transform:uppercase;margin-bottom:40px}
.card-listing{list-style:none;display:flex;flex-wrap:wrap;padding:0;margin:0;justify-content:center}
.card{padding:0 15px;margin-bottom:30px}
.card--cols-three{width:100%}
@media(min-width:768px){.card--cols-three{width:50%}}
@media(min-width:992px){.card--cols-three{width:33.333%}}
.card__btn{display:block;text-decoration:none;color:#fff}
.card__media{overflow:hidden;margin-bottom:15px}
.card__image{width:100%;padding-top:75%;background-size:cover;background-repeat:no-repeat;transition:transform .4s}
.card__btn:hover .card__image{transform:scale(1.04)}
.card__heading{font-family:'Noto Serif JP',serif;font-weight:400;font-size:20px;letter-spacing:1px}
.card__subheading{font-family:'Roboto Condensed',sans-serif;font-weight:300;font-size:14px;color:rgba(255,255,255,.6);margin-top:5px}
.team-readmore{text-align:center;margin-top:10px}

/* ===== TOUT OVERLAY ===== */
.c-tout-overlay{position:relative;padding:120px 0;background-size:cover;background-repeat:no-repeat;text-align:center}
.c-tout-overlay--dimmed::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(8,15,10,.7)}
.c-tout-overlay .container{position:relative;z-index:1}
.c-tout-overlay h2{font-family:'Noto Serif JP',serif;font-weight:400;font-size:36px;letter-spacing:3px;text-transform:uppercase;margin-bottom:30px}
.c-tout-overlay p{max-width:700px;margin:0 auto 15px;font-size:15px;line-height:1.8;color:rgba(255,255,255,.82)}
.cta-buttons-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:30px}

/* ===== TESTIMONIALS ===== */
.c-testimonials{padding:90px 0 80px}
.testimonials-grid{display:grid;grid-template-columns:1fr;gap:24px;margin-top:10px}
@media(min-width:768px){.testimonials-grid{grid-template-columns:repeat(2,1fr)}}
.testimonial-card{background:#193223;padding:30px 28px;display:flex;gap:18px;align-items:flex-start}
.testimonial-card__avatar{flex-shrink:0;width:54px;height:54px;border-radius:50%;overflow:hidden}
.testimonial-card__avatar img{width:100%;height:100%;object-fit:cover}
.testimonial-card__body{flex:1}
.testimonial-card__text{font-size:14px;line-height:1.75;color:rgba(255,255,255,.8);margin-bottom:14px;font-style:italic}
.testimonial-card__text::before{content:'\201C';font-family:'Noto Serif JP',serif;font-size:28px;color:#d4a054;line-height:1;display:block;margin-bottom:6px}
.testimonial-card__author{display:flex;gap:12px;align-items:center}
.testimonial-card__name{font-size:13px;font-weight:400;letter-spacing:.5px}
.testimonial-card__date{font-size:11px;color:rgba(255,255,255,.4)}

/* ===== SOCIAL ===== */
.c-one-col--text{padding:60px 0;text-align:center}
.social-accounts{list-style:none;padding:0;margin:0;display:flex;gap:20px;justify-content:center}
.social-accounts a{color:rgba(255,255,255,.7);font-size:20px;transition:color .2s}
.social-accounts a:hover{color:#d4a054;opacity:1}
.social-accounts--inline{gap:30px}
.social-accounts--inline a{font-size:15px;display:flex;align-items:center;gap:8px;letter-spacing:1px}
.social-accounts--inline span{font-size:22px}

/* ===== MOBILE FOOTER ===== */
.mobi-footer{display:none}
@media(max-width:768px){
    .mobi-footer--sticky{display:block;position:fixed;bottom:0;left:0;right:0;z-index:999;background:#080f0a;border-top:1px solid rgba(255,255,255,.08);padding:8px 10px}
    .mobi-footer__list{list-style:none;display:flex;gap:8px;padding:0;margin:0}
    .mobi-footer__item{flex:1}
    .mobi-footer__item .btn-brand{padding:10px 12px;font-size:12px}
}

/* ===== FOOTER ===== */
footer{background:#0d1a10;border-top:1px solid rgba(255,255,255,.06)}
.site-footer-desktop-primary{padding:60px 0 40px}
.site-footer-desktop-primary__container{display:flex;flex-direction:column;align-items:center;gap:28px;text-align:center}
.footer-logo img{height:auto;display:block;margin:0 auto;opacity:.8}
.footer-social{margin:5px 0}
.footer-social .social-accounts{gap:24px}
.footer-social .social-accounts a{font-size:18px}
.site-footer-desktop-primary .site-nav-menu{justify-content:center;flex-wrap:wrap;gap:20px}
.site-footer-desktop-primary .site-nav-link{font-size:12px;letter-spacing:1.5px;color:rgba(255,255,255,.55)}
.site-footer-desktop-primary .site-nav-link:hover{color:rgba(255,255,255,.85)}
.site-footer-desktop-primary .site-nav-link::after{display:none}
.footer-contact{margin-top:5px}
.footer-contact p{font-size:13px;color:rgba(255,255,255,.5);line-height:1.8;font-weight:300}
.footer-contact a{color:rgba(255,255,255,.5)}
.footer-contact a:hover{color:#d4a054;opacity:1}
.footer-imprint{margin-top:15px;padding-top:22px;border-top:1px solid rgba(255,255,255,.08);max-width:460px}
.footer-imprint h4{font-family:'Noto Serif JP',serif;font-weight:400;font-size:13px;letter-spacing:1.5px;margin-bottom:10px;color:rgba(255,255,255,.6)}
.footer-imprint p{font-size:12px;color:rgba(255,255,255,.4);line-height:1.9;font-weight:300}
.site-footer-desktop-secondary{border-top:1px solid rgba(255,255,255,.06);padding:18px 0;text-align:center}
.site-powered-by p{font-size:11px;color:rgba(255,255,255,.3);letter-spacing:1px;font-weight:300}

/* ===== REVEAL ===== */
.revealable{opacity:0;transform:translateY(25px);transition:opacity .7s ease,transform .7s ease}
.revealable.is-revealed{opacity:1;transform:translateY(0)}

/* ===== SUBPAGE HERO ===== */
.subpage-hero{padding-top:120px;padding-bottom:50px;background:#0d1a10;text-align:center}
.subpage-hero--short{padding-top:110px;padding-bottom:40px}
.subpage-hero h1{font-family:'Noto Serif JP',serif;font-weight:400;font-size:32px;letter-spacing:4px;text-transform:uppercase}

/* ===== LEGAL PAGES ===== */
.legal-content{max-width:800px;margin:0 auto;padding:40px 20px 80px}
.legal-updated{font-size:12px;color:rgba(255,255,255,.4);margin-bottom:35px}
.legal-content h2{font-family:'Noto Serif JP',serif;font-weight:400;font-size:18px;margin-top:35px;margin-bottom:12px;letter-spacing:1px;color:#d4a054}
.legal-content p{font-size:14px;line-height:1.85;color:rgba(255,255,255,.75);margin-bottom:12px}
.legal-content a{color:#d4a054;text-decoration:underline}

/* ===== GALLERY PAGE ===== */
.gallery-page{padding:30px 20px 80px}
.gallery-intro{text-align:center;font-size:15px;color:rgba(255,255,255,.6);margin-bottom:40px;max-width:600px;margin-left:auto;margin-right:auto}
.gallery-collage{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media(min-width:768px){.gallery-collage{grid-template-columns:repeat(3,1fr);gap:16px}}
.gallery-collage__item{overflow:hidden}
.gallery-collage__item img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gallery-collage__item:hover img{transform:scale(1.05)}
.gallery-collage__item--tall{grid-row:span 2}
.gallery-collage__item--wide{grid-column:span 2}

/* ===== TEAM PAGE ===== */
.team-page{padding:30px 20px 80px;max-width:960px;margin:0 auto}
.team-member{display:flex;flex-wrap:wrap;gap:30px;margin-bottom:60px;align-items:center}
.team-member--reverse{flex-direction:row-reverse}
.team-member__photo{width:100%;max-width:340px;flex-shrink:0}
.team-member__photo img{width:100%;aspect-ratio:3/4;object-fit:cover}
.team-member__bio{flex:1;min-width:280px}
.team-member__bio h2{font-family:'Noto Serif JP',serif;font-weight:400;font-size:24px;letter-spacing:1px;margin-bottom:6px}
.team-member__role{font-size:13px;color:#d4a054;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:16px}
.team-member__bio p:not(.team-member__role){font-size:14px;line-height:1.85;color:rgba(255,255,255,.75)}
@media(max-width:767px){
    .team-member,.team-member--reverse{flex-direction:column}
    .team-member__photo{max-width:100%}
}

/* ===== ABOUT PAGE ===== */
.about-page{padding:30px 20px 80px;max-width:860px;margin:0 auto}
.about-photo{margin-bottom:40px;overflow:hidden}
.about-photo img{width:100%;max-height:450px;object-fit:cover}
.about-text p{font-size:15px;line-height:1.9;color:rgba(255,255,255,.78);margin-bottom:18px}

/* ===== BOOKING PAGE ===== */
.booking-page{padding:30px 20px 80px;max-width:720px;margin:0 auto}
.booking-info{text-align:center;margin-bottom:40px}
.booking-info p{font-size:14px;color:rgba(255,255,255,.65);line-height:1.7;margin-bottom:8px}
.booking-info a{color:#d4a054}
.booking-form-wrap{background:#193223;padding:40px 35px;border:1px solid rgba(255,255,255,.06)}
.form-row{display:flex;gap:20px;margin-bottom:20px}
.form-row--full .form-group{width:100%}
.form-group{flex:1;min-width:0}
.input-label{display:block;font-size:12px;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:6px}
.input-label-required{color:#d4a054}
.form-control{
    width:100%;background:#0d1a10;border:1px solid rgba(255,255,255,.15);
    color:#fff;font-family:'Roboto Condensed',sans-serif;font-size:14px;
    padding:11px 14px;transition:border-color .2s;font-weight:300;
    -webkit-appearance:none;appearance:none;border-radius:0;
}
.form-control:focus{outline:none;border-color:#d4a054}
.form-control.has-error{border-color:#e94560}
select.form-control{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23fff' fill='none' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
select.form-control option{background:#193223;color:#fff}
textarea.form-control{resize:vertical;min-height:70px}
.error-label{display:none;font-size:11px;color:#e94560;margin-top:4px;font-style:normal}
.form-actions{margin-top:28px;text-align:center}
.form-error-msg{display:block;font-size:12px;color:#e94560;margin-top:12px}
@media(max-width:600px){
    .form-row{flex-direction:column;gap:16px}
    .booking-form-wrap{padding:28px 18px}
}

/* ===== THANK YOU PAGE ===== */
.thankyou-page{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:120px 20px 60px;text-align:center}
.thankyou-box{max-width:500px}
.thankyou-icon{font-size:48px;color:#d4a054;margin-bottom:20px}
.thankyou-page h1{font-family:'Noto Serif JP',serif;font-weight:400;font-size:26px;letter-spacing:2px;margin-bottom:12px}
.thankyou-name{font-size:18px;color:#d4a054;margin-bottom:24px}
.thankyou-details{background:#193223;padding:20px;margin-bottom:24px}
.thankyou-details p{font-size:14px;color:rgba(255,255,255,.8);margin-bottom:6px}
.thankyou-details strong{color:#d4a054}
.thankyou-note{font-size:13px;color:rgba(255,255,255,.55);line-height:1.7;margin-bottom:30px}
.thankyou-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ===== RESPONSIVE ===== */
@media(max-width:768px){
    .hero--fullheight{height:85vh;min-height:480px}
    .hero__content{bottom:30px}
    .hero__content h2{font-size:16px;letter-spacing:2px}
    .c-split__content{padding:35px 20px}
    .c-split__col{min-height:280px}
    .c-split__heading{font-size:24px}
    .c-tout-overlay{padding:70px 20px}
    .c-tout-overlay h2{font-size:24px}
    .c-menu-section{padding:60px 0 50px}
    .menu-cat-title{font-size:16px}
    .testimonial-card{padding:22px 18px}
    .site-footer-desktop-primary{padding:40px 0 30px}
    body{padding-bottom:56px}
    .subpage-hero{padding-top:90px;padding-bottom:30px}
    .subpage-hero h1{font-size:24px}
}

/* ===== LOGO WHITE FILTER ===== */
.logo--white{filter:brightness(0) invert(1);-webkit-filter:brightness(0) invert(1)}

/* ===== PROSE BLOCK ===== */
.prose-block{max-width:800px;margin:0 auto}
.prose-block p{font-size:15px;line-height:1.9;color:rgba(255,255,255,.78);margin-bottom:18px}
