:root{
  --cream:#fff6e9;--sand:#fdebd6;--card:#ffffff;
  --bg:#fff6e9;--surface:#ffffff;--surface2:#fff1e0;
  --ink:#2c1a0e;--text:#2c1a0e;--muted:#9a7e64;
  --orange:#ff7a16;--coral:#ff4f2e;--sea:#06b6c9;--sea-deep:#048497;--sun:#ffcf33;
  --line:#f0dcc4;--line2:#e7cfb2;
  --ok:#1ba85f;--bad:#e23b2e;--warn:#d98a00;--gold:#d98a00;
  --shadow:0 18px 40px rgba(214,128,40,.16);
  --display:'Bricolage Grotesque',sans-serif;--body:'Outfit',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--cream);color:var(--ink);font-family:var(--body);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;min-height:100vh}
a{color:inherit;text-decoration:none}
.bgfx{position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(46% 50% at 88% -4%,rgba(255,207,51,.4),transparent 60%),
  radial-gradient(40% 45% at 96% 2%,rgba(255,122,22,.22),transparent 60%),
  radial-gradient(55% 45% at 4% 100%,rgba(6,182,201,.12),transparent 60%)}
.wrap{position:relative;z-index:1;margin:0 auto;padding:0 24px}

/* nav + brand */
nav{display:flex;align-items:center;justify-content:space-between;padding:20px 0;gap:14px}
.brand{display:flex;align-items:center;gap:11px}
.brand img{height:46px;width:auto;display:block}
.brand .txt{display:flex;flex-direction:column;line-height:1}
.brand .txt b{font-family:var(--display);font-weight:800;font-size:22px;letter-spacing:-.5px;color:var(--ink)}
.brand .txt span{font-size:8px;letter-spacing:4px;color:var(--muted);font-weight:500;margin-top:3px}
.nav-links{display:flex;gap:24px;font-weight:500;font-size:15px}
.nav-links a{color:var(--ink);opacity:.7;transition:.2s}
.nav-links a:hover{opacity:1;color:var(--orange)}

.btn{display:inline-flex;align-items:center;gap:8px;justify-content:center;font-family:var(--body);font-weight:700;border:none;cursor:pointer;border-radius:100px;font-size:15px;padding:12px 24px;transition:.25s;text-align:center}
.btn-primary{background:var(--orange);color:#fff;box-shadow:0 10px 24px rgba(255,122,22,.35)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(255,122,22,.5)}
.btn-ghost{background:transparent;color:var(--ink);border:2px solid var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff}
.btn-block{display:flex;width:100%}

/* hero bits (home) */
.hero{position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:-10% -10% 0 -10%;z-index:0;
  background:radial-gradient(48% 60% at 84% 6%,rgba(255,207,51,.55),transparent 60%),
  radial-gradient(42% 52% at 92% 0%,rgba(255,122,22,.38),transparent 60%)}
.sun{position:absolute;top:24px;right:5%;width:140px;height:140px;z-index:1;animation:spin 60s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.wave{display:block;width:100%;height:auto;position:relative;z-index:2;margin-bottom:-6px}
.pill,.eyebrow{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:100px;padding:8px 16px;font-size:13px;font-weight:600;color:var(--sea-deep);box-shadow:var(--shadow);margin-bottom:22px;text-transform:none;letter-spacing:0}
.dot{width:8px;height:8px;border-radius:50%;background:var(--sea);box-shadow:0 0 0 4px rgba(6,182,201,.2)}
h1{font-family:var(--display);font-weight:800;font-size:clamp(46px,8vw,98px);line-height:.92;letter-spacing:-2px}
h1 .glow,.glow{color:var(--orange)}
h1 .u{position:relative;color:var(--orange)}
h1 .u::after{content:"";position:absolute;left:0;right:0;bottom:6px;height:14px;background:var(--sun);z-index:-1;border-radius:8px}
.sub{color:#7a5f47;max-width:520px;margin-top:18px;font-size:18px}
.muted{color:var(--muted)}
.kick{font-family:var(--body);font-weight:700;font-size:13px;letter-spacing:2px;text-transform:uppercase;color:var(--orange);margin-bottom:8px}
.section{padding:48px 0;position:relative;z-index:1}
.section-head,.head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:26px;flex-wrap:wrap;gap:10px}
h2{font-family:var(--display);font-weight:800;font-size:clamp(30px,5vw,50px);letter-spacing:-1px}
.head a{font-weight:600;color:var(--sea-deep)}

/* what we do band */
.doers{background:var(--sea-deep);color:#fff;padding:42px 0;position:relative;z-index:1}
.doers .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.doer{text-align:center}
.doer .ic{width:54px;height:54px;margin:0 auto 12px;border-radius:16px;background:rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center}
.doer b{display:block;font-family:var(--display);font-weight:600;font-size:17px}
.doer span{font-size:13px;opacity:.7}
@media(max-width:720px){.doers .wrap{grid-template-columns:repeat(2,1fr);gap:24px}}

/* generic cards / grid */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:22px}
.card{background:var(--card);border:1px solid var(--line);border-radius:22px;overflow:hidden;box-shadow:var(--shadow);transition:.3s}
.card:hover{transform:translateY(-6px);box-shadow:0 26px 50px rgba(214,128,40,.24)}
.card-img{height:180px;position:relative;display:flex;align-items:flex-end;padding:14px;background-size:cover;background-position:center}
.g1,.p1{background:linear-gradient(140deg,#ffd23f,#ff7a16)}
.g2,.p2{background:linear-gradient(140deg,#06b6c9,#048497)}
.g3,.p3{background:linear-gradient(140deg,#ff8fa3,#ff4f6d)}
.g4{background:linear-gradient(140deg,#7ad1dd,#06b6c9)}
.card-img::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(44,26,14,.55),transparent 55%)}
.card-img b,.card-img .tag{position:relative;z-index:1;color:#fff}
.card-img b{font-family:var(--display);font-weight:700;font-size:23px;letter-spacing:-.5px;text-shadow:0 2px 14px rgba(0,0,0,.35)}
.tag{position:absolute;top:12px;left:12px;background:rgba(255,255,255,.9);color:var(--ink);border:none;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:5px 11px;border-radius:100px;z-index:2}
.tag.iconic{color:var(--coral)}
.tag.warn{color:var(--sea-deep)}
.card-body{padding:16px 18px}
.card-body .nm{font-family:var(--display);font-weight:700;font-size:21px}
.meta{display:flex;gap:14px;color:var(--muted);font-size:13px;margin:8px 0 12px;flex-wrap:wrap}
.meta i{color:var(--orange);font-style:normal;margin-right:4px}
.card-foot{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--line);padding-top:12px}
.price small{color:var(--muted);font-size:11px;display:block}
.price b{font-family:var(--display);font-weight:800;font-size:19px}.price b span{font-size:12px;color:var(--muted);font-weight:400}

/* event card (home) */
.ecard{background:var(--card);border-radius:24px;box-shadow:var(--shadow);overflow:hidden;border:1px solid var(--line);transition:.3s}
.ecard:hover{transform:translateY(-6px);box-shadow:0 26px 50px rgba(214,128,40,.24)}
.ecard .ph{height:190px;position:relative;display:flex;align-items:flex-start;padding:14px;background-size:cover;background-position:center}
.ecard .ph .date{background:#fff;border-radius:14px;padding:8px 12px;text-align:center;box-shadow:0 6px 14px rgba(0,0,0,.12)}
.ecard .ph .date b{display:block;font-family:var(--display);font-weight:800;font-size:22px;line-height:1}
.ecard .ph .date small{font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}
.ecard .body{padding:18px 20px}
.ecard .body h3{font-family:var(--display);font-weight:700;font-size:21px;letter-spacing:-.5px}
.ecard .body .m{color:var(--muted);font-size:14px;margin:4px 0 14px}
.ecard .foot{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--line);padding-top:14px}
.ecard .foot .pr b{font-family:var(--display);font-weight:800;font-size:20px}
.ecard .foot .pr small{display:block;font-size:11px;color:var(--muted)}

/* event rows (club page) */
.ev{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:12px 14px;margin-bottom:12px;flex-wrap:wrap;box-shadow:var(--shadow);transition:.25s}
.ev:hover{transform:translateY(-3px)}
.ev .thumb{width:74px;height:74px;border-radius:14px;background-size:cover;background-position:center;flex:0 0 auto}
.ev .when{font-family:var(--display);font-weight:800;font-size:22px;min-width:56px;text-align:center;color:var(--orange)}
.ev .when small{display:block;font-size:10px;letter-spacing:1px;color:var(--muted);font-family:var(--body);font-weight:500}
.ev .info{flex:1;min-width:150px}
.ev .info b{font-size:16px;font-weight:600}
.ev .info div{color:var(--muted);font-size:13px}

.banner{height:210px;border-radius:20px;background-size:cover;background-position:center;position:relative;margin-top:16px;box-shadow:var(--shadow)}

/* forms */
.panel{background:var(--card);border:1px solid var(--line);border-radius:22px;padding:22px;margin-top:18px;box-shadow:var(--shadow)}
label{display:block;font-size:12px;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);font-weight:600;margin:14px 0 6px}
input,select,textarea{width:100%;background:#fff;border:1px solid var(--line2);color:var(--ink);border-radius:12px;padding:12px 14px;font-family:var(--body);font-size:15px}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,122,22,.15)}
input[type=file]{padding:10px;background:#fff7ee}
.row{display:flex;gap:12px;flex-wrap:wrap}.row>div{flex:1;min-width:120px}
.summary{display:flex;justify-content:space-between;align-items:center;border-top:1px dashed var(--line2);margin-top:18px;padding-top:16px}
.summary .tot{font-family:var(--display);font-weight:800;font-size:30px}
.note{margin-top:18px;font-size:13px;color:#7a5f47;background:#fff7ee;border:1px solid var(--line);border-left:3px solid var(--sea);border-radius:0 12px 12px 0;padding:12px 16px}

/* ticket */
.ticket{background:var(--card);border:1px solid var(--line);border-radius:24px;overflow:hidden;margin-top:18px;box-shadow:var(--shadow)}
.ticket-head{padding:20px 22px;display:flex;justify-content:space-between;align-items:flex-start;border-bottom:2px dashed var(--line2)}
.ticket-head .club{font-family:var(--display);font-weight:800;font-size:24px}
.ticket-head .ev2{color:var(--orange);font-size:13px;margin-top:2px;font-weight:600}
.paid{font-size:10px;letter-spacing:1px;text-transform:uppercase;font-weight:700;color:var(--ok);background:rgba(27,168,95,.12);border:1px solid rgba(27,168,95,.3);border-radius:100px;padding:5px 11px}
.qr-zone{padding:24px;text-align:center}
#qr{display:inline-flex;align-items:center;justify-content:center;background:#fff;border-radius:16px;padding:12px;border:1px solid var(--line)}
.tinfo{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:0 22px 18px}
.tinfo small{display:block;font-size:10px;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);font-weight:600}
.tinfo b{font-size:15px;font-weight:500}
.valid-once{margin:0 22px 20px;text-align:center;color:var(--sea-deep);font-size:12px;letter-spacing:.5px;text-transform:uppercase;font-weight:600}

/* gallery / memories */
.gmasonry{columns:3;column-gap:14px}
.gmasonry .gi{break-inside:avoid;margin-bottom:14px;border-radius:18px;overflow:hidden;border:1px solid var(--line);position:relative;display:block;box-shadow:var(--shadow)}
.gmasonry .gi img{width:100%;display:block;transition:.4s}
.gmasonry .gi:hover img{transform:scale(1.05)}
.gmasonry .gi span{position:absolute;left:0;right:0;bottom:0;padding:14px 12px 10px;font-size:13px;color:#fff;font-weight:600;background:linear-gradient(to top,rgba(44,26,14,.85),transparent);opacity:0;transition:.3s}
.gmasonry .gi:hover span{opacity:1}
@media(max-width:820px){.gmasonry{columns:2}}
@media(max-width:520px){.gmasonry{columns:1}}

.mosaic{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:140px;gap:14px}
.mosaic .m{border-radius:18px;position:relative;overflow:hidden;display:flex;align-items:flex-end;padding:12px;color:#fff;font-weight:600;font-size:13px;background-size:cover;background-position:center;box-shadow:var(--shadow)}
.mosaic .m::before{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(44,26,14,.5),transparent 55%)}
.mosaic .m span{position:relative;z-index:1}
@media(max-width:720px){.mosaic{grid-template-columns:repeat(2,1fr)}}

/* cta */
.cta-box{background:var(--ink);border-radius:32px;padding:56px 36px;text-align:center;position:relative;overflow:hidden;box-shadow:var(--shadow)}
.cta-box::before{content:"";position:absolute;top:-40%;right:-8%;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(255,207,51,.5),transparent 70%)}
.cta-box h2{color:#fff;position:relative}
.cta-box h2 .o{color:var(--sun)}
.cta-box p{color:rgba(255,255,255,.72);margin:14px auto 24px;max-width:420px;position:relative}

footer{background:var(--ink);color:rgba(255,255,255,.6);padding:28px 0;font-size:14px;margin-top:40px;position:relative;z-index:1}
footer .wrap{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}

/* tables (admin) */
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:11px 10px;border-bottom:1px solid var(--line);vertical-align:middle}
th{color:var(--muted);font-size:11px;letter-spacing:.5px;text-transform:uppercase;font-weight:600}
.pill{box-shadow:none;margin:0;padding:3px 10px;font-size:11px;border-radius:100px;border:1px solid var(--line2);background:#fff}
.pill.paid{color:var(--ok);border-color:rgba(27,168,95,.4)}
.pill.pending{color:var(--warn);border-color:rgba(217,138,0,.4)}
.pill.in{color:var(--sea-deep);border-color:rgba(6,182,201,.4)}
.stats{display:flex;gap:12px;flex-wrap:wrap;margin:8px 0 22px}
.stat{flex:1;min-width:120px;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:14px;box-shadow:var(--shadow)}
.stat b{font-family:var(--display);font-weight:800;font-size:28px;display:block}
.stat small{color:var(--muted);font-size:11px;letter-spacing:.5px;text-transform:uppercase;font-weight:600}
