/* ==========================
   PACIENTE AUTH
========================== */

body{
    margin:0;
    font-family: 'Segoe UI', sans-serif;
    background:linear-gradient(135deg,#f5f7fa,#e4efe9);
}

/* Centrado completo */
.auth-wrapper{
    min-height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:20px;
}

/* Card premium */
.auth-card{
    background:white;
    padding:40px;
    border-radius:20px;
    box-shadow:0 20px 40px rgba(0,0,0,.08);
    width:100%;
    max-width:420px;
    transition:.3s ease;
}

.auth-card:hover{
    transform:translateY(-3px);
}

.logo-img{
    width:150px;
}

/* Inputs */
.auth-card .form-control{
    border-radius:12px;
    padding:12px;
}

/* Botón personalizado (sobrescribe Bootstrap) */
.auth-card .btn-primary{
    background:#8ca590 !important;
    border:none !important;
    border-radius:12px;
    padding:12px;
    transition:.2s ease;
}

.auth-card .btn-primary:hover{
    background:#7a9480 !important;
}

/* ==========================
   AGENDA PACIENTE
========================== */

.card{
    border-radius:20px !important;
}

#slots .btn{
    min-width:90px;
    font-weight:500;
}


/* ==========================
   SLOT PREMIUM
========================== */

@keyframes slotFadeIn {
    from { opacity:0; transform:translateY(15px) scale(.95); }
    to { opacity:1; transform:translateY(0) scale(1); }
}

.slot-btn{
    background:#8ca590;
    border:none;
    color:white;
    border-radius:14px;
    font-weight:600;
    min-width:95px;
    transition:all .25s ease;
    box-shadow:0 6px 14px rgba(140,165,144,.25);
    opacity:0;
    animation:slotFadeIn .4s ease forwards;
}

.slot-btn:hover{
    background:#7a9480;
    transform:translateY(-3px);
    box-shadow:0 12px 22px rgba(122,148,128,.35);
}

.slot-btn.selected{
    background:#2f3e34;
    box-shadow:0 8px 18px rgba(0,0,0,.25);
}

/* ==========================
   MODAL PREMIUM
========================== */

.modal-overlay{
    position:fixed;
    inset:0;
    background:rgba(20,20,20,.45);
    backdrop-filter:blur(8px);
    display:flex;
    justify-content:center;
    align-items:center;
    z-index:9999;
}

.premium-modal{
    background:#fff;
    padding:35px;
    border-radius:24px;
    width:100%;
    max-width:480px;
    box-shadow:0 30px 60px rgba(0,0,0,.15);
    animation:modalEnter .3s ease;
}

@keyframes modalEnter{
    from{opacity:0; transform:translateY(20px) scale(.97);}
    to{opacity:1; transform:translateY(0) scale(1);}
}

.modal-header-premium{
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-bottom:25px;
}

.secure-badge{
    font-size:12px;
    background:#e4efe9;
    color:#4f6f60;
    padding:6px 12px;
    border-radius:20px;
    font-weight:600;
}

.modal-body-premium label{
    font-size:13px;
    font-weight:600;
    color:#555;
    margin-bottom:6px;
    display:block;
}

.input-group-premium{
    margin-bottom:18px;
}

.row-premium{
    display:grid;
    grid-template-columns:1fr 1fr 1fr;
    gap:12px;
}

.premium-modal .form-control{
    border-radius:14px;
    padding:12px;
    border:1px solid #e0e0e0;
    transition:.2s ease;
}

.premium-modal .form-control:focus{
    border-color:#8ca590;
    box-shadow:0 0 0 3px rgba(140,165,144,.15);
}

.modal-footer-premium{
    margin-top:25px;
    display:flex;
    justify-content:space-between;
    gap:12px;
}

.btn-cancel{
    flex:1;
    background:#f2f2f2;
    border:none;
    border-radius:14px;
    padding:12px;
    font-weight:600;
}

.btn-pay{
    flex:1;
    background:#8ca590;
    border:none;
    color:white;
    border-radius:14px;
    padding:12px;
    font-weight:700;
    box-shadow:0 8px 18px rgba(140,165,144,.25);
}

.btn-pay:hover{
    background:#7a9480;
    transform:translateY(-2px);
    box-shadow:0 12px 24px rgba(122,148,128,.35);
}

.price-summary{
    display:flex;
    align-items:center;
    justify-content:space-between;
    background:#f5f7fa;
    padding:20px 24px;
    border-radius:18px;
    margin:28px 0;
}

.price-summary span{
    font-size:15px;
    font-weight:600;
    color:#555;
    letter-spacing:.3px;
}

.price-summary strong{
    font-size:24px;
    font-weight:700;
    color:#2f3e34;
    margin-left:40px; /* 🔥 separación real */
}

/* ==========================
   LOADER PREMIUM
========================== */

.loader-overlay{
    position: fixed;
    inset:0;
    background: rgba(0,0,0,.55);
    backdrop-filter: blur(6px);
    display:flex;
    justify-content:center;
    align-items:center;
    z-index:10000;
}

.loader-card{
    background:white;
    padding:35px;
    border-radius:20px;
    text-align:center;
    box-shadow:0 20px 40px rgba(0,0,0,.2);
    width:90%;
    max-width:320px;
}

.spinner{
    width:50px;
    height:50px;
    border:4px solid #e0e0e0;
    border-top:4px solid #8ca590;
    border-radius:50%;
    margin:0 auto 15px;
    animation:spin 1s linear infinite;
}

@keyframes spin{
    to{ transform:rotate(360deg); }
}

.loader-card p{
    font-weight:600;
    color:#444;
}

/* ==========================
   SUCCESS MODAL
========================== */

.success-card{
    background:white;
    padding:40px;
    border-radius:25px;
    text-align:center;
    box-shadow:0 25px 50px rgba(0,0,0,.2);
    width:90%;
    max-width:380px;
    animation: modalFade .3s ease;
}

.success-icon{
    width:70px;
    height:70px;
    background:#8ca590;
    color:white;
    border-radius:50%;
    display:flex;
    justify-content:center;
    align-items:center;
    font-size:32px;
    margin:0 auto 20px;
    box-shadow:0 10px 25px rgba(140,165,144,.35);
}


/* BOTON LOGOUT AGENDA PACIENTE */
.btn-logout {
    background: #ffffff;
    border: 1.5px solid #e0e0e0;
    color: #444;
    padding: 8px 18px;
    border-radius: 50px;
    font-weight: 500;
    font-size: 14px;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    transition: all 0.3s ease;
    box-shadow: 0 2px 6px rgba(0,0,0,0.05);
}

.btn-logout:hover {
    background: #f8f9fa;
    color: #dc3545;
    border-color: #dc3545;
    transform: translateY(-2px);
    box-shadow: 0 6px 14px rgba(0,0,0,0.08);
}

.btn-logout i {
    font-size: 16px;
}

/* Mobile */

@media(max-width:576px){

    .brand-title{
        font-size:18px;
    }

    .brand-sub{
        font-size:10px;
    }

    .logout-btn{
        padding:10px;
        width:42px;
        height:42px;
        border-radius:50%;
        justify-content:center;
    }

    .logout-text{
        display:none;
    }
}

@media(max-width:576px){
    .row-premium{ grid-template-columns:1fr; }
    .premium-modal{ margin:20px; padding:25px; }
}

@media (max-width: 576px){

    .auth-card{
        padding:30px 25px;
    }

    .logo-img{
        width:120px;
    }

    #slots .btn{
        width:100%;
    }
}

/* ==========================
   MIS PAQUETES ACTIVO
========================== */

.mis-paquete-card{
    background:white;
    border-radius:18px;
    padding:16px;
    margin-bottom:16px;
    box-shadow:0 10px 25px rgba(0,0,0,.05);
    transition:.25s ease;
}

.mis-paquete-header{
    display:flex;
    justify-content:space-between;
    align-items:center;
    cursor:pointer;
}

.mis-paquete-header h6{
    margin:0;
    font-weight:700;
}

.mis-paquete-header small{
    color:#777;
}

.chevron{
    font-size:22px;
    transition:.3s ease;
}

.mis-paquete-card.active .chevron{
    transform:rotate(90deg);
}

.mis-paquete-body{
    margin-top:15px;
    display:none;
}

.mis-paquete-card.active .mis-paquete-body{
    display:block;
}

.servicio-line{
    display:flex;
    justify-content:space-between;
    padding:10px 0;
    border-bottom:1px solid #f0f0f0;
}

.servicio-line:last-child{
    border-bottom:none;
}

.badge-sesiones{
    background:#e4efe9;
    color:#4f6f60;
    padding:6px 12px;
    border-radius:20px;
    font-size:12px;
    font-weight:600;
}

/* ==========================
   PAQUETES DISPONIBLES
========================== */

.paquete-card-mini{
    background:white;
    border-radius:18px;
    padding:18px;
    display:flex;
    justify-content:space-between;
    align-items:center;
    box-shadow:0 10px 25px rgba(0,0,0,.05);
    transition:.25s ease;
}

.paquete-card-mini:hover{
    transform:translateY(-3px);
}

.paquete-card-mini h6{
    margin:0;
    font-weight:700;
}

.paquete-card-mini small{
    color:#777;
}

.precio-box{
    text-align:right;
}

.precio-box strong{
    display:block;
    font-size:18px;
    color:#2f3e34;
}

.btn-mini{
    margin-top:8px;
    background:#8ca590;
    border:none;
    color:white;
    padding:6px 14px;
    border-radius:12px;
    font-size:13px;
}

@media(max-width:576px){

    .container{
        padding-left:15px;
        padding-right:15px;
    }

    h4{
        font-size:20px;
    }

    h6{
        font-size:14px;
    }
}



/* ==========================
   GRID PAQUETES
========================== */

.paquetes-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:18px;
}

/* ==========================
   CARD PAQUETE
========================== */

.paquete-card{
background:white;
border-radius:18px;
padding:18px;
border:1px solid #f0f0f0;
box-shadow:0 8px 20px rgba(0,0,0,.04);
display:flex;
flex-direction:column;
justify-content:space-between;
transition:.25s ease;
}

.paquete-card:hover{
transform:translateY(-4px);
box-shadow:0 14px 30px rgba(0,0,0,.08);
}

/* header */

.paquete-header h6{
font-weight:700;
margin-bottom:3px;
}

.paquete-header small{
color:#777;
font-size:12px;
}

/* precio */

.paquete-precio{
font-size:26px;
font-weight:700;
color:#2f3e34;
margin:10px 0;
}

.paquete-precio span{
display:block;
font-size:12px;
color:#888;
font-weight:500;
}

/* servicios */

.paquete-servicios{
margin:10px 0 15px;
}

.paquete-servicio{
display:flex;
justify-content:space-between;
font-size:13px;
padding:6px 0;
border-bottom:1px solid #f2f2f2;
}

.paquete-servicio span{
background:#e4efe9;
color:#4f6f60;
padding:2px 8px;
border-radius:12px;
font-size:11px;
}

/* botón */

.btn-paquete{
background:#8ca590;
border:none;
color:white;
border-radius:12px;
padding:10px;
font-weight:600;
font-size:14px;
transition:.2s;
}

.btn-paquete:hover{
background:#7a9480;
transform:translateY(-1px);
}

/* ==========================
   RESPONSIVE
========================== */

@media(max-width:992px){
.paquetes-grid{
grid-template-columns:repeat(2,1fr);
}
}

@media(max-width:576px){

.paquetes-grid{
grid-template-columns:1fr;
}

.paquete-card{
padding:16px;
}

.paquete-precio{
font-size:22px;
}
/* ==========================
   GRID PAQUETES PRO
========================== */

.paquetes-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:22px;
margin-top:20px;
}

/* ==========================
   CARD PAQUETE
========================== */

.paquete-card{
position:relative;
background:white;
border-radius:20px;
padding:22px;
border:1px solid #f1f1f1;
box-shadow:0 10px 25px rgba(0,0,0,.05);
display:flex;
flex-direction:column;
justify-content:space-between;
transition:.25s ease;
overflow:hidden;
}

.paquete-card:hover{
transform:translateY(-6px);
box-shadow:0 20px 40px rgba(0,0,0,.1);
}

/* paquete destacado */

.paquete-destacado{
border:2px solid #8ca590;
transform:scale(1.03);
}

.paquete-destacado:hover{
transform:scale(1.05);
}

/* badge */

.badge-popular{
position:absolute;
top:14px;
right:14px;
background:#8ca590;
color:white;
font-size:11px;
padding:5px 10px;
border-radius:20px;
font-weight:600;
}

/* header */

.paquete-header h5{
font-weight:700;
margin-bottom:4px;
}

.paquete-header p{
font-size:13px;
color:#777;
margin:0;
}

/* precio */

.paquete-precio{
font-size:32px;
font-weight:700;
color:#2f3e34;
margin:15px 0 5px;
}

.paquete-precio span{
display:block;
font-size:12px;
color:#888;
}

/* divider */

.paquete-divider{
height:1px;
background:#f0f0f0;
margin:15px 0;
}

/* servicios */

.paquete-servicios{
display:flex;
flex-direction:column;
gap:8px;
margin-bottom:18px;
}

.paquete-servicio{
display:flex;
justify-content:space-between;
font-size:14px;
}

.paquete-servicio strong{
background:#e4efe9;
color:#4f6f60;
padding:2px 8px;
border-radius:12px;
font-size:12px;
}

/* botón */

.btn-paquete{
background:#8ca590;
border:none;
color:white;
border-radius:14px;
padding:12px;
font-weight:600;
font-size:15px;
transition:.2s;
margin-top:auto;
}

.btn-paquete:hover{
background:#7a9480;
transform:translateY(-2px);
box-shadow:0 8px 18px rgba(140,165,144,.35);
}

/* ==========================
   RESPONSIVE
========================== */

@media(max-width:992px){

.paquetes-grid{
grid-template-columns:repeat(2,1fr);
}

}

@media(max-width:576px){

.paquetes-grid{
grid-template-columns:1fr;
}

.paquete-card{
padding:18px;
}

.paquete-precio{
font-size:28px;
}

}
.badge-sesion{
background:#e4efe9;
color:#4f6f60;
padding:3px 10px;
border-radius:12px;
font-size:12px;
font-weight:600;
}

.paquete-info{
font-size:13px;
color:#555;
margin-bottom:10px;
}

.paquete-servicios small{
display:block;
margin-bottom:6px;
}

}

