:root {
    --primary: #1457d9;
    --primary-2: #0ea5e9;
    --primary-dark: #0a2472;
    --navy: #071b3b;
    --navy-2: #0b2a55;
    --bg: #f5f8fc;
    --surface: #ffffff;
    --surface-soft: #f8fbff;
    --text: #121a2f;
    --muted: #667085;
    --border: #e6ecf5;
    --shadow: 0 18px 55px rgba(15, 47, 99, .10);
    --shadow-soft: 0 10px 30px rgba(15, 79, 179, .07);
    --danger: #dc2626;
    --success: #15803d;
    --warning: #ea580c;
    --radius-lg: 26px;
    --radius-md: 18px;
    --radius-sm: 12px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    min-height: 100vh;
    font-family: Inter, "Segoe UI", Roboto, Arial, sans-serif;
    background:
        radial-gradient(circle at top left, rgba(20, 87, 217, .12), transparent 34%),
        linear-gradient(180deg, #f8fbff 0%, #eef4fb 100%);
    color: var(--text);
}
a { color: var(--primary); text-decoration: none; }
a:hover { color: var(--primary-dark); }

.app-shell { display: flex; min-height: 100vh; }
.sidebar {
    width: 292px;
    background:
        radial-gradient(circle at top left, rgba(14, 165, 233, .32), transparent 30%),
        linear-gradient(180deg, #081a3a 0%, #07142c 100%);
    color: #fff;
    padding: 24px 20px;
    display: flex;
    flex-direction: column;
    position: sticky;
    top: 0;
    height: 100vh;
    box-shadow: 18px 0 55px rgba(8, 24, 57, .18);
    z-index: 20;
}
.brand { display: flex; align-items: center; gap: 12px; padding: 6px 8px 22px; border-bottom: 1px solid rgba(255,255,255,.12); }
.brand-mark {
    width: 48px;
    height: 48px;
    background: linear-gradient(135deg, #2f80ff 0%, #0ea5e9 100%);
    color: #fff;
    border-radius: 17px;
    display: grid;
    place-items: center;
    font-weight: 900;
    letter-spacing: -.03em;
    box-shadow: 0 12px 30px rgba(14, 165, 233, .35);
}
.brand strong { display: block; font-size: 18px; line-height: 1.1; }
.brand small { color: #b6c7e8; display: block; margin-top: 4px; }
.menu { margin-top: 24px; display: grid; gap: 7px; }
.menu a {
    color: #dce8ff;
    padding: 12px 14px;
    border-radius: 15px;
    display: flex;
    align-items: center;
    gap: 11px;
    font-weight: 700;
    letter-spacing: -.01em;
    transition: .18s ease;
}
.menu a:hover, .menu a.active {
    background: rgba(255,255,255,.12);
    color: #fff;
    transform: translateX(3px);
}
.menu-icon { width: 26px; height: 26px; display: grid; place-items: center; border-radius: 9px; background: rgba(255,255,255,.10); }
.sidebar-user {
    margin-top: auto;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.08);
    border-radius: 20px;
    padding: 15px;
    display: grid;
    gap: 4px;
}
.sidebar-user small { color: #b6c7e8; }
.logout { margin-top: 8px; color: #ffd0d0; font-weight: 800; }

.main { flex: 1; padding: 30px; min-width: 0; }
.topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 22px;
}
.page-kicker {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 7px 11px;
    border-radius: 999px;
    background: #eaf2ff;
    color: var(--primary-dark);
    font-size: 12px;
    font-weight: 900;
    margin-bottom: 10px;
}
.topbar h1 { margin: 0; font-size: clamp(24px, 2.4vw, 34px); color: var(--primary-dark); letter-spacing: -.04em; }
.topbar p { margin: 7px 0 0; color: var(--muted); }
.top-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }

.card {
    background: rgba(255,255,255,.92);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 24px;
    box-shadow: var(--shadow-soft);
    margin-bottom: 22px;
    backdrop-filter: blur(12px);
}
.card:hover { box-shadow: var(--shadow); }
.card-header { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 18px; }
.card-header h2, .card h2 { margin: 0; color: var(--primary-dark); letter-spacing: -.03em; }
.card h3 { color: #1f2a44; margin-bottom: 10px; }
.card-header p { margin: 6px 0 0; color: var(--muted); }
.narrow-card { max-width: 1050px; }
.section-title { display:flex; align-items:center; gap:10px; }
.section-icon { width: 38px; height: 38px; display:grid; place-items:center; border-radius: 14px; background: #eef5ff; color: var(--primary); }

.btn {
    border: 1px solid var(--border);
    background: #fff;
    color: var(--primary-dark);
    padding: 10px 15px;
    border-radius: 13px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-weight: 800;
    font-size: 14px;
    box-shadow: 0 8px 18px rgba(15, 47, 99, .04);
    transition: .18s ease;
}
.btn:hover { border-color: #bcd4ff; transform: translateY(-1px); box-shadow: 0 12px 24px rgba(15, 47, 99, .08); }
.btn-primary { background: linear-gradient(135deg, var(--primary), #0ea5e9); border-color: transparent; color: #fff; }
.btn-success { background: linear-gradient(135deg, #16a34a, #22c55e); border-color: transparent; color: #fff; }
.btn-danger { background: linear-gradient(135deg, #dc2626, #f97316); border-color: transparent; color: #fff; }
.btn-small { padding: 7px 10px; font-size: 12px; border-radius: 10px; }
.btn-block { width: 100%; }

.alert { padding: 13px 16px; border-radius: 16px; margin-bottom: 18px; font-weight: 800; border: 1px solid transparent; }
.alert.success { background: #dcfce7; color: #166534; border-color: #bbf7d0; }
.alert.error { background: #fee2e2; color: #991b1b; border-color: #fecaca; }

.hero-card {
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at top right, rgba(14,165,233,.24), transparent 34%),
        linear-gradient(135deg, #ffffff 0%, #edf5ff 100%);
    border: 1px solid #dfeaff;
    border-radius: 30px;
    padding: 28px;
    margin-bottom: 22px;
    box-shadow: var(--shadow-soft);
}
.hero-card:after {
    content: "";
    position: absolute;
    right: -70px;
    top: -90px;
    width: 260px;
    height: 260px;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(20,87,217,.18), rgba(14,165,233,.10));
}
.hero-content { position: relative; z-index: 1; display:flex; justify-content:space-between; gap:20px; align-items:center; }
.hero-title { margin: 0; font-size: clamp(24px, 3vw, 38px); color: var(--primary-dark); letter-spacing: -.05em; }
.hero-desc { color: var(--muted); max-width: 720px; line-height: 1.7; margin: 10px 0 0; }
.hero-badges { display:flex; gap:9px; flex-wrap: wrap; margin-top: 16px; }

.stats-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 16px; margin-bottom: 22px; }
.stat-card {
    position: relative;
    overflow: hidden;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 23px;
    padding: 20px;
    box-shadow: var(--shadow-soft);
}
.stat-card:before { content:""; position:absolute; top:0; left:0; right:0; height:4px; background: linear-gradient(90deg, var(--primary), var(--primary-2)); }
.stat-card .stat-icon { width: 42px; height: 42px; display:grid; place-items:center; border-radius: 16px; background: #eef5ff; margin-bottom: 12px; }
.stat-card span { color: var(--muted); display: block; margin-bottom: 8px; font-weight: 750; }
.stat-card strong { font-size: 30px; color: var(--primary-dark); letter-spacing: -.04em; word-break: break-word; }

.flow-strip {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 12px;
    margin-bottom: 22px;
}
.flow-step {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 20px;
    padding: 15px;
    min-height: 112px;
    box-shadow: 0 8px 22px rgba(15,47,99,.05);
}
.flow-step b { display:block; color: var(--primary-dark); margin-bottom:6px; }
.flow-step small { color: var(--muted); line-height: 1.5; }
.flow-number { width: 26px; height:26px; display:grid; place-items:center; border-radius:999px; background: #eaf2ff; color: var(--primary); font-weight:900; margin-bottom:8px; }

.table-responsive { overflow-x: auto; border-radius: 18px; border: 1px solid var(--border); }
table { width: 100%; border-collapse: separate; border-spacing: 0; background: #fff; }
th { text-align: left; font-size: 12px; color: #667085; background: #f8fbff; text-transform: uppercase; letter-spacing: .04em; }
th, td { padding: 14px 13px; border-bottom: 1px solid var(--border); vertical-align: top; }
tbody tr:last-child td { border-bottom: none; }
tr:hover td { background: #fbfdff; }
.text-center { text-align: center; }
.muted { color: var(--muted); }
.badge { display: inline-flex; align-items:center; gap:6px; padding: 6px 11px; border-radius: 999px; font-size: 12px; font-weight: 900; white-space: nowrap; }
.badge-blue { background: #dbeafe; color: #1d4ed8; }
.badge-indigo { background: #e0e7ff; color: #3730a3; }
.badge-orange { background: #ffedd5; color: #c2410c; }
.badge-purple { background: #f3e8ff; color: #7e22ce; }
.badge-green { background: #dcfce7; color: #15803d; }
.badge-teal { background: #ccfbf1; color: #0f766e; }
.badge-yellow { background: #fef3c7; color: #a16207; }
.badge-red { background: #fee2e2; color: #b91c1c; }
.badge-gray { background: #f3f4f6; color: #374151; }

.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.form-stack { display: grid; gap: 11px; }
.form-group { display: grid; gap: 8px; }
.span-2 { grid-column: span 2; }
label { font-weight: 850; color: #344054; font-size: 14px; }
input, select, textarea {
    width: 100%;
    border: 1px solid #dfe7f2;
    border-radius: 14px;
    padding: 12px 13px;
    font: inherit;
    background: #fff;
    color: var(--text);
    outline: none;
    transition: .16s ease;
}
input:focus, select:focus, textarea:focus { border-color: #9cc0ff; box-shadow: 0 0 0 4px rgba(20, 87, 217, .10); }
textarea { resize: vertical; }
.form-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 8px; }
.filter-row { display: flex; gap: 10px; margin-bottom: 16px; flex-wrap: wrap; }
.filter-row select { max-width: 260px; }

.detail-grid { display: grid; grid-template-columns: minmax(0, 1fr) 370px; gap: 22px; align-items:start; }
.info-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; margin: 14px 0 20px; }
.info-grid div { background: #f8fbff; border: 1px solid var(--border); border-radius: 16px; padding: 13px; }
.info-grid small { color: var(--muted); display: block; font-weight: 700; }
.info-grid strong { display: block; margin-top: 5px; color: #16213a; }
.preline { white-space: pre-line; line-height: 1.7; }
.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.timeline { display: grid; gap: 13px; }
.timeline-item { position: relative; border-left: 3px solid var(--primary); padding: 4px 0 4px 14px; }
.timeline-item:before { content:""; position:absolute; width:11px; height:11px; border-radius:50%; background: var(--primary); left:-7px; top:8px; box-shadow:0 0 0 4px #eaf2ff; }
.timeline-item small { display: block; color: var(--muted); margin-top: 3px; }
.review-box { border: 1px solid var(--border); border-radius: 17px; padding: 15px; margin-top: 12px; background: #fbfdff; }
.inline-form { display: inline-flex; margin: 2px; }
.action-cell { min-width: 340px; }

.auth-body {
    min-height: 100vh;
    display: grid;
    place-items: center;
    background:
        radial-gradient(circle at 20% 10%, rgba(20,87,217,.24), transparent 28%),
        radial-gradient(circle at 80% 20%, rgba(14,165,233,.20), transparent 30%),
        linear-gradient(135deg, #f8fbff 0%, #eef4ff 100%);
    padding: 24px;
}
.auth-card {
    width: min(1040px, 100%);
    min-height: 560px;
    background: rgba(255,255,255,.92);
    border: 1px solid #dfe9f8;
    border-radius: 34px;
    overflow: hidden;
    box-shadow: 0 30px 90px rgba(8,43,104,.18);
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    backdrop-filter: blur(18px);
}
.login-panel {
    background:
        radial-gradient(circle at top right, rgba(14,165,233,.34), transparent 30%),
        linear-gradient(160deg, #081a3a 0%, #0a2b64 100%);
    color: #fff;
    padding: 44px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
.login-panel h1 { font-size: clamp(30px, 4vw, 48px); line-height: 1.02; margin: 20px 0 14px; letter-spacing: -.06em; }
.login-panel p { color: #c9d9f4; line-height: 1.7; }
.login-flow { display:grid; grid-template-columns:repeat(2,1fr); gap:10px; margin-top:22px; }
.login-flow span { background:rgba(255,255,255,.10); border:1px solid rgba(255,255,255,.13); padding:11px; border-radius:14px; font-weight:800; color:#eaf3ff; }
.login-form-panel { padding: 44px; display:flex; flex-direction:column; justify-content:center; }
.login-brand { margin-bottom: 22px; }
.login-note { margin-top: 16px; color: var(--muted); background: #f8fbff; border-radius: 14px; padding: 13px; border: 1px solid var(--border); }
.empty-state { text-align: center; padding: 50px; }

.print-body { background: #e5e7eb; padding: 24px; }
.print-actions { max-width: 900px; margin: 0 auto 12px; display: flex; gap: 8px; justify-content: flex-end; }
.document-page { background: white; max-width: 900px; margin: 0 auto; padding: 48px; min-height: 1120px; color: #111827; }
.doc-header { display: flex; justify-content: space-between; border-bottom: 3px solid var(--primary-dark); padding-bottom: 16px; margin-bottom: 28px; }
.doc-header h1 { margin: 0; color: var(--primary-dark); }
.doc-company { font-weight: 900; color: var(--primary-dark); }
.doc-meta { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-bottom: 24px; }
.doc-table th, .doc-table td { border: 1px solid #d1d5db; }
.doc-table tfoot th { background: #f3f4f6; }
.payment-box { border: 1px solid #d1d5db; border-radius: 12px; padding: 14px; margin-top: 24px; background: #f9fafb; }
.signature-block { display: grid; grid-template-columns: 1fr 290px; margin-top: 56px; text-align: center; page-break-inside: avoid; }
.signature-box { min-height: 150px; }
.signature-date { margin: 0 0 8px; font-weight: 600; }
.signature-role { margin: 0; color: #374151; }
.signature-space { height: 78px; }
.signature-name { margin: 0; border-top: 1px solid #111827; padding-top: 6px; display: inline-block; min-width: 220px; }

@media print {
    .no-print { display: none !important; }
    .print-body { background: #fff; padding: 0; }
    .document-page { box-shadow: none; max-width: none; padding: 24px; }
}
@media (max-width: 1180px) {
    .stats-grid, .flow-strip { grid-template-columns: repeat(2, 1fr); }
    .detail-grid, .two-col { grid-template-columns: 1fr; }
    .side-panel { order: -1; }
    .hero-content { display:block; }
}
@media (max-width: 820px) {
    .app-shell { display: block; }
    .sidebar { width: 100%; height: auto; position: relative; }
    .main { padding: 18px; }
    .topbar { display: grid; }
    .form-grid, .info-grid, .stats-grid, .flow-strip { grid-template-columns: 1fr; }
    .span-2 { grid-column: span 1; }
    .auth-card { grid-template-columns: 1fr; }
    .login-panel { padding: 28px; }
    .login-form-panel { padding: 28px; }
    .login-flow { grid-template-columns:1fr; }
}

/* Company settings update */
.brand-mark-logo {
    background: #fff;
    padding: 6px;
}
.brand-mark-logo img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    border-radius: 12px;
}
.settings-layout {
    display: grid;
    grid-template-columns: 300px minmax(0, 1fr);
    gap: 22px;
    align-items: start;
}
.settings-logo-card {
    border: 1px solid var(--border);
    background: #f8fbff;
    border-radius: 22px;
    padding: 18px;
    display: grid;
    gap: 12px;
}
.logo-preview-box {
    height: 180px;
    border: 1px dashed #bcd4ff;
    border-radius: 20px;
    display: grid;
    place-items: center;
    background: #fff;
    overflow: hidden;
}
.logo-preview-box img {
    max-width: 82%;
    max-height: 82%;
    object-fit: contain;
}
.logo-placeholder {
    width: 86px;
    height: 86px;
    border-radius: 28px;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, var(--primary), var(--primary-2));
    color: #fff;
    font-size: 30px;
    font-weight: 900;
    box-shadow: 0 14px 34px rgba(20, 87, 217, .23);
}
.company-preview {
    display: flex;
    gap: 14px;
    align-items: center;
    border: 1px solid var(--border);
    border-radius: 20px;
    background: #f8fbff;
    padding: 16px;
}
.company-preview strong,
.company-preview small {
    display: block;
}
.company-preview strong {
    color: var(--primary-dark);
    font-size: 18px;
}
.brand-mark-light {
    background: #fff;
    color: var(--primary-dark);
    border: 1px solid var(--border);
    box-shadow: 0 8px 20px rgba(15, 47, 99, .07);
}
.brand-mark-light img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    border-radius: 12px;
}
.doc-header-modern {
    align-items: flex-start;
    gap: 20px;
}
.doc-brand {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    max-width: 560px;
}
.doc-brand strong,
.doc-brand small {
    display: block;
}
.doc-brand strong {
    color: var(--primary-dark);
    font-size: 18px;
    line-height: 1.2;
}
.doc-brand small {
    color: #4b5563;
    line-height: 1.45;
    margin-top: 3px;
}
.doc-logo {
    width: 70px;
    height: 70px;
    border-radius: 18px;
    display: grid;
    place-items: center;
    background: #eef5ff;
    border: 1px solid #dbeafe;
    color: var(--primary-dark);
    font-weight: 900;
    flex: 0 0 auto;
    overflow: hidden;
}
.doc-logo img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 7px;
    background: #fff;
}
.doc-title-box {
    text-align: right;
}
.doc-title-box h1 {
    margin: 0;
    color: var(--primary-dark);
}
.doc-title-box p {
    margin: 6px 0 0;
    font-weight: 800;
    color: #344054;
}

@media (max-width: 900px) {
    .settings-layout {
        grid-template-columns: 1fr;
    }
    .doc-header-modern,
    .doc-brand {
        display: block;
    }
    .doc-title-box {
        text-align: left;
        margin-top: 14px;
    }
    .doc-logo {
        margin-bottom: 10px;
    }
}

/* Update 003 - Master Rekening Pembayaran */
.info-box {
    border: 1px solid #dbeafe;
    background: #eff6ff;
    color: #1e3a8a;
    border-radius: 16px;
    padding: 13px 16px;
    margin-bottom: 16px;
    line-height: 1.6;
}
.actions-cell {
    min-width: 260px;
}
.checkbox-group {
    align-content: start;
}
.checkbox-label {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-weight: 850;
}
.checkbox-label input[type="checkbox"] {
    width: 18px;
    height: 18px;
}


/* Update 005 - Pisah Logo Brand Aplikasi dan Logo Perusahaan/KOP */
.settings-layout-wide {
    grid-template-columns: 640px minmax(0, 1fr);
}
.settings-logo-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}
.logo-placeholder-kop {
    background: linear-gradient(135deg, #1f2937, #64748b);
}
.preview-grid-two {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
@media (max-width: 1180px) {
    .settings-layout-wide {
        grid-template-columns: 1fr;
    }
}
@media (max-width: 760px) {
    .settings-logo-grid,
    .preview-grid-two {
        grid-template-columns: 1fr;
    }
}
