/* ==== Vivid White & Blue Glass Theme ==== */
:root{
  --white:#ffffff;
  --blue-50:#f0f9ff;
  --blue-100:#e0f2ff;
  --blue-300:#67e8f9;
  --blue-500:#0ea5e9;
  --blue-600:#0284c7;
  --ink:#0b1324;
  --muted:#64748b;
  --glass:rgba(255,255,255,.16);
  --card:rgba(255,255,255,.22);
  --border:rgba(2,132,199,.25);
  --ring:rgba(2,132,199,.6);
  --gray-100:#f3f4f6;
  --gray-200:#e5e7eb;
  --gray-300:#d1d5db;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:"Cairo",system-ui,-apple-system,"Segoe UI",Roboto,"Noto Sans Arabic","Noto Sans",sans-serif;
  color:var(--ink);
  background:
    radial-gradient(900px 600px at 95% -10%, rgba(103,232,249,.25), transparent 60%),
    radial-gradient(900px 600px at -10% 95%, rgba(14,165,233,.18), transparent 60%),
    linear-gradient(180deg, var(--white), var(--blue-50));
}
.container{max-width:1200px; margin:0 auto; padding:16px; padding-bottom:96px}
.glass{background:var(--glass); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px); border:1px solid var(--border); box-shadow:0 12px 30px rgba(2,132,199,.15), inset 0 1px 0 rgba(255,255,255,.75); border-radius:22px}
.card{background:var(--card); backdrop-filter:blur(18px); border:1px solid var(--border); box-shadow:0 10px 28px rgba(2,132,199,.22); border-radius:22px}
.h1{font-weight:800; font-size:clamp(22px,4.8vw,34px); margin:0 0 6px}
.muted{color:var(--muted)}
.sub{font-size:14px}
.sub2{font-size:12px}
.row{display:grid; gap:16px}
@media(min-width:1024px){ .row{ grid-template-columns:2fr 1fr } }
.btn{appearance:none; border:none; cursor:pointer; padding:16px 18px; border-radius:20px; font-weight:800; color:#06223a; background:linear-gradient(180deg,rgba(255,255,255,.70),rgba(255,255,255,.22)); border:1px solid rgba(2,132,199,.35); box-shadow:0 8px 24px rgba(14,165,233,.22), inset 0 1px 0 rgba(255,255,255,.9); transition:transform .18s ease, box-shadow .18s ease}
.btn:focus-visible{outline:3px solid var(--ring)}
.btn:hover{transform:translateY(-2px); box-shadow:0 16px 36px rgba(14,165,233,.3), inset 0 1px 0 rgba(255,255,255,1)}
.btn.block{display:block; width:100%}
.btn.sm{padding:10px 14px; border-radius:14px}
.phase-grid{display:grid; grid-template-columns:1fr; gap:12px; margin-top:8px}
@media(min-width:768px){ .phase-grid{grid-template-columns:repeat(3,1fr)} }
.phase{display:flex; align-items:center; justify-content:space-between; padding:18px; background:linear-gradient(140deg, rgba(255,255,255,.85), rgba(14,165,233,.10))}
.badge{display:inline-flex; align-items:center; justify-content:center; width:48px; height:48px; border-radius:14px; background:var(--blue-100); color:var(--blue-600); font-weight:800; border:1px solid rgba(2,132,199,.35)}
.panel{margin-top:16px}
.panel.hidden{display:none}
.tabs{display:flex; gap:8px; padding:10px}
.tab{padding:10px 14px; border-radius:16px; background:linear-gradient(180deg,rgba(255,255,255,.6),rgba(255,255,255,.22)); border:1px solid rgba(2,132,199,.35); font-weight:800; cursor:pointer; color:#06314d}
.tab.active{box-shadow:0 8px 22px rgba(14,165,233,.25)}
.section{padding:16px}
.grid-cal{display:grid; grid-template-columns:repeat(7,1fr); gap:8px; text-align:center}
.day-h{font-size:12px; font-weight:800; color:#0b3a5a}
.cell{height:100px; padding:10px; text-align:start; border-radius:16px; background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.7)); border:1px solid rgba(2,132,199,.25); box-shadow:inset 0 1px 0 rgba(255,255,255,.95); transition:transform .12s ease}
.cell:active{transform:scale(.99)}
.cell .n{font-size:13px; font-weight:800}
.cell .list{margin-top:4px; display:grid; gap:2px}
.weekend{background:linear-gradient(180deg, rgba(243,244,246,.98), rgba(229,231,235,.92)); border-color: var(--gray-300); color:#475569}
.weekend .n{color:#334155}
.weekend .pill{background:rgba(148,163,184,.35); border-color:rgba(148,163,184,.45); color:#334155}
.kpi{height:10px; width:100%; background:rgba(2,132,199,.12); border-radius:999px; overflow:hidden; border:1px solid var(--border)}
.kpi>span{display:block; height:10px; background:linear-gradient(90deg,var(--blue-500),var(--blue-600))}
.stack{display:grid; gap:12px}
.table{width:100%; border-collapse:separate; border-spacing:0 8px}
.th{font-size:12px; color:#0b3a5a; text-align:right; padding:6px 8px}
.tr{background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.7)); border:1px solid rgba(2,132,199,.25)}
.td{padding:10px 8px; font-size:14px}
.sticky-nav{position:fixed; bottom:12px; left:50%; transform:translateX(-50%); width:min(680px,calc(100% - 24px)); display:grid; grid-template-columns:repeat(3,1fr); gap:8px; padding:8px; z-index:20}
.hidden-sm{display:none}
@media(min-width:1024px){ .sticky-nav{display:none} .hidden-sm{display:block}}
.pill{display:inline-flex; gap:6px; align-items:center; font-size:11px; padding:4px 8px; border-radius:999px; background:rgba(255,255,255,.85); border:1px solid rgba(2,132,199,.35); color:#06314d}
.flex-between{display:flex; align-items:center; justify-content:space-between; gap:8px}
.month{font-weight:800; color:#06314d}
.mb10{margin-bottom:10px}
.mt6{margin-top:6px}
.mt10{margin-top:10px}
.psmall{font-size:12px}
.pbig{font-size:20px; font-weight:800}
.obj-list{margin:10px 0 0; padding:0 16px 0 0; display:grid; gap:6px}
.row-inline{display:flex; gap:8px; flex-wrap:wrap; align-items:center; margin-bottom:10px}
.date-input{padding:10px 12px; border-radius:12px; border:1px solid var(--border); background:rgba(255,255,255,.95); font-family:inherit}
.row1col{display:grid; grid-template-columns:1fr; gap:12px}
.gap12{gap:12px}
.day-grid{display:grid; gap:8px; max-height:420px; overflow:auto}
.sec-title{font-weight:800; margin-bottom:8px; color:#06314d}
.table-title{padding:14px 16px; font-weight:800; color:#06314d}
.overflow{overflow:auto}
.p0{padding:0}
.subtitle{font-weight:700; margin-bottom:6px}
.reset{padding:0; margin:0}
.fs14{font-size:14px}

/* ==== Password Gate styles ==== */
.gate{position:fixed; inset:0; display:flex; align-items:center; justify-content:center; padding:20px; background:linear-gradient(180deg, rgba(255,255,255,.85), rgba(224,242,254,.85)); backdrop-filter:blur(10px); z-index:100}
.gate-card{width:min(520px,100%); padding:22px}
.gate-head{margin-bottom:10px}
.gate-form{display:grid; gap:10px; margin-top:8px}
.gate-input{padding:14px 16px; border-radius:16px; border:1px solid var(--border); font-family:inherit; background:#fff}
.pw-error{margin-top:6px; color:#b91c1c; font-weight:700; font-size:13px}
