:root {
    --bg:#030303;
    --accent:#00aaff;
    --glass-bg:rgba(255,255,255,0.03);
    --card-border:rgba(255,255,255,0.1);
    --input-bg:rgba(255,255,255,0.05);
    --text-dim:rgba(255,255,255,0.3);
    --unit:clamp(0.7rem,0.95vw,1.6rem);
    --trans-slow:0.7s cubic-bezier(0.4,0,0.2,1);
    --rlg:24px;--rmd:16px;--rp:9999px;
    --sh:0 4px 24px rgba(0,0,0,0.55),0 16px 64px rgba(0,0,0,0.65);
    --e:cubic-bezier(0.16,1,0.3,1);
}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:#000}
::-webkit-scrollbar-thumb{background:#333;border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:#444}
*{margin:0;padding:0;box-sizing:border-box;font-family:'Plus Jakarta Sans',sans-serif;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}
input,textarea{-webkit-user-select:text;user-select:text}
html{scroll-behavior:smooth;font-size:var(--unit)}
body{background:var(--bg);color:white;line-height:1.5;overflow-x:hidden;min-height:100vh}
#star-canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:-1;background:radial-gradient(circle at 5% 50%,rgba(0,170,255,0.15) 0%,transparent 50%),radial-gradient(circle at 95% 50%,rgba(0,170,255,0.15) 0%,transparent 50%),linear-gradient(180deg,#050505 0%,#000 100%)}
.reveal{opacity:0;transform:translateY(1.5rem);transition:opacity 0.7s ease-out,transform 0.7s ease-out}
.reveal.active{opacity:1;transform:translateY(0)}

/* === Nav (ported from texc.me) === */
.nav-wrap{position:fixed;top:1.2rem;left:0;right:0;width:90%;max-width:65rem;margin:0 auto;z-index:2000}
.nav-dock{height:3.8rem;background:rgba(10,10,10,0.2);backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);border:1px solid var(--card-border);border-radius:5rem;display:flex;align-items:center;justify-content:space-between;padding:0 1.4rem;transition:border-color .4s,background .4s}
@media(hover:hover){.nav-dock:hover{border-color:rgba(255,255,255,0.18)}}
.nav-brand{display:flex;align-items:center;gap:0.7rem;cursor:pointer;text-decoration:none;color:white}
.nav-name{font-weight:700;font-size:1rem;letter-spacing:-0.02em;color:white}
.nav-links{display:flex;align-items:center;gap:1.5rem;list-style:none;justify-content:center}
.nl{color:rgba(255,255,255,0.6);text-decoration:none;font-size:0.85rem;font-weight:500;transition:color 0.5s ease,background 0.3s ease;padding:0.4rem 0.9rem;border-radius:5rem;white-space:nowrap;cursor:pointer}
@media(hover:hover){.nl:hover{color:var(--accent);background:rgba(0,170,255,0.06)}}
.nl.act{color:var(--accent);background:rgba(0,170,255,0.08);border:1px solid rgba(0,170,255,0.15)}
.nav-actions{display:flex;align-items:center;gap:0.5rem}

.icon-btn{width:34px;height:34px;border-radius:50%;border:1px solid var(--card-border);background:rgba(255,255,255,0.03);display:grid;place-items:center;font-size:15px;cursor:pointer;transition:background .3s,border-color .3s;color:white}
@media(hover:hover){.icon-btn:hover{background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.18)}}

.hud-curtain{position:fixed;inset:0;background:rgba(2,4,10,0.7);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);z-index:5000;display:flex;align-items:flex-start;justify-content:center;padding-top:140px;opacity:0;pointer-events:none;transition:opacity .3s var(--e)}
.hud-curtain.on{opacity:1;pointer-events:all}
.hud-box{width:min(600px,calc(100% - 32px));background:rgba(14,18,28,0.96);border:1px solid rgba(255,255,255,0.09);border-radius:var(--rlg);box-shadow:var(--sh);overflow:hidden;transform:translateY(-20px) scale(0.95);transition:transform .3s var(--e);backdrop-filter:blur(28px)}
.hud-curtain.on .hud-box{transform:translateY(0) scale(1)}
.hud-input{width:100%;padding:20px;background:transparent;border-bottom:1px solid rgba(255,255,255,0.07);font-size:16px;font-family:'Plus Jakarta Sans',sans-serif;color:#fff;outline:none;border-top:none;border-left:none;border-right:none}
.hud-scroll{max-height:300px;overflow-y:auto}
.hud-opt{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;cursor:pointer;transition:background .2s,color .2s;color:rgba(255,255,255,0.45)}
@media(hover:hover){.hud-opt:hover{background:rgba(255,255,255,0.05);color:#fff}}
.hud-pill{font-size:11px;background:rgba(255,255,255,0.06);padding:2px 8px;border-radius:4px;color:white;font-family:monospace}

header{height:85vh;display:flex;justify-content:center;align-items:center;text-align:center}
.hero-content h1{font-size:5.5rem;font-weight:800;letter-spacing:-0.25rem;margin-bottom:0.8rem;line-height:0.9}
.btn-get-started{padding:1rem 2.5rem;background:var(--accent);color:white;border-radius:5rem;font-weight:700;text-decoration:none;cursor:pointer;border:none;font-size:0.9rem;box-shadow:0 4px 15px rgba(0,170,255,0.3);display:inline-block;transition:0.3s;margin-top:1.2rem}
@media(hover:hover){.btn-get-started:hover{transform:scale(1.05)}}
section{max-width:80rem;margin:3rem auto;padding:4rem 1.2rem 0;text-align:center}
.label{text-transform:uppercase;letter-spacing:0.35rem;font-size:0.85rem;color:var(--accent);display:inline-block;font-weight:800;margin-bottom:1.2rem;transform:skewX(-7deg)}
h2{font-size:2.8rem;margin-bottom:3.5rem;font-weight:800}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem;justify-items:center}
.card,.pricing-card{background:var(--glass-bg);border:1px solid var(--card-border);padding:3.5rem 2.2rem;border-radius:2.2rem;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;max-width:26rem;transition:transform 0.3s cubic-bezier(0.34,1.56,0.64,1),border-color 0.3s ease;position:relative}
@media(hover:hover){.card:hover,.pricing-card:hover{transform:scale(1.05);border-color:var(--accent)}}
.card h3,.pricing-card h3{font-size:1.6rem;margin-bottom:1rem;color:var(--accent)}
.plan-badge{position:absolute;top:0;left:50%;transform:translate(-50%,-50%);background:var(--accent);color:white;padding:0.4rem 1.2rem;border-radius:2rem;font-size:0.75rem;font-weight:800;text-transform:uppercase;letter-spacing:1px;white-space:nowrap;box-shadow:0 4px 10px rgba(0,170,255,0.4)}
.price-tag{font-size:1.4rem;color:white;font-weight:800;margin-bottom:1.2rem}
.feature-list{list-style:none;margin:1.5rem 0}
.feature-list li{font-size:0.85rem;color:#cbd5e1;margin-bottom:0.6rem}
.btn-main{padding:1rem 2.5rem;background:var(--accent);color:white;border-radius:5rem;font-weight:700;cursor:pointer;border:none;font-size:0.9rem;transition:0.3s}
.featured{border:2px solid var(--accent);position:relative}

#booking{position:relative}
#bookingContainer{max-width:38rem;margin:0 auto;text-align:left;position:relative}
#bookingWrap{background:var(--glass-bg);border:1px solid var(--card-border);padding:3rem;border-radius:2.5rem;position:relative;overflow:hidden;transition:height 0.6s cubic-bezier(0.16,1,0.3,1)}
form#bookingForm input,form#bookingForm textarea,.select-btn{width:100%;background:var(--input-bg);border:1px solid var(--card-border);padding:1.2rem;border-radius:1rem;color:white;margin-bottom:1.2rem;outline:none;transition:transform 0.3s ease,border-color 0.3s ease}
form#bookingForm textarea{resize:none;scrollbar-width:thin;scrollbar-color:#333 #000}
form#bookingForm textarea::-webkit-scrollbar{width:4px}
form#bookingForm textarea::-webkit-scrollbar-thumb{background:#333;border-radius:10px}
@media(hover:hover){form#bookingForm input:hover,form#bookingForm textarea:hover,.select-btn:hover{transform:scale(1.02);border-color:var(--accent)}}
.custom-select{position:relative;margin-bottom:1.2rem;cursor:pointer}
.select-btn{display:flex;justify-content:flex-start;align-items:center;font-size:0.9rem;font-weight:600;margin-bottom:0}
.plan-menu{position:absolute;top:110%;left:0;width:100%;max-width:15rem;background:var(--input-bg);backdrop-filter:blur(20px);border:1px solid var(--card-border);border-radius:1rem;z-index:10;opacity:0;visibility:hidden;transition:0.4s;overflow:hidden}
.plan-menu.active{opacity:1;visibility:visible}
.plan-opt{padding:0.6rem 1rem;color:white;transition:0.2s;font-size:0.85rem;border-radius:1rem;margin:0.2rem}
@media(hover:hover){.plan-opt:hover{background:var(--accent)}}
#planInput{position:absolute;width:100%;height:3.5rem;opacity:0;pointer-events:none;top:0;left:0;z-index:-1}

#ticketOverlay{position:absolute;inset:0;background:rgba(0,0,0,0.88);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.5s ease;z-index:10;border-radius:2.5rem}
#ticketOverlay.on{opacity:1;pointer-events:all}
#ticketSent{font-size:22px;font-weight:800;color:white;letter-spacing:-0.3px;opacity:0;transition:opacity 0.4s ease 0.2s}

#postChat{display:flex;flex-direction:column;height:420px}
#postChatMsgs{flex:1;overflow-y:auto;padding:4px 0 16px;display:flex;flex-direction:column;gap:10px;scrollbar-width:thin;scrollbar-color:#333 transparent}
#postChatMsgs::-webkit-scrollbar{width:3px}
#postChatMsgs::-webkit-scrollbar-thumb{background:#333;border-radius:10px}
.pc-msg{max-width:75%;padding:11px 16px;font-size:14px;line-height:1.45;word-wrap:break-word;animation:msgIn 0.3s cubic-bezier(0.34,1.56,0.64,1) forwards}
@keyframes msgIn{from{opacity:0;transform:translateY(8px) scale(0.96)}to{opacity:1;transform:translateY(0) scale(1)}}
.pc-msg.them{align-self:flex-start;background:rgba(255,255,255,0.07);color:#c8d4e0;border-radius:18px 18px 18px 4px}
.pc-msg.me{align-self:flex-end;background:var(--accent);color:white;border-radius:18px 18px 4px 18px}
#postChatInputRow{display:flex;gap:10px;align-items:flex-end;padding-top:16px;border-top:1px solid rgba(255,255,255,0.1)}
#postChatInput{flex:1;padding:12px 16px;background:rgba(0,0,0,0.28);border:1px solid rgba(255,255,255,0.09);border-radius:22px;color:white;font-size:14px;font-family:'Plus Jakarta Sans',sans-serif;resize:none;outline:none;max-height:120px;overflow-y:auto;line-height:1.4;transition:border-color 0.3s;scrollbar-width:none}
#postChatInput::-webkit-scrollbar{display:none}
#postChatInput:focus{border-color:rgba(0,170,255,0.4)}
#postChatInput::placeholder{color:rgba(255,255,255,0.25)}
#postChatSend{width:42px;height:42px;border-radius:50%;flex-shrink:0;background:var(--accent);border:none;cursor:pointer;display:grid;place-items:center;transition:transform 0.2s,background 0.2s;box-shadow:0 4px 14px rgba(0,170,255,0.35)}
@media(hover:hover){#postChatSend:hover{transform:scale(1.08);background:#22bbff}}
#postChatSend:active{transform:scale(0.96)}

footer{width:100%;max-width:80rem;margin:4rem auto 2rem;padding:2.5rem 2rem;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--card-border)}
.footer-left{color:var(--text-dim);font-weight:700;font-size:0.9rem;white-space:nowrap}
.footer-right{display:flex;gap:3rem;align-items:center}
.footer-link{text-decoration:none;color:var(--text-dim);font-weight:700;font-size:0.9rem;text-transform:uppercase;letter-spacing:1px;transition:color 0.3s;cursor:pointer;white-space:nowrap}
@media(hover:hover){.footer-link:hover{color:white}}

@media(orientation:portrait){
    .grid{grid-template-columns:1fr}
    footer{flex-direction:column-reverse;gap:1.5rem;text-align:center}
    .footer-right{gap:2rem;justify-content:center}
    header{height:40vh}
    .btn-get-started{margin-top:0.6rem}
    .hero-content h1{font-size:3.5rem}
    .nav-links{display:none}
}
@media(max-width:968px){
    .nav-links{display:none}
}

/* === Pricing layout: white new price + struck old price + -50% on the right === */
.price-stack{display:flex;align-items:center;justify-content:center;gap:0.7rem;margin-bottom:1.2rem;flex-wrap:wrap}
.price-tag{font-size:1.6rem;color:white;font-weight:800;margin-bottom:0;letter-spacing:-0.02em;line-height:1}
.price-meta{display:flex;align-items:center;gap:0.4rem}
.price-old{font-size:0.85rem;color:rgba(255,255,255,0.45);text-decoration:line-through;font-weight:600;font-family:'Plus Jakarta Sans',sans-serif;line-height:1}
.discount-tag{font-size:0.75rem;color:#e63946;font-weight:700;letter-spacing:0.3px;line-height:1}
.plan-desc{font-size:0.85rem;color:#94a3b8;margin-bottom:1rem;line-height:1.5}