/* ============================================================
   JADWALIN — App-specific styles (extends styles.css)
   ============================================================ */

/* ---------- Public Nav ---------- */
.nav { position: sticky; top: 0; z-index: 50; background: rgba(251,248,248,.92); backdrop-filter: blur(14px); border-bottom: 1px solid var(--line); }
.nav-inner { display:flex; align-items:center; justify-content:space-between; height: 68px; }
.logo { display:flex; align-items:center; gap:10px; font-weight:800; font-size:20px; letter-spacing:-.03em; }
.logo-mark { width:32px;height:32px;border-radius:9px;background:var(--grad-red);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:19px;box-shadow:var(--sh-red); }
.nav-links { display:flex; gap:28px; font-size:15px; font-weight:600; color:var(--ink-2); }
.nav-links a:hover, .nav-links a.on { color: var(--red-600); }
.nav-right { display:flex; align-items:center; gap:10px; }
@media (max-width: 860px){ .nav-links { display:none; } }

/* ---------- Marketplace cards ---------- */
.mp-hero { background:var(--grad-red-soft); padding:36px 0 24px; border-bottom:1px solid var(--line); }
.mp-search { display:flex; gap:8px; align-items:center; background:#fff; border:1.5px solid var(--line-2); border-radius:var(--r-pill); padding:6px 6px 6px 20px; box-shadow:var(--sh-sm); max-width:680px; }
.mp-search input { flex:1; border:none; outline:none; font-family:inherit; font-size:15px; background:transparent; padding:10px 0; }

.cat-row { display:flex; gap:10px; overflow-x:auto; padding:6px 0 14px; }
.cat-row::-webkit-scrollbar { height:0; }
.cat-pill { flex:none; padding:10px 18px; border-radius:var(--r-pill); background:#fff; border:1px solid var(--line); font-size:13.5px; font-weight:600; color:var(--ink-2); cursor:pointer; white-space:nowrap; transition:.15s;}
.cat-pill:hover { border-color:var(--red-400); }
.cat-pill.on { background:var(--ink); color:#fff; border-color:var(--ink); }

.mp-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
@media (max-width:1000px){ .mp-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .mp-grid{ grid-template-columns:1fr; } }

.mp-card { overflow:hidden; display:flex; flex-direction:column; }
.mp-card .cover { height:140px; display:flex; align-items:center; justify-content:center; font-size:54px; position:relative; }
.mp-card .badge-pos { position:absolute; top:12px; left:12px; }
.mp-card-body { padding:16px 18px 18px; flex:1; display:flex; flex-direction:column; gap:8px; }
.mp-card h3 { font-size:16.5px; display:flex; align-items:center; gap:6px; line-height:1.25; }
.mp-card h3 svg{ width:16px;height:16px;color:var(--blue);flex:none; }
.mp-meta { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--ink-3); }
.mp-rate { display:flex; align-items:center; gap:4px; font-size:13.5px; font-weight:700; }
.mp-rate svg { width:15px;height:15px;fill:var(--gold);color:var(--gold); }
.mp-foot { margin-top:auto; padding-top:12px; border-top:1px solid var(--line); display:flex; align-items:center; justify-content:space-between; }
.mp-price-label { font-size:11.5px; color:var(--muted); }
.mp-price { font-size:17px; font-weight:800; letter-spacing:-.02em; }

/* ---------- Dashboard layout (admin & mitra) ---------- */
.dash-wrap { display:grid; grid-template-columns: 260px 1fr; min-height: 100vh; background: var(--bg); }
@media (max-width: 920px){ .dash-wrap { grid-template-columns: 1fr; } .dash-side { display:none; } }

.dash-side { background:#fff; border-right:1px solid var(--line); padding: 22px 16px; position:sticky; top:0; height:100vh; overflow-y:auto;}
.dash-side .brand { padding: 4px 8px 22px; border-bottom: 1px solid var(--line); display:flex; align-items:center; gap:10px; font-weight:800; font-size:18px; letter-spacing:-.02em; margin-bottom:14px;}
.dash-side .scope { font-family:'Space Mono',monospace; font-size:10px; letter-spacing:.12em; color:var(--muted); padding: 16px 12px 8px; text-transform:uppercase; font-weight:700;}
.dash-side nav a { display:flex; align-items:center; gap:11px; padding: 11px 12px; border-radius: 10px; color: var(--ink-2); font-weight:600; font-size:14.5px; transition:.15s; margin-bottom:2px;}
.dash-side nav a:hover { background: var(--bg-2); color: var(--ink); }
.dash-side nav a.on { background: var(--grad-red); color:#fff; box-shadow: var(--sh-red); }
.dash-side nav a.on svg { color:#fff; }
.dash-side nav a svg { width:17px;height:17px; color:var(--ink-3); }
.dash-side .foot { margin-top: 24px; padding-top: 18px; border-top:1px solid var(--line); }

.dash-main { padding: 0 30px 60px; min-width: 0; }
.dash-top { display:flex; align-items:center; justify-content:space-between; padding: 22px 0; border-bottom: 1px solid var(--line); margin-bottom: 28px; flex-wrap:wrap; gap:14px; }
.dash-top h1 { font-size: 24px; font-weight: 800; letter-spacing:-.02em; }
.dash-top .sub { font-size: 13.5px; color: var(--ink-3); margin-top:2px; }
.user-chip { display:flex; align-items:center; gap:10px; padding:6px 14px 6px 6px; border-radius:99px; background:#fff; border:1px solid var(--line); }
.user-chip .av { width:32px;height:32px;border-radius:50%; background:var(--grad-red); color:#fff; display:flex;align-items:center;justify-content:center; font-weight:700; font-size:13px;}

/* ---------- Stat cards ---------- */
.stat-grid { display:grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 28px; }
@media (max-width: 920px){ .stat-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px){ .stat-grid { grid-template-columns: 1fr; } }

.stat { padding: 20px 22px; background:#fff; border:1px solid var(--line); border-radius: var(--r-lg); position:relative; overflow:hidden; }
.stat .lbl { font-size: 12px; color: var(--ink-3); font-weight:600; letter-spacing:.02em; text-transform:uppercase; }
.stat .val { font-size: 28px; font-weight: 800; letter-spacing:-.02em; margin: 8px 0 6px; }
.stat .delta { font-size: 12.5px; font-weight:700; }
.stat .delta.up { color: var(--green); }
.stat .delta.dn { color: var(--red-500); }
.stat .ic { position:absolute; top:18px; right:18px; width:38px;height:38px;border-radius:11px; background:var(--grad-red-soft); display:flex;align-items:center;justify-content:center; color:var(--red-600);}
.stat .ic svg { width:18px; height:18px; }
.stat.dark { background: var(--ink); color:#fff; border-color: var(--ink); }
.stat.dark .lbl { color: rgba(255,255,255,.6); }
.stat.dark .ic { background: rgba(255,255,255,.08); color:#FFB3B3; }
.stat.grad { background: var(--grad-red); color:#fff; border:none; }
.stat.grad .lbl { color: rgba(255,255,255,.78); }
.stat.grad .ic { background: rgba(255,255,255,.18); color:#fff; }
.stat.grad .delta.up { color: #C7FFE7; }

/* ---------- Tables ---------- */
.table-card { background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; }
.table-head { padding:18px 22px; display:flex; align-items:center; justify-content:space-between; border-bottom:1px solid var(--line); flex-wrap:wrap; gap:10px;}
.table-head h3 { font-size:16.5px; font-weight:700; letter-spacing:-.01em;}
table.t { width:100%; border-collapse:collapse;}
table.t th { text-align:left; padding:12px 22px; font-size:11.5px; font-weight:700; color:var(--ink-3); text-transform:uppercase; letter-spacing:.06em; background:var(--bg-2); border-bottom:1px solid var(--line);}
table.t td { padding:14px 22px; font-size:14px; color:var(--ink); border-bottom:1px solid var(--line); vertical-align:middle;}
table.t tr:last-child td { border-bottom:none;}
table.t tr:hover td { background:var(--bg-2);}
.t-empty { padding: 40px 22px; text-align:center; color: var(--muted); font-size:14px; }

/* ---------- Form ---------- */
.form-grid { display:grid; gap:18px; }
.form-row { display:grid; grid-template-columns: 1fr 1fr; gap:14px; }
@media (max-width:600px){ .form-row { grid-template-columns:1fr; } }
.field label { display:block; font-size:13px; font-weight:600; color:var(--ink-2); margin-bottom:7px; }
.field input, .field select, .field textarea {
    width:100%; padding:12px 14px; font-family:inherit; font-size:14.5px;
    border:1.5px solid var(--line-2); border-radius:10px; background:#fff; color:var(--ink);
    transition:.15s; outline:none;
}
.field input:focus, .field select:focus, .field textarea:focus { border-color: var(--red-500); box-shadow: 0 0 0 4px rgba(225,29,42,.08); }
.field .help { font-size: 12px; color: var(--muted); margin-top:5px; }

/* ---------- Auth pages ---------- */
.auth-wrap { min-height:100vh; display:grid; grid-template-columns: 1fr 1fr; }
@media (max-width:880px){ .auth-wrap{ grid-template-columns:1fr; } .auth-side{ display:none; } }
.auth-side { background:var(--grad-red-deep); color:#fff; padding:50px; display:flex; flex-direction:column; justify-content:space-between; position:relative; overflow:hidden;}
.auth-side::before { content:''; position:absolute; inset:0; background: radial-gradient(700px 400px at 80% -10%, rgba(255,255,255,.12), transparent 60%); }
.auth-side > * { position:relative; z-index:1; }
.auth-form { padding: 50px; display:flex; flex-direction:column; justify-content:center; max-width:520px; width:100%; margin:0 auto;}

/* ---------- Slot picker for booking ---------- */
.slot-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
@media (max-width:560px){ .slot-grid{ grid-template-columns:repeat(3,1fr); } }
.slot-btn { padding:12px 0; border:1.5px solid var(--line-2); border-radius:10px; background:#fff; font-size:14px; font-weight:700; color:var(--ink-2); cursor:pointer; text-align:center; transition:.15s;}
.slot-btn:hover { border-color: var(--red-400); color: var(--red-600);}
.slot-btn.on { background: var(--grad-red); color:#fff; border-color:transparent; box-shadow: var(--sh-red);}
.slot-btn.dis { background:#F5F0F1; color:var(--muted); cursor:not-allowed; }

/* ---------- Mini calendar ---------- */
.mini-cal { display:grid; grid-template-columns: repeat(7,1fr); gap:6px; }
.mini-cal .d { aspect-ratio:1; border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:13px; font-weight:600; cursor:pointer; color:var(--ink-2); background:var(--bg-2); transition:.12s;}
.mini-cal .d:hover { background:var(--red-50); color:var(--red-600);}
.mini-cal .d.head { background:transparent; cursor:default; color:var(--muted); font-size:11px; text-transform:uppercase; }
.mini-cal .d.dim { background:transparent; color:var(--muted); cursor:default; }
.mini-cal .d.on { background:var(--grad-red); color:#fff; box-shadow:var(--sh-red); }
.mini-cal .d.past { color:var(--muted); cursor:not-allowed; background:transparent; }

/* ---------- Sponsor / detail ---------- */
.tenant-hero { background:var(--grad-red-soft); padding: 40px 0; }
.tenant-cover { height:200px; border-radius:var(--r-lg); display:flex; align-items:center; justify-content:center; font-size:90px;}

.layanan-row { padding: 18px; background:#fff; border:1px solid var(--line); border-radius: var(--r-md); display:flex; align-items:center; gap:18px; transition:.15s;}
.layanan-row:hover { border-color: var(--red-400); box-shadow: var(--sh-sm);}
.layanan-row.selected { border-color: var(--red-500); box-shadow: 0 0 0 3px rgba(225,29,42,.1);}
.layanan-row .info { flex:1; }
.layanan-row .pricing { text-align:right; }
.layanan-row .pricing .v { font-size:18px; font-weight:800; letter-spacing:-.02em;}

/* ---------- Responsive helpers ---------- */
.hide-sm { }
@media (max-width:760px){ .hide-sm{ display:none !important; } }

.empty-state { padding:60px 24px; text-align:center; color:var(--ink-3); }
.empty-state .em-ic { font-size:48px; margin-bottom:14px; opacity:.5; }

/* mobile dash toggle */
.dash-mob-bar { display:none; }
@media (max-width:920px){
  .dash-mob-bar{ display:flex; align-items:center; justify-content:space-between; padding:14px 18px; background:#fff; border-bottom:1px solid var(--line); position:sticky; top:0; z-index:30;}
  .dash-main { padding: 0 18px 50px; }
}
