/* ============================================
   CK Cart & Search Plugin v2.0 - Styles
   CK Healthguard Green Theme
   ============================================ */

:root {
    --ck-green:       #1a7c3e;
    --ck-green-dark:  #145f30;
    --ck-green-light: #e8f5e9;
    --ck-white:       #ffffff;
    --ck-text:        #333333;
    --ck-text-light:  #777777;
    --ck-border:      #d0e8d9;
    --ck-shadow:      0 8px 32px rgba(26,124,62,0.18);
    --ck-radius:      8px;
    --ck-font:        -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* ===== CART BUTTON ===== */
.ck-cart-wrapper {
    display: inline-flex;
    align-items: center;
    position: relative;
}

.ck-cart-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background-color: var(--ck-green);
    color: var(--ck-white) !important;
    text-decoration: none !important;
    padding: 10px 18px;
    border-radius: var(--ck-radius);
    font-family: var(--ck-font);
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: background-color 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
    box-shadow: 0 2px 8px rgba(26,124,62,0.3);
    position: relative;
    border: none;
    outline: none;
    background-clip: padding-box;
}

.ck-cart-btn:hover,
.ck-cart-wrapper:hover .ck-cart-btn {
    background-color: var(--ck-green-dark);
    transform: translateY(-1px);
    box-shadow: 0 4px 16px rgba(26,124,62,0.4);
}

.ck-cart-btn:active { transform: translateY(0); }

.ck-cart-icon { display: flex; align-items: center; }
.ck-cart-icon svg { width: 20px; height: 20px; }

/* Count Badge */
.ck-cart-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 20px;
    padding: 0 5px;
    background: rgba(255,255,255,0.22);
    color: var(--ck-white);
    border-radius: 50px;
    font-size: 11px;
    font-weight: 700;
    transition: transform 0.3s cubic-bezier(0.175,0.885,0.32,1.275);
}
.ck-cart-count.ck-has-items {
    background: #38ab46;
    animation: ck-pop 0.4s cubic-bezier(0.175,0.885,0.32,1.275);
}
@keyframes ck-pop {
    0%   { transform: scale(1); }
    50%  { transform: scale(1.4); }
    100% { transform: scale(1); }
}

.ck-cart-label { font-size: 13px; font-weight: 600; }

/* Large variant */
.ck-cart-large .ck-cart-btn { padding: 13px 24px; font-size: 16px; }
.ck-cart-large .ck-cart-icon svg { width: 18px; height: 18px; }

/* ===== MINI CART DROPDOWN ===== */
.ck-mini-cart {
    display: none;
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    width: 320px;
    background: var(--ck-white);
    border: 1px solid var(--ck-border);
    border-radius: var(--ck-radius);
    box-shadow: var(--ck-shadow);
    z-index: 99999;
    overflow: hidden;
    animation: ck-slide-down 0.22s cubic-bezier(0.22,1,0.36,1);
    transform-origin: top right;
}

.ck-mini-cart.ck-open {
    display: block;
}

@keyframes ck-slide-down {
    from { opacity: 0; transform: scaleY(0.92) translateY(-6px); }
    to   { opacity: 1; transform: scaleY(1)    translateY(0); }
}

/* Arrow pointer */
.ck-mini-cart-arrow {
    position: absolute;
    top: -7px;
    right: 20px;
    width: 14px;
    height: 14px;
    background: var(--ck-white);
    border-left: 1px solid var(--ck-border);
    border-top: 1px solid var(--ck-border);
    transform: rotate(45deg);
    z-index: 1;
}

/* ===== MINI CART ITEMS ===== */
.ck-mini-items {
    max-height: 280px;
    overflow-y: auto;
    padding: 10px 0;
}

.ck-mini-items::-webkit-scrollbar { width: 4px; }
.ck-mini-items::-webkit-scrollbar-thumb { background: var(--ck-border); border-radius: 4px; }

.ck-mini-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    border-bottom: 1px solid #f0f0f0;
    transition: background 0.15s;
}
.ck-mini-item:last-child { border-bottom: none; }
.ck-mini-item:hover { background: #fafff9; }

.ck-mini-img {
    width: 52px;
    height: 52px;
    flex-shrink: 0;
    border-radius: 6px;
    overflow: hidden;
    border: 1px solid var(--ck-border);
    background: #f5f5f5;
}
.ck-mini-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.ck-mini-img-placeholder {
    width: 100%;
    height: 100%;
    background: #e8f5e9;
}

.ck-mini-info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 3px;
}
.ck-mini-name {
    font-size: 13px;
    font-weight: 600;
    color: #222;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block;
    font-family: var(--ck-font);
}
.ck-mini-qty-price {
    font-size: 12px;
    color: var(--ck-text-light);
    font-family: var(--ck-font);
    display: flex;
    align-items: center;
    gap: 4px;
}
.ck-mini-qty {
    font-weight: 700;
    color: var(--ck-green);
}
.ck-mini-qty-price .woocommerce-Price-amount { font-size: 12px; color: var(--ck-text-light); }

.ck-mini-line-total {
    font-size: 13px;
    font-weight: 700;
    color: var(--ck-green);
    font-family: var(--ck-font);
}
.ck-mini-line-total .woocommerce-Price-amount { font-size: 13px; font-weight: 700; color: var(--ck-green); }

/* Remove button */
.ck-mini-remove {
    width: 26px;
    height: 26px;
    border: none;
    background: transparent;
    cursor: pointer;
    color: #bbb;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s, color 0.15s;
    flex-shrink: 0;
    padding: 0;
}
.ck-mini-remove:hover { background: #ffe5e5; color: #e53935; }
.ck-mini-remove svg { width: 14px; height: 14px; }

/* ===== MINI CART EMPTY ===== */
.ck-mini-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 30px 20px;
    gap: 10px;
    color: var(--ck-text-light);
    font-family: var(--ck-font);
}
.ck-mini-empty svg { width: 40px; height: 40px; stroke: #ccc; }
.ck-mini-empty p { margin: 0; font-size: 14px; }
.ck-shop-btn {
    display: inline-block;
    padding: 8px 18px;
    background: var(--ck-green);
    color: var(--ck-white) !important;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 600;
    text-decoration: none !important;
    transition: background 0.2s;
    font-family: var(--ck-font);
    margin-top: 4px;
}
.ck-shop-btn:hover { background: var(--ck-green-dark); }

/* ===== MINI CART FOOTER ===== */
.ck-mini-footer {
    padding: 12px 14px;
    border-top: 2px solid var(--ck-green-light);
    background: #fafff9;
    font-family: var(--ck-font);
}
.ck-mini-total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
    font-size: 14px;
    color: var(--ck-text);
}
.ck-mini-total span:first-child { font-weight: 600; }
.ck-mini-total-amount { font-weight: 700; color: var(--ck-green); font-size: 15px; }
.ck-mini-total-amount .woocommerce-Price-amount { font-size: 15px; font-weight: 700; color: var(--ck-green); }

.ck-mini-actions {
    display: flex;
    gap: 8px;
}
.ck-mini-view-cart,
.ck-mini-checkout {
    flex: 1;
    text-align: center;
    padding: 9px 10px;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 600;
    text-decoration: none !important;
    transition: background 0.2s, transform 0.15s;
    font-family: var(--ck-font);
    display: block;
}
.ck-mini-view-cart {
    background: var(--ck-green-light);
    color: var(--ck-green) !important;
    border: 1px solid var(--ck-border);
}
.ck-mini-view-cart:hover { background: #d0ead8; }
.ck-mini-checkout {
    background: var(--ck-green);
    color: var(--ck-white) !important;
}
.ck-mini-checkout:hover { background: var(--ck-green-dark); transform: translateY(-1px); }

/* Loading state */
.ck-mini-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 20px;
    color: var(--ck-green);
    font-size: 13px;
    font-family: var(--ck-font);
}
.ck-spinner {
    width: 18px; height: 18px;
    border: 2px solid var(--ck-border);
    border-top-color: var(--ck-green);
    border-radius: 50%;
    animation: ck-spin 0.6s linear infinite;
    flex-shrink: 0;
}
@keyframes ck-spin { to { transform: rotate(360deg); } }

/* ===== SEARCH ===== */
.ck-search-wrapper {
    position: relative;
    width: 100%;
    max-width: 600px;
    font-family: var(--ck-font);
}
.ck-search-form { position: relative; width: 100%; }
.ck-search-inner {
    display: flex;
    align-items: center;
    background: var(--ck-white);
    border: 1px solid var(--ck-border);
    border-radius: var(--ck-radius);
    overflow: hidden;
    transition: border-color 0.2s, box-shadow 0.2s;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}
.ck-search-inner:focus-within {
    border-color: var(--ck-green);
    box-shadow: 0 0 0 3px rgba(26,124,62,0.12);
}
.ck-search-icon { display: flex; align-items: center; padding: 0 12px; color: #888; flex-shrink: 0; }
.ck-search-icon svg { width: 18px; height: 18px; }
.ck-search-inner:focus-within .ck-search-icon { color: var(--ck-green); }

.ck-search-input {
    flex: 1; border: none !important; outline: none !important;
    background: transparent !important; padding: 4px 8px !important;
    font-size: 15px !important; color: var(--ck-text) !important;
    font-family: var(--ck-font) !important; box-shadow: none !important;
    -webkit-appearance: none;
}
.ck-search-input::placeholder { color: #aaa; }
.ck-search-input::-webkit-search-cancel-button { -webkit-appearance: none; }

.ck-search-btn {
    background-color: var(--ck-green) !important; color: var(--ck-white) !important;
    border: none !important; padding: 13px 20px !important; font-size: 14px !important;
    font-weight: 600 !important; cursor: pointer !important;
    font-family: var(--ck-font) !important; transition: background-color 0.2s !important;
    flex-shrink: 0; height: auto; border-radius: 0; letter-spacing: 0.3px;
}
.ck-search-btn:hover { background-color: var(--ck-green-dark) !important; }

/* Live Results */
.ck-live-results {
    position: absolute; top: calc(100% + 4px); left: 0; right: 0;
    background: var(--ck-white); border: 1px solid var(--ck-border);
    border-radius: var(--ck-radius); box-shadow: var(--ck-shadow);
    z-index: 99999; overflow: hidden;
    animation: ck-dropdown 0.2s ease;
}
@keyframes ck-dropdown { from { opacity:0; transform:translateY(-6px); } to { opacity:1; transform:translateY(0); } }

.ck-results-list { list-style: none !important; margin: 0 !important; padding: 6px 0 !important; max-height: 320px; overflow-y: auto; }
.ck-result-item { margin: 0 !important; padding: 0 !important; border: none !important; }
.ck-result-link {
    display: flex !important; align-items: center !important; gap: 12px !important;
    padding: 10px 14px !important; text-decoration: none !important; color: var(--ck-text) !important;
    transition: background-color 0.15s !important;
}
.ck-result-link:hover { background-color: var(--ck-green-light) !important; }
.ck-result-img { width: 44px !important; height: 44px !important; object-fit: cover !important; border-radius: 4px !important; border: 1px solid var(--ck-border) !important; flex-shrink: 0 !important; }
.ck-result-info { display: flex !important; flex-direction: column !important; gap: 3px !important; flex: 1 !important; min-width: 0 !important; }
.ck-result-title { font-size: 14px !important; font-weight: 600 !important; color: #222 !important; white-space: nowrap !important; overflow: hidden !important; text-overflow: ellipsis !important; display: block !important; }
.ck-result-price { font-size: 13px !important; color: var(--ck-green) !important; font-weight: 600 !important; }
.ck-result-price del { color: #999 !important; font-weight: 400 !important; margin-right: 4px !important; }

.ck-see-all {
    display: block !important; text-align: center !important; padding: 10px !important;
    background: var(--ck-green-light) !important; color: var(--ck-green) !important;
    font-size: 13px !important; font-weight: 600 !important; text-decoration: none !important;
    border-top: 1px solid var(--ck-border) !important; transition: background 0.15s !important;
}
.ck-see-all:hover { background: #d0ead8 !important; }
.ck-no-results { padding: 14px 16px !important; color: #777 !important; font-size: 14px !important; margin: 0 !important; text-align: center !important; }
.ck-loading { display: flex; align-items: center; justify-content: center; padding: 16px; color: var(--ck-green); gap: 8px; font-size: 14px; }

@media (max-width: 480px) {
    .ck-mini-cart { width: 290px; right: -10px; }
    .ck-search-btn { padding: 11px 14px !important; font-size: 13px !important; }
    .ck-cart-btn { padding: 9px 14px; font-size: 14px; }
}
