/* ============================================================================
   OpenLagoon dashboard — app shell + design system.
   Aesthetic: Squarespace/Typeform — airy, refined, thin-stroke icons, no emojis.
   Brand: cream #FBFAF7 · lagoon teal #3F9A91 · ink #1C1F26. Loaded after Bootstrap.
   ========================================================================== */
:root{
  --cream:#fbfaf7; --paper:#ffffff; --ink:#1c1f26; --muted:#6a7180; --faint:#9aa0ac;
  --teal:#3f9a91; --teal-deep:#2f8077; --teal-pale:#e8f3f1; --teal-soft:#d3e9e5;
  --sand:#ece8df; --sand-2:#e0dbd0; --coral:#d98a78;
  --r:6px; --r-lg:7px; --r-sm:4px; --pill:6px;
  --shadow-sm:0 1px 2px rgba(28,31,38,.04);
  --shadow:0 1px 2px rgba(28,31,38,.04), 0 10px 30px rgba(28,31,38,.05);
  --shadow-lg:0 24px 60px rgba(28,31,38,.14);
  --sb:264px;
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}

/* ---------- base ---------------------------------------------------------- */
body.app{ margin:0; background:var(--cream)!important; color:var(--ink); font-family:var(--font); -webkit-font-smoothing:antialiased; }
body.app *{ box-sizing:border-box; }
.app-shell{ display:flex; min-height:100vh; }

/* hide the legacy chrome (old top navbar + per-page sidebar) on app pages */
body.app > nav.navbar{ display:none!important; }
body.app > footer{ display:none!important; }
body.app #sidebarMenu, body.app .sidebar{ display:none!important; }

/* ---------- sidebar ------------------------------------------------------- */
.app-sidebar{
  width:var(--sb); flex:0 0 var(--sb); position:fixed; inset:0 auto 0 0; z-index:40;
  background:var(--paper); border-right:1px solid var(--sand);
  display:flex; flex-direction:column; padding:1.6rem 1.1rem;
}
.sb-brand{ display:flex; align-items:center; gap:.6rem; padding:.2rem .4rem 1.4rem; text-decoration:none; }
.sb-brand .mark{ width:30px; height:30px; border-radius:5px; background:linear-gradient(140deg,var(--teal),var(--teal-deep)); display:flex; align-items:center; justify-content:center; color:#fff; flex:0 0 auto; }
.sb-brand .name{ font-weight:700; font-size:1.12rem; letter-spacing:-.02em; color:var(--ink); }
.sb-section{ font-size:.66rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--faint); padding:1rem .8rem .35rem; }
.sb-nav{ display:flex; flex-direction:column; gap:.12rem; }
.sb-link{
  display:flex; align-items:center; gap:.7rem; padding:.6rem .8rem; border-radius:var(--r-sm);
  color:var(--muted); text-decoration:none; font-size:.93rem; font-weight:500; position:relative;
  transition:background .14s, color .14s;
}
.sb-link svg{ width:19px; height:19px; flex:0 0 auto; stroke-width:1.8; opacity:.85; }
.sb-link:hover{ background:var(--cream); color:var(--ink); }
.sb-link.active{ background:var(--teal-pale); color:var(--teal-deep); font-weight:600; }
.sb-link.active svg{ opacity:1; color:var(--teal-deep); }
.sb-spacer{ flex:1; }
.sb-account{ border-top:1px solid var(--sand); padding-top:.9rem; margin-top:.6rem; }
.sb-acct-row{ display:flex; align-items:center; gap:.6rem; padding:.35rem .4rem; }
.sb-avatar{ width:34px; height:34px; border-radius:50%; background:var(--teal); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:.85rem; flex:0 0 auto; }
.sb-acct-name{ font-weight:600; font-size:.88rem; line-height:1.1; color:var(--ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:130px; }
.sb-plan{ font-size:.66rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--teal-deep); }
.sb-logout{ display:flex; align-items:center; gap:.6rem; padding:.55rem .8rem; margin-top:.35rem; border-radius:var(--r-sm); color:var(--muted); text-decoration:none; font-size:.9rem; font-weight:500; }
.sb-logout:hover{ background:var(--cream); color:var(--coral); }
.sb-logout svg{ width:18px; height:18px; stroke-width:1.8; }

/* ---------- content ------------------------------------------------------- */
.app-main{ margin-left:var(--sb); flex:1; min-width:0; }
.app-content{ max-width:1180px; padding:2.6rem 3rem 4rem; margin:0 auto; }

/* normalize the legacy page wrappers so content flows full-width in the shell */
body.app .container, body.app .container-fluid{ max-width:none!important; width:100%!important; padding:0!important; margin:0!important; }
body.app .row{ margin:0!important; }
body.app main, body.app main[class*="col-"]{ width:100%!important; max-width:100%!important; flex:0 0 100%!important; margin:0!important; padding:0!important; }
/* Only the PAGE-LEVEL content column (col-md-9/10 that left room for the old sidebar)
   goes full-width; nested filter/form columns keep their horizontal layout. */
body.app .app-content > .container-fluid > .row > [class*="col-"],
body.app .app-content > .container > .row > [class*="col-"]{ flex:0 0 100%!important; max-width:100%!important; width:100%!important; padding-left:0!important; padding-right:0!important; }

/* ---------- page header --------------------------------------------------- */
.app-content h1, .text-gradient{ font-size:1.95rem!important; font-weight:700; letter-spacing:-.025em; color:var(--ink)!important; background:none!important; -webkit-text-fill-color:initial!important; margin:0 0 .2rem; }
.app-content .h2{ font-size:1.95rem!important; font-weight:700; letter-spacing:-.025em; color:var(--ink)!important; }
.app-content .text-muted{ color:var(--muted)!important; }
.app-content .border-bottom{ border-bottom:1px solid var(--sand)!important; padding-bottom:1.4rem!important; margin-bottom:2rem!important; }

/* ---------- cards --------------------------------------------------------- */
.app-content .card, .ol-card{ background:var(--paper)!important; border:1px solid var(--sand)!important; border-radius:var(--r-lg)!important; box-shadow:var(--shadow-sm)!important; }
.app-content .card-header{ background:transparent!important; border-bottom:1px solid var(--sand)!important; padding:1.2rem 1.5rem!important; font-weight:700; }
.app-content .card-body{ padding:1.5rem!important; }

/* ---------- stat cards (rebuilt markup) ----------------------------------- */
.stat-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.1rem; margin-bottom:2.4rem; }
@media(max-width:1100px){ .stat-grid{ grid-template-columns:repeat(2,1fr);} }
.stat{ background:var(--paper); border:1px solid var(--sand); border-radius:var(--r-lg); padding:1.4rem 1.45rem; box-shadow:var(--shadow-sm); transition:box-shadow .18s, transform .18s; cursor:pointer; }
.stat:hover{ box-shadow:var(--shadow); transform:translateY(-2px); }
.stat-ic{ width:40px; height:40px; border-radius:6px; background:var(--teal-pale); color:var(--teal-deep); display:flex; align-items:center; justify-content:center; margin-bottom:1rem; }
.stat-ic svg{ width:20px; height:20px; stroke-width:1.8; }
.stat-num{ font-size:2rem; font-weight:700; letter-spacing:-.03em; line-height:1; color:var(--ink); }
.stat-label{ font-size:.74rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:var(--faint); margin-top:.45rem; }

/* ---------- buttons ------------------------------------------------------- */
.app-content .btn, .ol-btn2{ border-radius:var(--r)!important; font-weight:600!important; font-size:.9rem; padding:.55rem 1.25rem!important; border:1px solid transparent; transition:filter .15s, background .15s; display:inline-flex; align-items:center; gap:.45rem; }
.app-content .btn svg, .ol-btn2 svg{ width:16px; height:16px; stroke-width:2; }
.app-content .btn-primary, .app-content .btn-dark, .ol-btn2{ background:var(--ink)!important; border-color:var(--ink)!important; color:#fff!important; }
.app-content .btn-primary:hover, .ol-btn2:hover{ filter:brightness(1.18); }
.app-content .btn-outline-primary, .app-content .btn-outline-secondary, .app-content .btn-outline-light{ background:var(--paper)!important; color:var(--ink)!important; border:1px solid var(--sand-2)!important; }
.app-content .btn-outline-primary:hover{ background:var(--cream)!important; border-color:var(--teal)!important; color:var(--teal-deep)!important; }
.app-content .btn-success{ background:var(--teal)!important; border-color:var(--teal)!important; color:#fff!important; }
.app-content .btn-danger{ background:var(--coral)!important; border-color:var(--coral)!important; }
.app-content .btn-sm{ padding:.4rem .9rem!important; font-size:.82rem; }

/* ---------- tables -------------------------------------------------------- */
.app-content .table{ color:var(--ink); }
.app-content .table thead th{ font-size:.72rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--faint); border-bottom:1px solid var(--sand)!important; padding:.7rem 1rem; }
.app-content .table td{ border-color:var(--sand)!important; padding:.85rem 1rem; vertical-align:middle; }
.app-content .table tbody tr:hover{ background:var(--cream); }

/* ---------- forms --------------------------------------------------------- */
.app-content .form-control, .app-content .form-select{ border:1px solid var(--sand-2); border-radius:var(--r-sm); padding:.6rem .8rem; font-size:.92rem; color:var(--ink); background:var(--paper); }
.app-content .form-control:focus, .app-content .form-select:focus{ border-color:var(--teal); box-shadow:0 0 0 3px rgba(63,154,145,.16); }
.app-content .form-label{ font-size:.78rem; font-weight:600; color:var(--muted); margin-bottom:.35rem; }

/* ---------- badges -------------------------------------------------------- */
.app-content .badge{ font-weight:600; border-radius:var(--pill); padding:.32em .7em; }
.app-content .badge.bg-primary, .app-content .badge.bg-success{ background:var(--teal-pale)!important; color:var(--teal-deep)!important; }
.app-content .badge.bg-secondary{ background:var(--sand)!important; color:var(--muted)!important; }
.app-content .badge.bg-warning{ background:#fbeee0!important; color:#b06a35!important; }
.app-content .badge.bg-danger{ background:#f7e3df!important; color:#b5503c!important; }

/* ---------- compact table action buttons + debootstrapped badges/toggles -- */
.app-content .table .btn, .app-content .btn-group-sm .btn{ padding:.36rem .5rem!important; font-size:.82rem; border-radius:5px!important; }
.app-content .table .btn i{ font-size:.85rem; }
.app-content .btn-group{ gap:.3rem; }
.app-content .btn-group .btn{ border-radius:5px!important; }
.app-content .badge{ border-radius:4px!important; font-weight:600; }
.app-content .badge.bg-info{ background:var(--teal-pale)!important; color:var(--teal-deep)!important; }
.app-content .btn-info, .app-content .btn-secondary{ background:var(--cream)!important; border:1px solid var(--sand-2)!important; color:var(--ink)!important; }
.app-content .btn-info:hover, .app-content .btn-secondary:hover{ background:var(--paper)!important; border-color:var(--teal)!important; color:var(--teal-deep)!important; }
/* toggles → teal, not Bootstrap blue */
.app-content .form-check-input:checked{ background-color:var(--teal)!important; border-color:var(--teal)!important; }
.app-content .form-check-input:focus{ border-color:var(--teal)!important; box-shadow:0 0 0 3px rgba(63,154,145,.16)!important; }
/* keep wide tables tidy: tight cells, single-line rows, horizontal scroll if needed */
.app-content .table-responsive{ overflow-x:auto; border-radius:6px; }
.app-content #rooms-table td, .app-content #rooms-table th{ padding:.6rem .55rem!important; white-space:nowrap; }
.app-content #rooms-table td:first-child, .app-content #rooms-table th:first-child{ white-space:normal; padding-left:.2rem!important; }
.app-content #rooms-table .btn{ padding:.32rem .44rem!important; }
.app-content #rooms-table .btn i{ font-size:.82rem; }
/* debootstrap alert/info banners */
.app-content .alert{ border-radius:5px!important; border:1px solid var(--sand)!important; }
.app-content .alert-info, .app-content .alert-primary{ background:var(--teal-pale)!important; border-color:var(--teal-soft)!important; color:var(--teal-deep)!important; }
.app-content .alert-success{ background:var(--teal-pale)!important; color:var(--teal-deep)!important; }
.app-content .alert-warning{ background:#fbeee0!important; color:#9a5a2a!important; border-color:#f0dcc4!important; }

/* ---------- modals (Bootstrap restyle) ------------------------------------ */
.modal-content{ border:0!important; border-radius:var(--r-lg)!important; box-shadow:var(--shadow-lg)!important; }
.modal-header{ border-bottom:1px solid var(--sand)!important; padding:1.4rem 1.6rem!important; }
.modal-title{ font-weight:700; letter-spacing:-.01em; }
.modal-body{ padding:1.6rem!important; }
.modal-footer{ border-top:1px solid var(--sand)!important; padding:1.1rem 1.6rem!important; }
.modal-backdrop.show{ opacity:.4; }

/* ---------- empty / loading / misc --------------------------------------- */
.app-content a{ color:var(--teal-deep); }
.app-content hr{ border-color:var(--sand); }
.app-content .text-primary{ color:var(--teal-deep)!important; }
.app-content code, .app-content pre{ background:#f4f2ec; border-radius:8px; }

/* ---------- reusable modal + toast (ui.js) -------------------------------- */
.ui-overlay{ position:fixed; inset:0; z-index:1100; background:rgba(28,31,38,.42); display:flex; align-items:center; justify-content:center; padding:1.5rem; opacity:0; transition:opacity .18s; }
.ui-overlay.show{ opacity:1; }
.ui-modal{ width:100%; max-width:440px; background:var(--paper); border-radius:var(--r-lg); box-shadow:var(--shadow-lg); padding:1.8rem; transform:translateY(8px); transition:transform .18s; }
.ui-overlay.show .ui-modal{ transform:translateY(0); }
.ui-modal h3{ font-size:1.2rem; font-weight:700; letter-spacing:-.01em; margin:0 0 .5rem; color:var(--ink); }
.ui-modal p{ color:var(--muted); font-size:.93rem; line-height:1.5; margin:0 0 1.2rem; }
.ui-modal .ui-field{ margin:0 0 1.1rem; }
.ui-modal label{ display:block; font-size:.78rem; font-weight:600; color:var(--muted); margin-bottom:.35rem; }
.ui-modal input, .ui-modal select, .ui-modal textarea{ width:100%; padding:.65rem .8rem; border:1px solid var(--sand-2); border-radius:var(--r-sm); font:inherit; font-size:.93rem; color:var(--ink); }
.ui-modal input:focus, .ui-modal select:focus, .ui-modal textarea:focus{ outline:none; border-color:var(--teal); box-shadow:0 0 0 3px rgba(63,154,145,.16); }
.ui-actions{ display:flex; justify-content:flex-end; gap:.6rem; margin-top:1.4rem; }
.ui-btn{ border:0; border-radius:var(--pill); font-weight:600; font-size:.9rem; padding:.6rem 1.3rem; cursor:pointer; }
.ui-btn-primary{ background:var(--ink); color:#fff; } .ui-btn-primary:hover{ filter:brightness(1.18); }
.ui-btn-ghost{ background:var(--paper); color:var(--ink); border:1px solid var(--sand-2); } .ui-btn-ghost:hover{ background:var(--cream); }
.ui-btn-danger{ background:var(--coral); color:#fff; }
.ui-toast{ position:fixed; bottom:26px; left:50%; transform:translateX(-50%) translateY(12px); z-index:1200; background:var(--ink); color:#fff; padding:.7rem 1.2rem; border-radius:var(--pill); font-size:.9rem; font-weight:500; box-shadow:var(--shadow-lg); opacity:0; transition:opacity .2s, transform .2s; pointer-events:none; }
.ui-toast.show{ opacity:1; transform:translateX(-50%) translateY(0); }

@media(max-width:860px){
  .app-sidebar{ transform:translateX(-100%); transition:transform .2s; }
  .app-sidebar.open{ transform:translateX(0); }
  .app-main{ margin-left:0; }
  .app-content{ padding:1.6rem 1.2rem 3rem; }
  .app-mobile-bar{ display:flex!important; }
}
.app-mobile-bar{ display:none; align-items:center; gap:.8rem; padding:1rem 1.2rem; border-bottom:1px solid var(--sand); position:sticky; top:0; background:var(--cream); z-index:30; }
