/*
Theme Name: Styletrim - Barber and Hair Salon Website Template
Theme URI: https://templatesjungle.com/
Author: TemplatesJungle
Author URI: https://templatesjungle.com/
Description: Styletrim is specially designed product packaged for Barber and Hair Salon by TemplatesJungle.
Version: 1.1
*/

/*--------------------------------------------------------------
This is main CSS file that contains custom style rules used in this template
--------------------------------------------------------------*/

/*------------------------------------*\
    Table of contents
\*------------------------------------*/

/*------------------------------------------------

CSS STRUCTURE:

1. VARIABLES

2. GENERAL TYPOGRAPHY
  2.1 General Styles
  2.2 Background Color
  2.3 Section
    - Section Paddings
    - Section Margins
    - Section Title
    - Content width
  2.4 Buttons
    - Primary Buttons
    - Outline Buttons

3. CONTENT ELEMENTS
  - Dropdown
  - Breadcrumbs
  - Form
  - Svg Color
  - Swiper
  - Zoom Effect
  - Pagination

4. SITE STRUCTURE
  4.1 Header
  4.2 Slider Section
  4.3 Our Services
  4.4 About Section
  4.5 Popular Products Section
  4.6 Footer Section

5. OTHER PAGES STYLE
  5.1 Faqs Page
  5.2 Price Plan page
  5.3 Team page
  5.4 Reviews page
  5.5 Single Product page

    
/*--------------------------------------------------------------
/** 1. VARIABLES
--------------------------------------------------------------*/


.navbar-menu {
  display: flex;
  align-items: center;
  gap: 10px;
  list-style: none;
  margin: 0;
  padding: 0;
  flex-wrap: wrap; /* IMPORTANTE */
}

.navbar-menu li {
  flex: 1 1 auto;
}

.navbar-menu a {
  display: block;
  padding: 10px 14px;
  text-decoration: none;
  border-radius: 8px;
  white-space: normal; /* permite salto de línea */
  text-align: center;
}

/* MOBILE */
@media (max-width: 768px) {

  .navbar-menu {
      flex-direction: column;
      width: 100%;
  }

  .navbar-menu li {
      width: 100%;
  }

  .navbar-menu a {
      width: 100%;
  }
}

/* Contenedor relativo */
.image-holder {
  overflow: hidden;
}

/* Overlay oscuro */
.image-holder::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.5);
  opacity: 0;
  transition: 0.3s ease;
}

/* Íconos ocultos inicialmente */
.social-links {
  opacity: 0;
  transform: translateY(20px);
  transition: 0.3s ease;
  z-index: 2;
}

/* HOVER */
.image-holder:hover::after {
  opacity: 1;
}

.image-holder:hover .social-links {
  opacity: 1;
  transform: translateY(0);
}

.social-links a {
  font-size: 18px;
  transition: 0.2s;
}

.social-links a:hover {
  transform: scale(1.2);
  color: #f5c518; /* dorado premium */
}

.team-member img {
  width: 100%;
  height: 260px;
  object-fit: cover;
  object-position: top; /* 👈 clave */
}

.member-info {
  min-height: 80px;
}

:root {
  --accent-color: #11120D;
  --secondary-color: #796d4c;
  --black-color: #3C3C3C;
  --light-black-color: #343536;
  --dark-color: #797876;
  --primary-color: #11120D;
  --primary-color-200: #E8F0F1;
  --primary-color-400: #c4e9ed;
  --gray-color: #777F81;
  --light-color: #FFFFFF;

  --bs-dark-rgb: 87, 87, 87;
  --bs-gray-100: #EEEFEF;
  --bs-gray-300: #DCDCDC;
  --bs-primary-text-emphasis: var(--primary-color);
  --bs-primary: #11120D;
  --bs-light-rgb: 255, 255, 255;
  --bs-primary-rgb: 17, 18, 13;
  --bs-secondary-rgb: 121, 109, 76;
  --swiper-theme-color: #111 !important;
  --cadet-blue-color: #9AB4B7;
}

/* Fonts */
:root {
  --heading-font: "Oswald", sans-serif;
  --body-font: "Source Sans 3", sans-serif;
}

/*----------------------------------------------*/
/* 2 GENERAL TYPOGRAPHY
/*----------------------------------------------*/

/* 2.1 General Styles
/*----------------------------------------------*/
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

html {
  box-sizing: border-box;
}

body {
  background-color: #ffffff;
  font-family: var(--body-font);
  font-size: 18px;
  font-weight: 400;
  line-height: 164%;
  letter-spacing: 0.40px;
  color: var(--dark-color);
  margin: 0;
}

p {
  color: var(--dark-color);
}

a {
  color: inherit;
  text-decoration: none;
  transition: 0.3s ease-in-out;
  text-decoration: none;

}

a:hover {
  color: var(--primary-color);
}


/*--------------------------------------------------------------
/** 2.3 Section
--------------------------------------------------------------*/
/* - Section Padding
--------------------------------------------------------------*/
.padding-small {
  padding-top: 6em;
  padding-bottom: 6em;
}

.padding-medium {
  padding-top: 6em;
  padding-bottom: 6em;
}

.padding-large {
  padding-top: 12em;
  padding-bottom: 12em;
}

/* - Section Margin
--------------------------------------------------------------*/
.margin-small {
  margin-top: 8.125em;
  margin-bottom: 8.125em;
}

.margin-medium {
  margin-top: 10em;
  margin-bottom: 10em;
}

.margin-large {
  margin-top: 12em;
  margin-bottom: 12em;
}


/* - Section Title
--------------------------------------------------------------*/
h1,
h2,
h3,
h4,
h5,
h6 {
  color: var(--black-color);
  font-family: var(--heading-font);
  text-transform: capitalize;
  font-weight: 500;
  letter-spacing: 0.0675rem;
}


/* - Content width
--------------------------------------------------------------*/
.container-md {
  max-width: 1465px;
}

.container-lg {
  max-width: 1750px;
}


/*--------------------------------------------------------------
/** 2.4 Buttons
--------------------------------------------------------------*/

.btn {
  padding: 15px 35px;
  text-transform: uppercase;
  transition: all 0.4s ease-in-out;
  font-weight: 500;
  letter-spacing: 0.0675rem;
  border-radius: 0;
}

/* Primary Buttons */
.btn-primary {
  --bs-btn-color: #fff;
  --bs-btn-bg: var(--accent-color);
  --bs-btn-border-color: var(--accent-color);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--secondary-color);
  --bs-btn-hover-border-color: var(--secondary-color);
  --bs-btn-focus-shadow-rgb: 49, 132, 253;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: var(--secondary-color);
  --bs-btn-active-border-color: var(--secondary-color);
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: var(--secondary-color);
  --bs-btn-disabled-border-color: #df808f;
}

.btn-outline-primary {
  --bs-btn-color: var(--accent-color);
  --bs-btn-border-color: var(--accent-color);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--accent-color);
  --bs-btn-hover-border-color: var(--accent-color);
  --bs-btn-focus-shadow-rgb: 13, 110, 253;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: var(--accent-color);
  --bs-btn-active-border-color: var(--accent-color);
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: var(--accent-color);
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: var(--accent-color);
  --bs-gradient: none;
}

.btn-check:active+.btn-primary:focus,
.btn-check:checked+.btn-primary:focus,
.btn-primary.active:focus,
.btn-primary:active:focus,
.show>.btn-primary.dropdown-toggle:focus {
  box-shadow: none;
}

/*--------------------------------------------------------------
/** 3.CONTENT ELEMENTS
--------------------------------------------------------------*/

/* Dropdown
------------------------------------------------------------- */
.dropdown-item {
  color: var(--black-color);
  font-family: var(--heading-font);
  font-weight: 300;
  /* padding: 0px 18px; */
  font-size: 16px;
}

.dropdown-item.active,
.dropdown-item:active {
  color: var(--bs-dropdown-link-hover-color);
  text-decoration: none;
  background-color: var(--bs-dropdown-link-hover-bg);
}

/* Breadcrumb
------------------------------------------------------------- */
.breadcrumb-item+.breadcrumb-item::before {
  color: var(--light-color);
}

/* Form
------------------------------------------------------------- */
.form-check-input:checked {
  background-color: var(--accent-color);
  border-color: var(--accent-color);
  box-shadow: none;
}

.form-check-input:focus {
  border-color: var(--accent-color);
  outline: 0;
  box-shadow: none;
}

.form-control:focus,
.form-select:focus {
  border-color: var(--dark-color);
  outline: 0;
  box-shadow: none;
}

input,
select,
textarea {
  border-color: var(--dark-color);
  outline: 0;
  box-shadow: none;
}

select:focus {
  box-shadow: none;
}


/* Svg Color
------------------------------------------------------------- */
svg.light-color {
  color: var(--light-color);
}

svg.dark-color {
  color: var(--dark-color);
}

svg.light-blue-color {
  color: #5BC4F1;
}

svg.primary-color {
  color: var(--primary-color);
}

svg.accent-color {
  color: var(--accent-color);
}

svg.primary-color-500 {
  color: var(--bs-primary-rgb);
}

/* Swiper
------------------------------------------------------------- */
/* Swiper */
.swiper-pagination {
  position: unset !important;
  padding-top: 45px;
}

.swiper-pagination span.swiper-pagination-bullet {
  width: 18px;
  height: 18px;
  background-color: var(--accent-color);
  opacity: 0.2;

}

.swiper-pagination span.swiper-pagination-bullet:hover,
.swiper-pagination span.swiper-pagination-bullet.swiper-pagination-bullet-active {
  background: var(--accent-color);
  opacity: 1;
}

/* -Zoom Effect
------------------------------------------*/
.zoom-effect {
  position: relative;
  overflow: hidden;
}

.zoom-effect img {
  max-width: 100%;
  -webkit-transition: 0.6s ease-out;
  -moz-transition: 0.6s ease-out;
  transition: 0.6s ease-out;
}

.zoom-effect:hover img {
  -webkit-transform: scale(1.1, 1.1);
  -moz-transform: scale(1.1, 1.1);
  transform: scale(1.1, 1.1);
}

.zoom-effect:before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  position: absolute;
  z-index: 2;
  opacity: 0;
  -moz-transition: 0.5s ease;
  -webkit-transition: 0.5s ease;
  transition: 0.5s ease;
}

.zoom-effect:hover:before {
  opacity: 1;
  cursor: pointer;
}


/* ------ Pagination ------*/
.pagination {
  --bs-pagination-padding-x: 0.75rem;
  --bs-pagination-padding-y: 0.375rem;
  --bs-pagination-font-size: 1rem;
  --bs-pagination-color: var(--bs-body-color);
  --bs-pagination-bg: var(--bs-body-bg);
  --bs-pagination-border-width: 0;
  --bs-pagination-border-color: var(--bs-border-color);
  --bs-pagination-border-radius: 0;
  --bs-pagination-hover-color: var(--bs-light);
  --bs-pagination-hover-bg: var(--bs-primary);
  --bs-pagination-hover-border-color: var(--bs-border-color);
  --bs-pagination-focus-color: var(--bs-light);
  --bs-pagination-focus-bg: var(--bs-primary);
  --bs-pagination-focus-box-shadow: none;
  --bs-pagination-active-color: var(--bs-light);
  --bs-pagination-active-bg: var(--bs-primary);
  --bs-pagination-active-border-color: var(--bs-primary);
  --bs-pagination-disabled-color: var(--bs-primary-color);
  --bs-pagination-disabled-bg: var(--bs-primary-bg);
  --bs-pagination-disabled-border-color: var(--bs-border-color);
  display: flex;
  padding-left: 0;
  list-style: none;
}


/*----------------------------------------------*/
/* 4 SITE STRUCTURE */
/*----------------------------------------------*/

/* 4.1 Header
/*----------------------------------------------*/

a.nav-link {
  font-family: var(--heading-font);
  text-transform: capitalize;
  color: var(--black-color);
  font-size: 18px;
}

a.nav-link:focus {
  color: var(--accent-color);
}

a.nav-link.active,
a.nav-link:hover {
  color: var(--primary-color) !important;
  outline: none;
}

#primary-header .dropdown .search::after {
  content: none;
}

#primary-header .search-dropdown .dropdown-menu {
  width: 260px;
}

#primary-header .search-dropdown .dropdown-menu input {
  min-width: 100%;
}

#primary-header .search-dropdown .dropdown-menu button {
  padding: 0 12px;
  min-height: -webkit-fill-available;
  border-radius: 0.25rem;
}



/* 4.2 Slider Section
/*----------------------------------------------*/
section#slider .banner-content {
  width: 50%;
}

section#slider .main-slider-button-next,
.main-slider-button-prev {
  z-index: 111111;
  height: fit-content;
  opacity: 0.9;
}

section#slider .main-slider-button-next.swiper-button-disabled,
.main-slider-button-prev.swiper-button-disabled {
  opacity: 0.6;
}

.banner-title {
  color: #FFF;
  text-shadow: 1px 2px 4px rgba(0, 0, 0, 0.27);
}

@media only screen and (max-width: 999px) {
  section#slider .banner-content {
    width: 66%;
  }
}



/* 4.3 Services Section
/*----------------------------------------------*/

a.hover-color h4 {
  transition: all 0.5s ease-in-out;
}

a.hover-color h4:hover {
  color: var(--accent-color);
}


/* 
 4.4 About style
--------------------------------------------------------------*/

/*---- video section style start ----*/
/* color box style */
div#cboxOverlay {
  opacity: 0.8 !important;
}

.video .video-player {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

iconify-icon.video-icon {
  color: var(--bs-light);
  border-radius: 6.25rem;
  background: rgba(255, 255, 255, 0.35);
  transition: all 0.4s ease-in-out;
  animation: playAnimation 2s infinite alternate;
}


@keyframes playAnimation {
  0% {
    font-size: 35px;
  }

  100% {
    font-size: 60px;
  }
}



/* 4.5 Popular Products
------------------------------------------------------------- */
.product-item .btn-wishlist {
  display: block;
  z-index: 111;
  position: absolute;
  top: 10px;
  padding: 6px 10px;
  color: var(--bs-black);
  background: var(--bs-white);
  right: 10px;
  opacity: 0;
  transition: opacity 0.5s ease-in;
}

.product-item .btn-cart {
  display: block;
  z-index: 111;
  position: absolute;
  top: 60px;
  padding: 6px 10px;
  color: var(--bs-black);
  background: var(--bs-white);
  right: 10px;
  opacity: 0;
  transition: opacity 0.5s ease-in;
}

.product-item:hover .btn-wishlist,
.product-item:hover .btn-cart {
  opacity: 1;
}



/* 4.6 Footer Section
/*----------------------------------------------*/
iconify-icon.social-icon {
  font-size: 1.125rem;
  padding: 0.75rem;
  border-radius: 4.375rem;
  border: 1px solid var(--accent-color);
  color: var(--accent-color);
  transition: all 0.5s ease;
}

iconify-icon.social-icon:hover {
  color: #FFF;
  border: 1px solid var(--accent-color);
  background: var(--accent-color);
}



/*----------------------------------------------*/
/* 5 OTHER PAGES STYLE */
/*----------------------------------------------*/


/* --------------------------------------------------------------
5.1 Faqs Page
/*----------------------------------------------*/
.accordion-button {
  font-size: inherit;
}

.accordion .accordion-button::after {
  content: "";
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' class='plus' viewBox='0 0 16 16'%3E%3Cpath d='M8 4a.5.5 0 0 1 .5.5v3h3a.5.5 0 0 1 0 1h-3v3a.5.5 0 0 1-1 0v-3h-3a.5.5 0 0 1 0-1h3v-3A.5.5 0 0 1 8 4z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-size: 1.6rem;
  width: 1.5rem;
  height: 1.5rem;
}

.accordion .accordion-button:not(.collapsed)::after {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' class='minus' viewBox='0 0 16 16'%3E%3Cpath d='M4 8a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7A.5.5 0 0 1 4 8z'/%3E%3C/svg%3E");
  transform: rotate(0deg);
}


/*--------------------------------------------------------------
 5.2 Price Plan page style
  --------------------------------------------------------------*/
.plan-post {
  border: 1px solid var(--accent-color);

}

span.price-tick {
  color: var(--accent-color);
}

.price-option {
  height: 320px;
}


/* --------------------------------------------------------------
5.3  Team page style
------------------------------------------------------------- */
.team-member ul.social-links {
  top: 0;
}

.team-member ul li {
  padding: 5px;
  transform: rotatey(-90deg) perspective(100px);
  transform-origin: left;
  cursor: pointer;
  transition: .5s ease-in-out;
  background-color: var(--accent-color);
}

.team-member ul li:first-of-type {
  transition-delay: .3s;
}

.team-member ul li:nth-of-type(2) {
  transition-delay: 0.6s;
}

.team-member ul li:nth-of-type(3) {
  transition-delay: 0.9s;
}

.team-member ul li:last-of-type {
  transition-delay: 1.3s;
}

.team-member:hover ul li {
  transform: rotatey(0deg);
}


/*--------------------------------------------------------------
5.4 Reviews page style
--------------------------------------------------------------*/
.reviews-components {
  border: 1px solid var(--light-text-color);
  box-shadow: 0px 12px 90px rgba(12, 12, 12, 0.06);
  border-radius: 9px;
}

iconify-icon.quote {
  font-size: 60px;
  color: var(--accent-color);
}

.rate {
  color: var(--accent-color);
}




/*--------------------------------------------------------------
5.5 Single Product page style
--------------------------------------------------------------*/

.nav-tabs .nav-link {
  transition: all 0.1s ease-in;
  border-radius: 0px;
  color: var(--black-color);
}

.nav-tabs .nav-link.show .nav-link,
.nav-tabs .nav-link.active {
  background-color: transparent;
  border-color: transparent;
  transition: all 0.1s ease-in;
  color: var(--bs-primary);
}

.nav-tabs .nav-link:focus,
.nav-tabs .nav-link:hover {
  color: var(--bs-primary);
  isolation: isolate;
  border-color: transparent;
  transition: all 0.1s ease-in;
}

/* product-thumbnail-slider */
.product-thumbnail-slider {
  height: 600px;
}

.product-box {
  width: 25%;
}

.product-info .color-product-options .color-item {
  display: inline-block;
  vertical-align: top;
  width: 25px;
  height: 25px;
  cursor: pointer;
  border: 1px solid var(--bs-gray);
  padding: 1px;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  border-radius: 50%;
  margin: 0 3px;
}

.product-info .color-product-options .color-item span {
  border: 1px solid var(--bs-dark);
  display: block;
  width: 100%;
  height: 100%;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  border-radius: 50%;
}

@media screen and (max-width: 800px) {
  .product-box {
    width: 50%;
  }
}

aside {
    position: fixed;
    /* o absolute si lo quieres dentro de un contenedor */
    top: 0;
    left: 0;
    height: 100vh;
    width: 260px;

    z-index: 9999;
    /* 👈 clave */
}


/* ===================== SIDEBAR ===================== */
.sidebar {
    width: var(--sidebar);
    background: black;
    border-right: 1px solid #1a1200;
    display: flex;
    flex-direction: column;
    position: fixed;


    /* o absolute si lo quieres dentro de un contenedor */
    top: 0;
    left: 0;
    height: 100vh;
    width: 260px;

    z-index: 9999;
    /* 👈 clave */
}

.sidebar-logo {
    padding: 22px 18px 18px;
    border-bottom: 1px solid rgba(255, 255, 255, .08)
}

.sidebar-logo h1 {
    font-family: 'Playfair Display', serif;
    font-size: 18px;
    color: var(--gold);
    line-height: 1.2
}

.sidebar-logo span {
    font-size: 10px;
    color: rgba(200, 160, 90, .55);
    letter-spacing: 1.2px;
    text-transform: uppercase;
    display: block;
    margin-top: 3px
}

.nav-section {
    padding: 14px 0 6px
}

.nav-label {
    font-size: 9px;
    font-weight: 500;
    color: rgba(200, 160, 90, .4);
    text-transform: uppercase;
    letter-spacing: 1.2px;
    padding: 0 18px 8px
}

.nav-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 18px;
    text-decoration: none;
    color: rgba(220, 190, 140, .65);
    border-left: 2px solid transparent;
    font-size: 13px;
    transition: all .15s
}

.nav-item:hover {
    background: rgba(200, 131, 43, .12);
    color: #E8D5AA
}

.nav-item.active {
    background: rgba(200, 131, 43, .18);
    color: var(--gold);
    border-left-color: var(--gold);
    font-weight: 500
}

.nav-icon {
    width: 16px;
    text-align: center;
    flex-shrink: 0
}

.sidebar-footer {
    margin-top: auto;
    padding: 16px 18px;
    border-top: 1px solid rgba(255, 255, 255, .06)
}

.sidebar-footer a {
    font-size: 12px;
    color: rgba(200, 160, 90, .4);
    text-decoration: none
}

.sidebar-footer a:hover {
    color: #e05050
}

.main {
    margin-left: var(--sidebar);
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 100vh
}

.topbar {
    background: var(--bg2);
    border-bottom: 1px solid var(--border);
    padding: 13px 28px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: sticky;
    top: 0;
    z-index: 40;
    box-shadow: 0 1px 4px rgba(0, 0, 0, .06)
}

.topbar h2 {
    font-family: 'Playfair Display', serif;
    font-size: 18px;
    color: var(--gold-dim);
    font-weight: 500
}

.topbar-right {
    display: flex;
    gap: 10px;
    align-items: center
}

.content {
    padding: 28px;
    flex: 1
}

.btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    border-radius: var(--radius);
    font-size: 13px;
    cursor: pointer;
    border: 1px solid var(--border);
    background: var(--bg3);
    color: var(--text);
    font-family: 'Inter', sans-serif;
    text-decoration: none;
    transition: all .15s;
    line-height: 1;
    font-weight: 500
}

.btn:hover {
    border-color: var(--gold);
    color: var(--gold-dim)
}

.btn-primary {
    background: var(--gold);
    color: #fff;
    border-color: var(--gold);
    font-weight: 600
}

.btn-primary:hover {
    background: var(--gold-dim);
    border-color: var(--gold-dim);
    color: #fff
}

.btn-danger {
    background: var(--danger-bg);
    color: var(--danger);
    border-color: #f5c6c6
}

.btn-danger:hover {
    background: #FBDADA;
    border-color: var(--danger)
}

.btn-sm {
    padding: 5px 11px;
    font-size: 12px
}

.btn-icon {
    padding: 6px 10px
}

/* ===================== CARDS ===================== */
.card {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    margin-bottom: 24px;
    box-shadow: 0 1px 4px rgba(0, 0, 0, .05)
}

.card-header {
    padding: 14px 22px;
    border-bottom: 1px solid var(--border-soft);
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--bg3)
}

.card-header h3 {
    font-size: 11px;
    font-weight: 600;
    color: var(--gold-dim);
    letter-spacing: .8px;
    text-transform: uppercase
}

.card-body {
    padding: 22px
}

/* ===================== STATS ===================== */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
    margin-bottom: 26px
}

.stat-card {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 18px 20px;
    box-shadow: 0 1px 4px rgba(0, 0, 0, .04)
}

.stat-label {
    font-size: 11px;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: .8px;
    margin-bottom: 6px
}

.stat-value {
    font-size: 30px;
    font-weight: 600;
    color: var(--gold);
    font-family: 'Playfair Display', serif
}

.stat-sub {
    font-size: 11px;
    color: var(--text-dim);
    margin-top: 3px
}

/* ===================== TABLE ===================== */
.table-wrap {
    overflow-x: auto
}

table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px
}

thead tr {
    border-bottom: 2px solid var(--border-soft);
    background: var(--bg3)
}

th {
    text-align: left;
    padding: 10px 16px;
    font-size: 10px;
    font-weight: 600;
    color: var(--gold-dim);
    text-transform: uppercase;
    letter-spacing: .8px;
    white-space: nowrap
}

td {
    padding: 11px 16px;
    border-bottom: 1px solid var(--border-soft);
    color: var(--text);
    vertical-align: middle
}

tbody tr:last-child td {
    border-bottom: none
}

tbody tr:hover td {
    background: #FAF6EE
}

/* ===================== BADGES ===================== */
.badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 99px;
    font-size: 11px;
    font-weight: 500
}

.badge-active {
    background: var(--success-bg);
    color: var(--success);
    border: 1px solid #b8e0c8
}

.badge-inactive {
    background: var(--bg3);
    color: var(--text-dim);
    border: 1px solid var(--border)
}

/* ===================== AVATAR ===================== */
.avatar {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background: var(--gold-bg);
    border: 1px solid #DFC898;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 600;
    color: var(--gold-dim);
    flex-shrink: 0;
    font-family: 'Playfair Display', serif
}

.flex-row {
    display: flex;
    align-items: center;
    gap: 10px
}

.actions {
    display: flex;
    gap: 6px
}

/* ===================== FORMS ===================== */
.form-group {
    margin-bottom: 16px
}

.form-group label {
    display: block;
    font-size: 11px;
    color: var(--text-muted);
    margin-bottom: 6px;
    letter-spacing: .4px;
    text-transform: uppercase
}

.form-control {
    width: 100%;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 9px 12px;
    font-size: 13px;
    color: var(--text);
    font-family: 'Inter', sans-serif;
    transition: border-color .2s
}

.form-control:focus {
    outline: none;
    border-color: var(--gold);
    box-shadow: 0 0 0 3px rgba(200, 131, 43, .1)
}

.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px
}

.form-row-3 {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 14px
}

/* ===================== TOGGLE ===================== */
.toggle-wrap {
    display: flex;
    align-items: center;
    gap: 10px
}

.toggle-track {
    width: 38px;
    height: 21px;
    border-radius: 99px;
    background: var(--border);
    position: relative;
    cursor: pointer;
    transition: background .2s;
    flex-shrink: 0;
    border: 1px solid #C8BEA8
}

.toggle-track.on {
    background: var(--gold)
}

.toggle-thumb {
    width: 15px;
    height: 15px;
    background: #fff;
    border-radius: 50%;
    position: absolute;
    top: 2px;
    left: 2px;
    transition: left .2s;
    box-shadow: 0 1px 3px rgba(0, 0, 0, .2)
}

.toggle-track.on .toggle-thumb {
    left: 20px
}

/* ===================== SEARCH ===================== */
.table-toolbar {
    padding: 14px 22px;
    border-bottom: 1px solid var(--border-soft);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    background: var(--bg2)
}

.search-input {
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 7px 12px;
    font-size: 13px;
    color: var(--text);
    font-family: 'Inter', sans-serif;
    width: 240px
}

.search-input:focus {
    outline: none;
    border-color: var(--gold)
}

/* ===================== ALERT / FLASH ===================== */
.flash {
    padding: 11px 18px;
    border-radius: var(--radius);
    font-size: 13px;
    margin-bottom: 20px;
    border: 1px solid
}

.flash-success {
    background: var(--success-bg);
    color: var(--success);
    border-color: #b8e0c8
}

.flash-error {
    background: var(--danger-bg);
    color: var(--danger);
    border-color: #f5c6c6
}



/* ===================== CONFIG ===================== */
.config-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px
}

.schedule-row {
    display: flex;
    align-items: center;
    padding: 9px 0;
    border-bottom: 1px solid var(--border-soft)
}

.schedule-row:last-child {
    border: none
}

.day-label {
    width: 100px;
    font-size: 13px;
    color: var(--text-muted)
}

.time-range {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1
}

.time-range input {
    width: 96px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 6px 8px;
    font-size: 12px;
    color: var(--text);
    font-family: 'Inter', sans-serif
}

.time-range input:focus {
    outline: none;
    border-color: var(--gold)
}

/* ===================== PROMO SERVICES ===================== */
.promo-service-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 0;
    border-bottom: 1px solid var(--border-soft)
}

.promo-service-item:last-child {
    border: none
}

.promo-service-item label {
    flex: 1;
    font-size: 13px;
    cursor: pointer
}

.promo-service-item input[type=number] {
    width: 64px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 5px 8px;
    font-size: 13px;
    color: var(--text);
    font-family: 'Inter', sans-serif
}

/* ===================== MISC ===================== */
.empty-state {
    text-align: center;
    padding: 48px;
    color: var(--text-dim)
}

.divider {
    border: none;
    border-top: 1px solid var(--border);
    margin: 20px 0
}

.gold {
    color: var(--gold)
}

.text-muted {
    color: var(--text-muted)
}

.text-small {
    font-size: 12px
}

/* ===================== QUICK CARDS ===================== */
.quick-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px
}

.quick-card {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 20px;
    text-align: center;
    text-decoration: none;
    display: block;
    transition: all .2s;
    cursor: pointer
}

.quick-card:hover {
    border-color: var(--gold);
    background: var(--gold-bg);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(200, 131, 43, .12)
}

.quick-card .qicon {
    font-size: 26px;
    margin-bottom: 8px
}

.quick-card .qtitle {
    font-size: 13px;
    font-weight: 600;
    color: var(--gold-dim)
}

.quick-card .qsub {
    font-size: 11px;
    color: var(--text-dim);
    margin-top: 3px
}


.tab-content {
    display: none;
}

.tab-content.active {
    display: block;
}

:root {
    --primary-color: #1a1a1a;
    --secondary-color: #d4af37;
    --accent-color: #2c2c2c;
    --light-color: #f5f5f5;
    --text-color: #333;
    --text-light: #666;
    --border-color: #ddd;
    --success-color: #4caf50;
    --error-color: #f44336;
    
    --spacing-xs: 0.5rem;
    --spacing-sm: 1rem;
    --spacing-md: 1.5rem;
    --spacing-lg: 2rem;
    --spacing-xl: 3rem;
    
    --font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    --font-size-base: 1rem;
    --font-size-sm: 0.875rem;
    --font-size-lg: 1.25rem;
    --font-size-xl: 1.5rem;
    --font-size-2xl: 2rem;
    
    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.1);
    --shadow-md: 0 4px 6px rgba(0, 0, 0, 0.1);
    --shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.1);
    
    --border-radius: 8px;
    --border-radius-lg: 12px;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    font-family: var(--font-family);
    color: var(--text-color);
    background-color: #fff;
    line-height: 1.6;
}

.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 var(--spacing-md);
}

/* ==================== NAVEGACIÓN ==================== */

.navbar {
    min-height: 70px; /* ajusta a tu diseño */
}

.navbar {
    color: white;
    padding: var(--spacing-md) 0;
    box-shadow: var(--shadow-md);
    position: sticky;
    top: 0;
    z-index: 100;
}


.navbar .container {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.navbar-brand h1 {
    font-size: var(--font-size-xl);
    font-weight: 700;
    letter-spacing: 1px;
    color: var(--secondary-color);
}

.navbar-brand a {
    text-decoration: none;
}

.navbar-menu {
    display: flex;
    align-items: center; /* asegura alineación interna */
    gap: 15px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.navbar-menu a {
    color: white;
    text-decoration: none;
    font-weight: 600;
    transition: color 0.3s ease;
    text-decoration: none;
}


.navbar-menu a:hover {
    color: var(--secondary-color);
}



/* ==================== HERO SECTION ==================== */

.hero {
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--accent-color) 100%);
    color: white;
    padding: var(--spacing-xl) 0;
    text-align: center;
}

.hero h2 {
    font-size: var(--font-size-2xl);
    margin-bottom: var(--spacing-md);
    font-weight: 700;
}

.hero p {
    font-size: var(--font-size-lg);
    color: rgba(255, 255, 255, 0.9);
    margin-bottom: var(--spacing-lg);
}

/* ==================== SECCIONES ==================== */

.barbers-section,
.booking-section {
    padding: var(--spacing-xl) 0;
}

.barbers-section h3,
.booking-section h3 {
    font-size: var(--font-size-2xl);
    margin-bottom: var(--spacing-lg);
    color: var(--primary-color);
    text-align: center;
}

/* ==================== GRID DE BARBEROS ==================== */

.barbers-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--spacing-lg);
    margin-top: var(--spacing-lg);
}

.barber-card {
    background: white;
    border-radius: var(--border-radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-md);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    border: 1px solid var(--border-color);
}

.barber-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-lg);
}

.barber-photo {
    width: 100%;
    height: 250px;
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--accent-color) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.barber-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.photo-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--accent-color) 100%);
    color: var(--secondary-color);
    font-size: 3rem;
    font-weight: bold;
}

.barber-info {
    padding: var(--spacing-md);
}

.barber-info h4 {
    font-size: var(--font-size-lg);
    margin-bottom: var(--spacing-sm);
    color: var(--primary-color);
}

.specialties {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-xs);
    margin-bottom: var(--spacing-md);
}

.specialty-badge {
    background: var(--light-color);
    color: var(--primary-color);
    padding: var(--spacing-xs) var(--spacing-sm);
    border-radius: 20px;
    font-size: var(--font-size-sm);
    border: 1px solid var(--border-color);
}

.barber-contact {
    color: var(--text-light);
    font-size: var(--font-size-sm);
    margin-bottom: var(--spacing-md);
}

/* ==================== FORMULARIO DE RESERVA ==================== */

.booking-container {
    max-width: 100%;
    margin: 0 auto;
    background: white;
    padding: var(--spacing-lg);
    border-radius: var(--border-radius-lg);
    box-shadow: var(--shadow-md);
}

.booking-header {
    margin-bottom: var(--spacing-lg);
}

.btn-back {
    display: inline-block;
    color: var(--primary-color);
    text-decoration: none;
    font-weight: 500;
    margin-bottom: var(--spacing-md);
    transition: color 0.3s ease;
}

.btn-back:hover {
    color: var(--secondary-color);
}

.booking-header h2 {
    font-size: var(--font-size-xl);
    color: var(--primary-color);
}

.booking-form {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.form-section {
    padding: var(--spacing-md);
    background: var(--light-color);
    border-radius: var(--border-radius);
    border-left: 4px solid var(--secondary-color);
}

.form-section h3 {
    font-size: var(--font-size-lg);
    margin-bottom: var(--spacing-md);
    color: var(--primary-color);
}

/* ==================== LISTA DE SERVICIOS ==================== */

.services-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
}

.service-checkbox {
    display: flex;
    align-items: center;
    padding: var(--spacing-sm);
    background: white;
    border: 2px solid var(--border-color);
    border-radius: var(--border-radius);
    cursor: pointer;
    transition: all 0.3s ease;
}

.service-checkbox:hover {
    border-color: var(--secondary-color);
    background: rgba(212, 175, 55, 0.05);
}

.service-checkbox input[type="checkbox"] {
    margin-right: var(--spacing-sm);
    cursor: pointer;
    width: 18px;
    height: 18px;
    accent-color: var(--secondary-color);
}

.service-checkbox input[type="checkbox"]:checked + .service-name {
    color: var(--secondary-color);
    font-weight: 600;
}

.service-name, .promotion-name {
    flex: 1;
    font-weight: 500;
}

.service-duration {
    color: var(--text-light);
    font-size: var(--font-size-sm);
    margin-right: var(--spacing-md);
}

.service-price, .promotion-price {
    font-weight: 600;
    color: var(--secondary-color);
}

.duration-summary {
    background: white;
    padding: var(--spacing-md);
    border-radius: var(--border-radius);
    border: 1px solid var(--border-color);
}

.duration-summary p {
    margin: var(--spacing-xs) 0;
    font-size: var(--font-size-sm);
}

.duration-summary strong {
    color: var(--secondary-color);
    font-size: var(--font-size-lg);
}

/* ==================== INPUTS Y FORMULARIOS ==================== */

.form-group {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.form-group label {
    font-weight: 600;
    color: var(--primary-color);
}

.form-input {
    padding: var(--spacing-sm);
    border: 2px solid var(--border-color);
    border-radius: var(--border-radius);
    font-size: var(--font-size-base);
    font-family: var(--font-family);
    transition: border-color 0.3s ease;
}

.form-input:focus {
    outline: none;
    border-color: var(--secondary-color);
    box-shadow: 0 0 0 3px rgba(212, 175, 55, 0.1);
}

/* ==================== SLOTS DE TIEMPO ==================== */

.time-slots {
    background: white;
    padding: var(--spacing-md);
    border-radius: var(--border-radius);
    border: 1px solid var(--border-color);
}

.time-slots .placeholder {
    text-align: center;
    color: var(--text-light);
    padding: var(--spacing-md);
}

.time-slots-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
    gap: var(--spacing-sm);
}

.time-slot {
    position: relative;
    cursor: pointer;
}

.time-slot input[type="radio"] {
    display: none;
}

.time-slot span {
    display: block;
    padding: var(--spacing-sm);
    text-align: center;
    border: 2px solid var(--border-color);
    border-radius: var(--border-radius);
    background: white;
    font-weight: 500;
    transition: all 0.3s ease;
}

.time-slot input[type="radio"]:checked + span {
    background: var(--secondary-color);
    color: white;
    border-color: var(--secondary-color);
}

.time-slot:hover span {
    border-color: var(--secondary-color);
}

/* ==================== BOTONES ==================== */

.btn {
    padding: var(--spacing-sm) var(--spacing-md);
    border: none;
    border-radius: var(--border-radius);
    font-size: var(--font-size-base);
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    text-decoration: none;
    display: inline-block;
    text-align: center;
}

.btn-primary {
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--accent-color) 100%);
    color: white;
    border: none;
}

.btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

.btn-large {
    padding: var(--spacing-md) var(--spacing-lg);
    font-size: var(--font-size-lg);
    width: 100%;
    margin-top: var(--spacing-lg);
}

/* ==================== ALERTAS ==================== */

.alert {
    padding: var(--spacing-md);
    border-radius: var(--border-radius);
    margin-bottom: var(--spacing-md);
    font-weight: 500;
}

.alert-success {
    background: rgba(76, 175, 80, 0.1);
    color: #2e7d32;
    border-left: 4px solid var(--success-color);
}

.alert-error {
    background: rgba(244, 67, 54, 0.1);
    color: #c62828;
    border-left: 4px solid var(--error-color);
}

/* ==================== PIE DE PÁGINA ==================== */

.footer {
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--accent-color) 100%);
    color: white;
    padding: var(--spacing-lg) 0;
    text-align: center;
    margin-top: var(--spacing-xl);
}

.footer p {
    margin: 0;
    opacity: 0.9;
}

/* ==================== RESPONSIVE ==================== */

@media (max-width: 768px) {
    .barbers-grid {
        grid-template-columns: 1fr;
    }
    
    .time-slots-grid {
        grid-template-columns: repeat(auto-fill, minmax(70px, 1fr));
    }
    
    .booking-container {
        padding: var(--spacing-md);
    }
}

@media (max-width: 480px) {
    :root {
        --spacing-md: 1rem;
        --spacing-lg: 1.5rem;
    }
    
    .navbar-brand h1 {
        font-size: var(--font-size-lg);
    }
    
    .hero h2 {
        font-size: var(--font-size-lg);
    }
    
    .hero p {
        font-size: var(--font-size-base);
    }
}


@keyframes slideIn {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.barber-card {
    animation: slideIn 0.3s ease-out;
}

.btn-primary:active {
    transform: scale(0.98);
}
