/* ============================================================
   DEXCALOR — Custom CSS
   Font: Montserrat (self-hosted)
   Primary: #004d80
   ============================================================ */

/* Self-hosted Montserrat font */
@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/montserrat/Montserrat-Regular.woff2') format('woff2');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/montserrat/Montserrat-Medium.woff2') format('woff2');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/montserrat/Montserrat-SemiBold.woff2') format('woff2');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/montserrat/Montserrat-Bold.woff2') format('woff2');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

/* Root Variables */
:root {
    --color-primary: #004d80;
    --color-primary-dark: #003a60;
    --color-primary-light: #e8f2f9;
    --color-danger: #dc3545;
    --font-main: 'Montserrat', sans-serif;
}

/* Base */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    font-family: var(--font-main);
    font-size: 15px;
    color: #1a1a1a;
    background-color: #fff;
    line-height: 1.6;
}

/* Top Bar */
.top-bar {
    background-color: #1a1a1a;
    font-size: 0.82rem;
}
.top-menu a { font-size: 0.82rem; }
.top-menu a:hover { opacity: 0.7; }

/* Header */
.main-header { border-bottom: 1px solid #e8e8e8; }
.logo-link img { transition: opacity 0.2s; }
.logo-link:hover img { opacity: 0.85; }

/* Search */
.search-container .form-control:focus { box-shadow: none; border-color: var(--color-primary); }

/* Header utils */
.header-utils a { transition: color 0.2s; }
.header-utils a:hover { color: var(--color-primary) !important; }
.cart-count { background-color: var(--color-primary) !important; }

/* Categories Nav */
.categories-nav {
    z-index: 100;
    border-bottom: 2px solid #f0f0f0;
}
.categories-nav .nav-link {
    font-size: 0.88rem;
    font-weight: 600;
    letter-spacing: 0.01em;
    transition: color 0.2s;
    position: relative;
}
.categories-nav .nav-link::after {
    content: '';
    position: absolute;
    bottom: 0; left: 50%; right: 50%;
    height: 2px;
    background: var(--color-primary);
    transition: all 0.3s ease;
}
.categories-nav .nav-link:hover::after,
.categories-nav .nav-link.active::after { left: 0; right: 0; }
.categories-nav .nav-link:hover { color: var(--color-primary) !important; }

/* ============================================================
   HERO SLIDER
   ============================================================ */
.hero-slider { position: relative; overflow: hidden; }
.carousel-item {
    background-size: cover;
    background-position: center;
    height: calc(100vh - 150px);
    min-height: 500px;
    max-height: 700px;
}

/* ============================================================
   FEATURES SECTION
   ============================================================ */
.features-section { border-bottom: 1px solid #f0f0f0; }
.feature-icon-circle {
    width: 64px; height: 64px;
    background-color: var(--color-primary-light);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color 0.3s, transform 0.3s;
}
.feature-icon-circle:hover {
    background-color: var(--color-primary);
    transform: scale(1.08);
}
.feature-icon-circle:hover img { filter: brightness(0) invert(1); }

/* ============================================================
   PRODUCT CARDS
   ============================================================ */
.product-card {
    border: 1px solid #f0f0f0;
    transition: box-shadow 0.3s, transform 0.3s;
    border-radius: 8px;
}
.product-card:hover {
    box-shadow: 0 8px 30px rgba(0,0,0,0.12) !important;
    transform: translateY(-3px);
}
.product-img-wrap { min-height: 180px; overflow: hidden; }
.product-img-wrap img {
    transition: transform 0.4s ease;
    mix-blend-mode: multiply;
}
.product-card:hover .product-img-wrap img { transform: scale(1.04); }

.add-to-cart-btn {
    background-color: var(--color-primary) !important;
    min-width: 60px;
    transition: background-color 0.2s;
    cursor: pointer;
}
.add-to-cart-btn:hover { background-color: var(--color-primary-dark) !important; }

/* ============================================================
   CATEGORY BANNER
   ============================================================ */
.category-banner {
    background-size: cover;
    background-position: center;
    height: 460px;
    position: relative;
    overflow: hidden;
}
.category-banner .overlay {
    position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0.3) 0%, rgba(0,0,0,0.7) 100%);
}
.category-banner > div:last-child { position: relative; z-index: 2; }

/* ============================================================
   SIDEBAR FILTERS
   ============================================================ */
.filter-card { border-radius: 12px; }
.form-check-input:checked { background-color: var(--color-primary); border-color: var(--color-primary); }
.form-range::-webkit-slider-thumb { background: var(--color-primary); }

/* ============================================================
   BREADCRUMB
   ============================================================ */
.breadcrumb-item + .breadcrumb-item::before { content: "›"; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn-primary {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
}
.btn-primary:hover {
    background-color: var(--color-primary-dark);
    border-color: var(--color-primary-dark);
}
.btn-outline-primary { color: var(--color-primary); border-color: var(--color-primary); }
.btn-outline-primary:hover { background-color: var(--color-primary); border-color: var(--color-primary); }
.btn-dexcalor {
    background-color: var(--color-primary);
    color: #fff;
    border: none;
    transition: background-color 0.2s, transform 0.2s;
}
.btn-dexcalor:hover { background-color: var(--color-primary-dark); color: #fff; transform: translateY(-1px); }

/* ============================================================
   PRODUCT DETAIL
   ============================================================ */
.thumbnail-box {
    transition: all 0.2s ease;
    border: 2px solid transparent !important;
    cursor: pointer;
}
.thumbnail-box:hover { border-color: #dee2e6 !important; }
.thumbnail-box.active-thumbnail { border-color: var(--color-primary) !important; }

/* ============================================================
   CART & CHECKOUT
   ============================================================ */
.cart-item-row { transition: background 0.2s; }
.cart-item-row:hover { background: #fafafa; }
.order-summary-card { background: #f8f9fa; border-radius: 16px; }

/* ============================================================
   ACCOUNT
   ============================================================ */
.account-sidebar .nav-link {
    font-weight: 500;
    border-radius: 8px;
    color: #444;
    transition: all 0.2s;
}
.account-sidebar .nav-link:hover,
.account-sidebar .nav-link.active {
    background: var(--color-primary-light);
    color: var(--color-primary);
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer-links a:hover { color: #fff !important; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 768px) {
    .carousel-item { height: 70vw; min-height: 300px; }
    .category-banner { height: 300px; }
    .top-bar .top-menu { display: none; }
}

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

/* ============================================================
   FORM STYLING
   ============================================================ */
.form-control:focus, .form-select:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 0.2rem rgba(0,77,128,0.15);
}

/* Price badge */
.promo-badge {
    background: var(--color-danger);
    color: #fff;
    font-size: 0.7rem;
    padding: 3px 8px;
    border-radius: 4px;
}

/* Pagination */
.pagination .page-item.active .page-link {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
}
.pagination .page-link { color: var(--color-primary); }
.pagination .page-link:hover { color: var(--color-primary-dark); }

/* Status badges */
.badge-status-noua        { background-color: #0d6efd; color: #fff; }
.badge-status-in_procesare { background-color: #fd7e14; color: #fff; }
.badge-status-expediata   { background-color: #0dcaf0; color: #000; }
.badge-status-livrata     { background-color: #198754; color: #fff; }
.badge-status-anulata     { background-color: #dc3545; color: #fff; }
