:root{
  --teal:#45C8E0;--teal-dark:#28A8C4;--teal-light:#AEE8F5;
  --mint:#A8D5B5;--mint-dark:#7BB88A;
  --coral:#D97272;--coral-dark:#C05050;
  --salmon:#E8946A;--salmon-dark:#CC7044;
  --yellow:#EDE87A;--yellow-dark:#C8C428;
  --gray:#9AA0A6;--gray-light:#C8CDD0;
  --navy:#18384A;--navy-light:#3D5166;
  --white:#fff;--off-white:#F4FBFD;
  --border:#D8EEF5;--text:#18384A;--text-muted:#6B7A8A;
  --shadow-sm:0 2px 8px rgba(43,58,74,.08);
  --shadow-md:0 4px 20px rgba(43,58,74,.12);
  --shadow-lg:0 8px 40px rgba(43,58,74,.16);
  --r:12px;--r-sm:8px;--r-lg:20px;
  --sidebar:260px;--topbar:64px;--tr:.2s ease;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;font-size:14px;color:var(--text);background:var(--off-white);line-height:1.6;-webkit-font-smoothing:antialiased}

/* ── LAYOUT ── */
.app-wrapper{display:flex;min-height:100vh}

/* ── SIDEBAR ── */
.sidebar{width:var(--sidebar);background:var(--navy);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:1000;transition:transform var(--tr);overflow:hidden}
.sidebar-header{display:flex;align-items:center;gap:10px;padding:0 18px;height:72px;border-bottom:1px solid rgba(255,255,255,.08);position:relative;flex-shrink:0}
.logo-mark{width:36px;height:36px;background:conic-gradient(var(--teal) 0 60deg,var(--mint) 60deg 120deg,var(--yellow) 120deg 180deg,var(--coral) 180deg 240deg,var(--salmon) 240deg 300deg,var(--gray-light) 300deg 360deg);border-radius:50%;flex-shrink:0;position:relative}
.logo-mark::after{content:'';position:absolute;inset:8px;background:var(--navy);border-radius:50%}
.sidebar-logo{max-width:170px;max-height:44px;object-fit:contain;filter:brightness(0) invert(1);opacity:.9}
.brand{display:flex;flex-direction:column;line-height:1.2}
.brand-main{font-family:'Playfair Display',serif;font-size:17px;font-weight:700;color:#fff;letter-spacing:.5px}
.brand-sub{font-size:10px;color:var(--teal-light);letter-spacing:1.5px;text-transform:uppercase}
.sidebar-close{display:none;background:none;border:none;color:var(--gray);font-size:18px;cursor:pointer;padding:4px;position:absolute;right:12px;top:50%;transform:translateY(-50%)}
.sidebar-nav{flex:1;padding:14px 12px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}
.nav-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:var(--r-sm);color:rgba(255,255,255,.6);text-decoration:none;font-size:14px;font-weight:400;transition:all var(--tr)}
.nav-item i{width:18px;text-align:center;font-size:15px;flex-shrink:0}
.nav-item:hover{background:rgba(255,255,255,.08);color:#fff}
.nav-item.active{background:var(--teal);color:#fff;font-weight:500}
.nav-public{opacity:.75!important}
.nav-ext{font-size:10px!important;margin-left:auto!important;opacity:.6}
.nav-divider{border-top:1px solid rgba(255,255,255,.08);margin:8px 0}
.sidebar-footer{padding:14px 16px;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:10px;flex-shrink:0}
.admin-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}
.admin-avatar{width:34px;height:34px;background:var(--teal);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;flex-shrink:0}
.admin-details{display:flex;flex-direction:column;min-width:0}
.admin-name{font-size:13px;font-weight:500;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.admin-role{font-size:10px;color:var(--gray);text-transform:uppercase;letter-spacing:1px}
.btn-logout{color:var(--gray);font-size:16px;text-decoration:none;padding:6px;border-radius:6px;transition:color var(--tr)}
.btn-logout:hover{color:var(--coral)}

/* ── OVERLAY ── */
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:999}

/* ── MAIN ── */
.main-content{margin-left:var(--sidebar);flex:1;min-width:0;display:flex;flex-direction:column;min-height:100vh}

/* ── TOPBAR ── */
.topbar{height:var(--topbar);background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:16px;padding:0 24px;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm)}
.menu-toggle{display:none;background:none;border:none;font-size:20px;color:var(--text-muted);cursor:pointer;padding:6px;border-radius:6px}
.menu-toggle:hover{background:var(--off-white)}
.topbar-title{font-family:'Playfair Display',serif;font-size:20px;font-weight:600;flex:1}
.topbar-actions{display:flex;align-items:center;gap:16px}
.topbar-date{font-size:13px;color:var(--text-muted);white-space:nowrap}
.btn-new{background:var(--teal);color:#fff;text-decoration:none;padding:8px 16px;border-radius:var(--r-sm);font-size:13px;font-weight:500;display:flex;align-items:center;gap:7px;transition:background var(--tr);white-space:nowrap}
.btn-new:hover{background:var(--teal-dark)}

/* ── PAGE BODY ── */
.page-body{padding:28px 28px 40px;flex:1}

/* ── STAT CARDS ── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:18px;margin-bottom:26px}
.stat-card{background:#fff;border-radius:var(--r);padding:22px;box-shadow:var(--shadow-sm);border:1px solid var(--border);position:relative;overflow:hidden}
.stat-card::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%}
.stat-card.teal::before{background:var(--teal)}.stat-card.mint::before{background:var(--mint)}
.stat-card.coral::before{background:var(--coral)}.stat-card.salmon::before{background:var(--salmon)}
.stat-card.yellow::before{background:var(--yellow-dark)}
.stat-icon{font-size:26px;margin-bottom:12px}
.stat-card.teal .stat-icon{color:var(--teal)}.stat-card.mint .stat-icon{color:var(--mint-dark)}
.stat-card.coral .stat-icon{color:var(--coral)}.stat-card.salmon .stat-icon{color:var(--salmon)}
.stat-card.yellow .stat-icon{color:var(--yellow-dark)}
.stat-value{font-family:'Playfair Display',serif;font-size:30px;font-weight:700;line-height:1;margin-bottom:4px}
.stat-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;font-weight:500}

/* ── CARD ── */
.card{background:#fff;border-radius:var(--r);box-shadow:var(--shadow-sm);border:1px solid var(--border);overflow:hidden}
.card-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}
.card-title{font-family:'Playfair Display',serif;font-size:17px;font-weight:600}
.card-body{padding:20px}

/* ── GRID ── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}

/* ── TABLE ── */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;min-width:580px}
thead th{background:var(--off-white);color:var(--text-muted);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;padding:10px 14px;text-align:left;border-bottom:2px solid var(--border);white-space:nowrap}
tbody tr{border-bottom:1px solid var(--border);transition:background var(--tr)}
tbody tr:hover{background:var(--off-white)}
tbody tr:last-child{border-bottom:none}
td{padding:12px 14px;font-size:14px;vertical-align:middle}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}
.badge-confirmed{background:#e6f7f6;color:var(--teal-dark)}
.badge-pending{background:#fefbde;color:#8a7f00}
.badge-cancelled{background:#fce8e8;color:var(--coral-dark)}
.badge-completed{background:#e8f5eb;color:var(--mint-dark)}
.badge-half_day{background:#e8f5eb;color:var(--mint-dark)}
.badge-full_day{background:#e6f7f6;color:var(--teal-dark)}
.badge-custom{background:#fef0e8;color:var(--salmon-dark)}
.badge-active{background:#e6f7f6;color:var(--teal-dark)}
.badge-inactive{background:#f0f0f0;color:var(--gray)}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:var(--r-sm);font-size:13px;font-weight:500;cursor:pointer;border:none;text-decoration:none;transition:all var(--tr);white-space:nowrap;font-family:'DM Sans',sans-serif}
.btn-primary{background:var(--teal);color:#fff}.btn-primary:hover{background:var(--teal-dark)}
.btn-secondary{background:var(--off-white);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}
.btn-danger{background:var(--coral);color:#fff}.btn-danger:hover{background:var(--coral-dark)}
.btn-success{background:var(--mint-dark);color:#fff}.btn-success:hover{background:#5f9b6e}
.btn-warning{background:var(--yellow-dark);color:var(--navy)}.btn-warning:hover{background:#a8a020}
.btn-sm{padding:5px 12px;font-size:12px}
.btn-group{display:flex;gap:8px;flex-wrap:wrap}
.action-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;border:none;cursor:pointer;font-size:13px;text-decoration:none;transition:all var(--tr)}
.action-edit{background:#e6f7f6;color:var(--teal-dark)}.action-edit:hover{background:var(--teal);color:#fff}
.action-delete{background:#fce8e8;color:var(--coral-dark)}.action-delete:hover{background:var(--coral);color:#fff}
.action-view{background:#e8e8fe;color:#4050cc}.action-view:hover{background:#4050cc;color:#fff}

/* ── FORMS ── */
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:13px;font-weight:500;margin-bottom:6px}
.req{color:var(--coral);margin-left:2px}
.form-control{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:14px;font-family:'DM Sans',sans-serif;color:var(--text);background:#fff;transition:border-color var(--tr),box-shadow var(--tr);outline:none}
.form-control:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(94,196,192,.15)}
textarea.form-control{resize:vertical;min-height:90px}
.form-hint{font-size:12px;color:var(--text-muted);margin-top:4px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}

/* ── ALERTS ── */
.alert{padding:12px 16px;border-radius:var(--r-sm);font-size:14px;margin-bottom:18px;display:flex;align-items:flex-start;gap:10px}
.alert-success{background:#e8f5eb;color:var(--mint-dark);border:1px solid #b3debb}
.alert-error{background:#fce8e8;color:var(--coral-dark);border:1px solid #f0b8b8}
.alert-info{background:#e6f7f6;color:var(--teal-dark);border:1px solid var(--teal-light)}
.alert-warning{background:#fefbde;color:#7a6f00;border:1px solid #e0d960}

/* ── MODAL ── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:2000;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:var(--r-lg);width:100%;max-width:580px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:mIn .2s ease}
@keyframes mIn{from{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:none}}
.modal-header{padding:18px 22px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:#fff;z-index:1}
.modal-title{font-family:'Playfair Display',serif;font-size:17px;font-weight:600}
.modal-close{background:none;border:none;font-size:20px;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:6px;line-height:1}
.modal-close:hover{color:var(--coral);background:#fce8e8}
.modal-body{padding:20px 22px}
.modal-footer{padding:14px 22px 18px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}

/* ── FILTERS ── */
.filters-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.search-box{position:relative;flex:1;min-width:180px}
.search-box i{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:14px}
.search-box input{padding-left:36px}

/* ── CALENDAR ── */
.fc .fc-toolbar-title{font-family:'Playfair Display',serif;font-size:17px}
.fc .fc-button-primary{background:var(--teal)!important;border-color:var(--teal)!important;font-family:'DM Sans',sans-serif}
.fc .fc-button-primary:hover,.fc .fc-button-primary:not(:disabled).fc-button-active{background:var(--teal-dark)!important;border-color:var(--teal-dark)!important}
.fc .fc-daygrid-day.fc-day-today{background:rgba(94,196,192,.07)!important}
.fc-event{cursor:pointer}

/* ── PAGE HEADER ── */
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:22px;gap:14px;flex-wrap:wrap}
.page-header h1{font-family:'Playfair Display',serif;font-size:24px;font-weight:700;margin-bottom:3px}
.page-header p{color:var(--text-muted);font-size:14px}

/* ── PACKAGE CARDS ── */
.pkg-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:20px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.pkg-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px}
.pkg-card.half_day::before{background:var(--mint-dark)}
.pkg-card.full_day::before{background:var(--teal)}
.pkg-card.custom::before{background:var(--salmon)}
.pkg-type{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}
.pkg-name{font-family:'Playfair Display',serif;font-size:18px;font-weight:600;margin-bottom:6px}
.pkg-price{font-size:24px;font-weight:700;color:var(--teal);margin-bottom:4px}
.pkg-duration{font-size:13px;color:var(--text-muted)}

/* ── BOATS ── */
.boats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px}
.boat-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform var(--tr),box-shadow var(--tr)}
.boat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.boat-img{height:150px;display:flex;align-items:center;justify-content:center;font-size:46px;position:relative}
.boat-body{padding:14px}
.boat-name{font-family:'Playfair Display',serif;font-size:16px;font-weight:600;margin-bottom:6px}
.boat-meta{display:flex;gap:12px;margin-bottom:10px;flex-wrap:wrap}
.boat-meta-item{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-muted)}
.boat-actions{display:flex;gap:8px;padding-top:10px;border-top:1px solid var(--border)}

/* ── CREW CARDS ── */
.crew-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}

/* ── REPORT ── */
.report-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:22px}
.report-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:16px;text-align:center}
.report-value{font-family:'Playfair Display',serif;font-size:26px;font-weight:700;color:var(--teal)}
.report-label{font-size:12px;color:var(--text-muted);margin-top:4px;text-transform:uppercase;letter-spacing:.7px}

/* ── CREW CHECKBOX LIST ── */
.crew-checklist{border:1.5px solid var(--border);border-radius:var(--r-sm);overflow:hidden}
.crew-check-item{display:flex;align-items:center;gap:12px;padding:10px 14px;cursor:pointer;transition:background var(--tr);border-bottom:1px solid var(--border)}
.crew-check-item:last-child{border-bottom:none}
.crew-check-item:hover{background:rgba(94,196,192,.06)}
.crew-check-item input[type=checkbox]{width:17px;height:17px;accent-color:var(--teal);flex-shrink:0;cursor:pointer}

/* ── LOGIN ── */
.login-page{min-height:100vh;background:var(--navy);display:flex;align-items:center;justify-content:center;padding:20px;position:relative;overflow:hidden}
.login-page::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 20% 30%,rgba(94,196,192,.15) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(237,232,122,.08) 0%,transparent 50%)}
.login-card{background:#fff;border-radius:var(--r-lg);padding:38px;width:100%;max-width:420px;position:relative;z-index:1;box-shadow:var(--shadow-lg)}
.login-logo{text-align:center;margin-bottom:26px}
.login-logo img{max-width:220px;height:auto}
.login-logo-mark{width:60px;height:60px;background:conic-gradient(var(--teal) 0 60deg,var(--mint) 60deg 120deg,var(--yellow) 120deg 180deg,var(--coral) 180deg 240deg,var(--salmon) 240deg 300deg,var(--gray-light) 300deg 360deg);border-radius:50%;margin:0 auto 12px;position:relative}
.login-logo-mark::after{content:'';position:absolute;inset:12px;background:#fff;border-radius:50%}
.login-logo-name{font-family:'Playfair Display',serif;font-size:22px;font-weight:700}
.login-logo-sub{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;margin-top:3px}
.login-heading{text-align:center;margin-bottom:24px}
.login-heading h2{font-family:'Playfair Display',serif;font-size:19px;font-weight:600;margin-bottom:4px}
.login-heading p{font-size:13px;color:var(--text-muted)}

/* ── PAGINATION ── */
.pagination{display:flex;align-items:center;gap:5px;justify-content:center;margin-top:18px}
.page-link{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:6px;border:1px solid var(--border);font-size:13px;color:var(--text);text-decoration:none;transition:all var(--tr);background:#fff}
.page-link:hover,.page-link.active{background:var(--teal);color:#fff;border-color:var(--teal)}
.page-link.active{font-weight:600}

/* ── EMPTY STATE ── */
.empty-state{text-align:center;padding:44px 20px;color:var(--text-muted)}
.empty-state i{font-size:44px;margin-bottom:14px;display:block;color:var(--border)}
.empty-state h3{font-size:17px;font-weight:500;margin-bottom:6px;color:var(--text)}

/* ── SORT LINK ── */
a.sort-link{text-decoration:none;color:inherit}
a.sort-link:hover{color:var(--teal)}
a.sort-link.active-sort{color:var(--teal);font-weight:600}

/* ── PRINT ── */
@media print{.sidebar,.topbar,.btn,.btn-group,.action-btn,.filters-bar,.no-print{display:none!important}.main-content{margin-left:0!important}.page-body{padding:0!important}.card{box-shadow:none!important}}

/* ── RESPONSIVE ── */
@media(max-width:1024px){.grid-2{grid-template-columns:1fr}.grid-3{grid-template-columns:1fr 1fr}}
@media(max-width:768px){
  .sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}
  .sidebar-close{display:block}.sidebar-overlay.open{display:block}
  .main-content{margin-left:0}.menu-toggle{display:flex}
  .topbar{padding:0 16px}.topbar-date{display:none}
  .page-body{padding:18px 14px 30px}
  .form-row,.form-row-3{grid-template-columns:1fr}.grid-3{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}.boats-grid{grid-template-columns:1fr 1fr}
  .modal{border-radius:var(--r) var(--r) 0 0;max-height:95vh}.modal-overlay{align-items:flex-end;padding:0}
}
@media(max-width:480px){.stats-grid{grid-template-columns:1fr}.boats-grid{grid-template-columns:1fr}.btn-new span{display:none}.login-card{padding:26px 18px}}

/* Not Completed status badge */
.badge-not_completed{background:#fef0e8;color:#b05020}
