/* =============================================================
   VIP DESIGN LAYER — premium gold/cream/black tone
   Consumed by all "trust mechanism" pages (staff, partner, hr, sales).
   Mobile-first responsive; tables become stacked cards under 700px.
   ============================================================= */

:root {
    --vip-gold-50:  #FBF6E7;
    --vip-gold-100: #F4E9C3;
    --vip-gold-200: #E9D58D;
    --vip-gold-300: #D9BB57;
    --vip-gold-400: #C9A84C;
    --vip-gold-500: #B69136;
    --vip-gold-600: #9B7A24;
    --vip-gold-700: #7A5F1A;

    --vip-ink:        #15110A;
    --vip-ink-soft:   #2B2419;
    --vip-paper:      #FBFAF6;
    --vip-paper-2:    #F4F1E7;
    --vip-line:       rgba(21, 17, 10, 0.08);
    --vip-line-strong:rgba(21, 17, 10, 0.16);

    --vip-shadow-sm: 0 1px 2px rgba(21,17,10,0.04), 0 0 0 1px var(--vip-line);
    --vip-shadow-md: 0 6px 20px rgba(21,17,10,0.06), 0 0 0 1px var(--vip-line);
    --vip-shadow-lg: 0 18px 60px rgba(21,17,10,0.10), 0 0 0 1px var(--vip-line);

    --vip-radius:    14px;
    --vip-radius-sm: 10px;
    --vip-radius-lg: 22px;

    --vip-serif: 'Playfair Display', 'Cormorant Garamond', Georgia, serif;
}

/* ---------- ANIMATIONS ---------- */
@keyframes vip-rise {
    from { opacity: 0; transform: translateY(14px); }
    to   { opacity: 1; transform: translateY(0); }
}
@keyframes vip-fade {
    from { opacity: 0; }
    to   { opacity: 1; }
}
@keyframes vip-shine {
    0%   { background-position: -200% 0; }
    100% { background-position: 200% 0; }
}
@keyframes vip-pulse {
    0%, 100% { transform: scale(1); }
    50%      { transform: scale(1.03); }
}

/* page enter — apply via class on a wrapper.
   `backwards` (not `both`) so the final `transform: translateY(0)` is NOT retained after
   the animation completes — keeping a non-none transform on these elements creates a
   containing block that traps `position: fixed` modal backdrops inside, breaking modals
   like Quick Add Client / Add Current-Year Sale. */
.vip-page > * {
    animation: vip-rise 480ms cubic-bezier(.2,.9,.2,1) backwards;
}
.vip-page > *:nth-child(1) { animation-delay: 0ms; }
.vip-page > *:nth-child(2) { animation-delay: 60ms; }
.vip-page > *:nth-child(3) { animation-delay: 120ms; }
.vip-page > *:nth-child(4) { animation-delay: 180ms; }
.vip-page > *:nth-child(5) { animation-delay: 240ms; }
.vip-page > *:nth-child(6) { animation-delay: 300ms; }
.vip-page > *:nth-child(7) { animation-delay: 360ms; }
.vip-page > *:nth-child(n+8) { animation-delay: 420ms; }
/* Modals & fixed-position overlays must not inherit the page rise animation, otherwise
   `animation-fill-mode: both` leaves their opacity at 1 and the dark backdrop blocks
   the page on first paint. */
.vip-page > .modal-backdrop,
.vip-page > .vip-modal-backdrop,
.vip-page > [data-modal],
.vip-page > .vip-palette-backdrop { animation: none; }

@media (prefers-reduced-motion: reduce) {
    .vip-page > * { animation: vip-fade 200ms both; }
}

/* logo anim */
.vip-logo {
    display: inline-flex; align-items: center; gap: 10px;
    font-family: var(--vip-serif); font-weight: 700;
    color: var(--vip-ink); letter-spacing: 0.04em;
}
.vip-logo img {
    width: 36px; height: 36px;
    filter: drop-shadow(0 2px 4px rgba(201,168,76,0.35));
    animation: vip-pulse 4s ease-in-out infinite;
}
.vip-logo .crest {
    background: linear-gradient(120deg, var(--vip-gold-700) 0%, var(--vip-gold-400) 40%, var(--vip-gold-700) 80%);
    background-size: 200% 100%;
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent;
    animation: vip-shine 5.5s linear infinite;
}

/* ---------- HERO HEADER ---------- */
.vip-hero {
    background: radial-gradient(ellipse 600px 220px at 20% -20%, var(--vip-gold-100) 0%, transparent 70%),
                linear-gradient(180deg, var(--vip-paper) 0%, var(--vip-paper-2) 100%);
    border-radius: var(--vip-radius-lg);
    padding: 28px 32px;
    margin-bottom: 18px;
    position: relative; overflow: hidden;
    box-shadow: var(--vip-shadow-md);
}
.vip-hero::before {
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(120deg, transparent 30%, rgba(201,168,76,0.05) 50%, transparent 70%);
    background-size: 200% 100%;
    animation: vip-shine 8s linear infinite;
    pointer-events: none;
}
.vip-hero h1 {
    font-family: var(--vip-serif); font-weight: 600;
    font-size: 28px; line-height: 1.2;
    color: var(--vip-ink); letter-spacing: -0.01em;
    margin: 0;
}
.vip-hero .vip-subtitle {
    color: var(--vip-ink-soft); margin-top: 6px; font-size: 14px;
}

/* ---------- KPI CARDS ---------- */
.vip-kpi-row {
    display: grid; gap: 14px;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    margin-top: 18px;
}
.vip-kpi {
    background: var(--vip-paper);
    border-radius: var(--vip-radius);
    padding: 18px 20px;
    box-shadow: var(--vip-shadow-sm);
    transition: transform .25s, box-shadow .25s;
    position: relative; overflow: hidden;
}
.vip-kpi:hover {
    transform: translateY(-2px);
    box-shadow: var(--vip-shadow-md);
}
.vip-kpi::after {
    content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
    background: linear-gradient(180deg, var(--vip-gold-300) 0%, var(--vip-gold-500) 100%);
    opacity: 0.7;
}
.vip-kpi-label {
    font-size: 11px; font-weight: 600; letter-spacing: 0.08em;
    text-transform: uppercase; color: var(--vip-gold-700);
}
.vip-kpi-value {
    font-family: var(--vip-serif);
    font-size: 28px; font-weight: 700;
    color: var(--vip-ink); margin-top: 6px; line-height: 1.1;
    word-break: break-all;
}
.vip-kpi-sub { font-size: 12px; color: var(--vip-ink-soft); margin-top: 4px; }

/* ---------- CARD / SECTION ---------- */
.vip-card {
    background: var(--vip-paper);
    border-radius: var(--vip-radius);
    box-shadow: var(--vip-shadow-sm);
    margin-top: 18px;
    overflow: hidden;
}
.vip-card-head {
    display: flex; align-items: center; justify-content: space-between;
    padding: 18px 20px; border-bottom: 1px solid var(--vip-line);
    gap: 12px; flex-wrap: wrap;
}
.vip-card-title {
    font-family: var(--vip-serif); font-weight: 600;
    font-size: 17px; color: var(--vip-ink); margin: 0;
}
.vip-card-body { padding: 4px 20px 20px; }

/* ---------- TABLE / RESPONSIVE ---------- */
.vip-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding: 4px 0;
}
.vip-table {
    width: 100%;
    border-collapse: separate; border-spacing: 0;
    min-width: 640px;
}
.vip-table thead th {
    font-size: 11px; font-weight: 600; letter-spacing: 0.06em;
    text-transform: uppercase; color: var(--vip-gold-700);
    padding: 12px 14px; text-align: left; white-space: nowrap;
    border-bottom: 1px solid var(--vip-line-strong);
    background: var(--vip-paper-2);
}
.vip-table tbody td {
    padding: 14px; font-size: 14px; color: var(--vip-ink);
    border-bottom: 1px solid var(--vip-line);
    vertical-align: middle;
}
.vip-table tbody tr:hover { background: rgba(201,168,76,0.04); }
.vip-table tbody tr:last-child td { border-bottom: none; }

@media (max-width: 720px) {
    .vip-table { min-width: 100%; }
    .vip-table thead { display: none; }
    .vip-table tbody tr {
        display: block; margin-bottom: 12px;
        border-radius: var(--vip-radius-sm);
        background: var(--vip-paper);
        box-shadow: var(--vip-shadow-sm);
        padding: 6px 12px;
    }
    .vip-table tbody td {
        display: flex; justify-content: space-between; align-items: center;
        padding: 10px 0; border-bottom: 1px dashed var(--vip-line);
        text-align: right;
    }
    .vip-table tbody td:last-child { border-bottom: none; }
    .vip-table tbody td::before {
        content: attr(data-label);
        font-size: 11px; font-weight: 600; letter-spacing: 0.06em;
        text-transform: uppercase; color: var(--vip-gold-700);
        margin-right: 12px; text-align: left;
    }
}

/* ---------- BADGES / PILLS ---------- */
.vip-pill {
    display: inline-block; font-size: 11px; font-weight: 600;
    padding: 4px 10px; border-radius: 999px;
    letter-spacing: 0.04em; text-transform: uppercase;
    background: var(--vip-paper-2); color: var(--vip-ink-soft);
    border: 1px solid var(--vip-line);
}
.vip-pill-gold {
    background: linear-gradient(120deg, var(--vip-gold-300), var(--vip-gold-500));
    color: var(--vip-ink); border: 0;
}
.vip-pill-ink { background: var(--vip-ink); color: var(--vip-gold-200); border: 0; }
.vip-pill-green { background: rgba(34,197,94,0.14); color: #15803D; border: 0; }
.vip-pill-red   { background: rgba(239,68,68,0.14); color: #B91C1C; border: 0; }
.vip-pill-blue  { background: rgba(59,130,246,0.14); color: #1D4ED8; border: 0; }

/* ---------- BUTTONS ---------- */
.vip-btn {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 10px 18px; border-radius: 999px; border: 0;
    font-size: 13px; font-weight: 600; letter-spacing: 0.02em;
    cursor: pointer; transition: all .2s; text-decoration: none;
}
.vip-btn-primary {
    background: linear-gradient(135deg, var(--vip-gold-400), var(--vip-gold-600));
    color: var(--vip-ink);
    box-shadow: 0 4px 14px rgba(201,168,76,0.35);
}
.vip-btn-primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 22px rgba(201,168,76,0.45);
}
.vip-btn-ghost {
    background: transparent; color: var(--vip-ink);
    border: 1px solid var(--vip-line-strong);
}
.vip-btn-ghost:hover { border-color: var(--vip-gold-500); color: var(--vip-gold-700); }
.vip-btn-sm { padding: 7px 14px; font-size: 12px; }

/* ---------- FORM ---------- */
.vip-form-grid { display: grid; gap: 14px; grid-template-columns: 1fr 1fr; }
@media (max-width: 600px) { .vip-form-grid { grid-template-columns: 1fr; } }
.vip-field label {
    display: block; font-size: 11px; font-weight: 600;
    letter-spacing: 0.06em; text-transform: uppercase;
    color: var(--vip-gold-700); margin-bottom: 6px;
}
.vip-field input, .vip-field select, .vip-field textarea {
    width: 100%; padding: 12px 14px;
    box-sizing: border-box;
    border-radius: var(--vip-radius-sm);
    border: 1px solid var(--vip-line-strong);
    background: #fff; color: var(--vip-ink);
    font-size: 14px; font-family: inherit;
    transition: border-color .2s, box-shadow .2s;
}
.vip-field input:focus, .vip-field select:focus, .vip-field textarea:focus {
    outline: none; border-color: var(--vip-gold-500);
    box-shadow: 0 0 0 3px rgba(201,168,76,0.15);
}

/* ---------- MODAL ---------- */
.vip-modal-backdrop {
    position: fixed; inset: 0; background: rgba(21,17,10,0.45);
    display: flex; align-items: center; justify-content: center;
    z-index: 1000; padding: 20px;
    animation: vip-fade 180ms ease both;
    backdrop-filter: blur(4px);
}
.vip-modal {
    background: var(--vip-paper); border-radius: var(--vip-radius-lg);
    box-shadow: var(--vip-shadow-lg);
    max-width: 720px; width: 100%; max-height: 88vh;
    overflow: hidden;
    display: flex; flex-direction: column;
    animation: vip-rise 280ms cubic-bezier(.2,.9,.2,1) both;
}
.vip-modal-head {
    flex-shrink: 0;
    padding: 22px 28px;
    border-bottom: 1px solid var(--vip-line);
    display: flex; align-items: center; justify-content: space-between;
    background: linear-gradient(180deg, var(--vip-paper) 0%, var(--vip-paper-2) 100%);
}
.vip-modal-title {
    font-family: var(--vip-serif); font-weight: 600; font-size: 20px;
    margin: 0; color: var(--vip-ink);
}
.vip-modal-body {
    padding: 22px 28px;
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    overscroll-behavior: contain;
    scrollbar-width: thin;
    scrollbar-color: rgba(21,17,10,0.22) transparent;
}
.vip-modal-body::-webkit-scrollbar { width: 8px; }
.vip-modal-body::-webkit-scrollbar-thumb { background: rgba(21,17,10,0.18); border-radius: 4px; }
.vip-modal-body::-webkit-scrollbar-thumb:hover { background: rgba(21,17,10,0.28); }
.vip-modal-body::-webkit-scrollbar-track { background: transparent; }
.vip-modal-close {
    background: none; border: 0; font-size: 26px; line-height: 1;
    color: var(--vip-ink-soft); cursor: pointer; padding: 4px 10px;
    border-radius: 999px;
}
.vip-modal-close:hover { background: var(--vip-line); color: var(--vip-ink); }

@media (max-width: 600px) {
    .vip-modal-backdrop { padding: 0; align-items: flex-end; }
    .vip-modal { max-height: 95vh; border-radius: var(--vip-radius-lg) var(--vip-radius-lg) 0 0; }
}

/* ---------- MONEY / NUMERIC TYPOGRAPHY (global, role-agnostic) ---------- */
/* Promoted out of _partials/staff-money-style.blade.php so every page picks
   it up via vip.css instead of requiring an explicit @include per view. */
.vip-page .vip-kpi-value,
.vip-page .vip-money,
.vip-page .num,
.vip-page .vip-cashflow-value,
.vip-page .asset-valuation,
.vip-page .asset-fee-summary strong,
.vip-page .vip-timeline-amount,
.vip-page .commission-page-total strong,
.vip-page .commission-detail-formula strong {
    font-family: 'Inter', system-ui, sans-serif !important;
    font-variant-numeric: tabular-nums;
    font-weight: 600 !important;
    letter-spacing: -0.01em;
}
.vip-page .vip-kpi-value { font-size: clamp(18px, 1.8vw, 24px) !important; line-height: 1.15; }
.vip-page .vip-money     { font-size: clamp(13px, 1.1vw, 15px) !important; }
.vip-page .num           { font-size: clamp(16px, 1.6vw, 20px) !important; line-height: 1.15; }
.vip-page .vip-meter-pct       { font-size: clamp(28px, 3.2vw, 38px) !important; }
.vip-page .vip-meter-pct span  { font-size: 0.55em !important; }
.vip-page .vip-meter-stat-value{ font-size: clamp(14px, 1.3vw, 17px) !important; font-weight: 600 !important; }

/* ---------- DIVIDER & MISC ---------- */
.vip-rule {
    height: 1px; background: var(--vip-line-strong); margin: 24px 0;
}
.vip-money { font-family: var(--vip-serif); font-weight: 600; }
.vip-mono  { font-family: 'JetBrains Mono', 'Menlo', monospace; font-size: 12px; }
.vip-empty {
    text-align: center; padding: 40px 20px; color: var(--vip-ink-soft);
    font-size: 14px;
}
