
:root {
  --ai-bg: #0d1f27;
        --ai-panel: #173542;
        --ai-panel-alt: #1f4655;
        --ai-user-bubble: #15c98a;
        --ai-user-text: #06271b;
        --ai-assistant-bubble: #1f3d4a;
        --ai-border: #275b6d;
        --ai-accent: #6fffbe;
        --ai-accent-dark: #35d894;
        --ai-text: #f1f9f7;
        --ai-text-dim: #b9d1ca;
}
.checkout-info-grid{
  display:grid;
  grid-template-columns: minmax(0,1fr) 340px;
  gap:40px;
}
@media (max-width: 992px){
  .checkout-info-grid{
    grid-template-columns: 1fr;
  }
}

.ci-summary-list{
  list-style:none;
  margin:0 0 10px 0;
  padding:0;
}
.ci-summary-list li{
  display:flex;
  justify-content:space-between;
  padding:.4rem 0;
  border-bottom:1px dashed #d6e8e1;
  font-size:.85rem;
}
.ci-summary-list li:last-child{ border-bottom:none; }
.ci-summary-list li.ci-total{
  font-size:.95rem;
  font-weight:600;
  border-bottom:2px solid #bfe9da;
  margin-top:.25rem;
  padding-top:.6rem;
}
.ci-input{
  background:#fff;
  border:1px solid #d6e8e1;
  border-radius:10px;
  font-size:.85rem;
  transition:border-color .15s, box-shadow .15s;
}
.ci-input:focus{
  border-color:#9ddfc9;
  box-shadow:0 0 0 .15rem rgba(157,223,201,.35);
}
.btn-accent{
  --bs-btn-color:#063c2c;
  --bs-btn-bg:var(--accent,#9ee7cc);
  --bs-btn-border-color:var(--accent,#9ee7cc);
  --bs-btn-hover-bg:#8fdcbf;
  --bs-btn-hover-border-color:#8fdcbf;
  font-weight:600;
  border-radius:12px;
}


                            .hero-search-form {
                                position: relative;
                            }

                            .hero-search-results {
                                position: absolute;
                                top: 100%;
                                left: 0;
                                width: 100%;
                                max-width: 400px;
                                background: rgba(18, 36, 56, 0.9);
                                backdrop-filter: blur(6px);
                                border: 2px solid #6fffbe;
                                border-radius: 18px;
                                padding: 6px 0;
                                margin-top: 10px;
                                z-index: 40;
                                box-shadow: 0 10px 28px -4px rgba(0, 0, 0, 0.35), 0 4px 8px -2px rgba(0, 0, 0, 0.25);
                            }

                            .hero-search-results.hidden {
                                display: none;
                            }

                            .hero-search-results ul {
                                list-style: none;
                                margin: 0;
                                padding: 0;
                                max-height: 340px;
                                overflow-y: auto;
                            }

                            .hero-search-results li {
                                display: flex;
                                flex-direction: column;
                                gap: 2px;
                                cursor: pointer;
                                padding: 10px 16px;
                                transition: background .15s;
                                font-size: 14px;
                                line-height: 1.25;
                            }

                            .hero-search-results li:hover,
                            .hero-search-results li.active {
                                background: rgba(111, 255, 190, 0.12);
                            }

                            .hero-search-results li .name {
                                font-weight: 600;
                                color: #fff;
                            }

                            .hero-search-results li .price {
                                font-size: 12px;
                                font-weight: 500;
                                color: #6fffbe;
                            }

                            .hero-search-results li .excerpt {
                                font-size: 11px;
                                color: #d2dde6;
                                white-space: nowrap;
                                overflow: hidden;
                                text-overflow: ellipsis;
                            }

                            .hero-search-results .view-all {
                                border-top: 1px solid rgba(111, 255, 190, 0.25);
                                margin-top: 4px;
                                padding: 6px 16px 2px;
                                font-size: 11px;
                                text-align: right;
                                color: #89fdd1;
                            }

                            .hero-search-results::-webkit-scrollbar {
                                width: 8px;
                            }

                            .hero-search-results::-webkit-scrollbar-track {
                                background: transparent;
                            }

                            .hero-search-results::-webkit-scrollbar-thumb {
                                background: rgba(111, 255, 190, 0.35);
                                border-radius: 20px;
                            }

                            .hero-search-form input.form-control {
                                border: 2px solid #6fffbe !important;
                                background: rgba(255, 255, 255, 0.08);
                                color: #fff;
                                border-radius: 30px;
                                font-size: 1.1rem;
                                box-shadow: 0 2px 12px 0 rgba(23, 44, 69, 0.08);
                            }

                            .hero-search-form input.form-control::placeholder {
                                color: #fff;
                                opacity: 1;
                            }

                            .subcat-pills {
                                display: flex;
                                flex-wrap: wrap;
                                gap: 8px;
                                margin-top: 12px;
                            }
                            .subcat-pill {
                                background: rgba(255, 255, 255, 0.08);
                                border: 1px solid #6fffbe;
                                border-radius: 30px;
                                padding: 6px 16px;
                                font-size: 0.85rem;
                                color: black;
                                cursor: pointer;
                                transition: background .15s, border-color .15s;
                            }
                            .subcat-pill:hover {
                                background: rgba(111, 255, 190, 0.12);
                                border-color: #89fdd1;
                            }
                            .subcat-active {
                                background: #6fffbe;
                                color: #063c2c;
                                border-color: #6fffbe;
                            }

                            .ask-ai-ribbon {
            position: fixed;
            top: 50%;
            left: 0;
            transform: translateY(-50%) rotate(-90deg);
            transform-origin: left top;
            background: #6fffbe;
            /* active accent color */
            color: #0a1f17;
            text-decoration: none;
            font-weight: 600;
            font-size: .72rem;
            letter-spacing: .5px;
            padding: 10px 22px 9px;
            border-radius: 0 0 12px 12px;
            box-shadow: 0 6px 18px -4px rgba(0, 0, 0, .35), 0 2px 6px -2px rgba(0, 0, 0, .3);
            z-index: 1200;
            display: flex;
            align-items: center;
            gap: 6px;
            cursor: pointer;
            transition: .25s;
        }

        .ask-ai-ribbon:before {
            content: '🤖';
            font-size: .9rem;
            line-height: 1;
        }

        .ask-ai-ribbon:hover {
            filter: brightness(.95);
            /*transform: translateY(-50%) rotate(-90deg) translateX(2px);*/
        }

        @media (max-width: 992px) {
            .ask-ai-ribbon {
                transform: none;
                left: 8px;
                top: auto;
                bottom: 18px;
                border-radius: 14px;
                padding: 10px 16px;
            }
        }

        .top-info-bar{
            background:#bdf1de;
            color:#172b45;
            font-size:.75rem;
            letter-spacing:.3px;
            padding:6px 20px 5px;
            border-bottom:1px solid #a3ddca;
            position: relative;
            z-index: 999 !important;
        }
        .top-info-bar .top-link{
            color:#172b45;
            text-decoration:none;
            font-weight:500;
            display:inline-flex;
            align-items:center;
            gap:4px;
        }
        .top-info-bar .top-link:hover{ text-decoration:underline; }
        .top-info-bar .social-wrap .social-link{
            color:#172b45;
            display:flex;
            align-items:center;
            justify-content:center;
            width:30px;
            height:30px;
            border-radius:50%;
            background:rgba(23,43,69,0.08);
            text-decoration:none;
            font-size:14px;
            transition:.25s;
        }
        .top-info-bar .social-wrap .social-link:hover{
            background:#172b45;
            color:#bdf1de;
        }
        @media (max-width: 768px){
            .top-info-bar{
                padding:6px 14px 5px;
            }
        }

        .recommend-card.multi .rc-products{display:grid;gap:12px;}
@media(min-width:680px){.recommend-card.multi .rc-products{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));}}
.recommend-card.multi .rc-item{background:#234d5c;border:1px solid #2d5f70;padding:10px 12px;border-radius:10px;}
                        


    .chat-shell {
        background: var(--ai-bg);
        border: 1px solid var(--ai-border);
        border-radius: 22px;
        padding: 20px 22px 16px;
        box-shadow: 0 10px 30px -10px rgba(0, 0, 0, .55), 0 4px 12px -4px rgba(0, 0, 0, .4);
        color: var(--ai-text);
    }

    .chat-messages {
        max-height: 540px;
        overflow-y: auto;
        padding-right: 4px;
        scroll-behavior: smooth;
    }

    .chat-messages::-webkit-scrollbar {
        width: 8px;
    }

    .chat-messages::-webkit-scrollbar-thumb {
        background: rgba(111, 255, 190, .45);
        border-radius: 4px;
    }

    .chat-empty {
        padding: 40px 10px;
        text-align: center;
        color: var(--ai-text-dim);
        font-size: .9rem;
    }

    .chat-message {
        display: flex;
        flex-direction: column;
        margin-bottom: 18px;
    }

    .chat-message .bubble {
        padding: 12px 16px;
        border-radius: 18px;
        font-size: .9rem;
        line-height: 1.4rem;
        max-width: 100%;
        background: var(--ai-assistant-bubble);
        color: var(--ai-text);
        word-break: break-word;
        border: 1px solid #224d5c;
    }

    .chat-message.user .bubble {
        background: var(--ai-user-bubble);
        color: var(--ai-user-text);
        border: 1px solid var(--ai-user-bubble);
        align-self: flex-end;
        border-bottom-right-radius: 6px;
        box-shadow: 0 4px 14px -4px rgba(21, 201, 138, .65);
    }

    .chat-message.assistant .bubble {
        background: var(--ai-assistant-bubble);
        border-bottom-left-radius: 6px;
    }

    .typing .dot {
        width: 7px;
        height: 7px;
        border-radius: 50%;
        display: inline-block;
        background: var(--ai-accent);
        margin: 0 3px;
        animation: blink 1s infinite ease-in-out;
    }

    .typing .dot:nth-child(2) {
        animation-delay: .2s;
    }

    .typing .dot:nth-child(3) {
        animation-delay: .4s;
    }

    @keyframes blink {

        0%,
        80%,
        100% {
            opacity: .25;
            transform: translateY(0);
        }

        40% {
            opacity: 1;
            transform: translateY(-3px);
        }
    }

    .chat-input-bar {
        margin-top: 12px;
        background: var(--ai-panel);
        border: 1px solid var(--ai-border);
        border-radius: 16px;
        display: flex;
        align-items: flex-end;
        padding: 12px 12px 10px;
        gap: 10px;
    }

    .chat-input-bar textarea {
        background: transparent;
        border: none;
        outline: none;
        resize: none;
        color: var(--ai-text);
        width: 100%;
        font-size: .85rem;
        line-height: 1.25rem;
        max-height: 160px;
        overflow-y: auto;
    }

    .chat-input-bar textarea::placeholder {
        color: var(--ai-text-dim);
    }

    .chat-input-bar textarea::-webkit-scrollbar {
        width: 6px;
    }

    .chat-input-bar textarea::-webkit-scrollbar-thumb {
        background: rgba(111, 255, 190, .45);
        border-radius: 4px;
    }

    .send-btn {
        background: var(--ai-accent);
        border: none;
        color: #06271b;
        font-weight: 600;
        font-size: .75rem;
        letter-spacing: .5px;
        border-radius: 20px;
        padding: 10px 18px;
        transition: .25s;
        display: flex;
        align-items: center;
        gap: 4px;
    }

    .send-btn:disabled {
        opacity: .55;
        cursor: not-allowed;
    }

    .send-btn:hover:not(:disabled) {
        background: var(--ai-accent-dark);
        transform: translateY(-1px);
    }

    .recommend-card {
        margin-top: 10px;
        background: var(--ai-panel-alt);
        border: 1px solid var(--ai-border);
        border-radius: 14px;
        padding: 12px 14px 14px;
        color: var(--ai-text);
        max-width: 520px;
        font-size: .75rem;
    }

    .recommend-card.multi {
        display: flex;
        flex-direction: column;
        gap: 10px;
    }

    .recommend-card .rc-head {
        font-size: .55rem;
        text-transform: uppercase;
        letter-spacing: .9px;
        font-weight: 600;
        color: var(--ai-accent);
        margin-bottom: 6px;
    }

    .recommend-card h6 a {
        color: var(--ai-accent);
        text-decoration: none;
    }

    .recommend-card h6 a:hover {
        text-decoration: underline;
    }

    .price-tag {
        font-weight: 600;
        color: var(--ai-accent);
        font-size: .85rem;
    }

    .btn-accent {
        background: var(--ai-accent);
        color: #06271b;
        font-size: .65rem;
        font-weight: 600;
        border-radius: 16px;
        padding: 6px 14px;
        text-decoration: none;
        border: none;
    }

    .btn-accent:hover {
        background: var(--ai-accent-dark);
        color: #041912;
    }

    .fade-enter-active,
    .fade-leave-active {
        transition: opacity .25s;
    }

    .fade-enter,
    .fade-leave-to {
        opacity: 0;
    }

    @media (max-width:768px) {
        .chat-shell {
            padding: 16px 16px 14px;
        }

        .chat-messages {
            max-height: 60vh;
        }
    }

    


    