:root{
  --calas-blue:#0ea5e9;
  --calas-blue-2:#2563eb;
  --calas-aqua:#22d3ee;
  --calas-mint:#24d6a8;
  --calas-violet:#6d5dfc;
  --calas-ink:#122033;
  --calas-muted:#75839a;
  --calas-soft:#f3f9ff;
  --calas-card:rgba(255,255,255,.82);
  --calas-border:rgba(255,255,255,.78);
  --calas-shadow:0 18px 48px rgba(15,42,80,.11);
  --calas-shadow-soft:0 10px 28px rgba(15,42,80,.08);
  --calas-radius:24px;
}
*{box-sizing:border-box;min-width:0}
html{min-height:100%;background:#eef8ff;overflow-x:hidden}
body.pwa-body{
  min-height:100vh;
  margin:0;
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"SF Pro Display","Segoe UI",sans-serif;
  color:var(--calas-ink);
  background:
    radial-gradient(circle at 18% 0%, rgba(14,165,233,.20), transparent 30%),
    radial-gradient(circle at 96% 22%, rgba(109,93,252,.12), transparent 28%),
    radial-gradient(circle at 66% 92%, rgba(36,214,168,.11), transparent 30%),
    linear-gradient(160deg,#f7fbff 0%,#edf8ff 52%,#fbfbff 100%);
  padding-bottom:calc(86px + env(safe-area-inset-bottom));
  overflow-x:hidden;
}
body.pwa-body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:.28;
  background-image:linear-gradient(135deg,rgba(255,255,255,.85) 0 1px,transparent 1px);
  background-size:46px 46px;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.75),transparent 70%);
}
a{color:var(--calas-blue-2);text-decoration:none}

.pwa-app-header{
  position:sticky;top:0;z-index:30;
  padding:10px 12px 4px;
  background:linear-gradient(180deg,rgba(239,248,255,.92),rgba(239,248,255,.50),transparent);
  backdrop-filter:blur(16px);
}
.pwa-app-bar{
  width:min(100%,540px);
  margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  background:rgba(255,255,255,.70);
  border:1px solid rgba(255,255,255,.84);
  box-shadow:var(--calas-shadow-soft);
  border-radius:22px;
  padding:8px 9px;
}
.pwa-brand{display:flex;align-items:center;gap:9px;min-width:0;color:var(--calas-ink)}
.pwa-brand-logo{width:38px;height:38px;object-fit:contain;border-radius:13px;background:rgba(255,255,255,.88);box-shadow:0 8px 18px rgba(15,42,80,.08);padding:4px;flex:0 0 auto}
.pwa-brand-text{display:flex;flex-direction:column;line-height:1.05;min-width:0}
.pwa-brand-text strong{font-size:13px;font-weight:900;letter-spacing:-.03em;white-space:nowrap}
.pwa-brand-text small{font-size:10.5px;color:var(--calas-muted);font-weight:750;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:132px}
.pwa-lang-dropdown{flex:0 0 auto}
.pwa-lang-toggle{height:38px;border:0;border-radius:999px;background:rgba(255,255,255,.88);box-shadow:0 8px 18px rgba(15,42,80,.08);padding:0 11px;font-size:12px;font-weight:850;color:var(--calas-ink);display:flex;align-items:center;gap:6px}
.pwa-lang-flag{font-size:15px;line-height:1}.pwa-lang-menu{border:0;border-radius:18px;box-shadow:0 20px 48px rgba(15,42,80,.16);padding:8px;min-width:166px}.pwa-lang-menu .dropdown-item{border-radius:12px;padding:9px 10px;font-size:13px;font-weight:750;display:flex;align-items:center;gap:9px;color:var(--calas-ink)}.pwa-lang-menu .dropdown-item.active{background:linear-gradient(135deg,var(--calas-blue),var(--calas-violet));color:#fff}

.pwa-page{position:relative;z-index:1;width:min(100%,540px);margin:0 auto;padding:12px 12px 6px;display:grid;gap:12px;overflow-x:hidden}
.pwa-frame,.pwa-card{background:var(--calas-card);border:1px solid var(--calas-border);border-radius:var(--calas-radius);box-shadow:var(--calas-shadow);backdrop-filter:blur(20px)}
.pwa-card{padding:16px}
.pwa-hero{position:relative;overflow:hidden;padding:17px;background:linear-gradient(135deg,rgba(14,165,233,.96),rgba(109,93,252,.88));color:#fff;border-radius:26px;box-shadow:0 22px 52px rgba(37,99,235,.20)}
.pwa-hero-owner{display:flex;align-items:center;justify-content:space-between;gap:12px}
.pwa-hero::after{content:"";position:absolute;width:170px;height:170px;border-radius:50%;right:-82px;top:-86px;background:rgba(255,255,255,.16)}
.pwa-hero-kicker,.pwa-page-kicker{font-size:10px;text-transform:uppercase;letter-spacing:.13em;font-weight:900;color:rgba(255,255,255,.76)}
.pwa-page-kicker{color:var(--calas-blue-2)}
.pwa-hero h1,.pwa-title h1{font-size:24px;line-height:1.05;font-weight:900;letter-spacing:-.045em;margin:6px 0 4px}
.pwa-hero p,.pwa-muted{font-size:13px;color:var(--calas-muted);font-weight:650;margin:0}.pwa-hero p{color:rgba(255,255,255,.80)}
.pwa-logout-chip{position:relative;z-index:2;height:38px;border-radius:999px;background:rgba(255,255,255,.88);color:var(--calas-ink);display:inline-flex;align-items:center;gap:6px;padding:0 12px;font-size:12px;font-weight:850;box-shadow:0 8px 20px rgba(15,42,80,.08);white-space:nowrap}
.pwa-title{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;flex-wrap:wrap}.pwa-title h1{font-size:24px;margin:4px 0 0;color:var(--calas-ink)}

.pwa-grid{display:grid;grid-template-columns:1fr;gap:12px}.pwa-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.pwa-mini{padding:15px}.pwa-mini span{display:block;color:var(--calas-muted);font-size:10.5px;font-weight:850;text-transform:uppercase;letter-spacing:.08em}.pwa-mini strong{display:block;font-size:24px;font-weight:900;letter-spacing:-.04em;margin-top:4px}.pwa-mini small{display:block;color:var(--calas-muted);font-size:11.5px;font-weight:650;margin-top:2px}.pwa-section-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px;flex-wrap:wrap}.pwa-section-head h2,.pwa-card h2{margin:0;font-size:16px;font-weight:900;letter-spacing:-.035em}.pwa-live-pill,.pwa-status-pill{display:inline-flex;align-items:center;gap:5px;border-radius:999px;background:rgba(36,214,168,.13);color:#08795f;padding:7px 10px;font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.07em}.pwa-status-pill.is-blue{background:rgba(14,165,233,.12);color:#076fae}
.pwa-primary-btn,.pwa-secondary-btn,.pwa-light-btn{min-height:46px;border:0;border-radius:17px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:900;letter-spacing:-.015em;font-size:14px}.pwa-primary-btn{width:100%;background:linear-gradient(135deg,var(--calas-blue),var(--calas-violet));color:#fff;box-shadow:0 15px 32px rgba(37,99,235,.20)}.pwa-secondary-btn{width:100%;background:linear-gradient(135deg,var(--calas-mint),var(--calas-blue));color:#fff;box-shadow:0 15px 32px rgba(36,214,168,.17)}.pwa-light-btn{background:rgba(255,255,255,.84);color:var(--calas-ink);box-shadow:0 10px 22px rgba(15,42,80,.08);padding:0 14px;white-space:nowrap}.pwa-danger-btn{background:#fff1f2;color:#be123c;border-radius:16px;padding:11px 14px;font-size:13px;font-weight:850;border:0}
.pwa-days{display:flex;gap:8px;overflow-x:auto;overflow-y:hidden;padding:1px 1px 10px;scrollbar-width:none;-webkit-overflow-scrolling:touch}.pwa-days::-webkit-scrollbar{display:none}.pwa-day{border:0;min-width:62px;border-radius:18px;background:rgba(255,255,255,.82);box-shadow:0 10px 22px rgba(15,42,80,.07);padding:10px 8px;text-align:center;color:var(--calas-ink)}.pwa-day span{display:block;font-size:10px;text-transform:uppercase;color:var(--calas-muted);font-weight:850;letter-spacing:.05em}.pwa-day strong{display:block;font-size:20px;font-weight:900;line-height:1.1}.pwa-day small{display:block;font-size:9px;font-weight:850;color:var(--calas-blue-2)}.pwa-day.is-active{background:linear-gradient(135deg,var(--calas-blue),var(--calas-violet));color:#fff}.pwa-day.is-active span,.pwa-day.is-active small{color:rgba(255,255,255,.78)}.pwa-day.is-locked{opacity:.44;filter:grayscale(.25)}
.pwa-slots{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.pwa-slot{border:0;border-radius:19px;background:#fff;box-shadow:0 10px 24px rgba(15,42,80,.075);padding:13px;color:var(--calas-ink);display:flex;flex-direction:column;gap:3px;min-height:82px;overflow:hidden}.pwa-slot strong{font-size:20px;font-weight:900;letter-spacing:-.035em}.pwa-slot span{font-size:11px;font-weight:750;color:var(--calas-muted)}.pwa-slot em{font-size:11px;font-style:normal;font-weight:850;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pwa-slot.is-open{background:linear-gradient(135deg,#ffffff,#f5fcff);border:1px solid rgba(14,165,233,.16)}.pwa-slot.is-open em{color:#07996f}.pwa-slot.is-waiting{background:linear-gradient(135deg,#fffaf0,#fff4cf);border:1px solid rgba(245,158,11,.18)}.pwa-slot.is-waiting em{color:#b45309}.pwa-slot-badge{display:inline-flex;width:max-content;max-width:100%;border-radius:999px;padding:4px 7px;background:rgba(36,214,168,.12);font-size:9px;font-weight:900;text-transform:uppercase}.pwa-slot.is-waiting .pwa-slot-badge{background:rgba(245,158,11,.13)}
.pwa-court-card{display:flex;align-items:center;justify-content:space-between;gap:10px}.pwa-court-icon{width:46px;height:46px;border-radius:16px;background:linear-gradient(135deg,rgba(14,165,233,.12),rgba(36,214,168,.11));display:grid;place-items:center;font-size:22px}.pwa-form-control{border:0;border-radius:16px;background:rgba(255,255,255,.86);box-shadow:inset 0 0 0 1px rgba(15,42,80,.075);padding:12px 13px;font-size:14px;font-weight:750}.pwa-info{border-radius:18px;background:rgba(14,165,233,.09);color:#27627e;padding:12px 13px;font-size:12.5px;font-weight:750}.pwa-list{display:grid;gap:10px}.pwa-list-item{display:flex;align-items:center;justify-content:space-between;gap:10px;background:rgba(255,255,255,.68);border-radius:18px;padding:12px 13px;overflow:hidden}.pwa-list-item strong{font-weight:900}.pwa-list-item span,.pwa-list-item strong{overflow:hidden;text-overflow:ellipsis}.pwa-avatar{width:56px;height:56px;border-radius:20px;background:linear-gradient(135deg,var(--calas-blue),var(--calas-violet));display:grid;place-items:center;color:#fff;font-size:24px;font-weight:900;box-shadow:0 14px 30px rgba(37,99,235,.18);flex:0 0 auto}
.pwa-bottom-nav{position:fixed;left:50%;bottom:calc(10px + env(safe-area-inset-bottom));transform:translateX(-50%);z-index:50;width:min(calc(100% - 24px),430px);height:64px;border-radius:24px;background:rgba(255,255,255,.90);border:1px solid rgba(255,255,255,.86);backdrop-filter:blur(24px);box-shadow:0 18px 50px rgba(15,42,80,.16);display:grid;grid-auto-flow:column;grid-auto-columns:1fr;align-items:center;padding:5px}.pwa-bottom-link{height:54px;border-radius:20px;color:#8b98aa;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-weight:850;overflow:hidden}.pwa-bottom-link small{font-size:10px;font-weight:850;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pwa-bottom-icon{font-size:18px;line-height:1}.pwa-bottom-link.is-active{background:linear-gradient(135deg,rgba(14,165,233,.12),rgba(109,93,252,.12));color:#075fa8}
@media (min-width:760px){.pwa-page{padding-top:18px}.pwa-grid{grid-template-columns:1fr 1fr}.pwa-slots{grid-template-columns:repeat(3,minmax(0,1fr))}.pwa-hero h1,.pwa-title h1{font-size:30px}}@media (max-width:380px){.pwa-grid-2{grid-template-columns:1fr}.pwa-slots{grid-template-columns:1fr 1fr}.pwa-page{padding-left:10px;padding-right:10px}.pwa-app-header{padding-left:10px;padding-right:10px}.pwa-brand-text strong{font-size:12.5px}.pwa-brand-text small{max-width:104px}.pwa-lang-toggle{padding:0 9px}.pwa-card{padding:14px}.pwa-slot{padding:12px;min-height:78px}.pwa-slot strong{font-size:18px}.pwa-bottom-nav{width:min(calc(100% - 16px),430px)}}

/* PACK 21: desktop adaptive layout. Mobile remains unchanged. */
@media (min-width: 900px) {
  body.pwa-body{
    padding-bottom:110px;
    background:
      radial-gradient(circle at 12% 0%, rgba(14,165,233,.18), transparent 30%),
      radial-gradient(circle at 88% 14%, rgba(109,93,252,.12), transparent 30%),
      radial-gradient(circle at 66% 88%, rgba(36,214,168,.12), transparent 34%),
      linear-gradient(145deg,#f7fbff 0%,#eef8ff 48%,#fbfbff 100%);
  }

  .pwa-app-header{
    padding:18px 32px 8px;
  }

  .pwa-app-bar{
    width:min(calc(100vw - 64px),1040px);
    border-radius:26px;
    padding:12px 14px;
  }

  .pwa-brand-logo{
    width:48px;
    height:48px;
    border-radius:16px;
  }

  .pwa-brand-text strong{
    font-size:16px;
  }

  .pwa-brand-text small{
    max-width:260px;
    font-size:12px;
  }

  .pwa-lang-toggle{
    height:44px;
    padding:0 16px;
    font-size:13px;
  }

  .pwa-page{
    width:min(calc(100vw - 64px),1040px);
    padding:24px 32px 24px;
    gap:18px;
  }

  .pwa-card{
    padding:24px;
    border-radius:30px;
  }

  .pwa-frame,
  .pwa-card{
    box-shadow:0 24px 70px rgba(15,42,80,.10);
  }

  .pwa-hero{
    padding:28px;
    border-radius:32px;
    min-height:150px;
  }

  .pwa-hero h1,
  .pwa-title h1{
    font-size:38px;
    letter-spacing:-.055em;
  }

  .pwa-hero p,
  .pwa-muted{
    font-size:15px;
  }

  .pwa-section-head h2,
  .pwa-card h2{
    font-size:20px;
  }

  .pwa-grid-2{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:18px;
  }

  .pwa-mini{
    min-height:150px;
    display:flex;
    flex-direction:column;
    justify-content:center;
  }

  .pwa-mini strong{
    font-size:34px;
  }

  .pwa-days{
    padding-bottom:12px;
  }

  .pwa-day{
    min-width:82px;
    padding:14px 10px;
    border-radius:22px;
  }

  .pwa-day strong{
    font-size:26px;
  }

  .pwa-slots{
    grid-template-columns:repeat(5,minmax(0,1fr));
    gap:14px;
  }

  .pwa-slot{
    min-height:118px;
    border-radius:24px;
    padding:18px;
  }

  .pwa-slot strong{
    font-size:28px;
  }

  .pwa-list{
    gap:14px;
  }

  .pwa-list-item{
    padding:18px 20px;
    border-radius:22px;
  }

  .pwa-primary-btn,
  .pwa-secondary-btn,
  .pwa-light-btn{
    min-height:52px;
    border-radius:20px;
    font-size:15px;
  }

  .pwa-bottom-nav{
    width:min(calc(100vw - 64px),760px);
    height:72px;
    bottom:22px;
    border-radius:28px;
    padding:7px;
  }

  .pwa-bottom-link{
    height:58px;
    border-radius:22px;
    flex-direction:row;
    gap:8px;
  }

  .pwa-bottom-icon{
    font-size:20px;
  }

  .pwa-bottom-link small{
    font-size:12px;
  }
}

@media (min-width: 1280px) {
  .pwa-app-bar{
    width:min(calc(100vw - 96px),1120px);
  }

  .pwa-page{
    width:min(calc(100vw - 96px),1120px);
    padding-left:36px;
    padding-right:36px;
  }

  .pwa-page > .pwa-title,
  .pwa-page > .pwa-hero,
  .pwa-page > .alert{
    width:100%;
  }

  .pwa-slots{
    grid-template-columns:repeat(5,minmax(0,1fr));
  }
}

/* PACK 28: announcements + issue report polish */
.pwa-announcement-item{
  border-radius:18px;
  background:rgba(255,255,255,.68);
  border:1px solid rgba(15,42,80,.06);
  padding:13px 14px;
}
.pwa-announcement-item strong{
  display:block;
  font-size:14px;
  font-weight:900;
  color:var(--calas-ink);
  margin-bottom:5px;
}
.pwa-announcement-item p{
  margin:0;
  color:var(--calas-muted);
  font-size:12.5px;
  font-weight:650;
  line-height:1.45;
}
@media(max-width:380px){
  .pwa-bottom-link small{font-size:9px}
  .pwa-bottom-icon{font-size:17px}
}
/* PACK 38B: QR scanner screen */
.pwa-scan-page .pwa-card{
  overflow:hidden;
}

.pwa-scan-card{
  padding:14px;
}

.pwa-scan-visual{
  position:relative;
  overflow:hidden;
  border-radius:28px;
  background:#071527;
  min-height:280px;
  box-shadow:0 18px 50px rgba(6,20,40,.18);
}

.pwa-qr-reader{
  width:100%;
  min-height:280px;
  border:0!important;
  overflow:hidden;
}

.pwa-qr-reader video{
  width:100%!important;
  min-height:280px!important;
  object-fit:cover!important;
  border-radius:28px;
}

.pwa-qr-reader img,
.pwa-qr-reader select,
.pwa-qr-reader button,
.pwa-qr-reader span{
  font-family:inherit!important;
}

.pwa-scan-frame{
  pointer-events:none;
  position:absolute;
  inset:0;
  display:block;
}

.pwa-scan-frame span{
  position:absolute;
  width:52px;
  height:52px;
  border-color:rgba(255,255,255,.92);
  filter:drop-shadow(0 8px 18px rgba(0,0,0,.28));
}

.pwa-scan-frame span:nth-child(1){top:25%;left:18%;border-top:4px solid;border-left:4px solid;border-radius:18px 0 0 0;}
.pwa-scan-frame span:nth-child(2){top:25%;right:18%;border-top:4px solid;border-right:4px solid;border-radius:0 18px 0 0;}
.pwa-scan-frame span:nth-child(3){bottom:25%;left:18%;border-bottom:4px solid;border-left:4px solid;border-radius:0 0 0 18px;}
.pwa-scan-frame span:nth-child(4){bottom:25%;right:18%;border-bottom:4px solid;border-right:4px solid;border-radius:0 0 18px 0;}

.pwa-scan-status{
  margin:14px 4px 0;
  padding:12px 14px;
  border-radius:18px;
  background:rgba(7,150,216,.09);
  color:#0f4668;
  font-size:13px;
  font-weight:800;
  line-height:1.35;
}

.pwa-scan-status.is-error{
  background:rgba(245,158,11,.14);
  color:#8a4b06;
}

.pwa-scan-status.is-success{
  background:rgba(16,185,129,.13);
  color:#08734e;
}

.pwa-scan-actions{
  display:flex;
  justify-content:center;
  margin-top:14px;
}

.pwa-scan-actions .pwa-secondary-btn{
  width:auto;
  min-width:190px;
}

.pwa-scan-help{
  margin:14px 4px 0;
  padding:14px;
  border-radius:20px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(10,46,80,.08);
}

.pwa-scan-help strong{
  display:block;
  color:var(--calas-ink);
  font-size:13px;
  font-weight:900;
  margin-bottom:4px;
}

.pwa-scan-help p{
  margin:0;
  color:var(--calas-muted);
  font-size:12px;
  font-weight:650;
  line-height:1.4;
}

.pwa-manual-qr-card h2{
  font-size:17px;
  font-weight:950;
  margin-bottom:4px;
}

.pwa-input{
  border-radius:18px!important;
  min-height:48px;
  border:1px solid rgba(10,46,80,.11);
  font-weight:750;
}

.pwa-inline-submit{
  border-radius:18px!important;
  font-weight:900;
  background:linear-gradient(135deg,#0796d8,#4f46e5);
  border:0;
}

@media(min-width:768px){
  .pwa-scan-visual,
  .pwa-qr-reader,
  .pwa-qr-reader video{
    min-height:420px!important;
  }
}

/* PACK 39 - owner dashboard widgets */
.pwa-owner-dashboard-hero{position:relative;overflow:hidden;border-radius:28px;padding:22px;background:linear-gradient(135deg,rgba(7,150,216,.98),rgba(99,102,241,.92));color:#fff;box-shadow:0 22px 52px rgba(37,99,235,.18);display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.pwa-owner-dashboard-hero:after{content:"";position:absolute;right:-34px;top:-44px;width:150px;height:150px;border-radius:50%;background:rgba(255,255,255,.16)}.pwa-owner-dashboard-hero>*{position:relative;z-index:1}.pwa-owner-dashboard-hero h1{margin:0;font-size:clamp(2rem,8vw,3rem);letter-spacing:-.06em;font-weight:950}.pwa-owner-dashboard-hero p{margin:.35rem 0 0;color:rgba(255,255,255,.82);font-weight:750}.pwa-next-card{display:grid;gap:14px}.pwa-next-reservation{display:grid;grid-template-columns:74px 1fr;gap:14px;align-items:center}.pwa-next-date{height:74px;border-radius:22px;background:linear-gradient(135deg,#eaf7ff,#eef2ff);display:grid;place-items:center;text-align:center}.pwa-next-date strong{font-size:2rem;line-height:1;font-weight:950;color:#0f172a}.pwa-next-date span{font-size:.76rem;color:#64748b;font-weight:900}.pwa-next-main strong{display:block;font-size:1.22rem;font-weight:950;color:#0f172a}.pwa-next-main span{display:block;color:#334155;font-weight:850}.pwa-next-main em{font-style:normal;color:#0796d8;font-weight:950;font-size:.78rem;text-transform:uppercase;letter-spacing:.06em}.pwa-next-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.pwa-stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.pwa-stat-card{min-height:104px;display:grid;align-content:center;text-align:center;padding:14px!important}.pwa-stat-card small{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:#64748b;font-weight:950}.pwa-stat-card strong{font-size:2rem;line-height:1;font-weight:950;color:#0f172a;letter-spacing:-.06em}.pwa-stat-card span{font-size:.75rem;color:#64748b;font-weight:850}.pwa-tourist-code-card strong{letter-spacing:.06em}.pwa-small-link{font-size:.82rem;font-weight:900;color:#0796d8;text-decoration:none}.pwa-list-item .pwa-status-pill{white-space:nowrap}
@media(max-width:420px){.pwa-owner-dashboard-hero{border-radius:24px;padding:18px}.pwa-owner-dashboard-hero h1{font-size:2rem}.pwa-next-actions{grid-template-columns:1fr}.pwa-stats-grid{grid-template-columns:1fr 1fr}.pwa-stat-card:last-child{grid-column:1 / -1}.pwa-next-reservation{grid-template-columns:62px 1fr}.pwa-next-date{height:62px;border-radius:18px}.pwa-next-date strong{font-size:1.65rem}}

/* PACK 40: Owner dashboard premium UI polish + mobile refinement */
.pwa-page{width:min(calc(100% - 24px),980px);margin:0 auto;padding:12px 0 18px;display:grid;gap:14px}.pwa-owner-dashboard-hero{position:relative;overflow:hidden;border-radius:30px;padding:22px;background:linear-gradient(135deg,rgba(255,255,255,.88),rgba(241,250,255,.76)),radial-gradient(circle at 92% 12%,rgba(109,93,252,.17),transparent 32%),radial-gradient(circle at 12% 82%,rgba(34,211,238,.18),transparent 34%);border:1px solid rgba(255,255,255,.78);box-shadow:0 22px 62px rgba(15,42,80,.10);display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.pwa-owner-dashboard-hero::after{content:"";position:absolute;right:-46px;bottom:-54px;width:180px;height:180px;border-radius:50%;background:linear-gradient(135deg,rgba(14,165,233,.16),rgba(109,93,252,.12));pointer-events:none}.pwa-owner-dashboard-hero>*{position:relative;z-index:1}.pwa-owner-dashboard-hero h1{font-size:clamp(1.55rem,5vw,2.25rem);font-weight:950;letter-spacing:-.055em;margin:2px 0 6px;color:#101828}.pwa-owner-dashboard-hero p{margin:0;color:#667085;font-weight:650;line-height:1.4}.pwa-hero-kicker{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:#0f8fca;font-weight:900}.pwa-logout-chip{display:inline-flex;align-items:center;gap:7px;border-radius:999px;background:rgba(255,255,255,.70);border:1px solid rgba(16,24,40,.07);color:#176b91;font-weight:850;font-size:.84rem;padding:9px 12px;box-shadow:0 10px 26px rgba(15,42,80,.06);white-space:nowrap}.pwa-card{border-radius:28px;padding:18px;border:1px solid rgba(255,255,255,.78);background:linear-gradient(180deg,rgba(255,255,255,.88),rgba(255,255,255,.70));box-shadow:0 16px 48px rgba(15,42,80,.08);overflow:hidden}.pwa-section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.pwa-section-head h2{font-size:1.12rem;font-weight:950;letter-spacing:-.035em;margin:0;color:#101828}.pwa-live-pill{display:inline-flex;align-items:center;gap:6px;border-radius:999px;background:#e8fff7;color:#079669;padding:7px 10px;font-weight:850;font-size:.75rem}.pwa-next-reservation{display:grid;grid-template-columns:74px minmax(0,1fr);gap:13px;align-items:center;padding:12px;border-radius:22px;background:rgba(248,252,255,.76);border:1px solid rgba(16,24,40,.05)}.pwa-next-date{width:68px;height:68px;border-radius:20px;background:linear-gradient(135deg,#0ea5e9,#6d5dfc);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 16px 34px rgba(14,165,233,.22)}.pwa-next-date strong{font-size:1.55rem;font-weight:950;line-height:1}.pwa-next-date span{font-size:.73rem;font-weight:850;opacity:.9}.pwa-next-main strong{display:block;font-size:1.08rem;font-weight:950;color:#101828}.pwa-next-main span{display:block;color:#667085;font-weight:780;margin-top:2px}.pwa-next-main em{display:inline-flex;margin-top:8px;border-radius:999px;background:#eef2ff;color:#4f46e5;padding:6px 9px;font-style:normal;font-weight:850;font-size:.74rem}.pwa-next-actions{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}.pwa-primary-btn,.pwa-secondary-btn{min-height:44px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:16px;padding:11px 14px;font-weight:900;text-decoration:none;border:0}.pwa-primary-btn{background:linear-gradient(135deg,#0ea5e9,#6d5dfc);color:#fff;box-shadow:0 16px 34px rgba(14,165,233,.22)}.pwa-secondary-btn{background:rgba(255,255,255,.76);color:#176b91;border:1px solid rgba(14,165,233,.12)}.pwa-stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.pwa-stat-card{min-height:116px;display:flex;flex-direction:column;justify-content:center;gap:3px}.pwa-stat-card small{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:#667085;font-weight:850}.pwa-stat-card strong{font-size:2rem;font-weight:950;letter-spacing:-.06em;color:#0f8fca;line-height:1}.pwa-stat-card span{font-size:.82rem;color:#75839a;font-weight:760}.pwa-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.pwa-mini{min-height:136px}.pwa-mini span{font-weight:850;color:#667085}.pwa-tourist-code-card strong{display:block;font-size:2rem;letter-spacing:.10em;margin-top:8px;color:#101828}.pwa-tourist-code-card small{display:block;color:#75839a;font-weight:650;line-height:1.35;margin-top:8px}.pwa-list{display:grid;gap:10px}.pwa-list-item{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;padding:11px 12px;border-radius:18px;background:rgba(248,252,255,.76);border:1px solid rgba(16,24,40,.05)}.pwa-list-item strong{font-weight:920;color:#101828}.pwa-muted{color:#75839a;font-weight:650}.pwa-status-pill{display:inline-flex;align-items:center;border-radius:999px;padding:6px 9px;font-size:.74rem;font-weight:880;white-space:nowrap}.pwa-status-pill.is-blue{background:#eef2ff;color:#4f46e5}.pwa-announcement-item{padding:12px;border-radius:18px;background:rgba(248,252,255,.76);border:1px solid rgba(16,24,40,.05)}.pwa-announcement-item strong{display:block;color:#101828;font-weight:920;margin-bottom:5px}.pwa-announcement-item p{margin:0;color:#667085;line-height:1.45;font-weight:650}.pwa-small-link{font-weight:850;font-size:.86rem;color:#0f8fca}.pwa-bottom-nav{box-shadow:0 -18px 45px rgba(15,42,80,.08)}
@media(min-width:860px){.pwa-page{padding-top:18px}.pwa-card{padding:22px}.pwa-owner-dashboard-hero{padding:26px}.pwa-stats-grid{gap:14px}.pwa-grid-2{gap:14px}}
@media(max-width:640px){.pwa-page{width:min(calc(100% - 18px),540px);gap:11px;padding-top:8px}.pwa-owner-dashboard-hero{border-radius:24px;padding:17px;display:grid}.pwa-owner-dashboard-hero h1{font-size:1.45rem}.pwa-owner-dashboard-hero p{font-size:.9rem}.pwa-logout-chip{width:max-content;padding:8px 10px;font-size:.78rem}.pwa-card{border-radius:22px;padding:14px}.pwa-section-head h2{font-size:1.03rem}.pwa-live-pill{font-size:.70rem;padding:6px 8px}.pwa-stats-grid{grid-template-columns:repeat(3,1fr);gap:8px}.pwa-stat-card{min-height:92px;border-radius:20px;padding:12px}.pwa-stat-card small{font-size:.62rem}.pwa-stat-card strong{font-size:1.35rem}.pwa-stat-card span{font-size:.68rem}.pwa-grid-2{grid-template-columns:1fr;gap:10px}.pwa-mini{min-height:110px}.pwa-tourist-code-card strong{font-size:1.55rem}.pwa-next-reservation{grid-template-columns:60px minmax(0,1fr);gap:10px;border-radius:18px}.pwa-next-date{width:56px;height:56px;border-radius:17px}.pwa-next-date strong{font-size:1.25rem}.pwa-next-date span{font-size:.64rem}.pwa-next-main strong{font-size:.98rem}.pwa-next-main span{font-size:.86rem}.pwa-next-actions{display:grid;grid-template-columns:1fr;gap:8px}.pwa-primary-btn,.pwa-secondary-btn{min-height:42px;border-radius:15px;font-size:.9rem}.pwa-list-item{grid-template-columns:1fr;gap:8px;border-radius:16px;padding:10px}.pwa-status-pill{width:max-content}.pwa-announcement-item{border-radius:16px;padding:10px}}
@media(max-width:380px){.pwa-page{width:min(calc(100% - 14px),540px)}.pwa-stats-grid{grid-template-columns:1fr 1fr}.pwa-stat-card{min-height:82px}.pwa-stat-card strong{font-size:1.25rem}}


/* PACK 43: final public polish */
.pwa-app-bar{
  width:min(100%,760px);
  padding:9px 12px;
}
.pwa-brand-logo-only{
  gap:0;
}
.pwa-brand-logo{
  width:54px;
  height:54px;
  border-radius:18px;
  padding:5px;
}
@media (max-width:520px){
  .pwa-brand-logo{width:48px;height:48px;border-radius:16px}
}

.pwa-bottom-nav{
  width:min(calc(100% - 24px),520px);
  height:62px;
  border-radius:24px;
  padding:5px;
}
.pwa-bottom-link{
  height:52px;
  gap:3px;
}
.pwa-bottom-icon{
  font-size:17px;
}
.pwa-bottom-link small{
  font-size:9.5px;
}

.pwa-slot-legend{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:7px;
}
.pwa-legend-sep{opacity:.55}
.pwa-legend-square{
  width:12px;
  height:12px;
  border-radius:4px;
  display:inline-flex;
  box-shadow:0 5px 13px rgba(15,42,80,.10);
}
.pwa-legend-square.is-green{background:#22c55e}
.pwa-legend-square.is-yellow{background:#facc15}

.pwa-court-card .pwa-court-icon{
  color:#8796aa;
  background:rgba(148,163,184,.12);
}
.pwa-court-card.is-available .pwa-court-icon{
  color:#ffffff;
  background:linear-gradient(135deg,#22c55e,#14b8a6);
  box-shadow:0 14px 26px rgba(34,197,94,.20);
}
.pwa-court-card.is-unavailable .pwa-court-icon{
  color:#ef4444;
  background:rgba(239,68,68,.10);
}

.pwa-rules-card{
  overflow:hidden;
  padding:20px;
}
.pwa-rules-logo{
  display:flex;
  justify-content:center;
  margin:2px 0 18px;
}
.pwa-rules-logo img{
  width:min(230px,70%);
  height:auto;
  display:block;
}
.pwa-rules-content{
  background:rgba(255,255,255,.62);
  border:1px solid rgba(15,42,80,.06);
  border-radius:20px;
  padding:18px;
  color:#40516a;
  line-height:1.65;
  font-size:14px;
  font-weight:650;
}

.pwa-reservation-card{
  display:grid;
  gap:16px;
}
.pwa-reservation-head{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:13px;
}
.pwa-reservation-head h2{
  margin:0;
  font-size:20px;
  font-weight:950;
  letter-spacing:-.035em;
}
.pwa-action-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
}
@media (min-width:620px){
  .pwa-action-grid{
    grid-template-columns:1fr 1fr;
  }
  .pwa-action-grid .pwa-danger-btn{
    grid-column:1 / -1;
  }
}

.pwa-status-pill.is-ok{
  background:rgba(34,197,94,.13);
  color:#15803d;
}
.pwa-status-pill.is-no{
  background:rgba(239,68,68,.12);
  color:#b91c1c;
}

.pwa-bookings-card{padding:14px}
.pwa-bookings-list{
  display:grid;
  gap:12px;
}
.pwa-booking-item{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:13px;
  padding:13px;
  border-radius:22px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(15,42,80,.055);
  box-shadow:0 9px 22px rgba(15,42,80,.045);
}
.pwa-booking-date{
  width:56px;
  min-height:56px;
  border-radius:18px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,var(--calas-blue),var(--calas-violet));
  color:#fff;
  box-shadow:0 14px 28px rgba(37,99,235,.16);
}
.pwa-booking-date strong{
  font-size:21px;
  line-height:1;
  font-weight:950;
}
.pwa-booking-date span{
  margin-top:3px;
  font-size:9px;
  font-weight:850;
  opacity:.85;
}
.pwa-booking-main{
  min-width:0;
  display:grid;
  gap:6px;
}
.pwa-booking-title-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
}
.pwa-booking-title-row strong{
  font-size:15px;
  font-weight:950;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
}
.pwa-booking-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:2px;
}
.pwa-mini-link{
  display:inline-flex;
  align-items:center;
  gap:5px;
  min-height:31px;
  padding:0 10px;
  border-radius:999px;
  background:rgba(14,165,233,.08);
  color:#0875b5;
  font-size:11px;
  font-weight:900;
  text-decoration:none;
  white-space:nowrap;
}
.pwa-mini-link.is-danger{
  background:rgba(239,68,68,.10);
  color:#b91c1c;
}

.pwa-empty-state{
  min-height:180px;
  display:grid;
  place-items:center;
  text-align:center;
  gap:10px;
}
.pwa-empty-state > i{
  width:58px;
  height:58px;
  border-radius:20px;
  display:grid;
  place-items:center;
  background:rgba(14,165,233,.10);
  color:#0875b5;
  font-size:26px;
}

.pwa-form-label{
  font-size:12px;
  font-weight:900;
  color:var(--calas-muted);
}
.pwa-profile-form .pwa-primary-btn{
  margin-top:4px;
}

.pwa-scan-status-compact{
  min-height:0;
  padding:0;
  margin-top:10px;
  font-size:12px;
  color:var(--calas-muted);
}
.pwa-scan-status-compact:empty{
  display:none;
}

@media (max-width:420px){
  .pwa-reservation-head{
    grid-template-columns:auto 1fr;
  }
  .pwa-reservation-head .pwa-status-pill{
    grid-column:1 / -1;
    width:max-content;
  }
  .pwa-booking-item{
    grid-template-columns:1fr;
  }
  .pwa-booking-date{
    width:100%;
    min-height:46px;
    flex-direction:row;
    gap:7px;
  }
  .pwa-booking-date span{margin-top:0}
}
