




/* ═══ PATCH 20: Admin dashboard error banner + loading spinner ═══ */
.adm-error-banner{background:#FAE8E3;border:1px solid #C4472F;border-radius:10px;margin:12px 14px;padding:12px 14px}
.adm-error-title{font-size:12px;font-weight:700;color:#8A2F1C;margin-bottom:6px}
.adm-error-list{font-size:10px;color:#3D3D38;line-height:1.5}
.adm-error-item{padding:3px 0}
.adm-error-item strong{color:#8A2F1C}
.adm-error-hint{color:#7A7A72;font-style:italic}
.adm-error-retry{margin-top:8px;padding:6px 14px;background:#C4472F;color:white;border:none;border-radius:14px;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;cursor:pointer}
.adm-error-retry:active{background:#8A2F1C;transform:scale(.96)}
.adm-loading-spinner{text-align:center;padding:60px 20px}
.adm-loading-spinner .spinner{display:inline-block;width:32px;height:32px;border:3px solid #EDE8DC;border-top-color:#C9A84C;border-radius:50%;animation:admspin .8s linear infinite;margin-bottom:12px}
.adm-loading-spinner .txt{font-size:12px;color:#7A7A72;letter-spacing:.05em}
.sponsor-admin-section{padding:0 14px 10px}
.sponsor-admin-input-row{display:flex;gap:6px;margin-bottom:8px}
.sponsor-admin-input-row input{flex:1;padding:10px 12px;background:white;border:1px solid #EDE8DC;border-radius:8px;font-size:12px;color:#1A3325;font-family:inherit;min-height:40px}
.sponsor-admin-input-row input:focus{border-color:#C9A84C;outline:none}
.sponsor-admin-add-btn{padding:10px 16px;background:#1A3325;color:#C9A84C;border:none;border-radius:8px;font-size:11px;font-weight:600;min-height:40px}
.sponsor-admin-list{background:white;border:1px solid #EDE8DC;border-radius:10px;padding:8px}
.sponsor-admin-row{display:flex;align-items:center;gap:10px;padding:8px;border-bottom:1px solid #F7F3EC}
.sponsor-admin-row:last-child{border-bottom:none}
.sponsor-admin-logo{width:40px;height:40px;border-radius:6px;background:#F7F3EC;object-fit:contain;flex-shrink:0;border:1px solid #EDE8DC}
.sponsor-admin-info{flex:1;min-width:0}
.sponsor-admin-name{font-size:12px;font-weight:500;color:#1A3325}
.sponsor-admin-url{font-size:10px;color:#7A7A72;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sponsor-admin-remove{background:transparent;border:none;color:#C4472F;font-size:18px;cursor:pointer;padding:4px 8px}



/* ═══ PATCH 23: Dual-channel notifications ═══ */
.nav-tab{position:relative}
.nav-tab .news-dot{position:absolute;top:6px;right:18px;width:9px;height:9px;background:#C4472F;border-radius:50%;border:2px solid #1A3325;box-shadow:0 0 0 0 rgba(196,71,47,0.6);animation:newsDotPulse 2s infinite}
@keyframes newsDotPulse{0%{box-shadow:0 0 0 0 rgba(196,71,47,0.6)}70%{box-shadow:0 0 0 8px rgba(196,71,47,0)}100%{box-shadow:0 0 0 0 rgba(196,71,47,0)}}
.news-popup-backdrop{position:fixed;inset:0;background:rgba(15,31,23,0.78);z-index:10002;display:flex;align-items:center;justify-content:center;padding:20px;animation:newsFadeIn .4s}
@keyframes newsFadeIn{from{opacity:0}to{opacity:1}}
.news-popup{background:white;border-radius:18px;padding:0;max-width:420px;width:100%;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,0.5);animation:newsSlideUp .5s ease-out}
@keyframes newsSlideUp{from{transform:translateY(30px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}
.news-popup-banner{background:linear-gradient(135deg,#1A3325,#2D5C43);padding:18px 22px;color:white;position:relative}
.news-popup-eyebrow{font-size:10px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:#C9A84C;display:flex;align-items:center;gap:6px}
.news-popup-eyebrow::before{content:"";display:inline-block;width:7px;height:7px;background:#C4472F;border-radius:50%;animation:newsDotPulse 2s infinite}
.news-popup-title{font-family:'Cormorant Garamond',Georgia,serif;font-size:22px;color:white;line-height:1.2;margin-top:6px;font-weight:400}
.news-popup-close{position:absolute;top:12px;right:14px;background:rgba(255,255,255,0.15);border:none;color:white;width:28px;height:28px;border-radius:50%;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.news-popup-body{padding:18px 22px}
.news-popup-msg{font-size:13px;color:#3D3D38;line-height:1.6;margin-bottom:14px;max-height:140px;overflow-y:auto}
.news-popup-meta{font-size:10px;color:#7A7A72;margin-bottom:14px}
.news-popup-actions{display:flex;gap:8px}
.news-popup-btn{flex:1;padding:12px;border:none;border-radius:24px;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;font-family:inherit;min-height:44px}
.news-popup-btn.primary{background:#C9A84C;color:#1A3325}
.news-popup-btn.secondary{background:transparent;color:#7A7A72;border:1px solid #EDE8DC}
.news-broadcast-bar{background:linear-gradient(135deg,#C9A84C,#E8C97A);padding:8px 12px;border-radius:8px;display:flex;align-items:center;gap:10px;margin-top:8px}
.news-broadcast-status{flex:1;font-size:10px;color:#1A3325;font-weight:600}
.news-broadcast-status.sent{color:#085041}
.news-broadcast-btn{background:#1A3325;color:#C9A84C;border:none;border-radius:14px;padding:6px 12px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;min-height:28px;font-family:inherit}
.news-broadcast-btn:disabled{background:#7A7A72;cursor:not-allowed}
.news-broadcast-btn.sent{background:#085041;color:white}

/* ═══ PATCH 22: Password reset modal ═══ */
.pwr-backdrop{position:fixed;inset:0;background:rgba(15,31,23,0.75);z-index:10001;display:flex;align-items:center;justify-content:center;padding:20px;animation:pwrFadeIn .3s}
@keyframes pwrFadeIn{from{opacity:0}to{opacity:1}}
.pwr-modal{background:white;border-radius:16px;padding:28px 24px;max-width:400px;width:100%;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,0.4);animation:pwrSlideUp .4s ease-out}
@keyframes pwrSlideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.pwr-icon{font-size:48px;margin-bottom:8px}
.pwr-title{font-family:'Cormorant Garamond',Georgia,serif;font-size:24px;color:var(--gd);margin-bottom:6px;font-weight:400}
.pwr-sub{font-size:12px;color:var(--tl);line-height:1.5;margin-bottom:18px}
.pwr-input{width:100%;padding:14px;background:#FAFAF7;border:2px solid var(--gd);border-radius:10px;font-size:14px;color:var(--td);font-family:inherit;margin-bottom:10px;min-height:52px}
.pwr-input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,168,76,0.18);outline:none;background:white}
.pwr-error{background:#FAE8E3;border:1px solid #C4472F;color:#8A2F1C;padding:10px 12px;border-radius:8px;font-size:11px;margin-bottom:10px;line-height:1.4}
.pwr-submit-btn{width:100%;padding:14px;background:var(--gold);color:var(--gd);font-size:13px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;border:none;border-radius:24px;cursor:pointer;min-height:52px;margin-bottom:8px;font-family:inherit}
.pwr-submit-btn:active{background:#B5934A;transform:scale(.98)}
.pwr-submit-btn:disabled{background:#9A9A92;cursor:not-allowed}
.pwr-cancel-btn{width:100%;padding:10px;background:transparent;color:var(--tl);font-size:11px;border:none;cursor:pointer;font-family:inherit}

.pwa-ios-sheet{position:fixed;bottom:0;left:0;right:0;background:white;border-radius:18px 18px 0 0;padding:20px 22px 28px;z-index:10000;box-shadow:0 -4px 20px rgba(0,0,0,.15);animation:pwaSlideUp .4s ease-out;max-width:540px;margin:0 auto}
@keyframes pwaSlideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.pwa-ios-sheet h3{font-family:'Cormorant Garamond',Georgia,serif;font-size:22px;color:var(--gd);margin-bottom:12px}
.pwa-ios-step{display:flex;align-items:flex-start;gap:12px;padding:10px 0;font-size:12px;color:var(--gd);line-height:1.4}
.pwa-ios-step-n{flex-shrink:0;width:24px;height:24px;background:var(--gold);color:var(--gd);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:11px}
.pwa-ios-sheet-close{width:100%;margin-top:14px;padding:12px;background:var(--gd);color:var(--gold);border:none;border-radius:20px;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;cursor:pointer}
.pwa-ios-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:9999;animation:pwaFadeIn .3s}
@keyframes pwaFadeIn{from{opacity:0}to{opacity:1}}
/* ═══ PATCH 18: Admin Dashboard — complete styles ═══ */
#screen-admin{padding-bottom:80px}
.adm-hero{background:#1A3325;padding:48px 20px 20px;position:relative;color:white}
.adm-badge{position:absolute;top:8px;left:50%;transform:translateX(-50%);background:var(--gold);color:var(--gd);font-size:10px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;padding:3px 10px;border-radius:12px}
.adm-eyebrow{font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--gold);margin-top:0}
.adm-title{font-family:'Cormorant Garamond',Georgia,serif;font-size:26px;color:white;line-height:1;margin-top:6px}
.adm-title em{color:#E8C97A;font-style:italic}
.adm-sub{font-size:10px;color:rgba(255,255,255,0.55);margin-top:4px}
.adm-interval-bar{padding:12px 14px 4px;display:flex;align-items:center;justify-content:space-between}
.adm-interval-lbl{font-size:10px;font-weight:500;letter-spacing:0.16em;text-transform:uppercase;color:var(--gold)}
.interval-sel{background:white;border:1px solid var(--ivory);border-radius:8px;padding:6px 10px;font-size:11px;color:var(--gd);font-family:inherit;cursor:pointer}
.adm-sec-hdr{font-family:'Cormorant Garamond',Georgia,serif;font-size:17px;color:var(--gd);padding:14px 14px 4px;display:flex;align-items:center;gap:6px}
.adm-sec-lbl{font-size:10px;font-weight:500;letter-spacing:0.16em;text-transform:uppercase;color:var(--gold);padding:14px 14px 4px}
.adm-card{background:white;border:1px solid var(--ivory);border-radius:10px;padding:12px 14px;margin:0 14px 8px}
.stat-grid{padding:0 14px;display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:4px}
.stat-box{background:white;border:1px solid var(--ivory);border-radius:10px;padding:12px}
.stat-num{font-family:'Cormorant Garamond',Georgia,serif;font-size:26px;color:var(--gd);line-height:1}
.stat-lbl{font-size:8px;color:var(--tl);margin-top:4px;text-transform:uppercase;letter-spacing:0.1em;font-weight:500}
.stat-delta{font-size:10px;color:var(--gold);margin-top:3px}
.pulse-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--red);animation:admpulse 1.5s infinite;vertical-align:middle}
.pulse-dot-green{display:inline-block;width:6px;height:6px;border-radius:50%;background:#085041;animation:admpulse 1.5s infinite;vertical-align:middle;margin-left:4px}
@keyframes admpulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.5;transform:scale(1.4)}}
.pending-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--ivory);gap:8px;transition:opacity .3s}
.pending-row:last-child{border-bottom:none}
.pending-info{flex:1;min-width:0}
.pending-name{font-size:12px;font-weight:600;color:var(--gd)}
.pending-meta{font-size:10px;color:var(--tl);margin-top:2px}
.pending-meta.warn{color:var(--red);font-weight:500}
.pending-actions{display:flex;gap:5px;flex-shrink:0}
.btn-approve,.btn-reject{padding:7px 11px;border:none;border-radius:7px;font-size:10px;font-weight:600;cursor:pointer;min-height:32px}
.btn-approve{background:#085041;color:white}
.btn-approve:active{background:#063D30;transform:scale(.96)}
.btn-approve:disabled{background:#9A9A92;cursor:not-allowed}
.btn-reject{background:transparent;color:var(--red);border:1px solid var(--red)}
.btn-reject:active{background:var(--red);color:white;transform:scale(.96)}
.btn-reject:disabled{opacity:.4;cursor:not-allowed}
.adm-tool-grid{padding:0 14px 10px;display:grid;grid-template-columns:1fr 1fr;gap:8px}
.tool-btn{padding:14px 10px;background:var(--gd);color:#E8C97A;border:1px solid #0F1F17;border-radius:10px;font-size:11px;font-weight:500;min-height:52px;text-align:center;line-height:1.3;box-shadow:0 1px 3px rgba(0,0,0,.08);cursor:pointer;font-family:inherit}
.tool-btn:active{transform:scale(.97);background:#0F1F17}
.tool-btn.danger{background:var(--red);color:white;border-color:#8A2F1C}
.tool-btn.danger:active{background:#8A2F1C}
.tool-btn.success{background:#085041;color:white;border-color:#063D30}
.tool-btn.success:active{background:#063D30}
.traffic-row{display:flex;align-items:center;gap:8px;margin-bottom:7px}
.traffic-row-lbl{width:58px;font-size:10px;color:var(--tm)}
.traffic-row-bar{flex:1;height:9px;background:var(--cream);border-radius:5px;overflow:hidden;border:1px solid var(--ivory)}
.traffic-row-fill{height:100%;background:var(--gold)}
.traffic-row-val{width:40px;font-size:10px;font-weight:500;color:var(--gd);text-align:right}
.traffic-total{font-size:10px;color:var(--tl);margin-top:4px;padding-top:6px;border-top:1px solid var(--ivory);text-align:right}
.game-rank-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--ivory)}
.game-rank-row:last-child{border-bottom:none}
.game-rank-name{font-size:11px;font-weight:500;color:var(--gd)}
.game-rank-plays{font-size:10px;color:var(--tl)}
.game-rank-player{font-size:10px;color:var(--tm);text-align:right}
.game-rank-score{font-family:'Cormorant Garamond',Georgia,serif;font-size:18px;color:var(--gold);line-height:1;text-align:right}
.nps-hdr{display:flex;align-items:baseline;gap:8px;margin-bottom:8px}
.nps-score{font-family:'Cormorant Garamond',Georgia,serif;font-size:32px;color:#085041}
.nps-score.neg{color:var(--red)}
.nps-label{font-size:10px;color:var(--tl)}
.nps-bar{display:flex;gap:3px;height:10px;border-radius:5px;overflow:hidden;margin-bottom:5px;background:var(--cream)}
.nps-bar-seg{height:100%}
.nps-bar-seg.prom{background:#639922}
.nps-bar-seg.pass{background:#FAC775}
.nps-bar-seg.detr{background:var(--red)}
.nps-legend{display:flex;justify-content:space-between;font-size:10px;color:var(--tl)}
.log-card{background:white;border:1px solid var(--ivory);border-radius:10px;margin:0 14px 8px;overflow:hidden}
.log-scroll{max-height:260px;overflow-y:auto}
.log-row{padding:10px 12px;border-bottom:1px solid var(--ivory);transition:opacity .3s}
.log-row:last-child{border-bottom:none}
.log-row.reverted{opacity:.4;background:var(--cream)}
.log-row.revert{background:#FEF8EC}
.log-row-head{display:flex;align-items:center;gap:8px;font-size:10px;margin-bottom:3px}
.log-time{color:var(--tl);font-family:'SF Mono',Monaco,monospace}
.log-email{color:var(--gold);font-weight:500;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.log-undo{background:transparent;border:1px solid var(--red);color:var(--red);padding:2px 8px;border-radius:8px;font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;cursor:pointer}
.log-undo:active{background:var(--red);color:white}
.log-action{font-size:11px;color:var(--gd);line-height:1.4}
.log-action strong{color:var(--gold)}
.adm-loading{text-align:center;padding:40px 20px;color:var(--tl);font-size:12px}
.adm-loading::before{content:"";display:inline-block;width:20px;height:20px;border:2px solid var(--ivory);border-top-color:var(--gold);border-radius:50%;animation:admspin .7s linear infinite;margin-right:8px;vertical-align:middle}
@keyframes admspin{to{transform:rotate(360deg)}}
.undo-toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:var(--gd);color:white;padding:12px 18px;border-radius:24px;display:flex;align-items:center;gap:12px;z-index:900;box-shadow:0 6px 20px rgba(0,0,0,.25);max-width:90vw;transition:opacity .3s,transform .3s}
.undo-toast.hidden{opacity:0;transform:translateX(-50%) translateY(20px);pointer-events:none}
.undo-toast-msg{font-size:12px}
.undo-toast-btn{background:var(--gold);color:var(--gd);border:none;padding:6px 14px;border-radius:14px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer}
.undo-toast-btn:active{background:#B5934A}
.nav-tab.admin-only{display:none}
.nav-tab.admin-only.shown{display:flex}

/* ═══ PATCH 17: Admin Quick Panel ═══ */
.aqp-btn{position:relative;padding:14px 8px;background:var(--cream);border:1px solid var(--ivory);border-radius:10px;font-size:11px;color:var(--gd);font-weight:500;cursor:pointer;min-height:76px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;font-family:inherit}
.aqp-btn:active{transform:scale(.97);background:#EDE8DC}
.aqp-btn.aqp-btn-csv{background:var(--gd);color:var(--gold);border-color:var(--gd)}
.aqp-btn.aqp-btn-csv:active{background:#0F1F17}
.aqp-icon{font-size:22px;line-height:1}
.aqp-lbl{font-size:10px;font-weight:600;line-height:1.25;letter-spacing:.02em}
.aqp-badge{position:absolute;top:6px;right:6px;background:var(--red);color:white;font-size:10px;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}
/* ═══ PATCH 13: Button rendering fix + markant form inputs ═══ */
button{-webkit-appearance:none !important;appearance:none !important;cursor:pointer;font-family:inherit}
button:focus,button:focus-visible{outline:none !important}
button::-moz-focus-inner{border:0;padding:0}
.reg-input{border:2px solid var(--gd) !important;padding:14px !important;min-height:52px !important;font-size:16px !important;background:#FAFAF7 !important;border-radius:10px !important}
.reg-input:focus{border-color:var(--gold) !important;box-shadow:0 0 0 3px rgba(201,168,76,.18) !important;outline:none !important;background:white !important}
#btn-continue-payment{background:var(--gold) !important;color:var(--gd) !important;font-weight:600 !important;min-height:56px !important;box-shadow:0 4px 14px rgba(201,168,76,.3) !important}
#btn-continue-payment:active{transform:scale(.98) !important;background:#B5934A !important}
#new-attendee + button{background:var(--gd) !important;color:var(--gold) !important;min-height:48px !important;min-width:48px !important;border:1px solid #0F1F17 !important;font-size:20px !important;font-weight:600 !important}
#new-attendee + button:active{transform:scale(.95) !important;background:#0F1F17 !important}
#tickets-left-badge span{animation:pulseScarcity 2s infinite}
@keyframes pulseScarcity{0%,100%{opacity:1}50%{opacity:.7}}
/* ── VARIABLES ── */
:root{
  /* ═══ THEME COLORS — Change these to retheme the entire app ═══ */
  --theme-primary: #1A3325;
  --theme-primary-light: #085041;
  --theme-primary-lighter: #0A6B54;
  --theme-accent: #C9A84C;
  --theme-accent-light: #E8C97A;
  --theme-accent-bg: #FBF5E6;
  --theme-danger: #C4472F;
  --theme-success: #085041;
  --theme-success-bg: #E1F5EE;
  --theme-muted: #7A7A72;
  --theme-disabled: #9A9A92;
  --theme-disabled-bg: #E5E5E0;
  /* Surfaces */
  --theme-bg: #F7F3EC;
  --theme-card: #FFFFFF;
  --theme-border: #EDE8DC;
  /* Mapped aliases (used throughout) */
  --gd: var(--theme-primary);
  --gold: var(--theme-accent);
  --gold-l: var(--theme-accent-light);
  --td: #3C3427;
  --tm: #5C5649;
  --tl: var(--theme-muted);
  --cream: var(--theme-bg);
  --ivory: var(--theme-border);
  --red: var(--theme-danger);
  --r: 14px;
  --white: #FFFFFF;
  --gm: #085041;
  --font: 'Inter','Segoe UI',system-ui,-apple-system,sans-serif}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100vh;overflow:hidden;font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--td)}
h1,h2,h3{font-family:'Cormorant Garamond',serif;font-weight:400;line-height:1.15}
input,textarea,select{font-family:'DM Sans',sans-serif}
button{cursor:pointer}

/* ── LANGUAGE TOGGLE ── */
.lang-toggle{display:flex;background:rgba(255,255,255,.1);border-radius:20px;padding:2px}
.lang-btn{padding:4px 11px;font-size:10px;font-weight:500;border:none;border-radius:16px;background:none;color:rgba(255,255,255,.5);cursor:pointer;transition:all .2s}
.lang-btn.active{background:var(--gold);color:var(--gd)}
.lang-toggle-light{background:var(--ivory)}
.lang-toggle-light .lang-btn{color:var(--tl)}
.lang-toggle-light .lang-btn.active{background:var(--gd);color:var(--gold)}

/* ── POPUP X — global regel ── */
.popup-x{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);color:var(--white);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;z-index:99999;-webkit-tap-highlight-color:rgba(255,255,255,.3)}.popup-x:hover{background:rgba(255,255,255,.3)}
.popup-x-dark{background:rgba(0,0,0,.08);color:var(--td)}

/* ── ONBOARDING ── */
#onboard{position:fixed;inset:0;background:var(--gd);z-index:2000;display:flex;flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:40px}
#onboard.hide{display:none}
.ob-hero{padding:56px 28px 28px;text-align:center}
.ob-eyebrow{font-size:10px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.ob-title{font-family:'Cormorant Garamond',serif;font-size:52px;font-weight:300;color:var(--white);line-height:1.05;margin-bottom:6px}
.ob-title em{font-style:italic;color:var(--gold-l)}
.ob-sub{font-size:13px;color:rgba(255,255,255,.5);margin-bottom:20px}
.ob-tabs{display:flex;background:rgba(255,255,255,.07);border-radius:20px;padding:3px;margin:0 16px 14px}
.ob-tab{flex:1;padding:9px;font-size:12px;font-weight:500;text-align:center;border:none;background:none;border-radius:16px;color:rgba(255,255,255,.45);cursor:pointer;transition:all .2s}
.ob-tab.active{background:var(--gold);color:var(--gd);font-weight:600}
.ob-form{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:24px 20px;margin:0 16px 16px}
.ob-label{font-size:10px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:6px}
.ob-input{width:100%;padding:12px 14px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:10px;color:var(--white);font-size:16px;margin-bottom:14px;outline:none}
.ob-input:focus{border-color:var(--gold)}
.ob-input::placeholder{color:rgba(255,255,255,.3)}
.ob-note{font-size:11px;color:rgba(255,255,255,.35);margin-bottom:20px;line-height:1.6}
.ob-btn{width:100%;padding:16px;background:var(--gold);color:var(--gd);font-size:13px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;border:none;border-radius:24px;cursor:pointer;-webkit-appearance:none;touch-action:manipulation}
.ob-skip{display:block;text-align:center;font-size:12px;color:rgba(255,255,255,.3);margin:12px 0 24px;background:none;border:none;width:100%}
.ob-forgot{display:none;text-align:center;font-size:12px;color:var(--gold-l);background:none;border:none;width:100%;margin-bottom:12px}

/* ── SPLASH ── */
#splash{position:fixed;inset:0;background:var(--gd);z-index:1000;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;transition:opacity .8s ease}
#splash.hide{opacity:0;pointer-events:none}

.splash-title{font-family:'Cormorant Garamond',serif;font-size:52px;font-weight:300;color:var(--white);text-align:center;line-height:1.05}
.splash-title em{font-style:italic;color:var(--gold-l)}
.splash-bar{width:48px;height:2px;background:var(--gold);margin:4px auto}
.splash-count{display:flex;gap:16px;margin-top:8px}
.sc-unit{text-align:center}
.sc-num{font-family:'Cormorant Garamond',serif;font-size:36px;font-weight:300;color:var(--gold);line-height:1}
.sc-lbl{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-top:2px}
.splash-enter{margin-top:20px;padding:14px 32px;min-height:48px;background:var(--gold);color:var(--gd);font-size:13px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;border:none;border-radius:24px;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .12s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
@media (hover: hover) and (pointer: fine) {
  .splash-enter:hover{background:var(--gold-l)}
}
.splash-enter:active{transform:scale(0.96);background:var(--gold-l);box-shadow:inset 0 2px 8px rgba(0,0,0,.2)}
.splash-user{font-size:13px;color:rgba(255,255,255,.5);text-align:center}

/* ── LAYOUT ── */
#app{display:flex;flex-direction:column;height:100%;max-width:460px;margin:0 auto;background:var(--cream);box-shadow:0 0 40px rgba(0,0,0,.08);position:relative}
@media (min-width: 768px){
  body{background:#2a3d2f}
  #app{min-height:100vh}
}
#content{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding-bottom:calc(98px + env(safe-area-inset-bottom, 34px))}
.screen{display:none;opacity:0;transition:opacity .3s}
.screen.active{display:block;opacity:1}

/* ── BOTTOM NAV ── */
nav{position:fixed;bottom:0;left:0;right:0;height:calc(72px + env(safe-area-inset-bottom, 34px));background:var(--white);border-top:1px solid var(--ivory);display:flex;align-items:flex-start;justify-content:space-around;z-index:100;box-shadow:0 -4px 20px rgba(0,0,0,.07)}
.nav-tab-center{position:relative;display:flex;flex-direction:column;align-items:center;margin-top:-18px}
.nav-tab-center .nav-circle{width:52px;height:52px;border-radius:50%;background:#1A3325;border:3px solid var(--white);display:flex;align-items:center;justify-content:center;transition:background .2s}
.nav-tab-center .nav-circle svg{width:22px;height:22px;stroke:#C9A84C;fill:none;stroke-width:1.8}
.nav-tab-center.active .nav-circle{background:#C9A84C}
.nav-tab-center.active .nav-circle svg{stroke:#1A3325;stroke-width:2}
.nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;border:none;background:none;color:var(--tl);font-size:8px;font-weight:500;letter-spacing:.05em;text-transform:uppercase;transition:color .2s;padding:8px 0}
.nav-tab.active{color:var(--gold)}
.nav-tab svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round}
.nav-tab.active svg{stroke:var(--gold)}

/* ── CARDS ── */
.card{background:var(--white);border:1px solid var(--ivory);border-radius:var(--r);padding:18px 20px;margin:0 14px 10px}
.card-gold{border-left:3px solid var(--gold);border-radius:0 var(--r) var(--r) 0}
.card-dark{background:var(--gd);border-color:transparent}
.card-cream{background:var(--cream)}
.card-lbl{font-size:10px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:6px}
.card-h{font-size:21px;color:var(--gd);margin-bottom:6px}
.card-h-w{color:var(--white)}
.card-body{font-size:13px;color:var(--tm);line-height:1.7}
.card-body-d{color:rgba(255,255,255,.65)}

/* ── INFO HERO ── */
.info-hero{background:var(--gd);padding:52px 20px 28px;position:relative;overflow:hidden}
.info-hero::before{content:'';position:absolute;top:-40px;right:-40px;width:180px;height:180px;border-radius:50%;border:1px solid rgba(201,168,76,.15);pointer-events:none}
.hero-eyebrow{font-size:10px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.hero-title{font-family:'Cormorant Garamond',serif;font-size:50px;font-weight:300;color:var(--white);line-height:1;margin-bottom:6px}
.hero-title em{font-style:italic;color:var(--gold-l)}
.hero-sub{font-size:13px;color:rgba(255,255,255,.55);margin-bottom:18px}
.date-badge{display:inline-flex;flex-direction:column;align-items:center;background:rgba(201,168,76,.15);border:1px solid rgba(201,168,76,.4);border-radius:8px;padding:8px 18px;margin-bottom:8px}
.date-main{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:400;color:var(--gold);line-height:1.2}
.date-time{font-size:11px;color:var(--gold-l);letter-spacing:.08em}

/* ── COUNTDOWN ── */
.countdown{display:flex;gap:10px;margin:14px 0 0}
.cd-unit{text-align:center;background:rgba(255,255,255,.07);border-radius:8px;padding:8px 12px;min-width:50px}
.cd-num{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:300;color:var(--gold);line-height:1}
.cd-lbl{font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-top:2px}

/* ── TIMELINE ── */
.tl-item{display:flex;gap:12px;padding:11px 0;border-bottom:1px solid var(--ivory)}
.tl-item:last-child{border-bottom:none}
.tl-time{font-size:12px;font-weight:500;color:var(--gold);min-width:40px;padding-top:1px}
.tl-dot{width:7px;height:7px;border-radius:50%;background:var(--gold);flex-shrink:0;margin-top:4px}
.tl-text{font-size:13px;color:var(--tm)}

/* ── SECTION HEADER ── */
.sec-hdr{padding:20px 14px 6px}
.sec-title{font-family:'Cormorant Garamond',serif;font-size:26px;color:var(--gd)}
.sec-sub{font-size:12px;color:var(--tl);margin-top:2px}

/* ── NEWS ── */
.blog-post{background:var(--white);border:1px solid var(--ivory);border-radius:var(--r);padding:18px 20px;margin:0 14px 10px;position:relative}
.blog-date{font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:6px}
.blog-title{font-family:'Cormorant Garamond',serif;font-size:20px;color:var(--gd);margin-bottom:8px}
.blog-body{font-size:13px;color:var(--tm);line-height:1.7}
.blog-empty{text-align:center;padding:48px 24px;color:var(--tl)}
.blog-empty-icon{font-size:40px;margin-bottom:12px;opacity:.4}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
#news-carousel-scroll::-webkit-scrollbar{display:none}
.carousel-thumb{flex-shrink:0;width:140px;height:140px;border-radius:10px;object-fit:cover;cursor:pointer;border:2px solid transparent;transition:border-color .2s}
.carousel-thumb:hover{border-color:var(--gold)}
.blog-img-wrap{position:relative;margin-bottom:10px}
.blog-img{width:100%;border-radius:8px;object-fit:cover;max-height:200px;display:block}
.blog-dl-btn{position:absolute;bottom:8px;right:8px;background:rgba(0,0,0,.55);color:white;border:none;border-radius:20px;padding:5px 12px;font-size:11px;cursor:pointer;text-decoration:none;display:inline-block}
.blog-sched-badge{display:inline-block;background:#FBF5E6;border:1px solid rgba(201,168,76,.3);border-radius:6px;padding:3px 8px;font-size:10px;color:var(--gold);margin-bottom:8px}
.news-admin-bar{display:flex;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid var(--ivory)}
.n-edit-btn{padding:5px 12px;font-size:11px;font-weight:500;background:var(--cream);color:var(--gd);border:1px solid var(--ivory);border-radius:20px;cursor:pointer}
.n-del-btn{padding:5px 12px;font-size:11px;font-weight:500;background:#FBE8E8;color:var(--red);border:none;border-radius:20px;cursor:pointer}

/* ── NEWS ADMIN MODAL ── */
#news-modal{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:10040;display:none;align-items:flex-end;justify-content:center}
#news-modal.show{display:flex}
.news-modal-box{background:var(--cream);border-radius:16px 16px 0 0;padding:24px 20px 32px;width:100%;max-width:480px;max-height:88vh;overflow-y:auto;position:relative}
.nmi-label{font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);display:block;margin-top:12px;margin-bottom:4px}
.nmi-input{width:100%;padding:10px 12px;border:1.5px solid var(--ivory);border-radius:8px;font-size:13px;background:white;outline:none;color:var(--td)}
.nmi-input:focus{border-color:var(--gold)}
.nmi-textarea{width:100%;padding:10px 12px;border:1.5px solid var(--ivory);border-radius:8px;font-size:13px;background:white;resize:none;min-height:80px;outline:none;color:var(--td)}
.nmi-textarea:focus{border-color:var(--gold)}
.nmi-row{display:flex;align-items:center;gap:10px;margin-top:12px}
.nmi-switch{position:relative;width:40px;height:22px;flex-shrink:0}
.nmi-switch input{opacity:0;width:0;height:0;position:absolute}
.nmi-slider-el{position:absolute;inset:0;background:#ccc;border-radius:22px;transition:.3s;cursor:pointer}
.nmi-slider-el::before{content:'';position:absolute;width:16px;height:16px;left:3px;bottom:3px;background:white;border-radius:50%;transition:.3s}
.nmi-switch input:checked + .nmi-slider-el{background:var(--gold)}
.nmi-switch input:checked + .nmi-slider-el::before{transform:translateX(18px)}

/* ── PENDING MODAL ── */
#pending-modal{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:10045;display:none;align-items:flex-end;justify-content:center}
#pending-modal.show{display:flex}
.pending-modal-box{background:var(--cream);border-radius:16px 16px 0 0;padding:24px 20px 32px;width:100%;max-width:480px;max-height:88vh;overflow-y:auto;position:relative}
.p-row{background:white;border:1px solid var(--ivory);border-radius:10px;padding:14px;margin-bottom:8px}
.p-row.expired{background:#FEF2F2;border-color:#FECACA}
.p-name{font-size:15px;font-weight:500;color:var(--td)}
.p-meta{font-size:11px;color:var(--tl);margin-top:3px;line-height:1.5}
.p-timer{font-size:10px;font-weight:500;color:var(--gold);margin-top:4px}
.p-timer.urgent{color:var(--red)}
.p-actions{display:flex;gap:8px;margin-top:10px}
.btn-approve{flex:1;padding:9px;background:var(--gd);color:var(--gold);border:none;border-radius:8px;font-size:12px;font-weight:500;cursor:pointer}
.btn-reject{padding:9px 14px;background:transparent;color:var(--tl);border:1px solid var(--ivory);border-radius:8px;font-size:12px;cursor:pointer}

/* ── MODAL SHARED ── */
.modal-x{position:absolute;top:16px;right:16px;width:30px;height:30px;border-radius:50%;background:rgba(0,0,0,.08);border:none;font-size:18px;color:var(--td);cursor:pointer;display:flex;align-items:center;justify-content:center}

/* ── QUIZ ── */
.quiz-wrap{background:var(--gd);border-radius:var(--r);margin:14px;padding:20px;border-top:3px solid var(--gold)}
.quiz-label{font-size:10px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:4px}
.quiz-title-el{font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--white);margin-bottom:16px}
.quiz-q{font-size:14px;font-weight:500;color:var(--white);margin-bottom:12px;line-height:1.4}
.quiz-opts{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.qopt{padding:11px 14px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.15);border-radius:9px;color:rgba(255,255,255,.8);font-size:13px;text-align:left}
.qopt.correct{background:rgba(201,168,76,.2);border-color:var(--gold);color:var(--gold-l)}
.qopt.wrong{background:rgba(196,71,47,.15);border-color:rgba(196,71,47,.4);color:rgba(255,255,255,.5)}
.quiz-progress{font-size:11px;color:rgba(255,255,255,.4);margin-bottom:12px}
.quiz-btn{padding:11px 24px;background:var(--gold);color:var(--gd);font-size:12px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;border:none;border-radius:20px;margin-top:4px}
.quiz-score{text-align:center;padding:12px 0}
.quiz-score-num{font-family:'Cormorant Garamond',serif;font-size:56px;color:var(--gold);line-height:1}

/* ── PRIZE POPUP ── */
#prize-popup{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:10060;display:none;align-items:center;justify-content:center;padding:24px}
#prize-popup.show{display:flex}
.prize-card{background:var(--gd);border:2px solid var(--gold);border-radius:16px;padding:32px 24px;text-align:center;max-width:340px;width:100%;position:relative}
.prize-icon{font-size:56px;margin-bottom:12px}
.prize-title{font-family:'Cormorant Garamond',serif;font-size:32px;color:var(--gold);margin-bottom:10px}
.prize-body{font-size:14px;color:rgba(255,255,255,.75);line-height:1.6;margin-bottom:20px}
.prize-screenshot{background:rgba(201,168,76,.15);border:1px solid rgba(201,168,76,.4);border-radius:10px;padding:12px 16px;font-size:13px;color:var(--gold-l);margin-bottom:20px;line-height:1.5}
.prize-close{padding:11px 28px;background:var(--gold);color:var(--gd);font-size:12px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;border:none;border-radius:20px}

/* ── GAMES ── */
.games-grid{padding:12px 14px;display:grid;grid-template-columns:1fr 1fr;gap:10px}
.game-card{background:var(--white);border:1px solid var(--ivory);border-radius:var(--r);padding:16px;cursor:pointer;transition:transform .15s;border-top:3px solid var(--gold)}
.game-card:active{transform:scale(.97)}
.game-name{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--gd);margin-bottom:4px}
.game-desc{font-size:11px;color:var(--tl);line-height:1.5;margin-bottom:8px}
.game-best{font-size:10px;font-weight:500;color:var(--gold)}
.play-btn{display:block;width:100%;padding:8px;background:var(--gd);color:var(--gold);font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;border:none;border-radius:20px;margin-top:8px}

/* ── GAME SCREEN ── */
#game-screen{position:fixed;inset:0;background:var(--gd);z-index:200;display:none;flex-direction:column}
#game-screen.open{display:flex}
.game-header{display:flex;align-items:center;justify-content:space-between;padding:50px 16px 10px;background:rgba(0,0,0,.2)}
.game-header-title{font-family:'Cormorant Garamond',serif;font-size:20px;color:var(--white)}
.back-btn{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:var(--white);padding:6px 14px;border-radius:20px;font-size:12px}
.game-canvas-wrap{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}
canvas{touch-action:none;display:block}
.game-score-bar{display:flex;justify-content:space-between;align-items:center;padding:10px 20px;background:rgba(0,0,0,.3)}
.gscore{font-family:'Cormorant Garamond',serif;font-size:28px;color:var(--gold)}
.glbl{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.5)}
#gameover{position:absolute;inset:0;background:rgba(26,51,37,.95);display:none;flex-direction:column;align-items:center;justify-content:center;gap:12px;z-index:10;padding:24px}
#gameover.show{display:flex}
.go-title{font-family:'Cormorant Garamond',serif;font-size:40px;color:var(--white)}
.go-score{font-family:'Cormorant Garamond',serif;font-size:64px;color:var(--gold);line-height:1}
.go-lbl{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.initials-input{background:rgba(255,255,255,.1);border:1px solid rgba(201,168,76,.4);color:var(--white);font-size:24px;text-align:center;padding:10px;border-radius:8px;width:100px;letter-spacing:.2em;text-transform:uppercase}
.go-btn{padding:12px 28px;background:var(--gold);color:var(--gd);font-weight:500;font-size:12px;letter-spacing:.1em;text-transform:uppercase;border:none;border-radius:24px}
.go-btn-sec{padding:10px 24px;background:transparent;color:rgba(255,255,255,.6);font-size:12px;border:1px solid rgba(255,255,255,.2);border-radius:24px}
.milestone-msg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'Cormorant Garamond',serif;font-size:36px;color:var(--gold);text-align:center;pointer-events:none;opacity:0;transition:opacity .3s;z-index:5}
.milestone-msg.show{opacity:1}

/* ── LEADERBOARD ── */
.lb-section{margin-bottom:18px}
.lb-game{font-size:10px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.lb-row{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--white);border-radius:8px;margin-bottom:4px;border:1px solid var(--ivory)}
.lb-rank{font-size:15px;min-width:22px}
.lb-init{font-family:'Cormorant Garamond',serif;font-size:17px;color:var(--gd);min-width:48px}
.lb-pts{margin-left:auto;font-size:13px;font-weight:500;color:var(--gold)}

/* ── BRACKET ── */
.bracket-teaser{text-align:center;padding:36px 20px}
.bracket-teaser-icon{font-size:44px;margin-bottom:12px}
.bracket-teaser-text{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--gd);margin-bottom:6px}
.bracket-teaser-sub{font-size:13px;color:var(--tl)}
.bracket-flex{display:flex;gap:16px;align-items:flex-start;padding:8px 0;overflow-x:auto}
.bracket-round{display:flex;flex-direction:column;gap:8px;min-width:130px}
.round-label{font-size:10px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.bracket-match{background:var(--white);border:1px solid var(--ivory);border-radius:8px;overflow:hidden}
.bracket-player{padding:7px 10px;font-size:12px;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--ivory)}
.bracket-player:last-child{border-bottom:none}
.bracket-player.winner{background:#E1F5EE;color:var(--gm);font-weight:500}
.bracket-player.empty{color:var(--tl)}
.admin-panel{padding:16px;margin:0 14px 10px;background:var(--cream);border-radius:var(--r);border:1px solid var(--ivory)}
.admin-title{font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.admin-input{width:100%;padding:9px 12px;border:1px solid var(--ivory);border-radius:8px;font-size:13px;background:var(--white);margin-bottom:8px}
.admin-btn{padding:8px 16px;background:var(--gd);color:var(--gold);font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;border:none;border-radius:20px;margin-right:6px;margin-bottom:6px}

/* ── SURVEY ── */
.survey-progress{height:3px;background:var(--ivory)}
.survey-fill{height:100%;background:var(--gold);transition:width .4s}
.survey-q{padding:28px 20px 20px;min-height:calc(100vh - 140px);display:flex;flex-direction:column}
.survey-step{font-size:10px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.survey-question{font-family:'Cormorant Garamond',serif;font-size:25px;color:var(--gd);margin-bottom:22px;line-height:1.3}
.survey-options{display:flex;flex-direction:column;gap:8px;flex:1}
.opt-btn{padding:13px 16px;background:var(--white);border:1.5px solid var(--ivory);border-radius:10px;font-size:14px;color:var(--td);text-align:left;transition:border-color .15s,background .15s}
.opt-btn.selected{border-color:var(--gold);background:#FBF5E6}
.survey-text{width:100%;padding:13px;border:1.5px solid var(--ivory);border-radius:10px;font-size:14px;resize:none;min-height:80px;outline:none}
.survey-text:focus{border-color:var(--gold)}
.survey-nav{display:flex;justify-content:space-between;align-items:center;padding:10px 20px 6px;background:var(--white);border-top:1px solid var(--ivory)}
.snext-btn{padding:11px 22px;background:var(--gd);color:var(--gold);font-size:12px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;border:none;border-radius:24px}
.sskip-btn{font-size:12px;color:var(--tl);background:none;border:none}
.stars-row{display:flex;gap:10px;margin-top:8px}
.star-btn{font-size:30px;cursor:pointer;opacity:.3;transition:opacity .2s;background:none;border:none}
.star-btn.lit{opacity:1}
.nps-wrap{padding:6px 0}
.nps-slider{width:100%;accent-color:var(--gold);height:6px;margin:10px 0}
.nps-labels{display:flex;justify-content:space-between;font-size:11px;color:var(--tl)}
.nps-current{text-align:center;font-family:'Cormorant Garamond',serif;font-size:34px;color:var(--gold);margin:8px 0}
.survey-thanks{padding:48px 24px;text-align:center;display:none}
.survey-thanks.show{display:block}
.thanks-title{font-family:'Cormorant Garamond',serif;font-size:34px;color:var(--gd);margin:16px 0 8px}
.mode-toggle{display:flex;background:var(--ivory);border-radius:20px;padding:3px;margin:12px 14px 0}
.mode-btn{flex:1;padding:8px;font-size:12px;font-weight:500;text-align:center;border:none;background:none;border-radius:16px;color:var(--tl);transition:all .2s}
.mode-btn.active{background:var(--gd);color:var(--gold)}

/* ── TILMELD / TICKET ── */
.ticket-card{background:var(--gd);border-radius:16px;margin:0 14px 10px;padding:24px;border:2px solid var(--gold);position:relative;overflow:hidden}
.ticket-card::before{content:'';position:absolute;top:-30px;right:-30px;width:120px;height:120px;border-radius:50%;border:1px solid rgba(201,168,76,.2);pointer-events:none}
.ticket-title{font-family:'Cormorant Garamond',serif;font-size:28px;color:var(--white);margin-bottom:4px}
.ticket-detail{font-size:12px;color:rgba(255,255,255,.55);margin-bottom:3px}
.badge-ok{display:inline-block;background:var(--gold);color:var(--gd);font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:4px 10px;border-radius:20px;margin-top:10px}
.badge-pending{display:inline-block;background:rgba(201,168,76,.15);border:1px solid rgba(201,168,76,.4);color:var(--gold-l);font-size:10px;font-weight:500;padding:4px 10px;border-radius:20px;margin-top:10px}
.reg-form{padding:0 14px}
.reg-label{font-size:10px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--gd);display:block;margin-bottom:6px;margin-top:14px}
.reg-input{width:100%;padding:12px 14px;border:1.5px solid var(--ivory);border-radius:10px;font-size:16px;background:var(--white);outline:none;color:var(--td)}
.reg-input:focus{border-color:var(--gold)}
.mobilepay-box{background:var(--gd);border-radius:14px;margin:0 14px 10px;padding:20px;text-align:center;border:2px solid var(--gold)}
.mp-lbl{font-size:10px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:6px}
.mp-amount{font-family:'Cormorant Garamond',serif;font-size:42px;color:var(--white);line-height:1;margin-bottom:4px}
.mp-number{font-size:28px;font-weight:500;color:var(--gold);letter-spacing:.04em;margin-bottom:6px}
.mp-detail{font-size:11px;color:rgba(255,255,255,.4)}

/* ── GALLERY ── */
.gallery-tabs{display:flex;background:var(--ivory);border-radius:20px;padding:3px;margin:10px 14px 0}
.gallery-tab-btn{flex:1;padding:8px;font-size:11px;font-weight:500;text-align:center;border:none;background:none;border-radius:16px;color:var(--tl);transition:all .2s}
.gallery-tab-btn.active{background:var(--gd);color:var(--gold)}
.upload-area{margin:10px 14px;border:2px dashed rgba(201,168,76,.4);border-radius:12px;padding:24px;text-align:center;cursor:pointer}
.quota-bar-wrap{margin:8px 14px 0}
.quota-bar-bg{height:4px;background:var(--ivory);border-radius:4px;overflow:hidden}
.quota-bar-fill{height:100%;background:var(--gold);border-radius:4px;transition:width .4s}

/* ── PROFILE PANEL ── */
#profile-panel{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:300;display:none}
#profile-inner{position:absolute;right:0;top:0;bottom:0;width:88%;max-width:360px;background:var(--cream);overflow-y:auto;transform:translateX(100%);transition:transform .3s ease;padding-bottom:40px}
.pf-header{background:var(--gd);padding:52px 20px 24px;position:relative}
.pf-name{font-family:'Cormorant Garamond',serif;font-size:28px;color:var(--white)}
.pf-email{font-size:12px;color:rgba(255,255,255,.5);margin-top:4px}
.pf-member{font-size:11px;color:var(--gold);margin-top:2px}
.pf-logout-btn{position:absolute;top:52px;right:16px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.7);padding:6px 12px;border-radius:20px;font-size:16px;cursor:pointer}
.pf-section{padding:14px 16px 0}
.pf-section-title{font-size:10px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.pf-card{background:var(--white);border:1px solid var(--ivory);border-radius:var(--r);padding:14px 16px;margin-bottom:10px}
.pf-row{display:flex;align-items:center;justify-content:space-between;padding:5px 0;border-bottom:1px solid var(--ivory)}
.pf-row:last-child{border-bottom:none}
.pf-row span:first-child{font-size:12px;color:var(--tl)}
.pf-row span:last-child{font-size:12px;font-weight:500;color:var(--td)}
.pf-status{font-size:11px;font-weight:500;padding:3px 8px;border-radius:20px}
.pf-ok{background:#E1F5EE;color:#085041}
.pf-pending{background:#FBF5E6;color:#7A5C00}
.pf-none{background:var(--ivory);color:var(--tl)}

/* ── DATE POPUP ── */
#date-popup{position:fixed;bottom:80px;left:14px;right:14px;z-index:400;display:none}
#date-popup.show{display:block;animation:slideup .3s ease}
@keyframes slideup{from{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}
.dp-card{background:var(--gd);border:1px solid rgba(201,168,76,.4);border-radius:14px;padding:16px 44px 16px 16px;position:relative}
.dp-close{position:absolute;top:10px;right:10px;width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.1);border:none;color:rgba(255,255,255,.7);font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.dp-icon{font-size:22px;margin-bottom:5px}
.dp-title{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--white);margin-bottom:3px}
.dp-body{font-size:12px;color:rgba(255,255,255,.65);line-height:1.5;margin-bottom:10px}
.dp-actions{display:flex;gap:8px}
.dp-btn-p{padding:7px 16px;background:var(--gold);color:var(--gd);font-size:11px;font-weight:500;border:none;border-radius:20px;cursor:pointer}
.dp-btn-s{padding:7px 14px;background:transparent;color:rgba(255,255,255,.5);font-size:11px;border:1px solid rgba(255,255,255,.2);border-radius:20px;cursor:pointer}

/* ── NPS POPUP ── */
#nps-popup{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:10055;display:none;align-items:center;justify-content:center;padding:24px}
#nps-popup.show{display:flex}
.nps-card{background:var(--white);border-radius:16px;padding:28px 22px;max-width:360px;width:100%;position:relative}
.nps-card-title{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--gd);margin-bottom:6px}
.nps-card-sub{font-size:13px;color:var(--tl);margin-bottom:18px;line-height:1.5}
.nps-scores{display:flex;gap:4px;margin-bottom:14px}
.nps-score-btn{flex:1;aspect-ratio:1;border-radius:6px;border:1.5px solid var(--ivory);background:var(--cream);font-size:12px;font-weight:500;color:var(--td);cursor:pointer;min-width:0;transition:all .15s}
.nps-score-btn.sel{background:var(--gd);color:var(--gold);border-color:var(--gd)}
.nps-comment{width:100%;padding:10px 12px;border:1.5px solid var(--ivory);border-radius:8px;font-size:13px;resize:none;min-height:60px;outline:none;margin-bottom:14px;color:var(--td)}
.nps-comment:focus{border-color:var(--gold)}
.nps-submit-btn{width:100%;padding:13px;background:var(--gd);color:var(--gold);font-size:12px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;border:none;border-radius:24px;cursor:pointer}

/* ── SPONSOR ── */
#sponsor-modal{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:10050;display:none;align-items:flex-end;justify-content:center}
#sponsor-modal.show{display:flex}
.sponsor-modal-box{background:var(--cream);border-radius:16px 16px 0 0;padding:24px 20px;width:100%;max-width:480px;max-height:80vh;overflow-y:auto;position:relative}
.sponsor-bar{overflow:hidden;padding:14px 0 12px;background:var(--gd);border-bottom:1px solid rgba(201,168,76,.2)}
.sponsor-bar-label{font-size:10px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);text-align:center;margin-bottom:8px}
@keyframes sponsorAutoScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.sponsor-scroll{display:flex;gap:12px;padding:0 16px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.sponsor-scroll::-webkit-scrollbar{display:none}
.sponsor-chip{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:90px;height:60px;padding:8px 14px;border:1px solid rgba(201,168,76,.25);border-radius:12px;font-size:11px;color:rgba(255,255,255,.6);cursor:pointer;background:rgba(255,255,255,.06);flex-shrink:0}
.sponsor-chip-name{font-size:11px;color:rgba(255,255,255,.75)}

/* ── MOBILEPAY INSTRUCTION POPUP (NY) ── */
#mp-instruction-popup{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:700;display:none;align-items:center;justify-content:center;padding:20px}
#mp-instruction-popup.show{display:flex}
.mp-inst-card{background:var(--gd);border:2px solid var(--gold);border-radius:16px;padding:28px 22px;max-width:360px;width:100%;position:relative;text-align:center}
.mp-inst-icon{font-size:46px;margin-bottom:10px}
.mp-inst-title{font-family:'Cormorant Garamond',serif;font-size:26px;color:var(--gold);margin-bottom:14px;line-height:1.2}
.mp-inst-number-big{font-size:38px;font-weight:500;color:var(--white);letter-spacing:.04em;margin:14px 0 6px;font-family:'DM Sans',sans-serif}
.mp-inst-amount{font-family:'Cormorant Garamond',serif;font-size:26px;color:var(--gold-l);margin-bottom:14px}
.mp-inst-list{text-align:left;background:rgba(255,255,255,.06);border:1px solid rgba(201,168,76,.2);border-radius:10px;padding:14px 16px;margin:14px 0 18px;font-size:13px;color:rgba(255,255,255,.8);line-height:1.8}
.mp-inst-list strong{color:var(--gold-l)}
.mp-inst-note{font-size:11px;color:rgba(255,255,255,.45);margin:8px 0 16px;line-height:1.5}
.mp-inst-btn{width:100%;padding:14px;background:var(--gold);color:var(--gd);font-size:13px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;border:none;border-radius:24px;margin-bottom:8px}
.mp-inst-cancel{width:100%;padding:10px;background:transparent;color:rgba(255,255,255,.5);font-size:12px;border:1px solid rgba(255,255,255,.2);border-radius:24px}

/* ── GALLERY DOWNLOAD OVERLAY (NY) ── */
.gf-btn{padding:6px 14px;border:1px solid var(--ivory);border-radius:20px;background:white;color:var(--td);font-size:12px;font-weight:500;font-family:inherit;cursor:pointer}
.gf-btn.active{background:var(--gd);color:var(--gold);border-color:var(--gd)}
.gal-tile{position:relative;border-radius:8px;overflow:hidden;aspect-ratio:1;background:var(--ivory)}
.gal-tile img{width:100%;height:100%;object-fit:cover;display:block}
.gal-dl-btn{position:absolute;bottom:6px;right:6px;background:rgba(0,0,0,.65);color:white;border:none;border-radius:20px;padding:5px 10px;font-size:11px;cursor:pointer;text-decoration:none;display:flex;align-items:center;gap:3px;line-height:1}

/* ── TOAST (NY) ── */
#toast{position:fixed;bottom:88px;left:50%;transform:translateX(-50%);background:var(--gd);color:var(--gold);padding:10px 18px;border-radius:20px;font-size:12px;font-weight:500;z-index:9998;opacity:0;transition:opacity .3s;pointer-events:none;max-width:90%;text-align:center}
#toast.show{opacity:1}

/* ── SOCIAL FOOTER (NY) ── */
.social-footer{padding:20px 14px 8px;text-align:center}
.social-footer-label{font-size:10px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--tl);margin-bottom:10px}
.social-footer-links{display:flex;gap:10px;justify-content:center}
.social-link{display:flex;align-items:center;gap:6px;padding:8px 14px;background:var(--cream);border:1px solid var(--ivory);border-radius:20px;color:var(--gd);text-decoration:none;font-size:12px;font-weight:500;transition:all .2s}
@media (hover: hover) and (pointer: fine) {
  .social-link:hover{background:var(--gd);color:var(--gold);border-color:var(--gd)}
  .sponsor-carousel-item:hover{border-color:var(--gold)}
}
.social-link:active{background:var(--gd);color:var(--gold);border-color:var(--gd);transform:scale(0.97)}
.sponsor-carousel-item:active{border-color:var(--gold);transform:scale(0.97)}
.social-link svg{flex-shrink:0}

/* ── SPONSOR CAROUSEL (NY) ── */
.sponsor-carousel-wrap{padding:14px 0 4px;background:var(--cream);overflow:hidden;border-top:1px solid var(--ivory);border-bottom:1px solid var(--ivory)}
.sponsor-carousel-label{font-size:10px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);text-align:center;margin-bottom:10px}
.sponsor-carousel{display:flex;gap:22px;overflow-x:auto;padding:0 14px 14px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.sponsor-carousel::-webkit-scrollbar{display:none}
.sponsor-carousel-item{flex-shrink:0;padding:10px 18px;background:white;border:1px solid var(--ivory);border-radius:10px;font-size:12px;color:var(--gd);white-space:nowrap;cursor:pointer;font-weight:500}

/* ── GAME COUNTDOWN OVERLAY (NY) ── */
#game-countdown{position:absolute;inset:0;display:none;align-items:center;justify-content:center;background:rgba(26,51,37,.92);z-index:8;flex-direction:column;gap:10px}
#game-countdown.show{display:flex}
.gc-num{font-family:'Cormorant Garamond',serif;font-size:120px;color:var(--gold);line-height:1;animation:gcPulse .8s ease-out}
.gc-vamos{font-family:'Cormorant Garamond',serif;font-size:64px;font-style:italic;color:var(--gold-l);animation:gcPulse .8s ease-out}
@keyframes gcPulse{0%{transform:scale(.5);opacity:0}50%{transform:scale(1.15);opacity:1}100%{transform:scale(1);opacity:1}}

/* ── CONFETTI ── */
.confetti-piece{position:fixed;width:8px;height:8px;border-radius:2px;animation:cffall linear forwards;z-index:9999;pointer-events:none}
@keyframes cffall{0%{transform:translateY(-20px) rotate(0deg);opacity:1}100%{transform:translateY(100vh) rotate(720deg);opacity:0}}
@keyframes wlpulse{0%,100%{opacity:1}50%{opacity:.3}}
