/**
 * SIM Frontend — Unified Stylesheet
 * @version 2.0.0
 * @author  YoiKut.com Team
 *
 * File ini adalah sumber styling tunggal untuk seluruh halaman public SIM:
 *  - Login, Register, Reset Password
 *  - Checkout
 *  - Payment Confirmation
 *  - Member Dashboard (List, Edit, Account, Settings, Transactions, Users, Tamu, RSVP)
 *
 * INTEGRASI DENGAN APPEARANCE SETTINGS:
 *  Semua warna brand menggunakan CSS custom properties.
 *  Nilai ini di-override secara dinamis oleh Admin > General Settings > Tampilan Dashboard
 *  melalui <style id="sim-appearance-vars"> yang di-inject di wp_head (priority 5).
 *
 * LOAD ORDER (penting):
 *  1. sim-public-vars.css  — CSS vars fallback defaults
 *  2. frontend.css         — semua structural + brand styles  ← FILE INI
 *  3. <style id="sim-appearance-vars"> — override vars dari settings admin (wp_head p.5)
 */

/* ================================================================
   §0. BOX-SIZING GLOBAL SEMUA WRAPPER SIM
   ================================================================ */
.sim-checkout-form-wrapper *,
.sim-checkout-form-wrapper *::before,
.sim-checkout-form-wrapper *::after,
.sim-checkout-wrapper *,
.sim-checkout-wrapper *::before,
.sim-checkout-wrapper *::after,
.sim-confirmation-wrapper *,
.sim-confirmation-wrapper *::before,
.sim-confirmation-wrapper *::after,
.sim-dashboard-wrapper *,
.sim-dashboard-wrapper *::before,
.sim-dashboard-wrapper *::after,
.sim-ios-container *,
.sim-ios-container *::before,
.sim-ios-container *::after {
    box-sizing: border-box;
}

/* ================================================================
   §1. ALERT MESSAGES
   ================================================================ */
.sim-alert {
    padding: 14px 18px;
    border-radius: 16px;
    margin-bottom: 20px;
    font-size: 14px;
    line-height: 1.5;
    display: flex;
    align-items: flex-start;
    gap: 10px;
}
.sim-alert i { flex-shrink: 0; margin-top: 2px; }

.sim-alert-danger,
.sim-alert-error {
    background: #fee;
    color: #c33;
    border-left: 4px solid #c33;
}
.sim-alert-info {
    background: #e7f3ff;
    color: #0c5460;
    border-left: 4px solid #2196F3;
}
.sim-alert-warning {
    background: #fff8e1;
    color: #856404;
    border-left: 4px solid #ffc107;
}
.sim-alert-success {
    background: #e8f5e9;
    color: #2e7d32;
    border-left: 4px solid #4caf50;
}
.sim-alert-info-checkout {
    background: #e7f3ff;
    border-left: 4px solid #2196F3;
    padding: 12px 15px;
    border-radius: 8px;
    margin-bottom: 25px;
}
.sim-alert-info-checkout p { margin: 0; color: #0c5460; font-size: 14px; }
.sim-alert-success-checkout {
    background: #e8f5e9;
    border-left: 4px solid #4caf50;
    padding: 12px 15px;
    border-radius: 8px;
    margin-bottom: 20px;
}
.sim-alert-success-checkout small { color: #2e7d32; font-size: 12px; }

@keyframes sim-pulse-warning {
    0%, 100% { border-left-color: #ffc107; }
    50%       { border-left-color: #ff9800; }
}
.sim-rate-limit-warning { animation: sim-pulse-warning 2s ease-in-out infinite; }

/* ================================================================
   §2. NAVIGATION — Breadcrumb + Sub-Tabs
   ================================================================ */
.sim-nav-container {
    margin-bottom: 30px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.sim-breadcrumb-nav {
    background: #ffffff;
    padding: 6px;
    border-radius: 18px;
    box-shadow: 0 4px 15px rgba(26,83,92,0.05);
    display: inline-block;
    border: 1px solid #eef2f2;
    align-self: flex-start;
}
.breadcrumb-list {
    list-style: none;
    display: flex;
    align-items: center;
    padding: 0; margin: 0;
    gap: 4px;
}
.breadcrumb-pill {
    text-decoration: none !important;
    color: #5a7d82;
    padding: 10px 18px;
    border-radius: 14px;
    font-size: 13px;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 8px;
    transition: 0.2s;
}
.breadcrumb-item.active:not(.detail-view) .breadcrumb-pill {
    background: var(--sim-pub-primary-dark, #1a535c);
    color: #ffffff;
}
.breadcrumb-item.active:not(.detail-view) .dashicons { color: #ffffff; }
.breadcrumb-separator { margin: 0 5px; color: #cbd5d6; }

.sim-sub-tab-nav {
    background: #f0f4f4;
    padding: 4px;
    border-radius: 14px;
    display: flex;
    align-self: flex-start;
    gap: 2px;
    border: 1px solid #e2e8e8;
}
.sub-tab-item {
    text-decoration: none;
    padding: 8px 18px;
    border-radius: 10px;
    font-size: 12px;
    font-weight: 700;
    color: #5a7d82;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}
.sub-tab-item:hover { color: var(--sim-pub-primary-dark, #1a535c); text-decoration: none; }
.sub-tab-item.active {
    background: #ffffff;
    color: var(--sim-pub-primary-dark, #1a535c);
    box-shadow: 0 3px 10px rgba(0,0,0,0.08);
}

/* ================================================================
   §3. LOGIN / REGISTER / RESET PASSWORD WRAPPER
   ================================================================ */
.sim-checkout-form-wrapper {
    max-width: 500px;
    margin: 40px auto;
    padding: 40px;
    background: var(--sim-pub-bg, #f8fafa);
    border-radius: var(--sim-pub-radius, 24px);
    box-shadow: 0 8px 32px rgba(0,0,0,0.1);
    font-family: var(--sim-pub-font-body, inherit), sans-serif;
    color: var(--sim-pub-text, #1a535c);
}
.sim-checkout-header {
    font-size: 32px;
    font-weight: 700;
    color: var(--sim-pub-text, #1a535c);
    font-family: var(--sim-pub-font-heading, inherit), sans-serif;
    margin: 0 0 30px 0;
    text-align: left;
    border-bottom: none;
}
.sim-checkout-form { width: 100%; }

.sim-form-group { margin-bottom: 20px; position: relative; }
.sim-form-group label {
    display: block;
    margin-bottom: 8px;
    font-weight: 500;
    color: var(--sim-pub-text, #1a535c);
    font-size: 14px;
}
.sim-form-group input[type="checkbox"] {
    width: auto !important;
    margin-right: 8px;
    cursor: pointer;
    accent-color: var(--sim-pub-primary, #3a8686);
}

.sim-input-wrapper { position: relative; width: 100%; }

.sim-form-control {
    width: 100% !important;
    padding: 14px 18px 14px 25px !important;
    border: none !important;
    border-radius: var(--sim-pub-radius-sm, 20px) !important;
    font-size: 15px !important;
    color: #333 !important;
    background: var(--sim-pub-card, #ffffff) !important;
    transition: all 0.3s ease !important;
    box-sizing: border-box !important;
    font-family: var(--sim-pub-font-body, inherit), sans-serif !important;
    line-height: 1.5 !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05) !important;
}
.sim-form-control:focus {
    outline: none !important;
    border: none !important;
    box-shadow: 0 4px 16px rgba(58,134,134,0.15) !important;
    background: var(--sim-pub-card, #ffffff) !important;
}
.sim-form-control::placeholder { color: #b0bec5 !important; opacity: 1 !important; }

.sim-password-toggle {
    position: absolute;
    right: 15px; top: 50%;
    transform: translateY(-50%);
    cursor: pointer; color: #999; font-size: 16px;
    transition: color 0.2s ease; z-index: 10;
}
.sim-password-toggle:hover { color: var(--sim-pub-primary, #3a8686); }
.sim-password-toggle-group .sim-form-control { padding-right: 45px !important; }

.sim-help-text { margin: 8px 0 0 0; font-size: 13px; color: #666; }
.sim-help-text a {
    color: var(--sim-pub-primary, #3a8686);
    font-weight: 600; text-decoration: none; transition: color 0.2s ease;
}
.sim-help-text a:hover { color: var(--sim-pub-primary-dark, #1a535c); text-decoration: underline; }

.sim-reset-desc { font-size: 15px; color: #555; text-align: center; margin-bottom: 20px; }

.sim-auth-toggle { text-align: center; margin-top: 25px; }
.sim-toggle-text { color: #666; font-size: 14px; margin-right: 8px; }
.sim-toggle-link {
    color: var(--sim-pub-primary, #3a8686) !important;
    font-weight: 700 !important; text-decoration: none !important;
    font-size: 14px; transition: all 0.2s ease;
    display: inline-flex; align-items: center; gap: 6px;
}
.sim-toggle-link:hover { color: var(--sim-pub-primary-dark, #1a535c) !important; text-decoration: none !important; }

.sim-divider-dashed { border: none; border-top: 2px dashed #d0dede; margin: 30px 0; }

/* ================================================================
   §4. BUTTONS
   ================================================================ */
.sim-submit-row { margin: 25px 0 0 0; }

/* Primary Submit Button */
button.sim-button-primary,
.sim-button-primary-submit {
    width: 100% !important;
    padding: 16px 24px !important;
    border: none !important;
    border-radius: var(--sim-pub-radius-sm, 20px) !important;
    background: var(--sim-pub-button, #3a8686) !important;
    color: var(--sim-pub-button-text, #ffffff) !important;
    font-family: var(--sim-pub-font-body, inherit), sans-serif !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    box-shadow: 0 4px 16px rgba(58,134,134,0.3) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
}
button.sim-button-primary-submit:hover:not(:disabled) {
    transform: translateY(-2px) !important;
    background: var(--sim-pub-primary-dark, #1a535c) !important;
    box-shadow: 0 6px 20px rgba(58,134,134,0.4) !important;
}
button.sim-button-primary-submit:disabled {
    opacity: 0.6 !important; cursor: not-allowed !important;
    background: #cccccc !important; box-shadow: none !important;
}

/* Elementor Overrides */
.elementor-widget-container .sim-checkout-form-wrapper { max-width: 100%; }
.elementor * { box-sizing: border-box; }
.elementor .sim-button-primary-submit,
.elementor button.sim-button-primary-submit {
    background: var(--sim-pub-button, #3a8686) !important;
    border: none !important;
}
.elementor .sim-button-primary-submit:hover:not(:disabled),
.elementor button.sim-button-primary-submit:hover:not(:disabled) {
    background: var(--sim-pub-primary-dark, #1a535c) !important;
}
.elementor .sim-form-control,
.elementor input.sim-form-control { height: auto !important; min-height: 48px !important; }

/* iOS Save / Action Buttons */
.sim-ios-save,
body .sim-ios-container .sim-ios-save,
body .sim-ios-header .sim-ios-save,
body button.sim-ios-save {
    background:    var(--sim-pub-button, #3a8686) !important;
    border:        2px solid var(--sim-pub-button, #3a8686) !important;
    color:         var(--sim-pub-button-text, #ffffff) !important;
    padding:       10px 20px !important;
    border-radius: var(--sim-pub-radius-sm, 30px) !important;
    font-weight:   600 !important;
    cursor:        pointer !important;
    transition:    0.3s !important;
    display:       flex !important;
    align-items:   center !important;
    gap:           8px !important;
    font-size:     14px !important;
    text-decoration: none !important;
    box-shadow:    none !important;
}
body .sim-ios-header .sim-ios-save:hover,
body button.sim-ios-save:hover {
    background:   var(--sim-pub-primary-dark, #1a535c) !important;
    border-color: var(--sim-pub-primary-dark, #1a535c) !important;
    transform:    translateY(-1px) !important;
}
.sim-ios-save.quota-locked { background: #8fa7ab; opacity: 0.6; cursor: not-allowed; }

.sim-ios-save-full {
    width: 100%;
    background: var(--sim-pub-primary-dark, #1a535c);
    color: #ffffff; border: none; padding: 14px; border-radius: 14px;
    font-weight: 700; cursor: pointer; margin-top: 20px; transition: 0.3s;
}
.sim-ios-save-full:hover { background: var(--sim-pub-accent, #4ecdc4); }

.sim-ios-btn-ok {
    width:         100%;
    padding:       14px;
    border:        2px solid var(--sim-pub-button, #3a8686);
    border-radius: var(--sim-pub-radius-sm, 16px);
    background:    var(--sim-pub-button, #3a8686);
    color:         var(--sim-pub-button-text, #ffffff);
    font-weight:   700;
    font-size:     15px;
    cursor:        pointer;
    transition:    0.3s;
    display:       flex;
    align-items:   center;
    justify-content: center;
    gap:           6px;
    box-sizing:    border-box;
}
.sim-ios-btn-ok:hover {
    background:   var(--sim-pub-primary-dark, #1a535c);
    border-color: var(--sim-pub-primary-dark, #1a535c);
    transform:    translateY(-2px);
}
.sim-ios-btn-ok:disabled { opacity: 0.6; cursor: not-allowed; transform: none !important; }
.sim-ios-btn-ok .dashicons { font-size: 16px; width: 16px; height: 16px; }
.sim-ios-btn-ok:active { transform: scale(0.98); }

.sim-ios-btn-cancel {
    flex: 1; background: #f0f3f3; color: #555; border: none;
    padding: 13px; border-radius: 14px; font-weight: 700; font-size: 14px;
    cursor: pointer; transition: 0.2s;
    display: flex; align-items: center; justify-content: center; gap: 6px;
}
.sim-ios-btn-cancel:hover { background: #e0e3e3; }

.sim-ios-btn-danger {
    flex: 1.5; background: #e74c3c; color: #fff; border: none;
    padding: 13px; border-radius: 14px; font-weight: 700; font-size: 14px;
    cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 7px;
    transition: 0.2s; box-shadow: 0 4px 14px rgba(231,76,60,0.3); text-decoration: none;
}
.sim-ios-btn-danger:hover { background: #c0392b; color: #fff; text-decoration: none; }
.sim-ios-btn-danger:disabled { opacity: 0.6; cursor: not-allowed; }
.sim-ios-btn-danger .dashicons { font-size: 15px; width: 15px; height: 15px; }

.sim-action-btn {
    display: inline-block; padding: 15px 40px;
    background: var(--sim-pub-button, #3a8686);
    color: var(--sim-pub-button-text, #ffffff);
    text-decoration: none; border-radius: var(--sim-pub-radius-sm, 20px);
    font-size: 15px; font-weight: 600;
    box-shadow: 0 4px 12px rgba(58,134,134,0.3); transition: all 0.3s;
}
.sim-action-btn:hover {
    background: var(--sim-pub-primary-dark, #1a535c);
    color: var(--sim-pub-button-text, #ffffff) !important;
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(58,134,134,0.4);
    text-decoration: none;
}

/* Utility buttons */
.sim-btn-plain-text {
    background: #f2f2f7; color: #555; border: none;
    padding: 9px 14px; border-radius: 12px; font-size: 13px; font-weight: 600;
    cursor: pointer; transition: 0.2s; width: auto !important; height: auto !important;
}
.sim-btn-plain-text:hover { background: #e2e2ea; }
.sim-btn-save-inline { width: auto !important; padding: 9px 18px !important; display: inline-flex !important; }
.sim-btn-danger-outline {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 9px 14px; background: #fff0f0; color: #c0392b;
    border: 1.5px solid #ffcccc; border-radius: 12px;
    font-size: 12px; font-weight: 700; cursor: pointer; transition: 0.2s;
}
.sim-btn-danger-outline:hover { background: #c0392b; color: #fff; border-color: #c0392b; }
.sim-btn-cancel-choice {
    width: 100% !important; height: auto !important;
    background: #f2f2f7 !important; color: #555 !important;
    border-radius: 13px !important; padding: 11px !important;
    font-size: 13px; font-weight: 700;
    display: flex; align-items: center; justify-content: center; gap: 6px; margin-top: 4px;
}

/* ================================================================
   §5. MODAL SYSTEM (unified — semua view)
   ================================================================ */
.sim-modal-overlay,
.sim-ios-modal-overlay,
.sim-listtamu-modal-overlay,
.simrsvp-modal-overlay {
    position: fixed !important;
    top: 0; left: 0; width: 100%; height: 100%;
    background: rgba(26,83,92,0.45);
    backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
    z-index: 999999;
    display: none;
    align-items: center; justify-content: center;
    padding: 20px;
}

.sim-modal,
.sim-ios-modal-card,
.sim-listtamu-modal-box,
.simrsvp-modal-card {
    background: #fff;
    border-radius: 28px; width: 90%; max-width: 400px;
    box-shadow: 0 25px 50px -12px rgba(0,0,0,0.25);
    overflow: hidden;
    animation: simPopIn 0.3s cubic-bezier(0.175,0.885,0.32,1.15);
}
.sim-ios-modal-content {
    background: #fff; padding: 30px; border-radius: 20px;
    text-align: center; box-shadow: 0 15px 35px rgba(0,0,0,0.2);
    width: 260px !important;
}
.sim-listtamu-modal-box { max-width: 500px !important; }
.simrsvp-modal-card    { max-width: 450px !important; }
.sim-delete-confirm-card,
.sim-delete-choice-card,
.simrsvp-delete-card   { max-width: 430px !important; }
.sim-edit-wide {
    max-width:   480px !important;
    width:       calc(100vw - 40px) !important;
    box-sizing:  border-box !important;
    overflow-x:  hidden !important;
}

@keyframes simPopIn {
    from { transform: scale(0.9); opacity: 0; }
    to   { transform: scale(1);   opacity: 1; }
}
@keyframes simFadeIn {
    from { opacity: 0; transform: translateY(-20px); }
    to   { opacity: 1; transform: translateY(0); }
}
.sim-modal { animation: simFadeIn 0.3s ease-out; }
.sim-ios-modal {
    position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    background: rgba(0,0,0,0.3); z-index: 9999;
    display: flex; align-items: center; justify-content: center;
    backdrop-filter: blur(5px);
}

/* Modal Header */
.modal-header,
.sim-listtamu-modal-header,
.simrsvp-modal-header {
    padding: 20px 25px;
    border-bottom: 1px solid #f0f5f5;
    display: flex; justify-content: space-between; align-items: center;
    background: #fff;
}
.modal-header h3,
.sim-listtamu-modal-header h4,
.simrsvp-modal-header h3 {
    margin: 0; font-size: 18px; font-weight: 800;
    color: var(--sim-pub-text, #1a535c);
    display: flex; align-items: center; gap: 8px;
}

/* Danger Header */
.modal-header-danger,
.simrsvp-header-danger {
    background: linear-gradient(135deg,#fff5f5 0%,#ffe8e8 100%);
    border-bottom: 1px solid #ffcccc !important;
    flex-direction: column; align-items: center !important;
    gap: 10px; padding: 28px 25px 20px !important;
}
.modal-header-danger h3  { color: #c0392b !important; font-size: 20px !important; justify-content: center; }
.danger-icon-wrap,
.simrsvp-danger-icon {
    width: 56px; height: 56px; background: #fff;
    border: 2px solid #ffcccc; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
}
.danger-icon-wrap .dashicons,
.simrsvp-danger-icon .dashicons { font-size: 30px; color: #e74c3c; width: 30px; height: 30px; }

/* Close button */
.close-modal-btn,
.sim-listtamu-modal-close-icon,
.simrsvp-close-btn,
.sim-modal-close {
    background: #f0f3f3; border: none;
    width: 32px; height: 32px; border-radius: 50%;
    cursor: pointer; color: #8fa7ab;
    display: flex; align-items: center; justify-content: center;
    transition: 0.2s; flex-shrink: 0; line-height: 1;
}
.close-modal-btn:hover,
.simrsvp-close-btn:hover    { background: #ff6b6b; color: #fff; }
.sim-listtamu-modal-close-icon:hover { color: #e74c3c; }
.close-modal-btn .dashicons { font-size: 18px; width: 18px; height: 18px; }
.sim-modal-close { position: absolute; top: 12px; right: 16px; font-size: 24px; font-weight: 300; background: transparent; }
.sim-modal-close:hover { color: #333; background: transparent; }

/* Modal Body */
.modal-body,
.sim-listtamu-modal-body,
.simrsvp-modal-body { padding: 25px; }
.sim-listtamu-modal-body { max-height: 70vh; overflow-y: auto; }
.sim-listtamu-modal-footer {
    padding: 15px 25px; background: #f9f9f9; border-top: 1px solid #eee;
    display: flex; justify-content: flex-end; gap: 12px;
}

/* Delete warning */
.delete-warning-box,
.simrsvp-warn-box { background: #fdfafa; border: 1px solid #fce4e4; border-radius: 14px; padding: 18px; margin-bottom: 12px; }
.delete-target-name,
.simrsvp-warn-target {
    font-size: 13px; font-weight: 700; color: var(--sim-pub-text, #1a535c);
    text-align: center; margin: 0 0 14px;
    padding-bottom: 12px; border-bottom: 1px dashed #eee; word-break: break-word;
}
.delete-warning-list,
.simrsvp-warn-list { list-style: none; margin: 0 0 14px; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.delete-warning-list li,
.simrsvp-warn-list li { display: flex; align-items: flex-start; gap: 8px; font-size: 13px; color: #555; line-height: 1.5; }
.delete-warning-list li .dashicons,
.simrsvp-warn-list li .dashicons { font-size: 16px; width: 16px; height: 16px; margin-top: 2px; flex-shrink: 0; }
.dashicons-no  { color: #e74c3c !important; }
.dashicons-yes { color: #27ae60 !important; }
.delete-irreversible,
.simrsvp-warn-irreversible {
    font-size: 12px; color: #c0392b; text-align: center; margin: 0;
    background: #fff0f0; padding: 8px 12px; border-radius: 8px;
}

/* sim-modal inner button */
.sim-modal button,
.sim-ios-modal-content button {
    background: var(--sim-pub-primary, #3a8686);
    color: var(--sim-pub-button-text, #ffffff);
    border: none; border-radius: 12px; padding: 12px 30px;
    cursor: pointer; font-weight: 600; font-size: 15px;
    transition: all 0.3s; box-shadow: 0 4px 12px rgba(58,134,134,0.3);
}
.sim-modal button:hover { background: var(--sim-pub-primary-dark, #1a535c); transform: translateY(-2px); }

/* RSVP modal buttons */
.simrsvp-btn-cancel { flex: 1; background: #f0f3f3; color: #555; border: none; padding: 13px; border-radius: 14px; font-weight: 700; font-size: 14px; cursor: pointer; transition: 0.2s; }
.simrsvp-btn-cancel:hover { background: #e0e3e3; }
.simrsvp-btn-danger {
    flex: 1.5; background: #e74c3c; color: #fff; border: none; padding: 13px;
    border-radius: 14px; font-weight: 700; font-size: 14px; cursor: pointer;
    display: flex; align-items: center; justify-content: center; gap: 7px;
    transition: 0.2s; box-shadow: 0 4px 14px rgba(231,76,60,0.3); text-decoration: none;
}
.simrsvp-btn-danger:hover { background: #c0392b; color: #fff; }
.simrsvp-btn-danger .dashicons { font-size: 15px; width: 15px; height: 15px; }
.simrsvp-btn-ok {
    width: 100%; padding: 13px; border: none; border-radius: 16px;
    background: var(--sim-pub-primary, #3a8686); color: #fff; font-size: 15px; font-weight: 700; cursor: pointer; transition: 0.2s;
}
.simrsvp-btn-ok:hover { background: var(--sim-pub-primary-dark, #1a535c); }

/* List Tamu buttons */
.sim-listtamu-btn-primary,
.sim-listtamu-btn-close-modal {
    padding: 10px 22px; border-radius: 30px; font-size: 14px; font-weight: 600;
    cursor: pointer; transition: all 0.2s; border: none;
    display: inline-flex; align-items: center; gap: 8px;
}
.sim-listtamu-btn-primary      { background: var(--sim-pub-primary, #3a8686) !important; color: #fff !important; }
.sim-listtamu-btn-primary:hover { background: var(--sim-pub-primary-dark, #1a535c) !important; transform: translateY(-2px) !important; }
.sim-listtamu-btn-close-modal  { background: #e0e0e0 !important; color: #666 !important; }
.sim-listtamu-btn-close-modal:hover { background: #d0d0d0 !important; }

/* Capsule button (list tamu toolbar) */
.sim-listtamu-btn-capsule {
    padding: 6px 15px !important; border-radius: 30px !important;
    font-size: 11px !important; font-weight: 600 !important; cursor: pointer !important;
    border: 1px solid grey !important; display: inline-flex !important; align-items: center !important;
}
.sim-listtamu-btn-capsule i { margin-right: 5px !important; }

/* Choice buttons (users delete modal) */
.sim-choice-btn {
    width: 100%; display: flex; align-items: center; gap: 13px;
    padding: 14px 15px; border: 2px solid transparent; border-radius: 15px;
    cursor: pointer; text-align: left; transition: 0.2s; margin-bottom: 9px; background: #f9fbfb;
}
.sim-choice-btn:hover { transform: translateX(3px); }
.sim-choice-soft:hover { border-color: var(--sim-pub-primary, #3a8686); background: #f0f8f8; }
.sim-choice-hard:hover { border-color: #e74c3c; background: #fff5f5; }
.choice-icon { width: 38px; height: 38px; border-radius: 11px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.icon-soft { background: #eef6f6; } .icon-soft .dashicons { color: var(--sim-pub-primary, #3a8686); }
.icon-hard { background: #fff0f0; } .icon-hard .dashicons { color: #e74c3c; }
.choice-icon .dashicons { font-size: 18px; width: 18px; height: 18px; }
.choice-text { flex: 1; display: flex; flex-direction: column; gap: 3px; }
.choice-text strong { font-size: 13px; color: var(--sim-pub-text, #1a535c); }
.choice-text span   { font-size: 11px; color: #8fa7ab; line-height: 1.4; }
.choice-arrow       { color: #ccc; font-size: 15px; width: 15px; height: 15px; flex-shrink: 0; }

/* ================================================================
   §6. SPINNER & ANIMATIONS
   ================================================================ */
@keyframes simSpin  { 0%{transform:rotate(0deg);} 100%{transform:rotate(360deg);} }
@keyframes shake    { 10%,90%{transform:translate3d(-1px,0,0);} 20%,80%{transform:translate3d(2px,0,0);} 30%,50%,70%{transform:translate3d(-4px,0,0);} 40%,60%{transform:translate3d(4px,0,0);} }
@keyframes fadeInDown { from{opacity:0;transform:translateY(-5px);} to{opacity:1;transform:translateY(0);} }
@keyframes slideIn  { from{opacity:0;transform:translateY(-10px);} to{opacity:1;transform:translateY(0);} }
@keyframes fadeIn   { from{opacity:0;} to{opacity:1;} }
@keyframes expandDown { from{opacity:0;max-height:0;overflow:hidden;} to{opacity:1;max-height:500px;} }
@keyframes bounceIn { 0%{opacity:0;transform:scale(0.3);} 50%{opacity:1;transform:scale(1.05);} 70%{transform:scale(0.9);} 100%{transform:scale(1);} }
@keyframes quotaPulse {
    0%,100%{transform:scale(1);background:linear-gradient(135deg,#e8f5f5 0%,#f0f9f9 100%);}
    50%    {transform:scale(1.05);background:linear-gradient(135deg,#d4f1f4 0%,#e0f7fa 100%);}
}
@keyframes simrsvpStroke { 100%{stroke-dashoffset:0;} }
@keyframes simrsvpScale  { 0%,100%{transform:none;} 50%{transform:scale3d(1.1,1.1,1);} }
@keyframes simrsvpFill   { 100%{box-shadow:inset 0 0 0 40px #e6f7f4;} }
@keyframes simModalFadeIn { from{transform:translateY(20px);opacity:0;} to{transform:translateY(0);opacity:1;} }
@keyframes simrsvpPopIn  { from{transform:scale(.9);opacity:0;} to{transform:scale(1);opacity:1;} }

.sim-ios-spinner {
    border: 4px solid #f3f3f3;
    border-top: 4px solid var(--sim-pub-primary, #3a8686);
    border-radius: 50%; width: 40px; height: 40px;
    animation: simSpin 1s linear infinite; margin: 0 auto 15px;
}
.sim-ios-spinner.small { width: 30px; height: 30px; border-width: 3px; margin-bottom: 0; }
.sim-spin { display: inline-block; animation: simSpin 1s linear infinite; }

.simrsvp-spinner {
    display: inline-block; width: 14px; height: 14px;
    border: 2px solid rgba(255,255,255,0.4); border-top-color: #fff;
    border-radius: 50%; animation: simSpin 0.7s linear infinite;
    vertical-align: middle; margin-right: 6px;
}
.sim-coupon-loading {
    display: inline-block; width: 14px; height: 14px;
    border: 2px solid rgba(255,255,255,0.3); border-top-color: #fff;
    border-radius: 50%; animation: simSpin 0.6s linear infinite;
    margin-left: 8px; vertical-align: middle;
}

/* SVG Animated Checkmark */
.ios-success-icon-container,
.simrsvp-checkmark-wrap { width: 80px; height: 80px; margin: 0 auto; }

.ios-checkmark,
.simrsvp-checkmark {
    width: 80px; height: 80px; border-radius: 50%; display: block;
    stroke-width: 3; stroke-miterlimit: 10;
    animation: simrsvpFill 0.4s ease-in-out 0.4s forwards, simrsvpScale 0.3s ease-in-out 0.9s both;
}
.ios-checkmark__circle,
.simrsvp-checkmark__circle {
    stroke-dasharray: 166; stroke-dashoffset: 166;
    stroke-width: 3; stroke-miterlimit: 10;
    stroke: var(--sim-pub-accent, #4ecdc4); fill: none;
    animation: simrsvpStroke 0.6s cubic-bezier(0.65,0,0.45,1) forwards;
}
.ios-checkmark__check,
.simrsvp-checkmark__check {
    transform-origin: 50% 50%;
    stroke-dasharray: 48; stroke-dashoffset: 48;
    stroke: var(--sim-pub-accent, #4ecdc4);
    animation: simrsvpStroke 0.3s cubic-bezier(0.65,0,0.45,1) 0.8s forwards;
}

.success-icon-wrapper {
    width: 60px; height: 60px; background: #e6f7f4;
    color: var(--sim-pub-accent, #4ecdc4); border-radius: 50%;
    display: flex; align-items: center; justify-content: center; margin: 0 auto;
}
.success-icon-wrapper .dashicons { font-size: 40px; width: 40px; height: 40px; }

.sim-shake-animation { animation: shake 0.5s cubic-bezier(0.36,0.07,0.19,0.97) both; border: 2px solid #d32f2f !important; }
.sim-coupon-error-msg {
    display: block; color: #d32f2f; background: #ffebee;
    padding: 10px; border-radius: 6px; margin-top: 10px;
    font-size: 13px; border: 1px solid #ffcdd2; animation: fadeInDown 0.3s ease;
}
.sim-message-success, .sim-message-error { animation: slideIn 0.3s ease-out; }

/* ================================================================
   §7. CHECKOUT PAGE
   ================================================================ */
.sim-checkout-wrapper {
    max-width: 800px; margin: 40px auto; padding: 30px;
    background: var(--sim-pub-card, #ffffff);
    border-radius: var(--sim-pub-radius, 24px);
    box-shadow: 0 4px 20px rgba(0,0,0,0.08);
    font-family: var(--sim-pub-font-body, inherit), sans-serif;
}

/* Package Summary */
.sim-package-summary {
    background: var(--sim-pub-primary, #3a8686); color: white;
    padding: 25px; border-radius: 12px; margin-bottom: 30px;
}
.sim-package-summary h2 {
    margin: 0 0 15px 0; font-size: 21px; font-weight: 700;
    font-family: var(--sim-pub-font-heading, inherit), sans-serif;
}
.sim-package-summary-flex { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 15px; }
.sim-package-info p { margin: 5px 0; opacity: 0.9; font-size: 14px; }
.sim-package-price { text-align: right; }
.sim-package-price .sim-price-label { margin: 0; font-size: 12px; opacity: 0.8; }
.sim-package-price .sim-price-amount { margin: 5px 0 0 0; font-size: 21px; font-weight: 700; }

.sim-discount-indicator { display: none; margin-top: 8px; padding: 6px 12px; background: rgba(255,255,255,0.2); border-radius: 6px; }
.sim-discount-indicator small { display: block; opacity: 0.8; font-size: 11px; }
.sim-discount-indicator strong { font-size: 16px; }
#sim-discount-indicator { animation: bounceIn 0.5s ease-out; }

/* Coupon Section */
.sim-coupon-section {
    background: rgba(58,134,134,0.08); padding: 20px; border-radius: 12px;
    margin-bottom: 25px; border: 2px dashed var(--sim-pub-primary, #3a8686); transition: all 0.3s;
}
.sim-coupon-section:hover { box-shadow: 0 4px 12px rgba(58,134,134,0.15); }
.sim-coupon-toggle { cursor: pointer; user-select: none; }
.sim-coupon-toggle h3 {
    margin: 0; font-size: 15px; color: var(--sim-pub-primary, #3a8686);
    display: flex; align-items: center; gap: 8px; transition: all 0.3s;
}
.sim-coupon-toggle:hover h3 { color: var(--sim-pub-primary-dark, #1a535c); }
.sim-coupon-toggle:active { transform: scale(0.98); }
.sim-coupon-chevron { margin-left: auto; font-size: 13px; transition: transform 0.3s; }
.sim-coupon-content { display: none; margin-top: 15px; padding-top: 15px; border-top: 1px solid rgba(58,134,134,0.2); }
.sim-coupon-input-group { display: flex; gap: 10px; flex-wrap: wrap; }
.sim-coupon-input {
    flex: 1; min-width: 200px; padding: 12px 15px;
    border: 2px solid var(--sim-pub-primary, #3a8686); border-radius: 8px;
    font-size: 14px; text-transform: uppercase; font-weight: 600; letter-spacing: 1px;
    background: #fff; transition: all 0.3s; box-sizing: border-box;
}
.sim-coupon-input:focus { outline: none; border-color: var(--sim-pub-primary-dark, #1a535c); box-shadow: 0 0 0 3px rgba(58,134,134,0.1); }
.sim-coupon-input:disabled { background-color: #f8f9fa; cursor: not-allowed; opacity: 0.7; }
.sim-coupon-btn {
    padding: 12px 24px; background: var(--sim-pub-primary, #3a8686); color: white;
    border: none; border-radius: 8px; font-size: 14px; font-weight: 600;
    cursor: pointer; transition: all 0.3s; white-space: nowrap;
}
.sim-coupon-btn:hover { background: var(--sim-pub-primary-dark, #1a535c); transform: translateY(-2px); box-shadow: 0 4px 12px rgba(58,134,134,0.3); }
.sim-coupon-btn:disabled { opacity: 0.6; cursor: not-allowed; }

.sim-coupon-message { margin-top: 12px; display: none; padding: 12px 15px; border-radius: 8px; font-size: 13px; font-weight: 500; }
.sim-coupon-applied { display: none; margin-top: 15px; padding: 12px 15px; background: #e8f5e9; border-left: 4px solid #4caf50; border-radius: 8px; animation: fadeIn 0.3s ease-out; }
.sim-coupon-applied-flex { display: flex; justify-content: space-between; align-items: center; }
.sim-coupon-applied strong { color: #2e7d32; font-size: 13px; }
.sim-coupon-applied p { margin: 5px 0 0 0; font-size: 12px; color: #2e7d32; }
.sim-remove-coupon-btn,
#sim-remove-coupon-btn { padding: 6px 12px; background: #dc3545; color: white; border: none; border-radius: 6px; font-size: 11px; cursor: pointer; transition: all 0.2s; }
.sim-remove-coupon-btn:hover,
#sim-remove-coupon-btn:hover { background: #c82333; transform: scale(1.05); }

/* Price Breakdown */
.sim-price-breakdown {
    display: none; background: var(--sim-pub-bg, #f8fafa); padding: 20px;
    border-radius: 12px; margin-bottom: 25px; border: 1px solid #d0dede;
    animation: expandDown 0.3s ease-out;
}
.sim-price-breakdown h4 {
    margin: 0 0 15px 0; font-size: 15px; color: var(--sim-pub-text, #1a535c);
    font-family: var(--sim-pub-font-heading, inherit), sans-serif;
    padding-bottom: 10px; border-bottom: 2px solid var(--sim-pub-primary, #3a8686);
}
.sim-breakdown-row            { display: flex; justify-content: space-between; margin-bottom: 10px; font-size: 14px; }
.sim-breakdown-row span       { color: #666; }
.sim-breakdown-discount-row   { display: flex; justify-content: space-between; margin-bottom: 10px; color: #4caf50; font-size: 14px; }
.sim-breakdown-total-row      { border-top: 2px solid var(--sim-pub-primary, #3a8686); margin-top: 10px; padding-top: 10px; display: flex; justify-content: space-between; }
.sim-breakdown-total-row strong:first-child { font-size: 16px; color: var(--sim-pub-text, #1a535c); }
.sim-breakdown-total-row strong:last-child  { font-size: 18px; color: var(--sim-pub-primary, #3a8686); }
.sim-breakdown-note { margin-top: 12px; padding: 10px; background: #fff8e1; border-radius: 6px; border-left: 3px solid #ffc107; }
.sim-breakdown-note small { color: #856404; font-size: 11px; }
#sim-price-breakdown { animation: expandDown 0.3s ease-out; }
#sim-coupon-applied  { animation: fadeIn 0.3s ease-out; }

/* Addon Selection */
.sim-addon-selection-card {
    background: var(--sim-pub-card, #fdfdfd); padding: 20px; border-radius: 12px;
    margin-bottom: 25px; border: 2px dashed var(--sim-pub-primary, #3a8686);
}
.sim-addon-header { margin-bottom: 15px; }
.sim-addon-title h3 { margin: 0 0 5px 0; font-size: 16px; color: var(--sim-pub-primary, #3a8686); font-weight: 600; }
.sim-addon-title small { color: #666; font-size: 13px; display: block; margin-bottom: 5px; }
.sim-addon-price { margin: 5px 0 0; font-size: 14px; font-weight: bold; color: #e67e22; }
.sim-addon-controls {
    display: flex; align-items: center; justify-content: center; gap: 15px;
    background: #fff; padding: 12px; border-radius: 10px; border: 1px solid #ddd;
    max-width: 200px; margin: 0 auto;
}
.sim-addon-btn {
    width: 40px; height: 40px; border: none; background: var(--sim-pub-primary, #3a8686);
    color: #fff; border-radius: 8px; cursor: pointer; font-size: 16px; transition: all 0.2s;
    display: flex; align-items: center; justify-content: center;
}
.sim-addon-btn:hover { transform: scale(1.05); }
.sim-addon-btn:active { transform: scale(0.95); }
.sim-addon-btn-minus:hover { background: #c0392b; }
.sim-addon-btn-plus:hover  { background: #27ae60; }
.sim-addon-qty-input {
    width: 60px !important; height: 40px; text-align: center;
    border: 2px solid var(--sim-pub-primary, #3a8686); border-radius: 8px;
    font-weight: bold; font-size: 18px; color: var(--sim-pub-primary, #3a8686); background: #f9f9f9;
}

/* Quota Calculator */
.sim-quota-calculator {
    margin-top: 12px; padding: 10px 12px;
    background: linear-gradient(135deg,#e8f5f5 0%,#f0f9f9 100%);
    border-radius: 8px; border: 1px solid rgba(0,128,128,0.2); transition: all 0.3s;
}
.sim-quota-label { font-size: 13px; color: #666; margin: 0 0 4px 0; font-weight: 500; }
.sim-quota-value { margin: 0; font-size: 16px; color: var(--sim-pub-primary, #3a8686); }
.sim-quota-value strong { font-size: 20px; font-weight: 700; }
.sim-quota-highlight { animation: quotaPulse 0.5s ease; }

/* Registration Form */
.sim-registration-form h3 {
    margin-bottom: 20px; padding-bottom: 10px;
    border-bottom: 2px solid var(--sim-pub-primary, #3a8686);
    font-size: 18px; color: var(--sim-pub-text, #1a535c);
    font-family: var(--sim-pub-font-heading, inherit), sans-serif;
}
.sim-registration-form p { margin-bottom: 25px; color: #555; font-size: 14px; }
.sim-registration-form p a { color: var(--sim-pub-primary, #3a8686); text-decoration: none; font-weight: 600; }
.sim-registration-form p a:hover { color: var(--sim-pub-primary-dark, #1a535c); text-decoration: underline; }

.sim-checkout-wrapper .form-group { margin-bottom: 20px; }
.sim-checkout-wrapper .form-group label { display: block; margin-bottom: 8px; font-weight: 600; color: var(--sim-pub-text, #1a535c); font-size: 14px; }
.sim-checkout-wrapper .form-group label span { color: #dc3545; }
.sim-checkout-wrapper .form-group input {
    width: 100%; padding: 12px 15px; border: none; border-radius: 8px; font-size: 14px;
    box-sizing: border-box; background: var(--sim-pub-bg, #f8fafa); transition: all 0.3s; box-shadow: 0 2px 4px rgba(0,0,0,0.05);
}
.sim-checkout-wrapper .form-group input:focus { outline: none; background: var(--sim-pub-card, #fff); box-shadow: 0 4px 12px rgba(58,134,134,0.15); }
.sim-checkout-wrapper .form-group small { display: block; margin-top: 5px; color: #666; font-size: 11px; }

.sim-checkout-wrapper button[type="submit"],
.sim-checkout-wrapper .sim-checkout-submit {
    width: 100%; padding: 15px; background: var(--sim-pub-button, #3a8686);
    color: var(--sim-pub-button-text, #ffffff); border: none; border-radius: 12px;
    font-size: 16px; font-weight: 600; cursor: pointer; transition: all 0.3s;
    box-shadow: 0 4px 12px rgba(58,134,134,0.3);
}
.sim-checkout-wrapper button[type="submit"]:hover,
.sim-checkout-wrapper .sim-checkout-submit:hover {
    background: var(--sim-pub-primary-dark, #1a535c); transform: translateY(-2px); box-shadow: 0 6px 16px rgba(58,134,134,0.4);
}

.sim-logged-in-checkout .sim-user-info { background: #e7f3ff; border-left: 4px solid #2196F3; padding: 15px; margin-bottom: 25px; border-radius: 8px; }
.sim-logged-in-checkout .sim-user-info p { margin: 0; color: #0c5460; font-size: 14px; }
.sim-whatsapp-info { background: #e7f3ff; padding: 12px; border-radius: 8px; border-left: 3px solid #2196F3; margin-bottom: 20px; }
.sim-whatsapp-info small { color: #0d47a1; font-size: 12px; }

/* ================================================================
   §8. PAYMENT CONFIRMATION PAGE
   ================================================================ */
.sim-confirmation-wrapper {
    max-width: 800px; margin: 40px auto; padding: 30px;
    background: var(--sim-pub-card, #ffffff);
    border-radius: var(--sim-pub-radius, 24px);
    box-shadow: 0 4px 20px rgba(0,0,0,0.08);
    font-family: var(--sim-pub-font-body, inherit), sans-serif;
}

.sim-status-pending, .sim-status-success, .sim-status-canceled, .sim-status-other {
    padding: 30px; border-radius: 12px; text-align: center; margin-bottom: 30px;
}
.sim-status-pending  { background: color-mix(in srgb, var(--sim-pub-primary, #3a8686) 8%, var(--sim-pub-card, #ffffff)); border: 2px solid var(--sim-pub-primary, #3a8686); }
.sim-status-success  { background: #e8f5e9; border: 2px solid #4caf50; }
.sim-status-canceled { background: #fee;    border: 2px solid #dc3545; }
.sim-status-other    { background: var(--sim-pub-bg, #f8fafa); border: 2px solid #d0dede; }

.sim-status-icon {
    font-size: 48px;
    margin-bottom: 15px;
    background: transparent;       /* Tidak ada ornamen oval */
    border-radius: 0;
    display: block;
}
.sim-status-pending  .sim-status-icon { color: var(--sim-pub-primary, #3a8686); }
.sim-status-success  .sim-status-icon { color: var(--sim-pub-success, #4caf50); }
.sim-status-canceled .sim-status-icon { color: #dc3545; }
.sim-status-other    .sim-status-icon { color: var(--sim-pub-text-muted, #666); }

.sim-status-title { margin: 0 0 10px 0; font-size: 21px; font-weight: 700; font-family: var(--sim-pub-font-heading, inherit), sans-serif; }
.sim-status-pending  .sim-status-title { color: var(--sim-pub-text, #1a535c); }
.sim-status-success  .sim-status-title { color: #2e7d32; }
.sim-status-canceled .sim-status-title { color: #c33; }
.sim-status-other    .sim-status-title { color: var(--sim-pub-text, #1a535c); }

.sim-status-desc { margin: 0; font-size: 14px; opacity: 0.9; }
.sim-status-pending  .sim-status-desc { color: var(--sim-pub-text-muted, #7a9ea0); }
.sim-status-success  .sim-status-desc { color: #2e7d32; }
.sim-status-canceled .sim-status-desc { color: #c33; }
.sim-status-other    .sim-status-desc { color: #666; }

.sim-transaction-details { background: var(--sim-pub-bg, #f8fafa); padding: 25px; border-radius: 12px; margin-bottom: 25px; }
.sim-transaction-details h3 {
    margin: 0 0 20px 0; font-size: 16px; color: var(--sim-pub-text, #1a535c);
    font-family: var(--sim-pub-font-heading, inherit), sans-serif;
    padding-bottom: 10px; border-bottom: 2px solid var(--sim-pub-primary, #3a8686);
}
.sim-detail-grid  { display: grid; gap: 12px; }
.sim-detail-row   { display: flex; justify-content: space-between; padding: 10px 0; border-bottom: 1px solid #d0dede; font-size: 14px; }
.sim-detail-row:last-child { border-bottom: none; }
.sim-detail-label { color: #666; }
.sim-detail-value { color: var(--sim-pub-text, #1a535c); font-weight: 600; }
.sim-detail-invoice { font-family: monospace; color: var(--sim-pub-primary, #3a8686); font-size: 15px; }

.sim-price-breakdown-box { background: var(--sim-pub-card, #fff); padding: 15px; border-radius: 8px; margin: 10px 0; border: 1px dashed #d0dede; }
.sim-breakdown-item { display: flex; justify-content: space-between; padding: 8px 0; font-size: 14px; }
.sim-breakdown-item-label { color: #666; }
.sim-breakdown-item-value { color: var(--sim-pub-text, #1a535c); font-weight: 600; }
.sim-breakdown-discount { color: #4caf50; background: rgba(76,175,80,0.05); margin: 8px -5px; padding: 12px 5px; border-radius: 6px; }
.sim-breakdown-discount .sim-breakdown-item-label,
.sim-breakdown-discount .sim-breakdown-item-value { color: #4caf50; font-weight: 700; }
.sim-breakdown-unique          { color: #856404; margin-top: 8px; }
.sim-breakdown-unique.subtract { color: #dc3545; }
.sim-breakdown-unique.add      { color: #4caf50; }
.sim-breakdown-divider { border-top: 1px solid #d0dede; margin-top: 8px; padding-top: 12px; }
.sim-breakdown-total { display: flex; justify-content: space-between; align-items: center; padding: 15px 0; margin-top: 10px; border-top: 2px solid var(--sim-pub-primary, #3a8686); }
.sim-breakdown-total-label { font-size: 16px; color: var(--sim-pub-text, #1a535c); font-weight: 700; }
.sim-breakdown-total-value { font-size: 21px; font-weight: 700; color: var(--sim-pub-primary, #3a8686); }

.sim-info-box    { padding: 12px 15px; border-radius: 8px; font-size: 12px; margin-top: 12px; }
.sim-info-box i  { margin-right: 6px; }
.sim-info-warning { background: #fff8e1; border-left: 3px solid #ffc107; color: #856404; }
.sim-info-primary { background: #e7f3ff; border-left: 3px solid #2196F3; color: #0d47a1; }
.sim-info-success { background: #e8f5e9; border-left: 3px solid #4caf50; color: #2e7d32; }

.sim-coupon-badge { background: rgba(76,175,80,0.08); padding: 15px; border-radius: 8px; border: 2px solid rgba(76,175,80,0.3); margin-top: 10px; }
.sim-coupon-badge-flex  { display: flex; align-items: center; gap: 10px; }
.sim-coupon-badge-icon  { font-size: 21px; color: #4caf50; }
.sim-coupon-badge-title { font-weight: 700; color: #2e7d32; font-size: 14px; margin-bottom: 4px; }
.sim-coupon-badge-info  { color: #2e7d32; font-size: 12px; }

.sim-payment-methods { margin-bottom: 30px; }
.sim-payment-methods h3 {
    margin-bottom: 20px; padding-bottom: 10px;
    border-bottom: 2px solid var(--sim-pub-primary, #3a8686);
    font-size: 16px; color: var(--sim-pub-text, #1a535c);
    font-family: var(--sim-pub-font-heading, inherit), sans-serif;
}
.sim-payment-methods h4 { margin-bottom: 15px; color: var(--sim-pub-text, #1a535c); font-size: 15px; }

/* QRIS */
.sim-qris-container-wrapper { text-align: center; background: rgba(58,134,134,0.05); padding: 25px; border-radius: 12px; border: 2px solid rgba(58,134,134,0.2); margin-bottom: 25px; }
.sim-qris-spinner     { border: 4px solid #f3f3f3; border-top: 4px solid var(--sim-pub-primary, #3a8686); border-radius: 50%; width: 50px; height: 50px; animation: simSpin 1s linear infinite; margin: 0 auto; }
.sim-qris-loading     { margin: 40px 0; }
.sim-qris-loading-text    { margin-top: 15px; color: var(--sim-pub-primary, #3a8686); font-weight: 600; font-size: 14px; }
.sim-qris-loading-subtext { margin-top: 5px; color: #999; font-size: 12px; }
.sim-qris-image-box   { background: white; padding: 15px; border-radius: 8px; display: inline-block; box-shadow: 0 4px 12px rgba(0,0,0,0.1); }
.sim-qris-image       { max-width: 300px; width: 100%; height: auto; border-radius: 6px; display: block; }
.sim-qris-info        { margin-top: 20px; padding: 15px; background: rgba(58,134,134,0.1); border-radius: 8px; }
.sim-qris-info-title  { margin: 0 0 8px 0; color: var(--sim-pub-primary, #3a8686); font-size: 14px; font-weight: 600; }
.sim-qris-info-amount { margin: 0; color: var(--sim-pub-primary, #3a8686); font-size: 18px; font-weight: 700; }
.sim-qris-info-note   { margin: 8px 0 0 0; color: #666; font-size: 11px; }
.sim-qris-error { background: #fff8e1; border: 2px solid #ffc107; padding: 20px; margin: 20px 0; border-radius: 8px; text-align: left; }
.sim-qris-error-title   { margin: 0 0 10px 0; color: #856404; font-size: 14px; font-weight: 600; }
.sim-qris-error-message { margin: 0; color: #856404; font-size: 13px; line-height: 1.6; }

/* ================================================================
   BANK CARDS — warna mengikuti CSS vars Tampilan Dashboard
   Poin 3: card = warna tombol, copy btn = lebih gelap dari card
   Poin 4: logo bank estetik dengan white frame + shadow
   ================================================================ */

.sim-bank-list { display: grid; gap: 16px; }

.sim-bank-card,
.sim-confirmation-wrapper .sim-bank-card,
body .sim-bank-card {
    background:    var(--sim-pub-button, #3a8686) !important;
    color:         var(--sim-pub-button-text, #ffffff) !important;
    padding:       22px !important;
    border-radius: var(--sim-pub-radius, 16px) !important;
    display:       flex !important;
    flex-direction: column !important;
    gap:           16px !important;
    border:        none !important;
    box-shadow:    0 4px 20px rgba(0,0,0,0.15) !important;
    position:      relative !important;
    overflow:      hidden !important;
}

/* Efek kilau subtle di sudut kanan atas */
.sim-bank-card::after {
    content:        '' !important;
    position:       absolute !important;
    top:            -30px !important;
    right:          -30px !important;
    width:          100px !important;
    height:         100px !important;
    background:     rgba(255,255,255,0.07) !important;
    border-radius:  50% !important;
    pointer-events: none !important;
}

/* ── Logo Bank (Poin 4: estetik) ──────────────────────────── */
.sim-bank-logo-wrap {
    display:     flex !important;
    align-items: center !important;
}

.sim-bank-logo-frame {
    background:    rgba(255,255,255,0.95) !important;
    border-radius: calc(var(--sim-pub-radius, 16px) * 0.6) !important;
    padding:       10px 16px !important;
    display:       inline-flex !important;
    align-items:   center !important;
    justify-content: center !important;
    box-shadow:    0 2px 10px rgba(0,0,0,0.15) !important;
    min-width:     100px !important;
    min-height:    52px !important;
}

.sim-bank-logo-img {
    max-height:   40px !important;
    max-width:    140px !important;
    width:        auto !important;
    height:       auto !important;
    object-fit:   contain !important;
    display:      block !important;
    border-radius: 0 !important;
}

.sim-bank-logo-fallback {
    color:     var(--sim-pub-button, #3a8686) !important;
    font-size: 24px !important;
}

/* ── Info body ────────────────────────────────────────────── */
.sim-bank-info-body {
    flex: 1;
}

.sim-bank-name {
    font-weight:   700 !important;
    font-size:     18px !important;
    color:         var(--sim-pub-button-text, #ffffff) !important;
    margin-bottom: 6px !important;
    text-shadow:   0 1px 3px rgba(0,0,0,0.2) !important;
}

.sim-bank-number {
    font-size:     20px !important;
    font-weight:   800 !important;
    color:         var(--sim-pub-button-text, #ffffff) !important;
    letter-spacing: 2px !important;
    margin-bottom: 4px !important;
}

.sim-bank-holder {
    font-size:   13px !important;
    font-weight: 600 !important;
    color:       rgba(255,255,255,0.85) !important;
    opacity:     1 !important;
}

/* ── Tombol Salin (Poin 3: lebih gelap dari card) ─────────── */
.sim-copy-btn {
    width:         100% !important;
    background:    var(--sim-pub-primary-dark, #1a535c) !important;
    border:        2px solid rgba(255,255,255,0.2) !important;
    color:         var(--sim-pub-button-text, #ffffff) !important;
    padding:       12px 20px !important;
    border-radius: calc(var(--sim-pub-radius, 16px) * 0.6) !important;
    cursor:        pointer !important;
    font-size:     14px !important;
    font-weight:   700 !important;
    letter-spacing: 0.5px !important;
    transition:    all 0.25s ease !important;
    display:       flex !important;
    align-items:   center !important;
    justify-content: center !important;
    gap:           8px !important;
}

.sim-copy-btn:hover {
    background:    rgba(0,0,0,0.25) !important;
    border-color:  rgba(255,255,255,0.5) !important;
    transform:     translateY(-2px) !important;
    box-shadow:    0 4px 14px rgba(0,0,0,0.25) !important;
}

.sim-copy-btn:active {
    transform: translateY(0) !important;
}

.sim-copy-btn.copied {
    background:   rgba(76,175,80,0.4) !important;
    border-color: rgba(255,255,255,0.5) !important;
}

/* Elementor overrides */
.elementor-page .sim-bank-card *,
.elementor-section .sim-bank-card * { color: var(--sim-pub-button-text, #ffffff) !important; }
.elementor .sim-bank-card .sim-bank-name,
.elementor .sim-bank-card strong { color: var(--sim-pub-button-text, #ffffff) !important; font-weight: 700 !important; }

.sim-whatsapp-confirmation { background: #fff8e1; border-left: 4px solid #ffc107; padding: 25px; border-radius: 8px; margin-bottom: 25px; }
.sim-whatsapp-confirmation h4 { margin: 0 0 10px 0; color: #856404; font-size: 16px; }
.sim-whatsapp-confirmation p  { margin: 0 0 20px 0; color: #856404; line-height: 1.6; font-size: 13px; }
.sim-whatsapp-admin-box   { background: rgba(255,255,255,0.5); padding: 12px; border-radius: 6px; margin-bottom: 15px; }
.sim-whatsapp-admin-label  { display: block; color: #856404; margin-bottom: 5px; font-weight: 600; font-size: 12px; }
.sim-whatsapp-admin-number { font-size: 15px; font-weight: 700; color: #25D366; }
.sim-whatsapp-btn,
.sim-wa-confirm-btn {
    display: inline-block; padding: 15px 35px;
    background: #25D366; color: white !important; text-decoration: none;
    border-radius: 8px; font-size: 15px; font-weight: 600;
    box-shadow: 0 4px 12px rgba(37,211,102,0.3); transition: all 0.3s;
}
.sim-whatsapp-btn:hover,
.sim-wa-confirm-btn:hover { background: #1faa52; transform: translateY(-2px); box-shadow: 0 6px 16px rgba(37,211,102,0.4); color: white !important; text-decoration: none; }

/* ================================================================
   §9. DASHBOARD — iOS Container Base
   ================================================================ */
.sim-ios-container {
    background: var(--sim-pub-bg, #f4f7f7);
    max-width: 650px; margin: 30px auto;
    font-family: var(--sim-pub-font-body, 'Inter'), sans-serif;
    color: var(--sim-pub-text, #1a535c);
    border-radius: 20px; padding-bottom: 40px;
}
.sim-ios-container.list-view { max-width: 1000px; border-radius: 24px; }
.sim-ios-header {
    display: flex; justify-content: space-between; align-items: center;
    padding: 20px; background: rgba(244,247,247,0.9); backdrop-filter: blur(15px);
    position: sticky; top: 0; z-index: 100; border-radius: 20px 20px 0 0;
}
.sim-ios-container.list-view .sim-ios-header { padding: 25px 30px; border-radius: 24px 24px 0 0; }
.sim-ios-header h1 { font-size: 20px; font-weight: 800; margin: 0; color: var(--sim-pub-text, #1a535c); font-family: var(--sim-pub-font-heading, inherit), sans-serif; }

/* ================================================================
   §10. DASHBOARD — List View (Undangan)
   ================================================================ */
.sim-home-welcome h3 { font-family: var(--sim-pub-font-heading, inherit), sans-serif; color: var(--sim-pub-text, #1a535c); }

.sim-search-wrapper   { padding: 0 30px 20px; }
.sim-search-row       { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.sim-search-box {
    position: relative; display: flex; align-items: center;
    background: var(--sim-pub-card, #fff); border-radius: 15px; border: 1px solid #e0e7e7;
    padding: 0 15px; box-shadow: 0 5px 15px rgba(26,83,92,0.03); flex: 1; min-width: 200px;
}
.sim-search-box .dashicons { color: #8fa7ab; }
.sim-search-box input { width: 100%; border: none; padding: 12px 10px; font-size: 14px; color: var(--sim-pub-text, #1a535c); background: transparent; outline: none; box-shadow: none !important; }
.sim-search-wrapper .sim-search-box { flex: 1; }

.sim-paging-controls { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
.sim-paging-label { font-size: 12px; color: #8fa7ab; font-weight: 600; margin-right: 2px; }
.sim-paging-btn,
body .sim-paging-controls .sim-paging-btn,
body .sim-ios-container .sim-paging-btn {
    padding:       8px 18px !important;
    border-radius: var(--sim-pub-radius-sm, 20px) !important;
    border:        2px solid color-mix(in srgb, var(--sim-pub-primary, #3a8686) 30%, transparent) !important;
    background:    var(--sim-pub-card, #ffffff) !important;
    color:         var(--sim-pub-primary, #3a8686) !important;
    font-size:     13px !important;
    font-weight:   700 !important;
    cursor:        pointer !important;
    transition:    0.2s !important;
    text-decoration: none !important;
    box-shadow:    none !important;
}
.sim-paging-btn.active,
body .sim-paging-controls .sim-paging-btn.active,
body .sim-ios-container .sim-paging-btn.active {
    background:    var(--sim-pub-button, #3a8686) !important;
    color:         var(--sim-pub-button-text, #ffffff) !important;
    border-color:  var(--sim-pub-button, #3a8686) !important;
}
.sim-paging-btn:hover:not(.active),
body .sim-paging-controls .sim-paging-btn:hover:not(.active) {
    background:   color-mix(in srgb, var(--sim-pub-primary, #3a8686) 10%, white) !important;
    border-color: var(--sim-pub-primary, #3a8686) !important;
}
.sim-page-btn { width: 32px; height: 32px; border-radius: 10px; border: 1.5px solid #d0e1e1; background: var(--sim-pub-card, #fff); color: var(--sim-pub-primary, #3a8686); font-size: 12px; font-weight: 700; cursor: pointer; transition: 0.2s; display: inline-flex; align-items: center; justify-content: center; }
.sim-page-btn.active { background: var(--sim-pub-primary, #3a8686); color: #fff; border-color: var(--sim-pub-primary, #3a8686); }
.sim-page-btn:hover:not(.active) { background: #eef6f6; }

.sim-dashboard-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(300px,1fr)); gap: 30px; padding: 0 30px; align-items: start; }
.sim-invitation-item-group { display: flex; flex-direction: column; gap: 15px; margin-bottom: 20px; }

.sim-ios-card { background: var(--sim-pub-card, #fff); border-radius: 20px; overflow: hidden; box-shadow: 0 10px 25px rgba(26,83,92,0.05); border: 1px solid #e0e7e7; transition: 0.3s; }
.sim-ios-card:hover { transform: translateY(-5px); box-shadow: 0 15px 35px rgba(26,83,92,0.1); }
.card-thumb   { height: 150px; background-size: cover; background-position: center; position: relative; }
.card-content { padding: 18px; text-align: center; }
.card-meta-title { font-size: 10px; font-weight: 700; color: #8fa7ab; text-transform: uppercase; margin-bottom: 5px; }
.card-main-title { font-size: 16px; font-weight: 800; color: var(--sim-pub-text, #1a535c); margin-bottom: 12px; font-family: var(--sim-pub-font-heading, inherit), sans-serif; }

.rsvp-recent-card { display: flex; flex-direction: column; background: var(--sim-pub-card, #fff); border: 1px solid #e0e7e7; margin-top: -5px; }
.card-header-ios  { display: flex; align-items: center; gap: 12px; padding: 15px; border-bottom: 1px solid #f0f5f5; }
.header-icon { background: #f0f7f7; color: var(--sim-pub-primary, #3a8686); width: 35px; height: 35px; border-radius: 10px; display: flex; align-items: center; justify-content: center; }
.wishes-list-mini { flex: 1; padding: 5px 15px; }
.mini-wish-item { display: flex; align-items: center; gap: 10px; padding: 8px 0; border-bottom: 1px dashed #f0f5f5; }
.mini-avatar { width: 28px; height: 28px; border-radius: 50%; background: var(--sim-pub-accent, #4ecdc4); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 800; overflow: hidden; flex-shrink: 0; }
.mini-avatar img { width: 100%; height: 100%; object-fit: cover; }
.mini-content { flex: 1; min-width: 0; text-align: left; }
.mini-name    { font-size: 12px; font-weight: 700; color: var(--sim-pub-text, #1a535c); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mini-text    { font-size: 10px; color: #8fa7ab; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mini-badge   { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.is-hadir { background: var(--sim-pub-accent, #4ecdc4); }
.is-absen { background: #ff6b6b; }
.card-footer-ios { padding: 12px; border-top: 1px solid #f0f5f5; }
.view-all-btn { display: flex; align-items: center; justify-content: center; gap: 5px; width: 100%; padding: 8px; background: #f0f7f7; color: var(--sim-pub-primary, #3a8686); text-decoration: none; border-radius: 10px; font-size: 11px; font-weight: 700; transition: 0.2s; }
.view-all-btn:hover { background: var(--sim-pub-primary, #3a8686); color: #fff; text-decoration: none; }

.card-footer-actions { display: flex; gap: 6px; }

/* ================================================================
   ACTION BUTTONS — high-specificity selector + !important
   Mengalahkan Elementor global override pada a, button
   ================================================================ */
.sim-ios-container .action-btn-ios,
.sim-dashboard-wrapper .action-btn-ios,
body .sim-ios-container .action-btn-ios,
body .sim-dashboard-wrapper .action-btn-ios {
    flex:            1 !important;
    padding:         10px !important;
    border-radius:   var(--sim-pub-radius-sm, 12px) !important;
    text-decoration: none !important;
    font-size:       12px !important;
    font-weight:     700 !important;
    text-align:      center !important;
    display:         flex !important;
    align-items:     center !important;
    justify-content: center !important;
    gap:             4px !important;
    border:          2px solid transparent !important;
    cursor:          pointer !important;
    transition:      background 0.2s, color 0.2s, border-color 0.2s, transform 0.15s !important;
    min-width:       36px !important;
    box-sizing:      border-box !important;
    line-height:     1 !important;
}

/* btn-primary — tombol Edit & Buat Baru */
.sim-ios-container .action-btn-ios.btn-primary,
.sim-dashboard-wrapper .action-btn-ios.btn-primary,
body .sim-ios-container .action-btn-ios.btn-primary,
body .sim-dashboard-wrapper .action-btn-ios.btn-primary,
body .sim-ios-container a.action-btn-ios.btn-primary,
body .sim-ios-container button.action-btn-ios.btn-primary {
    background:    var(--sim-pub-button, #3a8686) !important;
    color:         var(--sim-pub-button-text, #ffffff) !important;
    border-color:  var(--sim-pub-button, #3a8686) !important;
    flex:          2.5 !important;
}
.sim-ios-container .action-btn-ios.btn-primary:hover,
body .sim-ios-container .action-btn-ios.btn-primary:hover {
    background:   var(--sim-pub-primary-dark, #1a535c) !important;
    border-color: var(--sim-pub-primary-dark, #1a535c) !important;
    color:        var(--sim-pub-button-text, #ffffff) !important;
    transform:    translateY(-1px) !important;
}

/* btn-secondary — Preview, Copy, Tamu, Admin-action, Quick Edit */
.sim-ios-container .action-btn-ios.btn-secondary,
.sim-dashboard-wrapper .action-btn-ios.btn-secondary,
body .sim-ios-container .action-btn-ios.btn-secondary,
body .sim-dashboard-wrapper .action-btn-ios.btn-secondary,
body .sim-ios-container a.action-btn-ios.btn-secondary,
body .sim-ios-container button.action-btn-ios.btn-secondary {
    background:   color-mix(in srgb, var(--sim-pub-primary, #3a8686) 10%, white) !important;
    color:        var(--sim-pub-primary, #3a8686) !important;
    border-color: color-mix(in srgb, var(--sim-pub-primary, #3a8686) 25%, transparent) !important;
}
.sim-ios-container .action-btn-ios.btn-secondary:hover,
body .sim-ios-container .action-btn-ios.btn-secondary:hover {
    background:   color-mix(in srgb, var(--sim-pub-primary, #3a8686) 18%, white) !important;
    color:        var(--sim-pub-primary-dark, #1a535c) !important;
    border-color: var(--sim-pub-primary, #3a8686) !important;
    transform:    translateY(-1px) !important;
}

.sim-card-countdown { display: flex; justify-content: center; margin-bottom: 15px; gap: 8px; }
.cd-item  { text-align: center; flex: 1; background: var(--sim-pub-primary, #3a8686); border-radius: 8px; padding: 8px 4px; color: #fff; }
.cd-val   { display: block; font-size: 14px; font-weight: 800; }
.cd-label { font-size: 8px; text-transform: uppercase; opacity: 0.8; }

.admin-badge { position: absolute; top: 12px; left: 12px; padding: 5px 12px; border-radius: 12px; font-size: 10px; font-weight: 800; color: #fff; backdrop-filter: blur(5px); box-shadow: 0 4px 10px rgba(0,0,0,0.1); z-index: 2; }
.status-publish { background: rgba(78,205,196,0.9); }
.status-draft   { background: rgba(143,167,171,0.9); }
.admin-login-status-badge { display: inline-flex; align-items: center; gap: 5px; background: #fff1f1; color: #ff6b6b; padding: 4px 10px; border-radius: 20px; font-size: 11px; font-weight: 700; border: 1px solid #ffdbdb; }
.quota-info-badge { font-size: 12px; color: var(--sim-pub-primary, #3a8686); background: #eef6f6; padding: 4px 12px; border-radius: 10px; display: inline-flex; align-items: center; gap: 6px; margin-top: 5px; border: 1px solid #d0e1e1; }
.admin-badge-mode,
.sim-ios-trx-container .admin-badge-mode,
body .sim-ios-trx-container .admin-badge-mode {
    background:     var(--sim-pub-button, #3a8686) !important;
    color:          var(--sim-pub-button-text, #ffffff) !important;
    padding:        8px 18px !important;
    border-radius:  var(--sim-pub-radius-sm, 50px) !important;
    font-size:      11px !important;
    font-weight:    800 !important;
    text-transform: uppercase !important;
    border:         2px solid color-mix(in srgb, var(--sim-pub-button, #3a8686) 60%, white) !important;
    display:        inline-flex !important;
    align-items:    center !important;
    gap:            6px !important;
}

/* Modal form fields */
.sim-ios-field { margin-bottom: 18px; }
.sim-ios-field label { display: block; font-size: 12px; font-weight: 700; color: #8fa7ab; margin-bottom: 8px; text-transform: uppercase; }
.sim-ios-field input,
.sim-ios-field select,
.sim-ios-input,
.sim-ios-select {
    width:       100%;
    max-width:   100%;
    padding:     12px 15px;
    border-radius: var(--sim-pub-radius-sm, 12px);
    border:      1px solid #e0e7e7;
    background:  #f9fbfb;
    font-size:   14px;
    color:       var(--sim-pub-text, #1a535c);
    outline:     none;
    box-sizing:  border-box;   /* FIX: cegah overflow ke kanan modal */
    display:     block;
    -webkit-appearance: none;
    appearance:  none;
}
.sim-ios-field input:focus,
.sim-ios-field select:focus {
    border-color: var(--sim-pub-primary, #3a8686);
    background:   var(--sim-pub-card, #fff);
}

/* Date input: pastikan tidak overflow di mobile/modal */
.sim-ios-field input[type="date"] {
    width:      100% !important;
    max-width:  100% !important;
    box-sizing: border-box !important;
    min-width:  0 !important;
}
input[type="date"]::-webkit-calendar-picker-indicator {
    cursor:  pointer;
    opacity: 0.6;
    flex-shrink: 0;
}
.sim-field-hint { font-size: 10px; color: #aeaeb2; line-height: 1.4; display: block; margin-top: 3px; }

.theme-preview-box { width: 100%; height: 150px; border-radius: 15px; overflow: hidden; margin-bottom: 12px; border: 1px solid #e0e7e7; }
.theme-preview-box img { width: 100%; height: 100%; object-fit: cover; }

.admin-action-options { display: flex; flex-direction: column; gap: 10px; }
.status-opt { display: flex; align-items: center; justify-content: center; gap: 10px; padding: 15px; border-radius: 15px; border: none; font-weight: 700; cursor: pointer; transition: 0.2s; }
.btn-publish { background: #e7f9f7; color: var(--sim-pub-primary, #3a8686); }
.btn-draft   { background: #f0f3f3; color: var(--sim-pub-text, #1a535c); }
.btn-trash   { background: #fff1f1; color: #c0392b; border: 1.5px solid #ffcccc !important; }
.btn-trash:hover { background: #c0392b; color: #fff; }

/* iOS Alert (SweetAlert style) */
.ios-alert-popup { width: 270px !important; border-radius: 14px !important; padding: 0 !important; background: rgba(255,255,255,0.9) !important; backdrop-filter: blur(20px); font-family: -apple-system, sans-serif !important; }
.ios-alert-title { font-size: 17px !important; font-weight: 600 !important; padding: 20px 15px 5px !important; color: #000 !important; }
.swal2-html-container { padding: 0 15px 20px !important; margin: 0 !important; }
.swal2-actions { display: flex !important; width: 100% !important; margin: 0 !important; border-top: 0.5px solid rgba(0,0,0,0.1); background: transparent !important; }
.ios-alert-confirm, .ios-alert-cancel { flex: 1; border: none !important; background: transparent !important; padding: 12px 5px !important; font-size: 17px !important; margin: 0 !important; cursor: pointer; }
.ios-alert-cancel  { color: #007aff !important; font-weight: 400 !important; border-right: 0.5px solid rgba(0,0,0,0.1) !important; border-radius: 0 0 0 14px !important; }
.ios-alert-confirm { color: #007aff !important; font-weight: 600 !important; border-radius: 0 0 14px 0 !important; }

/* ================================================================
   §11. DASHBOARD — Edit Page (Form Builder)
   ================================================================ */
.sim-ios-header-left { display: flex; align-items: center; gap: 12px; }
.sim-ios-icon-preview-main {
    width: 32px; height: 32px; background: var(--sim-pub-primary, #3a8686); color: #ffffff !important;
    border-radius: 9px; display: flex; align-items: center; justify-content: center;
    text-decoration: none; transition: transform 0.2s, opacity 0.2s;
    box-shadow: 0 2px 6px rgba(58,134,134,0.2);
}
.sim-ios-icon-preview-main:active { transform: scale(0.9); opacity: 0.8; }
.sim-ios-icon-preview-main .dashicons { font-size: 18px; width: 18px; height: 18px; }

.sim-ios-group-label { padding: 25px 20px 8px 38px; font-size: 10px; font-weight: 700; color: #8fa7ab; text-transform: uppercase; letter-spacing: 1px; }
.sim-ios-list { background: var(--sim-pub-card, #ffffff); margin: 0 15px; border-radius: 18px; overflow: hidden; box-shadow: 0 4px 12px rgba(0,0,0,0.03); }
.sim-ios-row  { padding: 14px 18px; display: flex; align-items: center; cursor: pointer; border-bottom: 1px solid #f0f5f5; }
.sim-ios-icon { width: 32px; height: 32px; border-radius: 9px; display: flex; align-items: center; justify-content: center; margin-right: 15px; color: #fff; }
.icon-blue   { background: var(--sim-pub-primary, #3a8686); }
.icon-green  { background: var(--sim-pub-accent, #4ecdc4); }
.icon-orange { background: #ff9500; }
.icon-purple { background: #af52de; }
.sim-ios-title { flex: 1; font-size: 15px; font-weight: 600; }
.sim-ios-chevron::after { content: '\f347'; font-family: dashicons; color: #8fa7ab; transition: 0.3s; display: inline-block; }
.sim-ios-row-wrapper.active .sim-ios-chevron::after { transform: rotate(180deg); }
.sim-ios-expandable { max-height: 0; overflow: hidden; background: #fafcfc; transition: max-height 0.5s ease-in-out; }
.sim-ios-row-wrapper.active .sim-ios-expandable { max-height: 5000px; }
.sim-ios-form-body  { padding: 20px; }
.sim-ios-input-group { margin-bottom: 18px; }
.sim-ios-input-group label { display: block; font-size: 13px; font-weight: 700; color: var(--sim-pub-primary, #3a8686); margin-bottom: 6px; }

/* Upload */
.sim-upload-box {
    position: relative; width: 100%; aspect-ratio: 16/9;
    border: 2px dashed var(--sim-pub-primary, #3a8686); margin: 10px;
    border-radius: 12px; background: #f4fcfc;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    overflow: hidden; transition: 0.3s;
}
.sim-file-input { position: absolute; inset: 0; width: 100% !important; height: 100% !important; opacity: 0; cursor: pointer; z-index: 10; }
.sim-error-notif { margin-top: 10px; font-size: 11px; color: #ff3b30; text-align: center; }
/* ── Upload Container: Box Utama ──────────────────────────────────── */
.sim-ios-upload-container-main {
    position: relative; width: 100%; aspect-ratio: 16/9;
    border-radius: 16px; overflow: hidden;
}

/* ── Dropzone: Area klik / drag — isi penuh container ── */
.sim-ios-upload-dropzone {
    position: absolute; inset: 0;
    background: #f4fcfc;
    /* Flex center agar .sim-ios-upload-content benar-benar terpusat */
    display: flex; align-items: center; justify-content: center;
    z-index: 1;
}

/* ── Content wrapper di dalam dropzone ── */
.sim-ios-upload-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    pointer-events: none; /* Klik menembus ke input file di bawahnya */
    text-align: center;
    padding: 12px;
}

/* ── Ikon kamera ── */
.sim-ios-upload-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
}
.sim-ios-upload-icon .dashicons {
    font-size: 40px !important;
    width: 40px !important;
    height: 40px !important;
    line-height: 1 !important;
    color: var(--sim-pub-primary, #3a8686);
    opacity: 0.55;
}

/* ── Teks label upload ── */
.sim-ios-upload-text {
    font-size: 12px;
    font-weight: 600;
    color: var(--sim-pub-primary, #3a8686);
    opacity: 0.7;
    max-width: 120px;
    line-height: 1.3;
}

/* ── Input file tersembunyi (full-cover di atas dropzone) ── */
.sim-ios-file-hidden {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    opacity: 0; cursor: pointer;
    z-index: 50; font-size: 0;
}

/* ── Preview overlay (muncul saat ada gambar) ── */
.sim-ios-preview-overlay { position: absolute; inset: 0; z-index: 10; display: none; background: #fff; }
.sim-ios-preview-overlay.has-content { display: grid; gap: 4px; padding: 4px; }
.sim-ios-preview-overlay.is-single  { grid-template-columns: 1fr; }
.sim-ios-preview-overlay.is-gallery { grid-template-columns: repeat(3,1fr); }
.sim-ios-preview-item { position: relative; width: 100%; height: 100%; overflow: hidden; border-radius: 10px; }
.sim-ios-preview-item img {
    width: 100%; height: 100%;
    object-fit: cover;
    border-radius: 10px;
    display: block;
}

/* ── Tombol hapus gambar (delete) ── PROPORSIONAL ── */
.sim-ios-delete-file {
    position: absolute;
    top: 6px; right: 6px;
    width: 26px !important;
    height: 26px !important;
    background: rgba(255, 59, 48, 0.9) !important;
    color: #fff !important;
    border: 2px solid rgba(255,255,255,0.7) !important;
    border-radius: 50% !important;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 6px rgba(0,0,0,0.25);
    z-index: 1000 !important;
    pointer-events: auto;
    padding: 0 !important;
    line-height: 1 !important;
    transition: background 0.2s, transform 0.15s;
}
.sim-ios-delete-file:hover {
    background: #ff3b30 !important;
    transform: scale(1.12);
}
.sim-ios-delete-file .dashicons {
    font-size: 13px !important;
    width: 13px !important;
    height: 13px !important;
    line-height: 1 !important;
}

/* ── Upload wrapper untuk tipe lama (.sim-upload-box) ── */
.sim-ios-upload-placeholder { display: flex; flex-direction: column; align-items: center; justify-content: center; color: var(--sim-pub-primary, #3a8686); pointer-events: none; }
.sim-ios-upload-placeholder .dashicons { font-size: 40px; width: 40px; height: 40px; margin-bottom: 8px; opacity: 0.6; }
.sim-ios-upload-placeholder p { margin: 0; font-size: 14px; font-weight: 600; opacity: 0.8; }
.sim-ios-upload-wrapper { min-height: 180px; position: relative; display: flex; align-items: center; justify-content: center; background: #f4fcfc; border: 2px dashed var(--sim-pub-primary, #3a8686); border-radius: 12px; }
.sim-preview-container { position: relative; padding: 3px; width: 100% !important; height: auto; }
.sim-preview-container img { width: 100%; height: auto; aspect-ratio: 16/9; object-fit: cover; border-radius: 10px !important; }
.sim-remove-btn { position: absolute; top: 8px; right: 8px; background: #ff5f5f; color: white; border: none; border-radius: 50%; width: 26px; height: 26px; cursor: pointer; font-size: 18px; line-height: 1; font-weight: bold; box-shadow: 0 2px 5px rgba(0,0,0,0.2); z-index: 1000 !important; pointer-events: auto; }
.sim-ios-modal { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.3); z-index: 9999; display: flex; align-items: center; justify-content: center; backdrop-filter: blur(5px); }
.sim-ios-modal-content { background: #fff; padding: 30px; border-radius: 20px; text-align: center; box-shadow: 0 15px 35px rgba(0,0,0,0.2); width: 260px !important; }

/* ================================================================
   §12. DASHBOARD — Account / Profile
   ================================================================ */
.sim-ios-account-container { max-width: 900px; margin: 0 auto; padding: 20px; font-family: var(--sim-pub-font-body, -apple-system), sans-serif; }
.account-profile-card { background: var(--sim-pub-card, #fff); border-radius: 24px; padding: 28px; display: flex; align-items: center; gap: 22px; box-shadow: 0 10px 30px rgba(0,0,0,0.05); border: 1px solid #f0f0f0; margin-bottom: 20px; }
.profile-avatar img { width: 76px; height: 76px; border-radius: 18px; object-fit: cover; border: 2px solid #f0f4f4; }
.profile-info h2 { margin: 0 0 4px; font-size: 20px; color: #1c1c1e; font-weight: 700; font-family: var(--sim-pub-font-heading, inherit), sans-serif; }
.profile-info p  { margin: 4px 0 0; font-size: 13px; color: #8e8e93; display: flex; align-items: center; gap: 6px; }
.profile-badge   { margin-left: auto; flex-shrink: 0; }
.badge-pkg { background: #007aff; color: #fff; padding: 6px 14px; border-radius: 20px; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; white-space: nowrap; }
.badge-pkg.badge-expired { background: #ff3b30; }

.account-details-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(200px,1fr)); gap: 15px; }
.detail-item { background: var(--sim-pub-card, #fff); padding: 20px; border-radius: 20px; display: flex; align-items: flex-start; gap: 14px; border: 1px solid #f0f0f0; transition: transform 0.2s, box-shadow 0.2s; }
.detail-item:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(0,0,0,0.06); }
.detail-item.item-expired { opacity: 0.7; border-color: #ffd0d0; }
.detail-icon { width: 42px; height: 42px; border-radius: 12px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px; }
.detail-icon .dashicons { color: #fff; font-size: 20px; width: 20px; height: 20px; }
.detail-text  { flex: 1; min-width: 0; }
.detail-label { display: block; font-size: 10px; color: #8e8e93; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 8px; }
.detail-value { display: block; font-size: 15px; font-weight: 700; color: #1c1c1e; word-break: break-all; }

.quota-numbers    { display: flex; align-items: baseline; gap: 4px; margin-bottom: 2px; }
.quota-remaining  { font-size: 28px; font-weight: 800; color: #007aff; line-height: 1; }
.quota-remaining.quota-purple { color: #af52de; }
.quota-sep        { font-size: 16px; color: #c7c7cc; font-weight: 400; }
.quota-total      { font-size: 16px; color: #aeaeb2; font-weight: 500; }
.quota-sublabel   { font-size: 10px; color: #aeaeb2; margin-bottom: 10px; }
.quota-sublabel.quota-empty { color: #ff3b30; }
.quota-progress-wrap  { margin-bottom: 6px; }
.quota-progress-bar   { height: 5px; background: #f2f2f7; border-radius: 10px; overflow: hidden; margin-bottom: 4px; }
.quota-progress-fill  { height: 100%; border-radius: 10px; transition: width 0.6s ease; }
.fill-blue   { background: #007aff; }
.fill-purple { background: #af52de; }
.quota-used-label { font-size: 10px; color: #aeaeb2; }
.quota-warning { margin-top: 6px; font-size: 10px; color: #ff3b30; background: #fff5f5; padding: 5px 8px; border-radius: 7px; border: 1px solid #ffd0d0; line-height: 1.4; }
.quota-warning.warning-orange { color: #c05500; background: #fff9f0; border-color: #ffe0c0; }

.expiry-active        { color: #34c759; font-weight: 700; font-size: 15px; }
.expiry-no-limit      { color: #007aff; font-weight: 700; font-size: 15px; }
.expiry-expiring-soon { color: #ff9500; font-weight: 700; font-size: 15px; }
.expiry-expired       { color: #ff3b30; font-weight: 700; font-size: 15px; }

.invoice-number { font-size: 13px; font-weight: 600; }
.invoice-status { display: inline-block; margin-top: 5px; padding: 3px 10px; border-radius: 12px; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.4px; }
.status-lunas   { background: #e8f9ef; color: #1c7a3c; }
.status-pending { background: #fff8e0; color: #856200; }
.status-batal   { background: #fff0f0; color: #c0392b; }
.status-default { background: #f2f2f7; color: #8e8e93; }

.account-actions { margin-top: 25px; text-align: center; padding: 0 20px; }

/* btn-logout: ikut warna & border dari Tampilan Dashboard
   iOS: outline ghost button — background transparan, teks & border ikut --sim-pub-button */
.btn-logout,
body .sim-ios-account-container .btn-logout,
body a.btn-logout {
    display:         inline-flex !important;
    align-items:     center !important;
    justify-content: center !important;
    gap:             8px !important;
    padding:         13px 28px !important;
    background:      transparent !important;
    border:          2px solid var(--sim-pub-button, #3a8686) !important;
    color:           var(--sim-pub-button, #3a8686) !important;
    border-radius:   var(--sim-pub-radius-sm, 14px) !important;
    text-decoration: none !important;
    font-weight:     600 !important;
    font-size:       14px !important;
    width:           100% !important;
    max-width:       320px !important;
    transition:      all 0.25s !important;
    box-sizing:      border-box !important;
}
.btn-logout:hover,
body .sim-ios-account-container .btn-logout:hover {
    background:  var(--sim-pub-button, #3a8686) !important;
    color:       var(--sim-pub-button-text, #ffffff) !important;
    transform:   translateY(-1px) !important;
    text-decoration: none !important;
}

/* ================================================================
   §13. DASHBOARD — Settings Page (Profile Edit)
   ================================================================ */
.sim-ios-settings-container { max-width: 700px; margin: 0 auto; }
.settings-form    { padding: 30px; }
.form-title       { margin: 0 0 25px 0; color: var(--sim-pub-text, #1a535c); font-size: 20px; font-weight: 800; font-family: var(--sim-pub-font-heading, inherit), sans-serif; }
.profile-photo-section { display: flex; align-items: center; gap: 20px; padding-bottom: 25px; margin-bottom: 25px; border-bottom: 1px solid #f0f4f4; }
.photo-wrapper { position: relative; width: 100px; height: 100px; }
.photo-wrapper img { width: 100%; height: 100%; border-radius: 24px; object-fit: cover; border: 3px solid #f0f4f4; }
.edit-overlay { position: absolute; bottom: -5px; right: -5px; background: var(--sim-pub-accent, #4ecdc4); width: 32px; height: 32px; border-radius: 10px; display: flex; align-items: center; justify-content: center; color: white; cursor: pointer; border: 3px solid #fff; box-shadow: 0 4px 10px rgba(78,205,196,0.3); transition: 0.3s; }
.edit-overlay:hover { transform: scale(1.1); background: var(--sim-pub-primary-dark, #1a535c); }
.photo-info label { display: block; font-weight: 700; color: var(--sim-pub-text, #1a535c); margin-bottom: 4px; }
.photo-info p { font-size: 11px; color: #8fa7ab; margin: 0; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.form-group label { display: block; font-size: 11px; font-weight: 700; color: #8fa7ab; margin-bottom: 8px; text-transform: uppercase; }
.form-group input { width: 100%; padding: 12px 15px; border-radius: 12px; border: 1px solid #f0f4f4; background: #f8fbfb; font-size: 14px; }
.form-group input:focus { border-color: var(--sim-pub-accent, #4ecdc4); background: #fff; outline: none; }

/* ================================================================
   §14. DASHBOARD — Transactions
   ================================================================ */
.sim-ios-trx-container { max-width: 1000px; margin: 0 auto; padding: 20px; }
.trx-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 30px; }
.trx-title  { font-size: 24px; font-weight: 850; color: var(--sim-pub-text, #1a535c); margin: 0; font-family: var(--sim-pub-font-heading, inherit), sans-serif; }
.trx-grid   { display: grid; grid-template-columns: repeat(auto-fill,minmax(320px,1fr)); gap: 20px; }
.trx-card   { background: var(--sim-pub-card, #fff); border-radius: 28px; border: 1px solid #f0f4f4; display: flex; flex-direction: column; transition: 0.4s cubic-bezier(0.165,0.84,0.44,1); overflow: hidden; }
.trx-card:hover { transform: translateY(-5px); box-shadow: 0 20px 40px rgba(26,83,92,0.1); }
.card-badge-row { padding: 20px 20px 0; display: flex; justify-content: space-between; align-items: center; }
.badge-status { font-size: 10px; font-weight: 800; text-transform: uppercase; padding: 6px 14px; border-radius: 50px; display: inline-flex; align-items: center; gap: 6px; }
.buyer-tag    { font-size: 11px; color: #5a7d82; font-weight: 700; background: #f4f7f7; padding: 4px 10px; border-radius: 8px; }
.is-pending .badge-status { background: #fff8eb; color: #b7791f; border: 1px solid #fbd38d; }
.is-paid    .badge-status { background: #e6fffa; color: #2c7a7b; border: 1px solid #81e6d9; }
.card-body   { padding: 20px; display: flex; justify-content: space-between; align-items: flex-end; flex-grow: 1; }
.package-name { font-size: 19px; font-weight: 800; color: var(--sim-pub-text, #1a535c); margin: 5px 0; }
.meta-date    { font-size: 11px; color: #a0aec0; font-weight: 600; }
.invoice-num  { font-size: 12px; color: #718096; background: #f7fafc; padding: 4px 8px; border-radius: 6px; font-family: 'Monaco', monospace; }
.price-group .value { font-size: 18px; font-weight: 900; color: var(--sim-pub-text, #1a535c); }
.card-action  { padding: 15px 20px; background: #fafdfd; border-top: 1px solid #f0f4f4; }
.has-double-btn { display: flex; gap: 10px; }
.btn-trx { flex: 1; border: none; cursor: pointer; padding: 12px; border-radius: 16px; font-size: 12px; font-weight: 700; transition: 0.3s; display: flex; align-items: center; justify-content: center; gap: 8px; }
.btn-confirm-lunas,
.sim-ios-trx-container .btn-confirm-lunas,
body .sim-ios-trx-container .btn-confirm-lunas,
body .sim-ios-trx-container button.btn-confirm-lunas {
    background:    var(--sim-pub-button, #3a8686) !important;
    color:         var(--sim-pub-button-text, #ffffff) !important;
    border:        2px solid var(--sim-pub-button, #3a8686) !important;
    border-radius: var(--sim-pub-radius-sm, 12px) !important;
}
.btn-confirm-lunas:hover,
body .sim-ios-trx-container button.btn-confirm-lunas:hover {
    background:   var(--sim-pub-primary-dark, #1a535c) !important;
    border-color: var(--sim-pub-primary-dark, #1a535c) !important;
    color:        var(--sim-pub-button-text, #ffffff) !important;
}
.btn-view-invoice  { background: var(--sim-pub-card, #fff); color: var(--sim-pub-text, #1a535c); border: 1px solid #e2e8f0; text-decoration: none; }
.btn-detail { display: flex; justify-content: space-between; align-items: center; text-decoration: none; font-size: 13px; font-weight: 700; color: var(--sim-pub-text, #1a535c); width: 100%; }
.card-admin-tools { display: flex; align-items: center; gap: 8px; }
/* btn-delete-trx — danger icon, seragam action-btn-ios, specificity tinggi */
.btn-delete-trx,
body .sim-ios-trx-container .btn-delete-trx,
body .sim-ios-container .btn-delete-trx,
body button.btn-delete-trx {
    flex:         0 0 36px !important;
    width:        36px !important;
    padding:      8px !important;
    color:        #e53e3e !important;
    background:   color-mix(in srgb, #e53e3e 10%, white) !important;
    border-color: color-mix(in srgb, #e53e3e 25%, transparent) !important;
    border-radius: var(--sim-pub-radius-sm, 12px) !important;
    border-width: 2px !important;
    border-style: solid !important;
    display:      flex !important;
    align-items:  center !important;
    justify-content: center !important;
    cursor:       pointer !important;
    transition:   0.2s !important;
}
.btn-delete-trx:hover,
body .sim-ios-trx-container .btn-delete-trx:hover,
body button.btn-delete-trx:hover {
    background:   #e53e3e !important;
    border-color: #e53e3e !important;
    color:        #fff !important;
    transform:    rotate(5deg) scale(1.1) !important;
}
.sim-pagination { margin-top: 40px; display: flex; justify-content: center; }
.sim-pagination ul { display: flex; list-style: none; gap: 8px; padding: 0; }
.sim-pagination li a, .sim-pagination li span { padding: 10px 18px; border-radius: 14px; background: var(--sim-pub-card, #fff); border: 1px solid #e2e8f0; color: var(--sim-pub-text, #1a535c); font-weight: 700; text-decoration: none; transition: 0.3s; display: block; }
.sim-pagination li span.current { background: var(--sim-pub-primary-dark, #1a535c); color: #fff; border-color: var(--sim-pub-primary-dark, #1a535c); }

/* ================================================================
   §15. DASHBOARD — Users Management
   ================================================================ */
.sim-ios-container.list-view .user-list { max-width: 1100px; }
.user-card-header-ios { padding: 20px; display: flex; align-items: center; gap: 15px; border-bottom: 1px solid #f8fbfb; position: relative; }
.user-mini-avatar { width: 50px; height: 50px; border-radius: 14px; object-fit: cover; background: #f0f5f5; border: 1px solid #eef2f2; flex-shrink: 0; }
.user-meta-info { flex: 1; min-width: 0; }
.user-name  { margin: 0; font-size: 15px; font-weight: 800; color: var(--sim-pub-text, #1a535c); }
.user-email { font-size: 11px; color: #8fa7ab; display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.user-wa    { font-size: 11px; color: #8fa7ab; display: flex; align-items: center; gap: 3px; margin-top: 2px; }
.user-wa .dashicons { font-size: 11px; width: 11px; height: 11px; }
.user-package-badge { position: absolute; top: 15px; right: 15px; font-size: 8px; font-weight: 800; padding: 4px 8px; border-radius: 8px; letter-spacing: 0.5px; white-space: nowrap; max-width: 90px; overflow: hidden; text-overflow: ellipsis; }
.badge-default  { background: #eef6f6; color: var(--sim-pub-primary, #3a8686); }
.badge-premium  { background: #fff9e6; color: #ff9500; border: 1px solid #ffeeb3; }
.badge-inactive { background: #f4f7f7; color: #8fa7ab; }
.user-card-stats-ios { display: grid; grid-template-columns: repeat(3,1fr); background: #f9fbfb; padding: 15px 10px; text-align: center; }
.stat-box { border-right: 1px solid #eef2f2; }
.stat-box:last-child { border-right: none; }
.stat-label { display: block; font-size: 8px; font-weight: 800; color: #8fa7ab; text-transform: uppercase; margin-bottom: 4px; }
.stat-val   { font-size: 13px; font-weight: 800; color: var(--sim-pub-text, #1a535c); }
.stat-val.is-expired { color: #ff3b30; }
.join-date-label { font-size: 10px; color: #cbd5d6; font-weight: 600; }

/* User card footer — icon aksi di kanan, date di kiri (iOS: always RTL action) */
.sim-ios-container .card-footer-actions {
    display:         flex !important;
    align-items:     center !important;
    justify-content: space-between !important;
    padding:         14px 16px !important;
    border-top:      1px solid #f8fbfb !important;
}
.user-actions-btns {
    display:     flex !important;
    gap:         8px !important;
    margin-left: auto !important;
}

/* Edit modal for users */
.edit-avatar-row { display: flex; align-items: center; gap: 14px; background: #f4f9f9; border: 1px solid #ddeeed; border-radius: 14px; padding: 13px 16px; margin-bottom: 18px; }
.edit-avatar-img { width: 54px; height: 54px; border-radius: 14px; object-fit: cover; border: 2px solid #ddeeed; flex-shrink: 0; }
.edit-avatar-note { font-size: 11px; color: #8fa7ab; display: flex; align-items: center; gap: 4px; margin-top: 4px; }
.edit-avatar-note .dashicons { font-size: 12px; width: 12px; height: 12px; }
.form-grid-two {
    display:               grid;
    grid-template-columns: 1fr 1fr;
    gap:                   14px;
    width:                 100%;
    box-sizing:            border-box;
    min-width:             0;
}
.form-grid-two > * { min-width: 0; }   /* prevent grid blowout */
.edit-modal-footer { display: flex; justify-content: space-between; align-items: center; gap: 10px; margin-top: 18px; padding-top: 16px; border-top: 1px solid #f0f5f5; flex-wrap: wrap; }

/* ================================================================
   §16. DASHBOARD — List Tamu
   ================================================================ */
.sim-dashboard-wrapper .sim-listtamu-content {
    font-family: var(--sim-pub-font-body, 'Segoe UI'), sans-serif !important;
    width: 100%; display: block;
}
.sim-dashboard-wrapper .sim-listtamu-content i,
.sim-dashboard-wrapper .sim-listtamu-content .fas,
.sim-dashboard-wrapper .sim-listtamu-content .far,
.sim-dashboard-wrapper .sim-listtamu-content .fab {
    font-family: "Font Awesome 5 Free", "Font Awesome 5 Brands" !important;
    font-weight: 900; font-style: normal;
}
.sim-dashboard-wrapper .sim-listtamu-content .far { font-weight: 400; }
.sim-dashboard-wrapper .sim-listtamu-content .fab { font-weight: 400; font-family: "Font Awesome 5 Brands" !important; }

.sim-dashboard-wrapper .sim-listtamu-card { background: var(--sim-pub-card, #fff) !important; border-radius: 20px !important; box-shadow: 0 2px 10px rgba(0,0,0,0.05) !important; overflow: hidden; margin: 10px 0 !important; border: 1px solid #e0e0e0 !important; }
.sim-dashboard-wrapper .sim-listtamu-card-header { background: var(--sim-pub-primary, #3a8686) !important; padding: 12px 15px !important; display: flex !important; justify-content: space-between !important; align-items: center !important; color: #fff !important; }
.sim-dashboard-wrapper .sim-listtamu-header-title { display: flex !important; align-items: center !important; gap: 10px !important; }
.sim-dashboard-wrapper .sim-listtamu-header-title h3 { margin: 0 !important; font-size: 14px !important; font-weight: 600 !important; color: #fff !important; }

.sim-dashboard-wrapper .sim-listtamu-toolbar { display: flex !important; justify-content: space-between !important; align-items: center !important; padding: 10px 15px !important; background: #f8f9fa !important; border-bottom: 1px solid #eee !important; }
.sim-dashboard-wrapper .sim-listtamu-search-wrapper { position: relative !important; padding: 10px 15px !important; }
.sim-dashboard-wrapper .sim-listtamu-search-wrapper input { width: 90% !important; padding: 8px 10px 8px 35px !important; border: 1px solid #ddd !important; border-radius: 20px !important; outline: none !important; background: var(--sim-pub-card, #fff) !important; }

.sim-dashboard-wrapper .sim-listtamu-ul   { list-style: none !important; padding: 0 !important; margin: 0 !important; }
.sim-dashboard-wrapper .sim-listtamu-item { display: flex !important; justify-content: space-between !important; align-items: center !important; padding: 15px !important; border-bottom: 1px solid #eee !important; background: var(--sim-pub-card, #fff) !important; }
.sim-dashboard-wrapper .sim-listtamu-info    { display: flex !important; align-items: flex-start !important; gap: 12px !important; }
.sim-dashboard-wrapper .sim-listtamu-number  { font-weight: bold !important; color: #888 !important; font-size: 14px !important; }
.sim-dashboard-wrapper .sim-listtamu-details h4 { margin: 0 0 4px 0 !important; font-size: 16px !important; font-weight: 600 !important; color: #333 !important; }
.sim-dashboard-wrapper .sim-listtamu-details p  { margin: 0 !important; font-size: 13px !important; color: #666 !important; }
.sim-dashboard-wrapper .sim-listtamu-badge-vip { background: #f1c40f !important; color: #fff !important; padding: 2px 8px !important; border-radius: 4px !important; font-size: 10px !important; margin-left: 5px !important; vertical-align: middle !important; }
.sim-dashboard-wrapper .sim-listtamu-actions { display: flex !important; gap: 15px !important; color: #adb5bd !important; }
.sim-dashboard-wrapper .sim-listtamu-actions i { cursor: pointer !important; font-size: 18px !important; transition: 0.2s !important; }
.sim-dashboard-wrapper .sim-listtamu-actions .sim-listtamu-btn-wa:hover    { color: #25d366 !important; }
.sim-dashboard-wrapper .sim-listtamu-actions .sim-listtamu-btn-share:hover { color: #3498db !important; }
.sim-dashboard-wrapper .sim-listtamu-actions .sim-listtamu-btn-edit:hover  { color: #f39c12 !important; }
.sim-dashboard-wrapper .sim-listtamu-actions .sim-listtamu-btn-del:hover   { color: #e74c3c !important; }

.sim-dashboard-wrapper .sim-listtamu-form-group { margin-bottom: 18px !important; }
.sim-dashboard-wrapper .sim-listtamu-form-group label { display: block !important; margin-bottom: 8px !important; font-size: 13px !important; font-weight: 600 !important; color: #555 !important; }
.sim-dashboard-wrapper .sim-listtamu-form-control { width: 100% !important; padding: 12px 15px !important; border: 2px solid #eee !important; border-radius: 10px !important; font-size: 14px !important; transition: all 0.3s !important; outline: none !important; background: #fafafa !important; }
.sim-dashboard-wrapper .sim-listtamu-form-control:focus { border-color: var(--sim-pub-primary, #3a8686) !important; background: var(--sim-pub-card, #fff) !important; box-shadow: 0 0 0 4px rgba(58,134,134,0.1) !important; }
.sim-dashboard-wrapper textarea.sim-listtamu-form-control { resize: vertical !important; line-height: 1.5 !important; }
.sim-dashboard-wrapper .sim-listtamu-modal-box { animation: simModalFadeIn 0.3s ease-out !important; }
.sim-dashboard-wrapper .badge-success { background-color: #27ae60 !important; border-radius: 6px !important; font-weight: 500 !important; transition: background 0.2s !important; }
.sim-dashboard-wrapper .badge-success:hover { background-color: #219150 !important; }

/* ================================================================
   §17. DASHBOARD — RSVP Wishes
   ================================================================ */
.simrsvp-toolbar { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.simrsvp-export-btn {
    flex-shrink: 0; width: 44px; height: 44px; border-radius: 13px;
    border: 1px solid #eef3f4; background: var(--sim-pub-card, #fff); color: var(--sim-pub-text, #1a535c);
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; transition: background 0.2s, color 0.2s, transform 0.15s;
    box-shadow: 0 3px 10px rgba(26,83,92,0.05);
}
.simrsvp-export-btn:hover { background: var(--sim-pub-primary-dark, #1a535c); color: #fff; transform: scale(1.05); }
.simrsvp-export-btn .dashicons { font-size: 20px; width: 20px; height: 20px; }
.simrsvp-search-box {
    flex: 1; position: relative; display: flex; align-items: center;
    background: var(--sim-pub-card, #fff); border-radius: 13px; border: 1px solid #eef3f4;
    box-shadow: 0 3px 10px rgba(26,83,92,0.05);
}
.simrsvp-search-icon { position: absolute; left: 13px; color: #bccdcf; font-size: 18px; width: 18px; height: 18px; }
.simrsvp-search-box input { width: 100%; border: none; padding: 12px 12px 12px 40px; background: transparent; outline: none; font-size: 14px; color: var(--sim-pub-text, #1a535c); border-radius: 13px; }

.simrsvp-export-desc { font-size: 12px; color: #8fa7ab; line-height: 1.6; margin-bottom: 18px; text-align: center; }
.simrsvp-export-desc strong { color: var(--sim-pub-text, #1a535c); }
.simrsvp-export-list { display: flex; flex-direction: column; gap: 10px; }
.simrsvp-export-row { display: flex; align-items: center; gap: 14px; padding: 14px 16px; border-radius: 16px; border: 1px solid #eef3f4; background: var(--sim-pub-card, #fff); text-decoration: none; color: var(--sim-pub-text, #1a535c); transition: background 0.18s, box-shadow 0.18s, transform 0.12s; }
.simrsvp-export-row:hover { background: #f0f7f7; box-shadow: 0 4px 14px rgba(26,83,92,0.08); transform: translateY(-1px); text-decoration: none; color: var(--sim-pub-text, #1a535c); }
.simrsvp-export-icon { width: 40px; height: 40px; border-radius: 10px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.simrsvp-export-icon .dashicons { font-size: 22px; width: 22px; height: 22px; }
.simrsvp-export-text { flex: 1; }
.simrsvp-export-text strong { display: block; font-size: 14px; font-weight: 700; margin-bottom: 2px; }
.simrsvp-export-text span   { font-size: 11px; color: #8fa7ab; }
.simrsvp-export-arrow { color: #dde8e8; flex-shrink: 0; }

.simrsvp-modal-card { animation: simrsvpPopIn 0.3s cubic-bezier(0.175,0.885,0.32,1.15); }

/* ================================================================
   §18. RESPONSIVE
   ================================================================ */
@media (max-width: 768px) {
    .sim-checkout-form-wrapper { margin: 20px; padding: 30px 20px; border-radius: 20px; }
    .sim-checkout-header { font-size: 28px; }
    .sim-form-control { font-size: 16px !important; }

    .sim-checkout-wrapper { padding: 20px; margin: 20px 10px; }
    .sim-package-summary { padding: 20px; }
    .sim-package-summary h2 { font-size: 18px; }
    .sim-package-summary-flex { flex-direction: column; align-items: flex-start; }
    .sim-package-price { text-align: left; width: 100%; margin-top: 15px; }
    .sim-coupon-input-group { flex-direction: column; }
    .sim-coupon-input, .sim-coupon-btn { min-width: 100%; width: 100%; }
    .sim-addon-controls { max-width: 180px; }
    .sim-addon-btn { width: 36px; height: 36px; }
    .sim-addon-qty-input { width: 55px !important; font-size: 16px; }

    .sim-confirmation-wrapper { padding: 20px; margin: 20px 10px; }
    .sim-status-pending, .sim-status-success, .sim-status-canceled, .sim-status-other { padding: 20px; }
    .sim-status-title { font-size: 18px; }
    .sim-status-icon { font-size: 36px; }
    .sim-bank-card { flex-direction: column !important; gap: 15px !important; }
    .sim-copy-btn { width: 100% !important; order: 2 !important; }
    .sim-breakdown-total-value { font-size: 18px; }

    .sim-ios-header { padding: 15px 20px; }
    .sim-dashboard-grid { padding: 0 20px; gap: 20px; }
    .sim-search-wrapper { padding: 0 15px 15px; }
    .sim-search-row { flex-direction: column; align-items: stretch; }
    .account-profile-card { flex-direction: column; text-align: center; }
    .profile-badge { margin: 8px 0 0; }
    .form-grid, .form-grid-two { grid-template-columns: 1fr; }
    .edit-modal-footer { flex-direction: column; align-items: stretch; }
    .sim-sub-tab-nav { width: 100%; }
    .sub-tab-item { flex: 1; text-align: center; padding: 8px 2px; font-size: 11px; }
}

@media (max-width: 480px) {
    .sim-checkout-form-wrapper { margin: 15px; padding: 25px 15px; border-radius: 16px; }
    .sim-checkout-header { font-size: 24px; margin-bottom: 20px; }
    button.sim-button-primary-submit { padding: 14px 20px !important; font-size: 15px !important; }
    .sim-modal, .sim-ios-modal-card { margin: 20% 15px; }
    .sim-modal h3 { font-size: 1.2em; }

    .sim-checkout-wrapper { margin: 15px; padding: 15px; }
    .sim-package-summary { padding: 15px; }
    .sim-package-summary h2 { font-size: 16px; }
    .sim-registration-form h3 { font-size: 16px; }

    .sim-confirmation-wrapper { margin: 15px; padding: 15px; }
    .sim-status-title { font-size: 16px; }
    .sim-transaction-details { padding: 15px; }
    .sim-qris-container-wrapper { padding: 15px; }

    .sim-listtamu-modal-box { max-width: 100% !important; border-radius: 20px 20px 0 0 !important; position: absolute !important; bottom: 0 !important; }
    .simrsvp-modal-card { max-width: 100% !important; border-radius: 20px 20px 0 0 !important; }

    #simPagingBar { padding: 15px 15px 0; }
    .trx-grid { grid-template-columns: 1fr; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    .sim-coupon-section, #sim-apply-coupon-btn, #sim-remove-coupon-btn, #sim-coupon-input { transition: none; }
    .sim-message-success, .sim-message-error, #sim-coupon-applied, #sim-price-breakdown, #sim-discount-indicator { animation: none; }
}
/* High contrast */
@media (prefers-contrast: high) {
    #sim-coupon-input { border-width: 2px; }
    .sim-message-success, .sim-message-error { border-left-width: 5px !important; }
}
/* Print */
@media print {
    .sim-coupon-section { display: none; }
    #sim-price-breakdown { border: 1px solid #000; page-break-inside: avoid; }
}

/* ================================================================
   PAGINATION — sim-dashboard-list (admin only, > 10 posts)
   ================================================================ */
.sim-pagination {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
    padding: 16px 20px 8px;
    justify-content: center;
}
.sim-page-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 36px;
    padding: 0 10px;
    border-radius: var(--sim-pub-radius, 10px);
    background: #f3f4f6;
    color: var(--sim-pub-text, #1a535c);
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    border: 1px solid #e5e7eb;
    transition: all .18s;
}
.sim-page-btn:hover {
    background: var(--sim-pub-primary, #3a8686);
    color: #fff;
    border-color: var(--sim-pub-primary, #3a8686);
}
.sim-page-btn.active {
    background: var(--sim-pub-primary, #3a8686);
    color: #fff;
    border-color: var(--sim-pub-primary, #3a8686);
    cursor: default;
    pointer-events: none;
}
.sim-page-info {
    font-size: 12px;
    color: #9ca3af;
    padding: 0 8px;
    white-space: nowrap;
}

/* ================================================================
   iOS-STYLE TOAST NOTIFICATION — sim-ios-toast
   Dipakai di view-confirmation-detail.php (copy rekening)
   ================================================================ */
#sim-ios-toast {
    position: fixed;
    top: -80px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 99999;
    display: flex;
    align-items: center;
    gap: 10px;
    background: rgba(30, 30, 30, 0.92);
    color: #fff;
    padding: 10px 20px 10px 14px;
    border-radius: 40px;
    font-size: 13.5px;
    font-weight: 600;
    box-shadow: 0 8px 32px rgba(0,0,0,0.22);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    white-space: nowrap;
    pointer-events: none;
    transition: top 0.32s cubic-bezier(0.34, 1.56, 0.64, 1),
                opacity 0.22s ease;
    opacity: 0;
}

#sim-ios-toast.sim-toast-visible {
    top: 22px;
    opacity: 1;
}

/* SVG ring + checkmark animation */
.sim-toast-ring {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 22px;
    height: 22px;
}

.sim-toast-ring svg {
    width: 22px;
    height: 22px;
    overflow: visible;
}

.sim-toast-circle {
    stroke: #4ecdc4;
    stroke-width: 1.5;
    fill: none;
    stroke-dasharray: 56.5;
    stroke-dashoffset: 56.5;
    animation: sim-toast-draw-circle 0.35s 0.05s ease forwards;
}

.sim-toast-check {
    stroke: #4ecdc4;
    stroke-width: 2;
    fill: none;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-dasharray: 18;
    stroke-dashoffset: 18;
    animation: sim-toast-draw-check 0.25s 0.35s ease forwards;
}

@keyframes sim-toast-draw-circle {
    to { stroke-dashoffset: 0; }
}

@keyframes sim-toast-draw-check {
    to { stroke-dashoffset: 0; }
}

/* Responsive: pada layar kecil pastikan tidak terlalu lebar */
@media (max-width: 480px) {
    #sim-ios-toast {
        font-size: 12.5px;
        padding: 9px 16px 9px 12px;
        max-width: calc(100vw - 32px);
        white-space: normal;
    }
}

/* ================================================================
   TOAST NOTIFICATION — iOS-style animated top toast
   (#sim-ios-toast + .sim-toast-visible)
   ================================================================ */
#sim-ios-toast {
    position: fixed;
    top: -80px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 99999;
    display: flex;
    align-items: center;
    gap: 10px;
    background: #1a535c;
    color: #fff;
    padding: 12px 20px 12px 14px;
    border-radius: 50px;
    font-size: 13px;
    font-weight: 600;
    box-shadow: 0 8px 28px rgba(26,83,92,0.28);
    white-space: nowrap;
    pointer-events: none;
    transition: top 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
    max-width: 90vw;
    overflow: hidden;
    text-overflow: ellipsis;
}
#sim-ios-toast.sim-toast-visible {
    top: 18px;
}

/* SVG checkmark ring inside toast */
.sim-toast-ring {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 22px;
    height: 22px;
}
.sim-toast-ring svg {
    width: 20px;
    height: 20px;
    overflow: visible;
}
.sim-toast-circle {
    stroke: #4ecdc4;
    stroke-width: 2;
    stroke-dasharray: 57;
    stroke-dashoffset: 57;
    fill: none;
    animation: sim-toast-circle-draw 0.4s ease forwards;
}
.sim-toast-check {
    stroke: #fff;
    stroke-width: 2.2;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-dasharray: 20;
    stroke-dashoffset: 20;
    fill: none;
    animation: sim-toast-check-draw 0.3s ease 0.3s forwards;
}
@keyframes sim-toast-circle-draw {
    to { stroke-dashoffset: 0; }
}
@keyframes sim-toast-check-draw {
    to { stroke-dashoffset: 0; }
}

/* ================================================================
   TOAST NOTIFICATION — sim-ios-toast (halaman konfirmasi)
   Muncul dari atas layar, animasi SVG checkmark iOS-style
   ================================================================ */

#sim-ios-toast {
    position:       fixed;
    top:            -80px;
    left:           50%;
    transform:      translateX(-50%);
    display:        flex;
    align-items:    center;
    gap:            10px;
    background:     var(--sim-pub-button, #3a8686);
    color:          var(--sim-pub-button-text, #ffffff);
    padding:        12px 20px 12px 14px;
    border-radius:  var(--sim-pub-radius-sm, 40px);
    border:         2px solid color-mix(in srgb, var(--sim-pub-button, #3a8686) 60%, white);
    font-size:      14px;
    font-weight:    600;
    white-space:    nowrap;
    z-index:        99999;
    box-shadow:     0 8px 30px rgba(0,0,0,0.2);
    transition:     top 0.35s cubic-bezier(0.34,1.56,0.64,1);
    pointer-events: none;
}

#sim-ios-toast.sim-toast-visible {
    top: 20px;
}

.sim-toast-ring {
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.sim-toast-ring svg {
    width: 22px;
    height: 22px;
    overflow: visible;
}

.sim-toast-circle {
    stroke: color-mix(in srgb, var(--sim-pub-button-text, #ffffff) 50%, transparent);
    stroke-width: 1.5;
    fill: none;
    stroke-dasharray: 56.5;
    stroke-dashoffset: 56.5;
    animation: none;
}

.sim-toast-check {
    stroke: #fff;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
    fill: none;
    stroke-dasharray: 20;
    stroke-dashoffset: 20;
    animation: none;
}

#sim-ios-toast.sim-toast-visible .sim-toast-circle {
    animation: sim-toast-circle-anim 0.4s ease forwards 0.05s;
}

#sim-ios-toast.sim-toast-visible .sim-toast-check {
    animation: sim-toast-check-anim 0.3s ease forwards 0.3s;
}

@keyframes sim-toast-circle-anim {
    to { stroke-dashoffset: 0; }
}

@keyframes sim-toast-check-anim {
    to { stroke-dashoffset: 0; }
}

/* ================================================================
   COPY BUTTON STATES
   ================================================================ */
.sim-copy-btn {
    transition: background 0.2s, transform 0.1s;
    cursor: pointer;
}
.sim-copy-btn:active {
    transform: scale(0.96);
}

/* ================================================================
   iOS ANIMATED TOAST — Konfirmasi Salin Nomor Rekening
   (#sim-ios-toast, .sim-toast-visible, .sim-toast-ring, etc.)
   ================================================================ */
#sim-ios-toast {
    position: fixed;
    top: -80px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 99999;
    display: flex;
    align-items: center;
    gap: 10px;
    background: #1a535c;
    color: #fff;
    padding: 12px 20px 12px 14px;
    border-radius: 40px;
    font-size: 14px;
    font-weight: 600;
    box-shadow: 0 8px 32px rgba(26,83,92,0.32);
    pointer-events: none;
    white-space: nowrap;
    transition: top 0.38s cubic-bezier(0.34, 1.56, 0.64, 1),
                opacity 0.25s ease;
    opacity: 0;
    min-width: 140px;
    max-width: 90vw;
    text-overflow: ellipsis;
    overflow: hidden;
}
#sim-ios-toast.sim-toast-visible {
    top: 18px;
    opacity: 1;
}
/* SVG ring wrapper */
.sim-toast-ring {
    flex-shrink: 0;
    width: 22px;
    height: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.sim-toast-ring svg {
    width: 22px;
    height: 22px;
    overflow: visible;
}
/* Animated circle stroke */
.sim-toast-circle {
    stroke: rgba(255,255,255,0.4);
    stroke-width: 1.5;
    fill: none;
    stroke-dasharray: 57;
    stroke-dashoffset: 57;
    animation: sim-toast-ring-draw 0.45s ease forwards;
}
/* Animated check stroke */
.sim-toast-check {
    stroke: #fff;
    stroke-width: 2;
    fill: none;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-dasharray: 20;
    stroke-dashoffset: 20;
    animation: sim-toast-check-draw 0.3s ease 0.25s forwards;
}
@keyframes sim-toast-ring-draw {
    to { stroke-dashoffset: 0; }
}
@keyframes sim-toast-check-draw {
    to { stroke-dashoffset: 0; }
}

/* ================================================================
   FIX: action-btn-ios — FA icon alignment (copy-link fa-link)
   ================================================================ */
.action-btn-ios i.fas,
.action-btn-ios i.far,
.action-btn-ios i.fab {
    font-size: 14px;
    line-height: 1;
    pointer-events: none;
}

/* ================================================================
   FIX: .sim-profile-input override tema (browser default border)
   ================================================================ */
.sim-profile-settings-wrap .sim-profile-input,
.sim-profile-settings-wrap .sim-profile-input:not([type="checkbox"]) {
    border: 1.5px solid #e8eeee !important;
    background: #f8fbfb !important;
    box-shadow: none !important;
    outline: none !important;
}
.sim-profile-settings-wrap .sim-profile-input:focus {
    border-color: var(--sim-pub-accent, #4ecdc4) !important;
    background: #fff !important;
    box-shadow: 0 0 0 3px rgba(78,205,196,.15) !important;
}
.sim-profile-settings-wrap .sim-profile-input--readonly {
    border-color: #e8eeee !important;
    background: #f0f4f4 !important;
}

/* ================================================================
   ANIMATED HOURGLASS — Poin 2: pasir turun animasi
   ================================================================ */

.sim-hourglass-icon {
    display:         flex !important;
    justify-content: center !important;
    align-items:     center !important;
    margin-bottom:   18px !important;
    background:      transparent !important;
    border-radius:   0 !important;
}

.sim-hourglass-svg {
    width:  64px;
    height: 86px;
    filter: drop-shadow(0 2px 6px rgba(0,0,0,0.15));
}

/* Frame & bars mengikuti warna primary */
.sim-hg-frame {
    fill:   none;
    stroke: var(--sim-pub-primary, #3a8686);
    stroke-width: 3;
    stroke-linejoin: round;
}
.sim-hg-bar {
    fill:         var(--sim-pub-primary, #3a8686);
    border-radius: 3px;
}

/* Pasir atas mengecil (kuras 0% → 100% dalam 3s, loop) */
.sim-hg-sand-top {
    fill: var(--sim-pub-accent, #4ecdc4);
    opacity: 0.85;
    transform-origin: center top;
    animation: simSandTop 3s ease-in-out infinite;
}

/* Pasir bawah mengembang (isi 0% → 100% dalam 3s, loop) */
.sim-hg-sand-bot {
    fill: var(--sim-pub-accent, #4ecdc4);
    opacity: 0.85;
    transform-origin: center bottom;
    animation: simSandBot 3s ease-in-out infinite;
}

/* Titik-titik pasir jatuh */
.sim-hg-drop1 {
    fill:    var(--sim-pub-primary, #3a8686);
    opacity: 0;
    animation: simDrop 3s 0.2s ease-in infinite;
}
.sim-hg-drop2 {
    fill:    var(--sim-pub-primary, #3a8686);
    opacity: 0;
    animation: simDrop 3s 0.5s ease-in infinite;
}
.sim-hg-drop3 {
    fill:    var(--sim-pub-primary, #3a8686);
    opacity: 0;
    animation: simDrop 3s 0.8s ease-in infinite;
}

@keyframes simSandTop {
    0%   { transform: scaleY(1);   }
    80%  { transform: scaleY(0.1); }
    100% { transform: scaleY(0);   }
}

@keyframes simSandBot {
    0%   { transform: scaleY(0.1); }
    80%  { transform: scaleY(1);   }
    100% { transform: scaleY(1);   }
}

@keyframes simDrop {
    0%   { opacity: 0; transform: translateY(0px);  }
    20%  { opacity: 1; transform: translateY(2px);  }
    70%  { opacity: 1; transform: translateY(6px);  }
    100% { opacity: 0; transform: translateY(10px); }
}

/* Pendulum hourglass card: berputar setelah pasir habis */
.sim-status-pending .sim-hourglass-icon {
    animation: simHourglassFlip 3s 3s ease-in-out infinite;
}
@keyframes simHourglassFlip {
    0%   { transform: rotate(0deg);   }
    8%   { transform: rotate(180deg); }
    100% { transform: rotate(180deg); }
}

/* ================================================================
   SIM LIST TOAST — seragam dengan sim-ios-toast, ikut CSS vars
   ================================================================ */
.sim-list-toast-pill {
    position:       fixed;
    top:            -80px;
    left:           50%;
    transform:      translateX(-50%);
    z-index:        99999;
    display:        flex;
    align-items:    center;
    gap:            10px;
    background:     var(--sim-pub-button, #3a8686);
    color:          var(--sim-pub-button-text, #ffffff);
    padding:        10px 20px 10px 14px;
    border-radius:  var(--sim-pub-radius-sm, 40px);
    border:         2px solid color-mix(in srgb, var(--sim-pub-button, #3a8686) 60%, white);
    font-size:      13.5px;
    font-weight:    600;
    white-space:    nowrap;
    pointer-events: none;
    opacity:        0;
    box-shadow:     0 8px 32px rgba(0,0,0,0.2);
    transition:     top 0.32s cubic-bezier(0.34,1.56,0.64,1), opacity 0.22s ease;
}
.sim-list-toast-icon {
    font-size:  16px;
    color:      var(--sim-pub-button-text, #ffffff);
    opacity:    0.85;
}

/* ================================================================
   ELEMENTOR OVERRIDE — Dashboard action buttons
   Elementor biasa override 'a', 'button', '.elementor-widget a'
   Selector ini memastikan CSS kita menang
   ================================================================ */
.elementor .sim-ios-container .action-btn-ios,
.elementor .sim-ios-container .action-btn-ios:link,
.elementor .sim-ios-container .action-btn-ios:visited,
.elementor .sim-ios-container a.action-btn-ios,
.elementor .sim-ios-container button.action-btn-ios {
    text-decoration: none !important;
    box-shadow:      none !important;
}
.elementor .sim-ios-container .action-btn-ios.btn-primary,
.elementor .sim-ios-container a.action-btn-ios.btn-primary,
.elementor .sim-ios-container button.action-btn-ios.btn-primary {
    background:    var(--sim-pub-button, #3a8686) !important;
    color:         var(--sim-pub-button-text, #ffffff) !important;
    border-color:  var(--sim-pub-button, #3a8686) !important;
    border-radius: var(--sim-pub-radius-sm, 12px) !important;
}
.elementor .sim-ios-container .action-btn-ios.btn-secondary,
.elementor .sim-ios-container a.action-btn-ios.btn-secondary,
.elementor .sim-ios-container button.action-btn-ios.btn-secondary {
    background:    color-mix(in srgb, var(--sim-pub-primary, #3a8686) 10%, white) !important;
    color:         var(--sim-pub-primary, #3a8686) !important;
    border-color:  color-mix(in srgb, var(--sim-pub-primary, #3a8686) 25%, transparent) !important;
    border-radius: var(--sim-pub-radius-sm, 12px) !important;
}
.elementor .sim-ios-trx-container .btn-confirm-lunas {
    background:    var(--sim-pub-button, #3a8686) !important;
    color:         var(--sim-pub-button-text, #ffffff) !important;
    border-color:  var(--sim-pub-button, #3a8686) !important;
    border-radius: var(--sim-pub-radius-sm, 12px) !important;
}
.elementor .sim-ios-trx-container .admin-badge-mode {
    background:    var(--sim-pub-button, #3a8686) !important;
    color:         var(--sim-pub-button-text, #ffffff) !important;
    border-radius: var(--sim-pub-radius-sm, 30px) !important;
}
.elementor .sim-ios-container .sim-paging-btn.active,
.elementor .sim-paging-controls .sim-paging-btn.active {
    background:   var(--sim-pub-button, #3a8686) !important;
    color:        var(--sim-pub-button-text, #ffffff) !important;
    border-color: var(--sim-pub-button, #3a8686) !important;
}
.elementor .sim-ios-header .sim-ios-save,
.elementor button.sim-ios-save {
    background:    var(--sim-pub-button, #3a8686) !important;
    color:         var(--sim-pub-button-text, #ffffff) !important;
    border-color:  var(--sim-pub-button, #3a8686) !important;
    border-radius: var(--sim-pub-radius-sm, 30px) !important;
}

/* ================================================================
   § 30. LIST TAMU — Scoped modal buttons + close icon override Elementor
   Semua selector pakai ID modal spesifik + class baru agar menang
   ================================================================ */

/* Close button iOS — semua modal list tamu */
#sim-listtamu-modal-tamu   .sim-lt-close-btn,
#sim-listtamu-modal-wa     .sim-lt-close-btn,
#sim-listtamu-modal-copy   .sim-lt-close-btn,
#sim-listtamu-modal-import .sim-lt-close-btn {
    background:    #f0f3f3 !important;
    border:        none !important;
    width:         32px !important;
    height:        32px !important;
    border-radius: 50% !important;
    cursor:        pointer !important;
    color:         #8fa7ab !important;
    display:       flex !important;
    align-items:   center !important;
    justify-content: center !important;
    font-size:     18px !important;
    line-height:   1 !important;
    flex-shrink:   0 !important;
    padding:       0 !important;
    transition:    background 0.2s, color 0.2s !important;
    box-shadow:    none !important;
    text-decoration: none !important;
}
#sim-listtamu-modal-tamu   .sim-lt-close-btn:hover,
#sim-listtamu-modal-wa     .sim-lt-close-btn:hover,
#sim-listtamu-modal-copy   .sim-lt-close-btn:hover,
#sim-listtamu-modal-import .sim-lt-close-btn:hover {
    background: #ff6b6b !important;
    color:      #fff !important;
}

/* Tombol Batal — ghost border, ikut CSS vars */
#sim-listtamu-modal-tamu   .sim-lt-btn-cancel,
#sim-listtamu-modal-wa     .sim-lt-btn-cancel,
#sim-listtamu-modal-copy   .sim-lt-btn-cancel,
#sim-listtamu-modal-import .sim-lt-btn-cancel {
    background:    transparent !important;
    border:        2px solid color-mix(in srgb, var(--sim-pub-primary, #3a8686) 30%, transparent) !important;
    color:         var(--sim-pub-text-muted, #8fa7ab) !important;
    padding:       10px 22px !important;
    border-radius: var(--sim-pub-radius-sm, 30px) !important;
    font-size:     14px !important;
    font-weight:   600 !important;
    cursor:        pointer !important;
    transition:    all 0.2s !important;
    box-shadow:    none !important;
    text-decoration: none !important;
}
#sim-listtamu-modal-tamu   .sim-lt-btn-cancel:hover,
#sim-listtamu-modal-wa     .sim-lt-btn-cancel:hover,
#sim-listtamu-modal-copy   .sim-lt-btn-cancel:hover,
#sim-listtamu-modal-import .sim-lt-btn-cancel:hover {
    background:   color-mix(in srgb, var(--sim-pub-primary, #3a8686) 8%, white) !important;
    border-color: var(--sim-pub-primary, #3a8686) !important;
}

/* Tombol Primer (Simpan/Import/Copy) — ikut CSS vars sepenuhnya */
#sim-listtamu-modal-tamu   .sim-lt-btn-primary,
#sim-listtamu-modal-wa     .sim-lt-btn-primary,
#sim-listtamu-modal-copy   .sim-lt-btn-primary,
#sim-listtamu-modal-import .sim-lt-btn-primary {
    background:    var(--sim-pub-button, #3a8686) !important;
    color:         var(--sim-pub-button-text, #ffffff) !important;
    border:        2px solid var(--sim-pub-button, #3a8686) !important;
    padding:       10px 22px !important;
    border-radius: var(--sim-pub-radius-sm, 30px) !important;
    font-size:     14px !important;
    font-weight:   700 !important;
    cursor:        pointer !important;
    transition:    all 0.2s !important;
    display:       inline-flex !important;
    align-items:   center !important;
    gap:           7px !important;
    box-shadow:    none !important;
    text-decoration: none !important;
}
#sim-listtamu-modal-tamu   .sim-lt-btn-primary:hover,
#sim-listtamu-modal-wa     .sim-lt-btn-primary:hover,
#sim-listtamu-modal-copy   .sim-lt-btn-primary:hover,
#sim-listtamu-modal-import .sim-lt-btn-primary:hover {
    background:   var(--sim-pub-primary-dark, #1a535c) !important;
    border-color: var(--sim-pub-primary-dark, #1a535c) !important;
    transform:    translateY(-1px) !important;
}

/* Footer layout: flex, rata kanan */
#sim-listtamu-modal-tamu   .sim-lt-modal-footer,
#sim-listtamu-modal-wa     .sim-lt-modal-footer,
#sim-listtamu-modal-copy   .sim-lt-modal-footer,
#sim-listtamu-modal-import .sim-lt-modal-footer {
    display:         flex !important;
    justify-content: flex-end !important;
    align-items:     center !important;
    gap:             12px !important;
    padding:         15px 25px !important;
    background:      color-mix(in srgb, var(--sim-pub-bg, #f4f7f7) 60%, white) !important;
    border-top:      1px solid color-mix(in srgb, var(--sim-pub-primary, #3a8686) 12%, transparent) !important;
}

/* Contact picker button — iOS action button style */
#sim-btn-select-contact {
    background:    var(--sim-pub-button, #3a8686) !important;
    color:         var(--sim-pub-button-text, #ffffff) !important;
    border:        none !important;
    border-radius: var(--sim-pub-radius-sm, 30px) !important;
    padding:       0 14px !important;
    height:        44px !important;
    display:       inline-flex !important;
    align-items:   center !important;
    justify-content: center !important;
    gap:           5px !important;
    cursor:        pointer !important;
    font-size:     13px !important;
    font-weight:   600 !important;
    transition:    0.2s !important;
    flex-shrink:   0 !important;
}
#sim-btn-select-contact:hover {
    background: var(--sim-pub-primary-dark, #1a535c) !important;
}
