:root{
  --accent:#ec4899; --accent2:#db2777; --green:#22c55e; --red:#ef4444; --amber:#f59e0b;
  --bg:#fdf4f9; --card:#fff; --line:#f3e1ec; --text:#1a1a24; --muted:#9a8a92; --radius:14px;
  --tint:#fce7f3; --tint-border:#fbcfe8;
}
*{box-sizing:border-box}
/* The [hidden] attribute must always win over class display rules (e.g. .modal,
   .ios-hint use display:flex) — otherwise hidden overlays block all taps. */
[hidden]{display:none !important}
html,body{margin:0;padding:0}
/* White html bg so the bottom safe-area area matches the white tabbar (no
   lavender gap under the nav on notch/home-indicator iPhones). */
html{background:#fff}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;
  background:var(--bg);color:var(--text);
  -webkit-tap-highlight-color:transparent;
}
/* Normal document scroll; the tab bar is fixed to the true bottom edge (below).
   Pad the body so content clears the fixed tab bar + home-indicator safe area. */
body.app{padding-bottom:calc(56px + env(safe-area-inset-bottom))}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit;font-size:16px}
.muted{color:var(--muted)} .tiny{font-size:12px}
.empty{text-align:center;color:var(--muted);padding:30px;font-size:14px}

/* ── Login ── */
.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;
  background:radial-gradient(700px 320px at 50% -10%,rgba(236,72,153,.35),transparent),var(--bg);padding:24px}
.login-card{background:var(--card);border-radius:18px;padding:30px 24px;width:100%;max-width:360px;
  box-shadow:0 16px 40px rgba(60,40,120,.14);text-align:center}
.login-logo{width:92px;height:92px;border-radius:22px;object-fit:cover;box-shadow:0 6px 18px rgba(236,72,153,.25)}
.login-card h1{margin:6px 0 0;font-size:22px}
.login-card form{margin-top:18px;text-align:left}
.login-card label{font-size:13px;color:var(--muted);display:block;margin-bottom:5px}
.login-card input{width:100%;padding:12px;border:1px solid var(--line);border-radius:10px;margin-bottom:14px}
.alert{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;border-radius:10px;padding:9px;font-size:13px;margin-top:10px}
.guest-btn{display:block;margin-top:12px;text-align:center;text-decoration:none;
  background:#fff;color:var(--accent2);border:1px solid var(--tint-border);border-radius:12px;
  padding:12px;font-size:15px;font-weight:700}

/* ── App bar ── */
.appbar{position:sticky;top:0;z-index:20;background:linear-gradient(135deg,#ec4899,#f9a8d4);
  color:#fff;padding:calc(env(safe-area-inset-top) + 12px) 14px 12px;box-shadow:0 2px 10px rgba(80,50,160,.2)}
.appbar-row{display:flex;align-items:center;justify-content:space-between}
.brand{font-weight:800;font-size:18px;display:flex;align-items:center;gap:8px}
.brand-logo{width:30px;height:30px;border-radius:8px;object-fit:cover;flex:0 0 auto}
.acct{position:relative}
.login-link{color:#fff;font-size:13px;text-decoration:none;background:rgba(255,255,255,.22);padding:7px 13px;border-radius:999px;font-weight:600;white-space:nowrap}
.acct summary{list-style:none;font-size:13px;opacity:.95;cursor:pointer}
.acct summary::-webkit-details-marker{display:none}
.acct-menu{position:absolute;right:0;top:24px;background:#fff;border-radius:10px;overflow:hidden;
  box-shadow:0 10px 24px rgba(0,0,0,.18);min-width:140px;z-index:30}
.acct-menu button{display:block;width:100%;text-align:left;padding:11px 14px;border:0;background:#fff;color:var(--text);font-size:13px}
.acct-menu button:hover{background:#fce7f3}
.acct-menu form{margin:0;border-top:1px solid var(--line)}
.search-row{margin-top:10px}
.search-row input{width:100%;border:0;border-radius:12px;padding:11px 14px 11px 40px;font-size:14px;color:var(--text);
  background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%239a8a92' stroke-width='2' stroke-linecap='round'%3E%3Ccircle cx='7' cy='7' r='5'/%3E%3Cline x1='11' y1='11' x2='15' y2='15'/%3E%3C/svg%3E") no-repeat 15px center;
  box-shadow:0 2px 8px rgba(120,40,90,.08)}
.search-row input::placeholder{color:#b09aa4}
.search-row input:focus{outline:2px solid rgba(255,255,255,.7)}

/* ── Chips ── */
.chips{display:flex;gap:8px;padding:12px;overflow-x:auto}
.chip{white-space:nowrap;background:#fce7f3;color:var(--accent2);border:1px solid #fbcfe8;
  border-radius:999px;padding:6px 13px;font-size:13px}
.chip.on{background:var(--accent2);color:#fff;border-color:var(--accent2)}

/* ── Catalogue grid ── */
.view{min-height:60vh}
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:11px;padding:0 12px;align-content:start}
@media(min-width:620px){.grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:900px){.grid{grid-template-columns:repeat(4,1fr)}}
.card{background:var(--card);border:1px solid var(--line);border-radius:13px;overflow:hidden;
  box-shadow:0 2px 8px rgba(30,20,70,.05);display:flex;flex-direction:column}
.card-img{position:relative;aspect-ratio:1/1;background:linear-gradient(135deg,#fbcfe8,#f9a8d4)}
.ph{width:100%;height:100%;object-fit:cover;display:block}
.ph-fallback{display:flex;align-items:center;justify-content:center;font-size:38px}
.ph-logo{object-fit:contain;padding:20%;opacity:.55;background:linear-gradient(135deg,#fce7f3,#fbcfe8)}
.av{position:absolute;top:6px;left:6px;font-size:10px;font-weight:700;color:#fff;padding:3px 7px;border-radius:7px;max-width:90%}
.av.ok{background:var(--green)} .av.no{background:var(--red)} .av.od{background:var(--amber)}
.card-body{padding:8px 9px}
.card-body .nm{font-weight:700;font-size:13px;line-height:1.25}
.card-body .meta{font-size:11px;color:var(--muted);margin-top:2px}
.card-body .price{font-size:13px;font-weight:700;color:var(--accent2);margin-top:3px}

/* ── Forms ── */
.form{padding:14px;display:flex;flex-direction:column;gap:4px}
.form label{font-size:12px;color:var(--muted);margin-top:8px}
.form input,.form select,.form textarea{width:100%;padding:11px;border:1px solid var(--line);border-radius:10px;background:#fff}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.grid2>div{min-width:0}
.grid2 label{margin-top:6px}
.form input{min-width:0;max-width:100%}
/* Full-width date fields, stacked and aligned with the other inputs.
   appearance:none forces iOS date inputs to stretch to 100% like the <select>
   (default styling sizes them to content, making them look narrower). */
.datefield{display:block;width:100%;text-align:left;-webkit-appearance:none;appearance:none;
  background:#fff;min-height:42px;line-height:1.2}
.dropzone{display:flex;align-items:center;justify-content:center;min-height:150px;border:2px dashed #f9a8d4;
  background:#fdf2f8;border-radius:12px;color:var(--accent2);text-align:center;overflow:hidden}
.dropzone .dz-ico{font-size:30px}
#dz-preview{width:100%;max-height:240px;object-fit:cover}
.btn-primary{margin-top:14px;background:var(--accent2);color:#fff;border:0;border-radius:12px;
  padding:13px;font-size:15px;font-weight:700;width:100%}
.btn-primary:disabled{opacity:.6}
.btn-secondary{margin-top:8px;background:#fce7f3;color:var(--accent2);border:1px solid #fbcfe8;
  border-radius:12px;padding:12px;font-size:14px;font-weight:700;width:100%}
.btn-danger{margin-top:8px;background:#fee2e2;color:#b91c1c;border:1px solid #fecaca;
  border-radius:12px;padding:12px;font-size:14px;font-weight:700;width:100%}

/* ── Bookings ── */
.newbooking{margin:12px;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.newbooking>summary{padding:12px 14px;font-weight:700;color:var(--accent2);list-style:none;cursor:pointer}
.newbooking>summary::-webkit-details-marker{display:none}
.seg{display:flex;gap:6px;padding:0 12px 8px;overflow-x:auto}
.seg button{background:#e7e7ef;border:0;border-radius:9px;padding:7px 12px;font-size:13px;color:#666;white-space:nowrap}
.seg button.on{background:#fff;color:var(--text);font-weight:700;box-shadow:0 1px 4px rgba(0,0,0,.08)}
#bookings-list{padding:0 12px;display:flex;flex-direction:column;gap:10px}
.bk{background:#fff;border:1px solid var(--line);border-radius:12px;padding:11px}
.bk-head{display:flex;justify-content:space-between;align-items:center;font-size:13px}
.ph-tag{font-size:10px;font-weight:700;padding:2px 8px;border-radius:6px;color:#fff;text-transform:capitalize}
.ph-tag.ok{background:var(--green)} .ph-tag.no{background:var(--red)} .ph-tag.od{background:var(--amber)} .ph-tag.past{background:#9aa3b2}
.bk-sub{font-size:12px;color:var(--muted);margin:3px 0 8px}
.bk-row{display:flex;align-items:center;gap:8px;margin-top:7px}
.bk-row input[type=date]{flex:1;min-width:0;padding:8px;border:1px solid var(--line);border-radius:8px;background:#fff}
.bk-row select{flex:1;min-width:0;padding:8px;border:1px solid var(--line);border-radius:8px;background:#fff}
.bk-row>span{flex:0 0 auto;color:var(--muted)}
.btn-save{flex:0 0 auto;background:var(--accent2);color:#fff;border:0;border-radius:8px;padding:9px 14px;font-weight:700;font-size:13px}
.btn-del{flex:0 0 auto;background:#fee;color:#b91c1c;border:1px solid #fbb;border-radius:8px;padding:9px 11px;font-size:13px}

/* ── Tabbar ── */
.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:25;display:flex;background:#fff;
  border-top:1px solid var(--line);padding-bottom:env(safe-area-inset-bottom)}
.tabbar button{flex:1;border:0;background:none;padding:9px 0 8px;font-size:18px;color:#9aa3b2;display:flex;flex-direction:column;align-items:center;gap:1px}
.tabbar button span{font-size:10px}
.tabbar button.on{color:var(--accent2)}

/* ── Modal / detail ── */
.modal{position:fixed;inset:0;z-index:40;background:rgba(12,8,24,.5);display:flex;align-items:flex-end;justify-content:center}
@media(min-width:620px){.modal{align-items:center}}
.modal-card{background:#fff;width:100%;max-width:460px;max-height:82vh;overflow:auto;border-radius:18px 18px 0 0;position:relative}
@media(min-width:620px){.modal-card{border-radius:18px}}
.modal-x{position:absolute;top:12px;right:12px;z-index:2;background:rgba(0,0,0,.5);color:#fff;border:0;border-radius:50%;width:38px;height:38px;font-size:17px;display:flex;align-items:center;justify-content:center}
.detail-img{aspect-ratio:1/1;background:linear-gradient(135deg,#fbcfe8,#f9a8d4)}
.detail-body{padding:14px}
.detail-body h2{margin:0 0 8px;font-size:19px}
.av-big{display:inline-block;font-size:13px;font-weight:700;color:#fff;padding:5px 12px;border-radius:9px}
.av-big.ok{background:var(--green)} .av-big.no{background:var(--red)} .av-big.od{background:var(--amber)}
.drow{display:flex;justify-content:space-between;font-size:13px;color:#555;padding:7px 0;border-bottom:1px solid #f1f0f6}
.drow.col{flex-direction:column;gap:4px}
.upcoming{margin-top:10px;background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;border-radius:10px;padding:8px 10px;font-size:12px}
.modal-card>.btn-primary{margin:0 14px 8px;width:calc(100% - 28px)}
.modal-card>.btn-secondary{margin:0 14px 16px;width:calc(100% - 28px)}

/* ── iOS hint + toasts ── */
.ios-hint{position:sticky;top:0;z-index:50;background:#1e222e;color:#fff;font-size:12px;
  padding:9px 12px;display:flex;align-items:center;gap:8px}
.ios-hint button{margin-left:auto;background:none;border:0;color:#9aa3b2;font-size:14px}
.toasts{position:fixed;left:0;right:0;bottom:80px;z-index:60;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none}
.toast{background:#16a34a;color:#fff;padding:10px 16px;border-radius:11px;font-size:13px;font-weight:700;box-shadow:0 6px 18px rgba(0,0,0,.25)}
.toast.err{background:#dc2626}
