.sidebar{background:var(--bg-sidebar);display:flex;flex-direction:column;height:100vh;left:0;overflow-y:auto;position:fixed;top:0;width:var(--sidebar-width);z-index:100}.sidebar-brand{align-items:center;display:flex;gap:var(--space-3);padding:var(--space-6) var(--space-6) var(--space-8)}.sidebar-brand-icon{color:var(--color-blue-400);font-size:var(--text-xl)}.sidebar-brand-text{color:var(--color-white);font-size:var(--text-lg);font-weight:var(--font-bold);letter-spacing:-.02em}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:var(--space-1);padding:0 var(--space-3)}.sidebar-link{align-items:center;background:none;border:none;border-radius:var(--radius-md);color:var(--color-navy-400);cursor:pointer;display:flex;font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--font-medium);gap:var(--space-3);padding:var(--space-3) var(--space-4);text-decoration:none;transition:all var(--transition-fast);width:100%}.sidebar-link:hover{background:#ffffff0f;color:var(--color-navy-200)}.sidebar-link.active{background:#3b82f626;color:var(--color-blue-400)}.sidebar-link-icon{flex-shrink:0;text-align:center;width:18px}.sidebar-footer{border-top:1px solid #ffffff14;margin-top:auto;padding:var(--space-4) var(--space-3)}@media (max-width:768px){.sidebar{transform:translateX(-100%)}}.login-page{align-items:center;background:linear-gradient(135deg,var(--color-navy-900) 0,var(--color-navy-800) 100%);display:flex;justify-content:center;min-height:100vh}.login-card{border:none;box-shadow:var(--shadow-lg);margin:var(--space-4);max-width:420px;width:100%}.login-card form{padding:0 var(--space-8) var(--space-8)}.login-header{padding:var(--space-10) var(--space-8) var(--space-6);text-align:center}.login-logo{color:var(--primary);font-size:2rem;margin-bottom:var(--space-4)}.login-header h1{font-size:var(--text-2xl);margin-bottom:var(--space-2)}.login-header p{color:var(--text-secondary);font-size:var(--text-sm)}.login-btn{font-size:var(--text-base);justify-content:center;margin-top:var(--space-2);padding:var(--space-3) var(--space-5);width:100%}.login-error{background:var(--danger-light);border-radius:var(--radius-md);color:var(--color-red-600);font-size:var(--text-sm);margin-bottom:var(--space-5);padding:var(--space-3) var(--space-4)}.loading-screen{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#f1f5f9cc;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.loading-content{align-items:center;color:var(--primary);display:flex;flex-direction:column;gap:var(--space-4)}.loading-content p{color:var(--text-secondary);font-size:var(--text-sm)}.pagination{display:flex;gap:var(--space-1);margin-top:var(--space-8);padding:var(--space-4) 0}.pagination,.pagination-button{align-items:center;justify-content:center}.pagination-button{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);display:inline-flex;font-size:var(--text-sm);font-weight:var(--font-medium);height:36px;min-width:36px;padding:0 var(--space-3);transition:all var(--transition-fast)}.pagination-button:hover:not(:disabled):not(.active){background:var(--bg-hover);border-color:var(--color-navy-300);color:var(--text-primary)}.pagination-button.active{background:var(--primary);border-color:var(--primary);color:var(--text-on-primary)}.pagination-button:disabled{cursor:not-allowed;opacity:.4}.nav-button{min-width:36px}.modules-grid{grid-gap:var(--space-5);display:grid;gap:var(--space-5);grid-template-columns:repeat(auto-fill,minmax(360px,1fr))}.module-card{transition:box-shadow var(--transition-fast)}.module-card:hover{box-shadow:var(--shadow-md)}.module-top{align-items:flex-start;display:flex;gap:var(--space-3);justify-content:space-between;margin-bottom:var(--space-2)}.module-name{font-size:var(--text-lg);font-weight:var(--font-semibold);word-break:break-word}.module-sender{color:var(--text-secondary);font-size:var(--text-sm);margin-bottom:var(--space-2)}.module-timestamps{display:flex;gap:var(--space-5);margin-bottom:var(--space-5)}.module-last-scan{align-items:center;color:var(--text-muted);display:flex;font-size:var(--text-xs);gap:var(--space-2)}.module-actions{border-top:1px solid var(--border-color);display:flex;flex-wrap:wrap;gap:var(--space-2);padding-top:var(--space-4)}@media (max-width:768px){.modules-grid{grid-template-columns:1fr}.module-actions{flex-direction:column}.module-actions .btn{justify-content:center;width:100%}}.toggle-switch label{align-items:center;color:var(--text-primary)!important;cursor:pointer;display:inline-flex;font-size:var(--text-base)!important;font-weight:var(--font-normal)!important;gap:var(--space-3)}.toggle-switch input[type=checkbox]{display:none}.toggle-switch .slider{background:var(--color-navy-300);border-radius:var(--radius-full);display:inline-block;flex-shrink:0;height:24px;position:relative;transition:background var(--transition-fast);width:44px}.toggle-switch .slider:before{background:var(--color-white);border-radius:50%;box-shadow:var(--shadow-xs);content:"";height:20px;left:2px;position:absolute;top:2px;transition:transform var(--transition-fast);width:20px}.toggle-switch input:checked+.slider{background:var(--primary)}.toggle-switch input:checked+.slider:before{transform:translateX(20px)}.module-form .form-row{grid-gap:var(--space-5);display:grid;gap:var(--space-5);grid-template-columns:1fr 1fr}.form-actions{border-top:1px solid var(--border-color);display:flex;gap:var(--space-3);margin-top:var(--space-6);padding-top:var(--space-4)}@media (max-width:768px){.module-form .form-row{grid-template-columns:1fr}}.overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a80;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal{background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-width:480px;outline:none;width:calc(100% - var(--space-8))}.modal-body{padding:var(--space-8);position:relative}.modal-body h2{margin-bottom:var(--space-4)}.modal-body p{color:var(--text-secondary);margin-bottom:var(--space-3)}.close-button{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:var(--text-2xl);line-height:1;padding:var(--space-1);position:absolute;right:var(--space-4);top:var(--space-4)}.close-button:hover{color:var(--text-primary)}.modal-body>button:last-child{margin-top:var(--space-5)}body.react-confirm-alert-body-element{overflow:hidden}.react-confirm-alert-blur{filter:url(#gaussian-blur);filter:blur(2px);-webkit-filter:blur(2px)}.react-confirm-alert-overlay{-ms-align-items:center;align-items:center;animation:react-confirm-alert-fadeIn .5s .2s forwards;background:#ffffffe6;bottom:0;display:-moz-flex;display:-ms-flex;display:-o-flex;display:flex;justify-content:center;left:0;opacity:0;position:fixed;right:0;top:0;z-index:99}.react-confirm-alert-body{background:#fff;border-radius:10px;box-shadow:0 20px 75px #00000021;color:#666;font-family:Arial,Helvetica,sans-serif;padding:30px;text-align:left;width:400px}.react-confirm-alert-svg{left:0;position:absolute;top:0}.react-confirm-alert-body>h1{margin-top:0}.react-confirm-alert-body>h3{font-size:16px;margin:0}.react-confirm-alert-button-group{display:-moz-flex;display:-ms-flex;display:-o-flex;justify-content:flex-start;margin-top:20px}.react-confirm-alert-button-group>button{background:#333;border:none;border-radius:5px;color:#eee;cursor:pointer;display:inline-block;font-size:12px;margin-right:10px;outline:none;padding:6px 18px}@keyframes react-confirm-alert-fadeIn{0%{opacity:0}to{opacity:1}}.dropzone{align-items:center;background:var(--bg-card);border:2px dashed var(--border-input);border-radius:var(--radius-lg);cursor:pointer;display:flex;flex-direction:column;justify-content:center;margin-bottom:var(--space-6);padding:var(--space-10);transition:all var(--transition-fast)}.dropzone:hover{background:var(--primary-light);border-color:var(--primary)}.dropzone p{color:var(--text-secondary);margin:0}.dropzone .plus-button{background:none;color:var(--text-muted);font-size:var(--text-2xl);margin-top:var(--space-3)}.dropzone.uploading{opacity:.6;pointer-events:none}.search-row-emails{display:flex;gap:var(--space-4);margin-bottom:var(--space-6)}.search-row-emails>div{flex:1 1}.imported-vessels{margin-top:var(--space-6)}.imported-vessels h3,.vessel-card{margin-bottom:var(--space-5)}.vessel-card{overflow:hidden}.vessel-card-header{align-items:center;background:var(--color-navy-50);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:var(--space-4) var(--space-6)}.vessel-card-header h4{font-size:var(--text-base);margin:0}.vessel-card-table{overflow-x:auto}.vessel-card-table table{margin:0}.vessel-card-table th{background:#0000}.vessel-card-table td{vertical-align:middle}.vessel-card-table td:first-child,.vessel-card-table th:first-child{width:50%}.vessel-card-table td:nth-child(2),.vessel-card-table th:nth-child(2){width:15%}.vessel-card-table td:nth-child(3),.vessel-card-table th:nth-child(3){width:35%}.vessel-card-table input[type=text],.vessel-card-table select{font-size:var(--text-sm);padding:var(--space-2) var(--space-3)}.row-actions{display:flex;flex-wrap:wrap;gap:var(--space-2)}.row-action-danger{color:var(--danger)!important}.row-action-danger:hover{background:var(--danger-light)!important;color:var(--color-red-600)!important}.vessel-card-footer{border-top:1px solid var(--border-color);padding:var(--space-3) var(--space-6)}.loader-container{display:flex;justify-content:center;padding:var(--space-8)}.loader{animation:spin .8s linear infinite;border-radius:50%;border-top:3px solid var(--border-color);border:3px solid var(--border-color);border-top-color:var(--primary);height:32px;width:32px}@keyframes spin{to{transform:rotate(1turn)}}.upload-status{color:var(--text-secondary);font-size:var(--text-sm);margin-top:var(--space-3)}.react-confirm-alert-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a80}.react-confirm-alert{background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:var(--space-8);text-align:center}.react-confirm-alert-button-group{display:flex;gap:var(--space-3);justify-content:center;margin-top:var(--space-6)}.react-confirm-alert-button-group button{border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);padding:var(--space-3) var(--space-5)}.react-confirm-alert-button-group button:first-child{background:var(--danger);color:var(--text-on-primary)}.react-confirm-alert-button-group button:last-child{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-primary)}@media (max-width:768px){.row-actions,.search-row-emails{flex-direction:column}.row-actions .btn{justify-content:center;width:100%}}.home-welcome{padding:var(--space-12) 0 var(--space-10);text-align:center}.home-welcome-icon{color:var(--primary);font-size:2.5rem;margin-bottom:var(--space-5)}.home-welcome h1{margin-bottom:var(--space-3)}.home-welcome-sub{color:var(--text-secondary);font-size:var(--text-lg)}.home-grid{grid-gap:var(--space-6);display:grid;gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin:0 auto;max-width:960px}.home-card{text-decoration:none;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.home-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.home-card-icon{align-items:center;background:var(--primary-light);border-radius:var(--radius-lg);color:var(--primary);display:flex;font-size:var(--text-xl);height:48px;justify-content:center;margin-bottom:var(--space-4);width:48px}.home-card h3{color:var(--text-primary);margin-bottom:var(--space-2)}.home-card p{color:var(--text-secondary);font-size:var(--text-sm);line-height:var(--leading-normal)}.ports-grid{grid-gap:var(--space-5);display:grid;gap:var(--space-5);grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.port-card,.port-card .card-body{display:flex;flex-direction:column;gap:var(--space-2)}.port-card .card-body{height:100%}.port-card h3{font-size:var(--text-lg);margin:0}.port-code{color:var(--text-secondary);font-family:var(--font-mono);font-size:var(--text-sm);margin:0}.port-timestamps{display:flex;flex-direction:column;gap:var(--space-1)}.port-scan-time{align-items:center;color:var(--text-muted);display:flex;font-size:var(--text-xs);gap:var(--space-2);margin:0}.port-card .btn{margin-top:auto}.no-ports-message{color:var(--text-secondary);grid-column:1/-1;padding:var(--space-10);text-align:center}.search-box-wrapper{margin-bottom:var(--space-5);max-width:400px}@media (max-width:768px){.ports-grid{grid-template-columns:1fr}}

/*!
 * Quill Editor v1.3.7
 * https://quilljs.com/
 * Copyright (c) 2014, Jason Chen
 * Copyright (c) 2013, salesforce.com
 */.ql-container{box-sizing:border-box;font-family:Helvetica,Arial,sans-serif;font-size:13px;height:100%;margin:0;position:relative}.ql-container.ql-disabled .ql-tooltip{visibility:hidden}.ql-container.ql-disabled .ql-editor ul[data-checked]>li:before{pointer-events:none}.ql-clipboard{height:1px;left:-100000px;overflow-y:hidden;position:absolute;top:50%}.ql-clipboard p{margin:0;padding:0}.ql-editor{word-wrap:break-word;box-sizing:border-box;height:100%;line-height:1.42;outline:none;overflow-y:auto;padding:12px 15px;tab-size:4;-moz-tab-size:4;text-align:left;white-space:pre-wrap}.ql-editor>*{cursor:text}.ql-editor blockquote,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6,.ql-editor ol,.ql-editor p,.ql-editor pre,.ql-editor ul{counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9;margin:0;padding:0}.ql-editor ol,.ql-editor ul{padding-left:1.5em}.ql-editor ol>li,.ql-editor ul>li{list-style-type:none}.ql-editor ul>li:before{content:"\2022"}.ql-editor ul[data-checked=false],.ql-editor ul[data-checked=true]{pointer-events:none}.ql-editor ul[data-checked=false]>li *,.ql-editor ul[data-checked=true]>li *{pointer-events:all}.ql-editor ul[data-checked=false]>li:before,.ql-editor ul[data-checked=true]>li:before{color:#777;cursor:pointer;pointer-events:all}.ql-editor ul[data-checked=true]>li:before{content:"\2611"}.ql-editor ul[data-checked=false]>li:before{content:"\2610"}.ql-editor li:before{display:inline-block;white-space:nowrap;width:1.2em}.ql-editor li:not(.ql-direction-rtl):before{margin-left:-1.5em;margin-right:.3em;text-align:right}.ql-editor li.ql-direction-rtl:before{margin-left:.3em;margin-right:-1.5em}.ql-editor ol li:not(.ql-direction-rtl),.ql-editor ul li:not(.ql-direction-rtl){padding-left:1.5em}.ql-editor ol li.ql-direction-rtl,.ql-editor ul li.ql-direction-rtl{padding-right:1.5em}.ql-editor ol li{counter-increment:list-0;counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li:before{content:counter(list-0,decimal) ". "}.ql-editor ol li.ql-indent-1{counter-increment:list-1}.ql-editor ol li.ql-indent-1:before{content:counter(list-1,lower-alpha) ". "}.ql-editor ol li.ql-indent-1{counter-reset:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-2{counter-increment:list-2}.ql-editor ol li.ql-indent-2:before{content:counter(list-2,lower-roman) ". "}.ql-editor ol li.ql-indent-2{counter-reset:list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-3{counter-increment:list-3}.ql-editor ol li.ql-indent-3:before{content:counter(list-3,decimal) ". "}.ql-editor ol li.ql-indent-3{counter-reset:list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-4{counter-increment:list-4}.ql-editor ol li.ql-indent-4:before{content:counter(list-4,lower-alpha) ". "}.ql-editor ol li.ql-indent-4{counter-reset:list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-5{counter-increment:list-5}.ql-editor ol li.ql-indent-5:before{content:counter(list-5,lower-roman) ". "}.ql-editor ol li.ql-indent-5{counter-reset:list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-6{counter-increment:list-6}.ql-editor ol li.ql-indent-6:before{content:counter(list-6,decimal) ". "}.ql-editor ol li.ql-indent-6{counter-reset:list-7 list-8 list-9}.ql-editor ol li.ql-indent-7{counter-increment:list-7}.ql-editor ol li.ql-indent-7:before{content:counter(list-7,lower-alpha) ". "}.ql-editor ol li.ql-indent-7{counter-reset:list-8 list-9}.ql-editor ol li.ql-indent-8{counter-increment:list-8}.ql-editor ol li.ql-indent-8:before{content:counter(list-8,lower-roman) ". "}.ql-editor ol li.ql-indent-8{counter-reset:list-9}.ql-editor ol li.ql-indent-9{counter-increment:list-9}.ql-editor ol li.ql-indent-9:before{content:counter(list-9,decimal) ". "}.ql-editor .ql-indent-1:not(.ql-direction-rtl){padding-left:3em}.ql-editor li.ql-indent-1:not(.ql-direction-rtl){padding-left:4.5em}.ql-editor .ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:3em}.ql-editor li.ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:4.5em}.ql-editor .ql-indent-2:not(.ql-direction-rtl){padding-left:6em}.ql-editor li.ql-indent-2:not(.ql-direction-rtl){padding-left:7.5em}.ql-editor .ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:6em}.ql-editor li.ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:7.5em}.ql-editor .ql-indent-3:not(.ql-direction-rtl){padding-left:9em}.ql-editor li.ql-indent-3:not(.ql-direction-rtl){padding-left:10.5em}.ql-editor .ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:9em}.ql-editor li.ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:10.5em}.ql-editor .ql-indent-4:not(.ql-direction-rtl){padding-left:12em}.ql-editor li.ql-indent-4:not(.ql-direction-rtl){padding-left:13.5em}.ql-editor .ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:12em}.ql-editor li.ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:13.5em}.ql-editor .ql-indent-5:not(.ql-direction-rtl){padding-left:15em}.ql-editor li.ql-indent-5:not(.ql-direction-rtl){padding-left:16.5em}.ql-editor .ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:15em}.ql-editor li.ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:16.5em}.ql-editor .ql-indent-6:not(.ql-direction-rtl){padding-left:18em}.ql-editor li.ql-indent-6:not(.ql-direction-rtl){padding-left:19.5em}.ql-editor .ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:18em}.ql-editor li.ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:19.5em}.ql-editor .ql-indent-7:not(.ql-direction-rtl){padding-left:21em}.ql-editor li.ql-indent-7:not(.ql-direction-rtl){padding-left:22.5em}.ql-editor .ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:21em}.ql-editor li.ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:22.5em}.ql-editor .ql-indent-8:not(.ql-direction-rtl){padding-left:24em}.ql-editor li.ql-indent-8:not(.ql-direction-rtl){padding-left:25.5em}.ql-editor .ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:24em}.ql-editor li.ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:25.5em}.ql-editor .ql-indent-9:not(.ql-direction-rtl){padding-left:27em}.ql-editor li.ql-indent-9:not(.ql-direction-rtl){padding-left:28.5em}.ql-editor .ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:27em}.ql-editor li.ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:28.5em}.ql-editor .ql-video{display:block;max-width:100%}.ql-editor .ql-video.ql-align-center{margin:0 auto}.ql-editor .ql-video.ql-align-right{margin:0 0 0 auto}.ql-editor .ql-bg-black{background-color:#000}.ql-editor .ql-bg-red{background-color:#e60000}.ql-editor .ql-bg-orange{background-color:#f90}.ql-editor .ql-bg-yellow{background-color:#ff0}.ql-editor .ql-bg-green{background-color:#008a00}.ql-editor .ql-bg-blue{background-color:#06c}.ql-editor .ql-bg-purple{background-color:#93f}.ql-editor .ql-color-white{color:#fff}.ql-editor .ql-color-red{color:#e60000}.ql-editor .ql-color-orange{color:#f90}.ql-editor .ql-color-yellow{color:#ff0}.ql-editor .ql-color-green{color:#008a00}.ql-editor .ql-color-blue{color:#06c}.ql-editor .ql-color-purple{color:#93f}.ql-editor .ql-font-serif{font-family:Georgia,Times New Roman,serif}.ql-editor .ql-font-monospace{font-family:Monaco,Courier New,monospace}.ql-editor .ql-size-small{font-size:.75em}.ql-editor .ql-size-large{font-size:1.5em}.ql-editor .ql-size-huge{font-size:2.5em}.ql-editor .ql-direction-rtl{direction:rtl;text-align:inherit}.ql-editor .ql-align-center{text-align:center}.ql-editor .ql-align-justify{text-align:justify}.ql-editor .ql-align-right{text-align:right}.ql-editor.ql-blank:before{color:#0009;content:attr(data-placeholder);font-style:italic;left:15px;pointer-events:none;position:absolute;right:15px}.ql-snow .ql-toolbar:after,.ql-snow.ql-toolbar:after{clear:both;content:"";display:table}.ql-snow .ql-toolbar button,.ql-snow.ql-toolbar button{background:none;border:none;cursor:pointer;display:inline-block;float:left;height:24px;padding:3px 5px;width:28px}.ql-snow .ql-toolbar button svg,.ql-snow.ql-toolbar button svg{float:left;height:100%}.ql-snow .ql-toolbar button:active:hover,.ql-snow.ql-toolbar button:active:hover{outline:none}.ql-snow .ql-toolbar input.ql-image[type=file],.ql-snow.ql-toolbar input.ql-image[type=file]{display:none}.ql-snow .ql-toolbar .ql-picker-item.ql-selected,.ql-snow .ql-toolbar .ql-picker-item:hover,.ql-snow .ql-toolbar .ql-picker-label.ql-active,.ql-snow .ql-toolbar .ql-picker-label:hover,.ql-snow .ql-toolbar button.ql-active,.ql-snow .ql-toolbar button:focus,.ql-snow .ql-toolbar button:hover,.ql-snow.ql-toolbar .ql-picker-item.ql-selected,.ql-snow.ql-toolbar .ql-picker-item:hover,.ql-snow.ql-toolbar .ql-picker-label.ql-active,.ql-snow.ql-toolbar .ql-picker-label:hover,.ql-snow.ql-toolbar button.ql-active,.ql-snow.ql-toolbar button:focus,.ql-snow.ql-toolbar button:hover{color:#06c}.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:focus .ql-fill,.ql-snow .ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover .ql-fill,.ql-snow .ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:focus .ql-fill,.ql-snow.ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:hover .ql-fill,.ql-snow.ql-toolbar button:hover .ql-stroke.ql-fill{fill:#06c}.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow .ql-toolbar button.ql-active .ql-stroke,.ql-snow .ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar button:focus .ql-stroke,.ql-snow .ql-toolbar button:focus .ql-stroke-miter,.ql-snow .ql-toolbar button:hover .ql-stroke,.ql-snow .ql-toolbar button:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow.ql-toolbar button.ql-active .ql-stroke,.ql-snow.ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar button:focus .ql-stroke,.ql-snow.ql-toolbar button:focus .ql-stroke-miter,.ql-snow.ql-toolbar button:hover .ql-stroke,.ql-snow.ql-toolbar button:hover .ql-stroke-miter{stroke:#06c}@media (pointer:coarse){.ql-snow .ql-toolbar button:hover:not(.ql-active),.ql-snow.ql-toolbar button:hover:not(.ql-active){color:#444}.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter{stroke:#444}}.ql-snow,.ql-snow *{box-sizing:border-box}.ql-snow .ql-hidden{display:none}.ql-snow .ql-out-bottom,.ql-snow .ql-out-top{visibility:hidden}.ql-snow .ql-tooltip{position:absolute;transform:translateY(10px)}.ql-snow .ql-tooltip a{cursor:pointer;text-decoration:none}.ql-snow .ql-tooltip.ql-flip{transform:translateY(-10px)}.ql-snow .ql-formats{display:inline-block;vertical-align:middle}.ql-snow .ql-formats:after{clear:both;content:"";display:table}.ql-snow .ql-stroke{fill:none;stroke:#444;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.ql-snow .ql-stroke-miter{fill:none;stroke:#444;stroke-miterlimit:10;stroke-width:2}.ql-snow .ql-fill,.ql-snow .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-empty{fill:none}.ql-snow .ql-even{fill-rule:evenodd}.ql-snow .ql-stroke.ql-thin,.ql-snow .ql-thin{stroke-width:1}.ql-snow .ql-transparent{opacity:.4}.ql-snow .ql-direction svg:last-child{display:none}.ql-snow .ql-direction.ql-active svg:last-child{display:inline}.ql-snow .ql-direction.ql-active svg:first-child{display:none}.ql-snow .ql-editor h1{font-size:2em}.ql-snow .ql-editor h2{font-size:1.5em}.ql-snow .ql-editor h3{font-size:1.17em}.ql-snow .ql-editor h4{font-size:1em}.ql-snow .ql-editor h5{font-size:.83em}.ql-snow .ql-editor h6{font-size:.67em}.ql-snow .ql-editor a{text-decoration:underline}.ql-snow .ql-editor blockquote{border-left:4px solid #ccc;margin-bottom:5px;margin-top:5px;padding-left:16px}.ql-snow .ql-editor code,.ql-snow .ql-editor pre{background-color:#f0f0f0;border-radius:3px}.ql-snow .ql-editor pre{margin-bottom:5px;margin-top:5px;padding:5px 10px;white-space:pre-wrap}.ql-snow .ql-editor code{font-size:85%;padding:2px 4px}.ql-snow .ql-editor pre.ql-syntax{background-color:#23241f;color:#f8f8f2;overflow:visible}.ql-snow .ql-editor img{max-width:100%}.ql-snow .ql-picker{color:#444;display:inline-block;float:left;font-size:14px;font-weight:500;height:24px;position:relative;vertical-align:middle}.ql-snow .ql-picker-label{cursor:pointer;display:inline-block;height:100%;padding-left:8px;padding-right:2px;position:relative;width:100%}.ql-snow .ql-picker-label:before{display:inline-block;line-height:22px}.ql-snow .ql-picker-options{background-color:#fff;display:none;min-width:100%;padding:4px 8px;position:absolute;white-space:nowrap}.ql-snow .ql-picker-options .ql-picker-item{cursor:pointer;display:block;padding-bottom:5px;padding-top:5px}.ql-snow .ql-picker.ql-expanded .ql-picker-label{color:#ccc;z-index:2}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-fill{fill:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-stroke{stroke:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-options{display:block;margin-top:-1px;top:100%;z-index:1}.ql-snow .ql-color-picker,.ql-snow .ql-icon-picker{width:28px}.ql-snow .ql-color-picker .ql-picker-label,.ql-snow .ql-icon-picker .ql-picker-label{padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-label svg,.ql-snow .ql-icon-picker .ql-picker-label svg{right:4px}.ql-snow .ql-icon-picker .ql-picker-options{padding:4px 0}.ql-snow .ql-icon-picker .ql-picker-item{height:24px;padding:2px 4px;width:24px}.ql-snow .ql-color-picker .ql-picker-options{padding:3px 5px;width:152px}.ql-snow .ql-color-picker .ql-picker-item{border:1px solid #0000;float:left;height:16px;margin:2px;padding:0;width:16px}.ql-snow .ql-picker:not(.ql-color-picker):not(.ql-icon-picker) svg{margin-top:-9px;position:absolute;right:0;top:50%;width:18px}.ql-snow .ql-picker.ql-font .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-label]:not([data-label=""]):before{content:attr(data-label)}.ql-snow .ql-picker.ql-header{width:98px}.ql-snow .ql-picker.ql-header .ql-picker-item:before,.ql-snow .ql-picker.ql-header .ql-picker-label:before{content:"Normal"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]:before{content:"Heading 1"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]:before{content:"Heading 2"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]:before{content:"Heading 3"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]:before{content:"Heading 4"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]:before{content:"Heading 5"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]:before{content:"Heading 6"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{font-size:2em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{font-size:1.5em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{font-size:1.17em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{font-size:1em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{font-size:.83em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{font-size:.67em}.ql-snow .ql-picker.ql-font{width:108px}.ql-snow .ql-picker.ql-font .ql-picker-item:before,.ql-snow .ql-picker.ql-font .ql-picker-label:before{content:"Sans Serif"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=serif]:before{content:"Serif"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=monospace]:before{content:"Monospace"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{font-family:Georgia,Times New Roman,serif}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{font-family:Monaco,Courier New,monospace}.ql-snow .ql-picker.ql-size{width:98px}.ql-snow .ql-picker.ql-size .ql-picker-item:before,.ql-snow .ql-picker.ql-size .ql-picker-label:before{content:"Normal"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=small]:before{content:"Small"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=large]:before{content:"Large"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=huge]:before{content:"Huge"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{font-size:10px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{font-size:18px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{font-size:32px}.ql-snow .ql-color-picker.ql-background .ql-picker-item{background-color:#fff}.ql-snow .ql-color-picker.ql-color .ql-picker-item{background-color:#000}.ql-toolbar.ql-snow{border:1px solid #ccc;box-sizing:border-box;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;padding:8px}.ql-toolbar.ql-snow .ql-formats{margin-right:15px}.ql-toolbar.ql-snow .ql-picker-label{border:1px solid #0000}.ql-toolbar.ql-snow .ql-picker-options{border:1px solid #0000;box-shadow:0 2px 8px #0003}.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label,.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options{border-color:#ccc}.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item.ql-selected,.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item:hover{border-color:#000}.ql-toolbar.ql-snow+.ql-container.ql-snow{border-top:0}.ql-snow .ql-tooltip{background-color:#fff;border:1px solid #ccc;box-shadow:0 0 5px #ddd;color:#444;padding:5px 12px;white-space:nowrap}.ql-snow .ql-tooltip:before{content:"Visit URL:";line-height:26px;margin-right:8px}.ql-snow .ql-tooltip input[type=text]{border:1px solid #ccc;display:none;font-size:13px;height:26px;margin:0;padding:3px 5px;width:170px}.ql-snow .ql-tooltip a.ql-preview{display:inline-block;max-width:200px;overflow-x:hidden;text-overflow:ellipsis;vertical-align:top}.ql-snow .ql-tooltip a.ql-action:after{border-right:1px solid #ccc;content:"Edit";margin-left:16px;padding-right:8px}.ql-snow .ql-tooltip a.ql-remove:before{content:"Remove";margin-left:8px}.ql-snow .ql-tooltip a{line-height:26px}.ql-snow .ql-tooltip.ql-editing a.ql-preview,.ql-snow .ql-tooltip.ql-editing a.ql-remove{display:none}.ql-snow .ql-tooltip.ql-editing input[type=text]{display:inline-block}.ql-snow .ql-tooltip.ql-editing a.ql-action:after{border-right:0;content:"Save";padding-right:0}.ql-snow .ql-tooltip[data-mode=link]:before{content:"Enter link:"}.ql-snow .ql-tooltip[data-mode=formula]:before{content:"Enter formula:"}.ql-snow .ql-tooltip[data-mode=video]:before{content:"Enter video:"}.ql-snow a{color:#06c}.ql-container.ql-snow{border:1px solid #ccc}.messages-list{display:flex;flex-direction:column;gap:var(--space-3)}.message-card-body{align-items:center;display:flex;justify-content:space-between;padding:var(--space-4) var(--space-6)}.editor-toolbar,.message-card-actions{display:flex;gap:var(--space-2)}.editor-toolbar{margin-bottom:var(--space-3)}.html-preview{background:var(--color-navy-50);border:1px solid var(--border-color);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:var(--text-sm);max-height:400px;overflow-y:auto;padding:var(--space-4);white-space:pre-wrap;word-break:break-word}.checkbox-label{align-items:center;color:var(--text-primary);cursor:pointer;display:inline-flex!important;font-size:var(--text-base);gap:var(--space-2)}.checkbox-label input[type=checkbox]{width:auto}.ql-container{border-radius:0 0 var(--radius-md) var(--radius-md);min-height:120px}.ql-toolbar{border-radius:var(--radius-md) var(--radius-md) 0 0}.error-modal{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a80;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1100}.error-modal-content{background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-width:420px;padding:var(--space-8);text-align:center;width:calc(100% - var(--space-8))}.error-modal-content h2{color:var(--danger);margin-bottom:var(--space-4)}.error-modal-content p{color:var(--text-secondary);margin-bottom:var(--space-6)}.arrivals-grid{grid-gap:var(--space-5);display:grid;gap:var(--space-5);grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.arrival-card{transition:box-shadow var(--transition-fast)}.arrival-card:hover{box-shadow:var(--shadow-md)}.arrival-header{border-bottom:1px solid var(--border-color);margin-bottom:var(--space-4);padding-bottom:var(--space-3)}.arrival-header h3{align-items:center;display:flex;font-size:var(--text-lg);gap:var(--space-2);margin:0}.imo{color:var(--text-secondary);display:block;font-family:var(--font-mono);font-size:var(--text-sm);margin-top:var(--space-1)}.arrival-details{display:flex;flex-direction:column;gap:var(--space-2)}.arrival-details p{align-items:center;color:var(--text-secondary);display:flex;font-size:var(--text-sm);gap:var(--space-2);margin:0}.arrival-details p strong{color:var(--text-primary)}.arrival-details .icon{color:var(--text-muted);flex-shrink:0;width:16px}.days-selector{align-items:center;display:flex;gap:var(--space-3)}.days-selector label{margin:0;white-space:nowrap}.days-selector .days-select{min-width:140px;width:auto}.no-arrivals-message{color:var(--text-secondary);grid-column:1/-1;padding:var(--space-10);text-align:center}@media (max-width:768px){.arrivals-grid{grid-template-columns:1fr}.days-selector{width:100%}}.manage-panel{margin-bottom:var(--space-5);overflow:hidden}.panel-header{align-items:center;background:var(--bg-card);border:none;cursor:pointer;display:flex;font-family:var(--font-sans);justify-content:space-between;padding:var(--space-4) var(--space-6);transition:background var(--transition-fast);width:100%}.panel-header:hover{background:var(--bg-hover)}.panel-header-left{align-items:center;display:flex;gap:var(--space-3)}.panel-header-left h3{font-size:var(--text-lg);margin:0}.panel-chevron{color:var(--text-muted);font-size:var(--text-sm);width:14px}.panel-body{border-top:1px solid var(--border-color);padding:0 var(--space-6) var(--space-6);padding-top:var(--space-5)}.panel-scroll{max-height:400px;overflow-y:auto;padding-right:var(--space-2)}.search-row{display:flex;gap:var(--space-4);margin-bottom:var(--space-5)}.search-row>div{flex:1 1}.country-group{margin-bottom:var(--space-6)}.country-group h4{border-bottom:1px solid var(--border-color);color:var(--text-secondary);font-size:var(--text-sm);letter-spacing:.05em;margin-bottom:var(--space-3);padding-bottom:var(--space-3);text-transform:uppercase}.attached-ports,.port-list{display:flex;flex-direction:column;gap:var(--space-2);list-style:none;margin:0;padding:0}.attached-ports li,.port-list li{align-items:center;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);display:flex;justify-content:space-between;padding:var(--space-3) var(--space-4);transition:background var(--transition-fast)}.attached-ports li:hover,.port-list li:hover{background:var(--bg-hover)}.port-actions{align-items:center;display:flex;gap:var(--space-2)}@media (max-width:768px){.search-row{flex-direction:column}.attached-ports li,.port-list li{align-items:stretch;flex-direction:column;gap:var(--space-3)}.port-actions{flex-direction:column}.port-actions .btn{justify-content:center;width:100%}}:root{--color-navy-950:#0a0f1a;--color-navy-900:#0f172a;--color-navy-800:#1e293b;--color-navy-700:#334155;--color-navy-600:#475569;--color-navy-500:#64748b;--color-navy-400:#94a3b8;--color-navy-300:#cbd5e1;--color-navy-200:#e2e8f0;--color-navy-100:#f1f5f9;--color-navy-50:#f8fafc;--color-blue-600:#2563eb;--color-blue-500:#3b82f6;--color-blue-400:#60a5fa;--color-blue-100:#dbeafe;--color-blue-50:#eff6ff;--color-green-600:#059669;--color-green-500:#10b981;--color-green-100:#d1fae5;--color-amber-600:#d97706;--color-amber-500:#f59e0b;--color-amber-100:#fef3c7;--color-red-600:#dc2626;--color-red-500:#ef4444;--color-red-100:#fee2e2;--color-indigo-600:#4f46e5;--color-indigo-500:#6366f1;--color-indigo-100:#e0e7ff;--color-white:#fff;--bg-page:var(--color-navy-100);--bg-card:var(--color-white);--bg-sidebar:var(--color-navy-900);--bg-input:var(--color-white);--bg-hover:var(--color-navy-50);--text-primary:var(--color-navy-800);--text-secondary:var(--color-navy-500);--text-muted:var(--color-navy-400);--text-on-dark:var(--color-navy-200);--text-on-primary:var(--color-white);--border-color:var(--color-navy-200);--border-input:var(--color-navy-300);--primary:var(--color-blue-600);--primary-hover:var(--color-blue-500);--primary-light:var(--color-blue-50);--success:var(--color-green-500);--success-light:var(--color-green-100);--warning:var(--color-amber-500);--warning-light:var(--color-amber-100);--danger:var(--color-red-500);--danger-light:var(--color-red-100);--info:var(--color-indigo-500);--info-light:var(--color-indigo-100);--font-sans:-apple-system,BlinkMacSystemFont,"Inter","Segoe UI",Roboto,sans-serif;--font-mono:"SF Mono","Fira Code",Menlo,monospace;--text-xs:0.75rem;--text-sm:0.8125rem;--text-base:0.9375rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--leading-tight:1.25;--leading-normal:1.5;--font-normal:400;--font-medium:500;--font-semibold:600;--font-bold:700;--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--radius-sm:0.375rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--radius-full:9999px;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 3px #0000000f,0 1px 2px #0000000a;--shadow-md:0 4px 6px -1px #00000012,0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000a;--transition-fast:150ms ease;--transition-base:200ms ease;--transition-slow:300ms ease;--sidebar-width:260px;--content-max-width:1280px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background:#f1f5f9;background:var(--bg-page);font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,sans-serif;font-family:var(--font-sans);font-size:.9375rem;font-size:var(--text-base);line-height:1.5;line-height:var(--leading-normal)}body,h1,h2,h3,h4,h5,h6{color:#1e293b;color:var(--text-primary)}h1,h2,h3,h4,h5,h6{font-weight:600;font-weight:var(--font-semibold);line-height:1.25;line-height:var(--leading-tight)}h1{font-size:1.875rem;font-size:var(--text-3xl)}h2{font-size:1.5rem;font-size:var(--text-2xl)}h3{font-size:1.25rem;font-size:var(--text-xl)}h4{font-size:1.125rem;font-size:var(--text-lg)}a{color:#2563eb;color:var(--primary);text-decoration:none}a:hover{color:#3b82f6;color:var(--primary-hover)}input[type=email],input[type=number],input[type=password],input[type=search],input[type=text],input[type=url],select,textarea{background:#fff;background:var(--bg-input);border:1px solid #cbd5e1;border:1px solid var(--border-input);border-radius:.5rem;border-radius:var(--radius-md);color:#1e293b;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,sans-serif;font-family:var(--font-sans);font-size:.9375rem;font-size:var(--text-base);outline:none;padding:.75rem 1rem;padding:var(--space-3) var(--space-4);transition:border-color .15s ease,box-shadow .15s ease;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%}input:focus,select:focus,textarea:focus{border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1f}input::placeholder,textarea::placeholder{color:#94a3b8;color:var(--text-muted)}label{color:#64748b;color:var(--text-secondary);display:block;font-size:.8125rem;font-size:var(--text-sm);font-weight:500;font-weight:var(--font-medium);margin-bottom:.5rem;margin-bottom:var(--space-2)}button{background:none;border:none;cursor:pointer;font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,sans-serif;font-family:var(--font-sans);outline:none}.btn{align-items:center;border-radius:.5rem;border-radius:var(--radius-md);display:inline-flex;font-size:.8125rem;font-size:var(--text-sm);font-weight:500;font-weight:var(--font-medium);gap:.5rem;gap:var(--space-2);padding:.75rem 1.25rem;padding:var(--space-3) var(--space-5);transition:all .15s ease;transition:all var(--transition-fast);white-space:nowrap}.btn-primary{background:#2563eb;background:var(--primary);color:#fff;color:var(--text-on-primary)}.btn-primary:hover{background:#3b82f6;background:var(--primary-hover);box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;box-shadow:var(--shadow-sm)}.btn-secondary{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-color);color:#1e293b;color:var(--text-primary)}.btn-secondary:hover{background:#f8fafc;background:var(--bg-hover);border-color:#cbd5e1;border-color:var(--color-navy-300)}.btn-danger{background:#ef4444;background:var(--danger);color:#fff;color:var(--text-on-primary)}.btn-danger:hover{background:#dc2626;background:var(--color-red-600)}.btn-success{background:#10b981;background:var(--success);color:#fff;color:var(--text-on-primary)}.btn-success:hover{background:#059669;background:var(--color-green-600)}.btn-ghost{background:#0000;color:#64748b;color:var(--text-secondary);padding:.5rem .75rem;padding:var(--space-2) var(--space-3)}.btn-ghost:hover{background:#f8fafc;background:var(--bg-hover);color:#1e293b;color:var(--text-primary)}.btn-sm{font-size:.75rem;font-size:var(--text-xs);padding:.5rem .75rem;padding:var(--space-2) var(--space-3)}.btn:disabled{cursor:not-allowed;opacity:.5;pointer-events:none}.card{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 1px 2px #0000000a;box-shadow:var(--shadow-xs)}.card-body{padding:1.5rem;padding:var(--space-6)}.badge{align-items:center;border-radius:9999px;border-radius:var(--radius-full);display:inline-flex;font-size:.75rem;font-size:var(--text-xs);font-weight:500;font-weight:var(--font-medium);gap:.25rem;gap:var(--space-1);padding:.25rem .75rem;padding:var(--space-1) var(--space-3);text-transform:capitalize}.badge-success{background:#d1fae5;background:var(--success-light);color:#059669;color:var(--color-green-600)}.badge-warning{background:#fef3c7;background:var(--warning-light);color:#d97706;color:var(--color-amber-600)}.badge-danger{background:#fee2e2;background:var(--danger-light);color:#dc2626;color:var(--color-red-600)}.badge-info{background:#e0e7ff;background:var(--info-light);color:#4f46e5;color:var(--color-indigo-600)}.badge-neutral{background:#f1f5f9;background:var(--color-navy-100);color:#475569;color:var(--color-navy-600)}.page{max-width:1280px;max-width:var(--content-max-width);padding:2rem;padding:var(--space-8);width:100%}.page-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;gap:var(--space-4);justify-content:space-between;margin-bottom:2rem;margin-bottom:var(--space-8)}.page-title{font-size:1.5rem;font-size:var(--text-2xl);font-weight:700;font-weight:var(--font-bold)}.page-subtitle{color:#64748b;color:var(--text-secondary);font-size:.8125rem;font-size:var(--text-sm);margin-top:.25rem;margin-top:var(--space-1)}.form-group{margin-bottom:1.25rem;margin-bottom:var(--space-5)}.form-card{max-width:640px}table{border-collapse:collapse;width:100%}th{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);color:#64748b;color:var(--text-secondary);font-size:.75rem;font-size:var(--text-xs);font-weight:600;font-weight:var(--font-semibold);letter-spacing:.05em;text-align:left;text-transform:uppercase}td,th{padding:.75rem 1rem;padding:var(--space-3) var(--space-4)}td{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--color-navy-100);font-size:.8125rem;font-size:var(--text-sm);vertical-align:middle}tbody tr:hover{background:#f8fafc;background:var(--color-navy-50)}.grid{grid-gap:1.25rem;grid-gap:var(--space-5);display:grid;gap:1.25rem;gap:var(--space-5)}.grid-auto{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}@media (max-width:768px){.page{padding:1.25rem;padding:var(--space-5)}.grid-auto{grid-template-columns:1fr}.page-header{align-items:flex-start;flex-direction:column}}.app-main,.app-shell{display:flex;min-height:100vh}.app-main{align-items:center;flex:1 1;flex-direction:column;margin-left:var(--sidebar-width);transition:margin-left var(--transition-slow)}.app-main.full-width{margin-left:0}@media (max-width:768px){.app-main{margin-left:0}}