/* ═══ Mike's Watersports · booking board ═══
   Designed for direct sunlight: max contrast, bold type, fat touch targets. */

:root{
  --navy:#013a63;
  --ink:#0b0f14;
  --paper:#ffffff;
  --line:#c9ced4;
  --line-soft:#e4e7ea;
  --coral:#ff5a45;
  --ok:#2b8a3e;
  --hour-w:96px;
  --row-h:66px;
  --label-w:78px;
  --head-h:40px;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Outfit',system-ui,sans-serif;
  background:var(--paper);
  color:var(--ink);
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overscroll-behavior:none;
}
.hidden{display:none !important}
.spacer{flex:1}
button{font:inherit;cursor:pointer}
input,select,textarea{font:inherit;color:var(--ink)}

/* ── buttons ── */
.btn{
  background:var(--navy);color:#fff;border:none;border-radius:12px;
  padding:12px 20px;font-weight:700;font-size:17px;
  min-height:48px;letter-spacing:.02em;
}
.btn:active{transform:scale(.97)}
.btn.big{font-size:19px;padding:14px 26px}
.btn.small{min-height:42px;padding:8px 16px;font-size:15px}
.btn.full{width:100%}
.btn.ghost{background:#fff;color:var(--navy);border:3px solid var(--navy)}
.btn.danger{background:#c92a2a}
.icon-btn{
  background:transparent;border:none;color:#fff;font-size:24px;
  width:48px;height:48px;border-radius:12px;line-height:1;
}
.icon-btn:active{background:rgba(255,255,255,.2)}

/* ── login ── */
.login{
  position:fixed;inset:0;background:var(--navy);z-index:100;
  display:flex;align-items:center;justify-content:center;padding:20px;
}
.login-card{
  width:100%;max-width:380px;background:#fff;border-radius:20px;
  padding:34px 28px;display:flex;flex-direction:column;gap:14px;
  box-shadow:0 20px 60px rgba(0,0,0,.4);
}
.login-logo{
  font-size:34px;font-weight:800;line-height:1.05;color:var(--navy);
  letter-spacing:-.01em;
}
.login-sub{color:var(--coral);font-weight:700;margin-top:-8px;margin-bottom:8px}
.login-card input{
  border:3px solid var(--ink);border-radius:12px;padding:13px 15px;
  font-size:18px;font-weight:600;width:100%;
}
.login-err{color:#c92a2a;font-weight:700;min-height:22px;text-align:center}

/* ── top bar ── */
.app{display:flex;flex-direction:column;height:100vh;height:100dvh}
.topbar{
  background:var(--navy);color:#fff;display:flex;align-items:center;
  gap:2px;padding:6px 8px;padding-top:calc(6px + env(safe-area-inset-top));
  flex:none;
}
.day-label{
  position:relative;background:transparent;border:none;color:#fff;
  font-weight:800;font-size:18px;padding:8px 10px;border-radius:12px;
  white-space:nowrap;
}
.day-label:active{background:rgba(255,255,255,.2)}
.day-label input[type=date]{
  position:absolute;inset:0;opacity:0;width:100%;height:100%;
}

/* ── day strip ── */
.day-strip{
  display:flex;gap:6px;overflow-x:auto;padding:8px;background:#fff;
  border-bottom:3px solid var(--ink);flex:none;
  scrollbar-width:none;
}
.day-strip::-webkit-scrollbar{display:none}
.day-chip{
  flex:none;border:3px solid var(--line);background:#fff;border-radius:14px;
  padding:6px 12px;text-align:center;min-width:64px;position:relative;
}
.day-chip .dow{font-size:12px;font-weight:700;text-transform:uppercase;color:#5a636d}
.day-chip .dom{font-size:20px;font-weight:800;line-height:1.1}
.day-chip.today .dow{color:var(--coral)}
.day-chip.sel{border-color:var(--ink);background:var(--ink);color:#fff}
.day-chip.sel .dow{color:#ffd7d0}
.day-chip .cnt{
  position:absolute;top:-8px;right:-6px;background:var(--coral);color:#fff;
  font-size:12px;font-weight:800;border-radius:999px;min-width:20px;height:20px;
  display:flex;align-items:center;justify-content:center;padding:0 5px;
  border:2px solid #fff;
}

/* ── board ── */
.board-wrap{
  flex:1;overflow:auto;position:relative;
  -webkit-overflow-scrolling:touch;
}
.board{position:relative;width:max-content;min-width:100%}

.time-head{
  position:sticky;top:0;z-index:30;display:flex;height:var(--head-h);
  background:#fff;border-bottom:3px solid var(--ink);width:max-content;
}
.time-head .corner{
  position:sticky;left:0;z-index:31;width:var(--label-w);flex:none;
  background:#fff;border-right:3px solid var(--ink);
}
.time-head .hr{
  flex:none;width:var(--hour-w);font-size:14px;font-weight:800;
  padding:10px 0 0 6px;color:var(--ink);border-left:1px solid var(--line);
}

.boat-row{
  position:relative;display:flex;height:var(--row-h);width:max-content;
  border-bottom:2px solid var(--line);
}
.boat-row:nth-child(even){background:rgba(1,58,99,.035)}
.boat-label{
  position:sticky;left:0;z-index:20;width:var(--label-w);flex:none;
  background:#fff;border-right:3px solid var(--ink);
  display:flex;align-items:center;padding:4px 6px 4px 0;
  font-size:14px;font-weight:800;line-height:1.1;word-break:break-word;
}
.boat-label .swatch{
  width:8px;align-self:stretch;border-radius:0 4px 4px 0;margin-right:6px;flex:none;
}
.row-canvas{position:relative;flex:none}

/* hour + half-hour gridlines */
.row-canvas::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    repeating-linear-gradient(90deg,
      var(--line-soft) 0, var(--line-soft) 1px,
      transparent 1px, transparent calc(var(--hour-w)/2)),
    repeating-linear-gradient(90deg,
      var(--line) 0, var(--line) 2px,
      transparent 2px, transparent var(--hour-w));
}

/* ── booking bars ── */
.bar{
  position:absolute;top:5px;height:calc(var(--row-h) - 12px);
  border-radius:12px;color:#fff;overflow:visible;
  display:flex;align-items:center;
  box-shadow:0 1px 0 rgba(0,0,0,.25), inset 0 0 0 2px rgba(0,0,0,.18);
  touch-action:pan-x pan-y;
  -webkit-user-select:none;user-select:none;-webkit-touch-callout:none;
  z-index:5;
}
.bar .bar-txt{
  padding:4px 8px 4px 14px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;
  pointer-events:none;
}
.bar .nm{font-weight:800;font-size:15px;display:block;line-height:1.15}
.bar .tm{font-weight:600;font-size:12.5px;opacity:.95;display:block}
.bar .grip{
  position:absolute;top:-6px;bottom:-6px;width:26px;z-index:6;
  touch-action:none;display:flex;align-items:center;justify-content:center;
}
.bar .grip::after{
  content:"";width:6px;height:60%;border-radius:4px;
  background:rgba(255,255,255,.85);box-shadow:0 0 0 1.5px rgba(0,0,0,.35);
}
.bar .grip.l{left:-8px}
.bar .grip.r{right:-8px}
.bar.dark-txt{color:var(--ink)}
.bar.dark-txt .grip::after{background:rgba(0,0,0,.55);box-shadow:0 0 0 1.5px rgba(255,255,255,.6)}

.bar.dragging{
  z-index:50;opacity:.92;
  box-shadow:0 10px 24px rgba(0,0,0,.45), inset 0 0 0 3px #fff;
  transform-origin:center;
}

.drag-tip{
  position:fixed;z-index:60;background:var(--ink);color:#fff;
  font-weight:800;font-size:18px;padding:8px 14px;border-radius:12px;
  pointer-events:none;box-shadow:0 6px 18px rgba(0,0,0,.4);
  white-space:nowrap;
}

/* now line */
.now-line{
  position:absolute;top:0;bottom:0;width:3px;background:var(--coral);
  z-index:12;pointer-events:none;
}
.now-line::before{
  content:"";position:absolute;top:0;left:-5px;width:13px;height:13px;
  background:var(--coral);border-radius:50%;
}

/* ── FAB ── */
.fab{
  position:fixed;right:18px;bottom:calc(18px + env(safe-area-inset-bottom));
  width:64px;height:64px;border-radius:50%;border:none;z-index:40;
  background:var(--coral);color:#fff;font-size:34px;font-weight:700;
  box-shadow:0 8px 22px rgba(0,0,0,.35);
}
.fab:active{transform:scale(.94)}

/* ── sheets ── */
.sheet-back{position:fixed;inset:0;background:rgba(1,20,35,.55);z-index:70}
.sheet{
  position:fixed;left:0;right:0;bottom:0;z-index:71;
  background:#fff;border-radius:22px 22px 0 0;
  max-width:560px;margin:0 auto;max-height:88dvh;overflow-y:auto;
  padding:10px 20px calc(24px + env(safe-area-inset-bottom));
  box-shadow:0 -12px 40px rgba(0,0,0,.35);
  animation:sheet-in .18s ease-out;
}
@keyframes sheet-in{from{transform:translateY(40px);opacity:.6}to{transform:none;opacity:1}}
.sheet-grip{width:48px;height:5px;border-radius:3px;background:var(--line);margin:6px auto 12px}
.sheet h2{font-size:22px;font-weight:800;margin-bottom:14px}
.sheet h3{
  font-size:15px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;
  color:var(--navy);margin:22px 0 10px;border-top:2px solid var(--line-soft);padding-top:16px;
}
.sheet label{display:block;font-weight:700;font-size:15px;margin-bottom:10px}
.sheet input[type=text],.sheet input[type=tel],.sheet input[type=password],
.sheet input[type=date],.sheet input[type=time],.sheet select,.sheet textarea{
  display:block;width:100%;margin-top:4px;
  border:3px solid var(--ink);border-radius:12px;padding:11px 13px;
  font-size:18px;font-weight:600;background:#fff;min-height:50px;
}
.sheet textarea{min-height:0}
/* minmax(0,…) lets the columns shrink — iOS date inputs otherwise refuse and overflow */
.two-col{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,1fr);gap:10px}
.sheet input[type=date]{
  -webkit-appearance:none;appearance:none;min-width:0;
  padding-left:8px;padding-right:6px;
}
.sheet input[type=date]::-webkit-date-and-time-value{text-align:left;margin:0}
.time-selects{display:flex;align-items:center;gap:4px;margin-top:4px}
.time-selects select{
  flex:1;min-width:0;margin-top:0 !important;
  -webkit-appearance:none;appearance:none;
  padding-left:4px !important;padding-right:4px !important;
  text-align:center;text-align-last:center;
}
.time-colon{font-size:20px;font-weight:800;flex:none}
.phone-row{display:flex;gap:8px;align-items:stretch;margin-top:4px}
.phone-row input{margin-top:0 !important;flex:1}
.phone-row .btn{display:flex;align-items:center;text-decoration:none}

.chip-row{display:flex;flex-wrap:wrap;gap:8px;margin:2px 0 14px}
.chip{
  border:3px solid var(--line);background:#fff;border-radius:999px;
  padding:9px 16px;font-weight:800;font-size:16px;min-height:46px;
}
.chip.sel{border-color:var(--ink);background:var(--ink);color:#fff}
.chip.boat-chip.sel{background:var(--chip-c);border-color:var(--chip-c)}
.chip .dot{
  display:inline-block;width:14px;height:14px;border-radius:50%;
  background:var(--chip-c);margin-right:7px;vertical-align:-1px;
  box-shadow:0 0 0 1.5px rgba(0,0,0,.25);
}
.chip.sel .dot{background:#fff}
.color-chip{width:46px;height:46px;border-radius:50%;border:3px solid transparent;padding:0}
.color-chip.sel{border-color:var(--ink);box-shadow:0 0 0 3px #fff inset}

.sheet-actions{display:flex;gap:10px;align-items:center;margin-top:18px}
.meta-line{margin-top:12px;font-size:13px;color:#5a636d;font-weight:600}

.toggle-row{
  display:flex !important;align-items:center;justify-content:space-between;gap:12px;
  border:2px solid var(--line-soft);border-radius:14px;padding:12px 14px;
}
.toggle-row input[type=checkbox]{
  appearance:none;width:58px;height:34px;border-radius:999px;flex:none;
  background:var(--line);position:relative;transition:background .15s;cursor:pointer;
}
.toggle-row input[type=checkbox]:checked{background:var(--ok)}
.toggle-row input[type=checkbox]::after{
  content:"";position:absolute;top:3px;left:3px;width:28px;height:28px;
  border-radius:50%;background:#fff;transition:left .15s;
  box-shadow:0 2px 5px rgba(0,0,0,.3);
}
.toggle-row input[type=checkbox]:checked::after{left:27px}
.toggle-row select{width:auto !important;min-height:44px !important;margin-top:0 !important;padding:6px 10px !important}
.hint{font-size:14px;color:#5a636d;font-weight:600;margin:8px 2px}

.inline-form{display:flex;gap:8px;margin-bottom:10px}
.inline-form input{margin-top:0 !important;flex:1;min-width:0}
.stack-form{display:flex;flex-direction:column;gap:10px;max-width:340px}
.stack-form input{margin-top:0 !important}
.stack-form .btn{align-self:flex-start}

.boat-list,.user-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.boat-item,.user-item{
  display:flex;align-items:center;gap:10px;border:2px solid var(--line-soft);
  border-radius:14px;padding:8px 10px;
}
.boat-item input[type=text]{
  flex:1;min-width:0;margin-top:0 !important;border-width:2px !important;
  min-height:44px !important;font-size:16px !important;
}
.boat-item input[type=color]{
  width:44px;height:44px;border:none;border-radius:10px;padding:0;background:none;flex:none;cursor:pointer;
}
.user-item .u-name{flex:1;font-weight:700;font-size:17px}
.x-btn{
  flex:none;width:42px;height:42px;border-radius:10px;border:none;
  background:#ffe3e0;color:#c92a2a;font-size:19px;font-weight:800;
}

.act-list{display:flex;flex-direction:column;gap:8px}
.act-item{border-left:6px solid var(--navy);background:#f4f6f8;border-radius:8px;padding:9px 12px}
.act-item .a-main{font-weight:800;font-size:16px}
.act-item .a-sub{font-size:13.5px;color:#5a636d;font-weight:600}
.act-item.deleted{border-left-color:#c92a2a}

/* ── toasts ── */
.toasts{
  position:fixed;top:calc(10px + env(safe-area-inset-top));left:12px;right:12px;
  z-index:90;display:flex;flex-direction:column;gap:8px;pointer-events:none;
}
.toast{
  background:var(--ink);color:#fff;border-radius:14px;padding:13px 18px;
  font-weight:700;font-size:16.5px;max-width:520px;margin:0 auto;width:100%;
  box-shadow:0 8px 24px rgba(0,0,0,.4);
  animation:toast-in .2s ease-out;
}
.toast.err{background:#c92a2a}
.toast.ok{background:var(--ok)}
@keyframes toast-in{from{transform:translateY(-16px);opacity:0}to{transform:none;opacity:1}}

@media (min-width:700px){
  :root{--hour-w:120px;--label-w:110px;--row-h:72px}
  .boat-label{font-size:16px}
  .bar .nm{font-size:16px}
}
