:root{
  --ink:#0f1c2e; --ink-2:#1d2d44; --paper:#f4f1ea; --card:#ffffff;
  --teal:#0d7a6f; --teal-dark:#0a5d54; --gold:#c4943a; --gold-light:#e0b85f;
  --line:#e3ddd0; --muted:#6b7280; --danger:#b23b3b; --ok:#2e7d54;
  --shadow:0 1px 3px rgba(15,28,46,.08),0 8px 24px rgba(15,28,46,.06);
  --serif:'Fraunces',Georgia,serif; --sans:'Plus Jakarta Sans',system-ui,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--sans);background:var(--paper);color:var(--ink);font-size:14px;line-height:1.55}
a{text-decoration:none;color:inherit}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;color:var(--ink);margin:0 0 .4em}

/* ---------- Shell ---------- */
.app-shell{display:flex;min-height:100vh}
.sidebar{width:256px;background:linear-gradient(180deg,var(--ink) 0%,var(--ink-2) 100%);color:#cdd6e2;
  position:fixed;top:0;bottom:0;left:0;display:flex;flex-direction:column;padding:18px 0;z-index:40;overflow-y:auto;overflow-x:hidden;transition:transform .2s ease}
.main{flex:1;margin-left:256px;display:flex;flex-direction:column;min-width:0;transition:margin-left .2s ease}

/* Toggle button hides the sidebar; content reclaims the space */
body.nav-collapsed .sidebar{transform:translateX(-100%)}
body.nav-collapsed .main{margin-left:0}
.brand{display:flex;align-items:center;gap:12px;padding:6px 22px 22px}
.brand-mark{width:42px;height:42px;border-radius:11px;background:linear-gradient(135deg,var(--teal),var(--gold));
  display:grid;place-items:center;font-size:22px;color:#fff;box-shadow:0 4px 12px rgba(13,122,111,.4)}
.brand-name{font-family:var(--serif);font-size:19px;font-weight:700;color:#fff;line-height:1}
.brand-sub{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-light);margin-top:3px}
.nav-menu{display:flex;flex-direction:column;gap:1px;padding:0 12px}
.nav-section{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:#6f7e91;padding:16px 12px 6px;font-weight:600}
.nav-item{display:flex;align-items:center;gap:11px;padding:9px 13px;border-radius:9px;color:#bcc7d6;font-weight:500;transition:.15s}
.nav-item i{font-size:16px;width:20px;text-align:center}
.nav-item:hover{background:rgba(255,255,255,.07);color:#fff}
.nav-item.active{background:linear-gradient(90deg,var(--teal),var(--teal-dark));color:#fff;box-shadow:0 4px 12px rgba(13,122,111,.35)}

/* ---------- Topbar ---------- */
.topbar{height:64px;background:rgba(255,255,255,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:16px;padding:0 26px;position:sticky;top:0;z-index:30}
.topbar-title{font-family:var(--serif);font-size:20px;font-weight:600;flex:1}
.topbar-right{display:flex;align-items:center;gap:14px}
.branch-chip{font-size:12px;background:#eef3f2;color:var(--teal-dark);padding:5px 11px;border-radius:20px;font-weight:600}
.user-chip{display:flex;align-items:center;gap:10px}
.avatar,.avatar-img{width:38px;height:38px;border-radius:11px;object-fit:cover}
.avatar{background:linear-gradient(135deg,var(--teal),var(--gold));color:#fff;display:grid;place-items:center;font-weight:700;font-size:14px}
.user-meta{line-height:1.2}.user-name{font-weight:600;font-size:13px}.user-role{font-size:11px;color:var(--muted)}
.logout-btn{width:38px;height:38px;border-radius:10px;border:1px solid var(--line);display:grid;place-items:center;color:var(--muted);font-size:17px;transition:.15s}
.logout-btn:hover{background:var(--danger);color:#fff;border-color:var(--danger)}
.menu-toggle{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;background:#fff;border:1px solid var(--line);border-radius:9px;font-size:20px;color:var(--ink);cursor:pointer;margin-right:10px}
.menu-toggle:hover{background:var(--teal);color:#fff;border-color:var(--teal)}

/* ---------- Content ---------- */
.content{padding:26px;max-width:1280px;width:100%}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:22px;gap:16px;flex-wrap:wrap}
.page-head h1{font-size:28px;margin:0}
.page-head .sub{color:var(--muted);font-size:13px;margin-top:3px}

/* ---------- Cards ---------- */
.card-x{background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:22px;margin-bottom:18px}
.card-x h3{font-size:17px}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;margin-bottom:22px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.stat::after{content:"";position:absolute;right:-18px;top:-18px;width:70px;height:70px;border-radius:50%;background:linear-gradient(135deg,var(--teal),transparent);opacity:.09}
.stat .label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.stat .value{font-family:var(--serif);font-size:34px;font-weight:700;margin-top:6px;color:var(--ink)}
.stat .ico{position:absolute;right:18px;bottom:16px;font-size:26px;color:var(--teal);opacity:.55}

/* ---------- Tables ---------- */
.table-x{width:100%;border-collapse:collapse;background:var(--card);border-radius:14px;overflow:hidden;box-shadow:var(--shadow)}
.table-x th{background:#f8f6f1;text-align:left;padding:12px 15px;font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:700;border-bottom:1px solid var(--line)}
.table-x td{padding:12px 15px;border-bottom:1px solid var(--line);vertical-align:middle}
.table-x tr:last-child td{border-bottom:none}
.table-x tr:hover td{background:#faf9f5}

/* ---------- Buttons / inputs ---------- */
.btn-pri{background:linear-gradient(135deg,var(--teal),var(--teal-dark));color:#fff;border:none;padding:10px 18px;border-radius:10px;font-weight:600;font-family:var(--sans);font-size:13px;cursor:pointer;transition:.15s;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.btn-pri:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(13,122,111,.35);color:#fff}
.btn-ghost{background:#fff;color:var(--ink);border:1px solid var(--line);padding:9px 16px;border-radius:10px;font-weight:600;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:7px}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal-dark)}
.btn-gold{background:linear-gradient(135deg,var(--gold-light),var(--gold));color:#3a2c10;border:none;padding:10px 18px;border-radius:10px;font-weight:700;cursor:pointer}
.field{margin-bottom:15px}
.field label{display:block;font-size:12.5px;font-weight:600;margin-bottom:6px;color:var(--ink-2)}
.field input,.field select,.field textarea{width:100%;padding:10px 13px;border:1px solid var(--line);border-radius:10px;font-family:var(--sans);font-size:14px;background:#fff;transition:.15s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(13,122,111,.12)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}

/* ---------- Badges ---------- */
.badge-x{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11.5px;font-weight:700}
.b-green{background:#e3f4ea;color:var(--ok)}.b-amber{background:#fbf0d9;color:#9a6b1a}
.b-red{background:#f8e2e2;color:var(--danger)}.b-gray{background:#eef0f2;color:#5a6573}
.b-teal{background:#e0f0ee;color:var(--teal-dark)}

@@media(max-width:860px){
  .sidebar{transform:translateX(-100%);transition:.25s;width:256px}
  body.nav-open .sidebar{transform:translateX(0);width:256px}
  /* on touch screens there is no hover, so always show full labels when open */
  .sidebar .nav-item,.sidebar .nav-parent>span{font-size:13.5px !important}
  .sidebar .nav-item span,.sidebar .brand-name,.sidebar .nav-sub{display:initial !important}
  .main{margin-left:0}.menu-toggle{display:block}
  .grid-2,.grid-3{grid-template-columns:1fr}
}

/* ---------- Collapsible submenu groups (POS-style) ---------- */
.nav-group{margin:1px 0}
.nav-parent{width:100%;display:flex;align-items:center;justify-content:space-between;background:none;border:none;
  color:#bcc7d6;font-weight:600;font-size:13px;padding:9px 13px;border-radius:9px;cursor:pointer;font-family:var(--sans)}
.nav-parent span{display:flex;align-items:center;gap:11px}
.nav-parent span i{font-size:16px;width:20px;text-align:center}
.nav-parent:hover{background:rgba(255,255,255,.07);color:#fff}
.nav-parent .chev{transition:.2s;font-size:12px}
.nav-group.open .chev{transform:rotate(180deg)}
.nav-sub{max-height:0;overflow:hidden;transition:max-height .25s ease;padding-left:8px}
.nav-group.open .nav-sub{max-height:1200px}
/* Open submenu sits on a subtle lighter tint of the menu's own (dark) background */
.nav-group.open > .nav-sub{background:rgba(255,255,255,.06);border-radius:10px;margin:4px 6px 6px;padding:6px 6px 6px 10px;border-left:3px solid var(--teal)}
/* nested report sub-groups (church-style) */
.nav-subgroup{margin:0}
.nav-subparent{width:100%;display:flex;align-items:center;justify-content:space-between;background:transparent !important;border:none !important;-webkit-appearance:none;appearance:none;color:rgba(255,255,255,.85);font-weight:500;padding:8px 12px 8px 14px;border-radius:8px;cursor:pointer;font-family:var(--sans);font-size:13px;text-transform:none;letter-spacing:normal}
.nav-subparent span{display:flex;align-items:center;gap:10px;min-width:0}
.nav-subparent span i{font-size:14px;width:16px;text-align:center;color:var(--gold-light);flex:0 0 auto}
.nav-subparent:hover{background:rgba(255,255,255,.08) !important;color:#fff}
.nav-subparent .chev{transition:.2s;font-size:11px;opacity:.7;flex:0 0 auto}
.nav-subgroup.open .chev{transform:rotate(180deg)}
.nav-subsub{max-height:0;overflow:hidden;transition:max-height .28s ease;margin-left:23px;border-left:1px solid rgba(255,255,255,.16);display:block}
.nav-subgroup.open .nav-subsub{max-height:1000px}
.nav-leaf{display:flex !important;align-items:center;gap:7px;padding:7px 10px 7px 12px;color:rgba(255,255,255,.78) !important;font-weight:500;font-size:12.5px;text-decoration:none !important;border-radius:0 7px 7px 0;transition:.15s;white-space:normal;line-height:1.3}
.nav-leaf i{font-size:13px;opacity:.5;flex:0 0 auto}
.nav-leaf:hover{background:rgba(255,255,255,.1);color:#fff !important}
.nav-leaf.active{background:var(--gold);color:#3a2c10 !important;font-weight:600}
.nav-sub .nav-item{font-size:12.5px;padding:8px 13px}

/* ---------- Topbar icon buttons + user chip dropdown ---------- */
.icon-btn{width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:#fff;color:var(--ink);
  display:grid;place-items:center;font-size:16px;cursor:pointer;transition:.15s}
.icon-btn:hover{background:var(--teal);color:#fff;border-color:var(--teal)}
.user-chip{cursor:pointer;text-decoration:none}
.theme-swatches{display:flex;gap:8px;padding:4px 0 6px}
.theme-swatches .sw{width:30px;height:30px;border-radius:8px;border:2px solid #fff;box-shadow:0 0 0 1px var(--line);cursor:pointer}
.theme-swatches .sw:hover{transform:scale(1.1)}

/* ---------- Marquee (moving text) ---------- */
.marquee{background:linear-gradient(90deg,var(--teal),var(--teal-dark));color:#fff;overflow:hidden;white-space:nowrap;padding:7px 0}
.marquee-track{display:inline-block;padding-left:100%;animation:scroll-left linear infinite;font-weight:600;font-size:13px}
@@keyframes scroll-left{0%{transform:translateX(0)}100%{transform:translateX(-100%)}}

/* ---------- Slide-in search panel ---------- */
.search-overlay{position:fixed;inset:0;background:rgba(15,28,46,.45);backdrop-filter:blur(2px);opacity:0;visibility:hidden;transition:.25s;z-index:200}
.search-overlay.show{opacity:1;visibility:visible}
.search-panel{position:fixed;top:0;right:0;height:100vh;width:90vw;max-width:90vw;background:var(--paper);
  box-shadow:-20px 0 60px rgba(0,0,0,.3);transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:201;
  display:flex;flex-direction:column}
.search-panel.open{transform:translateX(0)}
.search-head{display:flex;align-items:center;justify-content:space-between;padding:20px 26px;border-bottom:1px solid var(--line);background:#fff}
.search-head h3{margin:0;font-size:20px}
.search-filters{padding:18px 26px;background:#fff;border-bottom:1px solid var(--line)}
.search-filters input,.search-filters select{width:100%;padding:11px 14px;border:1px solid var(--line);border-radius:10px;font-family:var(--sans);font-size:14px}
.search-filters input:focus,.search-filters select:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(13,122,111,.12)}
.search-results{flex:1;overflow-y:auto;padding:18px 26px}
.sresult{display:flex;align-items:center;gap:14px;padding:12px 14px;background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:10px;transition:.15s;text-decoration:none;color:inherit}
.sresult:hover{border-color:var(--teal);transform:translateX(-3px);box-shadow:var(--shadow)}
.sresult img{width:46px;height:46px;border-radius:10px;object-fit:cover}
.sresult .nm{font-weight:700}
.sresult .mt{font-size:12px;color:var(--muted)}
.sresult>i{color:var(--muted)}

/* google translate banner suppression */
.goog-te-banner-frame{display:none !important}
body{top:0 !important}

/* utility: muted text (used across views) */
.muted{color:var(--muted)}

/* ===== Image Cropper / Upload Modal (global, authoritative) ===== */
.cropper-modal{position:fixed;inset:0;background:#0b1320;display:none;align-items:center;justify-content:center;z-index:99999;padding:16px;opacity:1}
.cropper-modal.show{display:flex}
.cropper-modal .cropper-inner{background:#ffffff;opacity:1;border-radius:20px;padding:0;width:100%;max-width:480px;box-shadow:0 30px 90px rgba(0,0,0,.55);position:relative;z-index:100000;max-height:92vh;overflow:hidden;display:flex;flex-direction:column}
.cropper-modal .cm-head{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;background:#0d9488;color:#fff}
.cropper-modal .cm-head h3{margin:0;font-size:17px;display:flex;align-items:center;gap:9px;color:#fff}
.cropper-modal .cm-head .cm-x{background:rgba(255,255,255,.20);border:none;color:#fff;width:34px;height:34px;border-radius:9px;cursor:pointer;font-size:15px}
.cropper-modal .cm-head .cm-x:hover{background:rgba(255,255,255,.35)}
.cropper-modal .cm-body{background:#ffffff;padding:20px 22px;overflow-y:auto}
.cropper-modal .crop-tabs{display:flex;gap:6px;background:#eef1f3;border-radius:12px;padding:5px;margin-bottom:16px}
.cropper-modal .crop-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;border:none;background:transparent;border-radius:9px;padding:10px;font-weight:600;font-size:14px;color:var(--muted);cursor:pointer}
.cropper-modal .crop-tab.active{background:#fff;color:var(--ink);box-shadow:0 2px 6px rgba(0,0,0,.08)}
.cropper-modal #cropDrop{border:2px dashed var(--line);border-radius:14px;padding:34px 20px;text-align:center;cursor:pointer;background:#f6f8f9}
.cropper-modal #cropDrop:hover{border-color:var(--teal);background:#eefaf8}
.cropper-modal .cam-wrap{background:#0b1421;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center;min-height:240px}
.cropper-modal #camVideo{width:100%;max-height:340px;display:block;object-fit:cover}
body.cropper-open{overflow:hidden}
