/* =====================================================================
   Doclyn Pasien - app.css
   Design system biru + emas (selaras brand doclyn.id)
   ===================================================================== */
:root{
  --c-bg:        #f5f6fa;
  --c-surface:   #ffffff;
  --c-primary:   #1a1a2e;   /* navy brand (top bar, teks kuat) */
  --c-primary-2: #2563eb;   /* biru aksi utama */
  --c-primary-d: #1e40af;
  --c-accent:    #f5be01;   /* emas Doclyn */
  --c-accent-2:  #3b82f6;
  --c-text:      #1f2433;
  --c-text-soft: #6b7280;
  --c-line:      #e6e8ef;
  --c-success:   #16a34a;
  --c-warning:   #d97706;
  --c-danger:    #dc2626;
  --c-info:      #2563eb;
  --radius:      16px;
  --radius-sm:   10px;
  --shadow-sm:   0 1px 3px rgba(16,24,40,.06);
  --shadow-md:   0 8px 24px rgba(16,24,40,.10);
  --tabbar-h:    66px;
  --safe-b:      env(safe-area-inset-bottom, 0px);
  --safe-t:      env(safe-area-inset-top, 0px);
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{
  font-family:'Plus Jakarta Sans',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--c-text);background:#e9ebf2;font-size:14px;line-height:1.45;
  -webkit-font-smoothing:antialiased;
}
a{text-decoration:none;color:inherit}
button{font-family:inherit;cursor:pointer;border:none;background:none}
img{max-width:100%;display:block}

/* ---------- Phone canvas (frame mobile di-center pada desktop) ---------- */
.phone-canvas{display:flex;justify-content:center;min-height:100vh}
.phone-frame{
  position:relative;width:100%;max-width:430px;min-height:100vh;
  background:var(--c-bg);display:flex;flex-direction:column;
  box-shadow:0 0 40px rgba(16,24,40,.12);overflow:hidden;
}
@media(min-width:480px){
  .phone-frame{min-height:92vh;margin:4vh 0;border-radius:28px}
}

/* ---------- Scrollable content ---------- */
.app-content{
  flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;
  padding:16px 16px calc(var(--tabbar-h) + var(--safe-b) + 16px);
}
.app-content.no-tabbar{padding-bottom:24px}

/* ---------- App header (home, dengan sapaan) ---------- */
.app-header{
  background:linear-gradient(135deg,var(--c-primary) 0%,#2a2a4a 100%);
  color:#fff;padding:calc(var(--safe-t) + 18px) 16px 18px;
}
.app-header-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.greeting{font-size:13px;opacity:.8}
.user-name{font-size:19px;font-weight:700;margin-top:2px}
.app-header-actions{display:flex;align-items:center;gap:10px}
.avatar{
  width:42px;height:42px;border-radius:50%;background:var(--c-accent);
  color:var(--c-primary);font-weight:800;display:flex;align-items:center;justify-content:center;font-size:17px;
}

/* ---------- Topbar (halaman dalam) ---------- */
.topbar{
  position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:8px;
  background:var(--c-surface);border-bottom:1px solid var(--c-line);
  padding:calc(var(--safe-t) + 10px) 12px 10px;min-height:54px;
}
.topbar-title{flex:1;font-size:17px;font-weight:700;margin:0;text-align:center}
.topbar-back,.topbar-action{
  width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  font-size:17px;color:var(--c-text);
}
.topbar-back:active,.icon-btn:active{background:var(--c-line)}
.icon-btn{position:relative;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:17px;color:#fff}
.app-header .icon-btn{background:rgba(255,255,255,.12)}
.topbar .icon-btn{color:var(--c-text)}
.badge-dot{
  position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;
  background:var(--c-danger);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;
}

/* ---------- Bottom tab bar + FAB ---------- */
.tab-bar{
  position:absolute;left:0;right:0;bottom:0;z-index:30;height:calc(var(--tabbar-h) + var(--safe-b));
  padding-bottom:var(--safe-b);background:var(--c-surface);border-top:1px solid var(--c-line);
  display:flex;align-items:flex-start;justify-content:space-around;
}
.tab-item{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding-top:9px;
  font-size:11px;color:var(--c-text-soft);font-weight:600;
}
.tab-item i{font-size:19px}
.tab-item.active{color:var(--c-primary-2)}
.tab-icon-wrap{position:relative}
.tab-badge{position:absolute;top:-2px;right:-5px;width:8px;height:8px;border-radius:50%;background:var(--c-danger);border:1.5px solid var(--c-surface)}
.tab-fab{flex:0 0 64px;display:flex;justify-content:center}
.tab-fab-circle{
  width:56px;height:56px;border-radius:50%;margin-top:-22px;
  background:linear-gradient(135deg,var(--c-primary-2),var(--c-primary-d));
  color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;
  box-shadow:0 6px 16px rgba(37,99,235,.45);border:4px solid var(--c-surface);
}
.tab-fab:active .tab-fab-circle{transform:scale(.94)}

/* ---------- Card ---------- */
.card{background:var(--c-surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px;margin-bottom:14px}
.card-flat{background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--radius);padding:14px;margin-bottom:12px}
.section-title{font-size:16px;font-weight:700;margin:18px 2px 10px}
.section-head{display:flex;align-items:center;justify-content:space-between;margin:18px 2px 10px}
.section-head .link{color:var(--c-primary-2);font-size:13px;font-weight:600}
.muted{color:var(--c-text-soft)}
.caption{font-size:12px;color:var(--c-text-soft)}

/* ---------- Quick actions (home) ---------- */
.quick-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.quick-item{
  background:var(--c-surface);border-radius:var(--radius);padding:14px 8px;text-align:center;box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;align-items:center;gap:8px;
}
.quick-item:active{transform:scale(.97)}
.quick-ico{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:20px;color:#fff}
.quick-item span{font-size:12px;font-weight:600;line-height:1.2}
.ico-blue{background:linear-gradient(135deg,#2563eb,#1e40af)}
.ico-teal{background:linear-gradient(135deg,#14b8a6,#0d9488)}
.ico-gold{background:linear-gradient(135deg,#f5be01,#d99a06)}

/* ---------- List item ---------- */
.list-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--c-line)}
.list-item:last-child{border-bottom:none}
.list-ico{width:42px;height:42px;border-radius:12px;background:#eef2ff;color:var(--c-primary-2);display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}
.list-body{flex:1;min-width:0}
.list-title{font-weight:600;font-size:14px}
.list-sub{font-size:12px;color:var(--c-text-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.list-chev{color:#c3c7d4}

/* ---------- Mitra card ---------- */
.mitra-card{display:flex;gap:12px;align-items:center;background:var(--c-surface);border-radius:var(--radius);padding:12px;box-shadow:var(--shadow-sm);margin-bottom:10px}
.mitra-logo{width:52px;height:52px;border-radius:14px;background:#eef2ff;display:flex;align-items:center;justify-content:center;color:var(--c-primary-2);font-size:20px;flex-shrink:0}
.mitra-info{flex:1;min-width:0}
.mitra-name{font-weight:700;font-size:14px}
.mitra-meta{font-size:12px;color:var(--c-text-soft);display:flex;gap:10px;flex-wrap:wrap;margin-top:3px}
.mitra-meta .open{color:var(--c-success);font-weight:600}
.mitra-meta .closed{color:var(--c-danger);font-weight:600}
.rating{color:var(--c-accent);font-weight:600}

/* ---------- Status chip ---------- */
.chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;font-size:11.5px;font-weight:700}
.chip i{font-size:9px}
.chip-wait{background:#fff7ed;color:#c2410c}
.chip-proc{background:#eff6ff;color:#1d4ed8}
.chip-done{background:#ecfdf5;color:#047857}
.chip-cancel{background:#fef2f2;color:#b91c1c}
.chip-soft{background:var(--c-line);color:var(--c-text-soft)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:48px;padding:0 20px;border-radius:14px;font-weight:700;font-size:15px;transition:transform .08s}
.btn:active{transform:scale(.98)}
.btn-block{display:flex;width:100%}
.btn-primary{background:linear-gradient(135deg,var(--c-primary-2),var(--c-primary-d));color:#fff;box-shadow:0 4px 12px rgba(37,99,235,.3)}
.btn-secondary{background:#eef2ff;color:var(--c-primary-2)}
.btn-gold{background:var(--c-accent);color:var(--c-primary)}
.btn-ghost{background:transparent;color:var(--c-text-soft)}
.btn-danger{background:var(--c-danger);color:#fff}
.btn[disabled],.btn.is-loading{opacity:.6;pointer-events:none}
.btn.is-loading::after{content:'';width:16px;height:16px;border:2px solid rgba(255,255,255,.5);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- Forms ---------- */
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px}
.input,.select,.textarea{
  width:100%;min-height:48px;padding:12px 14px;border:1.5px solid var(--c-line);border-radius:12px;
  font-size:15px;background:var(--c-surface);color:var(--c-text);transition:border-color .15s;
}
.textarea{min-height:96px;resize:vertical}
.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--c-primary-2)}
.field.has-error .input,.field.has-error .select{border-color:var(--c-danger)}
.field-error{color:var(--c-danger);font-size:12px;margin-top:5px}
.input-group{position:relative}
.input-group .input{padding-right:46px}
.input-suffix{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:38px;height:38px;display:flex;align-items:center;justify-content:center;color:var(--c-text-soft)}

/* ---------- Result table (lab) ---------- */
.result-table{width:100%;border-collapse:collapse;font-size:13px}
.result-table th{text-align:left;color:var(--c-text-soft);font-weight:600;padding:8px 6px;border-bottom:1px solid var(--c-line);font-size:12px}
.result-table td{padding:10px 6px;border-bottom:1px solid var(--c-line)}
.result-table .val{font-weight:700}
.flag-normal{color:var(--c-success);font-weight:700}
.flag-high{color:var(--c-danger);font-weight:700}
.flag-low{color:var(--c-warning);font-weight:700}

/* ---------- Sheet (bottom-sheet / action sheet) ---------- */
.sheet-overlay{position:absolute;inset:0;z-index:50;background:rgba(16,24,40,.45);display:flex;align-items:flex-end;opacity:0;pointer-events:none;transition:opacity .25s}
.sheet-overlay.open{opacity:1;pointer-events:auto}
.sheet{width:100%;background:var(--c-surface);border-radius:22px 22px 0 0;padding:10px 16px calc(16px + var(--safe-b));transform:translateY(100%);transition:transform .28s cubic-bezier(.32,.72,0,1)}
.sheet-overlay.open .sheet{transform:translateY(0)}
.sheet-handle{width:40px;height:4px;border-radius:2px;background:var(--c-line);margin:6px auto 12px}
.sheet-title{font-size:17px;font-weight:700;margin-bottom:12px}
.sheet-actions{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}
.sheet-action{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--c-line);border-radius:14px}
.sheet-action:active{background:#f7f8fc}
.sheet-action-ico{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:19px;flex-shrink:0}
.sheet-action-txt{flex:1;display:flex;flex-direction:column}
.sheet-action-txt small{color:var(--c-text-soft);font-size:12px}
.sheet-action-chev{color:#c3c7d4}

/* ---------- Toast ---------- */
.toast-container{position:fixed;left:50%;transform:translateX(-50%);bottom:calc(var(--tabbar-h) + 20px);z-index:9999;display:flex;flex-direction:column;gap:8px;width:calc(100% - 32px);max-width:398px}
.toast{display:flex;align-items:center;gap:10px;background:var(--c-primary);color:#fff;border-radius:12px;padding:12px 14px;box-shadow:var(--shadow-md);opacity:0;transform:translateY(12px);transition:all .3s;overflow:hidden;position:relative}
.toast.show{opacity:1;transform:translateY(0)}
.toast.hide{opacity:0;transform:translateY(12px)}
.toast-icon{font-size:18px}
.toast-success .toast-icon{color:#4ade80}
.toast-danger .toast-icon{color:#f87171}
.toast-warning .toast-icon{color:#fbbf24}
.toast-info .toast-icon{color:#60a5fa}
.toast-body{flex:1;font-size:13.5px}
.toast-close{color:rgba(255,255,255,.7);font-size:20px;line-height:1}
.toast-progress{position:absolute;left:0;bottom:0;height:3px;background:rgba(255,255,255,.4);width:100%;transform-origin:left;animation:toastbar linear forwards}
@keyframes toastbar{from{transform:scaleX(1)}to{transform:scaleX(0)}}

/* ---------- Skeleton ---------- */
.skeleton{background:linear-gradient(90deg,#eef0f5 25%,#e3e6ee 37%,#eef0f5 63%);background-size:400% 100%;animation:shimmer 1.4s ease infinite;border-radius:8px}
@keyframes shimmer{0%{background-position:100% 50%}100%{background-position:0 50%}}
.sk-line{height:12px;margin-bottom:8px}
.sk-line.w60{width:60%}.sk-line.w40{width:40%}.sk-line.w80{width:80%}
.sk-card{height:74px;border-radius:var(--radius);margin-bottom:12px}

/* ---------- Empty state ---------- */
.empty{text-align:center;padding:48px 24px;color:var(--c-text-soft)}
.empty i{font-size:46px;color:#c7ccda;margin-bottom:14px}
.empty h3{font-size:16px;color:var(--c-text);margin:0 0 6px}
.empty p{font-size:13px;margin:0 0 16px}

/* ---------- Pull to refresh ---------- */
.ptr-indicator{height:0;overflow:hidden;display:flex;align-items:center;justify-content:center;color:var(--c-text-soft);transition:height .15s}
.ptr-indicator i{animation:spin .8s linear infinite}

/* ---------- Carousel edukasi ---------- */
.h-scroll{display:flex;gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:4px;-webkit-overflow-scrolling:touch}
.h-scroll::-webkit-scrollbar{display:none}
.edu-card{scroll-snap-align:start;flex:0 0 240px;border-radius:var(--radius);overflow:hidden;background:var(--c-surface);box-shadow:var(--shadow-sm)}
.edu-card .edu-thumb{height:110px;background:linear-gradient(135deg,#2563eb,#1a1a2e);display:flex;align-items:center;justify-content:center;color:#fff;font-size:28px}
.edu-card .edu-body{padding:10px 12px}
.edu-card .edu-body b{font-size:13.5px;display:block;line-height:1.3}

/* ---------- Status banner (ringkasan berjalan) ---------- */
.status-banner{display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,#fff7e6,#fffdf5);border:1px solid #f5d98a;border-radius:var(--radius);padding:12px 14px;margin-bottom:14px}
.status-banner .sb-ico{width:40px;height:40px;border-radius:12px;background:var(--c-accent);color:var(--c-primary);display:flex;align-items:center;justify-content:center;font-size:18px}
.status-banner .sb-body{flex:1}
.status-banner .sb-body b{font-size:13.5px}
.status-banner .sb-body div{font-size:12px;color:var(--c-text-soft)}

/* ---------- Segmented filter ---------- */
.segment{display:flex;gap:6px;background:#eceef5;border-radius:12px;padding:4px;margin-bottom:14px}
.segment button{flex:1;padding:8px;border-radius:9px;font-size:13px;font-weight:600;color:var(--c-text-soft)}
.segment button.active{background:var(--c-surface);color:var(--c-primary);box-shadow:var(--shadow-sm)}

/* ===================== AUTH SCREENS ===================== */
.auth-bg .phone-frame{background:var(--c-bg)}
.auth-content{flex:1;display:flex;flex-direction:column;padding:calc(var(--safe-t) + 32px) 24px 32px;overflow-y:auto}
.auth-logo{text-align:center;margin-bottom:28px}
.auth-logo img{height:54px;margin:0 auto 10px}
.auth-logo .brand{font-size:24px;font-weight:800;color:var(--c-primary)}
.auth-logo .brand span{color:var(--c-primary-2)}
.auth-logo .tagline{font-size:13px;color:var(--c-text-soft);margin-top:4px}
.auth-title{font-size:22px;font-weight:800;margin-bottom:4px}
.auth-sub{color:var(--c-text-soft);margin-bottom:24px}
.auth-foot{text-align:center;margin-top:20px;font-size:13.5px;color:var(--c-text-soft)}
.auth-foot a{color:var(--c-primary-2);font-weight:700}
.auth-link{display:block;text-align:right;font-size:13px;color:var(--c-primary-2);font-weight:600;margin-top:-6px;margin-bottom:14px}

/* ---------- Onboarding ---------- */
.onb{flex:1;display:flex;flex-direction:column}
.onb-slides{flex:1;display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.onb-slides::-webkit-scrollbar{display:none}
.onb-slide{flex:0 0 100%;scroll-snap-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:32px}
.onb-slide .onb-ico{width:120px;height:120px;border-radius:32px;background:#eef2ff;color:var(--c-primary-2);display:flex;align-items:center;justify-content:center;font-size:52px;margin-bottom:28px}
.onb-slide h2{font-size:21px;margin:0 0 10px}
.onb-slide p{color:var(--c-text-soft);max-width:280px}
.onb-dots{display:flex;gap:7px;justify-content:center;padding:10px}
.onb-dots span{width:7px;height:7px;border-radius:50%;background:var(--c-line)}
.onb-dots span.active{width:20px;border-radius:4px;background:var(--c-primary-2)}

/* ---------- Splash ---------- */
.splash{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(160deg,var(--c-primary),#2a2a4a);color:#fff}
.splash img{height:72px;margin-bottom:18px}
.splash .brand{font-size:30px;font-weight:800;letter-spacing:.5px}

/* ---------- Mitra detail: hero + action bar ---------- */
.mitra-hero{text-align:center;padding:8px 0 16px}
.mitra-hero-logo{width:76px;height:76px;border-radius:22px;margin:0 auto 12px;background:linear-gradient(135deg,#eef2ff,#dbe4ff);color:var(--c-primary-2);display:flex;align-items:center;justify-content:center;font-size:32px}
.mitra-hero-name{font-size:19px;font-weight:800;margin:0 0 8px}
.mitra-hero-meta{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;font-size:13px}
.action-bar{
  position:absolute;left:0;right:0;bottom:calc(var(--tabbar-h) + var(--safe-b));
  background:var(--c-surface);border-top:1px solid var(--c-line);
  padding:10px 16px;z-index:25;
}
/* ---------- Form: field label + pick-list (radio layanan) ---------- */
.field-label{font-size:13px;font-weight:600;margin:4px 2px 8px}
.pick-list{display:flex;flex-direction:column;gap:8px;margin-bottom:6px}
.pick-row{display:flex;align-items:center;gap:10px;padding:13px 14px;border:1.5px solid var(--c-line);border-radius:12px;cursor:pointer}
.pick-row input{position:absolute;opacity:0;pointer-events:none}
.pick-txt{flex:1;font-size:14px;font-weight:500}
.pick-check{color:var(--c-line);font-size:18px}
.pick-row:has(input:checked){border-color:var(--c-primary-2);background:#eff6ff}
.pick-row:has(input:checked) .pick-check{color:var(--c-primary-2)}
.pick-row:has(input:checked) .pick-txt{font-weight:700;color:var(--c-primary-2)}

/* ---------- Stepper status (riwayat detail) ---------- */
.stepper{display:flex;align-items:center}
.step{display:flex;flex-direction:column;align-items:center;gap:6px;flex:0 0 auto}
.step-dot{width:32px;height:32px;border-radius:50%;background:var(--c-line);color:var(--c-text-soft);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}
.step.done .step-dot{background:var(--c-primary-2);color:#fff}
.step-lbl{font-size:11px;color:var(--c-text-soft);font-weight:600}
.step.done .step-lbl{color:var(--c-primary-2)}
.step-line{flex:1;height:3px;background:var(--c-line);margin:0 -2px;margin-bottom:18px;border-radius:2px}
.step-line.done{background:var(--c-primary-2)}

/* richtext dari body_html master */
.doclyn-richtext{font-size:13.5px;line-height:1.6;color:var(--c-text)}
.doclyn-richtext h2{font-size:16px;font-weight:700;margin:0 0 8px}
.doclyn-richtext h3{font-size:14px;font-weight:700;margin:14px 0 6px}
.doclyn-richtext p{margin:0 0 10px}
.doclyn-richtext ul{margin:0 0 10px;padding-left:18px}
.doclyn-richtext li{margin-bottom:4px}

.mt-0{margin-top:0}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}
.text-center{text-align:center}
