:root{--vt-c-white:#fff;--vt-c-white-soft:#f8f8f8;--vt-c-white-mute:#f2f2f2;--vt-c-black:#181818;--vt-c-black-soft:#222;--vt-c-black-mute:#282828;--vt-c-indigo:#2c3e50;--vt-c-divider-light-1:#3c3c3c4a;--vt-c-divider-light-2:#3c3c3c1f;--vt-c-divider-dark-1:#545454a6;--vt-c-divider-dark-2:#5454547a;--vt-c-text-light-1:var(--vt-c-indigo);--vt-c-text-light-2:#3c3c3ca8;--vt-c-text-dark-1:var(--vt-c-white);--vt-c-text-dark-2:#ebebeba3;--color-background:var(--vt-c-white);--color-background-soft:var(--vt-c-white-soft);--color-background-mute:var(--vt-c-white-mute);--color-border:var(--vt-c-divider-light-2);--color-border-hover:var(--vt-c-divider-light-1);--color-heading:var(--vt-c-text-light-1);--color-text:var(--vt-c-text-light-1);--section-gap:160px}@media (prefers-color-scheme:dark){:root{--color-background:var(--vt-c-black);--color-background-soft:var(--vt-c-black-soft);--color-background-mute:var(--vt-c-black-mute);--color-border:var(--vt-c-divider-dark-2);--color-border-hover:var(--vt-c-divider-dark-1);--color-heading:var(--vt-c-text-dark-1);--color-text:var(--vt-c-text-dark-2)}}*,:before,:after{box-sizing:border-box;margin:0;font-weight:400}body{min-height:100vh;color:var(--color-text);background:var(--color-background);text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:15px;line-height:1.6;transition:color .5s,background-color .5s}#app{font-weight:400}:root{--color-primary:#e73389;--color-primary-dark:#e73389;--color-primary-light:#fdf1f6;--color-secondary:#4a7ba7;--color-secondary-dark:#2a5298;--color-secondary-light:#1e3c721a;--color-accent:#2f5597;--color-success:#28a745;--color-success-bg:#eee;--color-success-border:#c3e6cb;--color-success-text:#155724;--color-error:#dc3545;--color-error-bg:#f8d7da;--color-error-border:#e73389;--color-error-text:#721c24;--color-warning:#ffc107;--color-warning-bg:#fff3cd;--color-warning-border:#ffeaa7;--color-warning-text:#856404;--color-info:#17a2b8;--color-info-bg:#d1ecf1;--color-info-border:#bee5eb;--color-info-text:#0c5460;--color-text:#2f2f2f;--color-text-light:#666;--color-text-dark:#2f2f2f;--color-text-muted:#999;--color-bg-gray:#f9f9f9;--color-bg-light:#f5f5f5;--color-border:#ddd;--color-border-light:#e0e0e0;--color-border-input:#e73389;--color-gradient-peach:linear-gradient(90deg, #f5e6e0 0%, #f0d9d1 100%);--color-gradient-pink:linear-gradient(90deg, #e85d9f 0%, #ff69b4 100%);--color-gradient-primary:linear-gradient(135deg, #e73389 0%, #d63a89 100%);--color-gradient-secondary:linear-gradient(135deg, #1e3c72 0%, #2a5298 100%);--color-panel-bg:white;--color-header-bg:#fdf1f6;--color-footer-bg:#3d3d3d;--shadow-sm:0 1px 3px #0000001a;--shadow-md:0 4px 12px #00000026;--shadow-lg:0 10px 40px #0000001a;--radius-sm:4px;--radius-md:6px;--radius-lg:12px;--radius-pill:20px}.flex{display:flex}.flex-row{flex-direction:row;display:flex}.flex-column{flex-direction:column;display:flex}.flex-center{justify-content:center;align-items:center;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.flex-align-center{align-items:center;display:flex}.flex-align-start{align-items:flex-start;display:flex}.flex-justify-center{justify-content:center;display:flex}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.flex-2{flex:2}.flex-3{flex:3}.grid{display:grid}.grid-2{grid-template-columns:repeat(2,1fr);display:grid}.grid-3{grid-template-columns:repeat(3,1fr);display:grid}.grid-4{grid-template-columns:repeat(4,1fr);display:grid}.gap-xs{gap:4px}.gap-sm{gap:8px}.gap-md{gap:12px}.gap-lg{gap:16px}.gap-xl{gap:20px}.gap-2xl{gap:40px}.p-0{padding:0}.p-xs{padding:6px}.p-sm{padding:12px}.p-md{padding:20px}.p-lg{padding:30px}.p-xl{padding:40px}.m-0{margin:0}.mb-xs{margin-bottom:6px}.mb-sm{margin-bottom:12px}.mb-md{margin-bottom:20px}.mb-lg{margin-bottom:30px}.mb-xl{margin-bottom:40px}.mt-xs{margin-top:6px}.mt-sm{margin-top:12px}.mt-md{margin-top:20px}.mt-lg{margin-top:30px}.ml-auto{margin-left:auto}.mr-auto{margin-right:auto}.w-full{width:100%}.w-auto{width:auto}.max-w-xs{max-width:320px}.max-w-sm{max-width:420px}.max-w-md{max-width:600px}.max-w-lg{max-width:800px}.h-full{height:100%}.min-h-screen{min-height:100vh}.details-grid{flex-direction:column;gap:.5rem;display:flex}.detail-row{grid-template-columns:150px 1fr;gap:1rem;display:grid}.detail-row .label{color:#666;font-weight:500}.detail-row .value{color:#e91e8c;font-weight:500}.text-xs{font-size:11px}.text-sm{font-size:12px}.text-base{font-size:14px}.text-md{font-size:16px}.text-lg{font-size:18px}.text-xl{font-size:20px}.text-2xl{font-size:24px}.text-3xl{font-size:32px}.text-4xl{font-size:48px}.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-uppercase{text-transform:uppercase}.letter-spacing-sm{letter-spacing:.5px}.letter-spacing-md{letter-spacing:1px}.line-height-normal{line-height:1.4}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-secondary)}.text-muted{color:var(--color-text-muted)}.text-light{color:var(--color-text-light)}.text-white{color:#fff}.heading{color:var(--color-primary-dark);font-size:14px;font-weight:600}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:#333;font-size:14px;font-weight:600}.form-input,.form-textarea{border:1px solid var(--color-border-input);border-radius:var(--radius-md);color:var(--color-text);background:#fff;padding:10px 14px;font-family:inherit;font-size:14px;transition:all .3s}.form-input:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light);outline:none}.form-input:disabled,.form-textarea:disabled{color:var(--color-text-light);cursor:not-allowed;border-color:var(--color-border);background:#f8f9fa}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-muted)}.form-textarea{resize:vertical;min-height:80px}.form-error{color:var(--color-error);margin-top:4px;font-size:13px}.form-hint{color:var(--color-text-light);margin-top:4px;font-size:12px}.form-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;display:grid}.form-checkbox{cursor:pointer;color:#495057;align-items:flex-start;gap:8px;font-size:13px;line-height:1.4;display:flex}.form-checkbox input{cursor:pointer;flex-shrink:0;margin-top:4px}.form-input-primary{border:2px solid var(--color-primary)}.form-input-primary:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.btn{border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:600;text-decoration:none;transition:all .3s;display:inline-flex}.btn:disabled{opacity:.7;cursor:not-allowed}.btn-primary{color:var(--color-primary-dark);background:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #e85d9f4d}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{color:var(--color-primary-dark);background:#fff}.btn-secondary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #1e3c724d}.btn-secondary:active:not(:disabled){transform:translateY(0)}.btn-outline{border:2px solid var(--color-primary);color:var(--color-primary);background:0 0}.btn-outline:hover:not(:disabled){background:var(--color-primary);color:#fff}.btn-ghost{color:var(--color-primary);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--color-primary-light)}.btn-icon{background:var(--color-bg-light);border-radius:var(--radius-sm);cursor:pointer;border:none;width:32px;height:32px;padding:6px;font-size:16px;transition:all .2s}.btn-icon:hover{background:var(--color-border-light)}.btn-sm{padding:6px 12px;font-size:12px}.btn-md{padding:10px 16px;font-size:14px}.btn-lg{padding:12px 20px;font-size:16px}.btn-large{width:100%;padding:12px 16px;font-size:16px}.btn-close{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;padding:0;font-size:24px;transition:color .2s}.btn-close:hover{color:var(--color-text)}.select-input{border:2px solid var(--color-primary-dark);color:var(--color-primary-dark);background:#fff;border-radius:16px;align-items:center;gap:12px;padding:6px 14px;font-size:13px;display:inline-flex}.radio-dot-group{flex-direction:column;align-items:center;gap:10px;display:inline-flex}.radio-dot{appearance:none;border:2px solid var(--color-primary-dark);cursor:pointer;background:0 0;border-radius:50%;width:16px;height:16px;margin:0;transition:background-color .2s,box-shadow .2s}.radio-dot:checked{background:var(--color-primary-dark)}.radio-dot:focus-visible{box-shadow:0 0 0 3px var(--color-primary-light);outline:none}.radio-box{border:2px solid var(--color-primary);background:0 0;border-radius:2px;flex:none;width:16px;height:16px}.radio-box.filled{background:var(--color-primary-dark)}.alert{border-radius:var(--radius-md);border:1px solid #0000;align-items:center;gap:10px;margin-bottom:20px;padding:12px 16px;font-size:14px;display:flex}.alert-error{background:var(--color-error-bg);border-color:var(--color-error-border);color:var(--color-error-text)}.alert-success{background:var(--color-success-bg);border-color:var(--color-success-border);color:var(--color-success-text)}.alert-warning{background:var(--color-warning-bg);border-color:var(--color-warning-border);color:var(--color-warning-text)}.alert-info{background:var(--color-info-bg);border-color:var(--color-info-border);color:var(--color-info-text)}.alert-icon{flex-shrink:0;font-size:16px}.alert-close{color:inherit;cursor:pointer;opacity:.7;background:0 0;border:none;flex-shrink:0;margin-left:auto;padding:0;font-size:20px}.alert-close:hover{opacity:1}.panel{border-radius:var(--radius-md);border:1px solid var(--color-border);flex-direction:column;height:100%;margin:10px;padding:20px;display:flex}.panel h1{color:var(--color-primary-dark);margin:0 0 1.5rem;font-size:1.5rem;font-weight:600}.panel h2{color:var(--color-primary-dark);font-size:1.25rem;font-weight:600}.panel h3{color:var(--color-primary-dark);font-size:1rem;font-weight:600}.panel::-webkit-scrollbar{width:8px}.panel::-webkit-scrollbar-track{background:var(--color-bg-light);border-radius:4px}.panel::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.panel::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.card{border-radius:var(--radius-md);box-shadow:var(--shadow-sm);background:#fdf1f6;padding:20px}.card-lg{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);background:#fff;padding:40px}.card-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.card-actions{gap:10px;display:flex}.card h1{color:var(--color-primary-dark);font-size:1.5rem;font-weight:600}a,.link{color:var(--color-secondary);text-decoration:none;transition:color .2s}a:hover,.link:hover{color:var(--color-primary-dark);text-decoration:underline}.link-primary{color:var(--color-primary);font-weight:600;text-decoration:none;transition:color .2s}.link-primary:hover{color:var(--color-primary-dark);text-decoration:underline}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.divider{text-align:center;margin:20px 0;position:relative}.divider:before{content:"";background:var(--color-border);height:1px;position:absolute;top:50%;left:0;right:0}.divider span{color:var(--color-text-muted);background:#fff;padding:0 16px;font-size:13px;position:relative}.page-header{border-radius:var(--radius-sm);justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.page-header h1{color:var(--color-primary-dark);margin:0;font-size:2rem;font-weight:600}.page-description{color:var(--color-text-light);max-width:720px;margin:.35rem 0 0}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);background:#fff;width:100%;max-width:600px;max-height:90vh;padding:30px;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-header h2{margin:0;font-size:20px;font-weight:600}@media (width<=768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.header[data-v-4c49ba1d]{background:var(--color-header-bg);border-bottom:1px solid var(--color-border-light);box-shadow:var(--shadow-sm);z-index:100;width:100%;position:sticky;top:0}.header-container[data-v-4c49ba1d]{justify-content:space-between;align-items:center;padding:0;display:flex;position:relative}.vessel-center[data-v-4c49ba1d]{z-index:1;gap:8px;position:absolute;left:50%;transform:translate(-50%)}.nav-menu[data-v-4c49ba1d]{flex-direction:column;align-items:flex-start;width:auto;display:flex;position:relative}.nav-items[data-v-4c49ba1d]{align-items:center;gap:0;height:70px;display:flex}.nav-item[data-v-4c49ba1d]{color:var(--color-primary-dark);cursor:pointer;align-items:center;width:120px;height:100%;padding:0 20px;font-size:15px;font-weight:500;text-decoration:none;display:flex}.submenu-container[data-v-4c49ba1d]{background:var(--color-header-bg);z-index:50;flex-direction:row;align-items:flex-start;width:100vw;display:flex;position:absolute;top:70px;left:0}.submenu-enter-active[data-v-4c49ba1d],.submenu-leave-active[data-v-4c49ba1d]{max-height:300px;transition:max-height .5s;overflow:hidden}.submenu-enter-from[data-v-4c49ba1d],.submenu-leave-to[data-v-4c49ba1d]{max-height:0;overflow:hidden}.submenu-content[data-v-4c49ba1d]{flex-direction:column;width:120px;padding:0 20px;display:flex}.submenu-item[data-v-4c49ba1d]{color:var(--color-text-dark);padding:8px 0;font-size:15px;text-decoration:none;display:block}.submenu-item[data-v-4c49ba1d]:hover{color:var(--color-primary-dark);text-decoration:underline}.header-actions[data-v-4c49ba1d]{align-items:center;gap:12px;padding-right:12px;display:flex}.btn-logout[data-v-4c49ba1d]{border:1px solid var(--color-border-light);color:var(--color-text);cursor:pointer;background:0 0;border-radius:16px;padding:6px 12px;font-size:12px;font-weight:600;transition:all .2s}.btn-logout[data-v-4c49ba1d]:hover{background:var(--color-primary-light);border-color:var(--color-primary)}.vessel-name[data-v-4c49ba1d]{color:var(--color-primary-dark);letter-spacing:.5px;padding-left:12px;font-size:14px;font-weight:600}.backdrop[data-v-4c49ba1d]{background:color-mix(in srgb, var(--color-text) 30%, transparent);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:40;pointer-events:auto;position:fixed;inset:0}.backdrop-enter-active[data-v-4c49ba1d],.backdrop-leave-active[data-v-4c49ba1d]{transition:all .5s}.backdrop-enter-from[data-v-4c49ba1d],.backdrop-leave-to[data-v-4c49ba1d]{opacity:0;-webkit-backdrop-filter:blur();backdrop-filter:blur()}.social-link[data-v-a98cbfcb]{color:#fff;font-size:18px;transition:color .2s}.social-link[data-v-a98cbfcb]:hover{color:var(--color-primary-dark)}.layout[data-v-a98cbfcb]{background:#fff;flex-direction:column;width:100%;min-height:100vh;display:flex}.layout-body[data-v-a98cbfcb]{flex:1;display:flex}.breadcrumb-wrapper[data-v-a98cbfcb]{background:#fff;border-bottom:1px solid #e8edf3}.breadcrumb[data-v-a98cbfcb]{padding:10px 20px}.breadcrumb-list[data-v-a98cbfcb]{flex-wrap:wrap;align-items:center;gap:6px;margin:0;padding:0;list-style:none;display:flex}.breadcrumb-item[data-v-a98cbfcb]{align-items:center;gap:6px;display:flex}.breadcrumb-link[data-v-a98cbfcb]{color:var(--color-primary-dark);font-size:13px;text-decoration:none}.breadcrumb-link[data-v-a98cbfcb]:hover{color:var(--color-primary-dark)}.breadcrumb-current[data-v-a98cbfcb]{color:var(--color-text-muted);font-size:13px}.breadcrumb-separator[data-v-a98cbfcb]{color:var(--color-text-light);font-size:12px}.main-content[data-v-a98cbfcb]{background:#fff;flex:1;width:100%;overflow-y:auto}.footer[data-v-a98cbfcb]{background:var(--color-footer-bg);color:#fff;text-align:center;border-top:1px solid #2a2a2a;margin-top:auto;padding:10px}.footer a[data-v-a98cbfcb]{color:#fff;text-decoration:none;transition:color .2s}.footer a[data-v-a98cbfcb]:hover{color:var(--color-primary-dark)}.blank-layout[data-v-e0a62de3]{background:var(--color-gradient-secondary);justify-content:center;align-items:center;width:100%;min-height:100vh;display:flex}.error-boundary[data-v-d5e06533]{background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);justify-content:center;align-items:center;width:100%;min-height:100vh;padding:20px;display:flex}.error-content[data-v-d5e06533]{text-align:center;background:#fff;border-radius:12px;max-width:500px;padding:40px;box-shadow:0 10px 40px #0000001a}.error-icon[data-v-d5e06533]{margin-bottom:20px;font-size:64px}.error-title[data-v-d5e06533]{color:#212529;margin:0 0 16px;font-size:24px;font-weight:600}.error-message[data-v-d5e06533]{color:#6c757d;margin:0 0 24px;font-size:14px;line-height:1.6}.error-details[data-v-d5e06533]{text-align:left;background:#f8f9fa;border-radius:6px;max-height:200px;margin:20px 0;padding:12px;overflow-y:auto}.error-details summary[data-v-d5e06533]{cursor:pointer;color:#495057;font-size:13px;font-weight:600}.error-details pre[data-v-d5e06533]{color:#dc3545;white-space:pre-wrap;word-break:break-word;margin:10px 0 0;font-size:11px}.error-actions[data-v-d5e06533]{justify-content:center;gap:12px;margin-top:24px;display:flex}@media (width<=480px){.error-content[data-v-d5e06533]{padding:30px 20px}.error-icon[data-v-d5e06533]{font-size:48px}.error-title[data-v-d5e06533]{font-size:20px}.error-actions[data-v-d5e06533]{flex-direction:column}}*{box-sizing:border-box;margin:0;padding:0}html,body,#app{width:100%;height:100vh}body{color:#212529;background:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:14px;line-height:1.6}input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{appearance:textfield}.app-container{flex-direction:column;width:100%;min-height:100vh;display:flex}.app-container>:first-child{flex:1}.login-page[data-v-ef494b69]{background:var(--color-gradient-peach);flex-direction:column;width:100%;display:flex}.login-content[data-v-ef494b69]{flex-direction:column;flex:1;justify-content:center;align-items:center;padding:40px 20px;display:flex}.logo-section[data-v-ef494b69]{text-align:center;margin-bottom:40px}.logo-text[data-v-ef494b69]{color:var(--color-text);letter-spacing:-.5px;margin:0 0 10px;font-size:48px;font-weight:700}.logo-accent[data-v-ef494b69]{color:var(--color-primary);font-style:italic}.logo-subtitle[data-v-ef494b69]{color:var(--color-primary);letter-spacing:1px;margin:0;font-size:14px;font-weight:500}.login-title[data-v-ef494b69]{color:var(--color-primary);text-align:center;margin:0 0 30px;font-size:20px;font-weight:600}.forgot-section[data-v-ef494b69]{text-align:right;margin-top:8px;margin-bottom:16px}.forgot-password[data-v-ef494b69]{color:var(--color-secondary);font-size:13px;text-decoration:none}.forgot-password[data-v-ef494b69]:hover{text-decoration:underline}.register-link[data-v-ef494b69]{text-align:center;color:var(--color-text-light);margin:0;font-size:13px}@media (width<=480px){.login-content[data-v-ef494b69]{padding:30px 20px}.logo-text[data-v-ef494b69]{font-size:36px}}
