/* ============================================================
 * BUILD: assets/css/public.css — หน้าเว็บลูกค้า
 * ธีม: DARK PREMIUM · glass + neon glow · navy/coral/violet
 * ============================================================ */
:root{
  --bg:#0a0c16; --bg-soft:#0f1220;
  --surface:rgba(255,255,255,.045); --surface-2:rgba(255,255,255,.075);
  --border:rgba(255,255,255,.09); --border-2:rgba(255,255,255,.14);
  --ink:#eef1f8; --ink-soft:#cdd3e4; --muted:#919bb4;
  --coral:#ff3b5c; --coral-d:#e02748; --violet:#8b5cff; --gold:#ffd166; --ok:#34d399;
  --radius:18px;
  --glow-coral:0 12px 40px rgba(255,59,92,.35);
  --glow-soft:0 18px 60px rgba(0,0,0,.5);
  --grad:linear-gradient(115deg,var(--coral),#ff6b8a 45%,var(--violet));
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Poppins',-apple-system,'Segoe UI','Sarabun',Tahoma,sans-serif;
  color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;
  padding-bottom:80px;position:relative;
  background:var(--bg);
}
/* แสง ambient เรืองๆ ด้านหลัง */
body::before{
  content:'';position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(620px 380px at 12% -4%, rgba(255,59,92,.22), transparent 60%),
    radial-gradient(680px 460px at 96% 6%, rgba(139,92,255,.20), transparent 60%),
    radial-gradient(900px 700px at 50% 108%, rgba(139,92,255,.10), transparent 60%),
    var(--bg);
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:1180px;margin:0 auto;padding:0 18px}

/* ---------- header ---------- */
.topbar{
  position:sticky;top:0;z-index:50;
  background:rgba(10,12,22,.72);backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid var(--border);
}
.topbar .inner{display:flex;align-items:center;justify-content:space-between;height:66px}
.brand{display:flex;align-items:center;gap:12px;font-weight:800;font-size:19px;letter-spacing:.3px;color:#fff}
.brand .logo{width:40px;height:40px;border-radius:13px;background:var(--grad);
  display:grid;place-items:center;font-size:21px;box-shadow:var(--glow-coral)}
.brand small{display:block;font-size:10.5px;font-weight:400;color:var(--muted);letter-spacing:0}
.top-actions{display:flex;gap:10px;align-items:center}
.btn-login{background:var(--surface-2);color:#fff;padding:10px 20px;border-radius:30px;
  font-size:14px;font-weight:600;border:1px solid var(--border-2);transition:.2s}
.btn-login:hover{background:var(--grad);border-color:transparent;box-shadow:var(--glow-coral)}

/* ---------- hero / banner ---------- */
.hero{padding:18px 0 4px}
.banner-slider{position:relative;border-radius:22px;overflow:hidden;
  box-shadow:var(--glow-soft);border:1px solid var(--border)}
.banner-track{display:flex;transition:transform .55s cubic-bezier(.4,0,.2,1)}
.banner-track .slide{min-width:100%;height:clamp(150px,24vw,270px);position:relative}
.banner-track .slide img{width:100%;height:100%;object-fit:cover}
.banner-dots{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);display:flex;gap:8px}
.banner-dots span{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.45);cursor:pointer;transition:.2s}
.banner-dots span.on{background:#fff;width:26px;border-radius:10px;box-shadow:0 0 12px rgba(255,255,255,.6)}

/* hero แบบไม่มีแบนเนอร์ (gradient mesh) */
.hero-fallback{height:clamp(150px,24vw,270px);border-radius:22px;position:relative;overflow:hidden;
  display:grid;place-items:center;text-align:center;color:#fff;border:1px solid var(--border);
  background:
    radial-gradient(420px 300px at 20% 20%, rgba(255,59,92,.5), transparent 60%),
    radial-gradient(420px 300px at 82% 78%, rgba(139,92,255,.55), transparent 60%),
    linear-gradient(135deg,#171a2e,#0d0f1d)}
.hero-fallback h1{font-size:clamp(26px,5vw,46px);font-weight:800;letter-spacing:.5px;
  text-shadow:0 6px 30px rgba(0,0,0,.5)}
.hero-fallback p{color:var(--ink-soft);margin-top:6px;font-size:15px}

/* แถบCTA ใต้แบนเนอร์ */
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:18px}
.hero-cta a{padding:13px 26px;border-radius:40px;font-weight:700;font-size:15px;transition:.2s;
  border:1px solid var(--border-2);background:var(--surface-2);color:#fff}
.hero-cta a.primary{background:var(--grad);border-color:transparent;box-shadow:var(--glow-coral)}
.hero-cta a:hover{transform:translateY(-2px)}

/* ---------- quick menu ---------- */
.quickmenu{display:grid;grid-template-columns:repeat(4,1fr);gap:13px;margin:26px 0}
.qm-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:20px 10px;text-align:center;transition:.22s;backdrop-filter:blur(8px)}
.qm-item:hover{transform:translateY(-4px);border-color:var(--border-2);
  background:var(--surface-2);box-shadow:0 16px 40px rgba(139,92,255,.18)}
.qm-item .ic{font-size:28px;margin-bottom:8px;filter:drop-shadow(0 4px 12px rgba(255,59,92,.4))}
.qm-item span{font-size:13.5px;font-weight:600;color:var(--ink-soft)}

/* ---------- section heading ---------- */
.sec-head{display:flex;align-items:center;justify-content:space-between;margin:34px 0 18px}
.sec-head h2{font-size:23px;font-weight:800;display:flex;align-items:center;gap:11px;color:#fff}
.sec-head h2::before{content:'';width:6px;height:24px;background:var(--grad);border-radius:4px;
  box-shadow:0 0 16px rgba(255,59,92,.6)}
.sec-head a{font-size:13px;color:var(--muted);font-weight:600}

/* ---------- event grid ---------- */
.event-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}
.ev-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;transition:.28s;display:flex;flex-direction:column;backdrop-filter:blur(8px)}
.ev-card:hover{transform:translateY(-6px);border-color:var(--coral);
  box-shadow:0 22px 50px rgba(255,59,92,.22)}
.ev-cover{aspect-ratio:1/1;position:relative;overflow:hidden;background:#1a1d2e}
.ev-cover img{width:100%;height:100%;object-fit:cover;transition:.5s}
.ev-card:hover .ev-cover img{transform:scale(1.07)}
.ev-cover::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(10,12,22,.55),transparent 45%)}
.ev-tag{position:absolute;top:12px;left:12px;z-index:2;background:var(--grad);color:#fff;font-size:11px;
  font-weight:800;padding:6px 13px;border-radius:30px;box-shadow:var(--glow-coral);letter-spacing:.3px}
.ev-body{padding:16px 17px 18px;flex:1;display:flex;flex-direction:column}
.ev-body h3{font-size:16px;font-weight:700;color:#fff;margin-bottom:7px;line-height:1.35;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ev-meta{font-size:12.5px;color:var(--muted);display:flex;align-items:center;gap:6px;margin-bottom:13px}
.ev-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between}
.ev-price{font-weight:800;color:#fff;font-size:18px}
.ev-price small{font-weight:400;color:var(--muted);font-size:11px}
.ev-btn{background:var(--surface-2);border:1px solid var(--border-2);color:#fff;font-size:13px;
  font-weight:700;padding:9px 17px;border-radius:30px;transition:.2s}
.ev-card:hover .ev-btn{background:var(--grad);border-color:transparent;box-shadow:var(--glow-coral)}

/* ---------- feature strip ---------- */
.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin:34px 0}
.feat{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:20px;backdrop-filter:blur(8px)}
.feat .fic{font-size:26px;margin-bottom:8px}
.feat h4{color:#fff;font-size:15px;font-weight:700;margin-bottom:4px}
.feat p{color:var(--muted);font-size:13px;line-height:1.55}

/* ---------- site footer ---------- */
.site-foot{margin:46px 0 10px;padding-top:26px;border-top:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;color:var(--muted);font-size:13px}
.site-foot .sf-brand{color:#fff;font-weight:800;font-size:16px;display:flex;align-items:center;gap:8px}

/* ---------- event detail ---------- */
.detail-wrap{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin:26px 0}
.detail-cover{border-radius:22px;overflow:hidden;box-shadow:var(--glow-soft);position:sticky;top:86px;border:1px solid var(--border)}
.detail-cover img{width:100%;aspect-ratio:1/1;object-fit:cover}
.detail-info h1{font-size:28px;font-weight:800;color:#fff;margin-bottom:12px;line-height:1.3}
.detail-info .meta-row{display:flex;gap:18px;flex-wrap:wrap;margin-bottom:18px;color:var(--muted);font-size:14px}
.detail-info .meta-row b{color:var(--ink)}
.detail-desc{background:var(--surface);border:1px solid var(--border);border-radius:16px;
  padding:18px 20px;font-size:14px;color:var(--ink-soft);white-space:pre-line;margin-bottom:22px;backdrop-filter:blur(8px)}

/* ---------- packages ---------- */
.pkg-list{display:flex;flex-direction:column;gap:13px}
.pkg{background:var(--surface);border:1.5px solid var(--border);border-radius:16px;padding:16px 18px;
  display:flex;align-items:center;gap:16px;transition:.2s;backdrop-filter:blur(8px)}
.pkg.sel{border-color:var(--coral);box-shadow:0 12px 30px rgba(255,59,92,.2);background:var(--surface-2)}
.pkg .pkg-info{flex:1}
.pkg .pkg-info h4{font-size:15.5px;font-weight:700;color:#fff}
.pkg .pkg-info p{font-size:12.5px;color:var(--muted)}
.pkg .pkg-price{text-align:right}
.pkg .pkg-price .now{font-weight:800;color:var(--coral);font-size:18px}
.pkg .pkg-price .old{font-size:12px;color:var(--muted);text-decoration:line-through}
.pkg .soldout{font-size:12px;font-weight:700;color:var(--muted);background:rgba(255,255,255,.06);padding:6px 12px;border-radius:8px}
.stepper{display:flex;align-items:center;border:1.5px solid var(--border-2);border-radius:10px;overflow:hidden}
.stepper button{width:34px;height:34px;border:0;background:var(--surface-2);font-size:18px;font-weight:700;color:#fff;cursor:pointer;transition:.15s}
.stepper button:hover{background:var(--coral)}
.stepper input{width:42px;height:34px;border:0;text-align:center;font-size:15px;font-weight:700;background:transparent;color:#fff;
  border-left:1.5px solid var(--border-2);border-right:1.5px solid var(--border-2);-moz-appearance:textfield}
.stepper input::-webkit-outer-spin-button,.stepper input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}

/* ---------- summary bar ---------- */
.sumbar{position:sticky;bottom:84px;background:rgba(15,18,32,.92);border:1px solid var(--border-2);border-radius:18px;
  padding:16px 20px;margin-top:22px;box-shadow:var(--glow-soft);backdrop-filter:blur(16px);
  display:flex;align-items:center;justify-content:space-between;gap:14px}
.sumbar .total small{font-size:12px;color:var(--muted);display:block}
.sumbar .total b{font-size:25px;color:var(--coral)}
.btn-book{background:var(--grad);color:#fff;border:0;padding:15px 32px;border-radius:14px;font-size:16px;font-weight:800;
  cursor:pointer;transition:.2s;white-space:nowrap;box-shadow:var(--glow-coral)}
.btn-book:hover{filter:brightness(1.08);transform:translateY(-2px)}
.btn-book:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}

/* ---------- form ---------- */
.field{margin-bottom:15px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--ink-soft);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1.5px solid var(--border-2);
  border-radius:11px;font-size:14.5px;font-family:inherit;transition:.15s;background:var(--surface-2);color:#fff}
.field input::placeholder,.field textarea::placeholder{color:var(--muted)}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--coral);box-shadow:0 0 0 4px rgba(255,59,92,.18)}
.field select option{background:#11142a;color:#fff}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:13px}

/* ---------- bottom nav ---------- */
.botnav{position:fixed;bottom:0;left:0;right:0;z-index:60;display:flex;
  background:rgba(12,14,26,.82);backdrop-filter:blur(20px) saturate(150%);
  border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom)}
.botnav a{flex:1;text-align:center;padding:10px 4px;font-size:10.5px;color:var(--muted);font-weight:600;transition:.18s}
.botnav a .ic{font-size:21px;display:block;margin-bottom:2px}
.botnav a.on,.botnav a:hover{color:#fff}
.botnav a.on .ic{filter:drop-shadow(0 0 10px rgba(255,59,92,.7))}
.botnav .center{position:relative;top:-18px}
.botnav .center .ic{width:56px;height:56px;background:var(--grad);color:#fff;border-radius:50%;
  display:grid;place-items:center;margin:0 auto 2px;font-size:25px;box-shadow:var(--glow-coral);
  border:3px solid var(--bg)}

/* ---------- ticket result ---------- */
.ticket-result{max-width:440px;margin:30px auto;background:var(--surface);border:1px solid var(--border);
  border-radius:22px;overflow:hidden;box-shadow:var(--glow-soft);backdrop-filter:blur(10px)}
.tr-head{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:30px 24px;text-align:center}
.tr-head .check{width:70px;height:70px;background:rgba(255,255,255,.2);border-radius:50%;display:grid;place-items:center;font-size:38px;margin:0 auto 14px}
.tr-body{padding:26px 24px}
.tr-qr{text-align:center;padding:16px 0}
.tr-qr img,.tr-qr canvas{margin:0 auto;border-radius:12px;background:#fff;padding:8px}
.tr-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px dashed var(--border);font-size:14px}
.tr-row:last-child{border:0}
.tr-row span{color:var(--muted)}
.tr-row b{color:#fff}

/* ---------- toast / loading ---------- */
.toast{position:fixed;bottom:96px;left:50%;transform:translateX(-50%) translateY(20px);
  background:#11142a;color:#fff;padding:13px 24px;border-radius:30px;font-size:14px;font-weight:600;
  z-index:200;opacity:0;pointer-events:none;transition:.3s;box-shadow:var(--glow-soft);border:1px solid var(--border-2)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.spinner{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;
  animation:spin .7s linear infinite;display:inline-block;vertical-align:middle}
@keyframes spin{to{transform:rotate(360deg)}}

.empty{text-align:center;padding:60px 20px;color:var(--muted);background:var(--surface);
  border:1px dashed var(--border-2);border-radius:18px}
.empty .ic{font-size:50px;opacity:.5;margin-bottom:12px}

/* ---------- responsive ---------- */
@media(max-width:860px){.detail-wrap{grid-template-columns:1fr;gap:20px}.detail-cover{position:static}}
@media(max-width:640px){
  .quickmenu{grid-template-columns:repeat(2,1fr)}
  .sec-head h2{font-size:19px}
  .detail-info h1{font-size:22px}
  .row2{grid-template-columns:1fr}
  .sumbar{flex-direction:column;align-items:stretch;bottom:88px}
  .sumbar .btn-book{width:100%}
  .brand small{display:none}
}

/* ============================================================
 * auth + account (ธีมเข้ม)
 * ============================================================ */
.auth-wrap{max-width:460px;margin:28px auto;padding:0 6px}
.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--glow-soft);padding:30px 26px;backdrop-filter:blur(12px)}
.auth-card h1{font-size:25px;color:#fff;margin:0 0 4px}
.auth-card .sub{color:var(--muted);font-size:14px;margin:0 0 20px}
.auth-err{background:rgba(239,68,68,.12);color:#fca5a5;border:1px solid rgba(239,68,68,.3);padding:10px 14px;border-radius:11px;font-size:14px;margin-bottom:14px}
.auth-form .afg{margin-bottom:13px}
.auth-form label{display:block;font-size:13px;font-weight:600;color:var(--ink-soft);margin-bottom:5px}
.auth-form input{width:100%;padding:13px 14px;border:1.5px solid var(--border-2);border-radius:12px;font-family:inherit;font-size:15px;background:var(--surface-2);color:#fff;transition:.15s}
.auth-form input::placeholder{color:var(--muted)}
.auth-form input:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 4px rgba(255,59,92,.16)}
.frow2{display:flex;gap:12px}
.frow2 .afg{flex:1}
.btn-auth{width:100%;border:none;cursor:pointer;margin-top:6px;background:var(--grad);color:#fff;padding:14px;border-radius:12px;font-family:inherit;font-size:16px;font-weight:800;box-shadow:var(--glow-coral);transition:.15s}
.btn-auth:hover{transform:translateY(-2px)}
.auth-foot{text-align:center;margin-top:16px;font-size:14px;color:var(--muted)}
.auth-foot a{color:var(--coral);font-weight:700}
.login-hint{background:rgba(139,92,255,.12);border:1px solid rgba(139,92,255,.3);color:#c4b5fd;padding:9px 14px;border-radius:11px;font-size:13.5px;margin-bottom:14px}
.login-hint a{color:#c4b5fd;font-weight:700}

.acc{max-width:760px;margin:20px auto;padding:0 4px}
.acc-flash{padding:11px 15px;border-radius:12px;font-size:14px;margin-bottom:14px}
.acc-flash.ok{background:rgba(52,211,153,.12);color:#6ee7b7;border:1px solid rgba(52,211,153,.3)}
.acc-flash.err{background:rgba(239,68,68,.12);color:#fca5a5;border:1px solid rgba(239,68,68,.3)}
.memcard{background:linear-gradient(125deg,#1a1d35,#14162a);border:1px solid var(--border-2);color:#fff;border-radius:20px;padding:22px;box-shadow:var(--glow-soft);position:relative;overflow:hidden}
.memcard::after{content:'';position:absolute;top:-40px;right:-30px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(255,59,92,.35),transparent 70%)}
.memcard-top{display:flex;align-items:center;gap:14px;position:relative;z-index:1}
.memav{width:56px;height:56px;border-radius:50%;background:var(--grad);display:grid;place-items:center;font-size:25px;font-weight:800;flex-shrink:0;box-shadow:var(--glow-coral)}
.memname{font-size:18px;font-weight:800}
.memcode{font-size:13px;color:var(--muted);margin-top:2px}
.memout{margin-left:auto;color:#fff;font-size:13px;background:var(--surface-2);border:1px solid var(--border-2);padding:8px 14px;border-radius:10px;text-decoration:none;white-space:nowrap}
.memstats{display:flex;gap:10px;margin-top:18px;position:relative;z-index:1}
.memstats>div{flex:1;background:rgba(255,255,255,.06);border:1px solid var(--border);border-radius:13px;padding:12px;text-align:center;font-size:12.5px;color:var(--ink-soft)}
.memstats>div span{display:block;font-size:20px;font-weight:800;margin-bottom:2px;color:#fff}
.acc-h{font-size:17px;color:#fff;margin:26px 0 12px;font-weight:800}
.acc-empty{background:var(--surface);border:1px dashed var(--border-2);border-radius:15px;padding:28px;text-align:center;color:var(--muted)}
.acc-empty a{color:var(--coral);font-weight:800}
.bcard{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:17px;margin-bottom:12px;backdrop-filter:blur(8px)}
.bcard-head{display:flex;justify-content:space-between;gap:12px}
.bcode{font-size:12px;color:var(--muted)}
.bevent{font-size:16px;font-weight:800;color:#fff;margin:2px 0}
.bdate{font-size:13px;color:var(--muted)}
.btotal{font-size:18px;font-weight:800;color:var(--coral);margin-top:4px}
.bpay{display:inline-block;margin-top:11px;background:var(--grad);color:#fff;padding:10px 18px;border-radius:11px;text-decoration:none;font-weight:800;font-size:14px;box-shadow:var(--glow-coral)}
.tks{margin-top:14px;border-top:1px dashed var(--border);padding-top:13px}
.tks-label{font-size:13px;font-weight:800;color:#fff;margin-bottom:9px}
.tk{display:flex;align-items:center;gap:13px;padding:9px 0;border-bottom:1px solid var(--border)}
.tk:last-child{border-bottom:none}
.tk-qr{width:72px;height:72px;flex-shrink:0;background:#fff;border-radius:8px;overflow:hidden;padding:4px}
.tk-qr img,.tk-qr canvas{display:block}
.tk-code{font-family:monospace;font-size:14px;font-weight:700;color:#fff;letter-spacing:.5px}
.tk-st{font-size:12px;font-weight:700;margin-top:4px;display:inline-block;padding:3px 10px;border-radius:20px}
.tk-issued{background:rgba(59,130,246,.18);color:#93c5fd}
.tk-activated{background:rgba(52,211,153,.18);color:#6ee7b7}
.tk-used{background:rgba(255,255,255,.08);color:var(--muted)}
.prof-form .afg{margin-bottom:13px}
.prof-form label{display:block;font-size:13px;font-weight:700;color:var(--ink-soft);margin-bottom:6px}
.prof-form input{width:100%;padding:12px 14px;border:1.5px solid var(--border-2);border-radius:12px;font-family:inherit;font-size:15px;background:var(--surface-2);color:#fff}
.prof-form input:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 4px rgba(255,59,92,.16)}
.prof-form input:disabled{background:rgba(255,255,255,.04);color:var(--muted)}
@media(max-width:560px){.frow2{flex-direction:column;gap:0}.memstats{flex-wrap:wrap}}

/* ============================================================
 * ✨ MOTION & POLISH — ปุ่มดิ้นได้ · กรอบไล่สี · nav เด่น
 * ============================================================ */
@keyframes gradShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes pulseGlow{0%,100%{box-shadow:0 10px 30px rgba(255,59,92,.5),0 0 0 0 rgba(255,59,92,.35)}
  50%{box-shadow:0 14px 48px rgba(139,92,255,.7),0 0 0 10px rgba(255,59,92,0)}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
@keyframes flowLine{0%{background-position:0% 0}100%{background-position:200% 0}}
@keyframes ringSpin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}
@keyframes shimmer{0%{transform:translateX(-120%)}60%,100%{transform:translateX(220%)}}

/* ปุ่มหลักทั้งหมด: gradient ไหลตลอด + แสง shimmer วิ่งตอน hover */
.btn-book,.btn-auth,.bpay,.hero-cta a.primary,.btn-login:hover,.ev-card:hover .ev-btn{
  background:linear-gradient(115deg,#ff3b5c,#ff6b8a,#8b5cff,#ff3b5c)!important;
  background-size:240% 240%!important;animation:gradShift 6s ease infinite;position:relative;overflow:hidden}
.btn-book::after,.btn-auth::after,.hero-cta a.primary::after{content:'';position:absolute;top:0;left:0;
  width:40%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.45),transparent);
  transform:translateX(-120%);pointer-events:none}
.btn-book:hover::after,.btn-auth:hover::after,.hero-cta a.primary:hover::after{animation:shimmer 1s ease}
.btn-book:hover,.btn-auth:hover,.hero-cta a.primary:hover{animation-duration:2.2s;transform:translateY(-3px) scale(1.02)}

/* hero CTA ปุ่มรอง: กรอบไล่สีเรืองๆ */
.hero-cta a:not(.primary){position:relative;background:rgba(255,255,255,.05);z-index:0}
.hero-cta a:not(.primary)::before{content:'';position:absolute;inset:0;border-radius:inherit;padding:1.5px;
  background:linear-gradient(115deg,#ff3b5c,#8b5cff);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:.6;transition:.3s}
.hero-cta a:not(.primary):hover::before{opacity:1;box-shadow:0 0 18px rgba(139,92,255,.5)}

/* การ์ดเมนูลัด: กรอบไล่สีดิ้น + ลอยตอน hover */
.qm-item{position:relative;z-index:0;overflow:hidden}
.qm-item::before{content:'';position:absolute;inset:0;border-radius:inherit;padding:1.5px;
  background:linear-gradient(115deg,#ff3b5c,#8b5cff,#ff3b5c);background-size:200% 100%;
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:.3s;animation:flowLine 3s linear infinite}
.qm-item:hover::before{opacity:1}
.qm-item:hover .ic{animation:floaty 1.4s ease-in-out infinite}

/* การ์ดงาน: ring ไล่สีเรืองตอน hover */
.ev-card{position:relative}
.ev-card::before{content:'';position:absolute;inset:0;border-radius:inherit;padding:1.6px;z-index:3;
  background:linear-gradient(120deg,#ff3b5c,#8b5cff,#ff3b5c);background-size:200% 100%;
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:.35s;animation:flowLine 3s linear infinite}
.ev-card:hover::before{opacity:1}

/* การ์ดจุดเด่น: ไอคอนเด้ง + เส้นเรืองด้านบน */
.feat{position:relative;overflow:hidden}
.feat::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,#ff3b5c,#8b5cff,transparent);background-size:200% 100%;
  animation:flowLine 4s linear infinite;opacity:.8}
.feat:hover .fic{animation:floaty 1.6s ease-in-out infinite}

/* ====== BOTTOM NAV ให้เด่น สว่าง ดิ้น ====== */
.botnav{background:rgba(17,20,36,.97)!important;backdrop-filter:blur(22px) saturate(160%);
  border-top:none!important;box-shadow:0 -12px 40px rgba(0,0,0,.65)!important;overflow:visible}
.botnav::before{content:'';position:absolute;top:0;left:0;right:0;height:2.5px;
  background:linear-gradient(90deg,#ff3b5c,#8b5cff,#ff3b5c,#8b5cff);background-size:200% 100%;
  animation:flowLine 5s linear infinite;box-shadow:0 0 16px rgba(255,59,92,.7)}
.botnav a{color:#c3cadd;font-size:11px;font-weight:700;position:relative}
.botnav a .ic{font-size:22px;transition:.2s}
.botnav a:hover{color:#fff}
.botnav a:hover .ic{transform:translateY(-2px) scale(1.12)}
.botnav a.on{color:#fff}
.botnav a.on::before{content:'';position:absolute;top:4px;left:50%;transform:translateX(-50%);
  width:34px;height:34px;border-radius:50%;background:radial-gradient(circle,rgba(255,59,92,.45),transparent 70%);z-index:-1}
.botnav a.on .ic{filter:drop-shadow(0 0 12px rgba(255,59,92,.9));transform:scale(1.1)}
.botnav .center{top:-20px}
.botnav .center .ic{width:60px;height:60px;font-size:27px;border:3px solid var(--bg);
  background:linear-gradient(115deg,#ff3b5c,#ff6b8a,#8b5cff,#ff3b5c)!important;background-size:240% 240%!important;
  animation:gradShift 5s ease infinite,pulseGlow 2.6s ease-in-out infinite}
.botnav .center:hover .ic{animation:gradShift 2s ease infinite,floaty 1.2s ease-in-out infinite}

/* ============================================================
 * 🏠 HOMEPAGE REDESIGN (ตาม mockup)
 * ============================================================ */
/* topbar 3 คอลัมน์ */
.topbar .inner{gap:18px}
.brand-tx{display:flex;flex-direction:column;line-height:1.15}
.topsearch{flex:1;max-width:560px;display:flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.07);border:1px solid var(--border-2);border-radius:40px;padding:7px 8px 7px 16px}
.topsearch .ts-ic{color:var(--muted);font-size:15px}
.topsearch input{flex:1;background:transparent;border:0;outline:0;color:#fff;font-family:inherit;font-size:14.5px}
.topsearch input::placeholder{color:var(--muted)}
.topsearch button{border:0;cursor:pointer;width:40px;height:40px;border-radius:50%;font-size:16px;color:#fff;
  background:linear-gradient(115deg,#ff3b5c,#8b5cff);box-shadow:var(--glow-coral)}
.top-actions{gap:14px}
.ta-icon{position:relative;width:42px;height:42px;display:grid;place-items:center;border-radius:50%;
  background:rgba(255,255,255,.06);border:1px solid var(--border);font-size:18px;transition:.2s}
.ta-icon:hover{background:rgba(255,255,255,.12)}
.ta-icon .dot{position:absolute;top:9px;right:10px;width:8px;height:8px;border-radius:50%;background:var(--coral);box-shadow:0 0 8px var(--coral)}
.ta-fav{display:flex;align-items:center;gap:7px;color:var(--ink-soft);font-size:14px;font-weight:600;padding:9px 14px;border-radius:30px;border:1px solid var(--border);background:rgba(255,255,255,.04);transition:.2s}
.ta-fav span{color:var(--coral)}
.ta-fav:hover{background:rgba(255,255,255,.1);color:#fff}
.ta-user{display:flex;align-items:center;gap:10px;padding:6px 12px 6px 6px;border-radius:40px;
  background:rgba(255,255,255,.06);border:1px solid var(--border-2);transition:.2s}
.ta-user:hover{background:rgba(255,255,255,.12)}
.ta-av{width:38px;height:38px;border-radius:50%;background:var(--grad);display:grid;place-items:center;
  font-weight:800;font-size:16px;color:#fff;box-shadow:var(--glow-coral)}
.ta-uname{font-size:14px;font-weight:700;color:#fff;display:flex;align-items:center;gap:7px}
.vip-chip{font-style:normal;font-size:10px;font-weight:800;color:#3a2406;background:linear-gradient(120deg,#ffd166,#fbbf24);
  padding:2px 7px;border-radius:6px;letter-spacing:.5px}
.ta-caret{color:var(--muted);font-size:12px}

/* hero arrows + badge */
.bn-arrow{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;
  border:1px solid var(--border-2);background:rgba(10,12,22,.55);backdrop-filter:blur(8px);color:#fff;
  font-size:26px;line-height:1;cursor:pointer;z-index:4;display:grid;place-items:center;transition:.2s}
.bn-arrow:hover{background:var(--grad);border-color:transparent;box-shadow:var(--glow-coral)}
.bn-arrow.prev{left:14px}.bn-arrow.next{right:14px}
.hf-badge{display:inline-block;background:linear-gradient(115deg,#ff3b5c,#8b5cff);color:#fff;font-size:12px;font-weight:700;
  padding:6px 16px;border-radius:30px;margin-bottom:10px;box-shadow:var(--glow-coral)}

/* feature bar (ไอคอนกลม 4) */
.feature-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:16px 0 4px;
  background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:18px;backdrop-filter:blur(8px)}
.fb-item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:5px}
.fb-ic{width:58px;height:58px;border-radius:50%;display:grid;place-items:center;font-size:26px;
  background:radial-gradient(circle at 30% 25%, color-mix(in srgb,var(--c) 75%,#fff 0%), color-mix(in srgb,var(--c) 60%,#000 30%));
  box-shadow:0 10px 26px color-mix(in srgb,var(--c) 45%,transparent);border:1px solid rgba(255,255,255,.18)}
.fb-item b{color:#fff;font-size:14px;font-weight:700}
.fb-item small{color:var(--muted);font-size:12px}

/* quick action cards */
.qa-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:22px 0}
.qa-card{display:flex;flex-direction:column;gap:12px;background:var(--surface);border:1px solid var(--border);
  border-radius:18px;padding:20px;backdrop-filter:blur(8px);transition:.22s;position:relative;overflow:hidden}
.qa-card:hover{transform:translateY(-4px);border-color:var(--border-2);box-shadow:0 18px 44px rgba(139,92,255,.18)}
.qa-ic{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;font-size:24px;
  background:radial-gradient(circle at 30% 25%, color-mix(in srgb,var(--c) 80%,#fff), color-mix(in srgb,var(--c) 55%,#000 35%));
  box-shadow:0 10px 26px color-mix(in srgb,var(--c) 45%,transparent)}
.qa-tx h3{color:#fff;font-size:16px;font-weight:800;margin:0}
.qa-tx p{color:var(--muted);font-size:13px;margin:2px 0 0}
.qa-btn{margin-top:auto;align-self:flex-start;background:var(--surface-2);border:1px solid var(--border-2);color:#fff;
  font-size:13px;font-weight:700;padding:8px 16px;border-radius:30px;transition:.2s}
.qa-card:hover .qa-btn{background:linear-gradient(115deg,#ff3b5c,#8b5cff);border-color:transparent;box-shadow:var(--glow-coral)}

/* two-column home */
.home-cols{display:grid;grid-template-columns:1.55fr 1fr;gap:26px;align-items:start;margin-top:8px}
.home-cols .event-grid{grid-template-columns:repeat(2,1fr)}

/* heart on card */
.ev-heart{position:absolute;top:12px;right:12px;z-index:2;width:32px;height:32px;border-radius:50%;
  display:grid;place-items:center;background:rgba(10,12,22,.5);backdrop-filter:blur(6px);color:#fff;font-size:15px;
  border:1px solid var(--border-2);transition:.2s}
.ev-card:hover .ev-heart{color:var(--coral);background:rgba(255,59,92,.18)}

/* categories neon pills */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.cat-pill{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 8px;border-radius:16px;
  background:var(--surface);border:1px solid var(--border);transition:.22s}
.cat-pill:hover{transform:translateY(-3px);border-color:var(--c);box-shadow:0 12px 30px color-mix(in srgb,var(--c) 40%,transparent)}
.cat-ic{width:50px;height:50px;border-radius:50%;display:grid;place-items:center;font-size:23px;color:#fff;
  background:radial-gradient(circle at 30% 25%, color-mix(in srgb,var(--c) 35%,transparent), transparent 70%);
  border:2px solid var(--c);box-shadow:0 0 18px color-mix(in srgb,var(--c) 55%,transparent),inset 0 0 14px color-mix(in srgb,var(--c) 30%,transparent)}
.cat-pill span:last-child{color:var(--ink-soft);font-size:13px;font-weight:700}

/* promo card */
.promo-card{margin-top:18px;border-radius:20px;padding:20px;position:relative;overflow:hidden;
  background:linear-gradient(125deg,#221433,#1a1130);border:1px solid var(--border-2)}
.promo-card::before{content:'';position:absolute;inset:0;border-radius:inherit;padding:1.5px;
  background:linear-gradient(120deg,#ff3b5c,#8b5cff,#ff3b5c);background-size:200% 100%;animation:flowLine 3s linear infinite;
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude}
.promo-top{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}
.promo-top b{color:#fff;font-size:16px}
.promo-cd{display:flex;gap:6px;color:#fff}
.promo-cd i{font-style:normal;display:flex;flex-direction:column;align-items:center;background:rgba(255,255,255,.1);border-radius:8px;padding:4px 7px;min-width:38px}
.promo-cd u{text-decoration:none;font-weight:800;font-size:15px}
.promo-cd em{font-style:normal;font-size:9px;color:var(--muted)}
.promo-off{font-size:30px;font-weight:800;color:#fff;margin-top:14px;
  background:linear-gradient(115deg,#ff3b5c,#ffd166);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.promo-sub{color:var(--ink-soft);font-size:13px;margin-bottom:14px}
.promo-bot{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.promo-code{font-family:monospace;font-weight:800;color:#ffd166;background:rgba(255,209,102,.12);border:1px dashed rgba(255,209,102,.5);padding:8px 14px;border-radius:10px;letter-spacing:1px}
.promo-btn{margin-left:auto;background:linear-gradient(115deg,#ff3b5c,#8b5cff);color:#fff;font-weight:800;font-size:14px;padding:10px 18px;border-radius:11px;box-shadow:var(--glow-coral);transition:.2s}
.promo-btn:hover{transform:translateY(-2px)}

/* trust bar */
.trust-bar{margin:30px 0 8px;background:var(--surface);border:1px solid var(--border);border-radius:20px;
  padding:20px 22px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;backdrop-filter:blur(8px)}
.trust-feats{display:flex;gap:26px;flex-wrap:wrap}
.tf{display:flex;align-items:center;gap:11px}
.tf>span{font-size:24px}
.tf b{color:#fff;font-size:14px;display:block}
.tf small{color:var(--muted);font-size:12px}
.trust-banks{display:flex;gap:9px;flex-wrap:wrap}
.bank{font-size:12px;font-weight:700;color:var(--ink-soft);background:rgba(255,255,255,.07);border:1px solid var(--border);padding:7px 13px;border-radius:9px}

/* responsive homepage */
@media(max-width:980px){
  .topsearch{order:3;max-width:none;flex-basis:100%}
  .topbar .inner{flex-wrap:wrap;height:auto;padding-top:10px;padding-bottom:10px}
  .home-cols{grid-template-columns:1fr}
}
@media(max-width:640px){
  .feature-bar{grid-template-columns:repeat(2,1fr)}
  .qa-grid{grid-template-columns:repeat(2,1fr)}
  .home-cols .event-grid{grid-template-columns:repeat(2,1fr)}
  .cat-grid{grid-template-columns:repeat(3,1fr)}
  .ta-fav,.ta-uname,.ta-caret{display:none}
  .trust-feats{gap:14px}
}

/* ============================================================
 * 💎 UPGRADE: feature-bar + quick actions (3D glossy · glow · ดิ้น)
 * ============================================================ */
@keyframes ringSpin{to{transform:rotate(360deg)}}
@keyframes glowPulse{0%,100%{opacity:.5;transform:scale(1)}50%{opacity:.95;transform:scale(1.12)}}

/* ---- feature bar ---- */
.feature-bar{background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.02));
  border:1px solid var(--border-2);gap:6px;padding:10px;box-shadow:0 16px 50px rgba(0,0,0,.4)}
.fb-item{--c:#8b5cff;padding:18px 12px;border-radius:18px;transition:.28s;cursor:default;position:relative;overflow:hidden}
.fb-item::after{content:'';position:absolute;inset:0;border-radius:inherit;opacity:0;transition:.3s;
  background:radial-gradient(120% 90% at 50% -10%, color-mix(in srgb,var(--c) 22%,transparent), transparent 60%)}
.fb-item:hover::after{opacity:1}
.fb-item:hover .fb-ic{transform:translateY(-5px) scale(1.05)}
.fb-ic{position:relative;width:66px;height:66px;border-radius:50%;font-size:28px;border:none;transition:.35s;
  background:
    radial-gradient(circle at 33% 26%, rgba(255,255,255,.6), transparent 40%),
    radial-gradient(circle at 50% 55%, color-mix(in srgb,var(--c) 95%,#fff), color-mix(in srgb,var(--c) 52%,#000 40%));
  box-shadow:0 14px 32px color-mix(in srgb,var(--c) 55%,transparent),
    inset 0 2px 7px rgba(255,255,255,.5), inset 0 -7px 14px rgba(0,0,0,.32)}
.fb-ic::before{content:'';position:absolute;inset:-5px;border-radius:50%;z-index:-1;filter:blur(2px);opacity:.85;
  background:conic-gradient(from 0deg, color-mix(in srgb,var(--c) 95%,transparent), transparent 52%, color-mix(in srgb,var(--c) 95%,transparent));
  animation:ringSpin 4.5s linear infinite}
.fb-ic::after{content:'';position:absolute;inset:-16px;border-radius:50%;z-index:-2;
  background:radial-gradient(circle, color-mix(in srgb,var(--c) 42%,transparent), transparent 65%);
  animation:glowPulse 2.8s ease-in-out infinite}
.fb-item b{font-size:14.5px}

/* ---- quick action cards ---- */
.qa-card{--c:#ff3b5c;overflow:hidden;z-index:0;border:1px solid var(--border);
  background:
    radial-gradient(150% 110% at 0% 0%, color-mix(in srgb,var(--c) 17%,transparent), transparent 52%),
    linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.015))}
.qa-card::before{content:'';position:absolute;inset:0;border-radius:inherit;padding:1.5px;z-index:-1;opacity:.65;transition:.3s;
  background:linear-gradient(135deg, color-mix(in srgb,var(--c) 95%,transparent), transparent 62%);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude}
.qa-card::after{content:'';position:absolute;top:-70px;right:-55px;width:170px;height:170px;border-radius:50%;z-index:-1;opacity:.45;transition:.4s;
  background:radial-gradient(circle, color-mix(in srgb,var(--c) 48%,transparent), transparent 70%)}
.qa-card:hover{transform:translateY(-7px);box-shadow:0 26px 54px color-mix(in srgb,var(--c) 32%,transparent);border-color:transparent}
.qa-card:hover::before{opacity:1}
.qa-card:hover::after{transform:scale(1.3);opacity:.85}
.qa-ic{position:relative;width:62px;height:62px;border-radius:18px;font-size:28px;transition:.4s;
  background:
    radial-gradient(circle at 32% 26%, rgba(255,255,255,.6), transparent 44%),
    linear-gradient(150deg, color-mix(in srgb,var(--c) 95%,#fff), color-mix(in srgb,var(--c) 48%,#000 42%));
  box-shadow:0 14px 30px color-mix(in srgb,var(--c) 55%,transparent),
    inset 0 2px 7px rgba(255,255,255,.5), inset 0 -7px 14px rgba(0,0,0,.32)}
.qa-card:hover .qa-ic{transform:translateY(-5px) rotate(-7deg) scale(1.08)}
.qa-tx h3{font-size:18px}
.qa-tx p{font-size:13.5px}
.qa-btn{border:none;color:#fff;font-weight:800;padding:11px 22px;transition:.25s;
  background:linear-gradient(115deg, color-mix(in srgb,var(--c) 88%,#000), color-mix(in srgb,var(--c) 55%,#8b5cff 45%));
  box-shadow:0 10px 22px color-mix(in srgb,var(--c) 45%,transparent)}
.qa-card:hover .qa-btn{transform:translateX(4px);box-shadow:0 12px 28px color-mix(in srgb,var(--c) 60%,transparent)}

/* ============================================================
 * 📱 MOBILE RESPONSIVE — ทั้งระบบ
 * ============================================================ */
@media(max-width:768px){
  .container{padding:0 14px}
  body{padding-bottom:84px}
  .topbar .inner{gap:10px;padding:9px 0;flex-wrap:wrap}
  .topsearch{order:3;flex-basis:100%;max-width:none}
  .home-cols{grid-template-columns:1fr}
  .home-cols .event-grid{grid-template-columns:1fr 1fr}
  .detail-wrap{grid-template-columns:1fr;gap:18px}
  .detail-cover{position:static}
}
@media(max-width:560px){
  .container{padding:0 12px}
  /* header กระชับ */
  .brand{font-size:16px;gap:9px}
  .brand .logo{width:34px;height:34px;font-size:18px;border-radius:11px}
  .brand small{display:none}
  .topsearch{padding:6px 6px 6px 13px;border-radius:30px}
  .topsearch input{font-size:14px}
  .topsearch button{width:34px;height:34px;font-size:14px}
  .top-actions{gap:8px}
  .ta-icon{width:38px;height:38px;font-size:16px}
  .ta-fav,.ta-uname,.ta-caret{display:none}
  .ta-user{padding:4px;border-radius:50%}
  .ta-av{width:34px;height:34px;font-size:15px}
  /* hero */
  .hero{padding:12px 0 4px}
  .banner-slider{border-radius:18px}
  .bn-arrow{width:38px;height:38px;font-size:22px}
  .bn-arrow.prev{left:8px}.bn-arrow.next{right:8px}
  .hero-cta{gap:8px;margin-top:14px}
  .hero-cta a{padding:11px 18px;font-size:14px;flex:1;text-align:center}
  /* feature bar */
  .feature-bar{gap:4px;padding:8px;border-radius:16px;margin:14px 0 4px}
  .fb-item{padding:14px 6px;border-radius:14px}
  .fb-ic{width:54px;height:54px;font-size:24px}
  .fb-item b{font-size:13px}
  .fb-item small{font-size:11px}
  /* quick actions */
  .qa-grid{gap:11px;margin:18px 0}
  .qa-card{padding:16px;gap:10px;border-radius:16px}
  .qa-ic{width:50px;height:50px;font-size:24px;border-radius:14px}
  .qa-tx h3{font-size:16px}
  .qa-tx p{font-size:12.5px}
  .qa-btn{padding:9px 16px;font-size:13px}
  /* sections */
  .sec-head{margin:24px 0 12px}
  .sec-head h2{font-size:18px}
  .sec-head h2::before{height:20px}
  .event-grid{gap:14px}
  .ev-body{padding:13px 14px 15px}
  .ev-body h3{font-size:15px}
  /* categories */
  .cat-grid{gap:9px}
  .cat-pill{padding:14px 6px;border-radius:14px}
  .cat-ic{width:44px;height:44px;font-size:20px}
  .cat-pill span:last-child{font-size:12px}
  /* promo */
  .promo-card{padding:16px}
  .promo-off{font-size:26px}
  .promo-cd i{min-width:34px;padding:4px 5px}
  .promo-bot{gap:8px}
  .promo-btn{margin-left:0;flex:1;text-align:center}
  /* trust + footer */
  .trust-bar{padding:16px;gap:14px;border-radius:16px}
  .trust-feats{gap:14px;flex-direction:column;align-items:flex-start}
  .site-foot{flex-direction:column;align-items:flex-start;gap:10px}
  /* event detail */
  .detail-info h1{font-size:21px}
  .sumbar{flex-direction:column;align-items:stretch;bottom:90px}
  .sumbar .btn-book{width:100%}
  /* account */
  .acc{margin:14px auto}
  .memstats{flex-wrap:wrap}
  .auth-wrap{margin:18px auto}
}
@media(max-width:430px){
  .home-cols .event-grid{grid-template-columns:1fr}
  .qa-grid{grid-template-columns:1fr 1fr}
  .feature-bar{grid-template-columns:repeat(2,1fr)}
  .hero-cta{flex-wrap:wrap}
  .hero-cta a{flex-basis:calc(50% - 4px)}
}
