/* ===== Timmerman Event Center — blue theme ===== */
:root{
  --blue-900:#172554; --blue-800:#1e3a8a; --blue-700:#1d4ed8; --blue-600:#2563eb;
  --blue-500:#3b82f6; --blue-400:#60a5fa; --blue-300:#93c5fd; --blue-100:#dbeafe; --blue-50:#eff6ff;
  --ink:#0f172a; --muted:#64748b; --line:#e2e8f0; --bg:#f4f8ff; --card:#ffffff;
  --danger:#dc2626; --ok:#16a34a; --gold:#f59e0b;
  --shadow:0 10px 30px -12px rgba(29,78,216,.30);
  --shadow-lg:0 24px 60px -18px rgba(29,78,216,.45);
  --radius:18px; --radius-sm:12px;
  --grad:linear-gradient(120deg,var(--blue-600),var(--blue-400) 60%,#22d3ee);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0; font-family:'Segoe UI',system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink); background:var(--bg); line-height:1.5; min-height:100vh;
  overflow-x:hidden;
}
a{color:var(--blue-700);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{line-height:1.2;margin:0 0 .4em}
code{background:var(--blue-50);padding:.1em .4em;border-radius:6px;font-size:.92em;color:var(--blue-800)}
.muted{color:var(--muted)}
em{font-style:normal;color:var(--blue-500);font-weight:600;font-size:.82em;text-transform:uppercase;letter-spacing:.03em}

/* floating background orbs */
.bg-orbs{position:fixed;inset:0;z-index:-1;overflow:hidden;pointer-events:none}
.bg-orbs span{position:absolute;border-radius:50%;filter:blur(60px);opacity:.5;animation:float 18s ease-in-out infinite}
.bg-orbs span:nth-child(1){width:420px;height:420px;background:var(--blue-300);top:-120px;left:-80px}
.bg-orbs span:nth-child(2){width:380px;height:380px;background:#a5f3fc;bottom:-120px;right:-60px;animation-delay:-6s}
.bg-orbs span:nth-child(3){width:300px;height:300px;background:var(--blue-200,#bfdbfe);top:40%;left:60%;animation-delay:-12s}
@keyframes float{0%,100%{transform:translate(0,0)}50%{transform:translate(30px,-40px)}}

/* layout */
.wrap{max-width:1020px;margin:0 auto;padding:26px 18px 60px;animation:rise .5s ease both}
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* top bar */
.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 20px;background:rgba(255,255,255,.8);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.brand{display:flex;align-items:center;gap:12px;font-weight:800;color:var(--ink)}
.brand:hover{text-decoration:none}
.brand-mark{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;
  background:var(--grad);color:#fff;font-weight:900;box-shadow:var(--shadow)}
.brand-mark.big{width:64px;height:64px;font-size:30px;border-radius:18px;margin:0 auto 12px}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand-text small{font-weight:600;color:var(--blue-500);font-size:.7em;letter-spacing:.08em;text-transform:uppercase}
.topnav{display:flex;align-items:center;gap:16px;font-weight:600}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  background:var(--grad);color:#fff;border:0;border-radius:12px;padding:12px 20px;
  font-size:15px;font-weight:700;cursor:pointer;box-shadow:var(--shadow);
  transition:transform .15s,box-shadow .15s,filter .15s;text-decoration:none;background-size:160% 160%}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);text-decoration:none;filter:saturate(1.1)}
.btn:active{transform:translateY(0)}
.btn:disabled{opacity:.6;cursor:default;transform:none}
.btn-block{display:flex;width:100%;margin-top:12px}
.btn-sm{padding:8px 14px;font-size:13px;border-radius:10px}
.btn-xl{padding:18px 26px;font-size:19px;border-radius:16px;margin-top:22px}
.btn-ghost{background:#fff;color:var(--blue-700);box-shadow:none;border:1.5px solid var(--blue-200,#bfdbfe)}
.btn-ghost:hover{background:var(--blue-50);box-shadow:0 6px 16px -10px rgba(29,78,216,.4)}
.btn-add{background:var(--blue-600);background-image:none;animation:pulseGlow 2.6s ease-in-out infinite}
.btn-add:hover{animation:none}
@keyframes pulseGlow{
  0%,100%{box-shadow:0 0 0 0 rgba(37,99,235,.50),0 8px 20px -10px rgba(37,99,235,.5)}
  50%{box-shadow:0 0 26px 5px rgba(37,99,235,.55),0 0 0 6px rgba(37,99,235,.14)}
}
.btn-submit{
  background:linear-gradient(120deg,#16a34a,#22c55e 70%,#4ade80);
  font-size:20px;padding:18px 26px;border-radius:16px;letter-spacing:.01em;
  box-shadow:0 12px 28px -10px rgba(22,163,74,.6)}
.btn-submit:hover{filter:saturate(1.12);box-shadow:0 18px 38px -12px rgba(22,163,74,.7)}
.btn-cant{background:linear-gradient(120deg,#dc2626,#ef4444 75%,#f87171);
  box-shadow:0 10px 24px -12px rgba(220,38,38,.55);margin-top:10px}
.btn-cant:hover{filter:saturate(1.12);box-shadow:0 16px 32px -12px rgba(220,38,38,.65)}
.btn-danger-ghost{background:#fff;color:var(--danger);box-shadow:none;border:1.5px solid #fecaca}
.btn-danger-ghost:hover{background:#fef2f2}
.spark{display:inline-block;animation:spark 1.6s ease-in-out infinite}
@keyframes spark{0%,100%{transform:scale(1) rotate(0)}50%{transform:scale(1.25) rotate(12deg)}}

/* cards */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;box-shadow:var(--shadow);margin-bottom:22px}
.card h2{font-size:1.15rem}

/* hero / home */
.hero{text-align:center;padding:60px 10px 30px}
.hero-badge{display:inline-block;background:var(--blue-100);color:var(--blue-700);font-weight:700;
  padding:6px 16px;border-radius:999px;letter-spacing:.05em;text-transform:uppercase;font-size:.75rem;margin-bottom:18px}
.hero-title{font-size:clamp(2rem,6vw,3.4rem);font-weight:900;letter-spacing:-.02em}
.hero-sub{max-width:560px;margin:18px auto 0;color:var(--muted);font-size:1.05rem}
.grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

/* footer */
.site-footer{text-align:center;padding:26px 16px 40px;color:var(--muted);font-size:.9rem}
.site-footer a{font-weight:700}

/* ===== Public event pages ===== */
.event{max-width:620px;margin:0 auto}
.event-head{text-align:center;margin-bottom:18px}
.event-title{font-size:clamp(1.7rem,5vw,2.6rem);font-weight:900;letter-spacing:-.02em}
.event-meta{list-style:none;padding:0;margin:0 0 20px;display:grid;gap:10px}
.event-meta li{display:flex;align-items:flex-start;gap:14px;background:#fff;border:1px solid var(--line);
  border-radius:14px;padding:14px 16px;box-shadow:var(--shadow)}
.event-meta .ico{font-size:1.3rem;line-height:1.4}
.event-meta .lbl{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--blue-500);font-weight:700}
.event-photo{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg);margin-bottom:20px}
.event-photo img{display:block;width:100%;height:auto}
.event-notes{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px 18px;margin-bottom:18px;box-shadow:var(--shadow)}
.event-notes h3{font-size:.95rem;color:var(--blue-700)}
.rsvp-by{text-align:center;color:var(--muted);margin:6px 0}
.page-switch{text-align:center;margin-top:22px;font-weight:600}

/* plan / menu header */
.plan-head{text-align:center;margin:6px 0 18px}
.plan-head h2{font-size:1.7rem;font-weight:900}

/* person rows / cards */
.people{display:grid;gap:10px}
.person-row{display:flex;gap:8px;align-items:center}
.person-row .inp{flex:1}
.person-row-del,.person-del{background:#fff;border:1.5px solid var(--line);color:var(--muted);
  width:42px;height:42px;border-radius:11px;font-size:22px;line-height:1;cursor:pointer;flex:none;transition:.15s}
.person-row-del:hover,.person-del:hover{border-color:#fecaca;color:var(--danger);background:#fef2f2}
.person-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:16px;
  padding:18px;margin-bottom:14px;box-shadow:var(--shadow)}
.person-del{position:absolute;top:12px;right:12px;width:34px;height:34px;font-size:18px}
.menu-grid{display:grid;gap:8px;margin-top:6px}
.menu-line{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:10px 12px;border:1px solid var(--line);border-radius:11px;background:var(--blue-50)}
.menu-name{font-weight:600;flex:1;min-width:0}
.menu-line .menu-qty{width:92px;flex:none}
.enter{animation:pop .28s ease both}
@keyframes pop{from{opacity:0;transform:scale(.96) translateY(-6px)}to{opacity:1;transform:none}}

/* inputs */
.inp{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:11px;font-size:15px;
  font-family:inherit;background:#fff;color:var(--ink);transition:border-color .15s,box-shadow .15s}
.inp:focus{outline:none;border-color:var(--blue-400);box-shadow:0 0 0 4px rgba(96,165,250,.25)}
select.inp{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%232563eb' stroke-width='2' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
.fld{display:block;margin-bottom:16px}
.fld>span{display:block;font-weight:700;margin-bottom:6px;font-size:.92rem}
.hint{display:block;color:var(--muted);font-size:.82rem;margin-top:6px}
.shake{animation:shake .4s}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-6px)}40%,80%{transform:translateX(6px)}}

/* ===== Modal ===== */
.modal{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;
  padding:18px;background:rgba(15,23,42,.55);backdrop-filter:blur(4px)}
.modal.show{display:flex;animation:fade .2s ease both}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal-card{position:relative;background:#fff;border-radius:22px;padding:30px 26px;max-width:440px;width:100%;
  box-shadow:var(--shadow-lg);animation:slideUp .32s cubic-bezier(.2,.9,.3,1.2) both;max-height:90vh;overflow:auto}
@keyframes slideUp{from{opacity:0;transform:translateY(30px) scale(.97)}to{opacity:1;transform:none}}
.modal-x{position:absolute;top:14px;right:14px;border:0;background:var(--blue-50);color:var(--blue-700);
  width:36px;height:36px;border-radius:50%;font-size:22px;line-height:1;cursor:pointer}
.modal-x:hover{background:var(--blue-100)}
.modal-body h2{font-size:1.5rem}
.success-state{text-align:center}
.big-check{font-size:3.4rem;animation:pop .5s ease both}

/* pin / login cards */
.pin-card,.login-card{max-width:400px;margin:6vh auto;text-align:center}
.pin-lock{font-size:2.6rem;margin-bottom:6px}
.pin-form{margin-top:18px}
.pin-input{text-align:center;font-size:2rem;letter-spacing:.5em;font-weight:800;padding:14px;transition:border-color .2s,box-shadow .2s,background .2s,color .2s}
.pin-input.ok{border-color:var(--ok)!important;color:var(--ok);background:#f0fdf4;box-shadow:0 0 0 4px rgba(22,163,74,.22)!important}
.pin-card.unlocked .btn{background:var(--ok);background-image:none}
.error-msg{background:#fef2f2;color:var(--danger);border:1px solid #fecaca;border-radius:11px;padding:10px 14px;font-weight:600}
.error-box{background:#fef2f2;color:#991b1b;border:1px solid #fecaca;border-radius:14px;padding:14px 18px;margin-bottom:18px}
.error-box ul{margin:.4em 0 0;padding-left:1.2em}

/* ===== Admin ===== */
.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.page-head h1{font-size:1.8rem;font-weight:900}
.head-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.head-actions form{margin:0}
.back{display:inline-block;color:var(--muted);font-weight:600;margin-bottom:6px;font-size:.9rem}

.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.stat-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:var(--shadow);
  position:relative;overflow:hidden;transition:transform .15s}
.stat-card:hover{transform:translateY(-3px)}
.stat-card::after{content:"";position:absolute;right:-20px;top:-20px;width:70px;height:70px;border-radius:50%;background:var(--blue-50)}
.stat-ico{font-size:1.5rem;position:relative}
.stat-num{font-size:2rem;font-weight:900;color:var(--blue-700);position:relative}
.stat-lbl{color:var(--muted);font-weight:600;font-size:.85rem;position:relative}

/* bar chart */
.bar-chart{display:grid;gap:12px;margin-top:8px}
.bar-row{display:grid;grid-template-columns:140px 1fr;align-items:center;gap:12px}
.bar-label{font-weight:600;font-size:.9rem;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
a.bar-label:hover{color:var(--blue-700)}
.bar-track{background:var(--blue-50);border-radius:999px;height:26px;overflow:hidden}
.bar-fill{height:100%;width:0;background:var(--grad);border-radius:999px;display:flex;align-items:center;
  justify-content:flex-end;padding-right:10px;color:#fff;font-weight:700;font-size:.82rem;
  animation:grow 1s cubic-bezier(.2,.8,.2,1) forwards}
@keyframes grow{to{width:var(--w)}}
.bar-fill span{text-shadow:0 1px 2px rgba(0,0,0,.2)}

/* event list */
.event-list{display:grid;gap:10px}
.event-row{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff;
  border:1px solid var(--line);border-radius:14px;padding:14px 18px;transition:.15s}
.event-row:hover{text-decoration:none;border-color:var(--blue-300);box-shadow:var(--shadow);transform:translateX(2px)}
.er-title{font-weight:800;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.er-sub{color:var(--muted);font-size:.85rem}
.er-stats{display:flex;align-items:center;gap:16px;color:var(--muted);font-weight:600}
.er-go{color:var(--blue-500);font-size:1.3rem}
.pill{font-size:.66rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;padding:3px 8px;border-radius:999px}
.pill-up{background:var(--blue-100);color:var(--blue-700)}
.pill-lock{background:#fef3c7;color:#92400e}

/* manage layout */
.manage-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:start}
.manage-grid .col{min-width:0}
.detail-list{list-style:none;padding:0;margin:0}
.detail-list li{display:grid;grid-template-columns:90px 1fr;gap:12px;padding:9px 0;border-bottom:1px dashed var(--line)}
.detail-list li:last-child{border-bottom:0}
.detail-list span{color:var(--muted);font-weight:700;font-size:.85rem}
.link-row{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}

/* chips (menu items) */
.chip-list{list-style:none;padding:0;margin:0 0 14px;display:flex;flex-wrap:wrap;gap:8px}
.chip{display:inline-flex;align-items:center;gap:6px;background:var(--blue-50);border:1px solid var(--blue-100);
  color:var(--blue-800);border-radius:999px;padding:6px 8px 6px 14px;font-weight:600}
.chip form{margin:0;display:inline}
.chip-x{border:0;background:#fff;color:var(--muted);width:24px;height:24px;border-radius:50%;cursor:pointer;font-size:16px;line-height:1}
.chip-x:hover{background:#fef2f2;color:var(--danger)}
.add-item{display:flex;gap:8px}
.add-item .inp{flex:1}

/* QR */
.qr-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.qr-box{text-align:center;background:var(--blue-50);border:1px solid var(--blue-100);border-radius:14px;padding:14px}
.qr-render{background:#fff;border-radius:10px;padding:6px;display:flex;justify-content:center}
.qr-render svg{width:100%;height:auto;max-width:200px}
.qr-label{font-weight:700;margin:10px 0 8px}

/* tabs + tables */
.tabs{display:flex;gap:6px;border-bottom:2px solid var(--line);margin-bottom:14px}
.tab{background:none;border:0;padding:10px 14px;font-weight:700;color:var(--muted);cursor:pointer;
  border-bottom:3px solid transparent;margin-bottom:-2px;font-size:.95rem}
.tab.active{color:var(--blue-700);border-color:var(--blue-600)}
.data-table{width:100%;border-collapse:collapse;font-size:.92rem}
.data-table th{text-align:left;color:var(--muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;
  padding:8px 10px;border-bottom:2px solid var(--line)}
.data-table td{padding:9px 10px;border-bottom:1px solid var(--line)}
.data-table tr:hover td{background:var(--blue-50)}
.ta-c{text-align:center}.ta-r{text-align:right}
.row-del{border:0;background:none;cursor:pointer;font-size:1.05rem;opacity:.6;transition:.15s}
.row-del:hover{opacity:1;transform:scale(1.15)}

/* forms */
.form .grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.photo-current{display:flex;align-items:center;gap:14px;margin-bottom:10px}
.photo-current img{width:90px;height:90px;object-fit:cover;border-radius:12px;border:1px solid var(--line)}
.check{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--muted);font-weight:600;text-transform:none;letter-spacing:0}

.empty{text-align:center;color:var(--muted);padding:24px;background:var(--blue-50);border-radius:14px;font-weight:600}

/* responsive */
@media(max-width:820px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .manage-grid{grid-template-columns:1fr}
  .form .grid-2{grid-template-columns:1fr}
}
@media(max-width:480px){
  .bar-row{grid-template-columns:96px 1fr}
  .topnav{gap:10px;font-size:.9rem}
  .qr-grid{grid-template-columns:1fr}
}
