/* =====================================================================
   WaqPro — style.css   (brand: deep green + gold)
   ===================================================================== */
:root{
  --green-900:#10391f; --green-800:#14532d; --green-700:#1d6334; --green-600:#2e7d46;
  --gold-600:#b8860b; --gold-500:#c8962f; --gold-400:#d9a93d;
  --ink:#1f2937; --muted:#6b7280; --line:#e5e7eb; --bg:#f4f6f4; --card:#ffffff;
  --ok:#16794a; --okbg:#e7f6ee; --danger:#b42318; --dangerbg:#fdecea;
  --warn:#9a6700; --warnbg:#fdf4d9; --radius:14px; --shadow:0 1px 2px rgba(16,57,31,.06),0 8px 24px rgba(16,57,31,.06);
  --sidebar-w:248px; --appbar-h:60px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Segoe UI',system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);font-size:15px;line-height:1.5;-webkit-text-size-adjust:100%}
a{color:var(--green-700);text-decoration:none}
a:hover{text-decoration:underline}
h1{font-size:1.45rem;margin:0 0 4px} h2{font-size:1.2rem} h3{font-size:1.02rem;margin:0}
code{background:#f1f3f1;padding:1px 5px;border-radius:5px;font-size:.82em}
.muted{color:var(--muted)} .small{font-size:.82rem} .strong{font-weight:600}
.ta-r{text-align:right} .ta-c{text-align:center} .nowrap{white-space:nowrap}
.link{color:var(--green-700)}

/* ---------- App shell ---------- */
.app-shell{min-height:100vh}
.appbar{position:fixed;top:0;left:0;right:0;height:var(--appbar-h);background:var(--green-900);color:#fff;
  display:flex;align-items:center;gap:12px;padding:0 14px;z-index:50;box-shadow:0 2px 10px rgba(0,0,0,.12)}
.appbar .brand{display:flex;align-items:center;gap:9px;color:#fff;font-size:1.18rem;font-weight:600}
.appbar .brand:hover{text-decoration:none}
.brand-emblem{height:34px;width:auto;background:#fff;border-radius:9px;padding:3px}
.brand-text strong{color:var(--gold-400)}
.appbar-spacer{flex:1}
.icon-btn{background:transparent;border:0;color:#fff;cursor:pointer;padding:8px;border-radius:10px;display:flex}
.icon-btn:hover{background:rgba(255,255,255,.12)}
.nav-toggle{display:none}

.lang-picker select{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.25);
  border-radius:9px;padding:6px 8px;font-size:.85rem;cursor:pointer}
.lang-picker select option{color:#111}

/* user menu */
.user-menu{position:relative}
.user-trigger{display:flex;align-items:center;gap:9px;background:transparent;border:0;color:#fff;cursor:pointer;padding:5px 6px;border-radius:12px}
.user-trigger:hover{background:rgba(255,255,255,.1)}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--gold-500);color:#3a2a06;display:flex;align-items:center;justify-content:center;font-weight:700}
.avatar.sm{width:30px;height:30px;font-size:.85rem}
.user-meta{display:flex;flex-direction:column;line-height:1.15;text-align:left}
.user-name{font-size:.9rem;font-weight:600} .user-role{font-size:.72rem;opacity:.8}
.user-dropdown{position:absolute;right:0;top:calc(100% + 8px);background:#fff;color:var(--ink);min-width:230px;
  border-radius:12px;box-shadow:var(--shadow);border:1px solid var(--line);padding:8px;display:none}
.user-dropdown.open{display:block}
.user-dropdown a{display:block;padding:9px 10px;border-radius:8px;color:var(--ink)}
.user-dropdown a:hover{background:var(--bg);text-decoration:none}
.user-dropdown a.danger{color:var(--danger)}
.ud-head{padding:8px 10px;border-bottom:1px solid var(--line);margin-bottom:6px}
.chip{display:inline-block;background:#eef3ee;color:var(--green-800);font-size:.72rem;padding:3px 9px;border-radius:999px;margin-top:5px;font-weight:600}
.chip-gold{background:#faf1da;color:var(--gold-600)}

/* ---------- Sidebar ---------- */
.sidebar{position:fixed;top:var(--appbar-h);bottom:0;left:0;width:var(--sidebar-w);background:#fff;border-right:1px solid var(--line);
  display:flex;flex-direction:column;z-index:40;transition:transform .25s ease}
.sidebar-brand{padding:16px 16px 6px;text-align:center;border-bottom:1px solid var(--line)}
.sidebar-logo{max-width:150px;width:80%;height:auto}
.nav{flex:1;padding:10px;overflow:auto}
.nav-item{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:11px;color:var(--ink);font-weight:500;margin-bottom:3px}
.nav-item:hover{background:var(--bg);text-decoration:none}
.nav-item.active{background:linear-gradient(90deg,var(--green-800),var(--green-700));color:#fff}
.nav-item.active .nav-ic{filter:brightness(0) invert(1)}
.nav-item.danger{color:var(--danger)}
.sidebar-foot{padding:12px 16px;border-top:1px solid var(--line)}

.scrim{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:35;display:none}
.scrim.show{display:block}

/* nav icons (inline SVG via mask) */
.nav-ic{width:20px;height:20px;display:inline-block;background:currentColor;flex:0 0 auto;
  -webkit-mask:center/contain no-repeat;mask:center/contain no-repeat;color:var(--green-700)}
.nav-ic[data-ic="grid"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Crect x='3' y='3' width='7' height='7'/%3E%3Crect x='14' y='3' width='7' height='7'/%3E%3Crect x='14' y='14' width='7' height='7'/%3E%3Crect x='3' y='14' width='7' height='7'/%3E%3C/svg%3E")}
.nav-ic[data-ic="users"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M17 21v-2a4 4 0 0 0-4-4H5a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='9' cy='7' r='4'/%3E%3Cpath d='M23 21v-2a4 4 0 0 0-3-3.87M16 3.13a4 4 0 0 1 0 7.75'/%3E%3C/svg%3E")}
.nav-ic[data-ic="sliders"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cline x1='4' y1='21' x2='4' y2='14'/%3E%3Cline x1='4' y1='10' x2='4' y2='3'/%3E%3Cline x1='12' y1='21' x2='12' y2='12'/%3E%3Cline x1='12' y1='8' x2='12' y2='3'/%3E%3Cline x1='20' y1='21' x2='20' y2='16'/%3E%3Cline x1='20' y1='12' x2='20' y2='3'/%3E%3Cline x1='1' y1='14' x2='7' y2='14'/%3E%3Cline x1='9' y1='8' x2='15' y2='8'/%3E%3Cline x1='17' y1='16' x2='23' y2='16'/%3E%3C/svg%3E")}
.nav-ic[data-ic="history"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M3 3v5h5'/%3E%3Cpath d='M3.05 13A9 9 0 1 0 6 5.3L3 8'/%3E%3Cpath d='M12 7v5l4 2'/%3E%3C/svg%3E")}
.nav-ic[data-ic="key"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M21 2l-2 2m-7.61 7.61a5.5 5.5 0 1 1-7.778 7.778 5.5 5.5 0 0 1 7.777-7.777zm0 0L15.5 7.5m0 0l3 3L22 7l-3-3'/%3E%3C/svg%3E")}
.nav-ic[data-ic="logout"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M9 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h4'/%3E%3Cpolyline points='16 17 21 12 16 7'/%3E%3Cline x1='21' y1='12' x2='9' y2='12'/%3E%3C/svg%3E")}
.nav-ic[data-ic="plus"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cline x1='12' y1='5' x2='12' y2='19'/%3E%3Cline x1='5' y1='12' x2='19' y2='12'/%3E%3C/svg%3E")}
.nav-ic[data-ic="heart"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M20.84 4.61a5.5 5.5 0 0 0-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 0 0-7.78 7.78l1.06 1.06L12 21.23l7.78-7.78 1.06-1.06a5.5 5.5 0 0 0 0-7.78z'/%3E%3C/svg%3E")}
.nav-ic[data-ic="building"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Crect x='4' y='2' width='16' height='20' rx='1'/%3E%3Cpath d='M9 22v-4h6v4'/%3E%3Cline x1='8' y1='6' x2='8' y2='6'/%3E%3Cline x1='12' y1='6' x2='12' y2='6'/%3E%3Cline x1='16' y1='6' x2='16' y2='6'/%3E%3Cline x1='8' y1='10' x2='8' y2='10'/%3E%3Cline x1='12' y1='10' x2='12' y2='10'/%3E%3Cline x1='16' y1='10' x2='16' y2='10'/%3E%3Cline x1='8' y1='14' x2='8' y2='14'/%3E%3Cline x1='12' y1='14' x2='12' y2='14'/%3E%3Cline x1='16' y1='14' x2='16' y2='14'/%3E%3C/svg%3E")}
.nav-ic[data-ic="layers"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpolygon points='12 2 2 7 12 12 22 7 12 2'/%3E%3Cpolyline points='2 17 12 22 22 17'/%3E%3Cpolyline points='2 12 12 17 22 12'/%3E%3C/svg%3E")}
.nav-ic[data-ic="wallet"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M21 12V7H5a2 2 0 0 1 0-4h14v4'/%3E%3Cpath d='M3 5v14a2 2 0 0 0 2 2h16v-5'/%3E%3Cpath d='M18 12a2 2 0 0 0 0 4h4v-4z'/%3E%3C/svg%3E")}
.nav-ic[data-ic="doc"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z'/%3E%3Cpolyline points='14 2 14 8 20 8'/%3E%3Cline x1='8' y1='13' x2='16' y2='13'/%3E%3Cline x1='8' y1='17' x2='16' y2='17'/%3E%3C/svg%3E")}
.nav-ic[data-ic="check"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M9 11l3 3L22 4'/%3E%3Cpath d='M21 12v7a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h11'/%3E%3C/svg%3E")}
.nav-ic[data-ic="sign"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M3 17c2-1 3-3 3-5 0-1-1-1-1 0 0 3 1 5 3 5'/%3E%3Cpath d='M8 17c4 0 6-12 9-12 1 0 1 1 0 2-2 2-4 6-4 9'/%3E%3Cline x1='3' y1='21' x2='21' y2='21'/%3E%3C/svg%3E")}
.nav-ic[data-ic="handshake"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M11 17l2 2a1 1 0 0 0 3-3'/%3E%3Cpath d='M14 14l2.5 2.5a1 1 0 0 0 3-3l-3.88-3.88a3 3 0 0 0-4.24 0l-.88.88a1 1 0 0 1-1.41 0l-.7-.7a1 1 0 0 0-1.42 0L3 13'/%3E%3Cpath d='M21 3l-3 1-4 4'/%3E%3Cpath d='M3 3l3 1 2 2'/%3E%3C/svg%3E")}
.nav-ic[data-ic="box"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M21 16V8a2 2 0 0 0-1-1.73l-7-4a2 2 0 0 0-2 0l-7 4A2 2 0 0 0 3 8v8a2 2 0 0 0 1 1.73l7 4a2 2 0 0 0 2 0l7-4A2 2 0 0 0 21 16z'/%3E%3Cpolyline points='3.27 6.96 12 12.01 20.73 6.96'/%3E%3Cline x1='12' y1='22' x2='12' y2='12'/%3E%3C/svg%3E")}
.nav-ic[data-ic="card"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Crect x='1' y='4' width='22' height='16' rx='2'/%3E%3Cline x1='1' y1='10' x2='23' y2='10'/%3E%3C/svg%3E")}
.nav-ic[data-ic="coins"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cellipse cx='9' cy='6' rx='7' ry='3'/%3E%3Cpath d='M2 6v6c0 1.66 3.13 3 7 3s7-1.34 7-3V6'/%3E%3Cpath d='M2 12v6c0 1.66 3.13 3 7 3 1.5 0 2.9-.2 4-.55'/%3E%3Cellipse cx='17' cy='15' rx='5' ry='2.5'/%3E%3C/svg%3E")}
.nav-ic[data-ic="chart"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cline x1='18' y1='20' x2='18' y2='10'/%3E%3Cline x1='12' y1='20' x2='12' y2='4'/%3E%3Cline x1='6' y1='20' x2='6' y2='14'/%3E%3Cline x1='3' y1='20' x2='21' y2='20'/%3E%3C/svg%3E")}
.nav-ic[data-ic="contact"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M16 21v-2a4 4 0 0 0-4-4H6a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='9' cy='7' r='4'/%3E%3Cpath d='M22 21v-2a4 4 0 0 0-3-3.87'/%3E%3C/svg%3E")}
.nav-ic[data-ic="cart"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Ccircle cx='9' cy='21' r='1'/%3E%3Ccircle cx='20' cy='21' r='1'/%3E%3Cpath d='M1 1h4l2.68 13.39a2 2 0 0 0 2 1.61h9.72a2 2 0 0 0 2-1.61L23 6H6'/%3E%3C/svg%3E")}
.nav-ic[data-ic="bell"]{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M18 8a6 6 0 0 0-12 0c0 7-3 9-3 9h18s-3-2-3-9'/%3E%3Cpath d='M13.73 21a2 2 0 0 1-3.46 0'/%3E%3C/svg%3E")}
.nav-ic{mask-image:var(--m)}

/* ---------- Content ---------- */
.content{margin-left:var(--sidebar-w);padding:calc(var(--appbar-h) + 20px) 22px 40px;max-width:1200px}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:18px;flex-wrap:wrap}

/* ---------- Cards ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;margin-bottom:18px}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-card{max-width:860px}

/* ---------- Stats ---------- */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}
.stat-card{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);color:var(--ink)}
.stat-card:hover{text-decoration:none;transform:translateY(-1px);transition:.15s}
.stat-ic{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center}
.stat-ic.green{background:#e7f1ea} .stat-ic.gold{background:#faf1da}
.stat-ic .nav-ic{width:24px;height:24px}
.stat-ic.gold .nav-ic{color:var(--gold-600)}
.stat-num{font-size:1.5rem;font-weight:700;line-height:1} .stat-lbl{color:var(--muted);font-size:.82rem;margin-top:3px}

/* quick links + timeline */
.quick-links{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.ql{display:flex;align-items:center;gap:10px;padding:12px;border:1px solid var(--line);border-radius:11px;color:var(--ink);font-weight:500}
.ql:hover{background:var(--bg);text-decoration:none}
.timeline{list-style:none;margin:0;padding:0}
.timeline li{display:flex;gap:12px;padding:9px 0;border-bottom:1px solid var(--line)}
.timeline li:last-child{border-bottom:0}
.tl-dot{width:9px;height:9px;border-radius:50%;background:var(--gold-500);margin-top:6px;flex:0 0 auto}
.phase-note{background:#fbfaf4;border:1px dashed var(--gold-400);font-size:.9rem;color:#5b4a1e}

/* ---------- Tables ---------- */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.table{width:100%;border-collapse:collapse;font-size:.9rem}
.table th,.table td{padding:11px 12px;text-align:left;border-bottom:1px solid var(--line);vertical-align:middle}
.table th{font-size:.74rem;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);background:#fafbfa}
.table tbody tr:hover{background:#fafdfb}
.cell-user{display:flex;align-items:center;gap:10px}
.group-title{margin:18px 0 8px;color:var(--green-800);font-size:.95rem;border-left:3px solid var(--gold-500);padding-left:8px}

/* badges */
.badge{display:inline-block;font-size:.74rem;font-weight:600;padding:3px 9px;border-radius:999px}
.badge-ok{background:var(--okbg);color:var(--ok)} .badge-danger{background:var(--dangerbg);color:var(--danger)}
.badge-gold{background:#faf3e0;color:var(--gold-600)}
.badge-warn{background:var(--warnbg);color:var(--warn)} .badge-muted{background:#eef0ee;color:var(--muted)}

/* ---------- Forms ---------- */
.field{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.field-label{font-size:.82rem;font-weight:600;color:#374151}
input,select,textarea{font:inherit;color:var(--ink);background:#fff;border:1px solid #cfd6cf;border-radius:10px;padding:10px 12px;width:100%;outline:none}
input:focus,select:focus,textarea:focus{border-color:var(--green-600);box-shadow:0 0 0 3px rgba(46,125,70,.15)}
input:disabled{background:#f3f4f3;color:var(--muted)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 18px}
.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}
.check{display:flex;align-items:center;gap:9px;margin:6px 0 4px}
.check input{width:auto}
.pw-wrap{position:relative;display:flex}
.pw-toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:transparent;border:0;cursor:pointer;font-size:1.05rem;padding:4px}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid #cfd6cf;color:var(--ink);
  padding:9px 15px;border-radius:10px;font-weight:600;cursor:pointer;font-size:.9rem;transition:.15s}
.btn:hover{background:var(--bg);text-decoration:none}
.btn .nav-ic{width:17px;height:17px}
.btn-primary{background:linear-gradient(135deg,var(--green-800),var(--green-600));border-color:transparent;color:#fff}
.btn-primary:hover{filter:brightness(1.06);background:linear-gradient(135deg,var(--green-800),var(--green-600))}
.btn-primary .nav-ic{color:#fff}
.btn-danger{background:var(--danger);border-color:transparent;color:#fff}
.btn-ok{background:var(--ok);border-color:transparent;color:#fff}
.btn-warn{background:var(--gold-600);border-color:transparent;color:#fff}
.btn-sm{padding:6px 10px;font-size:.82rem}
.btn-block{width:100%;justify-content:center;padding:12px}
.inline{display:inline} .inline-edit{display:flex;gap:8px;align-items:center}
.inline-lbl{font-size:.85rem;color:var(--muted)}

/* toolbar / tabs */
.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.toolbar .grow,.inline-edit .grow{flex:1;min-width:140px}
.toolbar.wrap{flex-wrap:wrap}
.tabs{display:flex;gap:6px;margin-bottom:16px;border-bottom:1px solid var(--line)}
.tab{padding:9px 14px;color:var(--muted);font-weight:600;border-bottom:2px solid transparent}
.tab.active{color:var(--green-800);border-bottom-color:var(--gold-500)}
.tab:hover{text-decoration:none}

/* diff viewer */
.diff summary{cursor:pointer;color:var(--green-700);font-size:.85rem}
.diff-body{margin-top:8px;background:#fafbfa;border:1px solid var(--line);border-radius:9px;padding:8px}
.diff-row{display:grid;grid-template-columns:130px 1fr auto 1fr;gap:8px;align-items:center;padding:3px 0;font-size:.82rem}
.diff-key{font-weight:600;color:#374151}
.diff-old{color:var(--danger);text-decoration:line-through;opacity:.8;word-break:break-word}
.diff-new{color:var(--ok);word-break:break-word}
.diff-arrow{color:var(--muted)}

/* alerts */
.alert{padding:11px 14px;border-radius:11px;margin-bottom:14px;font-size:.9rem;border:1px solid transparent}
.alert-ok{background:var(--okbg);color:var(--ok);border-color:#bfe6cf}
.alert-error{background:var(--dangerbg);color:var(--danger);border-color:#f3c5c0}
.alert-warn{background:var(--warnbg);color:var(--warn);border-color:#ecd9a3}
.alert-info{background:#e8f0fb;color:#1b4f8a;border-color:#bcd6f5}

/* ---------- Auth pages ---------- */
.auth-body{background:linear-gradient(135deg,#0f3a1f 0%,#16532d 45%,#1d6334 100%);min-height:100vh;display:flex;flex-direction:column}
.auth-topbar{display:flex;justify-content:flex-end;padding:14px 18px}
.auth-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px 16px}
.auth-card{background:#fff;border-radius:18px;box-shadow:0 18px 50px rgba(0,0,0,.25);padding:28px 26px;width:100%;max-width:420px}
.auth-logo{text-align:center;margin-bottom:10px}
.auth-logo img{max-width:230px;width:78%;height:auto}
.auth-title{text-align:center;font-size:1.3rem;margin:6px 0 2px}
.auth-sub{text-align:center;color:var(--muted);margin:0 0 18px;font-size:.9rem}
.auth-divider{display:flex;align-items:center;text-align:center;color:var(--muted);font-size:.8rem;margin:18px 0}
.auth-divider::before,.auth-divider::after{content:"";flex:1;height:1px;background:var(--line)}
.auth-divider span{padding:0 12px}
.g_id_signin{display:flex;justify-content:center}
.auth-foot{text-align:center;margin-top:16px}
.auth-copyright{color:rgba(255,255,255,.85);margin-top:18px}

/* ---------- Responsive / mobile (point 12) ---------- */
@media (max-width:860px){
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .grid-2{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .quick-links{grid-template-columns:1fr}
}
@media (max-width:760px){
  .nav-toggle{display:flex}
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0);box-shadow:0 0 40px rgba(0,0,0,.3)}
  .content{margin-left:0;padding:calc(var(--appbar-h) + 14px) 14px 40px}
  .user-meta{display:none}
  .brand-text{display:none}
  .diff-row{grid-template-columns:1fr;gap:2px}
  .diff-arrow{display:none}
}
@media (max-width:420px){
  .stat-grid{grid-template-columns:1fr}
  .appbar{gap:8px;padding:0 10px}
}

/* ===================== Date / Time picker popups ===================== */
.dp-pop,.tp-pop{background:#fff;border:1px solid var(--line);border-radius:12px;
  box-shadow:0 16px 40px rgba(0,0,0,.22);padding:10px;width:268px;color:var(--ink);
  font-size:14px;animation:dpIn .12s ease}
@keyframes dpIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.dp-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.dp-title{font-weight:700;color:var(--green-700)}
.dp-nav{border:0;background:var(--bg);width:30px;height:30px;border-radius:8px;cursor:pointer;
  font-size:18px;line-height:1;color:var(--green-700)}
.dp-nav:hover{background:var(--green-50,#e8f2ec)}
.dp-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.dp-dow{font-size:11px;text-align:center;color:var(--muted);padding:4px 0;font-weight:600}
.dp-cell{border:0;background:transparent;height:34px;border-radius:8px;cursor:pointer;
  font-size:13px;color:var(--ink)}
.dp-cell.empty{visibility:hidden;cursor:default}
.dp-cell:hover:not(.empty){background:var(--bg)}
.dp-cell.today{outline:1px solid var(--gold-500,#c8962f)}
.dp-cell.sel{background:var(--green-600,#1d6334);color:#fff;font-weight:700}
.dp-foot,.tp-foot{display:flex;justify-content:space-between;margin-top:8px;
  border-top:1px solid var(--line);padding-top:8px}
.dp-link{border:0;background:transparent;color:var(--green-700);font-weight:600;cursor:pointer;
  padding:4px 6px;border-radius:6px;font-size:13px}
.dp-link:hover{background:var(--bg)}
.dp-link.muted{color:var(--muted)}
/* time picker */
.tp-pop{width:180px}
.tp-wrap{display:flex;align-items:stretch;gap:4px;height:180px}
.tp-col{flex:1;overflow-y:auto;scrollbar-width:thin;border:1px solid var(--line);border-radius:8px}
.tp-col::-webkit-scrollbar{width:6px}
.tp-col::-webkit-scrollbar-thumb{background:#cbd5cd;border-radius:6px}
.tp-sep{display:flex;align-items:center;font-weight:800;color:var(--green-700);font-size:18px}
.tp-opt{display:block;width:100%;border:0;background:transparent;padding:7px 0;cursor:pointer;
  text-align:center;font-size:13px;color:var(--ink)}
.tp-opt:hover{background:var(--bg)}
.tp-opt.sel{background:var(--green-600,#1d6334);color:#fff;font-weight:700}

/* ===================== Phase 2 — Wakaf module ===================== */
.field > span{font-size:.82rem;font-weight:600;color:#374151}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}
.detail-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:18px;margin-bottom:18px}
.dl{display:grid;grid-template-columns:150px 1fr;gap:7px 14px;margin:6px 0 0}
.dl dt{color:var(--muted)} .dl dd{margin:0;font-weight:600}
.fieldset{border:1px solid var(--line);border-radius:12px;padding:14px 16px;margin:6px 0 14px}
.fieldset legend{font-size:.85rem;font-weight:700;color:var(--green-700);padding:0 6px}
.action-stack{display:flex;flex-direction:column;gap:9px}
.action-row{display:flex;gap:8px;align-items:center}
.progress{height:6px;border-radius:6px;background:var(--bg);overflow:hidden;margin-top:5px}
.progress span{display:block;height:100%;background:var(--green-600)}
@media (max-width:860px){ .detail-grid{grid-template-columns:1fr} .grid-3{grid-template-columns:1fr} .dl{grid-template-columns:120px 1fr} }
