@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";.layout{min-height:100vh;display:flex;flex-direction:column}.layout-body{display:flex;flex:1}.header{background-color:var(--color-brand-yellow-light);border-bottom:1px solid rgba(0,0,0,.08);position:sticky;top:0;z-index:100}.header-content{display:flex;align-items:center;justify-content:space-between;height:56px;padding:0 var(--spacing-md);max-width:1400px;margin:0 auto}.header-left,.header-right{display:flex;align-items:center;gap:var(--spacing-md)}.logo{font-size:var(--font-size-base);font-weight:600;color:var(--color-text);text-decoration:none}.logo:hover{text-decoration:none;color:var(--color-text)}.header-user-link{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;text-decoration:none;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-fast)}.header-user-link:hover{color:var(--color-text);background-color:#0000000d;text-decoration:none}.menu-toggle{display:none;align-items:center;justify-content:center;width:40px;height:40px;background:none;border:none;cursor:pointer;border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.menu-toggle:hover{background-color:#0000000d}.menu-icon{display:block;width:20px;height:2px;background-color:var(--color-text);position:relative}.menu-icon:before,.menu-icon:after{content:"";position:absolute;left:0;width:20px;height:2px;background-color:var(--color-text)}.menu-icon:before{top:-6px}.menu-icon:after{bottom:-6px}.sidebar{width:260px;background-color:var(--color-surface);border-right:1px solid var(--color-border-light);flex-shrink:0;overflow-y:auto;height:calc(100vh - 56px);position:sticky;top:56px}.sidebar-nav{padding:var(--spacing-md)}.sidebar-section{margin-bottom:var(--spacing-md)}.sidebar-label{display:block;font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-xs)}.sidebar-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);font-family:var(--font-family);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-white);color:var(--color-text);cursor:pointer}.sidebar-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0f172a1a}.sidebar-divider{height:1px;background-color:var(--color-border-light);margin:var(--spacing-md) 0}.sidebar-group{margin-bottom:var(--spacing-md)}.sidebar-group-title{font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;padding:var(--spacing-xs) var(--spacing-sm);margin-bottom:var(--spacing-xs)}.sidebar-link{display:block;padding:var(--spacing-sm) var(--spacing-md);color:var(--color-text-secondary);text-decoration:none;font-size:var(--font-size-sm);border-radius:var(--radius-md);transition:all var(--transition-fast);margin-bottom:2px}.sidebar-link:hover{background-color:var(--color-gray-50);color:var(--color-text);text-decoration:none}.sidebar-link.active{background-color:var(--color-gray-100);color:var(--color-text);font-weight:500}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0006;z-index:150;opacity:0;transition:opacity var(--transition-base)}.sidebar-overlay.open{opacity:1}.main{flex:1;background-color:var(--color-background);min-width:0}.main-content{max-width:1100px;margin:0 auto;padding:var(--spacing-lg)}.footer{background-color:var(--color-brand-yellow-light);border-top:1px solid rgba(0,0,0,.08);padding:var(--spacing-md) 0;text-align:center;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.footer-content{max-width:1400px;margin:0 auto;padding:0 var(--spacing-md)}@media (max-width: 1024px){.menu-toggle{display:flex}.sidebar{position:fixed;top:0;left:0;height:100vh;z-index:200;transform:translate(-100%);transition:transform var(--transition-base);box-shadow:var(--shadow-xl)}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block;pointer-events:none}.sidebar-overlay.open{pointer-events:auto}.main.with-sidebar{margin-left:0}}@media (max-width: 640px){.header-content{height:52px;padding:0 var(--spacing-sm)}.header-left,.header-right{gap:var(--spacing-sm)}.header-user-link{display:none}.logo{font-size:var(--font-size-sm)}.main-content{padding:var(--spacing-md)}.sidebar{width:280px}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);background:linear-gradient(135deg,var(--color-gray-50) 0%,var(--color-brand-yellow-light) 100%)}.login-card{width:100%;max-width:400px;padding:var(--spacing-xl)}.login-header{text-align:center;margin-bottom:var(--spacing-xl)}.login-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text);margin-bottom:var(--spacing-sm);letter-spacing:-.025em}.login-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.login-button{width:100%;margin-top:var(--spacing-md)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:var(--spacing-lg)}.membership-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.membership-list-item{padding:var(--spacing-md);background-color:var(--color-gray-50);border-radius:var(--radius-lg);border:1px solid var(--color-border-light)}.membership-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.membership-year{font-weight:600;font-size:var(--font-size-base)}.membership-list-details{display:flex;justify-content:space-between;align-items:center;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.membership-type{color:var(--color-text)}.membership-fee{font-weight:500}.membership-shared{margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--color-border-light);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.membership-info,.berth-details{display:flex;flex-direction:column;gap:var(--spacing-sm)}.info-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) 0}.info-label{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.info-value{font-weight:500;color:var(--color-text)}.membership-status{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border-light)}.berth-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.berth-item{padding:var(--spacing-md);background-color:var(--color-gray-50);border-radius:var(--radius-lg);border:1px solid var(--color-border-light)}.berth-name{font-weight:600;font-size:var(--font-size-base);margin-bottom:var(--spacing-sm);color:var(--color-text)}.history-section{margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--color-border-light)}.history-section summary{cursor:pointer;color:var(--color-text-secondary);font-weight:500;font-size:var(--font-size-sm);transition:color var(--transition-fast)}.history-section summary:hover{color:var(--color-text)}.history-section[open] summary{margin-bottom:var(--spacing-md)}.history-section .table{min-width:0}.history-section .table th,.history-section .table td{white-space:normal}@media (max-width: 640px){.dashboard-grid{grid-template-columns:1fr}.info-row{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}}:root{--color-brand-yellow-light: #f9ecca;--color-brand-yellow: #fdce1a;--color-brand-red: #e63213;--color-white: #ffffff;--color-gray-25: #fcfcfd;--color-gray-50: #f9fafb;--color-gray-100: #f2f4f7;--color-gray-200: #eaecf0;--color-gray-300: #d0d5dd;--color-gray-400: #98a2b3;--color-gray-500: #667085;--color-gray-600: #475467;--color-gray-700: #344054;--color-gray-800: #1d2939;--color-gray-900: #101828;--color-primary: #0f172a;--color-primary-hover: #1e293b;--color-primary-light: #334155;--color-accent: var(--color-brand-red);--color-accent-hover: #c92a0f;--color-background: var(--color-gray-50);--color-surface: var(--color-white);--color-surface-raised: var(--color-white);--color-text: var(--color-gray-900);--color-text-secondary: var(--color-gray-600);--color-text-muted: var(--color-gray-500);--color-border: var(--color-gray-200);--color-border-light: var(--color-gray-100);--color-success: #059669;--color-success-light: #d1fae5;--color-success-dark: #047857;--color-error: #dc2626;--color-error-light: #fee2e2;--color-error-dark: #b91c1c;--color-warning: #d97706;--color-warning-light: #fef3c7;--color-info: #0284c7;--color-info-light: #e0f2fe;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--shadow-xs: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-sm: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text);background-color:var(--color-background);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-hover)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.625rem 1rem;font-size:var(--font-size-sm);font-weight:500;font-family:var(--font-family);border-radius:var(--radius-md);border:none;cursor:pointer;transition:all var(--transition-fast);gap:var(--spacing-sm);line-height:1.25;white-space:nowrap}.btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--color-primary);color:var(--color-white);box-shadow:var(--shadow-xs)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover);box-shadow:var(--shadow-sm)}.btn-accent{background-color:var(--color-accent);color:var(--color-white);box-shadow:var(--shadow-xs)}.btn-accent:hover:not(:disabled){background-color:var(--color-accent-hover);box-shadow:var(--shadow-sm)}.btn-secondary{background-color:var(--color-white);color:var(--color-text);border:1px solid var(--color-border);box-shadow:var(--shadow-xs)}.btn-secondary:hover:not(:disabled){background-color:var(--color-gray-50);border-color:var(--color-gray-300)}.btn-ghost{background-color:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background-color:var(--color-gray-100);color:var(--color-text)}.btn-danger{background-color:var(--color-white);color:var(--color-error);border:1px solid var(--color-error)}.btn-danger:hover:not(:disabled){background-color:var(--color-error);color:var(--color-white)}.btn-sm{padding:.375rem .75rem;font-size:var(--font-size-xs)}.btn-lg{padding:.75rem 1.25rem;font-size:var(--font-size-base)}.btn-icon{padding:.5rem;min-width:2.25rem;min-height:2.25rem}.btn-icon.btn-sm{padding:.375rem;min-width:1.75rem;min-height:1.75rem}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;margin-bottom:var(--spacing-sm);font-weight:500;font-size:var(--font-size-sm);color:var(--color-text)}.form-input{width:100%;padding:.625rem .875rem;font-size:var(--font-size-sm);font-family:var(--font-family);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-white);color:var(--color-text);transition:all var(--transition-fast);line-height:1.5}.form-input::placeholder{color:var(--color-text-muted)}.form-input:hover:not(:disabled){border-color:var(--color-gray-300)}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0f172a1a}.form-input:disabled{background-color:var(--color-gray-50);color:var(--color-text-muted);cursor:not-allowed}.form-checkbox{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer}.form-checkbox input[type=checkbox]{width:1.125rem;height:1.125rem;accent-color:var(--color-primary);cursor:pointer}.form-hint{color:var(--color-text-muted);font-size:var(--font-size-xs);margin-top:var(--spacing-xs)}.card{background-color:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border-light);box-shadow:var(--shadow-sm)}.card-padded{padding:var(--spacing-lg)}.card-header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border-light)}.card-body{padding:var(--spacing-lg)}.card-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text)}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm);min-width:600px}.table th,.table td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;white-space:nowrap}.table th{background-color:var(--color-gray-50);font-weight:600;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border)}.table td{border-bottom:1px solid var(--color-border-light)}.table tbody tr{transition:background-color var(--transition-fast)}.table tbody tr:hover{background-color:var(--color-gray-25)}.table tbody tr:last-child td{border-bottom:none}.table td:first-child{white-space:normal;min-width:150px}.alert{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);font-size:var(--font-size-sm);display:flex;align-items:flex-start;gap:var(--spacing-sm)}.alert-error{background-color:var(--color-error-light);color:var(--color-error-dark);border:1px solid #fecaca}.alert-success{background-color:var(--color-success-light);color:var(--color-success-dark);border:1px solid #a7f3d0}.alert-warning{background-color:var(--color-warning-light);color:var(--color-warning);border:1px solid #fde68a}.alert-info{background-color:var(--color-info-light);color:var(--color-info);border:1px solid #bae6fd}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);flex-wrap:wrap;gap:var(--spacing-md)}.page-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text);letter-spacing:-.025em}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md);animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background-color:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border-light)}.modal-title{font-size:var(--font-size-lg);font-weight:600}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-text-muted);padding:0;line-height:1;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-fast)}.modal-close:hover{background-color:var(--color-gray-100);color:var(--color-text)}.modal-body{padding:var(--spacing-lg)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-lg);border-top:1px solid var(--color-border-light);background-color:var(--color-gray-25);border-radius:0 0 var(--radius-xl) var(--radius-xl)}.badge{display:inline-flex;align-items:center;padding:.125rem .5rem;font-size:var(--font-size-xs);font-weight:500;border-radius:var(--radius-full)}.badge-success{background-color:var(--color-success-light);color:var(--color-success-dark)}.badge-warning{background-color:var(--color-warning-light);color:var(--color-warning)}.badge-error{background-color:var(--color-error-light);color:var(--color-error)}.badge-info{background-color:var(--color-info-light);color:var(--color-info)}.badge-neutral{background-color:var(--color-gray-100);color:var(--color-text-secondary)}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--color-text-muted)}code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.875em;background-color:var(--color-gray-100);padding:.125rem .375rem;border-radius:var(--radius-sm);color:var(--color-text)}.text-secondary{color:var(--color-text-secondary)}.text-sm{font-size:var(--font-size-sm)}.text-xs{font-size:var(--font-size-xs)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--spacing-xs)}.mb-2{margin-bottom:var(--spacing-sm)}.mb-3{margin-bottom:var(--spacing-md)}.mb-4{margin-bottom:var(--spacing-lg)}.mb-5{margin-bottom:var(--spacing-xl)}.mt-0{margin-top:0}.mt-1{margin-top:var(--spacing-xs)}.mt-2{margin-top:var(--spacing-sm)}.mt-3{margin-top:var(--spacing-md)}.mt-4{margin-top:var(--spacing-lg)}.mt-5{margin-top:var(--spacing-xl)}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--spacing-xs)}.gap-2{gap:var(--spacing-sm)}.gap-3{gap:var(--spacing-md)}.gap-4{gap:var(--spacing-lg)}.spinner{width:1.25rem;height:1.25rem;border:2px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.spinner-sm{width:1rem;height:1rem}@keyframes spin{to{transform:rotate(360deg)}}.loading-container{display:flex;justify-content:center;align-items:center;padding:var(--spacing-2xl)}.empty-state{text-align:center;padding:var(--spacing-2xl);color:var(--color-text-muted)}.empty-state-icon{font-size:3rem;margin-bottom:var(--spacing-md);opacity:.5}.table-actions{display:flex;gap:var(--spacing-xs);justify-content:flex-end;flex-wrap:wrap}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.section-title{font-size:var(--font-size-lg);font-weight:600;margin:0}.vehicle-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.vehicle-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-gray-50);border-radius:var(--radius-md);border:1px solid var(--color-border-light)}.vehicle-info{display:flex;align-items:center;gap:var(--spacing-sm)}.vehicle-reg{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-weight:600;font-size:var(--font-size-base);letter-spacing:.05em}.vehicle-actions{display:flex;gap:var(--spacing-xs)}.vehicle-reg-cell{display:flex;align-items:center;gap:var(--spacing-sm)}.grouped-row{background-color:var(--color-gray-25)}.grouped-row+.grouped-row{border-top:none}.grouped-row td:first-child{border-left:3px solid var(--color-primary)}.user-selector{max-height:200px;overflow-y:auto;border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-white)}.user-selector-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;transition:background-color var(--transition-fast);border-bottom:1px solid var(--color-border-light)}.user-selector-item:last-child{border-bottom:none}.user-selector-item:hover{background-color:var(--color-gray-50)}.user-selector-item input[type=checkbox]{flex-shrink:0}.user-selector-info{display:flex;flex-direction:column;min-width:0}.user-selector-name{font-weight:500;font-size:var(--font-size-sm)}.user-selector-email{font-size:var(--font-size-xs);color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-users-list{display:flex;flex-direction:column;gap:2px}.member-user-tag{font-weight:500}@media (max-width: 640px){.page-header{flex-direction:column;align-items:stretch;gap:var(--spacing-sm)}.page-title{font-size:var(--font-size-xl)}.filters{flex-direction:column}.filter-group{min-width:100%!important}.card-padded{padding:var(--spacing-md)}.table th,.table td{padding:var(--spacing-sm)}.btn{padding:.5rem .75rem}.btn-sm{padding:.25rem .5rem;font-size:.7rem}}.select-container{font-size:var(--font-size-sm)}[data-sonner-toaster]{--normal-bg: var(--color-surface);--normal-text: var(--color-text);--normal-border: var(--color-border);--success-bg: var(--color-success-light);--success-text: var(--color-success-dark);--success-border: #a7f3d0;--error-bg: var(--color-error-light);--error-text: var(--color-error-dark);--error-border: #fecaca;font-family:var(--font-family)}.filters{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);flex-wrap:wrap}.filter-group{min-width:200px}.filter-group .form-group{margin-bottom:0}
