*,*::before,*::after{box-sizing:border-box}
:root{
  --bg:#0b1929; --bg-2:#0f2440; --ink:#e6eef8; --muted:#8aa3c0; --accent:#2BA7DF; --accent2:#5DC4F0; --accent3:#7FD7FF;
  --line:rgba(255,255,255,.10); --good:#34d399; --warn:#fbbf24; --bad:#f87171;
  --font-display:"Cormorant Garamond",Georgia,serif;
  --font-sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--font-sans);-webkit-font-smoothing:antialiased}
body{min-height:100vh;background:radial-gradient(1200px 600px at 80% -10%, rgba(43,167,223,.18), transparent 60%), radial-gradient(900px 500px at 0% 100%, rgba(125,215,255,.08), transparent 60%), var(--bg);background-attachment:fixed;padding-bottom:env(safe-area-inset-bottom)}
.h-display{font-family:var(--font-display);font-weight:500;letter-spacing:-.01em;line-height:1.05}
.tab-num{font-variant-numeric:tabular-nums}
a{color:var(--accent2);text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;border:0;background:transparent}
.clay{background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.015)),rgba(15,36,64,.45);backdrop-filter:blur(20px) saturate(160%);border:1px solid var(--line);border-radius:24px;box-shadow:0 24px 48px -16px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,255,255,.12)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 22px;border-radius:999px;font-weight:600;font-size:15px;transition:transform .25s,box-shadow .25s,background .25s}
.btn-primary{background:linear-gradient(135deg,#5DC4F0,#2BA7DF 60%,#1B89C2);color:#fff;box-shadow:0 10px 24px -6px rgba(43,167,223,.55),inset 0 1px 0 rgba(255,255,255,.35)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 36px -8px rgba(43,167,223,.7),inset 0 1px 0 rgba(255,255,255,.45)}
.btn-primary:disabled{opacity:.5;transform:none;cursor:not-allowed}
.btn-ghost{background:rgba(255,255,255,.04);border:1px solid var(--line);color:var(--ink)}
.btn-ghost:hover{background:rgba(255,255,255,.08)}
.input{width:100%;padding:14px 16px;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:14px;color:var(--ink);font-size:16px;outline:none;transition:border-color .2s,background .2s;font-family:inherit}
.input:focus{border-color:var(--accent);background:rgba(255,255,255,.06)}
.label{display:block;font-size:12px;color:var(--muted);margin-bottom:6px;letter-spacing:.06em;text-transform:uppercase}

/* Login */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}
.login-card{max-width:420px;width:100%;padding:32px 28px}
.logo-h{display:flex;justify-content:center;margin-bottom:20px}
.logo-h img{height:64px;width:auto}

/* Top bar */
.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);background:rgba(11,25,41,.82);border-bottom:1px solid var(--line)}
.topbar-l{display:flex;align-items:center;gap:12px;min-width:0;flex:1}
.topbar-l img{height:38px;width:auto;flex-shrink:0;filter:drop-shadow(0 4px 8px rgba(43,167,223,.25))}
.topbar-title{display:flex;flex-direction:column;justify-content:center;min-width:0;line-height:1.05}
.topbar-title h1{font-family:var(--font-display);font-size:22px;margin:0;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.005em}
.user-pill{display:inline-flex;align-items:center;gap:6px;align-self:flex-start;margin-top:3px;padding:2px 9px 2px 7px;background:rgba(43,167,223,.12);border:1px solid rgba(43,167,223,.28);border-radius:999px;font-size:10px;color:var(--accent3);letter-spacing:.08em;text-transform:uppercase;font-weight:600;white-space:nowrap}
.user-pill::before{content:"";width:6px;height:6px;border-radius:999px;background:var(--good);box-shadow:0 0 8px var(--good)}
.topbar-r{display:flex;gap:8px;align-items:center;flex-shrink:0}
.hbtn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:10px 16px;border-radius:999px;font-size:13px;font-weight:600;cursor:pointer;transition:transform .25s cubic-bezier(.22,1,.36,1),box-shadow .25s,background .25s,border-color .25s;font-family:inherit;line-height:1;white-space:nowrap;border:1px solid transparent}
.hbtn svg{width:16px;height:16px;flex-shrink:0}
.hbtn-primary{background:linear-gradient(135deg,#5DC4F0 0%,#2BA7DF 60%,#1B89C2 100%);color:#fff;box-shadow:0 8px 20px -6px rgba(43,167,223,.55),inset 0 1px 0 rgba(255,255,255,.30)}
.hbtn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 28px -8px rgba(43,167,223,.7),inset 0 1px 0 rgba(255,255,255,.4)}
.hbtn-primary:active{transform:translateY(0) scale(.96)}
.hbtn-ghost{background:rgba(255,255,255,.04);color:var(--ink);border-color:var(--line)}
.hbtn-ghost:hover{background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.18);transform:translateY(-1px)}
.hbtn-ghost:active{transform:translateY(0) scale(.96)}
@media (max-width:640px){
  .topbar{padding:12px 14px;gap:8px}
  .topbar-l img{height:34px}
  .topbar-title h1{font-size:18px}
  .hbtn{padding:11px;border-radius:14px}
  .hbtn svg{width:18px;height:18px}
  .hbtn-label{display:none}
}
@media (max-width:380px){
  .topbar-title h1{font-size:16px}
  .user-pill{font-size:9px;padding:1px 7px}
}

/* Container */
.wrap{max-width:1100px;margin:0 auto;padding:18px}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}
@media(max-width:640px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{padding:18px;border-radius:18px;background:rgba(255,255,255,.03);border:1px solid var(--line)}
.stat-l{font-size:11px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px}
.stat-v{font-family:var(--font-display);font-size:30px;line-height:1.05}
.stat.good .stat-v{color:var(--good)}
.stat.warn .stat-v{color:var(--warn)}
.stat.bad .stat-v{color:var(--bad)}

/* Filters */
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.chip{padding:8px 16px;border-radius:999px;background:rgba(255,255,255,.04);border:1px solid var(--line);color:var(--muted);font-size:13px;font-weight:500;transition:all .2s}
.chip.active{background:var(--accent);color:var(--bg);border-color:transparent;box-shadow:0 0 16px -4px var(--accent2)}
.chip:hover:not(.active){background:rgba(255,255,255,.08);color:var(--ink)}

/* Booking list */
.bookings{display:grid;gap:12px}
.booking{padding:18px;border-radius:18px;border:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01));position:relative;overflow:hidden;transition:transform .3s,border-color .3s,box-shadow .3s}
.booking:hover{transform:translateY(-2px);border-color:rgba(43,167,223,.3);box-shadow:0 18px 36px -12px rgba(0,0,0,.5)}
.booking.confirmed{border-left:3px solid var(--good)}
.booking.pending{border-left:3px solid var(--warn)}
.booking.cancelled{border-left:3px solid var(--bad);opacity:.55}
.bk-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}
.bk-when{font-family:var(--font-display);font-size:22px;line-height:1.1;color:var(--accent3)}
.bk-when small{display:block;font-family:var(--font-sans);font-size:12px;color:var(--muted);font-weight:400;margin-top:4px;letter-spacing:.04em;text-transform:uppercase}
.bk-price{font-family:var(--font-display);font-size:24px;color:var(--ink);text-align:right}
.bk-price small{display:block;font-family:var(--font-sans);font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.bk-body{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:560px){.bk-body{grid-template-columns:1fr}}
.bk-row{font-size:14px}
.bk-row strong{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:500;margin-bottom:3px}
.bk-row a{color:var(--accent2);text-decoration:none}
.bk-actions{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}
.bk-actions .btn{padding:8px 14px;font-size:13px;border-radius:999px}
.status-tag{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.status-pending{background:rgba(251,191,36,.15);color:var(--warn)}
.status-confirmed{background:rgba(52,211,153,.15);color:var(--good)}
.status-cancelled{background:rgba(248,113,113,.15);color:var(--bad)}
.empty{text-align:center;padding:60px 20px;color:var(--muted)}
.empty .em-icon{font-size:48px;opacity:.4;margin-bottom:12px}
.loading{text-align:center;padding:40px;color:var(--muted)}

/* Day grouping */
.day-group{margin-bottom:20px}
.day-h{font-family:var(--font-display);font-size:20px;margin:0 0 10px 4px;color:var(--accent3);font-weight:500;display:flex;align-items:baseline;gap:10px}
.day-h .count{font-family:var(--font-sans);font-size:11px;color:var(--muted);background:rgba(255,255,255,.06);padding:3px 9px;border-radius:999px;font-weight:500;letter-spacing:.05em;text-transform:uppercase}

/* Push permission */
.push-banner{margin-bottom:16px;padding:14px 16px;background:rgba(43,167,223,.08);border:1px solid rgba(43,167,223,.25);border-radius:16px;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.push-banner p{margin:0;font-size:13px;color:var(--ink)}
.push-banner small{color:var(--muted);font-size:11px;display:block;margin-top:4px}

/* Toast */
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--bg-2);border:1px solid var(--accent2);padding:12px 18px;border-radius:14px;color:var(--ink);box-shadow:0 18px 36px -12px rgba(0,0,0,.6);z-index:100;font-size:14px;animation:fade-up .3s}
@keyframes fade-up{from{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translateX(-50%)}}

.error{color:var(--bad);font-size:13px;margin-top:6px}
.muted{color:var(--muted)}

[hidden]{display:none !important}


/* Modal */
.modal-overlay{position:fixed;inset:0;z-index:60;display:grid;place-items:center;background:rgba(11,25,41,.85);backdrop-filter:blur(24px) saturate(150%);padding:16px;animation:fade .25s}
.modal-card{max-width:560px;width:100%;max-height:92vh;overflow-y:auto;padding:26px 24px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
@media(max-width:520px){.row2{grid-template-columns:1fr}}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* iOS PWA standalone : respect safe-area (status bar) */
body { padding-top: env(safe-area-inset-top); padding-left: env(safe-area-inset-left); padding-right: env(safe-area-inset-right); }
.topbar { padding-top: calc(14px + env(safe-area-inset-top)) !important; padding-left: calc(18px + env(safe-area-inset-left)); padding-right: calc(18px + env(safe-area-inset-right)); margin-top: calc(env(safe-area-inset-top) * -1); }
.modal-overlay { padding-top: calc(16px + env(safe-area-inset-top)) !important; }
