:root{
  /* Tema & efek dasar */
  --bg-1:#0b1020; --bg-2:#0e1530; --bg-3:#0a0f24;
  --text:#e8ecf4; --muted:#a9b6c9;
  --border:rgba(255,255,255,.08);
  --accent:#0E4D92; --accent-2:#0A3A6D;
  --radius:20px; --shadow:0 10px 30px rgba(0,0,0,.35);
  --safe-b: env(safe-area-inset-bottom, 0px);
  --noise: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="128" height="128" viewBox="0 0 128 128"><filter id="n"><feTurbulence type="fractalNoise" baseFrequency="0.8" numOctaves="2"/></filter><rect width="128" height="128" filter="url(%23n)" opacity=".035"/></svg>');

  /* Dock dinamis */
  --dock-font: clamp(13px, 3.7vw, 18px);
  --dock-gap: clamp(6px, 2vw, 10px);
  --dock-radius: clamp(14px, 3.2vw, 22px);

  /* Layout scale */
  --container: 860px;
  --g1: 10px; --g2: 12px; --g3: 16px; --g4: 20px; --g5: 24px; --g6: 28px;

  /* Ukuran ikon (apps & dock) */
  --icon-box: clamp(52px, 10vw, 64px);
  --icon-pad: clamp(6px, 1.4vw, 10px);
  --dock-ico: clamp(20px, 4.8vw, 26px); /* <- tambahan untuk dock flat */
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; color:var(--text);
  font:400 16px/1.5 ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, "Noto Sans";
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
  -webkit-tap-highlight-color: transparent;
  background:
    radial-gradient(1200px 600px at 20% -10%, rgba(14,77,146,.25),transparent 60%),
    radial-gradient(900px 500px at 90% 10%, rgba(10,58,109,.22),transparent 55%),
    linear-gradient(180deg,var(--bg-1),var(--bg-2) 50%, var(--bg-3) 100%);
  background-attachment: fixed;
  overflow-x:hidden;
}

/* Aurora + noise */
.aurora{
  position:fixed; inset:-20% -10%;
  background:
    radial-gradient(60% 40% at 70% 10%, rgba(14,77,146,.18), transparent 60%),
    radial-gradient(50% 35% at 20% 80%, rgba(10,58,109,.16), transparent 60%),
    conic-gradient(from 120deg, transparent 0 30%, rgba(14,77,146,.08) 40%, transparent 70%);
  filter: blur(38px) saturate(120%);
  animation: float 18s ease-in-out infinite alternate;
  pointer-events:none; z-index:-1; mix-blend-mode: screen;
}
@keyframes float{ 0%{transform:translateY(-2%) scale(1)} 100%{transform:translateY(2%) scale(1.03)} }
@media (prefers-reduced-motion:reduce){ .aurora{ animation:none } }
.grain{ position:fixed; inset:0; background-image:var(--noise); pointer-events:none; z-index:-1; }

/* ===== Container ===== */
.page{ max-width: var(--container); margin: 0 auto; padding: 0 var(--g3); }

/* ===== Layout utama ===== */
.wrap{ padding: 12px 0 calc(96px + var(--safe-b)); min-height: 100dvh; }

/* ===== Greeting Card ===== */
.greet-card{
  position: relative;
  margin: var(--g4) 0 var(--g3);
  display:flex; align-items:center; gap: var(--g3);
  background:#0d0f13; border:1px solid var(--border);
  border-radius: clamp(18px, 4.5vw, 30px);
  padding: clamp(20px, 5vw, 28px) clamp(14px, 4.4vw, 24px);
  box-shadow: 0 10px 24px rgba(0,0,0,.28);
  cursor: pointer; user-select:none;
}

/* Overline tanggal di dalam kartu */
.greet-overline{
  position: absolute; top: 10px; left: 16px; right: 16px;
  font-size: clamp(11px, 2.4vw, 12px);
  color: var(--muted);
  letter-spacing: .2px; font-weight: 700;
  text-transform: capitalize; /* huruf awal tiap kata kapital */
  pointer-events: none;       /* tidak mengganggu toggle kartu */
}

/* Konten salam */
.greet-text{ flex:1 1 auto; min-width:0; margin-top: 10px; }
.greet-big{ font-size: clamp(18px, 5.2vw, 28px); font-weight:800; color:#f1f5ff; }
.name-big {
  font-size: clamp(20px, 7vw, 36px); /* lebih kecil dan compact */
  font-weight: 900;
  color: #fff;
  line-height: 1.08;
  letter-spacing: .2px;
  text-wrap: balance;
}

/* Profil / Logout slot */
.profile-slot{ position:relative; flex:0 0 auto; width: clamp(68px, 18vw, 88px); height: clamp(68px, 18vw, 88px); }
.avatar-large{
  width:100%; height:100%; border-radius:50%; object-fit:cover;
  background:#111a2a; border:2.5px solid #fff; box-shadow:0 8px 20px rgba(0,0,0,.35);
}
.logout-btn{
  width:100%; height:100%; border:none; cursor:pointer;
  border-radius:50%; background:#ff4d4f; color:#fff;
  font-size: clamp(24px, 6.4vw, 32px);
  display:grid; place-items:center;
  box-shadow:0 10px 26px rgba(255,77,79,.35), inset 0 -4px 0 rgba(0,0,0,.25);
}
.logout-btn:active{ transform: translateY(1px) }

/* ===== Info pill ===== */
.pill{
  margin: var(--g5) 0 var(--g4);
  padding: 12px 14px;
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid var(--border); border-radius:999px;
  color:#d9e3f7; backdrop-filter: blur(10px);
  box-shadow: var(--shadow);
  display:flex; align-items:center; gap:10px;
}
.pill-dot{
  width:10px; height:10px; border-radius:50%;
  background: radial-gradient(circle at 30% 30%, var(--accent), var(--accent-2));
  box-shadow:0 0 14px var(--accent); flex:0 0 auto;
}

/* ===== Apps grid ===== */
.apps{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(14px, 3vw, 20px);
  padding-bottom: var(--g6);
}

.app{
  background:none; border:none; box-shadow:none; padding:0;
  display:flex; flex-direction:column; align-items:center; justify-content:flex-start;
  gap: clamp(6px, 1.8vw, 10px);
  text-align:center; text-decoration:none; color:var(--text);
  min-width:0;                             /* cegah label ketindih layout */
  transition: transform .12s ease;
}
.app:active{ transform:scale(.92); }

/* ===== Ikon Hybrid: emoji/SVG & PNG ===== */
.app-icon{
  width: var(--icon-box);
  height: var(--icon-box);
  aspect-ratio: 1/1;
  border-radius: 16px;
  display:grid; place-items:center;
  background: linear-gradient(135deg, var(--accent), var(--accent-2)); /* frame */
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 6px 16px rgba(14,77,146,.35);
  overflow: hidden;
  padding: var(--icon-pad);                /* sisakan napas utk PNG */
  font-size: calc(var(--icon-box) * .48);  /* emoji/SVG tetap proporsional */
}
.app-icon img,
.app-icon svg{
  width:100%; height:100%; object-fit:contain; display:block; /* PNG/SVG proporsional */
}
/* Opsi: PNG polos tanpa frame */
.app-icon.no-bg{ background: rgba(255,255,255,.05); border:none; box-shadow:none; }

/* Label */
.app-name{
  display:block; margin-top:2px;
  font-size: clamp(11px, 2.8vw, 13px);
  color:#e1e7f5;
  max-width:100%;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  min-height:1.2em;                       /* jaga tinggi baris minimum */
}

/* ===== Dock (ikon flat) ===== */
.dock{
  position:fixed; left:0; right:0; bottom:0;
  padding: 10px 14px calc(10px + var(--safe-b));
  background: rgba(10,15,26,.18); backdrop-filter: blur(10px);
  z-index:50;
}
.dock-inner{
  height: clamp(46px, calc(var(--dock-font) * 2.2), 54px);
  border-radius: var(--dock-radius);
  border:1px solid var(--border);
  display:grid; grid-template-columns: repeat(5, 1fr);
  gap: clamp(6px, 2vw, 10px); padding: clamp(4px, 1.2vw, 6px);
  background: rgba(255,255,255,.05); max-width: var(--container); margin: 0 auto;
}
.dock-btn{
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  border-radius: clamp(8px, 2.4vw, 12px); text-decoration:none; color:var(--text);
  font-size: clamp(15px, 3.8vw, 17px); line-height:1; user-select:none;
  outline:1.5px solid transparent;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  transition: background .18s ease, transform .12s ease, outline-color .18s ease, box-shadow .18s ease;
}
.dock-btn span{ display:block; font-size: clamp(9px, 2.4vw, 11px); line-height:1.1; margin-top:4px; }
.dock-btn:hover{ background:rgba(255,255,255,.06) }

/* Slot ikon di dock: FLAT, tanpa frame */
.dock-btn .app-icon{
  width: var(--dock-ico);
  height: var(--dock-ico);
  padding: 0;
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  overflow: visible;
}
/* PNG/SVG langsung di dock */
.dock-btn .app-icon img,
.dock-btn .app-icon svg{
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
/* Jika pakai emoji langsung dalam .app-icon di dock */
.dock-btn .app-icon{ font-size: var(--dock-ico); }

/* Efek tekan: dukung :active & class .is-pressed (JS) */
.dock-btn:active,
.dock-btn.is-pressed{
  transform: translateY(1px) scale(.98);
  background: rgba(255,255,255,.15);
  box-shadow: 0 0 10px rgba(255,255,255,.18);
}

/* Tab terpilih */
.dock-btn[aria-current="page"]{
  outline-color: color-mix(in oklab, var(--accent) 40%, transparent);
  background: rgba(255,255,255,0.07);
}

/* Disabled app/dock */
.app.is-disabled{
  pointer-events:none;
  opacity:.4;
}

.dock-btn.is-disabled{
  pointer-events:none;
  opacity:.4;
}

/* Overlay spinner for schedule lookup */
#lookupOverlay{
  position:fixed; inset:0; display:none;
  align-items:center; justify-content:center;
  background:rgba(0,0,0,.45);
  z-index:100;
}
#lookupOverlay.show{ display:flex; }
#lookupOverlay .spinner{
  width:48px; height:48px; border-radius:50%;
  border:5px solid rgba(255,255,255,.15);
  border-top-color:var(--accent);
  animation:spin .9s linear infinite;
}
@keyframes spin{ to{ transform:rotate(360deg); } }

/* Offline bottom sheet */
