@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--primary: #171644;--secondary: #5bc7d4;--white: #ffffff;--black: #000000;--bg-app: #f5f6f8;--bg-panel: var(--white);--bg-subtle: rgba(0, 0, 0, .025);--border-color: rgba(0, 0, 0, .1);--border-strong: rgba(0, 0, 0, .18);--text-primary: var(--black);--text-secondary: rgba(0, 0, 0, .55);--text-muted: rgba(0, 0, 0, .38);--text-faint: rgba(0, 0, 0, .22);--secondary-light: rgba(91, 199, 212, .1);--secondary-border: rgba(91, 199, 212, .35);--secondary-text: #0c838e;--error-bg: #fef2f2;--error-border: #fecaca;--error-text: #b91c1c;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 8px -1px rgba(0, 0, 0, .08), 0 2px 4px -2px rgba(0, 0, 0, .04);--shadow-lg: 0 12px 24px -4px rgba(0, 0, 0, .1), 0 4px 8px -4px rgba(0, 0, 0, .04);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-full: 9999px;--sidebar-width: 280px}*{box-sizing:border-box}html,body,#app{margin:0;min-height:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-app);color:var(--text-primary);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4{margin:0;color:var(--text-primary);font-weight:700;line-height:1.25}p{margin:0;color:var(--text-secondary);line-height:1.6}a{color:var(--primary);text-decoration:none}a:hover{color:var(--secondary);text-decoration:underline}button,input,select,textarea{font:inherit}.screen-loading{min-height:100vh;display:grid;place-items:center;background:var(--bg-app);color:var(--text-muted);font-size:15px}.login-shell{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:24px 16px;background:var(--white);position:relative;overflow:hidden}.login-bg{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}.partners-section{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:16px;margin-top:8px}.partners-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.partners-logos{display:flex;align-items:center;justify-content:center;gap:40px;flex-wrap:wrap}.partner-logo{height:36px;width:auto;object-fit:contain;opacity:.55;filter:grayscale(100%);transition:opacity .25s ease,filter .25s ease}.partner-logo-gc{height:52px}.partner-logo:hover{opacity:1;filter:grayscale(0%)}.login-credit{font-size:12px;color:var(--text-muted);text-align:center;font-weight:400;position:relative;z-index:1}.login-credit a{color:var(--primary);text-decoration:underline;text-underline-offset:2px;font-weight:500}.login-credit a:hover{color:var(--secondary)}.login-card{width:min(420px,100%);background:var(--white);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:40px 36px;display:grid;gap:24px;position:relative;z-index:1}.login-brand{display:flex;flex-direction:column;align-items:center;gap:14px}.login-logo{width:200px;height:auto}.login-brand h1{font-size:28px;font-weight:700;color:var(--primary);letter-spacing:-.02em}.login-card>p{font-size:14px;color:var(--text-muted);text-align:center}.form-stack{display:grid;gap:16px}label{display:grid;gap:6px;font-size:13px;font-weight:500;color:var(--text-primary)}input,select,textarea{width:100%;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--white);padding:10px 14px;min-height:44px;font-size:14px;color:var(--text-primary);transition:border-color .15s ease,box-shadow .15s ease}select{min-width:80px;padding-right:36px;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23000000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:16px}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--secondary);box-shadow:0 0 0 3px #5bc7d440}input::placeholder,textarea::placeholder{color:var(--text-faint)}input[type=file]{background:var(--bg-subtle);padding:8px 10px}input[type=checkbox]{width:16px;min-height:16px;accent-color:var(--primary);cursor:pointer}textarea{min-height:100px;resize:vertical}button{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid transparent;border-radius:var(--radius-md);min-height:44px;padding:10px 24px;background:var(--primary);color:var(--white);font-size:14px;font-weight:600;cursor:pointer;transition:background-color .15s ease,border-color .15s ease,box-shadow .15s ease}button:hover{background:var(--secondary);color:var(--white)}button:active{background:#4ab3bf}button:disabled{cursor:default;opacity:.5}button:disabled:hover{background:var(--primary)}.ghost-button{background:var(--white);border-color:var(--border-strong);color:var(--text-primary)}.ghost-button:hover{background:var(--secondary-light);border-color:var(--secondary);color:var(--primary)}.ghost-button:disabled:hover{background:var(--white);border-color:var(--border-strong);color:var(--text-primary)}a.ghost-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:10px 24px;border-radius:var(--radius-md);font-size:14px;font-weight:600;text-decoration:none;cursor:pointer}a.ghost-button:hover{text-decoration:none}.status-message{border-radius:var(--radius-md);padding:14px 18px;border:1px solid var(--border-color);background:var(--bg-subtle);color:var(--text-secondary);font-size:14px;line-height:1.5}.status-message.success{background:var(--secondary-light);border-color:var(--secondary-border);color:var(--secondary-text)}.status-message.error{background:var(--error-bg);border-color:var(--error-border);color:var(--error-text)}.info-notice{border-radius:var(--radius-md);padding:14px 18px;border:1px solid var(--border-color);background:var(--bg-subtle);color:var(--text-secondary);font-size:13px;line-height:1.6}.toast{position:fixed;top:24px;right:24px;z-index:50;display:flex;align-items:center;gap:10px;padding:14px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:500;line-height:1.5;box-shadow:var(--shadow-lg);opacity:0;transform:translate(20px);transition:opacity .3s ease,transform .3s ease;pointer-events:none;max-width:420px}.toast-visible{opacity:1;transform:translate(0);pointer-events:auto}.toast-success{background:var(--secondary-light);border:1px solid var(--secondary-border);color:var(--secondary-text)}.toast-error{background:var(--error-bg);border:1px solid var(--error-border);color:var(--error-text)}.toast svg{flex-shrink:0}.portal-shell{min-height:100vh;display:grid;grid-template-columns:var(--sidebar-width) minmax(0,1fr);background:var(--bg-app)}.portal-sidebar{background:var(--primary);border-right:none;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain}.portal-sidebar::-webkit-scrollbar{width:4px}.portal-sidebar::-webkit-scrollbar-track{background:transparent}.portal-sidebar::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.brand-block{display:flex;align-items:center;gap:12px;padding:24px 20px;border-bottom:1px solid rgba(255,255,255,.1)}.brand-mark{width:38px;height:38px;border-radius:var(--radius-md);background:var(--white);color:var(--primary);display:grid;place-items:center;font-size:18px;font-weight:700;flex-shrink:0}.brand-block h1{font-size:18px;font-weight:700;color:var(--white);line-height:1.2}.brand-block p{font-size:11px;color:#ffffff80;font-weight:500;letter-spacing:.02em}.side-nav{display:flex;flex-direction:column;gap:4px;padding:20px 14px;flex:1}.nav-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#fff6;padding:20px 12px 6px}.side-nav-link{display:flex;align-items:center;gap:10px;color:#ffffffa6;border-radius:var(--radius-md);padding:10px 12px;font-size:14px;font-weight:500;transition:background-color .15s ease,color .15s ease;text-decoration:none;white-space:nowrap}.nav-badge{margin-left:auto;font-size:9px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:2px 7px;border-radius:var(--radius-full);background:#5bc7d433;color:var(--secondary);line-height:1.4}.side-nav-link:hover{text-decoration:none;background:#5bc7d426;color:var(--white)}.side-nav-link.active{background:#5bc7d433;color:var(--white);font-weight:600}.side-nav-link svg{flex-shrink:0;opacity:.7}.side-nav-link:hover svg{opacity:.9}.side-nav-link.active svg{opacity:1}.sidebar-bottom{padding:12px 14px 20px;display:grid;gap:12px}.sidebar-language{display:grid;gap:6px;margin-bottom:10px}.sidebar-language label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#ffffff8c}.language-switch{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.language-option{min-height:40px;padding:8px 10px;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.2);background:#ffffff14;color:#fffc;display:inline-flex;align-items:center;justify-content:center;gap:7px;font-size:12px;font-weight:700;letter-spacing:.03em}.language-option:hover{background:#5bc7d426;border-color:#5bc7d480}.language-option.active{background:#5bc7d43b;border-color:var(--secondary);color:var(--white)}.language-option:focus-visible{outline:none;box-shadow:0 0 0 3px #5bc7d433}.language-option svg{flex-shrink:0;border-radius:2px;border:1px solid rgba(255,255,255,.35)}.sidebar-footer{background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);padding:12px 14px;display:flex;align-items:center;gap:10px}.user-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:#5bc7d440;color:var(--white);display:grid;place-items:center;font-size:14px;font-weight:700;flex-shrink:0}.user-details{display:grid;gap:1px;min-width:0;flex:1}.user-name{font-size:13px;font-weight:600;color:var(--white);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-tier{font-size:11px;color:#ffffff80;font-weight:500;text-transform:capitalize}.logout-btn{background:#ef444426;border:none;color:#f87171;padding:7px;min-height:auto;min-width:auto;border-radius:var(--radius-sm);cursor:pointer;flex-shrink:0;transition:background-color .15s ease}.logout-btn:hover{background:#ef444440}.logout-btn:disabled:hover{background:#ef444426}.credit-line{font-size:12px;color:#fff6;text-align:center;font-weight:400}.credit-line a{color:var(--secondary);text-decoration:underline;text-underline-offset:2px}.credit-line a:hover{color:var(--white)}.portal-main{padding:36px 48px;display:grid;align-content:start;gap:32px;max-width:1400px}.portal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding-bottom:24px;border-bottom:1px solid var(--border-color)}.portal-title-row{display:flex;align-items:center;gap:12px}.portal-header h2{font-size:26px;font-weight:700;line-height:1.3}.title-badge{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:4px 10px;border-radius:var(--radius-full);background:#1716440f;color:var(--primary);border:1px solid rgba(23,22,68,.18);line-height:1.3}.portal-header p{margin-top:4px;font-size:15px;color:var(--text-muted)}.portal-content{display:grid;gap:28px}.guidance-text{font-size:14px;color:var(--text-muted);line-height:1.6}.panel{background:var(--bg-panel);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:28px;display:grid;gap:24px}.panel h3{font-size:18px;font-weight:700;line-height:1.3}.compact-panel{padding:24px}.metric-grid{display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.metric-card{background:var(--bg-panel);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);padding:24px;display:grid;grid-template-columns:48px 1fr;grid-template-rows:auto auto;column-gap:16px;row-gap:4px;align-items:center;transition:box-shadow .15s ease,transform .15s ease}.metric-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.metric-icon{width:48px;height:48px;border-radius:var(--radius-md);background:var(--secondary-light);color:var(--primary);display:grid;place-items:center;grid-row:1 / -1}.metric-label{color:var(--text-muted);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;align-self:end}.metric-card h4{font-size:24px;color:var(--text-primary);font-weight:700;align-self:start}.segment-switch{display:inline-flex;flex-wrap:wrap;gap:4px;background:#0000000d;padding:5px;border-radius:var(--radius-md)}.segment-switch button{min-width:auto;background:transparent;border:1px solid transparent;color:var(--text-secondary);font-size:13px;font-weight:500;padding:9px 22px;min-height:38px;border-radius:var(--radius-sm)}.segment-switch button:hover{color:var(--text-primary);background:#ffffff80}.segment-switch button.active{background:var(--primary);border-color:var(--primary);color:var(--white);box-shadow:var(--shadow-xs);font-weight:600}.segment-switch button:disabled:hover{background:transparent;color:var(--text-secondary)}.form-grid{display:grid;gap:24px}.form-grid>button,.form-grid>.ghost-button{justify-self:start}.template-actions{display:flex;gap:12px;flex-wrap:wrap}.compact-grid{align-items:end}.two-col,.three-col,.filter-grid{display:grid;gap:16px}.two-col{grid-template-columns:repeat(2,minmax(0,1fr))}.three-col,.filter-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.filter-grid>button{align-self:end}.meta-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.meta-grid div{border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-subtle);padding:16px;display:grid;gap:6px}.meta-grid strong{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600}.meta-grid p{color:var(--text-primary);font-weight:600;font-size:14px}.subtle-text{color:var(--text-muted);font-size:14px}.bullet-list{margin:0;padding-left:18px;display:grid;gap:6px;color:var(--text-secondary);font-size:14px;line-height:1.6}.stack-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.header-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:12px;font-weight:600;line-height:1.4;white-space:nowrap}.badge-success{background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0}.badge-running{background:#1716440f;color:var(--primary);border:1px solid rgba(23,22,68,.18)}.badge-inactive{background:var(--error-bg);color:var(--error-text);border:1px solid var(--error-border)}.badge-company{background:#1716440f;color:var(--primary);border:1px solid rgba(23,22,68,.18)}.badge-individual{background:var(--secondary-light);color:var(--secondary-text);border:1px solid var(--secondary-border)}.badge-risk-low{background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0}.badge-risk-medium{background:#fefce8;color:#a16207;border:1px solid #fde68a}.badge-risk-high{background:var(--error-bg);color:var(--error-text);border:1px solid var(--error-border)}.badge-platinum{background:#1716440f;color:var(--primary);border:1px solid rgba(23,22,68,.18)}.badge-gold{background:#fefce8;color:#a16207;border:1px solid #fde68a}.badge-silver{background:#0000000a;color:var(--text-secondary);border:1px solid var(--border-color)}.tier-select{min-width:110px;min-height:32px;padding:4px 28px 4px 10px;font-size:12px;font-weight:600;border-radius:var(--radius-full);background-position:right 8px center;background-size:14px}.filter-section{display:grid;gap:16px;padding:20px;background:var(--bg-subtle);border:1px solid var(--border-color);border-radius:var(--radius-md)}.filter-actions{display:flex;align-items:center;gap:8px}.filter-actions>button{min-height:38px;padding:8px 20px;font-size:13px}.page-top-bar{display:flex;justify-content:flex-end;gap:8px}.query-bar{display:flex;align-items:flex-end;gap:16px;flex-wrap:wrap}.query-bar>label{flex:1;min-width:160px}.query-bar>button{min-width:120px;align-self:flex-end}.table-wrap{border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:auto;background:var(--white);box-shadow:var(--shadow-xs)}table{width:100%;border-collapse:collapse;min-width:780px}th,td{padding:14px 20px;border-bottom:1px solid var(--border-color);font-size:13px;text-align:left;vertical-align:middle}th{background:var(--bg-subtle);color:var(--text-muted);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}td{color:var(--text-primary)}tbody tr{transition:background-color .1s ease}tbody tr:hover{background:var(--bg-subtle)}tr:last-child td{border-bottom:0}.table-user{display:flex;align-items:center;gap:10px}.table-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:var(--primary);color:var(--white);display:grid;place-items:center;font-size:13px;font-weight:700;flex-shrink:0;line-height:1}.table-action{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);border:1px solid var(--primary);background:var(--primary);color:var(--white);text-decoration:none;padding:7px 16px;font-size:12px;font-weight:600;cursor:pointer;transition:background-color .15s ease,border-color .15s ease,transform .1s ease}.table-action:hover{text-decoration:none;background:var(--secondary);border-color:var(--secondary);transform:translateY(-1px)}.icon-button{min-width:34px;min-height:34px;width:34px;height:34px;padding:0;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--white);color:var(--text-muted);display:inline-flex;align-items:center;justify-content:center}.icon-button:hover{background:var(--secondary-light);border-color:var(--secondary);color:var(--primary)}.icon-button-danger:hover{background:var(--error-bg);border-color:var(--error-border);color:var(--error-text)}.pagination{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.pagination-summary{color:var(--text-muted);font-size:13px}.pagination-controls{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.pagination-size{display:inline-flex;align-items:center;gap:6px;color:var(--text-muted);font-size:13px}.pagination-size select{width:auto;min-height:34px;padding:6px 32px 6px 10px;font-size:13px}.pagination-pages{display:inline-flex;align-items:center;gap:4px}.pagination-page,.pagination-btn{min-height:34px;min-width:34px;padding:4px 10px;border-radius:var(--radius-sm);font-size:13px}.pagination-page{border:1px solid var(--border-color);background:var(--white);color:var(--text-secondary);font-weight:500}.pagination-page.active{border-color:var(--primary);background:var(--primary);color:var(--white)}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-backdrop{position:fixed;inset:0;background:#17164466;display:grid;place-items:center;padding:20px;z-index:40;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:modal-fade-in .2s ease}.modal-card{width:min(480px,100%);background:var(--bg-panel);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:0 25px 50px -12px #0003,0 0 0 1px #0000000d;padding:32px;display:grid;gap:24px;animation:modal-slide-up .25s ease}.modal-card h3{display:flex;align-items:center;gap:10px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;padding-top:8px}code{background:#1716440f;color:var(--primary);padding:2px 6px;border-radius:4px;font-size:13px}.drop-zone{border:2px dashed var(--border-strong);border-radius:var(--radius-md);padding:28px 20px;text-align:center;cursor:pointer;transition:border-color .2s ease,background-color .2s ease;background:var(--bg-subtle)}.drop-zone:hover{border-color:var(--secondary);background:var(--secondary-light)}.drop-zone-active{border-color:var(--secondary);background:var(--secondary-light);border-style:solid}.drop-zone-has-file{border-style:solid;border-color:var(--secondary-border);background:var(--secondary-light);padding:16px 20px}.drop-zone-disabled{opacity:.5;cursor:default;pointer-events:none}.drop-zone-prompt{display:grid;gap:8px;justify-items:center}.drop-zone-icon{width:48px;height:48px;border-radius:var(--radius-full);background:var(--white);border:1px solid var(--border-color);display:grid;place-items:center;color:var(--text-muted);margin-bottom:4px}.drop-zone:hover .drop-zone-icon,.drop-zone-active .drop-zone-icon{color:var(--secondary);border-color:var(--secondary-border)}.drop-zone-text{font-size:14px;font-weight:500;color:var(--text-secondary)}.drop-zone-browse{color:var(--secondary-text);font-weight:600;text-decoration:underline;text-underline-offset:2px}.drop-zone-hint{font-size:12px;color:var(--text-muted)}.drop-zone-file{display:flex;align-items:center;gap:12px;text-align:left}.drop-zone-file>svg{flex-shrink:0;color:var(--secondary-text)}.drop-zone-file-info{flex:1;display:grid;gap:2px;min-width:0}.drop-zone-file-name{font-size:14px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.drop-zone-file-size{font-size:12px;color:var(--text-muted)}.drop-zone-remove{min-width:32px;min-height:32px;width:32px;height:32px;padding:0;border-radius:var(--radius-sm);background:transparent;border:1px solid var(--border-color);color:var(--text-muted);display:grid;place-items:center;flex-shrink:0}.drop-zone-remove:hover{background:var(--error-bg);border-color:var(--error-border);color:var(--error-text)}@media(max-width:1340px){.three-col,.filter-grid,.meta-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:1024px){.portal-shell{grid-template-columns:1fr}.portal-sidebar{position:static;height:auto;border-right:none;border-bottom:none}.side-nav{flex-direction:row;flex-wrap:wrap;gap:4px;padding:12px}.nav-section-label{width:100%;padding:8px 12px 4px}.sidebar-footer{padding-bottom:16px}.portal-main{padding:28px 20px}.portal-header{padding-bottom:20px}}@media(max-width:760px){.login-card{padding:28px 24px}.login-logo{width:170px}.login-brand h1{font-size:22px}.portal-header h2{font-size:20px}.metric-grid,.two-col,.three-col,.filter-grid,.meta-grid{grid-template-columns:1fr}.side-nav{flex-direction:column}.segment-switch{display:flex;width:100%}.segment-switch button{flex:1}.form-grid>button,.form-grid>.ghost-button{width:100%}}.vessel-ais-card{background:#3b82f60f;border:1px solid rgba(59,130,246,.15);border-radius:var(--radius-md);padding:1rem 1.25rem;margin-bottom:1rem}.vessel-ais-card h4{margin:0 0 .75rem;font-size:.85rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.vessel-detail-row{padding:.75rem 0;border-bottom:1px solid rgba(0,0,0,.06)}.vessel-detail-row:last-child{border-bottom:none}.vessel-detail-row strong{display:block;margin-bottom:.25rem}.vessel-tag{display:inline-block;background:#0000000d;padding:2px 8px;border-radius:var(--radius-sm);font-size:.75rem;margin-right:6px;margin-top:6px;color:var(--text-secondary)}.id-scan-toggle{display:flex;gap:0;margin-bottom:1rem;border:1px solid rgba(0,0,0,.12);border-radius:var(--radius-sm);overflow:hidden;width:fit-content}.id-scan-toggle button{padding:.4rem 1rem;border:none;background:transparent;font-size:.8rem;cursor:pointer;color:var(--text-secondary);transition:background .2s,color .2s}.id-scan-toggle button.active{background:var(--primary);color:#fff}.id-scan-toggle button:not(.active):hover{background:#0000000a}.id-scan-container{margin-top:.5rem}.id-scan-zone{border:2px dashed rgba(0,0,0,.15);border-radius:var(--radius-md);padding:2rem;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;background:#00000003}.id-scan-zone:hover,.id-scan-zone-active{border-color:var(--secondary);background:#5bc7d40a}.id-scan-placeholder{display:flex;flex-direction:column;align-items:center;gap:.75rem;color:var(--text-secondary)}.id-scan-placeholder svg{opacity:.5}.id-scan-placeholder p{margin:0;font-size:.85rem}.id-scan-preview{max-width:100%;max-height:240px;border-radius:var(--radius-sm);object-fit:contain}.id-scan-actions{display:flex;align-items:center;gap:.75rem;margin-top:.75rem;flex-wrap:wrap}.id-scan-camera-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .8rem;font-size:.8rem;background:transparent;border:1px solid rgba(0,0,0,.15);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary)}.id-scan-camera-btn:hover{background:#0000000a}.id-scan-btn-group{display:flex;gap:.5rem;margin-left:auto}.id-scan-reset-btn{background:transparent!important;border:1px solid rgba(0,0,0,.15)!important;color:var(--text-secondary)!important}.id-scan-results{padding:.5rem 0}.id-scan-results-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.id-scan-results-header h4{margin:0}.id-scan-meta{display:flex;gap:.5rem;align-items:center}.id-scan-confidence{font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:999px;text-transform:uppercase;letter-spacing:.03em}.id-scan-confidence-high{background:#22c55e1f;color:#16a34a}.id-scan-confidence-medium{background:#f59e0b1f;color:#d97706}.id-scan-confidence-low{background:#ef44441f;color:#dc2626}.id-scan-doc-type{font-size:.7rem;color:var(--text-secondary);background:#0000000d;padding:2px 8px;border-radius:999px}@media(max-width:600px){.id-scan-actions{flex-direction:column;align-items:stretch}.id-scan-btn-group{margin-left:0;justify-content:stretch}.id-scan-btn-group button{flex:1}.id-scan-toggle{width:100%}.id-scan-toggle button{flex:1}}
