/* ============================================================
   RoomKey Rewards - Main Stylesheet
   ============================================================ */

:root {
    --rk-primary: #0f2a4f;
    --rk-primary-dark: #0a1e3a;
    --rk-primary-light: #1a4a7a;
    --rk-secondary: #0ea5e9;
    --rk-success: #10b981;
    --rk-warning: #f59e0b;
    --rk-danger: #ef4444;
    --rk-dark: #1e293b;
    --rk-gray: #64748b;
    --rk-light: #f8fafc;
    --rk-white: #ffffff;
    --rk-border: #e2e8f0;
    --rk-shadow: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);
    --rk-shadow-lg: 0 10px 15px -3px rgba(0,0,0,.1), 0 4px 6px -2px rgba(0,0,0,.05);
    --rk-radius: 12px;
    --rk-radius-sm: 8px;
    --rk-sidebar-bg: linear-gradient(180deg, #1e293b 0%, #0f172a 100%);
    --rk-sidebar-width: 260px;
}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    color: var(--rk-dark);
    background: var(--rk-light);
    -webkit-font-smoothing: antialiased;
}
h1, h2, h3, h4, h5, h6, .fw-heading {
    font-family: 'Poppins', 'Inter', sans-serif;
    font-weight: 600;
}

/* ============================================================
   PUBLIC NAVBAR
   ============================================================ */
.rk-navbar {
    background: rgba(255,255,255,.95);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--rk-border);
    padding: .75rem 0;
    z-index: 1030;
}
.rk-navbar .navbar-brand {
    font-family: 'Poppins', sans-serif;
    font-weight: 700;
    font-size: 1.35rem;
    color: var(--rk-primary);
}
.rk-navbar .navbar-brand i { color: var(--rk-warning); }
.rk-navbar .nav-link {
    font-weight: 500;
    color: var(--rk-dark);
    padding: .5rem 1rem;
    border-radius: var(--rk-radius-sm);
    transition: all .2s;
}
.rk-navbar .nav-link:hover,
.rk-navbar .nav-link.active { color: var(--rk-primary); background: rgba(99,102,241,.06); }

/* ============================================================
   HERO SECTION
   ============================================================ */
.rk-hero {
    background: linear-gradient(135deg, #0f2a4f 0%, #091b33 50%, #0c3a5e 100%);
    color: #fff;
    padding: 5rem 0 4rem;
    position: relative;
    overflow: hidden;
}
.rk-hero::after {
    content: '';
    position: absolute;
    top: -50%;
    right: -20%;
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, rgba(99,102,241,.3) 0%, transparent 70%);
    border-radius: 50%;
}
.rk-hero h1 { font-size: 2.75rem; font-weight: 700; line-height: 1.2; }
.rk-hero .lead { font-size: 1.15rem; opacity: .9; }
@media (max-width: 768px) {
    .rk-hero { padding: 3rem 0 2.5rem; }
    .rk-hero h1 { font-size: 2rem; }
}

/* ============================================================
   SECTION STYLES
   ============================================================ */
.rk-section { padding: 4rem 0; }
.rk-section-alt { background: #fff; }
.rk-section-title {
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: .5rem;
}
.rk-section-subtitle {
    color: var(--rk-gray);
    font-size: 1.05rem;
    margin-bottom: 2.5rem;
}

/* ============================================================
   PRICING CARDS
   ============================================================ */
.rk-pricing-card {
    background: #fff;
    border: 1px solid var(--rk-border);
    border-radius: var(--rk-radius);
    padding: 2rem 1.75rem;
    height: 100%;
    display: flex;
    flex-direction: column;
    position: relative;
    transition: transform .2s, box-shadow .2s;
}
.rk-pricing-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 40px rgba(15,42,79,.12);
}
.rk-pricing-popular {
    border: 2px solid var(--rk-dark);
    box-shadow: 0 8px 30px rgba(15,42,79,.10);
}
.rk-pricing-badge {
    position: absolute;
    top: -13px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--rk-dark);
    color: #fff;
    font-size: .75rem;
    font-weight: 600;
    padding: .3rem 1rem;
    border-radius: 20px;
    letter-spacing: .5px;
    text-transform: uppercase;
    white-space: nowrap;
}
.rk-pricing-header { text-align: center; margin-bottom: 1.5rem; }
.rk-pricing-plan {
    font-size: .85rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--rk-gray);
}
.rk-pricing-price {
    display: flex;
    align-items: baseline;
    justify-content: center;
    gap: 2px;
    margin: .5rem 0;
}
.rk-pricing-currency { font-size: 1.5rem; font-weight: 600; color: var(--rk-dark); }
.rk-pricing-amount { font-size: 3.5rem; font-weight: 700; line-height: 1; color: var(--rk-dark); }
.rk-pricing-period { font-size: 1rem; color: var(--rk-gray); font-weight: 400; }
.rk-pricing-desc { font-size: .9rem; color: var(--rk-gray); margin: 0; }
.rk-pricing-features {
    list-style: none;
    padding: 0;
    margin: 0 0 1.5rem;
    flex-grow: 1;
}
.rk-pricing-features li {
    padding: .55rem 0;
    font-size: .92rem;
    color: #334155;
    border-bottom: 1px solid #f1f5f9;
    display: flex;
    align-items: center;
    gap: .6rem;
}
.rk-pricing-features li:last-child { border-bottom: none; }
.rk-pricing-features li i.fa-check { color: #10b981; font-size: .8rem; }
.rk-pricing-features li i.fa-xmark { color: #cbd5e1; font-size: .8rem; }
.rk-pricing-disabled { color: #94a3b8 !important; }
.rk-pricing-card .btn { margin-top: auto; padding: .65rem; font-weight: 600; }

/* ============================================================
   CATEGORY PILLS
   ============================================================ */
.rk-category-pill {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .5rem 1.25rem;
    border-radius: 50px;
    background: #fff;
    border: 2px solid var(--rk-border);
    color: var(--rk-dark);
    font-weight: 500;
    font-size: .9rem;
    cursor: pointer;
    transition: all .2s;
    text-decoration: none;
}
.rk-category-pill:hover,
.rk-category-pill.active {
    border-color: var(--rk-primary);
    background: var(--rk-primary);
    color: #fff;
}
.rk-category-pill i { font-size: 1rem; }

/* ============================================================
   LISTING CARDS
   ============================================================ */
.rk-card {
    background: #fff;
    border-radius: var(--rk-radius);
    border: 1px solid var(--rk-border);
    overflow: hidden;
    transition: all .3s;
    height: 100%;
    display: flex;
    flex-direction: column;
}
.rk-card:hover {
    box-shadow: var(--rk-shadow-lg);
    transform: translateY(-4px);
}
.rk-card-img {
    width: 100%;
    height: 200px;
    object-fit: cover;
    background: linear-gradient(135deg, #e0e7ff, #c7d2fe);
}
.rk-card-body {
    padding: 1.25rem;
    flex: 1;
    display: flex;
    flex-direction: column;
}
.rk-card-category {
    display: inline-block;
    font-size: .75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--rk-primary);
    margin-bottom: .25rem;
}
.rk-card-title {
    font-size: 1.1rem;
    font-weight: 600;
    margin-bottom: .35rem;
    color: var(--rk-dark);
}
.rk-card-desc {
    font-size: .875rem;
    color: var(--rk-gray);
    margin-bottom: .75rem;
}
.rk-card-promo {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    font-size: .8rem;
    font-weight: 600;
    color: var(--rk-success);
    background: rgba(16,185,129,.08);
    padding: .35rem .75rem;
    border-radius: 6px;
    margin-bottom: .75rem;
}
.rk-card-meta {
    display: flex;
    align-items: center;
    gap: .75rem;
    font-size: .8rem;
    color: var(--rk-gray);
    margin-bottom: .75rem;
}
.rk-card-actions {
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
    margin-top: auto;
}
.rk-card-actions .btn { font-size: .8rem; padding: .35rem .75rem; border-radius: 6px; }
.rk-card-featured {
    position: absolute;
    top: 12px;
    right: 12px;
    background: var(--rk-warning);
    color: #fff;
    font-size: .7rem;
    font-weight: 700;
    padding: .25rem .6rem;
    border-radius: 4px;
    text-transform: uppercase;
}
.rk-card-distance {
    position: absolute;
    top: 12px;
    left: 12px;
    background: rgba(0,0,0,.6);
    color: #fff;
    font-size: .75rem;
    padding: .25rem .6rem;
    border-radius: 4px;
}

/* ============================================================
   TAGS
   ============================================================ */
.rk-tag {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    font-size: .7rem;
    color: var(--rk-gray);
    background: var(--rk-light);
    padding: .2rem .5rem;
    border-radius: 4px;
    margin: .15rem;
}

/* ============================================================
   ADMIN / CLIENT SIDEBAR
   ============================================================ */
.rk-sidebar {
    position: fixed;
    top: 0;
    left: 0;
    width: var(--rk-sidebar-width);
    height: 100vh;
    background: var(--rk-sidebar-bg);
    color: #fff;
    z-index: 1040;
    overflow-y: auto;
    transition: transform .3s;
}
.rk-sidebar-brand {
    padding: 1.25rem 1.5rem;
    font-family: 'Poppins', sans-serif;
    font-weight: 700;
    font-size: 1.2rem;
    border-bottom: 1px solid rgba(255,255,255,.1);
    display: flex;
    align-items: center;
    gap: .5rem;
}
.rk-sidebar-brand i { color: var(--rk-warning); }
.rk-sidebar-nav { padding: 1rem 0; }
.rk-sidebar-link {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .65rem 1.5rem;
    color: rgba(255,255,255,.7);
    text-decoration: none;
    font-size: .9rem;
    font-weight: 500;
    transition: all .2s;
    border-left: 3px solid transparent;
}
.rk-sidebar-link:hover {
    color: #fff;
    background: rgba(255,255,255,.08);
}
.rk-sidebar-link.active {
    color: #fff;
    background: rgba(255,255,255,.12);
    border-left-color: var(--rk-warning);
}
.rk-sidebar-link i { width: 20px; text-align: center; }
.rk-sidebar-section {
    font-size: .7rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: rgba(255,255,255,.4);
    padding: 1rem 1.5rem .5rem;
}

/* Nav pills & links — match sidebar color */
.rk-content .nav-pills .nav-link.active {
    background-color: var(--rk-dark);
    color: #fff;
}
.rk-content .nav-pills .nav-link {
    color: var(--rk-dark);
}
.rk-content .nav-pills .nav-link:hover:not(.active) {
    color: var(--rk-dark);
    background: rgba(30,41,59,.08);
}
.rk-content a {
    color: var(--rk-dark);
}
.rk-content a:hover {
    color: #0f172a;
}

/* ============================================================
   ADMIN MAIN CONTENT
   ============================================================ */
.rk-main {
    margin-left: var(--rk-sidebar-width);
    min-height: 100vh;
    padding: 0;
}
.rk-topbar {
    background: #fff;
    border-bottom: 1px solid var(--rk-border);
    padding: .75rem 1.5rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: sticky;
    top: 0;
    z-index: 1020;
}
.rk-topbar-title {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 1.15rem;
}
.rk-content { padding: 1.5rem; }

/* ============================================================
   STAT CARDS
   ============================================================ */
.rk-stat-card {
    background: #fff;
    border-radius: var(--rk-radius);
    padding: 1.25rem;
    border: 1px solid var(--rk-border);
    display: flex;
    align-items: center;
    gap: 1rem;
    transition: box-shadow .2s;
}
.rk-stat-card:hover { box-shadow: var(--rk-shadow); }
.rk-stat-icon {
    width: 48px;
    height: 48px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    color: #fff;
    flex-shrink: 0;
}
.rk-stat-icon.primary { background: linear-gradient(135deg, var(--rk-primary), var(--rk-primary-dark)); }
.rk-stat-icon.success { background: linear-gradient(135deg, var(--rk-success), #059669); }
.rk-stat-icon.warning { background: linear-gradient(135deg, var(--rk-warning), #d97706); }
.rk-stat-icon.danger { background: linear-gradient(135deg, var(--rk-danger), #dc2626); }
.rk-stat-icon.secondary { background: linear-gradient(135deg, var(--rk-secondary), #0284c7); }
.rk-stat-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--rk-dark);
    line-height: 1;
}
.rk-stat-label {
    font-size: .8rem;
    color: var(--rk-gray);
    margin-top: .15rem;
}

/* ============================================================
   DATA TABLES
   ============================================================ */
.rk-table {
    background: #fff;
    border-radius: var(--rk-radius);
    border: 1px solid var(--rk-border);
    overflow: hidden;
}
.rk-table-header {
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--rk-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: .75rem;
}
.rk-table-title { font-weight: 600; font-size: 1rem; }
.rk-table table { margin-bottom: 0; }
.rk-table thead th {
    background: var(--rk-light);
    font-size: .8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--rk-gray);
    border-bottom: 1px solid var(--rk-border);
    padding: .75rem 1rem;
    white-space: nowrap;
}
.rk-table tbody td {
    padding: .75rem 1rem;
    font-size: .875rem;
    vertical-align: middle;
    border-bottom: 1px solid var(--rk-border);
}

/* ============================================================
   STATUS BADGES
   ============================================================ */
.rk-badge {
    display: inline-block;
    padding: .25rem .6rem;
    border-radius: 50px;
    font-size: .7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .3px;
}
.rk-badge-active { background: rgba(16,185,129,.1); color: #059669; }
.rk-badge-pending { background: rgba(245,158,11,.1); color: #d97706; }
.rk-badge-rejected { background: rgba(239,68,68,.1); color: #dc2626; }
.rk-badge-inactive { background: rgba(100,116,139,.1); color: #475569; }
.rk-badge-prospect { background: rgba(99,102,241,.1); color: var(--rk-primary); }
.rk-badge-contacted { background: rgba(14,165,233,.1); color: #0284c7; }
.rk-badge-interested { background: rgba(16,185,129,.1); color: #059669; }
.rk-badge-proposal { background: rgba(245,158,11,.1); color: #d97706; }
.rk-badge-signed { background: rgba(16,185,129,.15); color: #047857; }
.rk-badge-lost { background: rgba(239,68,68,.1); color: #dc2626; }

/* ============================================================
   FORMS
   ============================================================ */
.rk-form-card {
    background: #fff;
    border-radius: var(--rk-radius);
    border: 1px solid var(--rk-border);
    padding: 1.5rem;
}
.rk-form-card .form-label {
    font-size: .85rem;
    font-weight: 500;
    color: var(--rk-dark);
}
.rk-form-card .form-control,
.rk-form-card .form-select {
    border-radius: var(--rk-radius-sm);
    border: 1px solid var(--rk-border);
    padding: .5rem .75rem;
    font-size: .9rem;
}
.rk-form-card .form-control:focus,
.rk-form-card .form-select:focus {
    border-color: var(--rk-primary);
    box-shadow: 0 0 0 3px rgba(99,102,241,.15);
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn-rk-primary,
a.btn-rk-primary,
a.btn-rk-primary:link,
a.btn-rk-primary:visited {
    background: var(--rk-primary) !important;
    color: #fff !important;
    border: none;
    border-radius: var(--rk-radius-sm);
    font-weight: 500;
    transition: all .2s;
    text-decoration: none;
}
.btn-rk-primary:hover, .btn-rk-primary:focus, .btn-rk-primary:active,
a.btn-rk-primary:hover, a.btn-rk-primary:focus, a.btn-rk-primary:active { background: var(--rk-primary-dark) !important; color: #fff !important; }
.btn-rk-outline,
a.btn-rk-outline,
a.btn-rk-outline:link,
a.btn-rk-outline:visited {
    background: transparent;
    color: var(--rk-primary) !important;
    border: 1px solid var(--rk-primary);
    border-radius: var(--rk-radius-sm);
    font-weight: 500;
    transition: all .2s;
    text-decoration: none;
}
.btn-rk-outline:hover, .btn-rk-outline:focus,
a.btn-rk-outline:hover, a.btn-rk-outline:focus { background: var(--rk-primary); color: #fff !important; }
.btn-rk-success, a.btn-rk-success, a.btn-rk-success:link, a.btn-rk-success:visited { background: var(--rk-success) !important; color: #fff !important; border: none; border-radius: var(--rk-radius-sm); text-decoration: none; }
.btn-rk-success:hover, .btn-rk-success:focus, a.btn-rk-success:hover, a.btn-rk-success:focus { background: #059669 !important; color: #fff !important; }
.btn-rk-warning, a.btn-rk-warning, a.btn-rk-warning:link, a.btn-rk-warning:visited { background: var(--rk-warning) !important; color: #fff !important; border: none; border-radius: var(--rk-radius-sm); text-decoration: none; }
.btn-rk-warning:hover, .btn-rk-warning:focus, a.btn-rk-warning:hover, a.btn-rk-warning:focus { background: #d97706 !important; color: #fff !important; }
.btn-rk-danger, a.btn-rk-danger, a.btn-rk-danger:link, a.btn-rk-danger:visited { background: var(--rk-danger) !important; color: #fff !important; border: none; border-radius: var(--rk-radius-sm); text-decoration: none; }
.btn-rk-danger:hover, .btn-rk-danger:focus, a.btn-rk-danger:hover, a.btn-rk-danger:focus { background: #dc2626 !important; color: #fff !important; }

/* ============================================================
   CONCIERGE (MOBILE-FIRST)
   ============================================================ */
.rk-concierge-header {
    background: linear-gradient(135deg, #0f2a4f, #091b33);
    color: #fff;
    padding: 1.5rem 1rem 1rem;
    text-align: center;
}
.rk-concierge-header h1 {
    font-size: 1.35rem;
    font-weight: 700;
    margin-bottom: .35rem;
}
.rk-concierge-header p {
    font-size: .85rem;
    opacity: .85;
    margin-bottom: 0;
}
.rk-concierge-filters {
    background: #fff;
    padding: .75rem 1rem;
    border-bottom: 1px solid var(--rk-border);
    position: sticky;
    top: 0;
    z-index: 100;
    overflow-x: auto;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
}
.rk-concierge-filters::-webkit-scrollbar { display: none; }
.rk-concierge-body { padding: 1rem; }

/* ============================================================
   FOOTER
   ============================================================ */
.rk-footer {
    background: var(--rk-dark);
    color: rgba(255,255,255,.7);
    padding: 3rem 0 1.5rem;
}
.rk-footer h5 { color: #fff; font-size: 1rem; }
.rk-footer a { color: rgba(255,255,255,.7); text-decoration: none; transition: color .2s; }
.rk-footer a:hover { color: var(--rk-warning); }
.rk-footer-bottom {
    border-top: 1px solid rgba(255,255,255,.1);
    padding-top: 1.5rem;
    margin-top: 2rem;
    font-size: .85rem;
}

/* ============================================================
   HOW IT WORKS
   ============================================================ */
.rk-step {
    text-align: center;
    padding: 2rem 1.5rem;
}
.rk-step-icon {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--rk-primary), var(--rk-primary-dark));
    color: #fff;
    font-size: 1.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 1rem;
}
.rk-step-num {
    position: absolute;
    top: -5px;
    right: -5px;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--rk-warning);
    color: #fff;
    font-size: .8rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* ============================================================
   PIPELINE CARDS (Prospects)
   ============================================================ */
.rk-pipeline-col { min-width: 280px; }
.rk-pipeline-header {
    padding: .75rem;
    border-radius: var(--rk-radius-sm);
    font-weight: 600;
    font-size: .85rem;
    margin-bottom: .75rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.rk-prospect-card {
    background: #fff;
    border-radius: var(--rk-radius-sm);
    border: 1px solid var(--rk-border);
    padding: .75rem;
    margin-bottom: .5rem;
    cursor: pointer;
    transition: box-shadow .2s;
}
.rk-prospect-card:hover { box-shadow: var(--rk-shadow); }

/* ============================================================
   MOBILE RESPONSIVE
   ============================================================ */
@media (max-width: 991px) {
    .rk-sidebar {
        transform: translateX(-100%);
    }
    .rk-sidebar.show {
        transform: translateX(0);
    }
    .rk-main {
        margin-left: 0;
    }
    .rk-sidebar-overlay {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba(0,0,0,.5);
        z-index: 1035;
        display: none;
    }
    .rk-sidebar-overlay.show { display: block; }
}
@media (max-width: 576px) {
    .rk-content { padding: 1rem; }
    .rk-stat-card { padding: 1rem; }
    .rk-stat-value { font-size: 1.25rem; }
}

/* ============================================================
   DETAIL PAGE
   ============================================================ */
.rk-detail-hero {
    width: 100%;
    height: 300px;
    object-fit: cover;
    border-radius: 0 0 var(--rk-radius) var(--rk-radius);
}
.rk-detail-info {
    background: #fff;
    border-radius: var(--rk-radius);
    border: 1px solid var(--rk-border);
    padding: 1.25rem;
    margin-bottom: 1rem;
}
.rk-detail-hours li {
    display: flex;
    justify-content: space-between;
    padding: .35rem 0;
    border-bottom: 1px solid var(--rk-border);
    font-size: .875rem;
}
.rk-detail-hours li:last-child { border-bottom: none; }

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}
.rk-animate { animation: fadeInUp .5s ease-out; }

/* ============================================================
   UTILITIES
   ============================================================ */
.rk-text-primary { color: var(--rk-primary) !important; }
.rk-text-success { color: var(--rk-success) !important; }
.rk-text-warning { color: var(--rk-warning) !important; }
.rk-text-danger { color: var(--rk-danger) !important; }
.rk-bg-primary { background-color: var(--rk-primary) !important; }
.rk-bg-light { background-color: var(--rk-light) !important; }
.cursor-pointer { cursor: pointer; }
.text-truncate-2 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
