:root{--sand: #f2ede4;--sand-2: #ebe5d8;--green-dark: #1a3a2a;--green-mid: #22503a;--lime: #c8f25a;--white: #fff;--gray-100: #f5f2ec;--gray-300: #d4cdc0;--gray-muted: #7a7a7a;--red: #b00020;--radius: 18px;--radius-sm: 12px;--bottom-nav-h: 80px}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{margin:0;padding:0;min-height:100vh}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--sand);color:var(--green-dark);overscroll-behavior-y:none}button{font-family:inherit}h1,h2{font-weight:800;letter-spacing:-.03em;margin:0}h1{font-size:32px}h2{font-size:22px}.muted{color:var(--gray-muted);font-size:14px}.muted.small{font-size:12px}.error{color:var(--red);font-size:14px;margin:8px 0 0}.help{color:var(--gray-muted);font-size:13px;line-height:1.5;margin-top:16px}.splash{display:flex;align-items:center;justify-content:center;text-align:center}.splash h1{font-size:56px;opacity:.4}.auth-screen{max-width:430px;margin:0 auto;min-height:100vh;padding:24px;padding-top:calc(24px + env(safe-area-inset-top));padding-bottom:calc(24px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:32px}.auth-header{margin-top:48px}.auth-header h1{font-size:40px}.auth-header .tagline{font-size:16px;color:var(--green-mid);margin:4px 0 0}.auth-form{display:flex;flex-direction:column;gap:12px}.auth-form label{font-size:12px;font-weight:700;color:var(--green-mid);text-transform:uppercase;letter-spacing:.05em}.auth-form input{background:var(--white);border:none;border-radius:var(--radius-sm);padding:16px;font-size:16px;color:var(--green-dark);-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%}.auth-form input:focus{outline:2px solid var(--green-dark)}.auth-form .otp-input{text-align:center;font-size:28px;letter-spacing:12px;font-weight:700}.auth-form button{background:var(--green-dark);color:var(--sand);border:none;border-radius:100px;padding:16px;font-size:15px;font-weight:700;cursor:pointer;margin-top:8px}.auth-form button:disabled{opacity:.5}.auth-form button.ghost{background:transparent;color:var(--green-dark);margin-top:4px}.shell{max-width:430px;margin:0 auto;position:relative;min-height:100vh}.page{max-width:430px;margin:0 auto;padding:24px 20px;padding-top:calc(24px + env(safe-area-inset-top));padding-bottom:calc(var(--bottom-nav-h) + 24px + env(safe-area-inset-bottom))}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.page-header button.ghost.small{background:transparent;border:none;color:var(--green-mid);font-size:13px;font-weight:600;cursor:pointer;padding:8px}.header-actions{display:flex;gap:4px}.header-actions button.ghost.small{font-size:18px;min-width:32px}.tabs{display:flex;gap:6px;background:#1a3a2a14;padding:4px;border-radius:100px;margin:16px 0}.tab{flex:1;background:transparent;border:none;padding:10px;border-radius:100px;font-weight:600;font-size:14px;color:var(--green-dark);cursor:pointer}.tab.active{background:var(--green-dark);color:var(--sand)}.empty{padding:60px 20px;text-align:center}.empty p{margin:4px 0}.session-list,.contact-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.session-card{background:var(--white);border-radius:var(--radius);padding:18px;position:relative;cursor:pointer}.session-date-row{display:flex;align-items:baseline;gap:8px;margin-bottom:8px}.session-date{font-weight:800;font-size:18px;text-transform:capitalize;letter-spacing:-.02em}.session-time{font-size:14px;color:var(--gray-muted)}.session-club{font-size:15px;color:var(--green-mid);margin:0 0 2px;font-weight:600}.session-court{font-size:13px;color:var(--gray-muted);margin:0 0 12px}.session-players{display:flex;align-items:center}.session-players .avatar{margin-left:-8px;border:2px solid var(--white)}.session-players .avatar:first-child{margin-left:0}.session-players .more{margin-left:6px;font-size:13px;color:var(--gray-muted);font-weight:600}.role-badge{position:absolute;top:16px;right:16px;font-size:10px;font-weight:800;padding:4px 10px;border-radius:100px;letter-spacing:.08em}.role-badge.organizer{background:var(--lime);color:var(--green-dark)}.role-badge.guest{background:#1a3a2a1a;color:var(--green-mid)}.contact-row{background:var(--white);border-radius:var(--radius);padding:14px;display:flex;align-items:center;gap:14px;cursor:pointer}.contact-info{flex:1}.contact-name{font-weight:600;margin:0 0 2px;font-size:15px}.contact-phone{font-size:13px;color:var(--gray-muted);margin:0}.contact-chevron{color:var(--gray-300);font-size:24px;line-height:1}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;color:var(--white);font-weight:700;flex-shrink:0}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:430px;background:var(--green-dark);display:flex;padding:12px 20px;padding-bottom:calc(12px + env(safe-area-inset-bottom));z-index:20}.bottom-nav .nav-item{flex:1;background:transparent;border:none;display:flex;flex-direction:column;align-items:center;gap:4px;color:#f2ede473;font-size:11px;font-weight:600;cursor:pointer;padding:4px 0}.bottom-nav .nav-item.active{color:var(--lime)}.fab{position:fixed;bottom:calc(var(--bottom-nav-h) + 12px + env(safe-area-inset-bottom));left:50%;margin-left:139px;width:56px;height:56px;border-radius:50%;background:var(--lime);color:var(--green-dark);font-size:32px;font-weight:800;border:none;cursor:pointer;box-shadow:0 8px 24px #1a3a2a40;z-index:15;line-height:1}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:30;opacity:0;transition:opacity .25s;pointer-events:none}.sheet-backdrop.open{opacity:1;pointer-events:auto}.sheet{position:fixed;bottom:0;left:50%;transform:translate(-50%) translateY(100%);width:100%;max-width:430px;background:var(--sand);border-radius:24px 24px 0 0;z-index:31;transition:transform .3s cubic-bezier(.32,.72,.36,1);max-height:90dvh;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;padding-bottom:calc(24px + env(safe-area-inset-bottom))}.sheet.open{transform:translate(-50%) translateY(0)}.sheet-handle{width:40px;height:4px;background:#1a3a2a33;border-radius:2px;margin:12px auto}.sheet-title{padding:8px 20px 16px;font-size:22px}.sheet-body{padding:0 20px}.form{display:flex;flex-direction:column;gap:16px}.field{display:flex;flex-direction:column;gap:6px}.field-row{display:flex;gap:12px}.field-row .field{flex:1}.field label{font-size:12px;font-weight:700;color:var(--green-mid);text-transform:uppercase;letter-spacing:.05em}.field input{background:var(--white);border:none;border-radius:var(--radius-sm);padding:14px 16px;font-size:16px;font-family:inherit;color:var(--green-dark);-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%}.field input:focus{outline:2px solid var(--green-dark)}.segmented{display:flex;background:#1a3a2a14;border-radius:100px;padding:4px}.segmented-item{flex:1;padding:12px;text-align:center;border-radius:100px;font-weight:600;font-size:14px;color:var(--green-dark);cursor:pointer;background:transparent;border:none}.segmented-item.active{background:var(--green-dark);color:var(--sand)}.btn{display:block;width:100%;background:var(--green-dark);color:var(--sand);border:none;border-radius:100px;padding:16px;font-size:15px;font-weight:700;cursor:pointer}.btn:disabled{opacity:.5}.btn.ghost{background:transparent;color:var(--green-dark)}.btn.ghost.danger{color:var(--red)}.btn.ghost-lime{background:var(--lime);color:var(--green-dark);text-align:center;text-decoration:none;display:block}a.btn{text-decoration:none;text-align:center;display:block}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--gray-100);text-decoration:none;font-size:18px;margin-left:4px}.player-actions{display:flex}.queue-block{background:var(--green-dark);color:var(--sand);border-radius:var(--radius);padding:24px;text-align:center}.queue-progress{font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--lime);margin:0 0 4px;font-weight:700}.queue-mode{font-size:14px;opacity:.7;margin:0 0 20px}.queue-contact{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:24px}.queue-contact span{font-size:20px;font-weight:700}.queue-block .btn{margin-bottom:12px}.queue-block .muted{color:#f2ede4b3}.form-actions{display:flex;flex-direction:column;gap:8px;margin-top:8px}.player-picker{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.player-pick{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--white);border-radius:var(--radius-sm);cursor:pointer}.player-pick.selected{background:var(--lime)}.player-name{flex:1;font-weight:600;font-size:15px}.player-pick .check{width:22px;height:22px;border-radius:50%;border:2px solid var(--green-dark);display:flex;align-items:center;justify-content:center;font-weight:800;color:var(--green-dark);font-size:14px}.player-pick.selected .check{background:var(--green-dark);color:var(--lime);border-color:var(--green-dark)}.player-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.player-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--white);border-radius:var(--radius-sm)}.player-row .player-phone{font-size:13px;color:var(--gray-muted)}.detail-block{background:var(--green-dark);color:var(--sand);border-radius:var(--radius);padding:20px;position:relative}.detail-block .detail-when{font-weight:800;font-size:18px;margin:0 0 8px;text-transform:capitalize}.detail-block .detail-where{font-size:16px;margin:0 0 2px;font-weight:600}.detail-block .muted{color:#f2ede4b3}.update-banner{position:fixed;top:calc(env(safe-area-inset-top) + 12px);left:50%;transform:translate(-50%);background:var(--green-dark);color:var(--lime);padding:12px 20px;border-radius:100px;font-size:14px;font-weight:600;z-index:1000;box-shadow:0 8px 24px #1a3a2a40;animation:slideDown .3s ease;cursor:pointer}@keyframes slideDown{0%{transform:translate(-50%) translateY(-150%)}to{transform:translate(-50%) translateY(0)}}@media (max-width: 380px){h1{font-size:28px}.page{padding:20px 16px;padding-bottom:calc(var(--bottom-nav-h) + 24px)}}
