/* ===== Cookies & Courtesies Gift Sender — Global Styles ===== */
/* Version: 2.3 - Added dynamic nav menu items CSS */

/* ═══════════════════════════════════════════════════════════════════
   CSS VARIABLES
   ═══════════════════════════════════════════════════════════════════ */
:root {
    /* Brand Colors */
    --ccgs-red: #D32F2F;
    --ccgs-red-dark: #B71C1C;
    --ccgs-red-light: #FFCDD2;
    --ccgs-red-50: #FFEBEE;
    
    /* Neutrals */
    --ccgs-bg: #F9F4EF;
    --ccgs-white: #FFFFFF;
    --ccgs-border: #EDE5DC;
    
    /* Text */
    --ccgs-text: #2D2D2D;
    --ccgs-text-mid: #555555;
    --ccgs-text-light: #999999;
    
    /* Shadows */
    --ccgs-shadow: 0 2px 12px rgba(0,0,0,0.06);
    --ccgs-shadow-md: 0 8px 32px rgba(0,0,0,0.10);
    --ccgs-shadow-lg: 0 16px 48px rgba(0,0,0,0.12);
    --ccgs-shadow-red: 0 6px 24px rgba(211, 47, 47, 0.35);
    
    /* Radii */
    --ccgs-r: 12px;
    --ccgs-r-lg: 18px;
    --ccgs-r-xl: 24px;
    --ccgs-r-full: 9999px;
    
    /* Transitions */
    --ccgs-ease: cubic-bezier(0.4, 0, 0.2, 1);
    --ccgs-ease-out: cubic-bezier(0, 0, 0.2, 1);
}

/* ═══════════════════════════════════════════════════════════════════
   DEFENSIVE SCROLL SAFEGUARD — Prevent Elementor/theme scroll lock
   ═══════════════════════════════════════════════════════════════════ */
html.ccgs-page,
body.ccgs-page {
    overflow-x: hidden !important;
    overflow-y: auto !important;
    height: auto !important;
    position: static !important;
}

html.ccgs-modal-open,
html.ccgs-modal-open body {
    overflow: hidden !important;
}

/* ═══════════════════════════════════════════════════════════════════
   BASE RESET
   ═══════════════════════════════════════════════════════════════════ */
.ccgs-wrap,
.ccgs-wizard,
.ccgs-claim,
.ccgs-shop-wrap,
.ccgs-customizer {
    font-family: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    color: #2D2D2D !important;
    line-height: 1.6 !important;
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale !important;
}

.ccgs-wrap *,
.ccgs-wrap *::before,
.ccgs-wrap *::after,
.ccgs-wizard *,
.ccgs-wizard *::before,
.ccgs-wizard *::after,
.ccgs-claim *,
.ccgs-claim *::before,
.ccgs-claim *::after,
.ccgs-shop-wrap *,
.ccgs-shop-wrap *::before,
.ccgs-shop-wrap *::after,
.ccgs-customizer *,
.ccgs-customizer *::before,
.ccgs-customizer *::after {
    box-sizing: border-box !important;
}

/* Prevent Elementor/theme from collapsing SVGs */
.ccgs-wrap svg,
.ccgs-wizard svg,
.ccgs-claim svg {
    overflow: visible !important;
}

.ccgs-wrap a,
.ccgs-wizard a,
.ccgs-claim a {
    text-decoration: none !important;
    color: inherit !important;
    transition: all 0.25s ease !important;
}

.ccgs-wrap img,
.ccgs-wizard img,
.ccgs-claim img {
    max-width: 100% !important;
    display: block !important;
}

.ccgs-wrap h1, .ccgs-wrap h2, .ccgs-wrap h3, .ccgs-wrap h4, .ccgs-wrap h5, .ccgs-wrap h6,
.ccgs-wizard h1, .ccgs-wizard h2, .ccgs-wizard h3, .ccgs-wizard h4, .ccgs-wizard h5, .ccgs-wizard h6,
.ccgs-claim h1, .ccgs-claim h2, .ccgs-claim h3, .ccgs-claim h4, .ccgs-claim h5, .ccgs-claim h6 {
    font-weight: 700 !important;
    line-height: 1.3 !important;
    font-family: 'Poppins', -apple-system, BlinkMacSystemFont, sans-serif !important;
    color: #2D2D2D !important;
    margin-top: 0 !important;
}

/* ═══════════════════════════════════════════════════════════════════
   WPAUTOP DEFENSE — Kill <br> tags injected by Elementor text widget
   ═══════════════════════════════════════════════════════════════════ */
.ccgs-wrap br,
.ccgs-dashboard br,
.ccgs-wizard br,
.ccgs-claim br,
.ccgs-shop-wrap br,
.ccgs-customizer br {
    display: none !important;
    height: 0 !important;
    line-height: 0 !important;
    font-size: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Also neutralize wpautop <p> wrappers inside flex/grid containers */
.ccgs-sidebar__nav > p,
.ccgs-delivery-cards > p,
.ccgs-ecard-grid > p,
.ccgs-wizard__progress > p,
.ccgs-wizard__nav > p,
.ccgs-wizard__product-bar > p,
.ccgs-schedule-options > p,
.ccgs-dash-banner > p,
.ccgs-recipient-row > p,
.ccgs-form-row > p,
.ccgs-modal__footer > p,
.ccgs-modal__tabs > p {
    display: contents !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ═══════════════════════════════════════════════════════════════════
   BUTTONS - ELEMENTOR OVERRIDE WITH !IMPORTANT
   ═══════════════════════════════════════════════════════════════════ */
.ccgs-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    padding: 10px 20px !important;
    border-radius: 10px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    border: none !important;
    transition: all 0.3s ease !important;
    font-family: 'Poppins', sans-serif !important;
    text-decoration: none !important;
    line-height: 1.4 !important;
    white-space: nowrap !important;
    box-sizing: border-box !important;
}

/* SVG inside buttons always aligned */
.ccgs-btn svg,
.ccgs-btn .ccgs-icon {
    width: 18px !important;
    height: 18px !important;
    display: block !important;
    flex-shrink: 0 !important;
    fill: currentColor !important;
}

.ccgs-btn--primary {
    background: linear-gradient(135deg, #D32F2F, #C41E3A) !important;
    color: #FFFFFF !important;
    box-shadow: 0 4px 16px rgba(211, 47, 47, 0.35) !important;
}

/* Nuclear override: ensure primary button text is ALWAYS white regardless of theme */
html body .ccgs-btn--primary,
html body .ccgs-btn--primary:link,
html body .ccgs-btn--primary:visited,
html body .ccgs-btn--primary:hover,
html body .ccgs-btn--primary:focus,
html body .ccgs-btn--primary:active,
html body button.ccgs-btn--primary,
html body a.ccgs-btn--primary {
    color: #FFFFFF !important;
}

.ccgs-btn--primary:hover {
    background: linear-gradient(135deg, #B71C1C, #A91929) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 24px rgba(211, 47, 47, 0.45) !important;
    color: #FFFFFF !important;
}

.ccgs-btn--primary:active {
    transform: translateY(0) !important;
}

.ccgs-btn--secondary {
    background: #F9F4EF !important;
    color: #2D2D2D !important;
    border: 1.5px solid #EDE5DC !important;
}

.ccgs-btn--secondary:hover {
    background: #FFFFFF !important;
    border-color: #D32F2F !important;
    color: #D32F2F !important;
}

.ccgs-btn--outline {
    background: transparent !important;
    border: 2px solid #D32F2F !important;
    color: #D32F2F !important;
}

.ccgs-btn--outline:hover {
    background: #D32F2F !important;
    color: #FFFFFF !important;
}

.ccgs-btn--white {
    background: #FFFFFF !important;
    color: #D32F2F !important;
    border: none !important;
    box-shadow: 0 4px 15px rgba(0,0,0,0.15) !important;
}

.ccgs-btn--white:hover {
    background: #FFF0F0 !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.2) !important;
    color: #D32F2F !important;
}

.ccgs-btn--ghost {
    background: transparent !important;
    color: #555555 !important;
    padding: 8px 16px !important;
}

.ccgs-btn--ghost:hover {
    color: #D32F2F !important;
    background: #FFEBEE !important;
}

.ccgs-btn--small {
    padding: 6px 14px !important;
    font-size: 12px !important;
    border-radius: 8px !important;
    box-shadow: none !important;
}

.ccgs-btn--large {
    padding: 14px 28px !important;
    font-size: 15px !important;
}

.ccgs-btn--icon {
    width: 40px !important;
    height: 40px !important;
    padding: 0 !important;
    border-radius: 12px !important;
}

.ccgs-btn:disabled,
.ccgs-btn.disabled {
    opacity: 0.5 !important;
    cursor: not-allowed !important;
    pointer-events: none !important;
}

/* ═══════════════════════════════════════════════════════════════════
   CARDS
   ═══════════════════════════════════════════════════════════════════ */
.ccgs-card {
    background: #FFFFFF !important;
    border-radius: 12px !important;
    box-shadow: 0 2px 12px rgba(0,0,0,0.06) !important;
    padding: 24px !important;
    transition: all 0.3s ease !important;
}

.ccgs-card--hover:hover {
    box-shadow: 0 8px 32px rgba(0,0,0,0.10) !important;
    transform: translateY(-4px) !important;
}

.ccgs-card--clickable {
    cursor: pointer !important;
}

/* ═══════════════════════════════════════════════════════════════════
   BADGES
   ═══════════════════════════════════════════════════════════════════ */
.ccgs-badge {
    display: inline-flex !important;
    align-items: center !important;
    padding: 4px 10px !important;
    border-radius: 6px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    white-space: nowrap !important;
    letter-spacing: 0.3px !important;
}

.ccgs-badge--pending,
.ccgs-badge--processing {
    background: linear-gradient(135deg, #FFF8E1, #FFECB3);
    color: #E65100;
}

.ccgs-badge--claimed {
    background: linear-gradient(135deg, #E3F2FD, #BBDEFB);
    color: #1565C0;
}

.ccgs-badge--shipped {
    background: linear-gradient(135deg, #E3F2FD, #BBDEFB);
    color: #0D47A1;
}

.ccgs-badge--delivered {
    background: linear-gradient(135deg, #E8F5E9, #C8E6C9);
    color: #2E7D32;
}

.ccgs-badge--primary {
    background: #D32F2F !important;
    color: #fff !important;
}

.ccgs-badge--premium {
    background: linear-gradient(135deg, #FFD700, #FFA500);
    color: #fff;
}

/* ═══════════════════════════════════════════════════════════════════
   FORM ELEMENTS
   ═══════════════════════════════════════════════════════════════════ */
.ccgs-form-group {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    margin-bottom: 20px !important;
}

.ccgs-form-group label {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #2D2D2D !important;
}

.ccgs-form-group label .required {
    color: #D32F2F !important;
}

.ccgs-input,
.ccgs-form-group input,
.ccgs-form-group select,
.ccgs-form-group textarea {
    padding: 12px 16px !important;
    border: 1.5px solid #EDE5DC !important;
    border-radius: 12px !important;
    font-size: 14px !important;
    color: #2D2D2D !important;
    outline: none !important;
    transition: all 0.2s ease !important;
    background: #FFFFFF !important;
    font-family: 'Poppins', sans-serif !important;
    width: 100% !important;
}

.ccgs-input:focus,
.ccgs-form-group input:focus,
.ccgs-form-group select:focus,
.ccgs-form-group textarea:focus {
    border-color: #D32F2F !important;
    box-shadow: 0 0 0 4px rgba(211, 47, 47, 0.1) !important;
}

.ccgs-input::placeholder,
.ccgs-form-group input::placeholder,
.ccgs-form-group textarea::placeholder {
    color: #999999 !important;
}

.ccgs-form-row {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 16px !important;
}

.ccgs-form-row-3 {
    grid-template-columns: repeat(3, 1fr) !important;
}

.ccgs-form-hint {
    font-size: 12px !important;
    color: #999999 !important;
    margin-top: 4px !important;
}

.ccgs-form-error {
    font-size: 12px !important;
    color: #D32F2F !important;
    margin-top: 4px !important;
}

/* Checkbox & Radio */
.ccgs-checkbox,
.ccgs-radio {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    cursor: pointer !important;
    font-size: 14px !important;
}

.ccgs-checkbox input,
.ccgs-radio input {
    width: 18px !important;
    height: 18px !important;
    accent-color: #D32F2F !important;
}

/* ═══════════════════════════════════════════════════════════════════
   TOAST NOTIFICATIONS
   ═══════════════════════════════════════════════════════════════════ */
.ccgs-toast {
    position: fixed !important;
    bottom: 28px !important;
    right: 28px !important;
    z-index: 9999 !important;
    background: #2D2D2D !important;
    color: #fff !important;
    padding: 16px 24px !important;
    border-radius: 12px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    box-shadow: 0 16px 48px rgba(0,0,0,0.12) !important;
    opacity: 0 !important;
    transform: translateY(20px) !important;
    transition: all 0.4s ease !important;
    pointer-events: none !important;
    max-width: 380px !important;
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
}

.ccgs-toast.show {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

.ccgs-toast--success {
    background: #2E7D32;
}

.ccgs-toast--error {
    background: #D32F2F !important;
}

.ccgs-toast--warning {
    background: #F57F17;
}

.ccgs-toast__icon {
    width: 24px;
    height: 24px;
    flex-shrink: 0;
}

.ccgs-toast__close {
    margin-left: auto;
    background: none;
    border: none;
    color: rgba(255, 255, 255, 0.7);
    cursor: pointer;
    padding: 4px;
}

.ccgs-toast__close:hover {
    color: #fff !important;
}

/* ═══════════════════════════════════════════════════════════════════
   MODALS
   ═══════════════════════════════════════════════════════════════════ */
.ccgs-modal-overlay {
    position: fixed !important;
    inset: 0 !important;
    background: rgba(0, 0, 0, 0.5) !important;
    backdrop-filter: blur(4px) !important;
    z-index: 9000 !important;
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 24px !important;
}

.ccgs-modal-overlay.open {
    display: flex !important;
}

.ccgs-modal {
    background: #FFFFFF !important;
    border-radius: 24px !important;
    width: 100% !important;
    max-width: 540px !important;
    max-height: 90vh !important;
    overflow: hidden !important;
    box-shadow: 0 16px 48px rgba(0,0,0,0.12) !important;
    animation: ccgsModalSlide 0.35s ease !important;
}

@keyframes ccgsModalSlide {
    from {
        transform: translateY(40px) scale(0.96);
        opacity: 0;
    }
    to {
        transform: translateY(0) scale(1);
        opacity: 1;
    }
}

.ccgs-modal--large {
    max-width: 720px;
}

.ccgs-modal--full {
    max-width: 90vw;
    max-height: 90vh;
}

.ccgs-modal__header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 24px 28px !important;
    border-bottom: 1px solid #EDE5DC !important;
}

.ccgs-modal__header h3 {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: #2D2D2D !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
}

.ccgs-modal__header h3 .ccgs-icon {
    color: #D32F2F !important;
}

.ccgs-modal__close {
    width: 36px !important;
    height: 36px !important;
    border-radius: 10px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: #999999 !important;
    cursor: pointer !important;
    border: none !important;
    background: none !important;
    transition: all 0.2s ease !important;
}

.ccgs-modal__close:hover {
    background: #F9F4EF !important;
    color: #D32F2F !important;
}

.ccgs-modal__close svg {
    width: 20px;
    height: 20px;
}

.ccgs-modal__body {
    padding: 28px !important;
    overflow-y: auto !important;
    max-height: calc(90vh - 180px) !important;
}

.ccgs-modal__footer {
    padding: 20px 28px !important;
    border-top: 1px solid #EDE5DC !important;
    display: flex !important;
    justify-content: flex-end !important;
    gap: 12px !important;
    background: #F9F4EF !important;
}

/* ═══════════════════════════════════════════════════════════════════
   SEARCH BOX
   ═══════════════════════════════════════════════════════════════════ */
.ccgs-search-box {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    background: #F9F4EF !important;
    border-radius: 9999px !important;
    padding: 10px 18px !important;
    border: 1.5px solid transparent !important;
    transition: all 0.2s ease !important;
}

.ccgs-search-box:focus-within {
    border-color: #D32F2F !important;
    background: #FFFFFF !important;
}

.ccgs-search-box__icon {
    width: 18px !important;
    height: 18px !important;
    color: #999999 !important;
    flex-shrink: 0 !important;
}

.ccgs-search-box input {
    border: none !important;
    background: none !important;
    outline: none !important;
    font-size: 14px !important;
    color: #2D2D2D !important;
    width: 200px !important;
    font-family: 'Poppins', sans-serif !important;
}

.ccgs-search-box input::placeholder {
    color: #999999 !important;
}

/* ═══════════════════════════════════════════════════════════════════
   GIFT GENIE FLOATING BUTTON
   ═══════════════════════════════════════════════════════════════════ */
.ccgs-gift-genie {
    position: fixed;
    bottom: 28px;
    right: 28px;
    z-index: 8000;
}

.ccgs-gift-genie__btn {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    background: linear-gradient(135deg, #D32F2F, #C41E3A) !important;
    color: #fff !important;
    padding: 16px 28px !important;
    border-radius: 9999px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    box-shadow: 0 6px 24px rgba(211, 47, 47, 0.35) !important;
    transition: all 0.3s ease !important;
    text-decoration: none !important;
}

.ccgs-gift-genie__btn:hover {
    background: linear-gradient(135deg, #B71C1C, #A91929) !important;
    transform: translateY(-4px) !important;
    box-shadow: 0 12px 36px rgba(211, 47, 47, 0.5) !important;
    color: #fff !important;
}

.ccgs-gift-genie__icon {
    width: 24px;
    height: 24px;
}

/* ═══════════════════════════════════════════════════════════════════
   LOADING STATES
   ═══════════════════════════════════════════════════════════════════ */
.ccgs-spinner {
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 2.5px solid rgba(255, 255, 255, 0.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: ccgsSpin 0.6s linear infinite;
}

.ccgs-spinner--dark {
    border-color: rgba(0, 0, 0, 0.1) !important;
    border-top-color: #D32F2F !important;
}

@keyframes ccgsSpin {
    to { transform: rotate(360deg); }
}

.ccgs-skeleton {
    background: linear-gradient(90deg, #F9F4EF 25%, #f0ebe6 50%, #F9F4EF 75%) !important;
    background-size: 200% 100% !important;
    animation: ccgsShimmer 1.5s infinite !important;
    border-radius: 12px !important;
}

@keyframes ccgsShimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* ═══════════════════════════════════════════════════════════════════
   ICONS
   ═══════════════════════════════════════════════════════════════════ */
.ccgs-icon {
    width: 20px;
    height: 20px;
    display: inline-flex;
    flex-shrink: 0;
}

.ccgs-icon--sm { width: 16px; height: 16px; }
.ccgs-icon--lg { width: 24px; height: 24px; }
.ccgs-icon--xl { width: 32px; height: 32px; }

.ccgs-icon svg {
    width: 100%;
    height: 100%;
}

/* ═══════════════════════════════════════════════════════════════════
   UTILITY CLASSES
   ═══════════════════════════════════════════════════════════════════ */
.ccgs-text-center { text-align: center; }
.ccgs-text-red { color: #D32F2F !important; }
.ccgs-text-muted { color: #999999 !important; }
.ccgs-text-small { font-size: 12px; }

.ccgs-mt-1 { margin-top: 8px; }
.ccgs-mt-2 { margin-top: 16px; }
.ccgs-mt-3 { margin-top: 24px; }
.ccgs-mb-1 { margin-bottom: 8px; }
.ccgs-mb-2 { margin-bottom: 16px; }
.ccgs-mb-3 { margin-bottom: 24px; }

.ccgs-flex { display: flex; }
.ccgs-flex-center { display: flex; align-items: center; justify-content: center; }
.ccgs-flex-between { display: flex; align-items: center; justify-content: space-between; }
.ccgs-gap-1 { gap: 8px; }
.ccgs-gap-2 { gap: 16px; }
.ccgs-gap-3 { gap: 24px; }

.ccgs-hidden { display: none !important; }
.ccgs-sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* ═══════════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
    .ccgs-form-row {
        grid-template-columns: 1fr !important;
    }
    
    .ccgs-form-row-3 {
        grid-template-columns: 1fr !important;
    }
    
    .ccgs-gift-genie__label {
        display: none;
    }
    
    .ccgs-gift-genie__btn {
        padding: 16px;
        border-radius: 50%;
    }
    
    .ccgs-modal {
        margin: 16px;
        max-height: calc(100vh - 32px);
    }
    
    .ccgs-modal__body {
        padding: 20px;
    }
    
    .ccgs-search-box input {
        width: 150px;
    }
}

@media (max-width: 480px) {
    .ccgs-btn--large {
        padding: 14px 28px;
        font-size: 15px;
    }
    
    .ccgs-modal__header,
    .ccgs-modal__footer {
        padding: 16px 20px;
    }
}

/* ═══════════════════════════════════════════════════════════════════
   DYNAMIC NAV MENU ITEMS
   
   These styles apply to the auto-injected Login/Register/Dashboard
   menu items. They work with most themes using Elementor or Starter/
   Astra/GeneratePress etc.
   ═══════════════════════════════════════════════════════════════════ */
.ccgs-menu-item {
    display: flex !important;
    align-items: center !important;
}

.ccgs-menu-item a {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 8px 16px !important;
    font-family: 'Poppins', sans-serif !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    text-decoration: none !important;
    transition: all 0.2s ease !important;
}

/* Sign In link — subtle text style */
.ccgs-menu-item--login a {
    color: #2D2D2D !important;
    background: transparent !important;
}

.ccgs-menu-item--login a:hover {
    color: #D32F2F !important;
}

/* Create Account — red button */
.ccgs-menu-item--register a.ccgs-btn {
    background: linear-gradient(135deg, #D32F2F, #C41E3A) !important;
    color: #FFFFFF !important;
    border-radius: 8px !important;
    padding: 8px 16px !important;
    box-shadow: 0 2px 8px rgba(211, 47, 47, 0.25) !important;
}

.ccgs-menu-item--register a.ccgs-btn:hover {
    background: linear-gradient(135deg, #B71C1C, #A91929) !important;
    box-shadow: 0 4px 16px rgba(211, 47, 47, 0.35) !important;
    transform: translateY(-1px) !important;
}

/* Dashboard link — icon styling */
.ccgs-menu-item--dashboard a {
    color: #D32F2F !important;
    font-weight: 600 !important;
    background: #FFF0F0 !important;
    border-radius: 8px !important;
}

.ccgs-menu-item--dashboard a:hover {
    background: #FFEBEE !important;
}

/* User name + logout */
.ccgs-menu-item--user a {
    color: #555555 !important;
    font-size: 13px !important;
}

.ccgs-menu-item--user a:hover {
    color: #D32F2F !important;
}

/* Mobile responsive */
@media (max-width: 768px) {
    .ccgs-menu-item a {
        padding: 10px 12px !important;
        font-size: 13px !important;
    }
    
    .ccgs-menu-item--user {
        display: none !important;
    }
}
