/**
 * OLAMI Master Manager — Check-in Admin Styles
 * File: assets/css/checkin-admin.css
 * Extracted from events.css in Phase 21B (v428)
 *
 * Contains: Check-in UI, badges, event grid, mobile check-in optimization
 */

/* === Core resets & check-in UI, badges, event grid (style.css lines 1-656) === */
        /* --- 1. CORE RESETS & CHECK-IN UI --- */
        .olami-checkin-wrap,
        .olami-stats-wrap,
        .oma-shell {
            font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
            color: var(--text);
            box-sizing: border-box;
            width: 100%;
        }

        .oc-group-body.forced-open {
            display: block !important;
        }

        /* BADGES ON GRID CARDS */
        .oc-select-card {
            overflow: visible !important;
            /* This allows the badge to pop out of the top */
            position: relative;
            margin-top: 12px;
            /* Adds space so the badge doesn't hit the section title */
        }

        .oc-badge-pending {
            position: absolute;
            top: -10px;
            /* Moves it up above the card border */
            left: 50%;
            transform: translateX(-50%);
            z-index: 10;
        }

        /* Sleek, optimized date field */
        input[type="date"] {
            appearance: none;
            -webkit-appearance: none;
            border: 1px solid var(--border);
            border-radius: 8px;
            padding: 10px 12px;
            background-color: var(--surface);
            font-size: 14px;
            width: 100%;
            max-width: 220px;
            cursor: pointer;
        }

        /* Force the placeholder to show MM/DD/YYYY in supporting browsers */
        input[type="date"]::before {
            content: attr(placeholder);
            width: 100%;
        }

        /* RED BADGE: Pending (Top Left or Inline) */
        .oc-badge-pending {
            position: absolute;
            top: -8px;
            left: 50%;
            transform: translateX(-50%);
            background: var(--danger);
            color: var(--text-inverse);
            font-size: 10px;
            font-weight: 800;
            padding: 3px 8px;
            border-radius: 10px;
            box-shadow: 0 2px 5px rgba(255, 59, 48, 0.3);
            z-index: 10;
            white-space: nowrap;
        }

        /* Hide the GO button to save space */
        #btn_load_list {
            display: none !important;
        }

        /* Ensure the date selector looks clean now that it's the primary trigger */
        .oc-date-row {
            display: flex;
            align-items: center;
            gap: 15px;
            margin-top: 10px;
        }

        /* Hide Group filter by default until JS decides to show it */
        #olami_group_filter {
            display: none;
        }



        /* New Event Grid Cards */
        .oc-event-grid {
            display: flex;
            flex-wrap: wrap;
            gap: 10px;
            margin-bottom: 15px;
        }

        .oc-grid-label {
            font-size: 10px;
            font-weight: 800;
            text-transform: uppercase;
            color: var(--text-muted);
            width: 100%;
            margin: 10px 0 5px 0;
            letter-spacing: 0.5px;
        }

        .oc-select-card {
            flex: 1 1 calc(25% - 10px);
            min-width: 140px;
            background: var(--surface);
            border: 1px solid var(--border-light);
            border-radius: 8px;
            padding: 15px;
            cursor: pointer;
            transition: all 0.2s;
            position: relative;
            display: flex;
            flex-direction: column;
            align-items: center;
            text-align: center;
        }

        .oc-select-card:hover {
            border-color: var(--border-hover);
            transform: translateY(-2px);
            box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
        }

        .oc-select-card.active {
            border-color: var(--text);
            background: var(--surface-hover);
            box-shadow: 0 0 0 2px var(--text);
            z-index: 2;
        }

        .oc-card-icon {
            font-size: 22px;
            margin-bottom: 5px;
        }

        .oc-card-title {
            font-size: 13px;
            font-weight: 700;
            color: var(--text);
            line-height: 1.2;
        }

        .oc-card-meta {
            font-size: 10px;
            color: var(--text-muted);
            margin-top: 2px;
        }

        /* Mobile Scroll for Event Cards Grid */
        @media (max-width: 768px) {
            .oc-event-grid {
                display: flex !important;
                flex-wrap: nowrap !important;
                overflow-x: auto !important;
                gap: 10px !important;
                padding-bottom: 10px;
                flex-wrap: nowrap;
                scrollbar-width: none;
            }
            
            .oc-event-grid::-webkit-scrollbar {
                display: none;
            }

            .oc-select-card {
                flex: 0 0 140px !important;
                min-width: 140px !important;
                max-width: 140px !important;
            }

            .oc-select-card::-webkit-scrollbar {
                display: none;
            }
            
            /* Hide grid labels on mobile to save space */
            .oc-grid-label {
                width: auto !important;
                flex-shrink: 0;
            }
        }

        /* Existing Check-in Items */
        .oc-item {
            display: flex;
            align-items: center;
            justify-content: space-between;
            background: var(--surface);
            padding: 12px 10px !important;
            border-bottom: 1px solid var(--border-light);
            transition: background 0.1s;
            box-sizing: border-box !important;
            width: 100%;
        }

        .oc-item:hover {
            background: var(--surface-hover);
            transition: background-color 0.5s ease, opacity 0.2s ease;
        }

        .rsvp-cb {
            transform: scale(1.3);
            transform-origin: center;
            margin: 0 12px 0 5px !important;
            accent-color: var(--primary);
            cursor: pointer;
            flex-shrink: 0;
        }

        .oc-left {
            display: flex;
            align-items: center;
            gap: 0 !important;
            overflow: hidden;
        }

        .oc-avatar {
            width: 45px;
            height: 45px;
            border-radius: 50%;
            object-fit: cover;
            border: 1px solid var(--border-light);
            flex-shrink: 0;
            box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05);
        }

        .oc-info {
            display: flex;
            flex-direction: column;
            overflow: hidden;
            justify-content: center;
            margin-left: 12px;
        }

        .oc-name {
            font-size: 15px;
            font-weight: 700;
            color: var(--text);
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            line-height: 1.2;
        }

        .oc-meta {
            font-size: 12px;
            color: var(--text-muted);
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            margin-top: 2px;
        }

        .oc-badge {
            background: var(--info-bg);
            color: var(--info-text);
            padding: 2px 6px;
            border-radius: 4px;
            font-size: 9px;
            text-transform: uppercase;
            font-weight: 700;
            margin-left: 6px;
            vertical-align: middle;
        }

        .oc-item.is-pending {
            background: var(--warning-bg) !important;
            border-left: 4px solid var(--warning);
        }
        
        /* Selected state for bulk actions */
        .oc-item.selected {
            background: var(--info-bg) !important;
            border-left: 4px solid var(--info) !important;
            box-shadow: inset 0 0 0 1px rgba(59, 130, 246, 0.3);
        }
        
        .oc-item.is-pending.selected {
            background: var(--warning-bg) !important;
            border-left: 4px solid var(--warning) !important;
            box-shadow: inset 0 0 0 2px rgba(255, 149, 0, 0.4);
        }
        
        /* Pending bulk bar positioning */
        #oc-pending-bulk-bar {
            position: sticky;
            top: 0;
            z-index: 100;
            margin-bottom: 10px;
        }
        
        /* Shift-click hint */
        .oc-shift-hint {
            background: var(--info-bg);
            color: var(--info-text);
            padding: 8px 15px;
            border-radius: 8px;
            font-size: 12px;
            margin-bottom: 10px;
            display: none;
            align-items: center;
            gap: 5px;
        }
        
        .oc-shift-hint.show {
            display: flex;
        }
        
        .oc-shift-hint kbd {
            background: var(--surface);
            padding: 2px 6px;
            border-radius: 4px;
            font-family: monospace;
            font-weight: bold;
            box-shadow: 0 1px 2px rgba(0,0,0,0.1);
        }

        .oc-btn-approve {
            background-color: var(--success) !important;
            color: var(--surface) !important;
            width: 38px !important;
            height: 38px !important;
            border-radius: 50% !important;
            cursor: pointer;
            font-size: 18px !important;
            display: flex !important;
            align-items: center;
            justify-content: center;
            box-shadow: 0 3px 6px rgba(0, 0, 0, 0.15) !important;
            border: 2px solid var(--surface) !important;
            margin-right: 8px !important;
            flex-shrink: 0 !important;
        }

        .oc-btn-reject {
            background-color: var(--danger) !important;
            color: var(--surface) !important;
            width: 38px !important;
            height: 38px !important;
            border-radius: 50% !important;
            cursor: pointer;
            font-size: 18px !important;
            display: flex !important;
            align-items: center;
            justify-content: center;
            box-shadow: 0 3px 6px rgba(0, 0, 0, 0.15) !important;
            border: 2px solid var(--surface) !important;
            flex-shrink: 0 !important;
        }

        #oc-bulk-bar {
            position: fixed;
            bottom: 30px;
            left: 50%;
            transform: translateX(-50%);
            background: var(--dark-bg);
            color: var(--dark-text);
            padding: 12px 25px;
            border-radius: 50px;
            display: flex;
            align-items: center;
            gap: 15px;
            box-shadow: 0 10px 30px rgba(0, 0, 0, 0.4);
            z-index: 9999999 !important;
            width: 90%;
            max-width: 450px;
            justify-content: space-between;
        }

        #bulk-count {
            font-weight: 700;
            font-size: 13px;
        }

        .oc-bulk-actions {
            display: flex;
            gap: 8px;
        }

        .oc-bulk-btn {
            background: var(--dark-surface) !important;
            color: var(--dark-text) !important;
            border: 1px solid var(--dark-surface-hover) !important;
            padding: 8px 14px !important;
            border-radius: 20px !important;
            font-size: 11px !important;
            font-weight: 700 !important;
            height: auto !important;
            line-height: normal !important;
        }

        .btn-checkin {
            background: var(--success) !important;
            border-color: var(--success) !important;
        }

        .btn-trash {
            background: var(--danger) !important;
            border-color: var(--danger) !important;
        }

        .oc-group-header {
            padding: 10px 15px;
            background: var(--surface-hover);
            font-size: 11px;
            font-weight: 800;
            text-transform: uppercase;
            color: var(--text-muted);
            border-bottom: 1px solid var(--border-light);
            margin-top: 10px;
        }

        .oc-switch {
            position: relative;
            display: inline-block;
            width: 44px;
            height: 24px;
            flex-shrink: 0;
        }

        .oc-switch input {
            opacity: 0;
            width: 0;
            height: 0;
        }

        .slider {
            position: absolute;
            cursor: pointer;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background-color: var(--border);
            transition: .4s;
            border-radius: 34px;
        }

        .slider:before {
            position: absolute;
            content: "";
            height: 18px;
            width: 18px;
            left: 3px;
            bottom: 3px;
            background-color: var(--surface);
            transition: .4s;
            border-radius: 50%;
        }

        input:checked+.slider {
            background-color: var(--success);
        }

        input:checked+.slider:before {
            transform: translateX(20px);
        }

        .oc-tabs {
            display: flex;
            justify-content: center;
            /* This centers them! */
            border-bottom: 2px solid var(--border-light);
            margin-bottom: 20px;
            gap: 60px;
            /* Generous spacing between the two tabs */
        }

        .oc-tab {
            padding: 15px 5px;
            background: transparent;
            border-bottom: 3px solid transparent;
            font-weight: 700;
            color: var(--text-muted);
            /* Darker gray for better readability */
            cursor: pointer;
            font-size: 14px;
            /* Slightly larger text */
            text-transform: uppercase;
            letter-spacing: 1px;
            /* Makes caps easier to read */
            transition: all 0.2s ease;
            user-select: none;
        }

        .oc-tab:hover {
            color: var(--text-secondary);
            /* Darkens slightly when you mouse over */
        }

        .oc-tab.active {
            border-bottom-color: var(--primary);
            /* Your Brand Red Underline */
            color: var(--text);
            /* Sharp Black Text */
            font-weight: 800;
            /* Extra bold */
        }

        .oc-controls {
            padding: 10px;
            background: var(--surface-hover);
            border-bottom: 1px solid var(--border-light);
            display: flex;
            gap: 10px;
        }

        .oc-filter-input {
            width: 100%;
            border: 1px solid var(--border);
            padding: 8px;
            border-radius: 6px;
            font-size: 13px;
        }

        .oc-quick-add {
            padding: 15px;
            background: var(--surface);
            border-bottom: 1px solid var(--border-light);
            position: relative;
        }

        /* This creates the row layout */
        .oc-quick-row {
            display: flex;
            gap: 10px;
            align-items: center;
            width: 100%;
        }

        #user_search_input {
            flex-grow: 1;
            width: auto !important;
            margin-bottom: 0 !important;
            height: 42px !important;
        }

        /* Buttons stay fixed width/height */
        .oc-quick-btn {
            height: 42px !important;
            padding: 0 20px !important;
            margin: 0 !important;
            white-space: nowrap;
            display: inline-flex;
            align-items: center;
            justify-content: center;
        }

        #oc-search-results {
            position: absolute;
            top: 100%;
            left: 0;
            right: 0;
            background: var(--surface);
            border: 1px solid var(--border);
            z-index: 100;
            max-height: 200px;
            overflow-y: auto;
            box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
        }

        .oc-result-item {
            padding: 10px;
            border-bottom: 1px solid var(--border-light);
            cursor: pointer;
            font-size: 13px;
        }

        .oc-result-item:hover {
            background: var(--surface-hover);
        }

        .olami-checkin-wrap .oc-toolbar {
            background: transparent !important;
            border: none !important;
            padding: 0 !important;
            box-shadow: none !important;
        }

        .olami-checkin-wrap .oc-select-area {
            background: var(--surface);
            padding: 20px;
            border-radius: 12px;
            border: 1px solid var(--border);
            margin-bottom: 20px;
        }

        .olami-checkin-wrap .nav-tab-wrapper {
            border-bottom: none !important;
            margin-bottom: 15px !important;
            padding-left: 0 !important;
        }

        .olami-checkin-wrap .nav-tab {
            background: transparent !important;
            border: none !important;
            font-size: 16px !important;
            font-weight: 700 !important;
            color: var(--text-secondary) !important;
            margin-right: 15px !important;
            padding: 0 !important;
        }

        .olami-checkin-wrap .nav-tab-active {
            color: var(--text) !important;
        }

        .olami-checkin-wrap h1,
        .olami-checkin-wrap hr,
        .tablenav.top {
            display: none !important;
        }

        .oc-stats {
            display: flex;
            gap: 10px;
            justify-content: space-between;
        }

        .oc-stat-box {
            background: var(--bg);
            padding: 8px 15px;
            border-radius: 4px;
            text-align: center;
            min-width: 60px;
            flex-grow: 1;
        }

        .oc-stat-box.is-green {
            background: var(--success-bg);
            color: var(--success-text);
        }

        .oc-stat-box.is-pending {
            background: var(--warning-bg);
            color: var(--warning-text);
        }

        .oc-stat-num {
            font-size: 20px;
            font-weight: 800;
            display: block;
            line-height: 1;
        }

        .oc-stat-label {
            font-size: 9px;
            text-transform: uppercase;
            opacity: 0.7;
        }


/* === Mobile check-in optimization (style.css lines 657-747) === */
        /* --- MOBILE CHECK-IN MANAGER OPTIMIZATION --- */
        @media (max-width: 768px) {
            /* Stats row - keep as flex, wrap if needed */
            .oc-stats-row {
                display: flex !important;
                flex-wrap: wrap !important;
                gap: 8px !important;
            }
            
            .oc-stat-card {
                flex: 1 1 calc(50% - 8px) !important;
                min-width: 80px !important;
            }
            
            /* Group headers - more touch-friendly */
            .oc-group-header {
                padding: 14px 15px !important;
                font-size: 12px !important;
            }
            
            /* Guest list & pending items - optimized vertical layout */
            .oc-item {
                padding: 12px 10px !important;
            }
            
            .oc-item .oc-avatar {
                width: 40px !important;
                height: 40px !important;
            }
            
            .oc-item .oc-info {
                margin-left: 10px !important;
            }
            
            .oc-item .oc-name {
                font-size: 14px !important;
            }
            
            .oc-item .oc-meta {
                font-size: 11px !important;
            }
            
            /* Approve/Reject buttons - larger touch targets */
            .oc-btn-approve,
            .oc-btn-reject {
                width: 42px !important;
                height: 42px !important;
                font-size: 18px !important;
            }
            
            /* Family dropdown in pending cards */
            .oc-item select {
                max-width: 90px !important;
                font-size: 12px !important;
                padding: 6px 8px !important;
            }
            
            /* Tabs row */
            .oc-tabs-row {
                display: flex !important;
                overflow-x: auto !important;
                flex-wrap: nowrap;
            }
            
            .oc-tab {
                flex: 0 0 auto !important;
                white-space: nowrap !important;
                padding: 12px 14px !important;
                font-size: 12px !important;
            }
            
            /* Search input - prevent iOS zoom */
            .oc-search-input,
            .oc-quick-row input {
                font-size: 16px !important;
            }
            
            /* Bulk action bar */
            #oc-bulk-bar {
                left: 10px !important;
                right: 10px !important;
                transform: none !important;
                width: auto !important;
            }
            
            .oc-bulk-btn {
                padding: 10px 12px !important;
                font-size: 11px !important;
            }
        }


