/* Ruang Karya – Soft Editorial White Theme (Eye-Friendly) */
:root {
    /* Base colors */
    --bg-main: #F7F7F5;
    /* off-white, like book paper */
    --bg-card: #FFFFFF;
    /* surface */
    --ink-main: #1F1F1F;
    /* soft black for text */
    --ink-muted: #5F5F5F;
    /* secondary text */
    --ink-accent: #2A2A2A;
    /* buttons / emphasis */

    --border-soft: #D8D8D2;
    --shadow-soft: 0 8px 22px rgba(0, 0, 0, .08);

    --radius: 16px;
}

/* Global */
html,
body {
    background: var(--bg-main);
    color: var(--ink-main);
}

.bg-paper {
    background: var(--bg-main) !important;
}

.text-ink {
    color: var(--ink-main) !important;
}

.text-muted-2 {
    color: var(--ink-muted) !important;
}

.border-ink-subtle {
    border-color: var(--border-soft) !important;
}

.link-plain {
    color: var(--ink-main);
    text-decoration: none;
}

.link-plain:hover {
    text-decoration: underline;
}

/* Navbar & Topbar */
.navbar,
.topbar {
    background: var(--bg-main) !important;
}

/* Brand */
.brand-mark {
    width: 38px;
    height: 38px;
    border: 1px solid var(--ink-accent);
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    letter-spacing: .5px;
    background: var(--bg-card);
    color: var(--ink-accent);
}

/* Buttons */
.btn-ink {
    --bs-btn-color: #FFFFFF;
    --bs-btn-bg: var(--ink-accent);
    --bs-btn-border-color: var(--ink-accent);
    --bs-btn-hover-bg: #1A1A1A;
    --bs-btn-hover-border-color: #1A1A1A;
}

.btn-outline-ink {
    --bs-btn-color: var(--ink-accent);
    --bs-btn-bg: transparent;
    --bs-btn-border-color: var(--ink-accent);
    --bs-btn-hover-color: #FFFFFF;
    --bs-btn-hover-bg: var(--ink-accent);
}

/* Badges */
.badge-outline {
    border: 1px solid var(--ink-accent);
    color: var(--ink-accent);
    background: transparent;
    border-radius: 999px;
    font-weight: 600;
}

.badge-ink {
    background: var(--ink-accent);
    color: #FFFFFF;
    border-radius: 999px;
    font-weight: 600;
}

/* Cards */
.card-paper {
    background: var(--bg-card);
    border-radius: var(--radius);
    border: 1px solid var(--border-soft);
    box-shadow: none;
}

.card-featured {
    border: 1px solid var(--ink-accent) !important;
    box-shadow: var(--shadow-soft);
}

/* Kicker */
.kicker {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    border: 1px solid var(--border-soft);
    padding: .35rem .6rem;
    border-radius: 999px;
    color: var(--ink-muted);
    font-size: .9rem;
}

/* Icon Pill */
.icon-pill {
    width: 44px;
    height: 44px;
    border: 1px solid var(--border-soft);
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--ink-accent);
    background: var(--bg-card);
}

/* Steps */
.step-num {
    width: 40px;
    height: 40px;
    border: 1px solid var(--border-soft);
    border-radius: 12px;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--ink-accent);
    background: var(--bg-card);
}

/* Alerts */
.alert-paper {
    background: var(--bg-card);
    border: 1px solid var(--border-soft);
    border-radius: var(--radius);
    color: var(--ink-main);
}

/* Lists */
.list-plain {
    list-style: none;
    padding-left: 0;
}

.list-plain li {
    display: flex;
    gap: .5rem;
    padding: .35rem 0;
    color: var(--ink-muted);
}

.list-plain i {
    color: var(--ink-accent);
}

/* Accordion */
.accordion-ink .accordion-item {
    background: var(--bg-card);
    border: 1px solid var(--border-soft);
    border-radius: var(--radius);
    margin-bottom: .75rem;
}

.accordion-ink .accordion-button {
    background: var(--bg-card);
    color: var(--ink-main);
}

.accordion-ink .accordion-button:not(.collapsed) {
    background: var(--bg-card);
}

/* Table */
.table-accounts thead th {
    color: var(--ink-main);
    font-weight: 700;
}

.table-accounts tbody td {
    color: var(--ink-muted);
}

.mono {
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}

/* Mock phone */
.mock-phone {
    border: 1px solid var(--border-soft);
    border-radius: 22px;
    background: var(--bg-card);
}

.mock-line,
.mock-tile {
    border: 1px solid var(--border-soft);
}

/* WhatsApp Floating Button */
.wa-float {
    position: fixed;
    right: 18px;
    bottom: 18px;
    width: 54px;
    height: 54px;
    border-radius: 16px;
    background: var(--ink-accent);
    color: #FFFFFF;
    border: none;
    box-shadow: var(--shadow-soft);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
}

.wa-float:hover {
    background: #1A1A1A;
}