/* ═══════════════════════════════════════════════════════════════════
   BOAT MAINTENANCE — Maritime Premium Design System v2.0
   Adapted to the actual class names used by the Razor markup.
   Paleta:
     Deep Ocean   #0A2540  · Cyan Marina #00B4D8 · Ice Blue #CAE9FF
     Coral Alerta #FF6B35  · Verde Mar   #06A77D · Ámbar    #F4A261
   Tipografía: Crimson Pro (headings) + DM Sans (body) + Material Icons
   ═══════════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Crimson+Pro:wght@400;600;700&family=DM+Sans:wght@300;400;500;600;700&display=swap');
@import url('https://fonts.googleapis.com/icon?family=Material+Icons');

/* ── Design Tokens ──────────────────────────────────────────────── */
:root {
  /* Brand */
  --ocean:        #0A2540;
  --ocean-800:    #0D2E4E;
  --ocean-700:    #103659;
  --ocean-600:    #134070;
  --cyan:         #00B4D8;
  --cyan-dark:    #0096B7;
  --cyan-light:   #CAE9FF;
  --cyan-xlight:  #E8F6FB;

  /* Semantic */
  --danger:       #FF6B35;
  --danger-light: #FFF0EB;
  --danger-dark:  #D94F1A;
  --success:      #06A77D;
  --success-light:#E6F7F2;
  --warning:      #F4A261;
  --warning-light:#FEF6EC;
  --warning-dark: #C97C3A;
  --info:         #00B4D8;
  --info-light:   #E8F6FB;

  /* Neutrals */
  --white:        #FFFFFF;
  --off-white:    #F8FAFC;
  --surface:      #FFFFFF;
  --surface-alt:  #F0F5FA;
  --border:       #D1E3F0;
  --border-light: #E8F0F7;
  --text:         #0A2540;
  --text-muted:   #4A6580;
  --text-light:   #8AA4BC;

  /* Compat aliases — older rules still reference these */
  --color-bg:           var(--off-white);
  --color-surface:      var(--surface);
  --color-surface-alt:  var(--surface-alt);
  --color-border:       var(--border);
  --color-text:         var(--text);
  --color-text-muted:   var(--text-muted);
  --color-primary:      var(--ocean);
  --color-danger:       var(--danger);
  --color-warning:      var(--warning-dark);
  --color-success:      var(--success);
  --color-info:         var(--cyan-dark);

  /* Layout */
  --sidebar-w:    220px;
  --sidebar-coll: 64px;
  --radius:       4px;
  --radius-lg:    8px;
  --radius-xl:    12px;

  /* Shadows */
  --shadow-sm:    0 1px 3px rgba(10,37,64,.08), 0 1px 2px rgba(10,37,64,.05);
  --shadow-md:    0 4px 16px rgba(10,37,64,.10), 0 2px 6px rgba(10,37,64,.06);
  --shadow-lg:    0 12px 32px rgba(10,37,64,.14), 0 4px 12px rgba(10,37,64,.08);
  --shadow-cyan:  0 4px 20px rgba(0,180,216,.25);

  /* Typography */
  --font-display: 'Crimson Pro', Georgia, serif;
  --font-body:    'DM Sans', 'Calibri', system-ui, -apple-system, sans-serif;
  --font-mono:    'JetBrains Mono', 'Fira Code', 'Consolas', monospace;

  /* ── NAUTICORE design-system additions ───────────────────────── */
  --ocean-700:    #133554;
  --ocean-600b:   #1E456B;
  --cyan-600:     #0098B8;
  --cyan-50:      #EAF6FC;
  --danger-50:    #FFEDE5;
  --success-50:   #E2F5EE;
  --warning-50:   #FCEFE0;
  --muted:        #4A6580;
  --muted-2:      #7E94A8;
  --border-soft:  #E6EEF5;
  --canvas:       #F1F6FB;
  --shadow-1:     0 1px 2px rgba(10,37,64,.05);
  --shadow-2:     0 4px 16px -4px rgba(10,37,64,.08);
  --shadow-3:     0 12px 40px -8px rgba(10,37,64,.14);
  --r-sm:         6px;
  --r-md:         10px;
  --r-lg:         14px;
  --r-xl:         20px;
}

/* ── Reset ──────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body {
  height: 100%;
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text);
  background: var(--off-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
a       { color: var(--cyan-dark); text-decoration: none; }
a:hover { color: var(--ocean); }
button  { font-family: var(--font-body); cursor: pointer; }
h1, h2, h3, h4 { font-family: var(--font-display); color: var(--ocean); letter-spacing: -.2px; }
::-webkit-scrollbar       { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 5px; }
::-webkit-scrollbar-thumb:hover { background: var(--text-light); }

/* ── App Shell ──────────────────────────────────────────────────── */
.app-shell    { display: flex; height: 100vh; overflow: hidden; }
.main-content { flex: 1; overflow-y: auto; display: flex; flex-direction: column;
                background: var(--off-white); }
.page-body    { flex: 1; padding: 28px 32px; max-width: 1440px; width: 100%; }

/* ── Sidebar ────────────────────────────────────────────────────── */
.sidebar      { width: var(--sidebar-w); background: var(--ocean); color: var(--white);
                display: flex; flex-direction: column; flex-shrink: 0;
                transition: width .2s ease; overflow: hidden; position: relative; }
.sidebar::before { content:''; position:absolute; top:0; right:0; bottom:0; width:1px;
                   background: linear-gradient(180deg, transparent, var(--cyan) 50%, transparent);
                   opacity:.35; }
.sidebar.collapsed { width: var(--sidebar-coll); }
.sidebar.open      { width: var(--sidebar-w); }

.sb-header    { display: flex; align-items: center; gap: 10px;
                padding: 0 16px; height: 64px;
                border-bottom: 1px solid rgba(0,180,216,.15); flex-shrink: 0; }
.sb-logo      { font-size: 22px; flex-shrink: 0;
                filter: drop-shadow(0 0 8px rgba(0,180,216,.6)); }
.sb-title     { color: var(--white); font-family: var(--font-display);
                font-size: 15px; font-weight: 600; letter-spacing: .3px; white-space: nowrap; }
.sidebar-toggle { margin-left: auto; background: none; border: none;
                  color: #94a3b8 !important; font-size: 12px;
                  opacity: .75; transition: opacity .15s; }
.sidebar-toggle:hover { opacity: 1; }

.sb-nav       { flex: 1; padding: 12px 0; overflow-y: auto; }
.nav-item     { display: flex; align-items: center; gap: 12px;
                padding: 10px 16px; color: #7DA3C0; font-size: 13px;
                font-weight: 500; cursor: pointer; position: relative;
                transition: all .15s; white-space: nowrap; text-decoration: none; }
.nav-item:hover  { color: var(--white); background: rgba(0,180,216,.08); text-decoration: none; }
.nav-item.active { color: var(--white); background: rgba(0,180,216,.12); }
.nav-item.active::before { content:''; position:absolute; left:0; top:4px; bottom:4px;
                            width:3px; background:var(--cyan); border-radius:0 2px 2px 0; }
.nav-icon     { font-size: 18px !important; flex-shrink: 0; }
.nav-label    { white-space: nowrap; }
.nav-item.collapsed { justify-content: center; padding: 10px; }
.nav-item.collapsed .nav-label { display: none; }

.alert-nav-badge { background: var(--danger); color: #fff; font-size: 10px;
                   font-weight: 700; padding: 1px 6px; border-radius: 10px;
                   min-width: 18px; text-align: center; margin-left: auto; }
.alert-nav-dot   { position: absolute; top: 8px; right: 10px; width: 7px;
                   height: 7px; border-radius: 50%; background: var(--danger); }

/* ── Vessel picker (sidebar dropdown) ───────────────────────────── */
.sb-vessel-picker       { padding: 12px 14px 8px; border-bottom: 1px solid rgba(0,180,216,.15); }
.sb-vessel-picker-label { display: block; color: #6A8FAB; font-size: 10px;
                          font-weight: 700; text-transform: uppercase;
                          letter-spacing: .8px; margin-bottom: 6px; }
.sb-vessel-picker .rz-dropdown {
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(0,180,216,.25) !important;
  color: var(--white) !important;
  font-size: 12.5px !important;
  min-height: 32px !important;
}
.sb-vessel-picker .rz-dropdown-label,
.sb-vessel-picker .rz-inputtext { color: var(--white) !important; }
.sb-vessel-picker .rz-dropdown-trigger { color: var(--cyan-light) !important; }

.nav-divider  { height: 1px; background: rgba(0,180,216,.15); margin: 8px 16px; }

.sv-vessel    { padding: 14px 16px; border-top: 1px solid rgba(0,180,216,.15); }
.sv-name      { color: var(--cyan-light); font-family: var(--font-display);
                font-size: 13px; font-weight: 600; margin-bottom: 2px; }
.sv-meta      { color: #6A8FAB; font-size: 11px; }

/* ── Alert Banner (top of main-content) ─────────────────────────── */
.alert-banner { padding: 12px 32px 0; display: flex; flex-direction: column; gap: 4px; }
.alert-item   { display: flex; align-items: center; gap: 10px;
                padding: 10px 14px; font-size: 13px;
                border-left: 3px solid; border-radius: var(--radius); }
.alert-item.severity-high   { background: var(--danger-light);  color: var(--danger-dark);
                              border-left-color: var(--danger); }
.alert-item.severity-medium { background: var(--warning-light); color: var(--warning-dark);
                              border-left-color: var(--warning); }
.alert-item.severity-low    { background: var(--info-light);    color: var(--cyan-dark);
                              border-left-color: var(--cyan); }
.alert-icon    { font-size: 17px; }
.alert-content { flex: 1; }
.alert-due     { opacity: .75; margin-left: 6px; }
.alert-dismiss { background: none; border: none; font-size: 16px;
                 opacity: .5; padding: 0 4px; transition: opacity .15s; cursor: pointer; }
.alert-dismiss:hover { opacity: 1; }
.alert-overflow { padding: 5px 14px; font-size: 12px; color: var(--text-muted); }

/* ── Inline alert (in-page banner) ──────────────────────────────── */
.inline-alert         { padding: 12px 16px; border-radius: var(--radius);
                        border-left: 3px solid; margin-bottom: 18px; font-size: 13px;
                        display: flex; align-items: center; gap: 8px; }
.inline-alert.danger  { background: var(--danger-light); color: var(--danger-dark);
                        border-left-color: var(--danger); }
.inline-alert.warning { background: var(--warning-light); color: var(--warning-dark);
                        border-left-color: var(--warning); }
.inline-alert.info    { background: var(--info-light); color: var(--cyan-dark);
                        border-left-color: var(--cyan); }
.inline-alert.success { background: var(--success-light); color: var(--success);
                        border-left-color: var(--success); }

/* ── Page Header ────────────────────────────────────────────────── */
.page-header   { display: flex; align-items: flex-start;
                 justify-content: space-between; margin-bottom: 28px; gap: 20px; flex-wrap: wrap; }
.page-header h1 { font-family: var(--font-display); font-size: 26px;
                  font-weight: 700; color: var(--ocean); letter-spacing: -.3px; }
.page-subtitle { color: var(--text-muted); margin-top: 4px; font-size: 13px; }
.back-link     { display: inline-flex; align-items: center; gap: 4px; font-size: 12px;
                 color: var(--text-muted); margin-bottom: 8px; }
.back-link:hover { color: var(--cyan-dark); }

/* ── Back button (NAUTICORE) ────────────────────────────────────── */
.nc-back        { display: inline-flex; align-items: center; gap: 6px;
                  background: var(--surface); border: 1px solid var(--border);
                  color: var(--muted); font-size: 13px; font-weight: 500;
                  padding: 7px 14px 7px 10px; border-radius: 99px; cursor: pointer;
                  margin-bottom: 16px; transition: all .15s; font-family: var(--font-body); }
.nc-back:hover  { border-color: var(--cyan); color: var(--ocean); background: var(--cyan-50); }
.nc-back .material-icons { font-size: 17px; }

.vessel-metrics, .metrics { display: flex; gap: 28px; }
.metric        { text-align: right; }
.metric-val, .metric-value {
                 display: block; font-family: var(--font-display); font-size: 24px;
                 font-weight: 700; color: var(--cyan-dark); line-height: 1; }
.metric-lbl, .metric-label {
                 font-size: 10px; color: var(--text-muted); text-transform: uppercase;
                 letter-spacing: .6px; margin-top: 4px; display: block; }

/* ── Summary Cards ──────────────────────────────────────────────── */
.summary-cards { display: grid; grid-template-columns: repeat(4, 1fr);
                 gap: 16px; margin-bottom: 32px; }
.summary-card  { display: flex; align-items: center; gap: 16px;
                 padding: 18px 20px; background: var(--surface);
                 border-radius: var(--radius-lg); box-shadow: var(--shadow-sm);
                 border-top: 3px solid var(--cyan); text-decoration: none; color: inherit;
                 transition: transform .15s, box-shadow .15s; }
.summary-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md);
                      text-decoration: none; }
.summary-card.red,    .summary-card.color-red    { border-top-color: var(--danger); }
.summary-card.amber,  .summary-card.color-amber  { border-top-color: var(--warning); }
.summary-card.blue,   .summary-card.color-blue   { border-top-color: var(--cyan); }
.summary-card.orange, .summary-card.color-orange { border-top-color: #EA580C; }
.summary-card.green,  .summary-card.color-green  { border-top-color: var(--success); }
.summary-icon  { font-size: 28px !important; opacity: .8; color: var(--ocean); }
.summary-body  { display: flex; flex-direction: column; gap: 2px; }
.summary-val, .summary-value {
                 display: block; font-family: var(--font-display); font-size: 28px;
                 font-weight: 700; line-height: 1; color: var(--ocean); }
.summary-lbl, .summary-label { font-size: 11px; color: var(--text-muted); margin-top: 3px; }

/* ── Dashboard Sections ─────────────────────────────────────────── */
.dashboard-section { margin-bottom: 28px; }
.section-title { font-family: var(--font-display); font-size: 16px; font-weight: 600;
                 margin-bottom: 12px; display: flex; align-items: center; gap: 8px;
                 letter-spacing: -.1px; color: var(--ocean); }
.section-title.danger   { color: var(--danger); }
.section-title.warning  { color: var(--warning-dark); }
.section-title.info     { color: var(--cyan-dark); }
.section-title.success  { color: var(--success); }
.task-list     { display: flex; flex-direction: column; gap: 8px; }
.show-more     { display: inline-block; padding: 8px 0; font-size: 13px;
                 color: var(--cyan-dark); font-weight: 600; }

/* ── Task Cards (dashboard) ─────────────────────────────────────── */
.task-card     { display: flex; align-items: center; gap: 14px;
                 background: var(--surface); border-radius: var(--radius-lg);
                 padding: 14px 18px; box-shadow: var(--shadow-sm);
                 border-left: 4px solid var(--border);
                 transition: box-shadow .15s, transform .1s; }
.task-card:hover { box-shadow: var(--shadow-md); transform: translateX(2px); }
.task-card.overdue,  .task-card.urgency-overdue  { border-left-color: var(--danger); }
.task-card.duesoon,  .task-card.urgency-duesoon  { border-left-color: var(--warning); }
.task-card.upcoming, .task-card.urgency-upcoming { border-left-color: var(--success); }
.task-card.unknown,  .task-card.urgency-unknown  { border-left-color: var(--border); }
.task-card.mandatory { background: #FFFBF5; }

.task-card-left  { flex-shrink: 0; }
.category-dot, .cat-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0;
                          display: inline-block; }
.task-card-body  { flex: 1; min-width: 0; }
.task-card-header { display: flex; align-items: center; gap: 8px; margin-bottom: 5px; flex-wrap: wrap; }
.task-title      { font-weight: 600; font-size: 13.5px; color: var(--text); }
.task-title:hover { color: var(--cyan-dark); }
.mandatory-badge { background: #FEF3C7; color: #92400E; font-size: 10px;
                   padding: 1px 7px; border-radius: 3px; font-weight: 600;
                   letter-spacing: .2px; white-space: nowrap; }
.task-card-meta  { display: flex; align-items: center; gap: 6px;
                   font-size: 12px; color: var(--text-muted); flex-wrap: wrap; }
.meta-sep        { color: var(--border); }
.meta-category, .meta-date { color: var(--text-muted); }
.task-reg-ref    { font-size: 11px; color: var(--text-muted); margin-top: 4px;
                   display: flex; align-items: center; gap: 4px; }
.task-card-right { display: flex; flex-direction: column; align-items: flex-end; gap: 5px;
                   flex-shrink: 0; }
.task-cost       { font-weight: 700; font-size: 14px; color: var(--text-muted);
                   font-family: var(--font-display); }

/* ── TaskList grid table ────────────────────────────────────────── */
.task-table          { background: var(--surface); border: 1px solid var(--border-light);
                       border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); }
.task-table-header   { display: grid;
                       grid-template-columns: 2.5fr 1.4fr 1.4fr 1fr 1fr 100px 80px;
                       gap: 12px; padding: 12px 18px; background: var(--off-white);
                       border-bottom: 2px solid var(--border);
                       font-size: 10.5px; font-weight: 700;
                       color: var(--text-muted); text-transform: uppercase;
                       letter-spacing: .6px; }
.task-table-row      { display: grid;
                       grid-template-columns: 2.5fr 1.4fr 1.4fr 1fr 1fr 100px 80px;
                       gap: 12px; align-items: center; padding: 12px 18px;
                       border-bottom: 1px solid var(--border-light);
                       cursor: pointer; transition: background .1s; font-size: 13px; }
.task-table-row:last-child { border-bottom: none; }
.task-table-row:hover      { background: var(--cyan-xlight); }
.task-table-row.row-overdue       { background: rgba(255,107,53,.04); }
.task-table-row.row-overdue:hover { background: rgba(255,107,53,.09); }
.col-task   { display: flex; align-items: center; gap: 10px; min-width: 0; }
.col-task > div { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.task-name  { font-weight: 600; color: var(--text); overflow: hidden;
              text-overflow: ellipsis; white-space: nowrap; }
.col-cat    { color: var(--text-muted); font-size: 12px; }
.col-date   { display: flex; flex-direction: column; gap: 3px; font-size: 12px; }
.task-meta-row { display: flex; align-items: center; gap: 6px; font-size: 11px;
                 color: var(--text-muted); }

/* ── Badges ─────────────────────────────────────────────────────── */
.badge           { display: inline-flex; align-items: center; gap: 5px;
                   padding: 3px 9px; border-radius: 99px;
                   font-size: 11.5px; font-weight: 500; letter-spacing: .01em;
                   white-space: nowrap; background: var(--off-white); color: var(--muted); }
.badge.overdue,   .badge.urgency-overdue  { background: var(--danger-50);  color: var(--danger); }
.badge.duesoon,   .badge.urgency-duesoon  { background: var(--warning-50); color: #B96A2C; }
.badge.upcoming,  .badge.urgency-upcoming { background: var(--success-50); color: var(--success); }
.badge.unknown,   .badge.urgency-unknown  { background: var(--off-white);  color: var(--muted); }
.badge.status-notstarted { background: var(--danger-50);  color: var(--danger); }
.badge.status-inprogress { background: var(--warning-50); color: #B96A2C; }
.badge.status-waiting    { background: #FFF0F0;           color: #C05621; }
.badge.status-completed  { background: var(--success-50); color: var(--success); }
.badge.status-cancelled  { background: var(--off-white);  color: var(--muted); }
.badge.priority-high     { background: var(--danger-50);  color: var(--danger); }
.badge.priority-medium   { background: var(--warning-50); color: #B96A2C; }
.badge.priority-low      { background: var(--success-50); color: var(--success); }
.badge.outcome-completed     { background: var(--success-50); color: var(--success); }
.badge.outcome-partiallydone { background: var(--warning-50); color: #B96A2C; }
.badge.outcome-deferred      { background: var(--cyan-50);    color: var(--cyan-600); }
.badge.outcome-failed        { background: var(--danger-50);  color: var(--danger); }

/* ── Buttons ────────────────────────────────────────────────────── */
.btn             { display: inline-flex; align-items: center; justify-content: center; gap: 7px;
                   padding: 9px 18px; border-radius: var(--radius);
                   font-size: 13px; font-weight: 600; border: 1px solid transparent;
                   transition: all .15s; letter-spacing: .1px; text-decoration: none;
                   cursor: pointer; font-family: var(--font-body); }
.btn:disabled    { opacity: .55; cursor: not-allowed; }
.btn-sm          { padding: 5px 12px; font-size: 12px; }
.btn-lg          { padding: 12px 24px; font-size: 14px; }
.btn-primary     { background: var(--ocean); color: var(--white); border-color: var(--ocean); }
.btn-primary:hover { background: var(--ocean-700); border-color: var(--ocean-700);
                     box-shadow: var(--shadow-md); color: var(--white); text-decoration: none; }
.btn-cyan        { background: var(--cyan); color: var(--ocean); border-color: var(--cyan); }
.btn-cyan:hover  { background: var(--cyan-dark); color: var(--white); box-shadow: var(--shadow-cyan); }
.btn-secondary   { background: var(--surface); color: var(--text); border-color: var(--border); }
.btn-secondary:hover { background: var(--surface-alt); border-color: var(--text-light); }
.btn-danger      { background: var(--danger); color: var(--white); border-color: var(--danger); }
.btn-danger:hover{ background: var(--danger-dark); border-color: var(--danger-dark); color: var(--white); }
.btn-outline     { background: transparent; color: var(--ocean); border-color: var(--ocean); }
.btn-outline:hover { background: var(--cyan-xlight); color: var(--ocean); text-decoration: none; }
.btn-ghost       { background: transparent; color: var(--text-muted); border-color: transparent; }
.btn-ghost:hover { background: var(--surface-alt); color: var(--text); }

/* ── Inputs ─────────────────────────────────────────────────────── */
.form-control, input[type="text"], input[type="number"], input[type="date"],
input[type="email"], input[type="password"], input[type="search"], textarea, select {
  font-family: var(--font-body); font-size: 13px; color: var(--text);
  background: var(--surface); border: 1.5px solid var(--border);
  border-radius: var(--r-md); padding: 8px 12px; width: 100%;
  transition: border-color .15s, box-shadow .15s; outline: none;
}
.form-control:focus, input:focus, textarea:focus, select:focus {
  border-color: var(--cyan); box-shadow: 0 0 0 3px rgba(0,180,216,.15);
}
.form-control:hover, input:hover, textarea:hover, select:hover { border-color: var(--text-light); }
textarea { resize: vertical; min-height: 80px; font-family: var(--font-body); }

/* ── Cards / Panels ─────────────────────────────────────────────── */
.card, .detail-card, .settings-card, .report-card, .form-card, .action-card {
  background: var(--surface); border: 1px solid var(--border-soft);
  border-radius: var(--r-lg); padding: 20px 22px; box-shadow: var(--shadow-1);
}
.card-title    { font-family: var(--font-display); font-size: 16px; font-weight: 700;
                 color: var(--ocean); margin-bottom: 14px;
                 padding-bottom: 10px; border-bottom: 1.5px solid var(--border); }

/* ── Modal ──────────────────────────────────────────────────────── */
.modal-backdrop { position: fixed; inset: 0; background: rgba(10,37,64,.55);
                  backdrop-filter: blur(2px);
                  display: flex; align-items: center; justify-content: center; z-index: 1000; }
.modal-dialog   { background: var(--surface); border-radius: var(--radius-xl);
                  padding: 28px; min-width: 380px; max-width: 560px; width: 90vw;
                  box-shadow: var(--shadow-lg); }
.modal-header   { margin-bottom: 16px; }
.modal-header h3 { font-family: var(--font-display); font-size: 20px; font-weight: 700;
                   color: var(--ocean); }
.modal-body p   { color: var(--text-muted); margin-bottom: 22px; font-size: 14px; line-height: 1.6; }
.modal-footer   { display: flex; justify-content: flex-end; gap: 10px; margin-top: 20px; }

/* ── Data tables ────────────────────────────────────────────────── */
.table-card      { background: var(--surface); border: 1px solid var(--border-soft);
                   border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow-1); }
.data-table      { width: 100%; border-collapse: separate; border-spacing: 0; font-size: 13.5px; }
.data-table thead tr { background: var(--off-white); }
.data-table th   { padding: 12px 18px; text-align: left; font-size: 11.5px; font-weight: 500;
                   color: var(--muted); text-transform: uppercase;
                   letter-spacing: .12em; white-space: nowrap; cursor: default;
                   border-bottom: 1px solid var(--border-soft); }
.data-table th.sortable { cursor: pointer; user-select: none; }
.data-table th.sortable:hover { color: var(--ocean); }
.data-table th.sort-asc::after  { content:" ↑"; color: var(--cyan-600); }
.data-table th.sort-desc::after { content:" ↓"; color: var(--cyan-600); }
.data-row        { border-bottom: 1px solid var(--border-soft); transition: background .1s;
                   cursor: pointer; }
.data-row:last-child td { border-bottom: 0; }
.data-row:hover  { background: var(--off-white); }
.data-row td     { padding: 13px 18px; font-size: 13.5px; vertical-align: middle;
                   border-bottom: 1px solid var(--border-soft); }
.td-date         { color: var(--text-muted); white-space: nowrap; font-size: 12px; }
.td-main         { font-weight: 600; }
.td-main a       { color: var(--text); }
.td-main a:hover { color: var(--cyan-dark); }
.td-muted        { color: var(--text-muted); font-size: 12px; }
.td-num          { text-align: right; font-variant-numeric: tabular-nums; font-weight: 600; }
.td-center       { text-align: center; }
.td-right        { text-align: right; }
.td-mono         { font-family: var(--font-mono); font-size: 11px; color: var(--text-muted); }

/* ── Category chips / stock ─────────────────────────────────────── */
.cat-chip        { display: inline-flex; align-items: center; gap: 6px; font-size: 12px;
                   color: var(--text-muted); padding-left: 4px; }
.cat-chip::before{ content:''; display:inline-block; width:3px; height:14px;
                    border-radius:2px; background: currentColor; flex-shrink:0; }
.stock-qty       { font-weight: 700; font-size: 15px; }
.stock-low       { color: var(--danger); }

/* ── Filter bar (pills + tabs) ──────────────────────────────────── */
.filter-bar      { display: flex; justify-content: space-between; align-items: center;
                   margin-bottom: 18px; flex-wrap: wrap; gap: 12px; }
.filter-pills, .filter-tabs { display: flex; gap: 6px; flex-wrap: wrap; }
.filter-pill, .filter-tab {
  padding: 6px 12px; border-radius: 99px; font-size: 12.5px; font-weight: 500;
  cursor: pointer; border: 1px solid var(--border); background: var(--surface);
  color: var(--muted); transition: all .15s; display: inline-flex;
  align-items: center; gap: 6px;
}
.filter-pill:hover, .filter-tab:hover { border-color: var(--cyan); color: var(--ocean); }
.filter-pill.active, .filter-tab.active {
  background: var(--ocean); color: var(--white); border-color: var(--ocean);
}
.pill-count, .filter-count {
  display: inline-block; background: rgba(255,255,255,.18);
  border-radius: 99px; padding: 0 6px; margin-left: 2px; font-size: 11px;
  min-width: 18px; text-align: center;
}
.filter-pill:not(.active) .pill-count,
.filter-tab:not(.active)  .filter-count { background: var(--off-white); color: var(--muted); }
.filter-controls { display: flex; gap: 8px; align-items: center; }

/* ── Empty / Loading ────────────────────────────────────────────── */
.empty-state     { display: flex; flex-direction: column; align-items: center;
                   justify-content: center; min-height: 280px; gap: 14px;
                   color: var(--text-muted); text-align: center; padding: 40px 20px; }
.empty-state .material-icons { font-size: 52px !important; opacity: .35; }
.loading-spinner { display: flex; flex-direction: column; align-items: center;
                   justify-content: center; min-height: 300px; gap: 14px;
                   color: var(--text-muted); }
.spinning        { animation: spin 1.6s linear infinite; font-size: 40px !important;
                   color: var(--cyan) !important; }
@keyframes spin  { to { transform: rotate(360deg); } }

/* ── Sailing Loader (full-page) ─────────────────────────────────── */
.sailing-loader {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; gap: 14px; min-height: 320px;
  color: var(--text-muted);
}
.sailing-loader-stage {
  position: relative; width: 240px; height: 96px;
  overflow: hidden; border-radius: 12px;
  background: linear-gradient(180deg,
    transparent 0%,
    transparent 55%,
    rgba(202,233,255,.18) 55%,
    rgba(0,180,216,.10) 100%);
}
.sailing-loader-boat {
  position: absolute; left: 50%; bottom: 38px;
  transform: translateX(-50%);
  animation: sail-bob 2.6s ease-in-out infinite;
  transform-origin: 50% 100%;
  color: var(--ocean);
  filter: drop-shadow(0 2px 4px rgba(10,37,64,.18));
}
.sailing-loader-boat .material-icons {
  font-size: 48px !important;
  color: var(--ocean) !important;
}
.sailing-loader-waves {
  position: absolute; left: 0; right: 0; bottom: 0;
  width: 100%; height: 32px;
}
.sailing-loader-waves .wave {
  fill: var(--cyan);
}
.sailing-loader-waves .wave-back {
  fill: rgba(0,180,216,.18);
  animation: wave-slide 7s linear infinite;
}
.sailing-loader-waves .wave-mid {
  fill: rgba(0,180,216,.35);
  animation: wave-slide 5s linear infinite reverse;
}
.sailing-loader-waves .wave-front {
  fill: rgba(0,180,216,.55);
  animation: wave-slide 3.5s linear infinite;
}
.sailing-loader-label {
  font-size: 12px; color: var(--text-muted);
  letter-spacing: .3px;
}
@keyframes sail-bob {
  0%, 100% { transform: translate(-50%, 0)    rotate(-4deg); }
  25%      { transform: translate(-50%, -3px) rotate(0deg); }
  50%      { transform: translate(-50%, -6px) rotate( 4deg); }
  75%      { transform: translate(-50%, -3px) rotate(0deg); }
}
@keyframes wave-slide {
  from { transform: translateX(0); }
  to   { transform: translateX(-120px); }
}
@media (prefers-reduced-motion: reduce) {
  .sailing-loader-boat,
  .sailing-loader-waves .wave { animation: none !important; }
}

/* ── Breadcrumb ─────────────────────────────────────────────────── */
.breadcrumb      { display: flex; align-items: center; gap: 5px; margin-bottom: 20px;
                   font-size: 12px; color: var(--text-muted); }
.breadcrumb a    { color: var(--text-muted); }
.breadcrumb a:hover { color: var(--cyan-dark); }
.breadcrumb .material-icons { font-size: 14px; }

/* ── Detail layout ──────────────────────────────────────────────── */
.detail-layout   { display: grid; grid-template-columns: 1fr 280px; gap: 22px; align-items: start; }
.detail-main     { display: flex; flex-direction: column; gap: 16px; }
.detail-header   { padding-bottom: 18px; border-bottom: 1.5px solid var(--border); }
.detail-row      { display: flex; justify-content: space-between; align-items: baseline;
                   padding: 8px 0; border-bottom: 1px solid var(--border-light); font-size: 13px; }
.detail-row:last-child { border-bottom: none; }
.detail-label    { color: var(--text-muted); font-size: 12px; }
.detail-value    { font-weight: 600; text-align: right; }
.detail-section-title { font-size: 10.5px; font-weight: 700; text-transform: uppercase;
                        letter-spacing: .7px; color: var(--text-muted); margin-bottom: 12px; }
.detail-text     { font-size: 13px; line-height: 1.6; color: var(--text); }
.detail-sidebar  { display: flex; flex-direction: column; gap: 14px; position: sticky; top: 24px; }
.action-card     { padding: 16px; }
.field-grid      { display: flex; flex-direction: column; gap: 2px; }
.field-row       { display: flex; justify-content: space-between; align-items: baseline;
                   padding: 8px 0; border-bottom: 1px solid var(--border-light);
                   gap: 12px; font-size: 13px; }
.field-row:last-child { border-bottom: none; }
.field-label     { color: var(--text-muted); font-size: 12px; flex-shrink: 0; }
.field-value     { font-weight: 600; text-align: right; flex: 1;
                   display: flex; justify-content: flex-end; align-items: center;
                   gap: 6px; flex-wrap: wrap; }

/* ── Parts ──────────────────────────────────────────────────────── */
.parts-row       { display: flex; justify-content: space-between; align-items: center;
                   padding: 9px 0; border-bottom: 1px solid var(--border-light); font-size: 13px; }
.parts-row:last-child { border-bottom: none; }
.parts-used-list { display: flex; flex-direction: column; gap: 8px; }
.parts-used-row  { display: flex; align-items: center; gap: 10px; padding: 8px 12px;
                   background: var(--surface-alt); border-radius: var(--radius); font-size: 13px; }

/* ── History rows ───────────────────────────────────────────────── */
.history-row     { display: flex; align-items: flex-start; gap: 14px; padding: 12px 0;
                   border-bottom: 1px solid var(--border-light); font-size: 12px; }
.history-row:last-child { border-bottom: none; }
.history-date    { color: var(--text-muted); min-width: 95px; padding-top: 2px; font-weight: 600; }
.history-body    { flex: 1; }
.history-title   { font-weight: 600; color: var(--text); margin-bottom: 3px; font-size: 13px; }
.history-meta    { color: var(--text-muted); font-size: 11px; margin-bottom: 2px; }
.history-notes   { color: var(--text-muted); font-style: italic; margin-top: 4px; line-height: 1.5; }

/* ── Form layout ────────────────────────────────────────────────── */
.form-layout     { max-width: 760px; }
.form-card       { padding: 28px; }
.form-card h2    { font-family: var(--font-display); font-size: 20px; color: var(--ocean);
                   margin-bottom: 22px; }
.form-group      { margin-bottom: 18px; }
.form-row        { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.form-row-3      { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 18px; }
.form-label      { display: block; font-size: 11.5px; font-weight: 700; letter-spacing: .4px;
                   text-transform: uppercase; color: var(--text-muted); margin-bottom: 6px; }
.form-hint       { display: block; font-size: 11px; color: var(--text-light); margin-top: 4px; }
.form-error      { display: block; font-size: 11px; color: var(--danger); margin-top: 4px; }
.checkbox-label  { display: flex; align-items: center; gap: 9px; cursor: pointer; font-size: 13px; }
.form-actions    { display: flex; gap: 10px; padding-top: 14px;
                   border-top: 1px solid var(--border-light); margin-top: 14px; }

/* ── Settings ───────────────────────────────────────────────────── */
.settings-layout { display: grid; grid-template-columns: 220px 1fr; gap: 24px; align-items: start; }
.settings-nav    { background: var(--surface); border: 1px solid var(--border-light);
                   border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm);
                   position: sticky; top: 24px; }
.settings-nav-item { display: flex; align-items: center; gap: 10px; padding: 13px 18px;
                     font-size: 13px; font-weight: 500; color: var(--text-muted);
                     border-bottom: 1px solid var(--border-light); transition: all .15s;
                     text-decoration: none; }
.settings-nav-item:last-child { border-bottom: none; }
.settings-nav-item:hover  { background: var(--cyan-xlight); color: var(--ocean); text-decoration: none; }
.settings-nav-item.active { background: var(--cyan-xlight); color: var(--ocean);
                            font-weight: 700; border-left: 3px solid var(--cyan); }
.settings-content { display: flex; flex-direction: column; gap: 18px; }
.settings-card   { padding: 22px; }
.settings-card-title { font-family: var(--font-display); font-size: 16px; font-weight: 700;
                       color: var(--ocean); margin-bottom: 18px; padding-bottom: 12px;
                       border-bottom: 1.5px solid var(--border); }
.settings-info-row, .settings-row {
                     display: flex; justify-content: space-between; align-items: center;
                     padding: 10px 0; border-bottom: 1px solid var(--border-light); font-size: 13px; }
.settings-info-row:last-child, .settings-row:last-child { border-bottom: none; }
.settings-info-label { color: var(--text-muted); font-size: 12px; font-weight: 600;
                       text-transform: uppercase; letter-spacing: .4px; }

.cat-settings-row { display: flex; align-items: center; gap: 10px; padding: 10px 0;
                    border-bottom: 1px solid var(--border-light); }
.cat-settings-row:last-child { border-bottom: none; }
.cat-color-dot   { width: 14px; height: 14px; border-radius: 50%; flex-shrink: 0; }

/* ── Upload component ───────────────────────────────────────────── */
.upload-zone     { position: relative; border: 2px dashed var(--border);
                   border-radius: var(--radius-lg); padding: 26px;
                   text-align: center; transition: all .2s; margin-bottom: 14px;
                   background: var(--off-white); }
.upload-zone.dragging, .upload-zone:hover { border-color: var(--cyan);
                   background: var(--cyan-xlight); }
.upload-input    { position: absolute; inset: 0; opacity: 0; cursor: pointer; width: 100%; }
.upload-label    { display: flex; flex-direction: column; align-items: center; gap: 7px;
                   cursor: pointer; color: var(--text-muted); font-size: 13px; }
.upload-label .material-icons { font-size: 32px !important; color: var(--cyan); }
.attachment-list { display: flex; flex-direction: column; gap: 7px; }
.attachment-item { display: flex; align-items: center; gap: 11px; padding: 9px 14px;
                   background: var(--surface-alt); border-radius: var(--radius);
                   border: 1px solid var(--border-light); }
.attachment-icon { font-size: 18px !important; color: var(--text-muted); flex-shrink: 0; }
.attachment-body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.attachment-name { font-size: 13px; font-weight: 600; display: block; overflow: hidden;
                   text-overflow: ellipsis; white-space: nowrap; color: var(--text); }
.attachment-name:hover { color: var(--cyan-dark); }
.attachment-meta { font-size: 11px; color: var(--text-muted); }
.attachment-del  { flex-shrink: 0; opacity: .5; }
.attachment-del:hover { opacity: 1; }
.attachment-row  { display: flex; align-items: center; gap: 10px; padding: 8px 0;
                   border-bottom: 1px solid var(--border-light); }

/* ── Alerts page ────────────────────────────────────────────────── */
.alert-card      { display: flex; align-items: flex-start; gap: 16px;
                   background: var(--surface); border: 1px solid var(--border-light);
                   border-radius: var(--radius-lg); padding: 16px 18px;
                   border-left: 4px solid var(--border);
                   transition: opacity .2s; box-shadow: var(--shadow-sm); }
.alert-card.is-read { opacity: .6; }
.alert-card.severity-high   { border-left-color: var(--danger); }
.alert-card.severity-medium { border-left-color: var(--warning); }
.alert-card.severity-low    { border-left-color: var(--success); }
.alert-card-icon { flex-shrink: 0; margin-top: 2px; }
.alert-card-icon .material-icons { font-size: 22px !important; }
.alert-card.severity-high   .alert-card-icon { color: var(--danger); }
.alert-card.severity-medium .alert-card-icon { color: var(--warning-dark); }
.alert-card.severity-low    .alert-card-icon { color: var(--success); }
.alert-card-body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 4px; }
.alert-card-actions { display: flex; flex-direction: column; gap: 7px;
                      flex-shrink: 0; align-items: flex-end; }
.unread-dot      { width: 8px; height: 8px; border-radius: 50%;
                   background: var(--cyan); flex-shrink: 0; display: inline-block; }

/* ── Reports ────────────────────────────────────────────────────── */
.report-card     { padding: 20px; }
.report-card-title { font-family: var(--font-display); font-size: 15px; font-weight: 700;
                     color: var(--ocean); margin-bottom: 16px; }
.share-bar       { display: flex; align-items: center; gap: 8px; }
.share-fill      { height: 6px; border-radius: 3px; min-width: 2px; flex-shrink: 0; }
.share-pct       { font-size: 11px; color: var(--text-muted); min-width: 36px; }

/* ── Compliance ─────────────────────────────────────────────────── */
.compliance-section { margin-bottom: 28px; }
.compliance-table   { display: flex; flex-direction: column; gap: 7px; margin-top: 12px; }
.compliance-row  { display: flex; align-items: center; gap: 14px;
                   background: var(--surface); border: 1px solid var(--border-light);
                   border-radius: var(--radius-lg); padding: 14px 18px;
                   border-left: 3px solid var(--border); box-shadow: var(--shadow-sm); }
.compliance-row.urgency-overdue  { border-left-color: var(--danger); }
.compliance-row.urgency-duesoon  { border-left-color: var(--warning); }
.compliance-row.urgency-upcoming { border-left-color: var(--success); }
.compliance-left { flex-shrink: 0; }
.compliance-body { flex: 1; min-width: 0; }
.compliance-right { display: flex; align-items: center; flex-shrink: 0; gap: 8px; }

/* ── Expandable rows ────────────────────────────────────────────── */
.expand-icon     { font-size: 18px !important; color: var(--text-muted); vertical-align: middle; }
.expanded-row    { background: var(--cyan-xlight); }
.expanded-content { padding: 14px 18px 18px; }
.expanded-grid   { display: grid; grid-template-columns: repeat(4, 1fr);
                   gap: 14px; margin-bottom: 10px; font-size: 12px; }
.exp-label       { display: block; font-size: 10px; color: var(--text-muted);
                   text-transform: uppercase; letter-spacing: .4px; margin-bottom: 2px;
                   font-weight: 700; }
.exp-notes       { font-style: italic; color: var(--text-muted); font-size: 12px;
                   line-height: 1.6; margin-top: 8px; }

/* ── Logbook ────────────────────────────────────────────────────── */
.log-year-summary { display: flex; gap: 14px; align-items: center;
                    font-size: 13px; color: var(--text-muted); margin-bottom: 12px; }
.wind-chip       { display: inline-block; padding: 2px 8px; border-radius: 3px;
                   font-size: 11px; font-weight: 700; }
.wind-calm       { background: var(--success-light); color: var(--success); }
.wind-moderate   { background: var(--warning-light); color: var(--warning-dark); }
.wind-fresh      { background: #FFF0EB; color: var(--danger-dark); }
.wind-strong     { background: var(--danger-light); color: var(--danger-dark); }

/* ── Radio group ────────────────────────────────────────────────── */
.radio-group     { display: flex; gap: 8px; flex-wrap: wrap; }
.radio-option    { display: flex; align-items: center; gap: 8px; padding: 9px 16px;
                   border-radius: var(--radius); border: 1.5px solid var(--border);
                   cursor: pointer; font-size: 13px; transition: all .15s; font-weight: 500; }
.radio-option:hover    { border-color: var(--cyan); color: var(--ocean); }
.radio-option.selected { border-color: var(--ocean); background: var(--cyan-xlight);
                         color: var(--ocean); }
.radio-icon      { font-size: 16px; }

/* ── Not found ──────────────────────────────────────────────────── */
.not-found       { text-align: center; padding: 80px 24px; color: var(--text-muted); }
.not-found h2    { font-family: var(--font-display); font-size: 26px; margin-bottom: 14px;
                   color: var(--ocean); }

/* ── Utilities ──────────────────────────────────────────────────── */
.text-danger   { color: var(--danger) !important; }
.text-success  { color: var(--success) !important; }
.text-warning  { color: var(--warning-dark) !important; }
.text-muted    { color: var(--text-muted) !important; }
.text-ocean    { color: var(--ocean) !important; }
.text-cyan     { color: var(--cyan-dark) !important; }
.font-medium   { font-weight: 600; }
.font-bold     { font-weight: 700; }
.font-display  { font-family: var(--font-display); }
.font-mono     { font-family: var(--font-mono); }

/* ── Toasts (Blazored) — full NAUTICORE styling ─────────────────── */
.blazored-toast-container {
  position: fixed; z-index: 1100; display: flex; flex-direction: column;
  gap: 10px; padding: 20px; max-width: 380px; list-style: none; margin: 0;
}
.blazored-toast-container.position-bottomright { bottom: 0; right: 0; }
.blazored-toast-container.position-bottomleft  { bottom: 0; left: 0; }
.blazored-toast-container.position-topright     { top: 0; right: 0; }
.blazored-toast-container.position-topleft      { top: 0; left: 0; }

.blazored-toast {
  display: flex; align-items: flex-start; gap: 12px;
  background: var(--surface); color: var(--text);
  border: 1px solid var(--border-soft);
  border-left: 4px solid var(--cyan);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-3);
  padding: 14px 16px; font-family: var(--font-body); font-size: 13.5px;
  position: relative; overflow: hidden; cursor: pointer;
  animation: nc-toast-in .22s ease;
}
@keyframes nc-toast-in { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.blazored-toast-success { border-left-color: var(--success); }
.blazored-toast-error   { border-left-color: var(--danger); }
.blazored-toast-warning { border-left-color: var(--warning); }
.blazored-toast-info    { border-left-color: var(--cyan); }

.blazored-toast-icon { flex-shrink: 0; width: 22px; height: 22px; display: grid;
  place-items: center; border-radius: 99px; margin-top: 1px; }
.blazored-toast-success .blazored-toast-icon { background: var(--success-50); color: var(--success); }
.blazored-toast-error   .blazored-toast-icon { background: var(--danger-50);  color: var(--danger); }
.blazored-toast-warning .blazored-toast-icon { background: var(--warning-50); color: #B96A2C; }
.blazored-toast-info    .blazored-toast-icon { background: var(--cyan-50);    color: var(--cyan-600); }
.blazored-toast-icon svg { width: 14px; height: 14px; }

.blazored-toast-message { flex: 1; min-width: 0; line-height: 1.45; color: var(--text); }
.blazored-toast-message h5 { margin: 0 0 2px; font-family: var(--font-display);
  font-size: 14px; font-weight: 600; color: var(--ocean); }

.blazored-toast-close {
  background: none; border: 0; cursor: pointer; color: var(--muted-2);
  padding: 0 2px; font-size: 16px; line-height: 1; flex-shrink: 0;
}
.blazored-toast-close:hover { color: var(--ocean); }
.blazored-toast-close svg { width: 13px; height: 13px; }

/* progress bar (if enabled) */
.blazored-toast .blazored-toast-progressbar,
.blazored-toast-progress {
  position: absolute; left: 0; bottom: 0; height: 3px; background: var(--cyan);
  opacity: .5;
}

/* ── Responsive ─────────────────────────────────────────────────── */
@media (max-width: 1200px) {
  .task-table-header, .task-table-row {
    grid-template-columns: 2.4fr 1.2fr 1.3fr 1fr 1fr 90px 70px;
  }
}
@media (max-width: 1024px) {
  .summary-cards   { grid-template-columns: repeat(2, 1fr); }
  .detail-layout   { grid-template-columns: 1fr; }
  .settings-layout { grid-template-columns: 1fr; }
  .settings-nav    { position: static; }
  .detail-sidebar  { position: static; }
  .expanded-grid   { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .sidebar         { width: var(--sidebar-coll); }
  .sb-title, .nav-label, .sv-vessel { display: none; }
  .summary-cards   { grid-template-columns: 1fr 1fr; }
  .form-row, .form-row-3 { grid-template-columns: 1fr; }
  .page-body       { padding: 20px 16px; }
  .alert-banner    { padding: 12px 16px 0; }
  .task-table-header { display: none; }
  .task-table-row  { grid-template-columns: 1fr; gap: 6px; padding: 14px; }
  .vessel-metrics, .metrics { gap: 16px; }
}

/* ═══════════════════════════════════════════════════════════════════
   NAUTICORE Web — shell, dashboard & component library (design v2)
   ═══════════════════════════════════════════════════════════════════ */

/* ── App grid shell ─────────────────────────────────────────────── */
.nc-app          { display: grid; grid-template-columns: 260px 1fr; min-height: 100vh;
                   background: var(--canvas); }
.nc-app.compact  { grid-template-columns: 72px 1fr; }
.nc-main         { display: flex; flex-direction: column; min-width: 0; background: var(--canvas); }

/* ── Sidebar (NAUTICORE) ────────────────────────────────────────── */
.nc-sidebar      { background: var(--ocean); color: #E6EEF5; padding: 22px 16px;
                   display: flex; flex-direction: column; gap: 24px;
                   position: sticky; top: 0; height: 100vh; overflow-y: auto;
                   border-right: 1px solid rgba(255,255,255,.04); }
.nc-brand        { display: flex; align-items: center; gap: 12px;
                   padding: 6px 8px 18px; border-bottom: 1px solid rgba(255,255,255,.06); }
.brand-mark      { width: 38px; height: 38px; border-radius: 10px;
                   background: linear-gradient(135deg, var(--cyan) 0%, var(--cyan-600) 100%);
                   display: grid; place-items: center; color: #fff;
                   font-family: var(--font-display); font-weight: 600; font-size: 20px;
                   letter-spacing: .5px; box-shadow: inset 0 -2px 4px rgba(0,0,0,.15); flex-shrink: 0; }
.brand-name      { display: flex; flex-direction: column; line-height: 1.1; min-width: 0; }
.brand-name b    { font-family: var(--font-display); font-weight: 600; font-size: 18px;
                   letter-spacing: .3px; color: #fff; white-space: nowrap; }
.brand-name span { font-size: 11px; color: var(--cyan-light); letter-spacing: .16em;
                   text-transform: uppercase; opacity: .7; }
.brand-mark .nc-mark { display: block; }
.nc-topbar-logo  { display: inline-flex; align-items: center; color: var(--cyan-dark);
                   margin-right: -6px; flex-shrink: 0; }

.nc-section      { display: flex; flex-direction: column; gap: 2px; }
.nc-section-label{ font-size: 10.5px; text-transform: uppercase; letter-spacing: .18em;
                   color: rgba(202,233,255,.45); padding: 0 12px 8px; font-weight: 500; }

.nc-nav-item     { display: flex; align-items: center; gap: 12px; padding: 9px 12px;
                   border-radius: var(--r-md); font-size: 14px; color: rgba(230,238,245,.78);
                   cursor: pointer; transition: background .15s, color .15s; position: relative;
                   white-space: nowrap; text-decoration: none; }
.nc-nav-item:hover  { background: rgba(255,255,255,.04); color: #fff; text-decoration: none; }
.nc-nav-item.active { background: rgba(0,180,216,.13); color: #fff; }
.nc-nav-item.active::before { content:''; position:absolute; left:-16px; top:8px; bottom:8px;
                   width:3px; background: var(--cyan); border-radius: 0 3px 3px 0; }
.nc-nav-item .material-icons { font-size: 19px; flex-shrink: 0; }
.nc-nav-item .nc-nav-badge { margin-left: auto; background: var(--danger); color: #fff;
                   font-size: 10.5px; font-weight: 600; padding: 1px 7px; border-radius: 99px;
                   min-width: 18px; text-align: center; }

.nc-sidebar-vessel { margin-top: auto; padding: 14px; border-radius: var(--r-lg);
                   background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.06); }
.nc-vessel-head  { display: flex; align-items: center; gap: 10px; }
.nc-vessel-avatar{ width: 36px; height: 36px; border-radius: 8px;
                   background: linear-gradient(135deg, #1B3D5C, #2A5577);
                   display: grid; place-items: center; color: var(--cyan-light); flex-shrink: 0; }
.nc-vessel-meta b{ display: block; color: #fff; font-size: 13.5px; font-family: var(--font-display);
                   font-weight: 600; letter-spacing: .2px; }
.nc-vessel-meta span { font-size: 11px; color: rgba(202,233,255,.6); }
.nc-vessel-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 12px;
                   padding-top: 12px; border-top: 1px solid rgba(255,255,255,.06); }
.nc-vessel-stat .v { font-family: var(--font-display); font-size: 16px; font-weight: 600;
                   color: #fff; letter-spacing: .3px; }
.nc-vessel-stat .l { display: block; font-size: 10px; color: rgba(202,233,255,.55);
                   text-transform: uppercase; letter-spacing: .14em; margin-top: 1px; }
.nc-vessel-picker { margin-top: 12px; }
.nc-vessel-picker .rz-dropdown { background: rgba(255,255,255,.06) !important;
                   border: 1px solid rgba(0,180,216,.25) !important; color: #fff !important;
                   font-size: 12.5px !important; }
.nc-vessel-picker .rz-dropdown-label, .nc-vessel-picker .rz-inputtext { color: #fff !important; }

/* ── Topbar ─────────────────────────────────────────────────────── */
.nc-topbar       { background: var(--surface); border-bottom: 1px solid var(--border-soft);
                   padding: 14px 32px; display: flex; align-items: center; gap: 16px;
                   position: sticky; top: 0; z-index: 10; }
.nc-crumbs       { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--muted); }
.nc-crumbs .sep  { color: var(--border); }
.nc-crumbs .cur  { color: var(--text); font-weight: 500; }
.nc-topbar-search{ margin-left: auto; position: relative; width: 320px; max-width: 38vw; }
.nc-topbar-search input { width: 100%; height: 38px; padding: 0 14px 0 38px; border-radius: 99px;
                   border: 1px solid var(--border); background: var(--off-white); font-size: 13px;
                   transition: border .15s, background .15s, box-shadow .15s; }
.nc-topbar-search input:focus { outline: none; border-color: var(--cyan); background: #fff;
                   box-shadow: 0 0 0 3px var(--cyan-50); }
.nc-topbar-search .material-icons { position: absolute; left: 11px; top: 50%;
                   transform: translateY(-50%); color: var(--muted-2); font-size: 18px; }
.nc-icon-btn     { width: 38px; height: 38px; border-radius: 99px; border: 1px solid var(--border);
                   background: var(--surface); display: grid; place-items: center; cursor: pointer;
                   color: var(--ocean); position: relative; transition: background .15s, border-color .15s; }
.nc-icon-btn:hover { background: var(--cyan-50); border-color: var(--cyan-light); }
.nc-icon-btn .dot{ position: absolute; top: 8px; right: 9px; width: 8px; height: 8px;
                   background: var(--danger); border-radius: 99px; border: 2px solid #fff; }
.nc-avatar       { width: 38px; height: 38px; border-radius: 99px;
                   background: linear-gradient(135deg, var(--ocean), var(--ocean-600));
                   color: #fff; display: grid; place-items: center; font-weight: 500;
                   font-size: 13px; letter-spacing: .5px; }

/* ── Page chrome (NAUTICORE) ────────────────────────────────────── */
.nc-page         { padding: 28px 32px 64px; max-width: 1500px; margin: 0 auto; width: 100%; }
.nc-page-title   { font-family: var(--font-display); font-size: 32px; font-weight: 500;
                   letter-spacing: -.01em; margin: 0 0 4px; color: var(--ocean); }
.nc-page-sub     { margin: 0; font-size: 14px; color: var(--muted); }

/* ── Hero card ──────────────────────────────────────────────────── */
.hero            { position: relative; color: #fff; border-radius: var(--r-xl); padding: 28px 32px;
                   overflow: hidden;
                   background: radial-gradient(ellipse at top right, rgba(0,180,216,.18), transparent 60%),
                               linear-gradient(135deg, var(--ocean) 0%, #143A5E 100%); }
.hero::after     { content:''; position:absolute; right:-100px; top:-120px; width:360px; height:360px;
                   border-radius:50%; pointer-events:none;
                   background: radial-gradient(circle, rgba(202,233,255,.10) 0%, transparent 70%); }
.hero-eyebrow    { font-size: 11px; letter-spacing: .22em; text-transform: uppercase;
                   color: var(--cyan-light); opacity: .7; margin-bottom: 8px; }
.hero-name       { font-family: var(--font-display); font-size: 38px; font-weight: 500;
                   letter-spacing: -.01em; margin: 0; color: #fff; }
.hero-tag        { font-size: 14px; color: rgba(202,233,255,.78); margin-top: 2px; }
.hero-stats      { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-top: 28px;
                   padding-top: 22px; border-top: 1px solid rgba(255,255,255,.08); }
.hero-stat .v    { font-family: var(--font-display); font-size: 26px; font-weight: 500;
                   letter-spacing: .3px; display: block; }
.hero-stat .l    { font-size: 11px; letter-spacing: .16em; text-transform: uppercase;
                   color: rgba(202,233,255,.6); margin-top: 2px; }

/* ── Stat tiles ─────────────────────────────────────────────────── */
.stat-tile       { background: var(--surface); border-radius: var(--r-lg);
                   border: 1px solid var(--border-soft); padding: 20px 22px; position: relative;
                   overflow: hidden; text-decoration: none; color: inherit; display: block;
                   transition: transform .15s, box-shadow .15s; }
.stat-tile:hover { transform: translateY(-2px); box-shadow: var(--shadow-2); text-decoration: none; }
.stat-tile.accent{ background: linear-gradient(135deg, var(--ocean) 0%, #163E63 100%);
                   color: #fff; border-color: transparent; }
.stat-tile.accent .stat-label, .stat-tile.accent .stat-sub { color: rgba(202,233,255,.75); }
.stat-tile.accent .stat-value { color: #fff; }
.stat-label      { font-size: 11.5px; text-transform: uppercase; letter-spacing: .14em;
                   font-weight: 500; color: var(--muted); }
.stat-value      { font-family: var(--font-display); font-size: 36px; font-weight: 500;
                   margin: 8px 0 2px; color: var(--ocean); letter-spacing: -.01em; line-height: 1; }
.stat-value .unit{ font-size: 14px; color: var(--muted); font-weight: 400; margin-left: 4px;
                   font-family: var(--font-body); }
.stat-sub        { font-size: 12.5px; color: var(--muted); }

/* ── Cards (NAUTICORE) ──────────────────────────────────────────── */
.nc-card         { background: var(--surface); border-radius: var(--r-lg);
                   border: 1px solid var(--border-soft); box-shadow: var(--shadow-1); }
.nc-card-pad     { padding: 20px 22px; }
.nc-card-head    { display: flex; align-items: center; justify-content: space-between; gap: 14px;
                   padding: 16px 22px; border-bottom: 1px solid var(--border-soft); }
.nc-card-head h3 { margin: 0; font-family: var(--font-display); font-size: 17px; font-weight: 600;
                   color: var(--ocean); letter-spacing: .2px; line-height: 1.2; }
.nc-card-head .card-sub { font-size: 12.5px; color: var(--muted); margin-top: 2px; }

/* ── Pills ──────────────────────────────────────────────────────── */
.pill            { display: inline-flex; align-items: center; gap: 6px; padding: 3px 9px;
                   border-radius: 99px; font-size: 11.5px; font-weight: 500; letter-spacing: .01em;
                   background: var(--off-white); color: var(--muted); white-space: nowrap; }
.pill .dot       { width: 6px; height: 6px; border-radius: 99px; background: currentColor; }
.pill.overdue    { background: var(--danger-50); color: var(--danger); }
.pill.duesoon    { background: var(--warning-50); color: #B96A2C; }
.pill.ok         { background: var(--success-50); color: var(--success); }
.pill.cyan       { background: var(--cyan-50); color: var(--cyan-600); }
.pill.mandatory  { background: #FBEAF0; color: #B43764; }

/* ── Compliance ring ────────────────────────────────────────────── */
.ring            { --pct: .85; --c: var(--cyan); width: 120px; height: 120px; border-radius: 50%;
                   background: conic-gradient(var(--c) calc(var(--pct) * 360deg), var(--border-soft) 0);
                   display: grid; place-items: center; position: relative; }
.ring::after     { content:''; position:absolute; inset:8px; background: var(--surface); border-radius:50%; }
.ring .ring-label{ position: relative; z-index: 1; text-align: center; }
.ring .ring-pct  { font-family: var(--font-display); font-size: 26px; font-weight: 500;
                   color: var(--ocean); line-height: 1; }
.ring .ring-cap  { font-size: 11px; color: var(--muted); text-transform: uppercase;
                   letter-spacing: .12em; margin-top: 2px; }

/* ── Timeline ───────────────────────────────────────────────────── */
.timeline        { position: relative; padding-left: 28px; }
.timeline::before{ content:''; position:absolute; left:8px; top:4px; bottom:4px; width:1px; background: var(--border); }
.timeline-item   { position: relative; padding: 0 0 18px; }
.timeline-item::before { content:''; position:absolute; left:-25px; top:4px; width:11px; height:11px;
                   border-radius:99px; background: var(--surface); border: 2px solid var(--cyan); }
.timeline-item.done::before  { border-color: var(--success); background: var(--success); }
.timeline-item.alert::before { border-color: var(--danger); background: var(--danger); }
.timeline-item .ti-head { font-size: 13.5px; font-weight: 500; color: var(--ocean); margin-bottom: 2px; }
.timeline-item .ti-meta { font-size: 12px; color: var(--muted); }

/* ── Calendar ───────────────────────────────────────────────────── */
.cal             { background: var(--surface); border-radius: var(--r-lg);
                   border: 1px solid var(--border-soft); padding: 20px; }
.cal-head        { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.cal-month       { font-family: var(--font-display); font-size: 18px; font-weight: 600; color: var(--ocean); }
.cal-nav         { display: flex; gap: 4px; }
.cal-nav button  { width: 28px; height: 28px; border-radius: 6px; border: 1px solid var(--border);
                   background: var(--surface); display: grid; place-items: center; cursor: pointer;
                   color: var(--muted); }
.cal-nav button:hover { background: var(--off-white); color: var(--ocean); }
.cal-grid        { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; }
.cal-dow         { font-size: 10.5px; font-weight: 500; color: var(--muted-2); text-transform: uppercase;
                   letter-spacing: .12em; text-align: center; padding: 6px 0; }
.cal-day         { min-height: 40px; display: flex; flex-direction: column; align-items: center;
                   justify-content: center; border-radius: 8px; font-size: 13px; cursor: pointer;
                   color: var(--text); position: relative; gap: 3px; border: 1px solid transparent;
                   padding: 4px 0; }
.cal-day:hover   { background: var(--off-white); }
.cal-day.dim     { color: var(--border); cursor: default; }
.cal-day.today   { background: var(--cyan-50); color: var(--ocean); font-weight: 600; }
.cal-day.selected{ background: var(--ocean); color: #fff; font-weight: 500; }
.cal-day .marks  { display: flex; gap: 2px; height: 5px; }
.cal-day .mark   { width: 4px; height: 4px; border-radius: 99px; background: var(--cyan); }
.cal-day .mark.danger  { background: var(--danger); }
.cal-day .mark.warning { background: var(--warning); }
.cal-day .mark.voyage  { background: var(--success); }
.cal-day.selected .mark { background: var(--cyan-light); }
.cal-day-detail  { margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--border-soft); }
.cal-day-detail-empty { color: var(--muted); font-size: 13px; text-align: center; padding: 12px 0; }
.cal-event       { display: flex; align-items: center; gap: 10px; padding: 8px 0; font-size: 13px;
                   border-bottom: 1px solid var(--border-soft); }
.cal-event:last-child { border-bottom: 0; }
.ev-dot          { width: 8px; height: 8px; border-radius: 99px; flex-shrink: 0; background: var(--cyan); }
.ev-dot.danger   { background: var(--danger); }
.ev-dot.warning  { background: var(--warning); }
.ev-dot.voyage   { background: var(--success); }
.ev-dot.cyan     { background: var(--cyan); }
.cal-event .ev-title { flex: 1; color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cal-event a.ev-title:hover { color: var(--cyan-600); }

/* ── Sidebar compact mode (manual collapse) ─────────────────────── */
.nc-app.compact { grid-template-columns: 72px 1fr; }
.nc-app.compact .brand-name,
.nc-app.compact .nc-section-label,
.nc-app.compact .nc-nav-item span:not(.material-icons):not(.nc-nav-badge),
.nc-app.compact .nc-sidebar-vessel,
.nc-app.compact .nc-vessel-picker { display: none; }
.nc-app.compact .nc-nav-item { justify-content: center; padding: 9px; }
.nc-app.compact .nc-brand { justify-content: center; }

/* ── Notification bell dropdown ─────────────────────────────────── */
.nc-bell-wrap    { position: relative; }
.nc-bell-backdrop{ position: fixed; inset: 0; z-index: 40; }
.nc-bell-menu    { position: absolute; top: 46px; right: 0; width: 320px; z-index: 50;
                   background: var(--surface); border: 1px solid var(--border-soft);
                   border-radius: var(--r-lg); box-shadow: var(--shadow-3); overflow: hidden; }
.nc-bell-head    { display: flex; align-items: center; justify-content: space-between;
                   padding: 12px 16px; border-bottom: 1px solid var(--border-soft);
                   font-family: var(--font-display); font-weight: 600; color: var(--ocean); font-size: 15px; }
.nc-bell-empty   { padding: 24px 16px; text-align: center; color: var(--muted); font-size: 13px; }
.nc-bell-item    { display: flex; align-items: flex-start; gap: 10px; padding: 11px 16px;
                   border-bottom: 1px solid var(--border-soft); transition: background .12s; }
.nc-bell-item:hover { background: var(--off-white); text-decoration: none; }
.nc-bell-item .ev-dot { margin-top: 5px; }
.nc-bell-title   { font-size: 13px; font-weight: 500; color: var(--ocean);
                   overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.nc-bell-meta    { font-size: 11.5px; color: var(--muted); }
.nc-bell-foot    { display: block; padding: 11px 16px; text-align: center; font-size: 12.5px;
                   font-weight: 500; color: var(--cyan-600); }
.nc-bell-foot:hover { background: var(--off-white); }

/* ── AIS panel ──────────────────────────────────────────────────── */
.ais-frame       { position: relative; width: 100%; height: 286px;
                   background: var(--off-white); border-top: 1px solid var(--border-soft);
                   overflow: hidden; border-radius: 0 0 var(--r-lg) var(--r-lg); }
.ais-frame iframe{ position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }

/* ── Dashboard grids ────────────────────────────────────────────── */
.dash-stats      { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin: 20px 0; }
.dash-cols       { display: grid; grid-template-columns: 1.6fr 1fr; gap: 20px; align-items: start; }

@media (max-width: 1100px) {
  .nc-app        { grid-template-columns: 72px 1fr; }
  .nc-sidebar .brand-name, .nc-sidebar .nc-section-label, .nc-vessel-picker,
  .nc-sidebar .nc-nav-item span:not(.material-icons):not(.nc-nav-badge),
  .nc-sidebar-vessel { display: none; }
  .nc-sidebar .nc-nav-item { justify-content: center; padding: 9px; }
  .dash-stats    { grid-template-columns: repeat(2, 1fr); }
  .dash-cols     { grid-template-columns: 1fr; }
  .hero-stats    { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 720px) {
  .nc-topbar-search { display: none; }
  .nc-page       { padding: 20px 16px 48px; }
}

/* ── Auth screens (login / access-denied) ───────────────────────── */
.nc-auth-shell   { position: relative; min-height: 100vh; display: grid;
                   place-items: center; padding: 24px;
                   background: linear-gradient(160deg, var(--ocean) 0%, var(--ocean-700) 55%, var(--ocean-600) 100%);
                   overflow: hidden; }
.nc-auth-bg      { position: absolute; inset: 0; pointer-events: none;
                   background:
                     radial-gradient(420px 420px at 85% 10%, rgba(0,180,216,.20), transparent 60%),
                     radial-gradient(520px 520px at 10% 95%, rgba(0,180,216,.14), transparent 60%); }
.nc-auth-card    { position: relative; z-index: 1; width: 100%; max-width: 400px;
                   background: var(--surface); border: 1px solid var(--border-light);
                   border-radius: var(--radius-xl); box-shadow: var(--shadow-lg);
                   padding: 34px 32px 30px; }
.nc-auth-brand   { display: flex; align-items: center; gap: 11px; margin-bottom: 22px; }
.nc-auth-mark    { width: 46px; height: 46px; border-radius: var(--radius-lg);
                   display: grid; place-items: center; color: #fff;
                   background: linear-gradient(135deg, var(--cyan), var(--cyan-dark));
                   box-shadow: var(--shadow-cyan); }
.nc-auth-mark--warn { background: linear-gradient(135deg, var(--danger), var(--danger-dark)); }
.nc-auth-mark--warn .material-icons { font-size: 26px; }
.nc-auth-appname { font-family: var(--font-display); font-size: 20px; font-weight: 600;
                   color: var(--ocean); letter-spacing: -.2px; }
.nc-auth-title   { font-family: var(--font-display); font-size: 25px; color: var(--ocean);
                   margin: 0; }
.nc-auth-sub     { color: var(--text-muted); font-size: 13px; margin: 4px 0 20px; }
.nc-auth-error   { display: flex; align-items: center; gap: 9px; margin-bottom: 18px;
                   padding: 10px 13px; font-size: 13px; border-radius: var(--radius-lg);
                   background: var(--danger-light); color: var(--danger-dark);
                   border: 1px solid #FAD3C4; }
.nc-auth-error .material-icons { font-size: 18px; }
.nc-auth-form    { display: flex; flex-direction: column; gap: 15px; }
.nc-auth-field   { display: flex; flex-direction: column; gap: 6px; }
.nc-auth-field span { font-size: 12px; font-weight: 600; color: var(--text-muted);
                   text-transform: uppercase; letter-spacing: .4px; }
.nc-auth-field input { padding: 11px 13px; border: 1px solid var(--border);
                   border-radius: var(--radius-lg); font-size: 14px; color: var(--text);
                   background: var(--surface); transition: border-color .15s, box-shadow .15s; }
.nc-auth-field input:focus { outline: none; border-color: var(--cyan);
                   box-shadow: 0 0 0 3px var(--cyan-xlight); }
.nc-auth-submit  { display: inline-flex; align-items: center; justify-content: center;
                   gap: 8px; margin-top: 6px; padding: 12px 16px; width: 100%;
                   border: none; border-radius: var(--radius-lg); cursor: pointer;
                   font-size: 14px; font-weight: 600; color: #fff;
                   background: linear-gradient(135deg, var(--cyan), var(--cyan-dark));
                   box-shadow: var(--shadow-cyan); transition: filter .15s, transform .05s; }
.nc-auth-submit:hover  { filter: brightness(1.05); }
.nc-auth-submit:active { transform: translateY(1px); }
.nc-auth-submit .material-icons { font-size: 19px; }
.nc-auth-submit--ghost { background: var(--ocean); box-shadow: var(--shadow-md); }
.nc-auth-actions { display: flex; flex-direction: column; gap: 12px; margin-top: 6px; }
.nc-auth-link    { background: none; border: none; cursor: pointer; color: var(--cyan-dark);
                   font-size: 13px; padding: 4px; }
.nc-auth-link:hover { text-decoration: underline; }

/* ── Topbar user menu ───────────────────────────────────────────── */
.nc-user-wrap    { position: relative; }
.nc-user-wrap .nc-avatar { border: none; cursor: pointer; }
.nc-user-menu    { position: absolute; top: 46px; right: 0; width: 256px; z-index: 50;
                   background: var(--surface); border: 1px solid var(--border-light);
                   border-radius: var(--radius-lg); box-shadow: var(--shadow-lg);
                   padding: 6px; }
.nc-user-head    { display: flex; align-items: center; gap: 11px; padding: 12px 12px 11px; }
.nc-user-avatar  { width: 40px; height: 40px; border-radius: 99px; flex: none;
                   background: linear-gradient(135deg, var(--ocean), var(--ocean-600));
                   color: #fff; display: grid; place-items: center; font-weight: 500;
                   font-size: 14px; letter-spacing: .5px; }
.nc-user-name    { font-weight: 600; color: var(--text); font-size: 14px;
                   white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.nc-user-mail    { color: var(--text-muted); font-size: 12px;
                   white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.nc-user-roles   { display: flex; flex-wrap: wrap; gap: 5px; padding: 0 12px 10px; }
.nc-role-chip    { font-size: 11px; font-weight: 600; padding: 2px 9px; border-radius: 99px;
                   background: var(--cyan-xlight); color: var(--cyan-dark); }
.nc-user-menu hr { border: none; border-top: 1px solid var(--border-light); margin: 4px 0; }
.nc-user-item    { display: flex; align-items: center; gap: 10px; width: 100%;
                   padding: 10px 12px; border: none; background: none; cursor: pointer;
                   border-radius: var(--radius); font-size: 13px; color: var(--text);
                   text-align: left; }
.nc-user-item:hover { background: var(--off-white); text-decoration: none; }
.nc-user-item .material-icons { font-size: 18px; color: var(--text-muted); }
.nc-user-logoutform { margin: 0; border-top: 1px solid var(--border-light); margin-top: 4px;
                   padding-top: 4px; }
.nc-user-logout  { color: var(--danger-dark); }
.nc-user-logout .material-icons { color: var(--danger-dark); }

/* ── User management (/settings/users) ──────────────────────────── */
.users-head      { display: flex; align-items: center; justify-content: space-between;
                   margin-bottom: 16px; gap: 12px; }
.users-table     { width: 100%; border-collapse: collapse; font-size: 13px; }
.users-table th  { text-align: left; font-size: 11px; font-weight: 600; letter-spacing: .4px;
                   text-transform: uppercase; color: var(--text-muted);
                   padding: 8px 12px; border-bottom: 1px solid var(--border); }
.users-table td  { padding: 12px; border-bottom: 1px solid var(--border-light);
                   vertical-align: middle; color: var(--text); }
.users-table tr.is-inactive td { opacity: .55; }
.users-table .ta-right { text-align: right; }
.u-name          { font-weight: 600; color: var(--text); }
.u-mail          { color: var(--text-muted); }
.u-flag          { display: inline-block; margin-top: 3px; font-size: 11px; font-weight: 600;
                   color: var(--danger-dark); background: var(--danger-light);
                   padding: 1px 7px; border-radius: 99px; }
.u-vessels       { color: var(--text); }
.u-allfleet      { color: var(--cyan-dark); font-weight: 600; }
.u-novessel      { color: var(--text-light); font-style: italic; }
.role-chip       { display: inline-block; font-size: 11px; font-weight: 700; padding: 3px 10px;
                   border-radius: 99px; letter-spacing: .3px; }
.role-admin      { background: var(--cyan-xlight); color: var(--cyan-dark); }
.role-crew       { background: #EAF0F6; color: var(--ocean-600); }
.role-guest      { background: #F0F2F5; color: var(--text-muted); }
.status-dot      { display: inline-block; width: 8px; height: 8px; border-radius: 99px;
                   margin-right: 6px; vertical-align: middle; }
.status-dot.ok   { background: #2BB673; }
.status-dot.off  { background: var(--text-light); }
.btn-icon        { display: inline-grid; place-items: center; width: 32px; height: 32px;
                   border: 1px solid var(--border); border-radius: var(--radius);
                   background: var(--surface); cursor: pointer; color: var(--text-muted); }
.btn-icon:hover  { background: var(--cyan-50); border-color: var(--cyan-light); color: var(--cyan-dark); }
.btn-icon .material-icons { font-size: 18px; }

/* ── Modal (used by user editor) ────────────────────────────────── */
.nc-modal-backdrop { position: fixed; inset: 0; z-index: 200; background: rgba(10,37,64,.45); }
.nc-modal        { position: fixed; z-index: 201; top: 50%; left: 50%;
                   transform: translate(-50%, -50%); width: min(480px, calc(100vw - 32px));
                   max-height: calc(100vh - 48px); display: flex; flex-direction: column;
                   background: var(--surface); border-radius: var(--radius-xl);
                   box-shadow: var(--shadow-lg); overflow: hidden; }
.nc-modal-head   { display: flex; align-items: center; justify-content: space-between;
                   padding: 16px 20px; border-bottom: 1px solid var(--border-light); }
.nc-modal-head h3 { margin: 0; font-family: var(--font-display); font-size: 19px; color: var(--ocean); }
.nc-modal-body   { padding: 18px 20px; overflow-y: auto; display: flex; flex-direction: column; gap: 14px; }
.nc-modal-foot   { display: flex; justify-content: flex-end; gap: 10px;
                   padding: 14px 20px; border-top: 1px solid var(--border-light);
                   background: var(--off-white); }
.form-note       { font-size: 13px; color: var(--text-muted); padding: 10px 12px;
                   background: var(--cyan-xlight); border-radius: var(--radius-lg); }
.form-error      { font-size: 13px; color: var(--danger-dark); background: var(--danger-light);
                   border: 1px solid #FAD3C4; padding: 10px 12px; border-radius: var(--radius-lg); }
