/* ============================================================
 * E-Service (frontend) — hub / form / success / track
 * ============================================================ */
.es-wrap { padding: 6px 0 30px; }
.es-hero { background: linear-gradient(135deg,#0ea5e9 0%,#0369a1 100%); color:#fff; border-radius:14px; padding:26px 28px; margin-bottom:22px; }
.es-hero h2 { margin:0 0 8px; font-size:24px; font-weight:800; }
.es-hero p { margin:0; font-size:15px; opacity:.95; }
.es-hero .es-hero-note { display:inline-block; margin-top:12px; background:rgba(255,255,255,.18); padding:6px 14px; border-radius:20px; font-size:13px; }
.es-hero .es-hero-note i { margin-right:6px; }

.es-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(210px,1fr)); gap:16px; }
.es-card { display:flex; flex-direction:column; background:#fff; border:1px solid #e5e7eb; border-radius:14px; padding:20px 18px; text-decoration:none; transition:transform .15s, box-shadow .15s; border-top:4px solid var(--es-c,#0ea5e9); }
.es-card:hover { transform:translateY(-4px); box-shadow:0 10px 24px rgba(0,0,0,.10); text-decoration:none; }
.es-card-icon { width:54px; height:54px; line-height:54px; text-align:center; border-radius:14px; font-size:26px; color:#fff; background:linear-gradient(135deg,var(--es-c,#0ea5e9),var(--es-cd,#0369a1)); margin-bottom:14px; }
.es-card-title { font-size:16px; font-weight:700; color:#1a2540; margin-bottom:6px; }
.es-card-desc { font-size:12.5px; color:#64748b; line-height:1.5; flex:1; margin-bottom:14px; }
.es-card-btn { font-size:13px; font-weight:700; color:var(--es-cd,#0369a1); }
.es-card-btn i { transition:transform .15s; }
.es-card:hover .es-card-btn i { transform:translateX(4px); }

.es-section-label { font-size:15px; font-weight:700; color:#334155; margin:26px 0 12px; padding-left:10px; border-left:4px solid #0ea5e9; }

/* form */
.es-form-head { background:linear-gradient(135deg,var(--es-c,#0ea5e9),var(--es-cd,#0369a1)); color:#fff; border-radius:14px 14px 0 0; padding:20px 24px; }
.es-form-head h2 { margin:0; font-size:21px; font-weight:800; }
.es-form-head h2 i { margin-right:8px; }
.es-form-head p { margin:6px 0 0; font-size:13px; opacity:.95; }
.es-form-body { background:#fff; border:1px solid #e5e7eb; border-top:none; border-radius:0 0 14px 14px; padding:22px 24px; }
.es-fieldset { margin-bottom:20px; }
.es-fieldset-title { font-size:15px; font-weight:700; color:#0369a1; margin-bottom:12px; padding-bottom:6px; border-bottom:2px solid #e0f2fe; }
.es-fieldset-title i { margin-right:6px; }
.es-form-group { margin-bottom:14px; }
.es-form-group label { display:block; font-weight:600; color:#334155; margin-bottom:5px; font-size:14px; }
.es-form-group .es-req { color:#ef4444; }
.es-form-group input[type=text], .es-form-group input[type=tel], .es-form-group input[type=email],
.es-form-group input[type=number], .es-form-group input[type=datetime-local], .es-form-group select, .es-form-group textarea {
  width:100%; padding:9px 12px; border:1px solid #cbd5e1; border-radius:8px; font-size:14px; font-family:inherit; }
.es-form-group textarea { min-height:90px; resize:vertical; }
.es-form-group .es-help { font-size:12px; color:#94a3b8; margin-top:3px; }
.es-row2 { display:flex; gap:14px; flex-wrap:wrap; }
.es-row2 > .es-form-group { flex:1; min-width:200px; }
.es-consent { background:#f8fafc; border:1px solid #e2e8f0; border-radius:10px; padding:12px 14px; font-size:13px; color:#475569; }
.es-consent label { font-weight:600; cursor:pointer; }
.es-error { background:#fef2f2; border:1px solid #fecaca; color:#991b1b; border-radius:10px; padding:12px 16px; margin-bottom:16px; font-size:14px; }
.es-btn-submit { background:linear-gradient(135deg,#0ea5e9,#0369a1); color:#fff; border:none; padding:12px 30px; border-radius:10px; font-size:16px; font-weight:700; cursor:pointer; }
.es-btn-submit:hover { opacity:.92; }
.es-btn-track { display:inline-block; margin-top:10px; color:#0369a1; font-weight:600; }
.es-anon-box { background:#fef9c3; border:1px solid #fde68a; border-radius:10px; padding:12px 14px; margin-bottom:14px; font-size:13px; color:#854d0e; }

/* success */
.es-success { background:#fff; border:1px solid #e5e7eb; border-radius:14px; padding:34px 28px; text-align:center; }
.es-success-icon { width:80px; height:80px; line-height:80px; margin:0 auto 16px; border-radius:50%; background:#dcfce7; color:#16a34a; font-size:42px; }
.es-success h2 { color:#16a34a; font-weight:800; margin:0 0 8px; }
.es-track-no { display:inline-block; background:#f0f9ff; border:2px dashed #0ea5e9; color:#0369a1; font-size:26px; font-weight:800; letter-spacing:1px; padding:12px 28px; border-radius:12px; margin:14px 0; font-family:monospace; }
.es-success-note { color:#64748b; font-size:14px; }

/* track */
.es-track-box { background:#fff; border:1px solid #e5e7eb; border-radius:14px; padding:24px; }
.es-timeline { list-style:none; padding:0; margin:18px 0 0; }
.es-timeline li { position:relative; padding:0 0 18px 30px; border-left:2px solid #e2e8f0; }
.es-timeline li:last-child { border-left-color:transparent; }
.es-timeline li .es-dot { position:absolute; left:-8px; top:2px; width:14px; height:14px; border-radius:50%; background:#0ea5e9; border:3px solid #fff; box-shadow:0 0 0 2px #bae6fd; }
.es-timeline li .es-tl-action { font-weight:700; color:#1a2540; }
.es-timeline li .es-tl-time { font-size:12px; color:#94a3b8; }
.es-timeline li .es-tl-detail { font-size:13px; color:#475569; margin-top:2px; }

/* status pills (shared) */
.es-pill { display:inline-block; padding:4px 14px; border-radius:14px; font-size:12px; font-weight:700; }
.es-pill.es-s0 { background:#f1f5f9; color:#475569; }
.es-pill.es-s1 { background:#fef3c7; color:#92400e; }
.es-pill.es-s2 { background:#dbeafe; color:#1e40af; }
.es-pill.es-s3 { background:#fee2e2; color:#991b1b; }
.es-pill.es-s4 { background:#dcfce7; color:#166534; }

@media (max-width:480px){
  .es-hero { padding:20px; } .es-hero h2 { font-size:20px; }
  .es-grid { grid-template-columns:1fr 1fr; gap:10px; }
  .es-card { padding:14px 12px; }
}
