:root{--green:#2e7d32;--green-dark:#1b5e20;--green-soft:#e8f5e9;--clay:#c5512f;--ink:#1f2937;--muted:#6b7280;--line:#e5e7eb;--bg:#f4f6f4;--white:#ffffff;--radius:14px}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased}@media (min-width:760px){body{background-image:url(/tennis-bg.png);background-repeat:no-repeat;background-position:50%;background-size:auto 85vh;background-attachment:fixed}}.app{max-width:960px;padding:16px 16px 48px}.app,.narrow{margin:0 auto}.narrow{max-width:460px}.header{justify-content:space-between;gap:12px;padding:8px 0 16px}.brand,.header{display:flex;align-items:center}.brand{gap:10px;font-weight:800;font-size:1.15rem;color:var(--green-dark)}.brand .ball{width:26px;height:26px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#d7f06a,#b5d334);border:2px solid #9bbd2a;flex:none}.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:0 1px 2px rgba(0,0,0,.04)}h1{font-size:1.4rem;margin:0 0 4px}h2{font-size:1.1rem;margin:0 0 12px}p.sub{color:var(--muted);margin:0 0 18px;font-size:.95rem}label{display:block;font-size:.85rem;font-weight:600;margin:12px 0 6px;color:var(--ink)}input{width:100%;padding:12px 14px;font-size:1rem;border:1px solid var(--line);border-radius:10px;background:#fff;outline:none}input:focus{border-color:var(--green);box-shadow:0 0 0 3px var(--green-soft)}button{font-family:inherit;cursor:pointer;border:none;border-radius:10px;font-weight:700;font-size:1rem;transition:transform .05s ease,background .15s ease,opacity .15s ease}button:active{transform:translateY(1px)}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{width:100%;padding:13px;background:var(--green);color:#fff;margin-top:16px}.btn-primary:hover:not(:disabled){background:var(--green-dark)}.btn-ghost{background:transparent;color:var(--green-dark);padding:8px 10px}.btn-danger{background:#fff;color:var(--clay);border:1px solid var(--clay);padding:10px 16px}.btn-danger:hover:not(:disabled){background:#fdece8}.tabs{display:flex;gap:6px;background:var(--green-soft);padding:4px;border-radius:12px;margin-bottom:16px}.tabs button{flex:1 1;padding:10px;background:transparent;color:var(--green-dark)}.tabs button.active{background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.08)}.datebar{display:flex;align-items:center;justify-content:space-between;gap:8px;margin:16px 0}.datebar .day{text-align:center;font-weight:700;text-transform:capitalize}.datebar .nav{width:44px;height:44px;font-size:1.3rem;background:var(--white);border:1px solid var(--line);border-radius:12px;color:var(--green-dark);flex:none}.datebar .nav:disabled{color:#cbd5e1}.slots{display:grid;grid-gap:8px;gap:8px}.slot{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-radius:12px;border:1.5px solid var(--line);background:#fff;text-align:left;width:100%}.slot .time{font-weight:700}.slot .who{font-size:.85rem;color:var(--muted)}.slot.free:hover:not(:disabled),.slot.selected{border-color:var(--green);background:var(--green-soft)}.slot.selected{box-shadow:0 0 0 3px rgba(46,125,50,.15)}.slot.busy{background:#fbfaf8;border-style:dashed;cursor:default}.slot.mine{border-color:var(--clay);background:#fdf0eb}.tag{font-size:.72rem;font-weight:700;padding:3px 8px;border-radius:999px}.tag.mine{background:var(--clay);color:#fff}.tag.busy{background:#eee;color:var(--muted)}.actionbar{position:-webkit-sticky;position:sticky;bottom:0;margin-top:16px;padding-top:8px}.banner{padding:12px 14px;border-radius:10px;font-size:.9rem;margin-top:14px}.banner.error{background:#fdecea;color:#b71c1c}.banner.info{background:var(--green-soft);color:var(--green-dark)}.rules{margin-top:18px;font-size:.82rem;color:var(--muted);line-height:1.5}.rules b{color:var(--ink)}.userline{display:flex;align-items:center;gap:8px;font-size:.85rem}.center,.userline{color:var(--muted)}.center{text-align:center;padding:40px 0}.linkbtn{background:none;color:var(--green-dark);text-decoration:underline;padding:0;font-weight:600}.brand-logo{width:34px;height:34px;border-radius:8px;object-fit:cover;flex:none}.brand-hero{text-align:center;margin:6px 0 14px}.brand-hero img{width:132px;height:132px;border-radius:24px;object-fit:cover;box-shadow:0 6px 18px rgba(27,94,32,.18)}p.subhero{color:var(--muted);text-align:center;margin:0 0 18px;font-size:.95rem}.layout{display:grid;grid-gap:16px;gap:16px;align-items:start;grid-template-columns:1fr;grid-template-areas:"cal" "slots" "form"}.area-cal{grid-area:cal}.area-form{grid-area:form}.area-slots{grid-area:slots}@media (min-width:760px){.layout{grid-template-columns:340px 1fr;grid-template-areas:"cal slots" "form slots"}}.booking-head{margin-bottom:4px}.booking-head h2{text-transform:capitalize;margin-bottom:8px}.cal{padding:14px}@media (min-width:760px){.cal{position:-webkit-sticky;position:sticky;top:12px}}.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.cal-title{font-weight:800;color:var(--green-dark);text-transform:capitalize}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:4px;gap:4px}.cal-dow .dow{text-align:center;font-size:.72rem;font-weight:700;color:var(--muted);text-transform:uppercase;padding:4px 0}.cal-cell{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;border-radius:10px;border:1.5px solid transparent;background:#fff;color:var(--ink);font-weight:600;font-size:.92rem}.cal-cell:hover:not(:disabled):not(.sel){border-color:var(--green);background:var(--green-soft)}.cal-cell.muted{color:#cbd5e1}.cal-cell.disabled{color:#d1d5db;cursor:not-allowed;background:#fafafa}.cal-cell.today{border-color:var(--green);color:var(--green-dark)}.cal-cell.sel{background:var(--green);color:#fff;border-color:var(--green)}.cal-legend{display:flex;gap:16px;justify-content:center;margin-top:12px;font-size:.78rem;color:var(--muted)}.cal-legend .dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:5px;vertical-align:middle}.cal-legend .dot.today{border:2px solid var(--green)}.cal-legend .dot.sel{background:var(--green)}.players{margin-top:16px}.players-head{display:flex;flex-direction:column;gap:2px;margin-bottom:8px}.player{border:1px solid var(--line);border-radius:12px;padding:10px;margin-bottom:8px;background:#fcfdfc}.player .p-name{margin-bottom:6px}.player .p-cfrow{display:flex;gap:6px;align-items:center}.player .p-cf{text-transform:uppercase;letter-spacing:.5px;font-family:ui-monospace,monospace}.player .p-cf.invalid{border-color:#e57373;box-shadow:0 0 0 3px #fdecea}.player .p-remove{flex:none;width:42px;height:42px;background:#fff;border:1px solid var(--line);border-radius:10px;color:var(--muted)}.player .p-meta{min-height:18px;margin-top:6px;font-size:.8rem}.player .p-meta .err{color:#b71c1c}.player .p-meta .ok{color:var(--green-dark);font-weight:600}.add-player{display:inline-block;margin:2px 0 4px}.muted{color:var(--muted)}.receipt{border:1px solid var(--line);border-radius:12px;padding:12px 14px;margin-top:12px;background:#fcfdfc}.receipt-row{display:flex;justify-content:space-between;gap:10px;padding:4px 0;font-size:.92rem}.receipt-players{border-top:1px dashed var(--line);border-bottom:1px dashed var(--line);margin:6px 0;padding:4px 0}.receipt-total{display:flex;justify-content:space-between;padding-top:8px;font-size:1.05rem}.banner.success,.receipt-total b{color:var(--green-dark)}.banner.success{background:var(--green-soft);font-weight:600}.banner.pay{font-size:.95rem}.consent{display:flex;gap:10px;align-items:flex-start;margin:16px 0 4px;font-size:.85rem;font-weight:400;color:var(--ink)}.consent input{width:auto;margin-top:2px;flex:none}.consent a{font-weight:600}.consent a,.legal h2{color:var(--green-dark)}.legal h2{font-size:1rem;margin:18px 0 6px}.legal li,.legal p{font-size:.9rem;line-height:1.55}.legal ul{padding-left:18px;margin:6px 0}.range-tabs{display:inline-flex;gap:4px;background:var(--green-soft);padding:4px;border-radius:12px;margin-bottom:16px}.range-tabs button{padding:8px 14px;background:transparent;color:var(--green-dark);font-size:.9rem}.range-tabs button.active{background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.08)}.stats{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:10px;gap:10px;margin-bottom:16px}@media (min-width:760px){.stats{grid-template-columns:repeat(5,1fr)}}.stat{background:var(--white);border:1px solid var(--line);border-radius:12px;padding:12px 14px;display:flex;flex-direction:column;gap:2px}.stat-label{font-size:.75rem;color:var(--muted)}.stat-value{font-size:1.25rem;font-weight:800;color:var(--ink)}.stat-sub{font-size:.72rem;color:var(--muted)}.stat.highlight{background:var(--green-soft);border-color:var(--green)}.stat.highlight .stat-value{color:var(--green-dark)}.stat.highlight.due{background:#fdf0eb;border-color:var(--clay)}.stat.highlight.due .stat-value{color:var(--clay)}.console-grid{display:grid;grid-template-columns:1fr;grid-gap:16px;gap:16px;align-items:start}@media (min-width:760px){.console-grid{grid-template-columns:1fr 1fr}}.payout-form{flex-direction:column;margin:8px 0 16px}.payout-fields,.payout-form{display:flex;gap:8px}.payout-fields input{flex:1 1}.list{display:flex;flex-direction:column}.list-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 0;border-top:1px solid var(--line)}.list-row:first-child{border-top:none}.small{font-size:.8rem}@media (max-width:520px){.email-hide{display:none}}.side-rail{display:none}@media (min-width:1280px){.side-rail{display:flex;flex-direction:column;gap:12px;position:fixed;left:8px;top:8px;height:calc(100vh - 16px);width:min(400px,calc((100vw - 960px) / 2 - 16px));box-sizing:border-box;z-index:0;pointer-events:none}.side-rail img{width:100%;flex:1 1;min-height:0;object-fit:cover;object-position:center top;border-radius:16px;box-shadow:0 6px 18px rgba(27,94,32,.2)}}.sponsor-rail{display:none}@media (min-width:1280px){.sponsor-rail{position:fixed;right:8px;top:8px;height:calc(100vh - 16px);width:min(400px,calc((100vw - 960px) / 2 - 16px));box-sizing:border-box;z-index:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:26px 16px;background:linear-gradient(160deg,#1b5e20,#0e3d15);border-radius:16px;box-shadow:0 6px 18px rgba(27,94,32,.2);overflow:auto}.sponsor-rail .sponsor-logo img{width:210px;max-width:92%;height:auto}}.sponsor-tag{color:#e9c46a;font-weight:800;letter-spacing:2px;text-transform:uppercase;font-size:.8rem;text-align:center}.sponsor-logo{display:block;line-height:0}.sponsor-venues{gap:16px;width:100%}.sponsor-venues,.venue{display:flex;flex-direction:column}.venue{gap:3px;text-align:center;color:#e8f5e9;font-size:.8rem;line-height:1.45}.venue b{color:#fff;font-size:.9rem}.venue a{color:#a8e6a0;font-weight:700;text-decoration:none}.venue a:hover{text-decoration:underline}.sponsor-footer{background:linear-gradient(160deg,#1b5e20,#0e3d15);padding:28px 16px 34px;margin-top:28px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px}.sponsor-footer .sponsor-logo img{width:200px;max-width:65%;height:auto;margin:0 auto}.sponsor-footer .sponsor-venues{flex-direction:row;flex-wrap:wrap;justify-content:center;gap:22px 40px}.sponsor-footer .venue{min-width:220px}@media (min-width:1280px){.sponsor-footer{display:none}}