/* Best of Phi Phi — shared stylesheet for venue sub-pages */
:root{
--ink:#0d1f14;--ink2:#143024;--forest:#1d3d2a;--moss:#3a6b47;
--gold:#c9a24b;--gold-lt:#e6cf94;--terra:#bf5d3f;
--cream:#f7f3e9;--sand:#efe8d6;--paper:#fdfbf5;--white:#fff;
--txt:#2a3a2e;--txt-mut:#6f7d70;--line:rgba(29,61,42,.14);
--espresso:#160f0a;--espresso2:#221610;--copper:#c2773f;--copper-lt:#e3a368;
--ff-display:'Fraunces',serif;--ff-body:'Outfit',sans-serif;
--s1:8px;--s2:16px;--s3:32px;--s4:64px;--s5:96px;--s6:128px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--ff-body);background:var(--cream);color:var(--txt);line-height:1.7;overflow-x:hidden;font-weight:300;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
em{font-style:italic}
a{color:inherit}
.wrap{max-width:1180px;margin:0 auto;padding:0 var(--s3)}
h1,h2,h3{font-family:var(--ff-display);font-weight:300;line-height:1.06;letter-spacing:-.01em}

/* lang bar */
.langbar{position:fixed;top:0;left:0;right:0;z-index:300;background:rgba(13,31,20,.86);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);padding:7px 14px;display:flex;align-items:center;justify-content:center;gap:5px;flex-wrap:wrap;border-bottom:1px solid rgba(201,162,75,.14)}
.langbar .globe{font-size:9px;letter-spacing:.3em;color:rgba(201,162,75,.55);margin-right:6px;text-transform:uppercase}
.lbtn{background:transparent;border:1px solid rgba(201,162,75,.16);color:rgba(247,243,233,.55);font-family:var(--ff-body);font-size:9.5px;font-weight:300;letter-spacing:.5px;padding:3px 7px;border-radius:30px;cursor:pointer;text-decoration:none;transition:.3s}
.lbtn:hover{border-color:var(--gold);color:var(--gold)}

/* breadcrumb */
.crumb{padding:54px 0 0;font-size:12px;letter-spacing:.04em;color:var(--txt-mut)}
.crumb a{color:var(--gold);text-decoration:none}
.crumb a:hover{text-decoration:underline}

/* mini hero */
.vhero{position:relative;height:58vh;min-height:420px;margin-top:14px;display:flex;align-items:flex-end;overflow:hidden;background:var(--espresso)}
.vhero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.vhero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,8,5,.15),rgba(13,8,5,.78))}
.vhero-in{position:relative;z-index:2;color:var(--cream);padding:0 0 44px;max-width:1180px;margin:0 auto;width:100%}
.vhero-in .vcat{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-lt);font-weight:500;margin-bottom:14px}
.vhero-in h1{font-size:clamp(34px,6vw,68px);color:var(--cream)}
.vhero-in .vmeta{display:flex;flex-wrap:wrap;gap:18px;margin-top:18px;font-size:13.5px;color:rgba(247,243,233,.82)}
.vhero-in .vrev .st{color:var(--gold-lt);letter-spacing:1px}
.vhero-in .vh .dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--moss);margin-right:7px;box-shadow:0 0 0 3px rgba(58,107,71,.25)}

/* detail */
.vbody{padding:var(--s5) 0}
.vlead{font-family:var(--ff-display);font-weight:300;font-size:clamp(20px,2.8vw,28px);line-height:1.5;color:var(--forest);max-width:820px;margin-bottom:30px}
.vlead b{font-weight:500}
.vtext{max-width:760px;font-size:16px;line-height:1.8;color:var(--txt);margin-bottom:30px}
.vfeat{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:28px;max-width:820px}
.feat{font-size:12.5px;color:var(--txt-mut);border:1px solid var(--line);padding:7px 14px;border-radius:30px}
.feat.gold{border-color:rgba(201,162,75,.5);color:#9a7a2e;background:rgba(201,162,75,.07)}
.feat.cert{border-color:rgba(58,107,71,.45);color:var(--moss);background:rgba(58,107,71,.07);font-weight:500}
.vdisc{font-size:13px;color:var(--txt-mut);background:rgba(29,61,42,.05);border-left:2px solid var(--gold);padding:12px 16px;border-radius:0 4px 4px 0;margin-bottom:28px;max-width:820px;line-height:1.6}
.cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:24px}
.btn{font-family:var(--ff-body);font-size:13.5px;font-weight:500;letter-spacing:.02em;padding:13px 26px;border-radius:34px;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:.32s;cursor:pointer;border:0}
.btn-fill{background:var(--forest);color:var(--cream)}
.btn-fill:hover{background:var(--ink2);transform:translateY(-2px)}
.btn-line{background:transparent;color:var(--forest);border:1px solid var(--line)}
.btn-line:hover{border-color:var(--forest);background:rgba(29,61,42,.04)}
.btn-gold{background:var(--gold);color:var(--ink)}.btn-gold:hover{background:var(--gold-lt);transform:translateY(-2px)}
.vpay{display:flex;flex-wrap:wrap;gap:7px;align-items:center;margin-top:8px}
.vpay .pk{font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-right:4px}
.vpay .pl{font-size:10px;letter-spacing:.06em;color:var(--txt-mut);border:1px solid var(--line);padding:4px 9px;border-radius:5px;background:var(--paper)}
.vpay .soon{font-size:10px;color:var(--txt-mut);opacity:.7}

/* copper dark (scubar) */
body.dark{background:var(--espresso);color:rgba(247,243,233,.84)}
body.dark .vlead{color:var(--cream)}
body.dark .vtext{color:rgba(247,243,233,.8)}
body.dark .feat{border-color:rgba(194,119,63,.3);color:rgba(247,243,233,.7)}
body.dark .feat.gold{border-color:rgba(194,119,63,.55);color:var(--copper-lt);background:rgba(194,119,63,.1)}
body.dark .btn-fill{background:var(--copper);color:#1a0f08}
body.dark .btn-fill:hover{background:var(--copper-lt)}
body.dark .btn-line{color:var(--copper-lt);border-color:rgba(194,119,63,.4)}
body.dark .btn-line:hover{border-color:var(--copper-lt);background:rgba(194,119,63,.08)}
body.dark .crumb{color:rgba(247,243,233,.55)}body.dark .crumb a{color:var(--copper-lt)}
body.dark .collection{background:var(--espresso2);border-color:rgba(194,119,63,.2)}
body.dark .collection h2,body.dark .ccard .cn{color:var(--cream)}
body.dark .ccard{background:rgba(255,255,255,.03);border-color:rgba(194,119,63,.2)}
body.dark .vpay .pl{border-color:rgba(194,119,63,.3);color:rgba(247,243,233,.6);background:rgba(255,255,255,.02)}

/* collection cross-links */
.collection{padding:var(--s5) 0;background:var(--paper);border-top:1px solid var(--line)}
.collection .eyebrow{font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);text-align:center;display:block;margin-bottom:14px}
.collection h2{text-align:center;font-size:clamp(26px,4vw,40px);color:var(--forest);margin-bottom:var(--s4)}
.cgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:1080px;margin:0 auto}
.ccard{display:block;text-decoration:none;background:var(--white);border:1px solid var(--line);border-radius:6px;padding:22px 22px;transition:.35s}
.ccard:hover{transform:translateY(-3px);box-shadow:0 22px 46px -34px rgba(29,61,42,.5);border-color:rgba(201,162,75,.4)}
.ccard .ck{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.ccard .cn{font-family:var(--ff-display);font-size:20px;color:var(--forest);line-height:1.15}
.ccard .cd{font-size:12.5px;color:var(--txt-mut);margin-top:6px}

/* footer */
.foot{background:var(--ink);color:var(--cream);text-align:center;padding:var(--s5) 24px var(--s4)}
.foot-logo{font-family:var(--ff-display);font-weight:300;font-size:32px}
.foot-logo em{color:var(--gold-lt)}
.foot-tag{font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);margin-top:10px}
.foot-rule{width:56px;height:1px;background:var(--gold);opacity:.5;margin:26px auto}
.foot-loc{font-size:14px;color:rgba(247,243,233,.7);line-height:1.8}
.foot-wa{display:inline-flex;margin-top:24px;background:var(--gold);color:var(--ink);padding:13px 26px;border-radius:34px;text-decoration:none;font-weight:500;font-size:14px;transition:.3s}
.foot-wa:hover{background:var(--gold-lt);transform:translateY(-2px)}
.foot-fine{margin-top:26px;font-size:12px;color:rgba(247,243,233,.45);line-height:1.8}
.foot-fine a{color:rgba(247,243,233,.6);text-decoration:none}

.wafloat{position:fixed;right:18px;bottom:22px;z-index:240;width:54px;height:54px;border-radius:50%;background:var(--gold);color:var(--ink);display:flex;align-items:center;justify-content:center;font-size:24px;text-decoration:none;box-shadow:0 10px 30px -8px rgba(201,162,75,.6);transition:.3s}
.wafloat:hover{transform:scale(1.08)}

body[dir="rtl"] .vdisc{border-left:0;border-right:2px solid var(--gold);border-radius:4px 0 0 4px}

@media(max-width:860px){
.wrap{padding:0 22px}
.vhero{height:48vh}
.cgrid{grid-template-columns:1fr}
.wafloat{bottom:18px}
}

/* ===== sub-page rich detail blocks ===== */
.vsec{margin:var(--s4) 0}
.vsec h2.vh{font-family:var(--ff-display);font-weight:400;font-size:clamp(22px,3vw,30px);color:var(--forest);margin-bottom:18px}
body.dark .vsec h2.vh{color:var(--cream)}
.hl-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:10px 26px;max-width:820px}
.hl-list li{position:relative;padding-left:22px;font-size:15px;color:var(--txt);line-height:1.5}
.hl-list li::before{content:"";position:absolute;left:0;top:9px;width:8px;height:8px;border-radius:50%;background:var(--gold)}
body.dark .hl-list li{color:rgba(247,243,233,.82)}
body.dark .hl-list li::before{background:var(--copper-lt)}
.info-card{border:1px solid var(--line);border-radius:8px;padding:28px 30px;max-width:820px;background:var(--paper)}
body.dark .info-card{background:var(--espresso2);border-color:rgba(194,119,63,.22)}
.info-grid{display:grid;grid-template-columns:130px 1fr;gap:14px 20px;margin:0}
.info-grid dt{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);padding-top:3px}
.info-grid dd{font-size:15px;color:var(--txt);line-height:1.55}
body.dark .info-grid dd{color:rgba(247,243,233,.85)}
.info-grid dd a{color:var(--forest);font-weight:500;text-decoration:none;border-bottom:1px solid var(--line)}
body.dark .info-grid dd a{color:var(--copper-lt);border-color:rgba(194,119,63,.3)}
.info-card .map-btn{margin-top:22px}
.subfaq{max-width:820px}
.subfaq .qa2{border-bottom:1px solid var(--line);padding:20px 0}
.subfaq .qa2:last-child{border-bottom:0}
.subfaq .qa2 h3{font-family:var(--ff-display);font-weight:400;font-size:clamp(17px,2.2vw,20px);color:var(--forest);margin-bottom:8px}
body.dark .subfaq .qa2 h3{color:var(--cream)}
.subfaq .qa2 p{font-size:15px;color:var(--txt);line-height:1.7}
body.dark .subfaq .qa2 p{color:rgba(247,243,233,.8)}
@media(max-width:860px){.hl-list{grid-template-columns:1fr}.info-grid{grid-template-columns:1fr;gap:4px 0}.info-grid dt{padding-top:14px}}

/* ===== embedded map ===== */
.vmap{width:100%;max-width:820px;height:340px;border:1px solid var(--line);border-radius:8px;margin-top:18px;display:block;filter:saturate(.92)}
body.dark .vmap{border-color:rgba(194,119,63,.25)}

/* ===== Island Journal ===== */
.journal-hero{padding:120px 0 var(--s4);text-align:center}
.journal-hero .eyebrow{font-size:11px;letter-spacing:.42em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:18px}
.journal-hero h1{font-size:clamp(40px,7vw,78px);color:var(--forest);line-height:1}
.journal-hero p{margin:22px auto 0;max-width:640px;color:var(--txt-mut);font-size:16px}
.jgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;max-width:1080px;margin:0 auto var(--s6)}
.jcard{display:block;text-decoration:none;background:var(--white);border:1px solid var(--line);border-radius:8px;overflow:hidden;transition:.35s}
.jcard:hover{transform:translateY(-4px);box-shadow:0 26px 54px -38px rgba(29,61,42,.55);border-color:rgba(201,162,75,.4)}
.jcard .jc-body{padding:28px 30px 30px}
.jcard .jc-tag{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:500}
.jcard h2{font-family:var(--ff-display);font-weight:400;font-size:24px;color:var(--forest);line-height:1.2;margin:12px 0 10px}
.jcard p{font-size:14.5px;color:var(--txt-mut);line-height:1.65}
.jcard .jc-more{margin-top:14px;font-size:12px;letter-spacing:.04em;color:var(--terra);font-weight:500}
.jcard.soon{opacity:.6;pointer-events:none}
/* article */
.article{max-width:760px;margin:0 auto;padding:110px 0 var(--s5)}
.article .a-tag{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);font-weight:500}
.article h1{font-family:var(--ff-display);font-weight:300;font-size:clamp(34px,5.5vw,56px);color:var(--forest);line-height:1.06;margin:16px 0 18px;letter-spacing:-.01em}
.article .a-meta{font-size:13px;color:var(--txt-mut);margin-bottom:30px}
.article .a-lead{font-family:var(--ff-display);font-weight:300;font-size:clamp(19px,2.6vw,25px);line-height:1.5;color:var(--forest);margin-bottom:32px}
.article h2{font-family:var(--ff-display);font-weight:400;font-size:clamp(24px,3.4vw,32px);color:var(--forest);margin:44px 0 14px;line-height:1.15}
.article h3{font-family:var(--ff-display);font-weight:500;font-size:20px;color:var(--forest);margin:30px 0 8px}
.article p{font-size:16.5px;line-height:1.85;color:var(--txt);margin-bottom:18px}
.article ul{margin:0 0 18px 22px}.article li{font-size:16.5px;line-height:1.8;color:var(--txt);margin-bottom:8px}
.article a{color:var(--terra);font-weight:500;text-decoration:none;border-bottom:1px solid rgba(191,93,63,.3)}
.article a:hover{border-color:var(--terra)}
.article .callout{background:var(--paper);border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:0 8px 8px 0;padding:20px 24px;margin:28px 0;font-size:15.5px;line-height:1.7}
.article .callout b{color:var(--forest)}
.article .a-faq{margin-top:46px;border-top:1px solid var(--line);padding-top:30px}
.article .a-faq .qa2{border-bottom:1px solid var(--line);padding:20px 0}
.article .a-faq .qa2:last-child{border-bottom:0}
.article .a-faq h3{margin:0 0 8px}
.article .a-faq p{margin:0;font-size:15.5px;color:var(--txt)}
@media(max-width:860px){.jgrid{grid-template-columns:1fr}}

/* ===== venue menu / price list ===== */
.menu-block{max-width:820px}
.menu-sub{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin:26px 0 12px;font-weight:500}
.drink{display:flex;justify-content:space-between;align-items:baseline;gap:18px;padding:13px 0;border-bottom:1px dashed var(--line)}
.drink .d-l{flex:1}
.drink .d-n{font-family:var(--ff-display);font-size:18px;color:var(--forest);font-weight:400}
.drink .d-d{font-size:13px;color:var(--txt-mut);line-height:1.5;margin-top:3px}
.drink .d-p{font-family:var(--ff-display);font-size:16px;color:#9a7a2e;white-space:nowrap;font-weight:500}
body.dark .drink{border-color:rgba(194,119,63,.22)}
body.dark .drink .d-n{color:var(--cream)}
body.dark .drink .d-d{color:rgba(247,243,233,.6)}
body.dark .drink .d-p{color:var(--copper-lt)}
.happy{background:rgba(201,162,75,.09);border:1px solid rgba(201,162,75,.32);border-radius:8px;padding:22px 26px;margin:18px 0;max-width:820px}
body.dark .happy{background:rgba(194,119,63,.1);border-color:rgba(194,119,63,.38)}
.happy .h-t{font-family:var(--ff-display);font-size:22px;color:#9a7a2e;margin-bottom:6px}
body.dark .happy .h-t{color:var(--copper-lt)}
.happy .h-d{font-size:14.5px;color:var(--txt);line-height:1.65}
body.dark .happy .h-d{color:rgba(247,243,233,.82)}
.menu-note{font-size:13px;color:var(--txt-mut);font-style:italic;margin-top:16px;max-width:820px;line-height:1.6}
.menu-note a{color:var(--terra);font-weight:500;text-decoration:none;border-bottom:1px solid rgba(191,93,63,.3)}
body.dark .menu-note a{color:var(--copper-lt);border-color:rgba(194,119,63,.3)}
