:root{--c-dark-roast: #57564F;--c-stone-grey: #7A7A73;--c-light-tan: #DDDADO;--c-ivory: #F8F3CE;--c-accent-orange: #F2921D;--c-accent-orange-hover: #E67E00;--c-white: #FFFFFF;--c-background: #F9FAFB;--c-text-dark: #111827;--c-text-medium: #4B5563;--c-text-light: #FFFFFF;--c-danger: #EF4444;--c-danger-hover: #DC2626;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Helvetica Neue", sans-serif}body{margin:0;font-family:var(--font-sans);background-color:var(--c-background);color:var(--c-text-dark);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-header{background-color:var(--c-white);padding:.5rem 2.5rem;box-shadow:0 4px 6px -1px #0000000d;border-bottom:1px solid var(--c-light-tan);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;width:100%;z-index:1000;box-sizing:border-box}.logo{text-decoration:none}.logo img{height:120px;width:auto;display:block;padding:10px;box-sizing:border-box}nav{display:flex;align-items:center;gap:2rem}nav a{text-decoration:none;color:var(--c-stone-grey);font-weight:600;font-size:1rem;padding-bottom:.25rem;border-bottom:2px solid transparent;transition:all .2s ease-in-out}nav a:hover{color:var(--c-dark-roast);border-bottom-color:var(--c-accent-orange)}nav span{color:var(--c-text-dark);font-weight:500}.logout-button{background-color:var(--c-dark-roast);color:var(--c-text-light);border:none;padding:.6rem 1.2rem;border-radius:8px;cursor:pointer;font-weight:600;font-size:.9rem;transition:background-color .2s}.logout-button:hover{background-color:#3d3c38}main{padding:2.5rem;padding-top:150px}.booking-container,.auth-form,.my-bookings-container,.admin-dashboard{max-width:1100px;margin:0 auto;background:var(--c-white);padding:2.5rem;border-radius:12px;box-shadow:0 10px 15px -3px #0000000d;border:1px solid var(--c-light-tan)}h2{font-size:2rem;font-weight:700;color:var(--c-dark-roast);margin-top:0}h3{font-size:1.5rem;font-weight:600;color:var(--c-dark-roast)}.date-navigation button{background-color:var(--c-stone-grey);color:var(--c-white)}.date-navigation button:hover{background-color:var(--c-dark-roast)}.booking-grid{width:100%;border-collapse:collapse}.booking-grid th,.booking-grid td{border:1px solid var(--c-light-tan);padding:.75rem;text-align:center}.booking-grid th{background-color:#f9fafb;font-weight:600;font-size:1rem}.slot-button{width:100%;padding:1rem 0;border:2px solid transparent;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s ease-in-out;font-size:.9rem}.slot-button.available{background-color:var(--c-white);color:var(--c-stone-grey);border-color:var(--c-light-tan)}.slot-button.available:hover{background-color:var(--c-ivory);border-color:var(--c-accent-orange)}.slot-button.booked{background-color:var(--c-stone-grey);color:var(--c-white);cursor:not-allowed}.slot-button.my-booking{background-color:var(--c-accent-orange);color:var(--c-white)}.slot-button.my-booking:hover{background-color:var(--c-accent-orange-hover)}.slot-button.blacked-out{background-color:var(--c-text-medium);color:var(--c-white);cursor:not-allowed}.message{padding:1rem;margin-bottom:1rem;border-radius:8px;font-weight:500;border:1px solid transparent}.message.success-message{background-color:#f0fff4;color:#2c5282;border-color:#9ae6b4}.message.error-message{background-color:#fff5f5;color:#c53030;border-color:#feb2b2}.auth-form{max-width:450px}.auth-form form{display:flex;flex-direction:column;gap:1.25rem}.auth-form input,.auth-form select,.blackout-form input,.blackout-form select,.booking-form input,.booking-form select,.user-form input,.user-form select,.court-form input,.court-form select,.recurring-form input,.recurring-form select,.settings-form input,.settings-form select{padding:.9rem;border:1px solid var(--c-light-tan);border-radius:8px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.auth-form input:focus,.auth-form select:focus,.blackout-form input:focus,.blackout-form select:focus,.booking-form input:focus,.booking-form select:focus,.user-form input:focus,.user-form select:focus,.court-form input:focus,.court-form select:focus,.recurring-form input:focus,.recurring-form select:focus,.settings-form input:focus,.settings-form select:focus{border-color:var(--c-accent-orange);box-shadow:0 0 0 3px #f2921d4d;outline:none}.auth-form button,.blackout-form button,.booking-form button,.user-form button,.court-form button,.recurring-form button,.save-button,.profile-form .save-button{padding:.9rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s;color:var(--c-text-light);border:none;background-color:var(--c-dark-roast)}.auth-form button:hover,.blackout-form button:hover,.booking-form button:hover,.user-form button:hover,.court-form button:hover,.recurring-form button:hover,.save-button:hover,.profile-form .save-button:hover{background-color:#3d3c38}.auth-form p a{color:var(--c-accent-orange)}.cancel-button{background-color:var(--c-danger)}.cancel-button:hover{background-color:var(--c-danger-hover)}.edit-button{background-color:var(--c-stone-grey)}.edit-button:hover{background-color:var(--c-dark-roast)}.admin-tabs button.active{color:var(--c-accent-orange);border-bottom-color:var(--c-accent-orange)}.blackout-form,.booking-form,.user-form,.court-form,.recurring-form,.settings-form{background-color:#f9fafb;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;align-items:center;margin-top:1rem;padding:1.5rem;border-radius:8px}.my-bookings-container{max-width:700px}.bookings-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1rem}.bookings-list li{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;border:1px solid var(--c-light-tan);border-radius:8px}.booking-info p{margin:.25rem 0 0;text-align:left;color:var(--c-text-medium)}.booking-info strong{font-size:1.2rem;color:var(--c-dark-roast)}.cancel-button,.edit-button{border:none;padding:.6rem 1.2rem;border-radius:8px;cursor:pointer;font-weight:600;transition:background-color .2s;color:var(--c-text-light)}.admin-dashboard{max-width:1200px}.admin-tabs{display:flex;border-bottom:2px solid var(--c-light-tan);margin-bottom:2rem}.admin-tabs button{padding:1rem 0;margin-right:2rem;border:none;background:none;cursor:pointer;font-size:1.1rem;font-weight:600;color:var(--c-text-medium);border-bottom:3px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s}.admin-table{width:100%;border-collapse:collapse;margin-top:2rem}.admin-table th,.admin-table td{border-bottom:1px solid var(--c-light-tan);padding:1rem;text-align:left}.admin-table th{background-color:#f9fafb;font-size:.9rem;text-transform:uppercase;color:var(--c-text-medium)}.admin-table button{margin-right:.5rem}.danger-zone{border:2px solid var(--c-danger);border-radius:12px;padding:1.5rem 2rem;margin-top:2rem;background-color:#fef2f2}.danger-zone h4{color:var(--c-danger);margin-top:0;font-size:1.25rem;font-weight:700}.danger-zone .danger-actions{display:flex;gap:1rem;margin-top:1rem}.danger-zone .danger-button{background-color:var(--c-danger);color:var(--c-text-light);border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:600;transition:background-color .2s}.danger-zone .danger-button:hover{background-color:var(--c-danger-hover)}.confirmation-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#11182799;display:flex;justify-content:center;align-items:center;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.confirmation-modal{background:var(--c-white);padding:2rem;border-radius:12px;box-shadow:0 10px 25px #0003;width:90%;max-width:500px;text-align:left}.confirmation-modal h3{color:var(--c-danger);margin-top:0}.confirmation-modal p{margin-bottom:1rem;line-height:1.5}.confirmation-modal input{width:100%;padding:.75rem;border:1px solid var(--medium-grey);border-radius:8px;font-size:1rem;margin-top:.5rem;box-sizing:border-box}.confirmation-modal .modal-actions{margin-top:1.5rem;display:flex;justify-content:flex-end;gap:1rem}.confirmation-modal .modal-actions button{padding:.6rem 1.2rem;border-radius:8px;font-weight:600;cursor:pointer;border:1px solid transparent}.confirmation-modal .modal-actions .confirm-button{background-color:var(--c-danger);color:var(--c-text-light)}.confirmation-modal .modal-actions .confirm-button:disabled{background-color:#f87171;cursor:not-allowed}.confirmation-modal .modal-actions .cancel-button{background-color:var(--light-grey);border-color:var(--medium-grey);color:var(--text-dark)}.app-footer{padding:2rem;text-align:center;color:var(--dark-grey);font-size:.9rem;font-weight:500}.settings-form{max-width:600px;margin-top:2rem;display:flex;flex-direction:column;gap:1rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:600;margin-bottom:.5rem}.form-group select,.form-group input{width:100%;padding:.9rem;border:1px solid var(--c-light-tan);border-radius:8px;font-size:1rem;background-color:var(--c-white);color:var(--c-text-dark);box-sizing:border-box}.form-group .form-hint{font-size:.85rem;color:var(--dark-grey);margin-top:.5rem}.all-day-checkbox{display:flex;align-items:center;gap:.5rem;grid-column:1 / -1;margin-bottom:-.5rem}.all-day-checkbox input{width:1.15rem;height:1.15rem}.all-day-checkbox label{font-weight:500;cursor:pointer}.profile-container{max-width:800px;text-align:left}.profile-form .form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.profile-form .form-actions{margin-top:2rem}.segmented-control{display:flex;border:1px solid var(--c-light-tan);border-radius:8px;overflow:hidden}.segmented-control button,.segmented-control .skill-tooltip-container{flex:1}.segmented-control button{width:100%;padding:.9rem;border:none;background-color:transparent;color:var(--c-stone-grey);font-weight:600;cursor:pointer;transition:background-color .2s,color .2s;border-right:1px solid var(--c-light-tan)}.segmented-control button:last-child{border-right:none}.segmented-control button.active{background-color:var(--c-dark-roast);color:var(--c-text-light)}.skill-tooltip-container{position:relative;display:inline-block}.skill-tooltip-text{visibility:hidden;width:200px;background-color:var(--c-dark-roast);color:var(--c-text-light);text-align:center;border-radius:6px;padding:8px;position:absolute;z-index:1;bottom:125%;left:50%;margin-left:-100px;opacity:0;transition:opacity .3s}.skill-tooltip-text:after{content:"";position:absolute;top:100%;left:50%;margin-left:-5px;border-width:5px;border-style:solid;border-color:var(--c-dark-roast) transparent transparent transparent}.skill-tooltip-container:hover .skill-tooltip-text{visibility:visible;opacity:1}.google-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.9rem;background-color:#4285f4;color:var(--c-text-light);border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s;margin-top:1rem}.google-btn:hover{background-color:#357ae8}.google-btn svg{width:20px;height:20px;background-color:var(--c-white);border-radius:50%;padding:2px}.auth-divider{display:flex;align-items:center;text-align:center;color:var(--dark-grey);margin:1.5rem 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;border-bottom:1px solid var(--medium-grey)}.auth-divider:not(:empty):before{margin-right:.25em}.auth-divider:not(:empty):after{margin-left:.25em}.toggle-switch{position:relative;display:inline-block;width:60px;height:34px}.toggle-switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--medium-grey);transition:.4s;border-radius:34px}.slider:before{position:absolute;content:"";height:26px;width:26px;left:4px;bottom:4px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.slider{background-color:var(--c-accent-orange)}input:checked+.slider:before{transform:translate(26px)}.account-connection-section{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--c-light-tan)}.connection-status{display:flex;justify-content:space-between;align-items:center;padding:1rem;background-color:var(--c-background);border-radius:8px}.connection-status p{margin:0;font-weight:500}.connection-status .status-text{color:var(--c-accent-orange)}.ical-section{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--c-light-tan)}.ical-feed-box{display:flex;align-items:center;gap:1rem;background-color:var(--c-background);padding:.5rem 1rem;border-radius:8px;border:1px solid var(--c-light-tan)}.ical-feed-box input{flex-grow:1;background-color:transparent;border:none;color:var(--c-text-dark);font-family:monospace;font-size:.9rem}.ical-feed-box input:focus{outline:none}.ical-feed-box button{padding:.5rem 1rem;font-size:.9rem;white-space:nowrap}.link-button{background:none;border:none;color:var(--c-accent-orange);text-decoration:underline;cursor:pointer;font-size:.85rem;padding:0;margin:0 0 0 5px}.link-button:hover{color:var(--c-accent-orange-hover)}
