/* Morocco Scenery — Airbnb-style Premium (Light) */
:root{
  --bg:#FBFAF7;
  --bg-2:#F5F3EE;
  --bg-3:#EFEBE2;
  --panel:#FFFFFF;
  --line:#EBEBEB;
  --line-2:#DDDAD2;
  --text:#222222;
  --text-2:#484848;
  --muted:#717171;
  --muted-2:#9CA3AF;
  --accent:#C8553D;
  --accent-2:#B04531;
  --accent-soft:#FCEFEB;
  --green:#008A05;
  --green-soft:#E6F4EA;
  --red:#C13515;
  --red-soft:#FCE8E6;
  --amber:#B25E09;
  --amber-soft:#FDF1E1;
  --blue:#1E68A8;
  --blue-soft:#E5EEF7;
  --radius:12px;
  --radius-lg:16px;
  --radius-xl:24px;
  --shadow-sm:0 1px 2px rgba(0,0,0,.04), 0 1px 3px rgba(0,0,0,.06);
  --shadow:0 6px 16px rgba(0,0,0,.06), 0 1px 4px rgba(0,0,0,.05);
  --shadow-lg:0 12px 32px rgba(0,0,0,.1), 0 4px 12px rgba(0,0,0,.06);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--text);font-family:'Inter','SF Pro Display',-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit;font-size:14px;background:#fff;border:1px solid var(--line);color:var(--text);padding:11px 14px;border-radius:10px;outline:none;transition:border-color .15s, box-shadow .15s}
input:focus,select:focus,textarea:focus{border-color:var(--text);box-shadow:0 0 0 4px rgba(34,34,34,.06)}
.serif{font-family:'Cormorant Garamond','Playfair Display',serif;font-weight:500;letter-spacing:-.01em}
::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:99px;border:2px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:var(--muted-2)}

/* ============ LOGIN ============ */
.login-wrap{min-height:100vh;display:grid;grid-template-columns:1.1fr 1fr}
.login-art{position:relative;background-size:cover;background-position:center;display:flex;align-items:flex-end;padding:56px}
.login-art::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05) 0%,rgba(0,0,0,.65) 100%)}
.login-art-inner{position:relative;z-index:1;color:#fff}
.login-art-inner .logo{font-family:'Cormorant Garamond',serif;font-size:34px;letter-spacing:.06em;margin-bottom:auto;font-weight:500}
.login-art-inner h1{font-family:'Cormorant Garamond',serif;font-size:54px;line-height:1.05;font-weight:500;margin-top:32px;max-width:520px;letter-spacing:-.01em}
.login-art-inner p{margin-top:20px;color:rgba(255,255,255,.85);max-width:440px;font-size:16px;line-height:1.55}
.login-form{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:48px;background:var(--bg)}
.login-card{width:100%;max-width:400px}
.login-card h2{font-family:'Cormorant Garamond',serif;font-size:42px;font-weight:500;margin-bottom:8px;letter-spacing:-.01em}
.login-card .sub{color:var(--muted);margin-bottom:32px;font-size:15px}
.login-card label{display:block;color:var(--text-2);font-size:13px;font-weight:500;margin:18px 0 8px}
.login-card input{width:100%}
.login-card .row{display:flex;justify-content:space-between;align-items:center;margin:24px 0}
.login-card .row a{color:var(--accent);font-size:13px;font-weight:500}
.login-card .row a:hover{text-decoration:underline}
.btn-primary{width:100%;background:var(--accent);color:#fff;font-weight:600;padding:14px;border-radius:10px;letter-spacing:.01em;transition:background .15s, transform .1s;font-size:15px}
.btn-primary:hover{background:var(--accent-2)}
.btn-primary:active{transform:scale(.98)}
.login-footer{margin-top:32px;color:var(--muted);font-size:12px;text-align:center;line-height:1.6}

/* ============ APP SHELL ============ */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.sidebar{background:var(--panel);border-right:1px solid var(--line);padding:20px 14px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:10px;padding:8px 12px 20px;border-bottom:1px solid var(--line);margin-bottom:14px}
.brand-mark{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-family:'Cormorant Garamond',serif;font-size:20px;letter-spacing:.02em}
.brand-name{font-family:'Cormorant Garamond',serif;font-size:21px;letter-spacing:.04em;font-weight:500;color:var(--text)}
.nav{display:flex;flex-direction:column;gap:1px}
.nav-section{color:var(--muted);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;padding:14px 12px 6px}
.nav a{display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:8px;color:var(--text-2);font-size:14px;transition:all .15s;font-weight:500}
.nav a:hover{background:var(--bg-2);color:var(--text)}
.nav a.active{background:var(--text);color:#fff}
.nav a.active svg{opacity:1}
.nav svg{width:16px;height:16px;flex-shrink:0;opacity:.7}
.user-card{margin-top:auto;padding:12px;border-top:1px solid var(--line);display:flex;align-items:center;gap:10px;border-radius:10px;cursor:pointer;transition:background .15s}
.user-card:hover{background:var(--bg-2)}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--bg-3);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:var(--accent);overflow:hidden;flex-shrink:0}
.avatar img{width:100%;height:100%;object-fit:cover}
.user-card .name{font-size:13.5px;font-weight:600;color:var(--text)}
.user-card .role{font-size:11.5px;color:var(--muted);margin-top:1px}

/* ============ MAIN ============ */
.main{padding:0}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 36px;border-bottom:1px solid var(--line);background:rgba(251,250,247,.85);backdrop-filter:blur(10px);position:sticky;top:0;z-index:10}
.topbar .search{flex:1;max-width:440px;position:relative}
.topbar .search input{width:100%;padding-left:42px;background:var(--bg-2);border-color:transparent}
.topbar .search input:focus{background:#fff;border-color:var(--line)}
.topbar .search svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--muted)}
.topbar-actions{display:flex;align-items:center;gap:10px}
.icon-btn{position:relative;width:38px;height:38px;border-radius:50%;background:transparent;display:flex;align-items:center;justify-content:center;color:var(--text-2);transition:background .15s;border:none}
.icon-btn:hover{background:var(--bg-2)}
.icon-btn .dot{position:absolute;width:8px;height:8px;background:var(--accent);border-radius:50%;top:9px;right:9px;border:2px solid var(--bg)}

.page{padding:36px 40px 60px;max-width:1500px;margin:0 auto}
.page-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:32px;gap:24px}
.page-head h1{font-family:'Cormorant Garamond',serif;font-size:40px;font-weight:500;letter-spacing:-.015em;line-height:1.1}
.page-head .crumbs{color:var(--muted);font-size:12px;margin-bottom:6px;text-transform:uppercase;letter-spacing:.1em;font-weight:600}
.page-actions{display:flex;gap:8px;flex-shrink:0}
.btn{padding:10px 18px;border-radius:10px;font-size:13.5px;font-weight:500;border:1px solid var(--line);background:#fff;color:var(--text);transition:all .15s;display:inline-flex;align-items:center;gap:8px;line-height:1}
.btn:hover{border-color:var(--text);background:var(--bg-2)}
.btn.primary{background:var(--text);color:#fff;border-color:var(--text)}
.btn.primary:hover{background:#000;border-color:#000}
.btn.ghost{background:transparent;border-color:transparent}
.btn.ghost:hover{background:var(--bg-2);border-color:transparent}
.btn.danger{color:var(--red);border-color:var(--red-soft)}
.btn.danger:hover{background:var(--red-soft);border-color:var(--red)}

/* ============ METRICS ============ */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}
.metric{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px 24px;transition:transform .15s, box-shadow .15s}
.metric:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.metric .label{color:var(--muted);font-size:12.5px;font-weight:500;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center}
.metric .label svg{width:14px;height:14px}
.metric .value{font-family:'Cormorant Garamond',serif;font-size:34px;font-weight:500;letter-spacing:-.02em;color:var(--text);line-height:1.05}
.metric .delta{margin-top:10px;font-size:12.5px;display:flex;align-items:center;gap:6px;font-weight:500}
.delta.up{color:var(--green)}
.delta.down{color:var(--red)}

/* ============ CARDS ============ */
.grid-2{display:grid;grid-template-columns:2fr 1fr;gap:18px;margin-bottom:24px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);padding:26px}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:12px}
.card-head h3{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:500;letter-spacing:-.01em}
.card-head .sub{color:var(--muted);font-size:13px;margin-top:2px}
.card-tabs{display:flex;gap:2px;background:var(--bg-2);padding:3px;border-radius:9px}
.card-tabs button{padding:6px 12px;border-radius:7px;font-size:12.5px;color:var(--muted);font-weight:500;transition:all .15s}
.card-tabs button.active{background:#fff;color:var(--text);box-shadow:var(--shadow-sm)}

/* ============ TABLE ============ */
.table{width:100%;border-collapse:collapse}
.table th{text-align:left;color:var(--muted);font-weight:600;font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;padding:12px 14px;border-bottom:1px solid var(--line)}
.table td{padding:16px 14px;border-bottom:1px solid var(--line);font-size:14px;color:var(--text-2);vertical-align:middle}
.table tr:last-child td{border-bottom:none}
.table tbody tr{transition:background .15s}
.table tbody tr:hover td{background:var(--bg-2)}
.table .name-cell{display:flex;align-items:center;gap:12px}
.table .name-cell .avatar{width:32px;height:32px;font-size:12px;background:var(--bg-3)}
.table .sub{color:var(--muted);font-size:12.5px}
.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:99px;font-size:11.5px;font-weight:500;letter-spacing:.01em;border:1px solid transparent}
.badge.green{background:var(--green-soft);color:var(--green);border-color:rgba(0,138,5,.15)}
.badge.red{background:var(--red-soft);color:var(--red);border-color:rgba(193,53,21,.15)}
.badge.amber{background:var(--amber-soft);color:var(--amber);border-color:rgba(178,94,9,.15)}
.badge.blue{background:var(--blue-soft);color:var(--blue);border-color:rgba(30,104,168,.15)}
.badge.muted{background:var(--bg-2);color:var(--muted);border-color:var(--line)}
.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor}

/* ============ FILTERS / TOOLBAR ============ */
.toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;gap:12px;flex-wrap:wrap}
.filters{display:flex;gap:6px;flex-wrap:wrap}
.chip{padding:7px 14px;border-radius:99px;background:#fff;border:1px solid var(--line);font-size:12.5px;color:var(--text-2);cursor:pointer;transition:all .15s;font-weight:500}
.chip:hover{border-color:var(--text);background:var(--bg-2)}
.chip.active{background:var(--text);color:#fff;border-color:var(--text)}

/* ============ MISC ============ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.activity{list-style:none}
.activity li{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--line);font-size:13.5px;color:var(--text-2)}
.activity li:last-child{border-bottom:none}
.activity .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);margin-top:6px;flex-shrink:0}
.activity .time{color:var(--muted);font-size:11.5px;margin-top:3px}
.empty{padding:60px;text-align:center;color:var(--muted)}
.progress{width:100%;height:6px;background:var(--bg-2);border-radius:99px;overflow:hidden}
.progress span{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:99px;transition:width .4s ease}
.kbd{background:var(--bg-2);border:1px solid var(--line);padding:2px 6px;border-radius:4px;font-size:11px;font-family:monospace;color:var(--muted);font-weight:500}

/* ============ INVOICE / SETTINGS ============ */
.invoice-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:28px}
.amount{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:500}
.flag{font-size:18px;margin-right:6px}
.settings-grid{display:grid;grid-template-columns:240px 1fr;gap:36px}
.settings-nav{display:flex;flex-direction:column;gap:1px}
.settings-nav a{padding:11px 16px;border-radius:9px;color:var(--text-2);font-size:14px;font-weight:500;transition:all .15s;cursor:pointer}
.settings-nav a:hover{background:var(--bg-2)}
.settings-nav a.active{background:var(--text);color:#fff}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:18px}
.field-row.full{grid-template-columns:1fr}
.field label{display:block;color:var(--text-2);font-size:13px;font-weight:500;margin-bottom:8px}
.field input,.field select,.field textarea{width:100%}

/* Generic table-wrapping utility (used on detail pages with wider tables).
   _app.js wraps every .card > .table in <div class="table-scroll"> at runtime. */
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -2px}
.table-scroll>.table{min-width:600px}

/* ============ TABLET ≤ 980px ============ */
@media (max-width:980px){
  .login-wrap{grid-template-columns:1fr}
  .login-art{display:none}
  .app{grid-template-columns:1fr}
  .sidebar{display:none}
  .metrics{grid-template-columns:repeat(2,1fr)}
  .grid-2,.split,.invoice-summary,.settings-grid{grid-template-columns:1fr}
  .page{padding:20px}
  .page-head h1{font-size:30px}
  .page-head{flex-wrap:wrap;align-items:flex-start;gap:14px}
  .page-actions{flex-wrap:wrap}
  /* Tables scroll horizontally so 7-col tables don't break the layout */
  .card>.table, .card .table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .card>.table thead, .card>.table tbody, .card>.table tr{min-width:100%}
  /* Two-up form rows collapse to one column */
  .field-row{grid-template-columns:1fr !important;gap:14px}
  /* Booking/invoice summary (4-col) → 2-col */
  .summary{grid-template-columns:1fr 1fr !important}
  /* Profile heads stack */
  .profile-head{flex-direction:column;gap:14px;padding:18px}
  .profile-head .actions, .profile-head>div:last-child{flex-wrap:wrap}
  /* Modal grids that use 1fr 1fr inline → single col */
  #as-modal-card .modal-body div[style*="grid-template-columns:1fr 1fr"],
  #as-modal-card .modal-body div[style*="grid-template-columns:1fr 1fr 1fr"]{
    grid-template-columns:1fr !important
  }
  /* Detail tab rows scroll horizontally if many tabs */
  .b-tabs, .tab-row{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;scrollbar-width:none}
  .b-tabs::-webkit-scrollbar, .tab-row::-webkit-scrollbar{display:none}
  .b-tabs button, .tab-row button{flex-shrink:0;white-space:nowrap}
  /* Filter chips wrap */
  .filters{flex-wrap:wrap}
  .toolbar{flex-direction:column;align-items:stretch}
  .toolbar input[placeholder*="Search"]{width:100% !important}
  /* Topbar tightens up */
  .topbar{padding:12px 16px 12px 64px}
  .topbar .search{max-width:none}
  .topbar-actions .btn{padding:9px 14px;font-size:13px}
}

/* Stop the whole page from scrolling horizontally on mobile.
   Anything that overflows must be inside a designed-to-scroll container. */
@media (max-width:980px){
  html, body { overflow-x: hidden; max-width: 100vw; }
  .main { min-width: 0; }
  /* Charts must respect their parent width — Chart.js sets explicit width on canvas
     (matching the fixed `height` attr), which on tablet/phone is way more than the card. */
  canvas { max-width: 100% !important; height: auto !important; }
}

/* ============ PHONE ≤ 600px ============ */
@media (max-width:600px){
  .page{padding:16px 14px 40px}
  .page-head h1{font-size:24px}
  .page-head .crumbs{font-size:11px}
  .metrics{grid-template-columns:1fr 1fr;gap:10px}
  .metric{padding:14px 16px}
  .metric .value{font-size:26px}
  .metric .label{font-size:11.5px}
  .metric .delta{font-size:11.5px}
  .card{padding:18px 16px;border-radius:14px}
  .card-head{flex-wrap:wrap;gap:10px}
  .card-head h3{font-size:20px}
  .summary{grid-template-columns:1fr 1fr !important;gap:10px}
  .summary .item{padding:12px}
  .summary .val{font-size:15px}
  .summary .lbl{font-size:10px}
  /* Login form on tiny screens */
  .login-form{padding:24px 16px}
  .login-card h2{font-size:30px}
  .login-card .sub{font-size:13.5px}
  /* Modals fill the screen on phones for easier tapping */
  #as-modal{padding:0 !important}
  #as-modal-card{border-radius:14px 14px 0 0 !important;max-height:95vh !important;align-self:flex-end}
  .modal-head{padding:18px 18px}
  .modal-head h3{font-size:21px}
  .modal-body{padding:18px}
  .modal-foot{padding:14px 18px;flex-wrap:wrap}
  .modal-foot .btn{flex:1;min-width:120px}
  /* On a phone the page-head already has the primary "+ New …" button,
     so hide the duplicate one in the topbar and let the search field span. */
  .topbar-actions .btn.primary{display:none}
  .topbar{padding:10px 14px 10px 60px}
  .topbar .search input{font-size:14px;padding:10px 10px 10px 36px}
  .topbar .search svg{left:11px}
  /* Metric values + deltas wrap on small screens (long deltas like "€ 17,400 · 2 overdue") */
  .metric .delta{white-space:normal;overflow-wrap:anywhere;line-height:1.3}
  .metric .value{font-size:24px;line-height:1.05}
  /* Page-actions stack BELOW the heading on phones */
  .page-head{flex-direction:column;align-items:stretch}
  .page-actions{justify-content:flex-end}
  /* Modals truly full-width on phone — override the inline max-width set by openModal() */
  #as-modal{padding:0 !important}
  #as-modal-card{max-width:100vw !important;width:100vw !important;border-radius:14px 14px 0 0 !important;align-self:flex-end}
  /* Tab row text smaller */
  .b-tabs button, .tab-row button{padding:10px 14px;font-size:13px}
  /* Profile head */
  .profile-head .avatar{width:56px;height:56px;font-size:18px}
  .profile-head h1{font-size:26px}
  .profile-head .meta{gap:14px;font-size:12.5px}
  /* Tighter table rows */
  .table th{padding:9px 10px;font-size:11px}
  .table td{padding:12px 10px;font-size:13px}
  /* Form labels smaller */
  .field label{font-size:12px}
  /* Hide non-critical columns inside the staff guide-detail trips table */
  .table.compact-mobile th:nth-child(n+5):not(:last-child),
  .table.compact-mobile td:nth-child(n+5):not(:last-child){display:none}
  /* Toast: don't take the whole width */
  #toast-wrap{left:14px;right:14px;bottom:14px;align-items:stretch}
  #toast-wrap > div{min-width:0 !important;width:100% !important}
  /* Burger icon larger touch target */
  .burger{width:42px;height:42px;top:10px;left:10px}
  /* Itinerary card images smaller */
  .itin-card .img{height:160px}
}

/* ============ MODAL OVERRIDES (light theme) ============ */
#ms-modal-card{background:#fff !important;border:1px solid var(--line) !important;box-shadow:var(--shadow-lg)}
.modal-head{border-bottom-color:var(--line) !important;color:var(--text)}
.modal-head h3{color:var(--text)}
.modal-foot{border-top-color:var(--line) !important}
.modal-x{background:#fff !important;border-color:var(--line) !important;color:var(--muted) !important}
.modal-x:hover{background:var(--bg-2) !important;color:var(--text) !important}
.menu-pop{background:#fff !important;border-color:var(--line) !important;box-shadow:var(--shadow-lg)}
.menu-pop button{color:var(--text) !important}
.menu-pop button:hover{background:var(--bg-2) !important}

/* ============ TOAST OVERRIDES ============ */
#toast-wrap > div{background:#fff !important;border-color:var(--line) !important;color:var(--text) !important;box-shadow:var(--shadow-lg) !important}

/* ============ ROW ACTIONS LIGHT ============ */
.row-actions{background:#fff !important;border-color:var(--line) !important;box-shadow:var(--shadow-sm)}
.row-actions button{color:var(--muted) !important}
.row-actions button:hover{background:var(--bg-2) !important;color:var(--text) !important}
tr.row-flash{animation:flash 1.2s ease}
@keyframes flash{0%{background:var(--accent-soft)}100%{background:transparent}}

/* ============ HOVER EFFECT ============ */
.itin-card{box-shadow:var(--shadow-sm);transition:transform .25s ease, box-shadow .25s ease}
.itin-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}

/* ============ PRINT ============ */
@media print {
  .sidebar, .topbar, .page-actions, .icon-btn, #toast-wrap, #ms-modal { display: none !important; }
  .app { grid-template-columns: 1fr !important; }
  .main { padding: 0 !important; }
  .page { padding: 0 !important; max-width: 100% !important; }
  body { background: #fff !important; }
  .card { break-inside: avoid; box-shadow: none !important; border: 1px solid #ddd !important; }
  .metric { box-shadow: none !important; }
}

/* ============ MOBILE BURGER ============ */
.burger {
  display: none;
  position: fixed;
  top: 12px; left: 12px;
  z-index: 100;
  width: 40px; height: 40px;
  border-radius: 10px;
  background: var(--panel);
  border: 1px solid var(--line);
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
}
@media (max-width: 980px) {
  .burger { display: flex; }
  /* Hide the burger while the drawer is open — otherwise it sits on top of the brand. */
  .burger.is-open { display: none; }
  .sidebar.is-open {
    display: flex !important;
    position: fixed !important;
    top: 0; left: 0; bottom: 0;
    width: 280px;
    z-index: 99;
    background: var(--panel);
    box-shadow: var(--shadow-lg);
    transition: transform 0.25s ease;
  }
  .sidebar-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.4);
    z-index: 98;
    display: none;
  }
  .sidebar-backdrop.is-open { display: block; }
  .topbar { padding-left: 64px !important; }
}

/* ============ SKELETON ============ */
.skel {
  background: linear-gradient(90deg, var(--bg-2), var(--bg-3), var(--bg-2));
  background-size: 200% 100%;
  animation: skel 1.4s infinite;
  border-radius: 6px;
  display: inline-block;
}
@keyframes skel {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ============ SORTABLE HEADERS ============ */
.table th.sortable {
  cursor: pointer;
  user-select: none;
}
.table th.sortable:hover { color: var(--text); }
.table th.sortable .sort-arrow {
  display: inline-block;
  margin-left: 4px;
  opacity: 0.4;
}
.table th.sortable.sort-asc .sort-arrow,
.table th.sortable.sort-desc .sort-arrow {
  opacity: 1;
  color: var(--accent);
}
