:root{--bg: #0D1B2A;--bg-card: #152233;--bg-surface: #1C2E42;--bg-hover: #1E3350;--text: #EEF3F8;--text-secondary: #8BAFC9;--text-light: #4E6E87;--yellow: #F5C842;--yellow-dark: #C9A020;--yellow-light: rgba(245, 200, 66, .12);--white: #FFFFFF;--danger: #E05252;--danger-light: rgba(224, 82, 82, .15);--success: #3DBE7A;--border: #1E3350;--border-light: #1A2D40;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--radius: 8px;--radius-lg: 14px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 40px;--space-2xl: 64px;--max-width: 800px;--nav-height: 56px;--bottom-nav-height: 60px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:var(--font-sans);color:var(--text);background:var(--bg);line-height:1.6;min-height:100vh}h1{font-size:1.8rem;font-weight:600;line-height:1.2;letter-spacing:-.02em}h2{font-size:1.3rem;font-weight:600}h3{font-size:1rem;font-weight:600}a{color:var(--yellow);text-decoration:none}a:hover{color:var(--yellow-dark)}img{max-width:100%;height:auto}.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-lg)}.page{padding:var(--space-xl) 0;padding-bottom:calc(var(--space-xl) + var(--bottom-nav-height));min-height:calc(100vh - var(--nav-height))}.page-header{margin-bottom:var(--space-lg)}.page-header h1{margin-bottom:0}.nav{position:sticky;top:0;z-index:100;background:#0d1b2aeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);height:var(--nav-height)}.nav-inner{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-lg);display:flex;align-items:center;justify-content:space-between;height:100%}.nav-brand{display:flex;align-items:center;gap:8px;font-size:1rem;font-weight:700;color:var(--yellow);text-decoration:none;letter-spacing:.02em}.nav-brand svg{width:20px;height:20px;color:var(--yellow)}.nav-right{display:flex;align-items:center;gap:var(--space-sm)}.nav-name{font-size:.8rem;color:var(--text-light)}.nav-bottom{display:none;position:fixed;bottom:0;left:0;right:0;height:var(--bottom-nav-height);background:#0d1b2af7;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border);z-index:100;padding-bottom:env(safe-area-inset-bottom,0)}.nav-link{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;flex:1;padding:8px;color:var(--text-light);font-size:.68rem;font-weight:500;transition:color .15s;text-decoration:none}.nav-link svg{width:20px;height:20px}.nav-link:hover{color:var(--text-secondary)}.nav-link.active{color:var(--yellow)}@media (max-width: 640px){.nav-bottom{display:flex}.nav-right .nav-settings{display:none}}.login-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-lg);background:var(--bg)}.login-card{text-align:center;max-width:360px;width:100%}.login-logo{margin-bottom:var(--space-md)}.login-card h1{font-size:2.4rem;font-weight:700;letter-spacing:.04em;margin-bottom:6px;color:var(--yellow)}.login-subtitle{color:var(--text-secondary);font-size:.9rem;margin-bottom:var(--space-xl);letter-spacing:.08em;text-transform:uppercase}.login-divider{width:40px;height:2px;background:var(--border);margin:0 auto var(--space-xl)}.login-form{display:flex;flex-direction:column;gap:var(--space-md);text-align:left}.login-note{text-align:center;font-size:.78rem;color:var(--text-light);margin-top:-4px}.login-sent{padding:var(--space-lg);background:var(--yellow-light);border:1px solid rgba(245,200,66,.25);border-radius:var(--radius);text-align:left}.login-sent-title{font-weight:600;color:var(--yellow);margin-bottom:var(--space-sm);font-size:.9rem}.form-group{text-align:left}.form-group label{display:block;font-size:.78rem;font-weight:500;color:var(--text-secondary);margin-bottom:5px;letter-spacing:.02em;text-transform:uppercase}input[type=text],input[type=email],input[type=date],input[type=time],textarea,select{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-sans);font-size:.9rem;color:var(--text);background:var(--bg-surface);transition:border-color .15s;outline:none}input:focus,textarea:focus,select:focus{border-color:var(--yellow);box-shadow:0 0 0 2px var(--yellow-light)}input::placeholder,textarea::placeholder{color:var(--text-light)}textarea{resize:vertical;min-height:80px;line-height:1.6}select option{background:var(--bg-card);color:var(--text)}input[type=date]::-webkit-calendar-picker-indicator,input[type=time]::-webkit-calendar-picker-indicator{filter:invert(.6) sepia(1) saturate(2) hue-rotate(180deg);cursor:pointer}.time-row,.date-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;border:none;border-radius:var(--radius);font-family:var(--font-sans);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s;text-decoration:none;line-height:1;min-height:44px}.btn svg{width:16px;height:16px}.btn-primary{background:var(--yellow);color:#0d1b2a}.btn-primary:hover{background:var(--yellow-dark);color:#0d1b2a}.btn-secondary{background:var(--bg-surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-hover)}.btn-danger{background:var(--danger-light);color:var(--danger);border:1px solid rgba(224,82,82,.3)}.btn-danger:hover{background:var(--danger);color:#fff}.btn-sm{padding:6px 12px;font-size:.8rem;min-height:36px}.btn-lg{padding:13px 28px;font-size:.95rem;min-height:50px}.btn-block{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-icon{padding:8px;background:transparent;border:none;cursor:pointer;color:var(--text-light);border-radius:6px;transition:all .15s;display:inline-flex;align-items:center;justify-content:center;min-height:36px;min-width:36px}.btn-icon svg{width:18px;height:18px}.btn-icon:hover{background:var(--bg-surface);color:var(--text-secondary)}.card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);overflow:hidden}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.calendar-nav{display:flex;align-items:center;gap:var(--space-sm)}.calendar-nav h2{min-width:160px;text-align:center;font-size:1.1rem}.calendar-grid{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);overflow:hidden}.tg-wrap{display:flex;flex-direction:column}.tg-header{display:grid;grid-template-columns:48px repeat(7,1fr);border-bottom:1px solid var(--border);background:var(--bg-card)}.tg-corner{border-right:1px solid var(--border-light)}.tg-col-head{padding:8px 4px;text-align:center;border-right:1px solid var(--border-light);display:flex;flex-direction:column;align-items:center;gap:4px}.tg-col-head:last-child{border-right:none}.tg-col-head.today .tg-col-num{background:var(--yellow);color:#0d1b2a}.tg-col-dayname{font-size:.62rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-light)}.tg-col-num{font-size:1rem;font-weight:600;color:var(--text-secondary);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%}.tg-body-wrap{overflow-y:auto;max-height:620px;padding-top:8px}.tg-body{display:grid;grid-template-columns:48px repeat(7,1fr);position:relative}.tg-time-col{position:relative;border-right:1px solid var(--border-light)}.tg-time-label{position:absolute;right:8px;font-size:.6rem;color:var(--text-light);transform:translateY(3px);white-space:nowrap;-webkit-user-select:none;user-select:none}.tg-day-col{position:relative;border-right:1px solid var(--border-light);cursor:pointer;background-image:repeating-linear-gradient(to bottom,var(--border-light) 0px,var(--border-light) 1px,transparent 1px,transparent 64px)}.tg-day-col:last-child{border-right:none}.tg-day-col:hover{background-color:#f5c84205}.tg-day-col.blacked-out{background-image:repeating-linear-gradient(45deg,transparent,transparent 5px,rgba(255,255,255,.018) 5px,rgba(255,255,255,.018) 10px);cursor:default}.tg-day-col.blacked-out:hover{background-color:transparent}.tg-blackout{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-start;justify-content:center;padding-top:10px;font-size:.62rem;color:var(--text-light);font-style:italic;text-align:center;pointer-events:none}.tg-event{position:absolute;left:3px;right:3px;border-radius:5px;padding:4px 7px;overflow:hidden;cursor:pointer;z-index:1;transition:opacity .1s,filter .1s;line-height:1.25}.tg-event:hover{filter:brightness(1.08)}.tg-event-past{opacity:.4;cursor:default}.tg-event-past:hover{filter:none}.tg-event-boat{font-size:.72rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tg-event-time{font-size:.64rem}.tg-event-user{font-size:.6rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tg-event-short .tg-event-boat{font-size:.65rem}.tg-now-line{position:absolute;left:48px;right:0;height:2px;background:var(--danger);z-index:3;pointer-events:none}.tg-now-dot{position:absolute;left:-4px;top:50%;transform:translateY(-50%);width:8px;height:8px;background:var(--danger);border-radius:50%}.calendar-legend{display:flex;flex-wrap:wrap;gap:var(--space-md);margin-top:var(--space-sm);padding:var(--space-xs) 0}.legend-item{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--text-secondary)}.legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.date-bookings{display:flex;flex-direction:column;gap:4px}.date-bookings-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-light)}.date-booking-item{display:flex;align-items:center;gap:8px;padding:6px 8px;background:var(--bg-surface);border-radius:4px;border-left:3px solid;font-size:.8rem}.date-booking-boat{font-weight:500;flex-shrink:0}.date-booking-time{color:var(--text-secondary);flex-shrink:0}.date-booking-user{color:var(--text-light);font-size:.72rem;margin-left:auto}.conflict-warning{display:flex;align-items:center;gap:6px;padding:8px 10px;background:var(--danger-light);border:1px solid rgba(224,82,82,.3);border-radius:var(--radius);color:var(--danger);font-size:.8rem}.conflict-warning svg{width:14px;height:14px;flex-shrink:0}.res-detail{display:flex;flex-direction:column;gap:var(--space-sm)}.res-detail-row{display:flex;justify-content:space-between;align-items:baseline;gap:var(--space-md);padding:var(--space-sm) 0;border-bottom:1px solid var(--border-light);font-size:.9rem}.res-detail-row:last-child{border-bottom:none}.res-detail-label{color:var(--text-light);font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;flex-shrink:0}.tab-bar{display:flex;gap:2px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:4px;margin-bottom:var(--space-lg)}.tab-btn{flex:1;padding:8px 12px;background:transparent;border:none;border-radius:10px;font-family:var(--font-sans);font-size:.85rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .15s;min-height:40px}.tab-btn:hover{color:var(--text)}.tab-btn.active{background:var(--bg-surface);color:var(--yellow);font-weight:600}.tab-header{margin-bottom:var(--space-md)}.tab-count{font-size:.82rem;color:var(--text-light)}.member-row{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-light);min-height:64px}.member-row:last-child{border-bottom:none}.row-inactive{opacity:.5}.boat-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.member-info{flex:1;min-width:0}.member-info strong{display:block;font-size:.9rem;font-weight:500;color:var(--text)}.member-info span{color:var(--text-secondary);font-size:.8rem}.row-actions{display:flex;gap:2px;flex-shrink:0}.section-divider{padding:var(--space-sm) var(--space-lg);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-light);background:var(--bg-surface);border-bottom:1px solid var(--border-light)}.badge{font-size:.7rem;font-weight:600;padding:3px 10px;border-radius:20px;flex-shrink:0;text-transform:uppercase;letter-spacing:.04em}.badge-member{background:var(--bg-surface);color:var(--text-secondary)}.badge-admin{background:var(--yellow-light);color:var(--yellow)}.badge-active{background:#3dbe7a26;color:var(--success)}.badge-inactive{background:var(--bg-surface);color:var(--text-light)}.color-picker{display:flex;gap:var(--space-sm);flex-wrap:wrap}.color-swatch{width:32px;height:32px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all .15s;padding:0}.color-swatch:hover{transform:scale(1.1)}.color-swatch.selected{border-color:var(--yellow);box-shadow:0 0 0 2px var(--bg-card),0 0 0 4px var(--yellow)}.color-picker-row{display:flex;align-items:center;gap:var(--space-md);flex-wrap:wrap}.color-custom-input{width:36px;height:36px;padding:2px;border:2px solid var(--border);border-radius:50%;background:transparent;cursor:pointer;flex-shrink:0}.color-custom-input::-webkit-color-swatch-wrapper{padding:0;border-radius:50%}.color-custom-input::-webkit-color-swatch{border:none;border-radius:50%}.color-custom-input:hover{border-color:var(--yellow)}.toggle-label{display:flex;align-items:center;gap:var(--space-sm);font-size:.9rem;cursor:pointer;color:var(--text-secondary);min-height:44px}.toggle-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--yellow);flex-shrink:0}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center;padding:var(--space-lg);opacity:0;transition:opacity .15s}.modal-backdrop.visible{opacity:1}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;transform:translateY(8px);transition:transform .15s}.modal-backdrop.visible .modal{transform:translateY(0)}.modal-header{padding:var(--space-lg) var(--space-lg) 0;display:flex;align-items:center;justify-content:space-between}.modal-header h2{font-size:1.05rem;color:var(--text)}.modal-body{padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md)}.modal-footer{padding:0 var(--space-lg) var(--space-lg);display:flex;justify-content:flex-end;gap:var(--space-sm)}@media (max-width: 640px){.modal-backdrop{align-items:flex-end;padding:0}.modal{max-width:100%;max-height:92vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0}}.toast-container{position:fixed;bottom:calc(var(--bottom-nav-height) + var(--space-md));right:var(--space-lg);z-index:400;display:flex;flex-direction:column;gap:var(--space-sm)}.toast{background:var(--bg-surface);border:1px solid var(--border);color:var(--text);padding:10px var(--space-lg);border-radius:var(--radius);box-shadow:var(--shadow);font-size:.85rem;animation:slideUp .2s ease;max-width:320px}.toast.success{background:#3dbe7a26;border-color:#3dbe7a4d;color:var(--success)}.toast.error{background:var(--danger-light);border-color:#e052524d;color:var(--danger)}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 640px){.toast-container{left:var(--space-md);right:var(--space-md);bottom:calc(var(--bottom-nav-height) + var(--space-sm))}.toast{max-width:100%}}.spinner{display:inline-block;width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--yellow);border-radius:50%;animation:spin .5s linear infinite}.spinner-lg{width:28px;height:28px}@keyframes spin{to{transform:rotate(360deg)}}.loading-page{display:flex;align-items:center;justify-content:center;min-height:200px}.empty-state{text-align:center;padding:var(--space-xl);color:var(--text-light);font-size:.9rem}.history-list{display:flex;flex-direction:column}.history-row{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-light)}.history-row:last-child{border-bottom:none}.history-row.history-cancelled{opacity:.65}.history-boat-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:4px}.history-info{flex:1;min-width:0}.history-boat{font-size:.9rem;font-weight:500;color:var(--text)}.history-time{font-size:.8rem;color:var(--text-secondary)}.history-cancelled-at{font-size:.75rem;color:var(--text-light);margin-top:2px}.cancel-detail{font-size:.75rem;color:var(--text-light);display:block}.late-cancel{background:#e052521f;color:var(--danger);border:1px solid rgba(224,82,82,.25)}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.hidden{display:none!important}.page-enter{animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 640px){:root{--space-lg: 16px;--space-xl: 24px;--space-2xl: 36px}h1{font-size:1.5rem}.page-header.flex{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.page-header .btn{align-self:stretch;justify-content:center}.calendar-header{flex-wrap:wrap;gap:var(--space-sm)}.calendar-nav h2{min-width:120px;font-size:.88rem}.tg-body-wrap{max-height:480px}.tg-col-head{padding:6px 2px}.tg-col-num{width:26px;height:26px;font-size:.85rem}.tg-event{left:1px;right:1px;padding:2px 3px}.tg-event-time,.tg-event-user{display:none}.tg-event-boat{font-size:.6rem}.tg-time-label{font-size:.52rem;right:4px}.member-row{padding:var(--space-sm) var(--space-md);gap:var(--space-sm);min-height:56px}.time-row,.date-row{grid-template-columns:1fr 1fr}.tab-btn{font-size:.8rem;padding:8px 6px}}
