/* Christian (Tiki in Waikiki) — Blackwork tribal palette */
:root{
  --c-black:#000;--c-bg-2:#0a0a0a;--c-card:#0f0d0a;--c-border:#1f1a14;
  --c-tapa:#5e3a1d;--c-tapa-hi:#7a4d28;--c-tapa-deep:#3a2410;
  --c-coconut:#f0e8d4;--c-coconut-soft:#d4cab2;
  --c-green:#4a7c3f;--c-green-hi:#6ba858;
  --c-text:#bfb8a4;--c-dim:#7d7666;
  --r-sm:0;--r-md:0;--r-lg:0;--r-pill:0;
  --trans:.2s ease;
  --font-h:'Bebas Neue','Impact',sans-serif;
  --font-b:'Inter',-apple-system,sans-serif;
  --font-acc:'Cormorant Garamond',Georgia,serif;
}
*,*::before,*::after{box-sizing:border-box}
[hidden]{display:none!important}
html{scroll-behavior:smooth;overflow-x:hidden}
body{margin:0;font-family:var(--font-b);color:var(--c-text);background:var(--c-black);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:var(--c-green-hi);text-decoration:none}a:hover{color:var(--c-coconut)}
img,svg{max-width:100%}
.container{max-width:1180px;margin:0 auto;padding:0 24px}
.skip-link{position:absolute;left:-9999px;background:var(--c-coconut);color:var(--c-black);padding:10px 16px;font-weight:800}.skip-link:focus{left:0;top:0;z-index:999}

/* Tapa-cloth pattern background — angular geometric */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.04;
  background-image:
    repeating-linear-gradient(45deg,var(--c-tapa) 0,var(--c-tapa) 1px,transparent 1px,transparent 14px),
    repeating-linear-gradient(-45deg,var(--c-tapa) 0,var(--c-tapa) 1px,transparent 1px,transparent 14px);
}
.site-header,main,.site-footer{position:relative;z-index:1}

/* Header — minimal monolithic */
.site-header{background:var(--c-black);border-bottom:1px solid var(--c-border);padding:16px 0;position:sticky;top:0;z-index:40}
.header-row{display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:inline-flex;align-items:center;gap:14px;text-decoration:none}
.brand-mark{font-size:1.6rem;color:var(--c-tapa-hi);line-height:1}
.brand-mark-lg{font-size:2.4rem}
.brand-text strong{display:block;font-family:var(--font-h);font-size:1.3rem;color:var(--c-coconut);letter-spacing:.16em;line-height:1}
.brand-text small{display:block;font-family:var(--font-b);font-size:.7rem;color:var(--c-dim);letter-spacing:.18em;text-transform:uppercase;margin-top:4px}
.nav{display:flex;gap:28px}
.nav a{color:var(--c-coconut-soft);font-family:var(--font-h);font-size:1rem;letter-spacing:.14em;text-transform:uppercase;padding:6px 0;border-bottom:1px solid transparent;transition:border-color var(--trans)}
.nav a:hover{border-bottom-color:var(--c-tapa-hi);color:var(--c-coconut)}
@media(max-width:780px){.nav{display:none}}

/* Buttons — rectangular, monolithic */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;border-radius:0;font-family:var(--font-h);font-size:1rem;border:1px solid transparent;cursor:pointer;transition:all var(--trans);text-decoration:none!important;letter-spacing:.14em;text-transform:uppercase;line-height:1}
.btn-primary{background:var(--c-coconut);color:var(--c-black);border-color:var(--c-coconut)}
.btn-primary:hover{background:var(--c-tapa);color:var(--c-coconut);border-color:var(--c-tapa)}
.btn-outline{background:transparent;color:var(--c-coconut);border-color:var(--c-coconut-soft)}
.btn-outline:hover{background:var(--c-coconut);color:var(--c-black)}
.btn-sm{padding:10px 18px;font-size:.85rem}
.btn-lg{padding:18px 32px;font-size:1.1rem}
.btn-xl{padding:22px 40px;font-size:1.25rem}
.btn-block{display:flex;width:100%}

/* Hero — heavy contrast monolith */
.hero{position:relative;padding:100px 0 110px;text-align:center;border-bottom:1px solid var(--c-border);background:var(--c-black)}
.hero-tapa{position:absolute;inset:0;z-index:0;opacity:.07;pointer-events:none;background-image:
  repeating-linear-gradient(0deg,var(--c-tapa-hi) 0,var(--c-tapa-hi) 2px,transparent 2px,transparent 36px),
  repeating-linear-gradient(60deg,var(--c-tapa) 0,var(--c-tapa) 2px,transparent 2px,transparent 36px),
  repeating-linear-gradient(120deg,var(--c-tapa) 0,var(--c-tapa) 2px,transparent 2px,transparent 36px);
}
.hero-inner{position:relative;z-index:2;max-width:920px}
.eyebrow{display:inline-block;font-family:var(--font-h);font-size:.78rem;color:var(--c-tapa-hi);letter-spacing:.32em;text-transform:uppercase;margin-bottom:24px;padding:8px 18px;border:1px solid var(--c-tapa);background:var(--c-tapa-deep)}
.hero-name{font-family:var(--font-h);font-size:clamp(4rem,12vw,9rem);line-height:.85;color:var(--c-coconut);margin:0;letter-spacing:.04em;text-shadow:none}
.hero-name-sub{display:block;color:var(--c-tapa-hi);font-size:.6em;margin-top:8px;letter-spacing:.12em}
.hero-divider{margin:24px 0;color:var(--c-tapa-hi);letter-spacing:1.2em;font-size:.9rem}
.hero-tag{font-family:var(--font-acc);font-style:italic;font-size:1.3rem;color:var(--c-coconut-soft);max-width:660px;margin:0 auto 28px;line-height:1.5}
.hero-tag strong{font-style:normal;font-family:var(--font-h);color:var(--c-coconut);letter-spacing:.06em}
.hero-trust{display:flex;flex-wrap:wrap;gap:14px 28px;justify-content:center;margin:0 0 36px;padding:0;list-style:none}
.hero-trust li{font-family:var(--font-h);color:var(--c-coconut);font-size:.92rem;letter-spacing:.18em}
.hero-ctas{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}

/* Headings */
h1,h2,h3,h4{font-family:var(--font-h);font-weight:400;color:var(--c-coconut);line-height:1.05;margin:0 0 .4em;letter-spacing:.06em}
h2{font-size:clamp(2.4rem,5vw,4rem);text-transform:uppercase}
h3{font-size:1.4rem;text-transform:uppercase;letter-spacing:.1em}
h4{font-size:.84rem;letter-spacing:.22em;text-transform:uppercase;color:var(--c-tapa-hi);font-weight:400}

/* Sections */
.section{padding:96px 0;border-top:1px solid var(--c-border)}
.section-alt{background:var(--c-bg-2)}
.section-head{text-align:center;margin-bottom:56px}
.section-head .eyebrow{margin-bottom:18px}
.section-head h2{margin-bottom:14px}
.section-head p{font-family:var(--font-acc);font-style:italic;font-size:1.2rem;color:var(--c-coconut-soft);max-width:620px;margin:0 auto;line-height:1.5}

/* Two-col */
.two-col{display:grid;grid-template-columns:1.6fr 1fr;gap:48px;align-items:start}
@media(max-width:880px){.two-col{grid-template-columns:1fr;gap:32px}}
p{margin:0 0 1em;color:var(--c-text)}
p strong{color:var(--c-coconut)}

/* Tag list */
.tag-list{display:flex;flex-wrap:wrap;gap:8px;list-style:none;padding:0;margin:18px 0 0}
.tag{display:inline-block;padding:7px 14px;font-family:var(--font-h);font-size:.78rem;letter-spacing:.16em;color:var(--c-coconut);background:var(--c-tapa-deep);border:1px solid var(--c-tapa)}

/* Quick facts */
.quick-facts{background:var(--c-bg-2);border:1px solid var(--c-tapa);padding:30px;position:relative}
.quick-facts::before,.quick-facts::after{content:"";position:absolute;width:18px;height:18px;border:2px solid var(--c-tapa-hi)}
.quick-facts::before{top:-2px;left:-2px;border-right:none;border-bottom:none}
.quick-facts::after{bottom:-2px;right:-2px;border-left:none;border-top:none}
.quick-facts dl{margin:0;display:grid;grid-template-columns:auto 1fr;gap:12px 18px}
.quick-facts dt{font-family:var(--font-h);font-size:.78rem;color:var(--c-tapa-hi);letter-spacing:.18em;align-self:center}
.quick-facts dd{margin:0;color:var(--c-coconut);font-size:.95rem;align-self:center}
.quick-facts dd a{color:var(--c-coconut);border-bottom:1px solid var(--c-tapa-hi)}

/* Style cards — heavy black blocks */
.styles-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:0}
.style-card{padding:40px 28px;border:1px solid var(--c-border);border-right:none;background:var(--c-black);transition:all var(--trans);position:relative;min-height:240px;display:flex;flex-direction:column}
.style-card:last-child{border-right:1px solid var(--c-border)}
.style-card:hover{background:var(--c-tapa-deep);border-color:var(--c-tapa-hi)}
.style-card .style-mark{font-size:2rem;color:var(--c-tapa-hi);margin-bottom:18px;line-height:1}
.style-card h3{margin-bottom:12px;color:var(--c-coconut)}
.style-card p{color:var(--c-coconut-soft);font-size:.96rem;margin:0;flex:1}
@media(max-width:780px){.style-card{border-right:1px solid var(--c-border);border-bottom:none}.style-card:last-child{border-bottom:1px solid var(--c-border)}}

/* FAQ */
.faq-grid{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:0}
.faq-grid details{background:var(--c-bg-2);border-bottom:1px solid var(--c-border);overflow:hidden}
.faq-grid details:first-child{border-top:1px solid var(--c-border)}
.faq-grid summary{cursor:pointer;padding:22px 22px;font-family:var(--font-h);font-size:1.08rem;color:var(--c-coconut);letter-spacing:.08em;text-transform:uppercase;list-style:none;position:relative;padding-right:50px}
.faq-grid summary::-webkit-details-marker{display:none}
.faq-grid summary::after{content:"▲";position:absolute;right:22px;top:50%;transform:translateY(-50%);color:var(--c-tapa-hi);font-size:.85rem;transition:transform var(--trans)}
.faq-grid details[open] summary::after{transform:translateY(-50%) rotate(180deg)}
.faq-grid details p{padding:0 22px 22px;color:var(--c-coconut-soft);margin:0;font-size:.96rem;line-height:1.7;font-family:var(--font-acc);font-style:italic}

/* Section CTA */
.section-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}

/* CTA section */
.cta-section{padding:100px 0;text-align:center;background:linear-gradient(180deg,var(--c-tapa-deep),var(--c-black));border-top:1px solid var(--c-tapa);border-bottom:1px solid var(--c-tapa)}
.cta-section h2{font-size:clamp(2.4rem,5vw,4rem);margin-bottom:18px;color:var(--c-coconut)}
.cta-section p{font-family:var(--font-acc);font-style:italic;font-size:1.2rem;color:var(--c-coconut-soft);max-width:580px;margin:0 auto 32px}

/* Footer */
.site-footer{background:var(--c-black);border-top:1px solid var(--c-tapa);padding:64px 0 28px}
.footer-grid{display:grid;grid-template-columns:1.3fr 2fr;gap:52px;margin-bottom:36px}
.footer-brand{display:flex;align-items:center;gap:18px}
.footer-brand strong{display:block;font-family:var(--font-h);color:var(--c-coconut);font-size:1.3rem;letter-spacing:.14em}
.footer-brand small{display:block;color:var(--c-dim);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;margin-top:6px}
.footer-links{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.footer-links h4{font-family:var(--font-h);color:var(--c-tapa-hi);margin:0 0 16px}
.footer-links ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px}
.footer-links a,.footer-links li{color:var(--c-coconut-soft);font-size:.92rem;font-family:var(--font-b)}
.footer-links a:hover{color:var(--c-coconut)}
.footer-bottom{border-top:1px solid var(--c-border);padding-top:22px;font-size:.78rem;color:var(--c-dim);text-align:center;font-family:var(--font-acc);font-style:italic}
@media(max-width:780px){.footer-grid{grid-template-columns:1fr}.footer-links{grid-template-columns:1fr 1fr}}

/* Sticky CTA */
.sticky-cta{position:fixed;right:18px;bottom:18px;z-index:50;background:var(--c-coconut);color:var(--c-black);padding:14px 22px;font-family:var(--font-h);font-size:.9rem;letter-spacing:.14em;text-decoration:none!important;border:1px solid var(--c-tapa);transition:all var(--trans)}
.sticky-cta:hover{background:var(--c-tapa);color:var(--c-coconut)}

/* Booking widget */
.booking-widget{position:fixed;left:18px;bottom:18px;z-index:50}
.booking-bubble{background:var(--c-coconut);color:var(--c-black);width:56px;height:56px;border:1px solid var(--c-tapa);cursor:pointer;display:flex;align-items:center;justify-content:center}
.booking-widget.is-open .booking-bubble .bk-open{display:none}
.booking-bubble .bk-close{display:none}
.booking-widget.is-open .booking-bubble .bk-close{display:block}
.booking-panel{position:absolute;left:0;bottom:72px;width:340px;max-width:calc(100vw - 36px);max-height:78vh;overflow-y:auto;background:var(--c-bg-2);border:1px solid var(--c-tapa);padding:22px}
.booking-head{margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--c-tapa)}
.booking-head strong{display:block;font-family:var(--font-h);font-size:1.1rem;color:var(--c-coconut);letter-spacing:.16em}
.booking-head small{display:block;color:var(--c-tapa-hi);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;margin-top:4px}
.booking-form label{display:block;margin-bottom:10px}
.booking-form span{display:block;font-family:var(--font-h);font-size:.78rem;color:var(--c-tapa-hi);letter-spacing:.18em;margin-bottom:5px}
.booking-form input,.booking-form select{width:100%;padding:10px 12px;background:var(--c-black);border:1px solid var(--c-border);color:var(--c-coconut);font-family:var(--font-b);font-size:.92rem;border-radius:0}
.booking-form input:focus,.booking-form select:focus{outline:none;border-color:var(--c-tapa-hi)}
.booking-form input[type="submit"]{background:var(--c-coconut);color:var(--c-black);border:1px solid var(--c-coconut);font-weight:700;cursor:pointer;padding:14px;font-family:var(--font-h);letter-spacing:.14em}
.booking-note{font-family:var(--font-acc);font-style:italic;color:var(--c-dim);font-size:.82rem;margin-top:10px;text-align:center}

/* Gallery */
.gallery-empty{text-align:center;padding:60px 20px;color:var(--c-dim);font-family:var(--font-acc);font-style:italic}
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:0}
