body {
    font-family: 'Playfair Display', serif;
    margin: 0;
    padding: 0;
    color: #333;
    background-color: #f4f0ea;
    padding-top: 65px;
}

/* Premium analytics direction layer */
body.millaray-premium-dashboard.reservas-admin-page {
    background:
        radial-gradient(circle at 12% 0%, rgba(227, 194, 139, .18), transparent 28%),
        linear-gradient(180deg, #fbf7ef 0%, #f2eadf 52%, #efe6d8 100%) !important;
    color: #2d2118;
    font-family: Inter, Manrope, "Source Sans 3", Arial, sans-serif !important;
    line-height: 1.48;
}

.millaray-premium-dashboard h1,
.millaray-premium-dashboard h2,
.millaray-premium-dashboard h3,
.millaray-premium-dashboard .dashboard-title h2,
.millaray-premium-dashboard .hero-card-copy h1,
.millaray-premium-dashboard .panel-header h3,
.millaray-premium-dashboard .analysis-header h3 {
    color: #26170f;
    font-family: "Playfair Display", "Cormorant Garamond", Georgia, serif !important;
    font-weight: 600 !important;
    letter-spacing: 0 !important;
    line-height: 1.08;
    text-transform: none !important;
}

.millaray-premium-dashboard .dashboard-title h2 {
    font-size: clamp(2rem, 3vw, 3.15rem) !important;
    margin-bottom: 6px;
}

.millaray-premium-dashboard .dashboard-title p,
.millaray-premium-dashboard .panel-header p,
.millaray-premium-dashboard .hero-actions,
.millaray-premium-dashboard .analysis-header p {
    color: rgba(45, 33, 24, .68);
    font-size: .98rem;
    line-height: 1.55;
}

.millaray-premium-dashboard .eyebrow,
.millaray-premium-dashboard .panel-kicker,
.millaray-premium-dashboard .soft-pill,
.millaray-premium-dashboard .preview-pill {
    font-family: Inter, Manrope, Arial, sans-serif !important;
    font-size: .76rem !important;
    font-weight: 800 !important;
    letter-spacing: .045em !important;
    text-transform: none !important;
}

.millaray-premium-dashboard .dashboard-topbar {
    background: transparent !important;
    border: 0 !important;
    padding-bottom: 18px !important;
}

.millaray-premium-dashboard .dashboard-actions .preview-pill,
.millaray-premium-dashboard .dashboard-date {
    background: rgba(255, 253, 248, .78);
    border: 1px solid rgba(92, 61, 39, .1);
    box-shadow: 0 12px 24px rgba(58, 36, 23, .06);
}

.millaray-premium-dashboard .millaray-hero-card {
    align-items: stretch;
    background:
        linear-gradient(115deg, rgba(45, 27, 18, .93) 0%, rgba(82, 54, 37, .82) 48%, rgba(201, 111, 61, .38) 100%) !important;
    border: 1px solid rgba(255, 249, 240, .38) !important;
    border-radius: 24px !important;
    box-shadow: 0 28px 70px rgba(45, 27, 18, .16) !important;
    color: #fffaf2;
    grid-template-columns: minmax(0, 1fr) minmax(340px, .72fr) !important;
    min-height: 360px;
    overflow: hidden;
    padding: 0 !important;
}

.millaray-premium-dashboard .hero-card-copy {
    align-content: center;
    display: grid;
    gap: 22px;
    padding: clamp(28px, 4vw, 48px) !important;
    position: relative;
    z-index: 1;
}

.millaray-premium-dashboard .hero-card-copy h1 {
    color: #fffaf2 !important;
    font-size: clamp(2.5rem, 5vw, 4.8rem) !important;
    max-width: 680px;
}

.millaray-premium-dashboard .hero-card-copy .soft-pill {
    background: rgba(255, 250, 242, .12);
    border: 1px solid rgba(255, 250, 242, .18);
    color: #f4d8aa;
    justify-self: start;
}

.millaray-premium-dashboard .hero-metrics-grid {
    gap: 12px !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.millaray-premium-dashboard .hero-metrics-grid div {
    background: rgba(255, 250, 242, .12) !important;
    border: 1px solid rgba(255, 250, 242, .16) !important;
    border-radius: 16px !important;
    box-shadow: none !important;
    min-height: 104px;
    padding: 16px !important;
}

.millaray-premium-dashboard .hero-metrics-grid span {
    color: rgba(255, 250, 242, .74) !important;
    font-size: .78rem;
    font-weight: 750;
}

.millaray-premium-dashboard .hero-metrics-grid strong {
    color: #fffaf2 !important;
    font-family: Inter, Manrope, Arial, sans-serif !important;
    font-size: clamp(1.75rem, 3vw, 2.45rem) !important;
    font-weight: 850;
}

.millaray-premium-dashboard .hero-illustration {
    border-radius: 0 !important;
    min-height: 360px;
    position: relative !important;
}

.millaray-premium-dashboard .hero-illustration::after {
    background: linear-gradient(90deg, rgba(45, 27, 18, .42), rgba(45, 27, 18, .04));
    content: "";
    inset: 0;
    position: absolute;
}

.millaray-premium-dashboard .hero-illustration img {
    height: 100% !important;
    object-fit: cover;
    width: 100%;
}

.millaray-premium-dashboard .hero-actions .btn-primary,
.millaray-premium-dashboard .dashboard-new-booking {
    border-radius: 14px !important;
    box-shadow: 0 18px 38px rgba(201, 111, 61, .22) !important;
    font-weight: 850;
}

.millaray-premium-dashboard .dashboard-canvas {
    gap: 26px !important;
}

.millaray-premium-dashboard .admin-dashboard {
    gap: 18px !important;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card {
    background: linear-gradient(145deg, rgba(255, 253, 248, .98), rgba(249, 239, 224, .9)) !important;
    border-color: rgba(92, 61, 39, .12) !important;
    box-shadow: 0 18px 45px rgba(45, 27, 18, .075) !important;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card > span,
.bi-kpi-grid span,
.bi-card .analysis-card-title span {
    letter-spacing: .055em !important;
    text-transform: none !important;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card > strong {
    font-size: clamp(2rem, 2.55vw, 2.65rem) !important;
}

.millaray-premium-dashboard .intelligent-analysis-panel,
.millaray-premium-dashboard .business-intelligence {
    background:
        linear-gradient(180deg, rgba(255, 253, 248, .96), rgba(251, 244, 234, .92)) !important;
    border: 1px solid rgba(92, 61, 39, .1) !important;
    border-radius: 24px !important;
    box-shadow: 0 24px 60px rgba(45, 27, 18, .08) !important;
    padding: clamp(22px, 3vw, 34px) !important;
}

.millaray-premium-dashboard .business-intelligence {
    background:
        linear-gradient(135deg, rgba(255, 253, 248, .98), rgba(245, 235, 220, .96)),
        radial-gradient(circle at 100% 0%, rgba(127, 147, 99, .18), transparent 32%) !important;
}

.bi-header {
    border-bottom: 1px solid rgba(45, 27, 18, .08);
    padding-bottom: 16px;
}

.bi-header h3,
.millaray-premium-dashboard .analysis-header h3 {
    font-size: clamp(1.7rem, 2.5vw, 2.45rem) !important;
}

.bi-tabs {
    background: rgba(255, 250, 242, .8) !important;
    border: 1px solid rgba(92, 61, 39, .1) !important;
    border-radius: 18px !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .7);
}

.bi-tab-button {
    border-radius: 13px !important;
    color: rgba(45, 33, 24, .68) !important;
    font-size: .86rem;
    font-weight: 800 !important;
}

.bi-tab-button.is-active {
    background: linear-gradient(135deg, #2d1b12, #76533a) !important;
    box-shadow: 0 14px 28px rgba(45, 27, 18, .18) !important;
    color: #fffaf2 !important;
}

.bi-grid {
    gap: 18px !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.bi-card,
.millaray-premium-dashboard .analysis-card,
.millaray-premium-dashboard .ai-insight-card {
    background: rgba(255, 253, 248, .92) !important;
    border: 1px solid rgba(92, 61, 39, .1) !important;
    border-radius: 18px !important;
    box-shadow: 0 18px 38px rgba(45, 27, 18, .065) !important;
}

.bi-card {
    min-height: 330px;
    padding: 18px !important;
}

.bi-card-wide {
    grid-column: span 2;
}

.analysis-card-title {
    align-items: start !important;
    gap: 14px;
}

.analysis-card-title strong,
.bi-kpi-grid strong {
    color: #26170f !important;
    font-family: Inter, Manrope, Arial, sans-serif !important;
    font-weight: 850 !important;
}

.bi-chart,
.bi-chart canvas {
    height: 250px !important;
}

.bi-funnel-row,
.bi-weekend-ranking article,
.bi-mini-predictions article,
.bi-prediction-copy p {
    background: rgba(255, 250, 242, .78) !important;
    border: 1px solid rgba(92, 61, 39, .08);
    border-radius: 14px !important;
}

.bi-annual-heatmap span,
.bi-weekly-heatmap span {
    border: 1px solid rgba(92, 61, 39, .08);
    box-shadow: inset 0 -10px 16px rgba(45, 27, 18, .035);
}

.bi-profit-table table {
    font-size: .86rem;
}

.bi-profit-table th {
    color: rgba(45, 33, 24, .58) !important;
    font-weight: 850;
    text-transform: none;
}

.bi-table-value {
    display: block;
    font-weight: 850;
    margin-bottom: 6px;
}

.bi-mini-bar {
    background: rgba(201, 111, 61, .12);
    border-radius: 999px;
    display: block;
    height: 6px;
    overflow: hidden;
    width: 86px;
}

.bi-mini-bar i {
    background: linear-gradient(90deg, #c96f3d, #e3c28b);
    display: block;
    height: 100%;
}

.bi-mini-bar.is-olive {
    background: rgba(127, 147, 99, .14);
}

.bi-mini-bar.is-olive i {
    background: linear-gradient(90deg, #7f9363, #d7c47d);
}

.millaray-premium-dashboard #guests-bar-chart.bar-chart {
    background: linear-gradient(180deg, rgba(255, 250, 242, .66), rgba(255, 250, 242, .24)) !important;
    border: 1px solid rgba(92, 61, 39, .08);
    border-radius: 16px;
    padding: 14px 16px 4px !important;
}

@media (max-width: 1180px) {
    .bi-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 860px) {
    .millaray-premium-dashboard .millaray-hero-card {
        grid-template-columns: 1fr !important;
    }

    .millaray-premium-dashboard .hero-metrics-grid,
    .bi-grid {
        grid-template-columns: 1fr !important;
    }

    .bi-card-wide {
        grid-column: span 1;
    }
}
nav {
    background-color: #000;
    text-align: center;
    padding: 15px;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 1000;
}
nav a {
    color: white;
    text-decoration: none;
    margin: 0 6px;
    font-weight: bold;
}
header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 100px 80px 40px 80px;
    background-color: #f4f0ea;
}
header h1 {
    font-size: 3em;
    margin: 0;
}
header p {
    font-size: 1.2em;
}
section {
    padding: 50px 20px;
    max-width: 1200px;
    margin: auto;
}
h2 {
    font-size: 2.5em;
    margin-bottom: 20px;
}
.info-section {
    display: flex;
    gap: 30px;
    align-items: center;
}
.info-section img {
    width: 50%;
    border-radius: 10px;
}
.info-section p {
    width: 50%;
    font-size: 1.1em;
}
.services {
    display: flex;
    gap: 20px;
}
.services { align-items: stretch; }

.service-card {
    flex: 1 1 30%;
    min-width: 220px;
    display: flex;
    flex-direction: column;
    align-items: stretch;
        /* Fuerza una altura consistente para que todos los contenedores queden del mismo tamaño */
        min-height: 380px;
    }

.service-card p { margin-top: auto; color:var(--muted); }
.service-card {
    background-color: white;
    border-radius: 10px;
    padding: 20px;
    flex: 1;
    text-align: center;
}
.service-card img {
    width: 100%;
    border-radius: 10px;
    margin-bottom: 15px;
        /* Forzar aspecto vertical (portrait) y recorte centrado sin cambiar la tarjeta */
        aspect-ratio: 3 / 4; /* ancho:alto = 3:4 => imagen más alta que ancha */
        height: auto;
        object-fit: cover;
        object-position: center;
        display: block;
        border-radius: 10px;
        margin-bottom: 15px;
    }

    /* En pantallas pequeñas, permitir que la altura de la tarjeta se reduzca para no consumir mucho espacio */
    @media (max-width: 700px) {
        .service-card { min-height: 0; }
    }
.gallery-title {
    font-size: 4em;
    font-weight: bold;
    letter-spacing: -2px;
    margin-bottom: 10px;
}
.gallery-subtitle {
    font-size: 2em;
    margin-bottom: 40px;
}
.gallery {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 20px;
    padding: 50px 20px;
}
.gallery img {
    width: 100%;
    border-radius: 10px;
}
.gallery-description {
    text-align: center;
    font-size: 1.2em;
    margin-top: 20px;
}
.menu {
    background-color: #211e1e;
    color: white;
    padding: 50px 20px;
}
.menu h2, .menu p {
    color: white;
}
.menu-item {
    margin-bottom: 30px;
}
.menu-item button {
    padding: 10px 20px;
    background-color: white;
    border: none;
    cursor: pointer;
    font-weight: bold;
}
.menu-item a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
}
.weekly-menu {
    padding: 50px 20px;
    background-color: #f4f0ea;
    text-align: center;
}
.weekly-menu h2 {
    font-size: 2.5em;
    margin-bottom: 20px;
}
.weekly-menu table {
    margin: auto;
    border-collapse: collapse;
    width: 80%;
}
.weekly-menu th, .weekly-menu td {
    border: 1px solid #333;
    padding: 10px;
    text-align: center;
}
.weekly-menu th {
    background-color: #211e1e;
    color: white;
}
footer {
    background-color: #211e1e;
    color: white;
    text-align: center;
    padding: 30px 20px;
}
footer a {
    color: white;
    margin: 0 10px;
}

/* Clases añadidas para reemplazar estilos inline */
.logo-nav {
    height: 50px;
    vertical-align: middle;
    margin-right: 20px;
}
.header-image {
    width: 300px;
    border-radius: 10px;
}

/* Responsive adjustments */
img { max-width: 100%; height: auto; display: block; }

/* Make nav use flex so links wrap and align on small screens */
nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    box-sizing: border-box;
}

nav a { padding: 8px 6px; }

/* Hamburger button styles */
.nav-toggle {
    display: none;
    background: transparent;
    border: none;
    color: white;
    font-size: 26px;
    cursor: pointer;
}

.nav-links { display: flex; gap: 10px; align-items: center; }

@media (max-width: 700px) {
    .nav-toggle { display: block; }
    .nav-links { display: none; width: 100%; }
    .nav-links.open { display: flex; flex-direction: column; }
}

@media (max-width: 900px) {
    header { padding: 60px 30px 30px 30px; }
    header h1 { font-size: 2.2em; }
    .gallery-title { font-size: 3em; }
    .gallery-subtitle { font-size: 1.4em; }
}

@media (max-width: 700px) {
    /* Stack header vertically */
    header { flex-direction: column; text-align: center; padding: 40px 20px; }
    .header-image { width: 220px; margin-top: 15px; }

    /* Stack info-section and services */
    .info-section { flex-direction: column; }
    .info-section img, .info-section p { width: 100%; }

    .services { flex-direction: column; }

    /* Gallery padding smaller */
    .gallery { padding: 30px 12px; }

    section { padding: 30px 12px; }

    .menu { padding: 30px 12px; }

    .weekly-menu table { width: 100%; }
}

@media (max-width: 420px) {
    nav { justify-content: center; }
    nav img.logo-nav { margin-bottom: 8px; }
    nav a { display: block; width: 100%; text-align: center; padding: 10px 0; }
    header h1 { font-size: 1.8em; }
    .gallery-title { font-size: 2.2em; }
}

/* -------------------------- */
/* Theme overrides / polish */
:root{
    --bg: #f4f0ea;
    --accent: #211e1e;
    --muted: #6b6b6b;
    --card-bg: #ffffff;
    --accent-2: #c49a6c;
}

/* Nav polish */
nav{ background:var(--accent); }
.nav-links a{ color:#fff; text-decoration:none; padding:8px 12px; border-radius:6px; transition:background .2s ease,transform .12s }
.nav-links a:hover{ background: rgba(255,255,255,0.06); transform:translateY(-2px) }
.nav-toggle{ background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.08); color:#fff; padding:6px 10px; border-radius:8px }

/* Cards */
.service-card{ border-radius:12px; padding:16px; background:var(--card-bg); box-shadow:0 8px 20px rgba(31,31,31,0.06); transition:transform .22s ease,box-shadow .22s ease }
.service-card:hover{ transform:translateY(-6px); box-shadow:0 18px 30px rgba(31,31,31,0.09) }
.service-card h3{ margin-top:6px; font-size:1.05rem }

/* Images subtle radius */
.gallery img, .service-card img{ border-radius:8px }

/* Buttons */
.menu-item button, .btn-primary{ background:linear-gradient(90deg,var(--accent-2),#e0b985); color:var(--accent); border:none; padding:10px 16px; border-radius:8px; font-weight:700; cursor:pointer }

/* Table look */
.weekly-menu table{ background:#fff; border-radius:8px; overflow:hidden }
.weekly-menu th{ background:var(--accent); color:#fff }
.weekly-menu td, .weekly-menu th{ padding:10px }

/* Typography polish */
h2{ color:var(--accent) }
p{ color:var(--muted) }

.section-heading {
    max-width: 760px;
    margin-bottom: 28px;
}

.section-heading span {
    color: var(--accent-2);
    display: block;
    font-weight: 700;
    letter-spacing: .04em;
    margin-bottom: 6px;
    text-transform: uppercase;
}

.section-heading h2 {
    margin: 0 0 10px;
}

.hero-carousel-section {
    background: linear-gradient(180deg, #fff 0%, #f7f1e9 100%);
    max-width: none;
    padding-left: max(20px, calc((100% - 1200px) / 2));
    padding-right: max(20px, calc((100% - 1200px) / 2));
}

.hero-carousel {
    align-items: center;
    display: grid;
    gap: 12px;
    grid-template-columns: auto minmax(0, 1fr) auto;
}

.carousel-viewport {
    overflow: hidden;
}

.carousel-track {
    display: flex;
    transition: transform .45s ease;
    will-change: transform;
}

.carousel-slide {
    background: #111;
    border-radius: 14px;
    color: #fff;
    flex: 0 0 100%;
    overflow: hidden;
    position: relative;
}

.carousel-slide img {
    aspect-ratio: 16 / 7;
    object-fit: cover;
    width: 100%;
}

.carousel-caption {
    background: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.72));
    bottom: 0;
    left: 0;
    padding: 28px;
    position: absolute;
    right: 0;
}

.carousel-caption span {
    color: #e8c995;
    display: block;
    font-size: .8rem;
    font-weight: 800;
    letter-spacing: .08em;
    margin-bottom: 6px;
    text-transform: uppercase;
}

.carousel-caption h3 {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(1.4rem, 3vw, 2.4rem);
    margin: 0 0 8px;
}

.carousel-caption p {
    color: rgba(255, 255, 255, .9);
    margin: 0;
    max-width: 54ch;
}

.carousel-arrow {
    align-items: center;
    background: rgba(33, 30, 30, .9);
    border: 0;
    border-radius: 999px;
    color: #fff;
    cursor: pointer;
    display: inline-flex;
    font-size: 2rem;
    height: 52px;
    justify-content: center;
    width: 52px;
}

.carousel-indicators {
    display: flex;
    gap: 10px;
    justify-content: center;
    margin-top: 14px;
}

.carousel-dot {
    background: rgba(33, 30, 30, .22);
    border: 0;
    border-radius: 999px;
    cursor: pointer;
    height: 10px;
    width: 28px;
}

.carousel-dot.is-active {
    background: var(--accent-2);
}

.reservation-section {
    background: #fffaf4;
    max-width: none;
    padding-left: max(20px, calc((100% - 1200px) / 2));
    padding-right: max(20px, calc((100% - 1200px) / 2));
}

.reservation-grid {
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(280px, .85fr) minmax(320px, 1.4fr);
}

.auth-panel,
.cabins-panel,
.booking-panel,
.reservations-panel {
    background: #fff;
    border: 1px solid rgba(33, 30, 30, .08);
    border-radius: 8px;
    box-shadow: 0 12px 26px rgba(31, 31, 31, .07);
    padding: 22px;
}

.booking-panel,
.reservations-panel {
    margin-top: 18px;
}

.panel-header {
    border-bottom: 1px solid rgba(33, 30, 30, .08);
    margin-bottom: 18px;
    padding-bottom: 12px;
}

.panel-header h3 {
    color: var(--accent);
    font-size: 1.25rem;
    margin: 0 0 6px;
}

.panel-header p {
    margin: 0;
}

.stacked-form,
.reservation-form {
    display: grid;
    gap: 12px;
}

.stacked-form label,
.reservation-form label {
    color: var(--accent);
    font-weight: 700;
}

.stacked-form input,
.reservation-form input,
.reservation-form textarea {
    border: 1px solid rgba(33, 30, 30, .18);
    border-radius: 8px;
    box-sizing: border-box;
    color: #333;
    font: inherit;
    padding: 11px 12px;
    width: 100%;
}

.stacked-form input:disabled,
.reservation-form input:disabled,
.reservation-form textarea:disabled {
    background: #f3f0ec;
    color: #858585;
}

.form-row {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.form-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.btn-primary,
.btn-secondary,
.cabin-card button,
.reservation-card button {
    border: 0;
    border-radius: 8px;
    cursor: pointer;
    font: inherit;
    font-weight: 700;
    min-height: 42px;
    padding: 10px 16px;
}

.btn-primary:disabled,
.btn-secondary:disabled,
.cabin-card button:disabled,
.reservation-card button:disabled {
    cursor: not-allowed;
    opacity: .62;
}

.btn-secondary,
.reservation-card button {
    background: #f0ece6;
    color: var(--accent);
}

.cabins-list {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
}

.cabin-card {
    border: 1px solid rgba(33, 30, 30, .1);
    border-radius: 8px;
    display: grid;
    gap: 10px;
    padding: 16px;
}

.cabin-card.selected {
    border-color: var(--accent-2);
    box-shadow: 0 0 0 3px rgba(196, 154, 108, .22);
}

.cabin-card h4,
.reservation-card h4 {
    color: var(--accent);
    font-size: 1.1rem;
    margin: 0;
}

.cabin-card p,
.reservation-card p {
    margin: 0;
}

.cabin-meta,
.reservation-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.cabin-meta span,
.reservation-meta span {
    background: #f4f0ea;
    border-radius: 999px;
    color: var(--accent);
    font-size: .92rem;
    font-weight: 700;
    padding: 6px 10px;
}

.cabin-card ul {
    color: var(--muted);
    margin: 0;
    padding-left: 18px;
}

.reservations-list {
    display: grid;
    gap: 12px;
}

.reservation-card {
    border: 1px solid rgba(33, 30, 30, .1);
    border-radius: 8px;
    display: grid;
    gap: 10px;
    padding: 16px;
}

.empty-state {
    background: #f4f0ea;
    border-radius: 8px;
    margin: 0;
    padding: 14px;
}

.form-message {
    border-radius: 8px;
    color: var(--accent);
    font-weight: 700;
    padding: 10px 12px;
}

.form-message.ok {
    background: #edf7ed;
}

.form-message.error {
    background: #fbe9e7;
}

/* Small screen nav open style ensure visible */
@media(max-width:700px){ .nav-links.open{ display:flex !important } }

@media (max-width: 850px) {
    .reservation-grid,
    .form-row {
        grid-template-columns: 1fr;
    }
}

/* Hotel system polish */
body {
    background: #f7f3ee;
    color: #232323;
    font-family: 'Inter', Arial, sans-serif;
    line-height: 1.55;
}

body::before {
    background: linear-gradient(90deg, #b88a55, #e2c79c, #b88a55);
    content: "";
    height: 3px;
    left: 0;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 1200;
}

h1,
h2,
.gallery-title {
    font-family: 'Playfair Display', Georgia, serif;
}

nav {
    background: rgba(20, 19, 18, .94);
    border-bottom: 1px solid rgba(255, 255, 255, .08);
    box-shadow: 0 14px 30px rgba(0, 0, 0, .18);
    min-height: 72px;
    padding: 10px 24px;
}

.logo-nav {
    height: 48px;
    margin-right: 12px;
}

.nav-links {
    gap: 4px;
}

.nav-links a {
    color: rgba(255, 255, 255, .86);
    font-size: .9rem;
    font-weight: 700;
    letter-spacing: .01em;
    padding: 10px 12px;
}

header {
    background:
        linear-gradient(90deg, rgba(20, 19, 18, .88), rgba(20, 19, 18, .5), rgba(247, 243, 238, .86)),
        url("hostalmillaray.png") center / cover;
    align-items: flex-start;
    color: #fff;
    min-height: 620px;
    overflow: hidden;
    padding: 108px max(28px, calc((100% - 1200px) / 2)) 96px;
    position: relative;
}

.hero-copy {
    max-width: 680px;
}

.hero-kicker {
    color: #e8c995;
    display: block;
    font-size: .86rem;
    font-weight: 800;
    letter-spacing: .12em;
    margin-bottom: 16px;
    text-transform: uppercase;
}

header h1 {
    color: #fff;
    font-size: clamp(3rem, 6vw, 5.5rem);
    line-height: .95;
    margin-bottom: 22px;
}

header p {
    color: rgba(255, 255, 255, .86);
    font-size: 1.12rem;
    max-width: 620px;
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 26px;
}

.btn-ghost {
    align-items: center;
    border: 1px solid rgba(255, 255, 255, .46);
    border-radius: 8px;
    color: #fff;
    display: inline-flex;
    font-weight: 800;
    min-height: 42px;
    padding: 10px 16px;
    text-decoration: none;
}

.header-image {
    background: rgba(255, 255, 255, .08);
    border: 1px solid rgba(255, 255, 255, .16);
    box-shadow: 0 24px 60px rgba(0, 0, 0, .25);
    padding: 18px;
    width: 240px;
}

.hotel-search {
    align-items: end;
    background: rgba(255, 255, 255, .96);
    border: 1px solid rgba(255, 255, 255, .5);
    border-radius: 8px;
    bottom: 32px;
    box-shadow: 0 24px 60px rgba(0, 0, 0, .22);
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(4, minmax(120px, 1fr)) auto;
    left: max(28px, calc((100% - 1200px) / 2));
    max-width: 1120px;
    padding: 18px;
    position: absolute;
    right: max(28px, calc((100% - 1200px) / 2));
    z-index: 2;
}

.hotel-search label {
    color: #211e1e;
    display: block;
    font-size: .78rem;
    font-weight: 800;
    letter-spacing: .08em;
    margin-bottom: 6px;
    text-transform: uppercase;
}

.hotel-search input,
.hotel-search select {
    background: #f8f4ee;
    border: 1px solid rgba(33, 30, 30, .16);
    border-radius: 6px;
    box-sizing: border-box;
    color: #211e1e;
    font: inherit;
    min-height: 44px;
    padding: 9px 10px;
    width: 100%;
}

.hotel-search .btn-primary {
    justify-content: center;
    min-height: 44px;
    text-decoration: none;
}

.footer-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: center;
    margin-top: 14px;
}

.footer-button {
    align-items: center;
    background: rgba(255, 255, 255, .08);
    border: 1px solid rgba(255, 255, 255, .14);
    border-radius: 999px;
    color: rgba(255, 255, 255, .92);
    display: inline-flex;
    font-weight: 800;
    justify-content: center;
    min-height: 42px;
    padding: 10px 16px;
    text-decoration: none;
    transition: transform .18s ease, background .18s ease;
}

.footer-button:hover {
    background: rgba(255, 255, 255, .14);
    transform: translateY(-2px);
}

section {
    padding-bottom: 72px;
    padding-top: 72px;
}

h2 {
    font-size: clamp(2rem, 4vw, 3.2rem);
    letter-spacing: 0;
}

.info-section,
.services,
.gallery,
.reservation-grid,
.admin-dashboard {
    align-items: stretch;
}

.info-section {
    background: #fff;
    border: 1px solid rgba(35, 35, 35, .08);
    border-radius: 8px;
    box-shadow: 0 16px 40px rgba(35, 35, 35, .08);
    overflow: hidden;
}

.info-section img {
    border-radius: 0;
    object-fit: cover;
}

.info-section p {
    box-sizing: border-box;
    padding: 34px;
}

.service-card,
.auth-panel,
.cabins-panel,
.booking-panel,
.reservations-panel,
.metric-card {
    border-radius: 8px;
    box-shadow: 0 18px 45px rgba(35, 35, 35, .08);
}

.service-card {
    text-align: left;
}

.service-card h3 {
    color: #211e1e;
    font-size: 1.18rem;
}

.rooms-showcase {
    background: #fff;
    max-width: none;
    padding-left: max(20px, calc((100% - 1200px) / 2));
    padding-right: max(20px, calc((100% - 1200px) / 2));
}

.room-grid {
    display: grid;
    gap: 22px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.room-card {
    background: #fff;
    border: 1px solid rgba(33, 30, 30, .08);
    border-radius: 8px;
    box-shadow: 0 18px 45px rgba(35, 35, 35, .08);
    overflow: hidden;
}

.room-card img {
    aspect-ratio: 4 / 3;
    object-fit: cover;
    width: 100%;
}

.room-card div {
    padding: 22px;
}

.room-card h3 {
    color: var(--accent);
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 1.5rem;
    margin: 0 0 10px;
}

.room-card p {
    margin: 0 0 16px;
}

.room-card a {
    color: #9b6938;
    font-weight: 800;
    text-decoration: none;
}

.menu {
    background:
        linear-gradient(135deg, rgba(33, 30, 30, .98), rgba(63, 48, 35, .95)),
        url("comedor_cabaña3.jpg") center / cover;
    max-width: none;
    padding-left: max(20px, calc((100% - 1200px) / 2));
    padding-right: max(20px, calc((100% - 1200px) / 2));
}

.menu h2 {
    color: #fff;
}

.menu-item,
.convenios {
    background: rgba(255, 255, 255, .08);
    border: 1px solid rgba(255, 255, 255, .12);
    border-radius: 8px;
    padding: 24px;
}

.menu-item p,
.convenios p,
.convenios li {
    color: rgba(255, 255, 255, .82);
}

.reservation-section {
    background:
        linear-gradient(180deg, #fffaf4, #f3eee8);
}

.admin-dashboard {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-top: 18px;
}

.admin-dashboard[hidden] {
    display: none;
}

.intelligent-analysis-panel {
    background: #fff;
    border: 1px solid rgba(33, 30, 30, .08);
    border-radius: 8px;
    box-shadow: 0 18px 45px rgba(35, 35, 35, .08);
    margin-top: 18px;
    padding: 22px;
}

.intelligent-analysis-panel[hidden] {
    display: none;
}

.analysis-header {
    align-items: flex-start;
    display: flex;
    gap: 16px;
    justify-content: space-between;
}

.data-badge {
    background: #f4f0ea;
    border: 1px solid rgba(196, 154, 108, .35);
    border-radius: 999px;
    color: #7b552f;
    flex: 0 0 auto;
    font-size: .82rem;
    font-weight: 800;
    padding: 7px 11px;
}

.analysis-summary,
.analysis-grid,
.charts-grid {
    display: grid;
    gap: 14px;
}

.analysis-summary {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-bottom: 14px;
}

.analysis-summary article,
.analysis-card,
.prediction-card,
.ai-insight-card {
    background: #fbf7f1;
    border: 1px solid rgba(33, 30, 30, .08);
    border-radius: 8px;
    padding: 16px;
}

.analysis-summary span,
.analysis-card-title span,
.prediction-card span,
.ai-insight-card span {
    color: #8a633b;
    display: block;
    font-size: .78rem;
    font-weight: 800;
    letter-spacing: .06em;
    text-transform: uppercase;
}

.analysis-summary strong,
.analysis-card-title strong,
.prediction-card strong {
    color: var(--accent);
    display: block;
    font-size: 1.32rem;
    line-height: 1.2;
    margin-top: 6px;
}

.analysis-summary p {
    margin: 6px 0 0;
}

.analysis-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.charts-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-top: 14px;
}

.analysis-card-title {
    align-items: flex-start;
    display: flex;
    gap: 12px;
    justify-content: space-between;
    margin-bottom: 14px;
}

.weekly-ranking,
.income-estimates,
.future-estimates,
.ai-insights {
    display: grid;
    gap: 10px;
}

.ranking-row,
.income-estimates div {
    align-items: center;
    background: #fff;
    border: 1px solid rgba(33, 30, 30, .06);
    border-radius: 8px;
    display: flex;
    gap: 10px;
    justify-content: space-between;
    padding: 10px 12px;
}

.ranking-row.is-top {
    background: #211e1e;
    color: #fff;
}

.ranking-row.is-top strong {
    color: #e8c995;
}

.ranking-row span,
.income-estimates span {
    font-weight: 700;
}

.ranking-row strong,
.income-estimates strong {
    color: var(--accent);
    white-space: nowrap;
}

.insight-list {
    color: var(--muted);
    display: grid;
    gap: 10px;
    margin: 0;
    padding-left: 18px;
}

.bar-chart {
    align-items: end;
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    min-height: 190px;
}

.bar-item {
    align-items: center;
    display: grid;
    gap: 6px;
    justify-items: center;
}

.bar-track {
    align-items: end;
    background: #efe8de;
    border-radius: 999px;
    display: flex;
    height: 158px;
    overflow: hidden;
    width: 18px;
}

.bar-track span {
    background: #b88a55;
    border-radius: 999px;
    display: block;
    width: 100%;
}

.bar-item.is-top .bar-track span {
    background: #211e1e;
}

.bar-item strong,
.bar-item small {
    color: var(--accent);
    font-size: .78rem;
}

.line-chart {
    align-items: end;
    background: linear-gradient(180deg, #fff 0%, #f4f0ea 100%);
    border-radius: 8px;
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    min-height: 230px;
    padding: 12px;
}

.line-point {
    align-items: center;
    align-self: end;
    background: linear-gradient(180deg, #211e1e, #b88a55);
    border-radius: 8px 8px 0 0;
    color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    min-height: 44px;
    padding: 8px 6px;
}

.line-point strong,
.line-point span {
    color: #fff;
    font-size: .72rem;
    text-align: center;
}

.heat-calendar {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(7, minmax(0, 1fr));
}

.heat-day {
    border-radius: 8px;
    color: #211e1e;
    display: grid;
    min-height: 54px;
    padding: 8px;
}

.heat-day.low {
    background: #f0ece6;
}

.heat-day.medium {
    background: #e8c995;
}

.heat-day.high {
    background: #211e1e;
    color: #fff;
}

.heat-day span {
    font-size: .74rem;
    font-weight: 800;
}

.heat-day strong {
    align-self: end;
    font-size: 1.1rem;
}

.prediction-card {
    background: linear-gradient(135deg, #211e1e, #3b2d20);
}

.prediction-card span,
.prediction-card strong,
.prediction-card p {
    color: #fff;
}

.prediction-card span {
    color: #e8c995;
}

.future-estimates p,
.ai-insights p {
    margin: 0;
}

.ai-insight-card {
    background: #211e1e;
    margin-top: 14px;
}

.ai-insight-card span {
    color: #e8c995;
    margin-bottom: 12px;
}

.ai-insights {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ai-insights p {
    background: rgba(255, 255, 255, .08);
    border: 1px solid rgba(255, 255, 255, .1);
    border-radius: 8px;
    color: rgba(255, 255, 255, .9);
    padding: 12px;
}

.metric-card {
    background: #211e1e;
    color: #fff;
    padding: 22px;
}

.metric-card span {
    color: rgba(255, 255, 255, .68);
    display: block;
    font-size: .9rem;
    font-weight: 700;
    margin-bottom: 8px;
}

.metric-card strong {
    color: #e8c995;
    display: block;
    font-size: 2.2rem;
    line-height: 1;
}

.cabin-card {
    background: linear-gradient(180deg, #fff, #fffbf7);
}

.weekly-menu {
    background: #f7f3ee;
}

footer {
    background: #171514;
}

footer p,
footer a {
    color: rgba(255, 255, 255, .82);
}

.gallery-page,
.admin-page {
    background: linear-gradient(180deg, #f7f3ee 0%, #f1ebe3 100%);
}

.page-hero {
    background:
        linear-gradient(90deg, rgba(20, 19, 18, .88), rgba(20, 19, 18, .48)),
        url("hostalmillaray.png") center / cover;
    color: #fff;
    margin: 0 auto;
    max-width: none;
    padding: 120px max(20px, calc((100% - 1200px) / 2)) 56px;
}

.page-hero h1,
.page-hero p {
    color: #fff;
}

.page-hero .hero-actions {
    margin-top: 18px;
}

.featured-photos {
    background: linear-gradient(180deg, #fff 0%, #f8f2ea 100%);
    max-width: none;
    padding-left: max(20px, calc((100% - 1200px) / 2));
    padding-right: max(20px, calc((100% - 1200px) / 2));
}

.photo-grid {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.photo-card {
    background: #fff;
    border: 1px solid rgba(33, 30, 30, .08);
    border-radius: 8px;
    box-shadow: 0 16px 36px rgba(35, 35, 35, .08);
    overflow: hidden;
}

.photo-card-large {
    grid-column: span 2;
}

.photo-card img {
    aspect-ratio: 4 / 3;
    object-fit: cover;
    width: 100%;
}

.photo-card div {
    padding: 18px;
}

.photo-card h3 {
    color: var(--accent);
    margin: 0 0 6px;
}

.photo-card p {
    margin: 0;
}

.reservation-callout {
    align-items: center;
    background: linear-gradient(135deg, #211e1e, #3b2d20);
    border-radius: 8px;
    color: #fff;
    display: flex;
    gap: 20px;
    justify-content: space-between;
    margin: 0 auto;
    max-width: 1200px;
    padding: 28px 24px;
}

.reservation-callout span {
    color: #e8c995;
    display: block;
    font-size: .82rem;
    font-weight: 800;
    letter-spacing: .08em;
    margin-bottom: 8px;
    text-transform: uppercase;
}

.reservation-callout h2,
.reservation-callout p {
    color: #fff;
}

.gallery-overview {
    display: grid;
    gap: 20px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.gallery-room,
.menu-admin-card,
.admin-login-card,
.menu-preview-card {
    background: #fff;
    border: 1px solid rgba(33, 30, 30, .08);
    border-radius: 8px;
    box-shadow: 0 18px 45px rgba(35, 35, 35, .08);
}

.gallery-room {
    overflow: hidden;
}

.gallery-room img {
    aspect-ratio: 4 / 3;
    object-fit: cover;
    width: 100%;
}

.gallery-room .room-copy,
.menu-admin-card,
.admin-login-card,
.menu-preview-card {
    padding: 22px;
}

.gallery-room h3,
.menu-admin-card h2,
.admin-login-card h2,
.menu-preview-card h2 {
    color: var(--accent);
    margin-top: 0;
}

.gallery-room ul,
.menu-admin-card ul {
    color: var(--muted);
    margin: 0;
    padding-left: 18px;
}

.gallery-strip {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    margin-top: 16px;
}

.gallery-strip img {
    aspect-ratio: 1 / 1;
    /* Carruseles de galería */
    .room-carousel {
        position: relative;
        aspect-ratio: 4 / 3;
        width: 100%;
    }

    .carousel-viewport {
        overflow: hidden;
        width: 100%;
        height: 100%;
    }

    .carousel-track {
        display: flex;
        height: 100%;
        transition: transform 0.5s ease-in-out;
    }

    .carousel-slide {
        flex-shrink: 0;
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .carousel-arrow {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        z-index: 10;
        background: rgba(255, 255, 255, 0.85);
        border: none;
        width: 44px;
        height: 44px;
        border-radius: 4px;
        cursor: pointer;
        display: flex;
        align-items: center;
        justify-content: center;
        transition: all 0.3s ease;
        font-size: 18px;
        color: var(--accent);
    }

    .carousel-arrow:hover {
        background: rgba(255, 255, 255, 1);
        box-shadow: 0 4px 12px rgba(33, 30, 30, 0.15);
    }

    .carousel-prev {
        left: 12px;
    }

    .carousel-next {
        right: 12px;
    }

    .carousel-prev::before {
        content: '‹';
        font-size: 24px;
        font-weight: bold;
    }

    .carousel-next::before {
        content: '›';
        font-size: 24px;
        font-weight: bold;
    }

    .carousel-indicators {
        position: absolute;
        bottom: 12px;
        left: 50%;
        transform: translateX(-50%);
        display: flex;
        gap: 8px;
        z-index: 10;
    }

    .carousel-dot {
        width: 10px;
        height: 10px;
        border-radius: 50%;
        border: none;
        background: rgba(255, 255, 255, 0.5);
        cursor: pointer;
        transition: all 0.3s ease;
    }

    .carousel-dot.is-active {
        background: rgba(255, 255, 255, 1);
        width: 28px;
        border-radius: 5px;
    }
    border-radius: 8px;
    object-fit: cover;
    width: 100%;
}

.menu-admin-layout {
    display: grid;
    gap: 18px;
    grid-template-columns: 320px minmax(0, 1fr);
}

.menu-editor {
    display: grid;
    gap: 16px;
}

.menu-day-card {
    background: #f9f5ef;
    border: 1px solid rgba(33, 30, 30, .08);
    border-radius: 8px;
    display: grid;
    gap: 10px;
    padding: 16px;
}

.menu-day-card h3 {
    color: var(--accent);
    margin: 0;
}

.menu-day-card label {
    color: var(--accent);
    font-weight: 700;
}

.menu-day-card textarea {
    border: 1px solid rgba(33, 30, 30, .16);
    border-radius: 8px;
    box-sizing: border-box;
    font: inherit;
    min-height: 84px;
    padding: 10px 12px;
    resize: vertical;
    width: 100%;
}

.menu-preview-table {
    border-collapse: collapse;
    width: 100%;
}

.menu-preview-table th,
.menu-preview-table td {
    border: 1px solid rgba(33, 30, 30, .12);
    padding: 12px;
    text-align: left;
    vertical-align: top;
}

.menu-preview-table th {
    background: var(--accent);
    color: #fff;
}

.menu-preview-table td:first-child {
    font-weight: 800;
    width: 130px;
}

.menu-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.menu-admin-hidden {
    display: none;
}

@media (max-width: 900px) {
    header {
        min-height: auto;
        padding-bottom: 32px;
    }

    .header-image {
        width: 180px;
    }

    .admin-dashboard {
        grid-template-columns: 1fr;
    }

    .analysis-summary,
    .analysis-grid,
    .charts-grid,
    .ai-insights {
        grid-template-columns: 1fr;
    }

    .hotel-search {
        grid-template-columns: 1fr 1fr;
        margin-top: 28px;
        position: static;
        width: 100%;
    }

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

    .gallery-overview,
    .menu-admin-layout {
        grid-template-columns: 1fr;
    }

    .hero-carousel {
        grid-template-columns: auto minmax(0, 1fr) auto;
    }

    .carousel-caption {
        padding: 18px;
    }

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

    .photo-card-large {
        grid-column: span 2;
    }

    .reservation-callout {
        align-items: flex-start;
        flex-direction: column;
    }
}

@media (max-width: 700px) {
    body {
        padding-top: 72px;
    }

    nav {
        padding: 10px 16px;
    }

    header {
        align-items: flex-start;
        text-align: left;
    }

    .hero-actions {
        width: 100%;
    }

    .hero-actions a {
        justify-content: center;
        width: 100%;
    }

    .analysis-header,
    .analysis-card-title,
    .ranking-row,
    .income-estimates div {
        align-items: flex-start;
        flex-direction: column;
    }

    .data-badge,
    .ranking-row strong,
    .income-estimates strong {
        white-space: normal;
    }

    .bar-chart {
        min-height: 170px;
    }

    .heat-calendar {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .info-section p {
        padding: 22px;
    }

    .hotel-search {
        grid-template-columns: 1fr;
    }

    .footer-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .footer-button {
        width: 100%;
    }

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

    .photo-card-large {
        grid-column: span 1;
    }

    .hero-carousel {
        grid-template-columns: 1fr;
    }

    .carousel-arrow {
        justify-self: center;
    }
}

/* end overrides */

/* Boutique illustrated dashboard */
.boutique-dashboard {
    --cream: #fbf3e7;
    --paper: rgba(255, 250, 240, .78);
    --paper-strong: rgba(255, 252, 246, .9);
    --terracotta: #cf7442;
    --terracotta-dark: #9d4d2d;
    --coffee: #2a1a10;
    --coffee-soft: #5a3a25;
    --gold: #ddb778;
    --olive: #8d9a68;
    --olive-dark: #65764e;
    --warm-black: #1d130d;
    background:
        radial-gradient(circle at 12% 6%, rgba(221, 183, 120, .28), transparent 26%),
        radial-gradient(circle at 86% 18%, rgba(141, 154, 104, .18), transparent 27%),
        linear-gradient(135deg, #fff7eb 0%, #f4e5d1 48%, #efe0cc 100%);
    color: var(--coffee);
    font-family: 'Inter', Arial, sans-serif;
    overflow-x: hidden;
    padding-top: 0;
}

.boutique-dashboard::before {
    display: none;
}

.boutique-dashboard h1,
.boutique-dashboard h2,
.boutique-dashboard h3,
.boutique-dashboard h4 {
    color: var(--coffee);
    font-family: 'Playfair Display', Georgia, serif;
    letter-spacing: 0;
}

.boutique-dashboard p {
    color: rgba(62, 43, 29, .72);
}

.boutique-dashboard nav {
    align-content: flex-start;
    align-items: stretch;
    background:
        linear-gradient(180deg, rgba(45, 28, 17, .94), rgba(25, 15, 10, .98)),
        radial-gradient(circle at 70% 36%, rgba(221, 183, 120, .2), transparent 34%);
    border: 1px solid rgba(255, 255, 255, .1);
    border-radius: 0 28px 28px 0;
    bottom: 0;
    box-shadow: 26px 0 80px rgba(64, 38, 20, .22);
    display: flex;
    flex-direction: column;
    gap: 24px;
    left: 0;
    min-height: 100vh;
    overflow: hidden;
    padding: 28px 16px 24px;
    position: fixed;
    right: auto;
    top: 0;
    width: 260px;
    z-index: 20;
}

.sidebar-brand {
    align-items: center;
    display: flex;
    gap: 12px;
    padding: 6px 8px 10px;
    position: relative;
    z-index: 2;
}

.boutique-dashboard .logo-nav {
    height: 54px;
    margin: 0;
    width: 54px;
}

.sidebar-brand span,
.sidebar-brand strong {
    color: #fff7eb;
    display: block;
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 1.55rem;
    line-height: .95;
}

.boutique-dashboard .nav-links {
    align-items: stretch;
    display: grid;
    gap: 9px;
    position: relative;
    z-index: 2;
}

.boutique-dashboard .nav-links a {
    align-items: center;
    border: 1px solid transparent;
    border-radius: 16px;
    color: rgba(255, 248, 237, .84);
    display: flex;
    font-size: .96rem;
    font-weight: 700;
    gap: 12px;
    min-height: 46px;
    padding: 0 14px;
    transition: transform .24s ease, background .24s ease, border-color .24s ease;
}

.boutique-dashboard .nav-links a::before {
    background: rgba(255, 248, 237, .18);
    border: 1px solid rgba(255, 248, 237, .15);
    border-radius: 12px;
    content: "";
    height: 20px;
    width: 20px;
}

.boutique-dashboard .nav-links a.is-active,
.boutique-dashboard .nav-links a:hover {
    background: linear-gradient(135deg, rgba(221, 183, 120, .72), rgba(207, 116, 66, .7));
    border-color: rgba(255, 248, 237, .22);
    color: #fff;
    transform: translateX(4px);
}

.sidebar-art {
    flex: 1;
    min-height: 280px;
    position: relative;
    z-index: 1;
}

.sidebar-art::before {
    background: linear-gradient(180deg, rgba(255, 242, 212, .9), rgba(191, 136, 79, .42));
    border-radius: 999px 999px 0 0;
    bottom: 0;
    content: "";
    height: 175px;
    left: -16px;
    position: absolute;
    width: 310px;
}

.sidebar-mountains,
.sidebar-mountains::before,
.sidebar-mountains::after {
    background: #d6a96f;
    border-radius: 60% 60% 0 0;
    bottom: 78px;
    content: "";
    height: 70px;
    left: -8px;
    position: absolute;
    transform: rotate(-7deg);
    width: 150px;
}

.sidebar-mountains::before {
    background: #e9c28a;
    bottom: 8px;
    left: 88px;
    transform: rotate(11deg);
}

.sidebar-mountains::after {
    background: #6d743f;
    bottom: -38px;
    height: 96px;
    left: 156px;
    transform: rotate(7deg);
    width: 92px;
}

.sidebar-cabin {
    bottom: 28px;
    height: 130px;
    left: 26px;
    position: absolute;
    width: 170px;
}

.sidebar-cabin .roof {
    background: linear-gradient(135deg, #8f4327, #d7783e);
    clip-path: polygon(50% 0, 100% 42%, 88% 50%, 88% 100%, 12% 100%, 12% 50%, 0 42%);
    height: 92px;
    left: 0;
    position: absolute;
    top: 0;
    width: 170px;
}

.sidebar-cabin .house {
    background: linear-gradient(180deg, #5b2d1c, #2a180f);
    border: 1px solid rgba(255, 211, 134, .25);
    border-radius: 12px 12px 4px 4px;
    bottom: 0;
    height: 76px;
    left: 24px;
    position: absolute;
    width: 122px;
}

.sidebar-cabin .door,
.sidebar-cabin .window {
    background: #f3b95d;
    border-radius: 5px 5px 0 0;
    bottom: 0;
    box-shadow: 0 0 20px rgba(243, 185, 93, .58);
    height: 42px;
    left: 66px;
    position: absolute;
    width: 25px;
}

.sidebar-cabin .window {
    bottom: 35px;
    height: 20px;
    left: 106px;
    width: 24px;
}

.leaf {
    background: var(--terracotta);
    border-radius: 100% 0 100% 0;
    height: 28px;
    position: absolute;
    transform: rotate(35deg);
    width: 14px;
}

.leaf-one { bottom: 210px; left: 34px; }
.leaf-two { background: #d99948; bottom: 176px; right: 30px; transform: rotate(-32deg); }
.leaf-three { background: #b8552f; bottom: 88px; left: 160px; transform: rotate(16deg); }

.sidebar-user {
    align-items: center;
    border-top: 1px solid rgba(255, 248, 237, .12);
    display: flex;
    gap: 12px;
    padding: 16px 8px 0;
    position: relative;
    z-index: 2;
}

.user-avatar {
    align-items: center;
    background: rgba(255, 248, 237, .92);
    border-radius: 999px;
    color: var(--coffee);
    display: inline-flex;
    font-weight: 800;
    height: 42px;
    justify-content: center;
    width: 42px;
}

.sidebar-user strong,
.sidebar-user small {
    color: #fff7eb;
    display: block;
}

.sidebar-user small {
    color: rgba(255, 248, 237, .68);
}

.boutique-dashboard .page-hero,
.boutique-dashboard footer {
    display: none;
}

.boutique-dashboard .dashboard-shell {
    display: block;
    margin-left: 260px;
    max-width: none;
    min-height: 100vh;
    padding: 36px clamp(18px, 3.2vw, 46px) 52px;
}

.dashboard-canvas {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(12, minmax(0, 1fr));
}

.boutique-dashboard .dashboard-topbar {
    align-items: flex-start;
    display: flex;
    gap: 18px;
    justify-content: space-between;
    margin-bottom: 24px;
}

.eyebrow,
.panel-kicker,
.soft-pill {
    color: var(--terracotta-dark);
    display: inline-flex;
    font-size: .76rem;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.boutique-dashboard .dashboard-title h2 {
    font-size: clamp(2.35rem, 4vw, 4.15rem);
    line-height: .92;
    margin: 8px 0 10px;
}

.boutique-dashboard .dashboard-title p {
    font-size: 1rem;
    margin: 0;
}

.boutique-dashboard .dashboard-actions {
    align-items: center;
    display: flex;
    gap: 12px;
}

.boutique-dashboard .dashboard-search,
.boutique-dashboard .dashboard-date {
    backdrop-filter: blur(18px);
    background: rgba(255, 252, 245, .66);
    border: 1px solid rgba(87, 57, 36, .13);
    border-radius: 18px;
    box-shadow: 0 16px 44px rgba(96, 58, 30, .08);
}

.boutique-dashboard .dashboard-search {
    min-width: min(36vw, 410px);
    padding: 0 16px;
}

.boutique-dashboard .dashboard-search::after {
    color: var(--coffee-soft);
    content: "⌕";
    font-size: 1.4rem;
}

.boutique-dashboard .dashboard-date,
.boutique-dashboard .dashboard-new-booking {
    border-radius: 18px;
    min-height: 52px;
}

.boutique-dashboard .dashboard-new-booking,
.boutique-dashboard .btn-primary {
    background: linear-gradient(135deg, #d98145, #c75d34);
    border-radius: 18px;
    box-shadow: 0 16px 34px rgba(184, 87, 45, .2);
    color: #fff;
}

.millaray-hero-card,
.boutique-dashboard .metric-card,
.boutique-dashboard .auth-panel,
.boutique-dashboard .cabins-panel,
.activity-panel,
.boutique-dashboard .intelligent-analysis-panel,
.boutique-dashboard .booking-panel,
.boutique-dashboard .reservations-panel,
.boutique-dashboard .analysis-card,
.boutique-dashboard .prediction-card,
.boutique-dashboard .ai-insight-card {
    backdrop-filter: blur(20px);
    background: var(--paper);
    border: 1px solid rgba(92, 61, 39, .12);
    border-radius: 30px;
    box-shadow: 0 24px 70px rgba(76, 45, 22, .11);
}

.millaray-hero-card {
    align-items: stretch;
    background:
        linear-gradient(135deg, rgba(255, 248, 237, .92), rgba(237, 207, 167, .64)),
        radial-gradient(circle at 82% 24%, rgba(221, 183, 120, .55), transparent 35%);
    display: grid;
    grid-column: span 7;
    grid-template-columns: minmax(0, 1.05fr) minmax(220px, .95fr);
    min-height: 350px;
    overflow: hidden;
    position: relative;
}

.millaray-hero-card::after {
    background: rgba(255, 255, 255, .32);
    border-radius: 999px;
    content: "";
    filter: blur(2px);
    height: 150px;
    position: absolute;
    right: -34px;
    top: -44px;
    width: 150px;
}

.hero-card-copy {
    align-content: center;
    display: grid;
    gap: 16px;
    padding: clamp(24px, 4vw, 42px);
    position: relative;
    z-index: 2;
}

.hero-card-copy h3 {
    font-size: clamp(2rem, 3.1vw, 3.55rem);
    line-height: .96;
    margin: 0;
    max-width: 11ch;
}

.hero-card-copy p {
    font-size: 1.02rem;
    margin: 0;
    max-width: 36ch;
}

.hero-stats-row {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.hero-stats-row div {
    background: rgba(255, 255, 255, .5);
    border: 1px solid rgba(90, 58, 37, .08);
    border-radius: 22px;
    min-width: 140px;
    padding: 14px 16px;
}

.hero-stats-row span,
.hero-stats-row strong {
    display: block;
}

.hero-stats-row span {
    color: rgba(62, 43, 29, .62);
    font-size: .78rem;
    font-weight: 800;
}

.hero-stats-row strong {
    color: var(--coffee);
    font-size: 1.35rem;
}

.hero-illustration {
    min-height: 300px;
    overflow: hidden;
    position: relative;
}

.sun-glow {
    background: radial-gradient(circle, rgba(255, 217, 139, .95), rgba(255, 217, 139, 0) 68%);
    height: 170px;
    position: absolute;
    right: 34px;
    top: 20px;
    width: 170px;
}

.mountain {
    background: #d2a96f;
    border-radius: 60% 60% 0 0;
    bottom: 58px;
    height: 160px;
    position: absolute;
    right: -10px;
    transform: rotate(-8deg);
    width: 290px;
}

.mountain-front {
    background: #78834e;
    bottom: 12px;
    height: 132px;
    right: 105px;
    transform: rotate(8deg);
    width: 250px;
}

.mini-cabin {
    bottom: 48px;
    height: 118px;
    position: absolute;
    right: 72px;
    width: 160px;
}

.mini-roof {
    background: linear-gradient(135deg, #8d3f26, #dd7c43);
    clip-path: polygon(50% 0, 100% 46%, 88% 54%, 88% 100%, 12% 100%, 12% 54%, 0 46%);
    height: 84px;
    position: absolute;
    width: 160px;
}

.mini-house {
    background: linear-gradient(180deg, #66331e, #2c180f);
    border-radius: 12px;
    bottom: 0;
    height: 70px;
    left: 22px;
    position: absolute;
    width: 116px;
}

.hero-mini-chart {
    align-items: end;
    background: rgba(255, 252, 246, .56);
    border: 1px solid rgba(90, 58, 37, .12);
    border-radius: 22px;
    bottom: 24px;
    display: flex;
    gap: 8px;
    height: 88px;
    left: 22px;
    padding: 14px;
    position: absolute;
    width: 120px;
}

.hero-mini-chart span {
    animation: barRise .8s ease both;
    background: linear-gradient(180deg, #d98145, #e7bd7b);
    border-radius: 999px;
    flex: 1;
}

.boutique-dashboard .admin-dashboard {
    display: grid;
    gap: 14px;
    grid-column: span 5;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin: 0;
}

.boutique-dashboard .admin-dashboard[hidden],
.boutique-dashboard .intelligent-analysis-panel[hidden],
.boutique-dashboard .dashboard-quick-panel[hidden] {
    display: none;
}

.boutique-dashboard .metric-card {
    color: var(--coffee);
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-height: 136px;
    overflow: hidden;
    padding: 18px 18px 16px;
    position: relative;
    transition: transform .24s ease, box-shadow .24s ease;
}

.boutique-dashboard .metric-card:hover,
.boutique-dashboard .analysis-card:hover,
.activity-grid article:hover,
.boutique-dashboard .cabin-card:hover {
    box-shadow: 0 30px 80px rgba(76, 45, 22, .16);
    transform: translateY(-4px);
}

.boutique-dashboard .metric-card i {
    align-items: center;
    background: linear-gradient(135deg, rgba(227, 194, 139, .22), rgba(201, 111, 61, .14));
    border: 1px solid rgba(201, 111, 61, .12);
    border-radius: 16px;
    color: var(--terracotta);
    display: inline-flex;
    font-size: 1rem;
    font-style: normal;
    font-weight: 900;
    height: 42px;
    justify-content: center;
    letter-spacing: .02em;
    position: absolute;
    right: 16px;
    top: 16px;
    width: 46px;
}

.boutique-dashboard .metric-card i::before,
.boutique-dashboard .metric-card i::after {
    content: none;
}

.boutique-dashboard .metric-card span,
.boutique-dashboard .metric-card small {
    color: rgba(62, 43, 29, .72);
    display: block;
    font-weight: 700;
}

.boutique-dashboard .metric-card span {
    font-size: .74rem;
    letter-spacing: .08em;
    margin-bottom: 2px;
    max-width: 140px;
    text-transform: uppercase;
}

.boutique-dashboard .metric-card strong {
    color: var(--coffee);
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(1.55rem, 2.4vw, 2.35rem);
    line-height: 1;
}

.boutique-dashboard .metric-card small {
    font-size: .76rem;
    margin-top: auto;
}

.reservas-admin-page .admin-dashboard {
    gap: 12px;
}

.boutique-dashboard .reservation-grid {
    display: grid;
    gap: 18px;
    grid-column: span 7;
    grid-template-columns: minmax(250px, .55fr) minmax(0, 1.45fr);
    margin: 0;
}

.activity-panel {
    grid-column: span 5;
    padding: 24px;
}

.boutique-dashboard .auth-panel,
.boutique-dashboard .cabins-panel,
.boutique-dashboard .booking-panel,
.boutique-dashboard .reservations-panel {
    margin: 0;
    padding: 24px;
}

.boutique-dashboard .panel-header {
    border: 0;
    margin: 0 0 18px;
    padding: 0;
}

.boutique-dashboard .panel-header h3 {
    font-size: clamp(1.35rem, 2vw, 1.9rem);
    line-height: 1;
    margin: 6px 0 8px;
}

.boutique-dashboard .panel-header p {
    margin: 0;
}

.activity-grid {
    display: grid;
    gap: 12px;
}

.activity-grid article,
.quick-analysis-list p,
.boutique-dashboard .ai-insights p {
    background: rgba(255, 252, 246, .68);
    border: 1px solid rgba(92, 61, 39, .08);
    border-radius: 22px;
    margin: 0;
    padding: 14px;
    transition: transform .24s ease, box-shadow .24s ease;
}

.activity-grid strong {
    color: var(--coffee);
    display: block;
    margin: 10px 0 4px;
}

.activity-grid p {
    font-size: .9rem;
    margin: 0;
}

.avatar-stack {
    display: flex;
}

.avatar-stack span {
    align-items: center;
    background: linear-gradient(135deg, #e9c58b, #b7c08b);
    border: 3px solid #fff7eb;
    border-radius: 999px;
    color: var(--coffee);
    display: inline-flex;
    font-size: .72rem;
    font-weight: 900;
    height: 34px;
    justify-content: center;
    margin-right: -8px;
    width: 34px;
}

.activity-icon {
    background: linear-gradient(135deg, rgba(207, 116, 66, .2), rgba(221, 183, 120, .24));
    border-radius: 15px;
    display: block;
    height: 38px;
    position: relative;
    width: 38px;
}

.activity-icon::before {
    background: var(--terracotta);
    border-radius: 8px;
    content: "";
    height: 17px;
    left: 11px;
    position: absolute;
    top: 12px;
    width: 17px;
}

.boutique-dashboard .cabins-list {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.boutique-dashboard .cabin-card {
    background: rgba(255, 252, 246, .58);
    border: 1px solid rgba(92, 61, 39, .1);
    border-radius: 26px;
    display: grid;
    gap: 14px;
    grid-template-columns: 116px minmax(0, 1fr);
    overflow: hidden;
    padding: 12px;
    transition: transform .24s ease, box-shadow .24s ease;
}

.boutique-dashboard .cabin-card.selected {
    border-color: rgba(207, 116, 66, .42);
    box-shadow: 0 0 0 4px rgba(207, 116, 66, .12);
}

.cabin-thumb {
    aspect-ratio: 1 / 1.2;
    background:
        radial-gradient(circle at 50% 20%, rgba(255, 229, 174, .75), transparent 34%),
        linear-gradient(180deg, rgba(233, 198, 142, .72), rgba(137, 151, 103, .46));
    border: 1px solid rgba(92, 61, 39, .1);
    border-radius: 20px;
    height: 100%;
    overflow: hidden;
    position: relative;
    width: 116px;
}

.cabin-illustration::before,
.cabin-illustration::after {
    content: "";
    position: absolute;
}

.cabin-illustration::before {
    background: rgba(141, 154, 104, .8);
    border-radius: 999px 999px 0 0;
    bottom: 0;
    height: 42%;
    left: -12%;
    width: 130%;
}

.cabin-illustration::after {
    background: #6d774c;
    clip-path: polygon(50% 0, 100% 100%, 0 100%);
    height: 38px;
    right: 10px;
    top: 34px;
    width: 34px;
}

.cabin-icon-roof,
.cabin-icon-body,
.cabin-icon-door {
    display: block;
    position: absolute;
    z-index: 2;
}

.cabin-icon-roof {
    background: linear-gradient(135deg, #9d4d2d, #d98645);
    clip-path: polygon(50% 0, 100% 48%, 88% 58%, 12% 58%, 0 48%);
    height: 46px;
    left: 20px;
    top: 43px;
    width: 76px;
}

.cabin-icon-body {
    background: linear-gradient(180deg, #63351f, #2a1a10);
    border-radius: 8px 8px 4px 4px;
    bottom: 24px;
    height: 42px;
    left: 31px;
    width: 55px;
}

.cabin-icon-door {
    background: #e7bc75;
    border-radius: 4px 4px 0 0;
    bottom: 24px;
    box-shadow: 0 0 18px rgba(231, 188, 117, .5);
    height: 24px;
    left: 50px;
    width: 14px;
}

.cabin-card-copy {
    min-width: 0;
}

.cabin-card-title {
    align-items: flex-start;
    display: flex;
    gap: 8px;
    justify-content: space-between;
}

.boutique-dashboard .cabin-card h4 {
    font-size: 1.25rem;
    margin: 0 0 8px;
}

.cabin-status {
    border-radius: 999px;
    font-size: .68rem;
    font-weight: 900;
    padding: 6px 9px;
    white-space: nowrap;
}

.cabin-status.is-hot { background: #ffe0d1; color: #b94f2d; }
.cabin-status.is-soft { background: #e8ecd7; color: #65764e; }
.cabin-status.is-pending { background: #f0e4d3; color: #7a5a38; }

.boutique-dashboard .cabin-meta span,
.boutique-dashboard .reservation-meta span {
    background: rgba(235, 214, 184, .58);
    border-radius: 999px;
    color: var(--coffee-soft);
    font-size: .76rem;
    padding: 6px 9px;
}

.boutique-dashboard .cabin-card p,
.boutique-dashboard .cabin-card li {
    font-size: .86rem;
}

.cabin-occupancy {
    background: rgba(88, 59, 38, .1);
    border-radius: 999px;
    height: 10px;
    margin: 12px 0;
    overflow: hidden;
}

.cabin-occupancy span {
    animation: fillBar 1s ease both;
    background: linear-gradient(90deg, var(--terracotta), var(--gold));
    border-radius: inherit;
    display: block;
    height: 100%;
}

.boutique-dashboard .intelligent-analysis-panel {
    display: grid;
    gap: 18px;
    grid-column: span 12;
    padding: 24px;
}

.boutique-dashboard .analysis-header {
    align-items: center;
    display: flex;
    justify-content: space-between;
}

.boutique-dashboard .data-badge {
    background: rgba(101, 118, 78, .16);
    border: 1px solid rgba(101, 118, 78, .16);
    border-radius: 999px;
    color: var(--olive-dark);
    font-weight: 900;
    padding: 9px 12px;
}

.boutique-dashboard .analysis-summary,
.boutique-dashboard .analysis-grid,
.boutique-dashboard .charts-grid,
.boutique-dashboard .ai-insights,
.quick-analysis-list {
    display: grid;
    gap: 14px;
}

.boutique-dashboard .analysis-summary {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.boutique-dashboard .analysis-summary article {
    background: rgba(255, 252, 246, .58);
    border: 1px solid rgba(92, 61, 39, .08);
    border-radius: 24px;
    padding: 18px;
}

.boutique-dashboard .analysis-summary span,
.boutique-dashboard .analysis-card-title span {
    color: rgba(62, 43, 29, .62);
    font-size: .78rem;
    font-weight: 900;
}

.boutique-dashboard .analysis-summary strong {
    color: var(--coffee);
    display: block;
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 2rem;
    margin-top: 6px;
}

.boutique-dashboard .charts-grid {
    grid-template-columns: minmax(0, 1.35fr) minmax(250px, .8fr) minmax(260px, 1fr);
}

.boutique-dashboard .analysis-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.boutique-dashboard .analysis-card,
.boutique-dashboard .ai-insight-card,
.boutique-dashboard .prediction-card {
    background: rgba(255, 252, 246, .62);
    padding: 20px;
    transition: transform .24s ease, box-shadow .24s ease;
}

.boutique-dashboard .analysis-card-title {
    align-items: flex-start;
    display: flex;
    justify-content: space-between;
    margin-bottom: 16px;
}

.boutique-dashboard .analysis-card-title strong {
    color: var(--coffee);
    font-size: .9rem;
}

.boutique-dashboard .bar-chart {
    align-items: end;
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    min-height: 230px;
}

.boutique-dashboard .bar-track {
    background: linear-gradient(180deg, rgba(237, 218, 190, .7), rgba(237, 218, 190, .24));
    border-radius: 999px;
    height: 178px;
    width: 24px;
}

.boutique-dashboard .bar-track span {
    animation: barRise 1s ease both;
    background: linear-gradient(180deg, #eabf77, #d16e3d);
    border-radius: 999px;
}

.boutique-dashboard .bar-item.is-top .bar-track span {
    background: linear-gradient(180deg, #2a1a10, #d16e3d);
}

.boutique-dashboard .line-chart {
    align-items: end;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .4), rgba(239, 224, 204, .34));
    border-radius: 24px;
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    min-height: 230px;
    padding: 16px;
}

.boutique-dashboard .line-point {
    animation: fillBar 1s ease both;
    background: linear-gradient(180deg, #7b8b57, #d9b371);
    border-radius: 999px 999px 16px 16px;
    min-height: 56px;
}

.boutique-dashboard .heat-calendar {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(7, minmax(0, 1fr));
}

.boutique-dashboard .heat-day {
    border-radius: 999px;
    min-height: 42px;
    padding: 8px 7px;
    text-align: center;
}

.boutique-dashboard .heat-day.low { background: #f1e8dc; }
.boutique-dashboard .heat-day.medium { background: #e9bd72; }
.boutique-dashboard .heat-day.high { background: #ce7040; color: #fff; }

.ranking-row,
.income-estimates div {
    align-items: center;
    background: rgba(255, 252, 246, .62);
    border: 1px solid rgba(92, 61, 39, .07);
    border-radius: 18px;
    display: flex;
    justify-content: space-between;
    margin-bottom: 8px;
    padding: 11px 12px;
}

.ranking-row.is-top {
    background: rgba(221, 183, 120, .24);
}

.insight-list {
    color: rgba(62, 43, 29, .78);
    display: grid;
    gap: 11px;
    margin: 0;
    padding-left: 18px;
}

.boutique-dashboard .ai-insight-card {
    background:
        radial-gradient(circle at 90% 10%, rgba(101, 118, 78, .18), transparent 30%),
        linear-gradient(135deg, rgba(255, 247, 235, .82), rgba(237, 219, 195, .62));
}

.boutique-dashboard .ai-insight-card > span,
.boutique-dashboard .prediction-card > div > span {
    color: var(--terracotta-dark);
    display: inline-flex;
    font-weight: 900;
    margin-bottom: 14px;
}

.boutique-dashboard .ai-insights {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.boutique-dashboard .prediction-card {
    align-items: center;
    background:
        linear-gradient(135deg, rgba(42, 26, 16, .96), rgba(111, 72, 42, .88)),
        radial-gradient(circle at 88% 35%, rgba(221, 183, 120, .34), transparent 34%);
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(190px, .55fr) minmax(0, 1fr) 120px;
    overflow: hidden;
}

.boutique-dashboard .prediction-card strong,
.boutique-dashboard .prediction-card p,
.boutique-dashboard .prediction-card span {
    color: #fff7eb;
}

.future-estimates {
    display: grid;
    gap: 8px;
}

.future-estimates p {
    background: rgba(255, 255, 255, .08);
    border: 1px solid rgba(255, 255, 255, .1);
    border-radius: 16px;
    margin: 0;
    padding: 10px 12px;
}

.future-sticker {
    height: 96px;
    position: relative;
}

.future-sticker::before,
.future-sticker::after {
    background: linear-gradient(135deg, #d98242, #8d4328);
    border-radius: 14px;
    bottom: 8px;
    content: "";
    height: 68px;
    position: absolute;
    right: 14px;
    width: 82px;
}

.future-sticker::after {
    background: #e7bc75;
    border-radius: 999px 999px 10px 10px;
    bottom: 54px;
    height: 32px;
    right: 35px;
    width: 42px;
}

.boutique-dashboard .dashboard-quick-panel {
    grid-column: span 5;
}

.quick-analysis-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.boutique-dashboard .booking-panel {
    grid-column: span 7;
}

.boutique-dashboard .reservations-panel:not(.dashboard-quick-panel) {
    grid-column: span 5;
}

.boutique-dashboard .stacked-form,
.boutique-dashboard .reservation-form {
    display: grid;
    gap: 12px;
}

.boutique-dashboard .stacked-form input,
.boutique-dashboard .reservation-form input,
.boutique-dashboard .reservation-form textarea {
    background: rgba(255, 252, 246, .64);
    border: 1px solid rgba(92, 61, 39, .14);
    border-radius: 16px;
}

.boutique-dashboard .btn-secondary,
.boutique-dashboard .reservation-card button {
    background: rgba(235, 214, 184, .58);
    border-radius: 16px;
    color: var(--coffee);
}

.boutique-dashboard .reservation-card {
    background: rgba(255, 252, 246, .62);
    border: 1px solid rgba(92, 61, 39, .09);
    border-radius: 22px;
}

.preview-empty {
    background:
        linear-gradient(135deg, rgba(255, 252, 246, .78), rgba(235, 214, 184, .44));
    border: 1px solid rgba(92, 61, 39, .1);
    border-radius: 24px;
    padding: 18px;
}

.preview-empty span,
.preview-empty strong {
    color: var(--coffee);
    display: block;
}

.preview-empty span {
    color: var(--terracotta-dark);
    font-size: .78rem;
    font-weight: 900;
    text-transform: uppercase;
}

.preview-empty strong {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 1.35rem;
    margin: 6px 0;
}

.preview-empty i {
    animation: skeleton 1.4s ease-in-out infinite;
    background: linear-gradient(90deg, rgba(221, 183, 120, .18), rgba(255, 255, 255, .7), rgba(221, 183, 120, .18));
    border-radius: 999px;
    display: block;
    height: 12px;
    margin-top: 10px;
}

.preview-empty i:nth-of-type(2) { width: 78%; }
.preview-empty i:nth-of-type(3) { width: 56%; }

.boutique-dashboard .form-row {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

@keyframes barRise {
    from { transform: scaleY(.18); transform-origin: bottom; }
    to { transform: scaleY(1); transform-origin: bottom; }
}

@keyframes fillBar {
    from { opacity: .2; transform: scaleX(.5); transform-origin: left; }
    to { opacity: 1; transform: scaleX(1); transform-origin: left; }
}

@keyframes skeleton {
    0% { background-position: -180px 0; }
    100% { background-position: 180px 0; }
}

@media (max-width: 1240px) {
    .boutique-dashboard nav {
        border-radius: 0;
        min-height: auto;
        position: relative;
        width: 100%;
    }

    .sidebar-art,
    .sidebar-user {
        display: none;
    }

    .boutique-dashboard .nav-links {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .boutique-dashboard .dashboard-shell {
        margin-left: 0;
    }

    .millaray-hero-card,
    .boutique-dashboard .admin-dashboard,
    .boutique-dashboard .reservation-grid,
    .activity-panel,
    .boutique-dashboard .dashboard-quick-panel,
    .boutique-dashboard .booking-panel,
    .boutique-dashboard .reservations-panel:not(.dashboard-quick-panel) {
        grid-column: span 12;
    }
}

@media (max-width: 900px) {
    .boutique-dashboard .dashboard-topbar,
    .boutique-dashboard .dashboard-actions,
    .boutique-dashboard .analysis-header {
        align-items: stretch;
        flex-direction: column;
    }

    .boutique-dashboard .dashboard-search {
        min-width: 0;
        width: 100%;
    }

    .millaray-hero-card,
    .boutique-dashboard .reservation-grid,
    .boutique-dashboard .charts-grid,
    .boutique-dashboard .analysis-grid,
    .boutique-dashboard .analysis-summary,
    .boutique-dashboard .ai-insights,
    .boutique-dashboard .prediction-card {
        grid-template-columns: 1fr;
    }

    .boutique-dashboard .admin-dashboard,
    .boutique-dashboard .cabins-list,
    .quick-analysis-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .boutique-dashboard .dashboard-shell {
        padding: 22px 14px 34px;
    }

    .boutique-dashboard .nav-links,
    .boutique-dashboard .admin-dashboard,
    .boutique-dashboard .cabins-list,
    .quick-analysis-list,
    .boutique-dashboard .form-row {
        grid-template-columns: 1fr;
    }

    .millaray-hero-card {
        border-radius: 28px;
        min-height: auto;
    }

    .hero-illustration {
        min-height: 240px;
    }

    .boutique-dashboard .cabin-card {
        grid-template-columns: 96px minmax(0, 1fr);
    }

    .cabin-thumb {
        width: 96px;
    }

    .boutique-dashboard .heat-calendar {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

/* Reservation admin dashboard */
.reservas-admin-page {
    background:
        radial-gradient(circle at top left, rgba(232, 201, 149, .32), transparent 34%),
        linear-gradient(135deg, #fffaf3 0%, #f4eadc 100%);
    padding-top: 0;
}

.reservas-admin-page::before {
    display: none;
}

.reservas-admin-page nav {
    align-content: flex-start;
    align-items: flex-start;
    background:
        linear-gradient(180deg, rgba(35, 23, 15, .97), rgba(22, 14, 10, .98)),
        url("Cabaña1.webp") center bottom / cover;
    border-bottom: 0;
    bottom: 0;
    box-shadow: 18px 0 50px rgba(45, 28, 16, .18);
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    gap: 26px;
    left: 0;
    min-height: 100vh;
    padding: 30px 18px;
    right: auto;
    text-align: left;
    top: 0;
    width: 250px;
}

.reservas-admin-page .logo-nav {
    height: auto;
    margin: 0 0 8px;
    width: 96px;
}

.reservas-admin-page .nav-toggle {
    display: none;
}

.reservas-admin-page .nav-links {
    align-items: stretch;
    display: grid;
    gap: 10px;
    width: 100%;
}

.reservas-admin-page .nav-links a {
    border-radius: 10px;
    color: rgba(255, 255, 255, .88);
    display: block;
    font-size: .96rem;
    padding: 13px 16px;
}

.reservas-admin-page .nav-links a:first-child,
.reservas-admin-page .nav-links a:hover {
    background: linear-gradient(90deg, #b9783e, #d59a5a);
    color: #fff;
    transform: none;
}

.reservas-admin-page .page-hero,
.reservas-admin-page footer {
    display: none;
}

.dashboard-shell {
    background: transparent;
    display: flex;
    flex-direction: column;
    margin-left: 250px;
    max-width: none;
    min-height: 100vh;
    padding: 34px 32px 46px;
}

.dashboard-topbar {
    align-items: center;
    display: flex;
    gap: 18px;
    justify-content: space-between;
    margin-bottom: 22px;
    order: 1;
}

.dashboard-title h2 {
    color: #241910;
    font-size: clamp(2rem, 3vw, 3rem);
    line-height: 1;
    margin: 0 0 8px;
}

.dashboard-title p {
    margin: 0;
}

.dashboard-actions {
    align-items: center;
    display: flex;
    gap: 14px;
}

.dashboard-search {
    align-items: center;
    background: rgba(255, 255, 255, .72);
    border: 1px solid rgba(94, 62, 35, .14);
    border-radius: 10px;
    display: flex;
    min-width: 330px;
    padding: 0 14px;
}

.dashboard-search span {
    height: 1px;
    overflow: hidden;
    position: absolute;
    width: 1px;
}

.dashboard-search input {
    background: transparent;
    border: 0;
    color: #2d2017;
    font: inherit;
    min-height: 48px;
    outline: 0;
    width: 100%;
}

.dashboard-date,
.dashboard-new-booking {
    align-items: center;
    background: rgba(255, 255, 255, .78);
    border: 1px solid rgba(94, 62, 35, .14);
    border-radius: 10px;
    color: #2d2017;
    display: inline-flex;
    font-weight: 800;
    min-height: 48px;
    padding: 0 16px;
    white-space: nowrap;
}

.dashboard-new-booking {
    background: linear-gradient(135deg, #cf7840, #df6b38);
    color: #fff;
    text-decoration: none;
}

.admin-section-heading {
    display: none;
}

.reservas-admin-page .reservation-grid {
    grid-template-columns: minmax(280px, .7fr) minmax(420px, 1.3fr);
    margin-top: 16px;
    order: 5;
}

.reservas-admin-page .auth-panel,
.reservas-admin-page .cabins-panel,
.reservas-admin-page .booking-panel,
.reservas-admin-page .reservations-panel,
.reservas-admin-page .intelligent-analysis-panel,
.reservas-admin-page .metric-card {
    background: rgba(255, 255, 255, .72);
    border: 1px solid rgba(91, 61, 35, .11);
    border-radius: 14px;
    box-shadow: 0 20px 50px rgba(73, 43, 21, .08);
}

.reservas-admin-page .admin-dashboard {
    grid-template-columns: repeat(6, minmax(0, 1fr));
    margin: 0 0 16px;
    order: 2;
}

.reservas-admin-page .metric-card {
    color: #2a1c12;
    min-height: 136px;
    padding: 18px 18px 16px;
}

.reservas-admin-page .metric-card-bookings {
    order: 5;
}

.reservas-admin-page .metric-card-guests {
    order: 3;
}

.reservas-admin-page .metric-card-income {
    order: 1;
}

.reservas-admin-page .metric-card-day {
    order: 4;
}

.reservas-admin-page .metric-card-cabin {
    order: 2;
}

.reservas-admin-page .metric-card-active {
    order: 6;
}

.reservas-admin-page .metric-card span {
    color: #3d2a1c;
    font-size: .74rem;
    letter-spacing: .08em;
    margin-bottom: 2px;
    text-transform: uppercase;
}

.reservas-admin-page .metric-card strong {
    color: #26170f;
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(1.65rem, 2.5vw, 2.35rem);
}

.reservas-admin-page .metric-card small {
    color: #6b8c4f;
    display: block;
    font-size: .8rem;
    font-weight: 700;
    margin-top: auto;
}

.reservas-admin-page .compact-metric {
    display: none;
}

.reservas-admin-page .intelligent-analysis-panel {
    display: flex;
    flex-direction: column;
    order: 3;
    padding: 20px;
}

.reservas-admin-page .intelligent-analysis-panel .charts-grid {
    order: 1;
}

.reservas-admin-page .intelligent-analysis-panel .analysis-header {
    order: 2;
}

.reservas-admin-page .intelligent-analysis-panel .ai-insight-card {
    order: 3;
}

.reservas-admin-page .intelligent-analysis-panel .analysis-summary {
    order: 4;
}

.reservas-admin-page .intelligent-analysis-panel .analysis-grid {
    order: 5;
}

.reservas-admin-page .analysis-summary {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.reservas-admin-page .analysis-grid {
    grid-template-columns: 1.4fr 1fr 1fr;
}

.reservas-admin-page .charts-grid {
    grid-template-columns: 1.65fr 1fr 1fr;
    margin-bottom: 18px;
}

.reservas-admin-page .charts-grid .prediction-card {
    grid-column: 1 / -1;
}

.reservas-admin-page .analysis-summary article,
.reservas-admin-page .analysis-card,
.reservas-admin-page .prediction-card,
.reservas-admin-page .ai-insight-card {
    background: rgba(255, 251, 245, .88);
    border-color: rgba(91, 61, 35, .1);
    border-radius: 12px;
}

.reservas-admin-page .ai-insight-card,
.reservas-admin-page .prediction-card {
    background: linear-gradient(135deg, #fff6e8, #f3dfc8);
}

.reservas-admin-page .ai-insight-card {
    margin-bottom: 18px;
}

.reservas-admin-page .ai-insight-card span,
.reservas-admin-page .prediction-card span {
    color: #b05d2f;
}

.reservas-admin-page .prediction-card strong,
.reservas-admin-page .prediction-card p {
    color: #2d2017;
}

.reservas-admin-page .ai-insights {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.reservas-admin-page .ai-insights p {
    background: rgba(255, 255, 255, .6);
    border-color: rgba(91, 61, 35, .08);
    color: #4c3c2c;
}

.dashboard-quick-panel {
    margin-top: 16px;
    order: 4;
}

.reservas-admin-page .booking-panel {
    order: 6;
}

.reservas-admin-page .reservations-panel:not(.dashboard-quick-panel) {
    order: 7;
}

.quick-analysis-list {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.quick-analysis-list p {
    background: #fff7ec;
    border: 1px solid rgba(91, 61, 35, .08);
    border-radius: 10px;
    color: #473525;
    margin: 0;
    padding: 12px;
}

.reservas-admin-page .cabin-card {
    background: rgba(255, 250, 244, .92);
    border-radius: 12px;
}

@media (max-width: 1180px) {
    .reservas-admin-page nav {
        position: static;
        min-height: auto;
        width: 100%;
    }

    .dashboard-shell {
        margin-left: 0;
    }

    .reservas-admin-page .admin-dashboard,
    .reservas-admin-page .analysis-grid,
    .reservas-admin-page .charts-grid,
    .reservas-admin-page .ai-insights,
    .quick-analysis-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .dashboard-topbar,
    .dashboard-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .dashboard-search {
        min-width: 0;
        width: 100%;
    }
}

@media (max-width: 700px) {
    .dashboard-shell {
        padding: 22px 14px 34px;
    }

    .reservas-admin-page .admin-dashboard,
    .reservas-admin-page .analysis-summary,
    .reservas-admin-page .analysis-grid,
    .reservas-admin-page .charts-grid,
    .reservas-admin-page .ai-insights,
    .quick-analysis-list {
        grid-template-columns: 1fr;
    }
}

/* Final boutique dashboard cascade lock */
.boutique-dashboard.reservas-admin-page {
    background:
        radial-gradient(circle at 12% 6%, rgba(221, 183, 120, .28), transparent 26%),
        radial-gradient(circle at 86% 18%, rgba(141, 154, 104, .18), transparent 27%),
        linear-gradient(135deg, #fff7eb 0%, #f4e5d1 48%, #efe0cc 100%);
}

.boutique-dashboard.reservas-admin-page nav {
    background:
        linear-gradient(180deg, rgba(45, 28, 17, .94), rgba(25, 15, 10, .98)),
        radial-gradient(circle at 70% 36%, rgba(221, 183, 120, .2), transparent 34%);
    border-radius: 0 28px 28px 0;
    gap: 24px;
    padding: 28px 16px 24px;
    position: fixed;
    width: 260px;
}

.boutique-dashboard .dashboard-shell {
    display: block;
    margin-left: 260px;
    padding: 36px clamp(18px, 3.2vw, 46px) 52px;
}

.boutique-dashboard .dashboard-canvas {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(12, minmax(0, 1fr));
}

.boutique-dashboard .millaray-hero-card { grid-column: span 7; }

.boutique-dashboard .admin-dashboard {
    display: grid;
    gap: 14px;
    grid-column: span 5;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin: 0;
    order: initial;
}

.boutique-dashboard .reservation-grid {
    display: grid;
    gap: 18px;
    grid-column: span 7;
    grid-template-columns: minmax(250px, .55fr) minmax(0, 1.45fr);
    margin: 0;
    order: initial;
}

.boutique-dashboard .activity-panel {
    grid-column: span 5;
}

.boutique-dashboard .intelligent-analysis-panel {
    display: grid;
    grid-column: span 12;
    order: initial;
}

.boutique-dashboard .dashboard-quick-panel {
    grid-column: span 5;
    margin-top: 0;
    order: initial;
}

.boutique-dashboard .booking-panel {
    grid-column: span 7;
    order: initial;
}

.boutique-dashboard .reservations-panel:not(.dashboard-quick-panel) {
    grid-column: span 5;
    order: initial;
}

.boutique-dashboard .metric-card,
.boutique-dashboard .auth-panel,
.boutique-dashboard .cabins-panel,
.boutique-dashboard .booking-panel,
.boutique-dashboard .reservations-panel,
.boutique-dashboard .intelligent-analysis-panel {
    background: rgba(255, 250, 240, .78);
    border: 1px solid rgba(92, 61, 39, .12);
    border-radius: 30px;
    box-shadow: 0 24px 70px rgba(76, 45, 22, .11);
}

.boutique-dashboard .metric-card {
    min-height: 130px;
    padding: 18px;
}

.boutique-dashboard .cabins-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.boutique-dashboard .cabin-card {
    background: rgba(255, 252, 246, .58);
    border-radius: 26px;
    grid-template-columns: 116px minmax(0, 1fr);
    padding: 12px;
}

.boutique-dashboard .analysis-summary {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.boutique-dashboard .charts-grid {
    grid-template-columns: minmax(0, 1.35fr) minmax(250px, .8fr) minmax(260px, 1fr);
}

.boutique-dashboard .analysis-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.boutique-dashboard .ai-insights {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.boutique-dashboard .quick-analysis-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.boutique-dashboard .admin-dashboard[hidden],
.boutique-dashboard .intelligent-analysis-panel[hidden],
.boutique-dashboard .dashboard-quick-panel[hidden] {
    display: none;
}

.market-dashboard-strip {
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(0, 1.2fr) minmax(260px, .9fr) minmax(260px, .9fr);
    margin-bottom: 14px;
}

.booking-funnel,
.horizontal-bar-chart {
    display: grid;
    gap: 11px;
}

.funnel-row,
.horizontal-row {
    align-items: center;
    display: grid;
    gap: 10px;
    grid-template-columns: 96px minmax(0, 1fr) 42px;
}

.funnel-row span,
.horizontal-row span,
.funnel-row strong,
.horizontal-row strong {
    color: var(--coffee-soft);
    font-size: .82rem;
    font-weight: 900;
}

.funnel-row div,
.horizontal-row div {
    background: rgba(237, 218, 190, .54);
    border-radius: 999px;
    height: 16px;
    overflow: hidden;
}

.funnel-row i,
.horizontal-row i {
    animation: fillBar 1s ease both;
    background: linear-gradient(90deg, #d16e3d, #eabf77);
    border-radius: inherit;
    display: block;
    height: 100%;
}

.market-funnel-card .funnel-row:nth-child(1) i { background: linear-gradient(90deg, #2a1a10, #c66f40); }
.market-funnel-card .funnel-row:nth-child(2) i { background: linear-gradient(90deg, #7b8b57, #d9b371); }
.market-funnel-card .funnel-row:nth-child(3) i { background: linear-gradient(90deg, #b85f3a, #eabf77); }

.profit-donut {
    align-items: center;
    display: grid;
    gap: 14px;
    grid-template-columns: 118px minmax(0, 1fr);
}

.donut-ring {
    align-items: center;
    aspect-ratio: 1;
    background:
        radial-gradient(circle, rgba(255, 252, 246, .96) 0 55%, transparent 56%),
        conic-gradient(#d16e3d calc(var(--score) * 1%), rgba(237, 218, 190, .72) 0);
    border-radius: 50%;
    display: grid;
    justify-items: center;
    padding: 14px;
}

.donut-ring strong {
    color: var(--coffee);
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 1.65rem;
    line-height: 1;
}

.donut-ring span,
.donut-copy p {
    color: rgba(62, 43, 29, .72);
    font-size: .82rem;
    font-weight: 800;
    margin: 0;
}

.donut-copy {
    display: grid;
    gap: 8px;
}

.donut-copy strong {
    color: var(--coffee);
    display: block;
    font-size: 1rem;
}

.market-table-card {
    overflow: hidden;
}

.market-table {
    overflow-x: auto;
}

.market-table table {
    border-collapse: collapse;
    min-width: 720px;
    width: 100%;
}

.market-table th,
.market-table td {
    border-bottom: 1px solid rgba(92, 61, 39, .09);
    color: var(--coffee-soft);
    font-size: .86rem;
    padding: 11px 10px;
    text-align: left;
    white-space: nowrap;
}

.market-table th {
    color: rgba(62, 43, 29, .62);
    font-size: .74rem;
    font-weight: 900;
    letter-spacing: .06em;
    text-transform: uppercase;
}

.market-table td:nth-child(5) {
    color: var(--coffee);
    font-weight: 900;
}

.margin-pill {
    background: rgba(123, 139, 87, .16);
    border-radius: 999px;
    color: #55653d;
    display: inline-flex;
    font-weight: 900;
    padding: 5px 9px;
}

.market-table p {
    background: rgba(221, 183, 120, .18);
    border-radius: 14px;
    color: var(--coffee-soft);
    font-weight: 800;
    margin: 14px 0 0;
    padding: 12px 14px;
}

@media (max-width: 1240px) {
    .boutique-dashboard.reservas-admin-page nav {
        border-radius: 0;
        position: relative;
        width: 100%;
    }

    .boutique-dashboard .dashboard-shell {
        margin-left: 0;
    }

    .boutique-dashboard .millaray-hero-card,
    .boutique-dashboard .admin-dashboard,
    .boutique-dashboard .reservation-grid,
    .boutique-dashboard .activity-panel,
    .boutique-dashboard .dashboard-quick-panel,
    .boutique-dashboard .booking-panel,
    .boutique-dashboard .reservations-panel:not(.dashboard-quick-panel) {
        grid-column: span 12;
    }
}

@media (max-width: 900px) {
    .boutique-dashboard .millaray-hero-card,
    .boutique-dashboard .reservation-grid,
        .boutique-dashboard .charts-grid,
        .boutique-dashboard .analysis-grid,
        .boutique-dashboard .analysis-summary,
        .market-dashboard-strip,
        .boutique-dashboard .ai-insights,
        .boutique-dashboard .prediction-card {
        grid-template-columns: 1fr;
    }

    .boutique-dashboard .admin-dashboard,
    .boutique-dashboard .cabins-list,
    .boutique-dashboard .quick-analysis-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .boutique-dashboard .admin-dashboard,
    .boutique-dashboard .cabins-list,
    .boutique-dashboard .quick-analysis-list,
    .boutique-dashboard .form-row {
        grid-template-columns: 1fr;
    }

    .boutique-dashboard .cabin-card {
        grid-template-columns: 96px minmax(0, 1fr);
    }
}

/* Analytics dashboard visual match */
.boutique-dashboard.reservas-admin-page {
    background: #c4c2ea;
    color: #28304a;
}

.boutique-dashboard.reservas-admin-page nav {
    background: #ffffff;
    border: 0;
    border-radius: 10px;
    bottom: auto;
    box-shadow: 0 10px 26px rgba(69, 72, 128, .16);
    gap: 12px;
    left: 14px;
    min-height: calc(100vh - 28px);
    padding: 12px 8px;
    top: 14px;
    width: 82px;
}

.boutique-dashboard .sidebar-brand {
    display: grid;
    gap: 6px;
    justify-items: center;
    padding: 0 0 8px;
}

.boutique-dashboard .sidebar-brand .logo-nav {
    height: 50px;
    width: 50px;
}

.boutique-dashboard .sidebar-brand div,
.boutique-dashboard .sidebar-art,
.boutique-dashboard .sidebar-user {
    display: none;
}

.boutique-dashboard .nav-links {
    gap: 7px;
}

.boutique-dashboard .nav-links a {
    align-items: center;
    background: #f3f4ff;
    border-radius: 6px;
    color: #596079;
    display: flex;
    font-size: .62rem;
    font-weight: 800;
    justify-content: center;
    line-height: 1.1;
    min-height: 44px;
    padding: 6px 4px;
    text-align: center;
}

.boutique-dashboard .nav-links a::before {
    display: none;
}

.boutique-dashboard .nav-links a.is-active,
.boutique-dashboard .nav-links a:hover {
    background: #6f73d2;
    color: #fff;
    transform: none;
}

.boutique-dashboard .dashboard-shell {
    margin-left: 104px;
    padding: 14px 18px 24px;
}

.boutique-dashboard .dashboard-topbar {
    align-items: center;
    background: transparent;
    margin: 0 0 12px;
}

.boutique-dashboard .dashboard-title .eyebrow,
.boutique-dashboard .dashboard-title p,
.boutique-dashboard .dashboard-actions {
    display: none;
}

.boutique-dashboard .dashboard-title h2 {
    color: #27304e;
    font-family: 'Inter', Arial, sans-serif;
    font-size: 1.08rem;
    font-weight: 900;
    letter-spacing: .04em;
    line-height: 1.1;
    margin: 0;
    text-transform: uppercase;
}

.boutique-dashboard .dashboard-title h2::after {
    color: #7680a6;
    content: " / mercado, reservas y comidas";
    font-size: .76rem;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: none;
}

.boutique-dashboard .dashboard-canvas {
    align-items: start;
    background: #d7d6f1;
    border-radius: 8px;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .55);
    gap: 10px;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    padding: 10px;
}

.boutique-dashboard .millaray-hero-card {
    display: none;
}

.boutique-dashboard .admin-dashboard {
    gap: 8px;
    grid-column: span 12;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    order: 1 !important;
}

.boutique-dashboard .metric-card,
.boutique-dashboard .auth-panel,
.boutique-dashboard .cabins-panel,
.boutique-dashboard .booking-panel,
.boutique-dashboard .reservations-panel,
.boutique-dashboard .activity-panel,
.boutique-dashboard .intelligent-analysis-panel,
.boutique-dashboard .analysis-card,
.boutique-dashboard .prediction-card,
.boutique-dashboard .ai-insight-card,
.boutique-dashboard .analysis-summary article {
    backdrop-filter: none;
    background: #ffffff;
    border: 1px solid #ebeefa;
    border-radius: 8px;
    box-shadow: 0 10px 22px rgba(80, 84, 142, .1);
}

.boutique-dashboard .metric-card {
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-height: 136px;
    overflow: hidden;
    padding: 18px 18px 16px;
    position: relative;
}

.boutique-dashboard .metric-card i {
    align-items: center;
    background: linear-gradient(135deg, rgba(227, 194, 139, .22), rgba(201, 111, 61, .14));
    border: 1px solid rgba(201, 111, 61, .12);
    border-radius: 16px;
    color: var(--terracotta);
    display: inline-flex;
    font-size: 1rem;
    font-style: normal;
    font-weight: 900;
    height: 42px;
    justify-content: center;
    letter-spacing: .02em;
    position: absolute;
    right: 16px;
    top: 16px;
    width: 46px;
}

.boutique-dashboard .metric-card i::before,
.boutique-dashboard .metric-card i::after {
    content: none;
}

.boutique-dashboard .metric-card span {
    color: rgba(62, 43, 29, .72);
    display: block;
    font-size: .74rem;
    font-weight: 700;
    letter-spacing: .08em;
    margin-bottom: 2px;
    max-width: 140px;
    text-transform: uppercase;
}

.boutique-dashboard .metric-card strong {
    color: var(--coffee);
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(1.55rem, 2.4vw, 2.35rem);
    line-height: 1;
}

.boutique-dashboard .metric-card small {
    color: rgba(62, 43, 29, .72);
    font-size: .76rem;
    font-weight: 700;
    margin-top: auto;
}

.boutique-dashboard .intelligent-analysis-panel {
    background: #f6f7ff;
    display: grid;
    gap: 10px;
    grid-column: span 12;
    order: 2 !important;
    padding: 10px;
}

.boutique-dashboard .analysis-header {
    align-items: center;
    display: flex;
    margin: 0;
}

.boutique-dashboard .panel-kicker {
    color: #6f73d2;
    font-size: .64rem;
}

.boutique-dashboard .analysis-header h3 {
    color: #27304e;
    font-family: 'Inter', Arial, sans-serif;
    font-size: 1rem;
    font-weight: 900;
    margin: 2px 0;
}

.boutique-dashboard .analysis-header p {
    color: #747c99;
    font-size: .78rem;
}

.boutique-dashboard .data-badge {
    background: #eef0ff;
    border-color: #dadcf8;
    border-radius: 999px;
    color: #5f65c7;
    font-size: .68rem;
}

.boutique-dashboard .analysis-summary,
.market-dashboard-strip,
.boutique-dashboard .charts-grid,
.boutique-dashboard .analysis-grid {
    gap: 8px;
    margin: 0;
}

.boutique-dashboard .intelligent-analysis-panel .analysis-header { order: 0 !important; }
.boutique-dashboard .intelligent-analysis-panel .analysis-summary { order: 1 !important; }
.boutique-dashboard .intelligent-analysis-panel .market-dashboard-strip { order: 2 !important; }
.boutique-dashboard .intelligent-analysis-panel .charts-grid { order: 3 !important; }
.boutique-dashboard .intelligent-analysis-panel .analysis-grid { order: 4 !important; }
.boutique-dashboard .intelligent-analysis-panel .market-table-card { order: 5 !important; }
.boutique-dashboard .intelligent-analysis-panel .ai-insight-card { order: 6 !important; }
.boutique-dashboard .intelligent-analysis-panel .prediction-card { order: 7 !important; }

.boutique-dashboard .analysis-summary {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.market-dashboard-strip {
    grid-template-columns: 1.25fr 1fr 1fr;
}

.boutique-dashboard .charts-grid {
    grid-template-columns: 1.25fr 1fr 1fr;
}

.boutique-dashboard .analysis-grid {
    grid-template-columns: 1fr 1fr 1fr;
}

.boutique-dashboard .analysis-summary article,
.boutique-dashboard .analysis-card,
.boutique-dashboard .ai-insight-card,
.boutique-dashboard .prediction-card {
    padding: 10px 12px;
}

.boutique-dashboard .analysis-summary span,
.boutique-dashboard .analysis-card-title span,
.boutique-dashboard .prediction-card span,
.boutique-dashboard .ai-insight-card span {
    color: #747c99;
    font-size: .66rem;
    letter-spacing: 0;
    text-transform: none;
}

.boutique-dashboard .analysis-summary strong,
.boutique-dashboard .analysis-card-title strong,
.boutique-dashboard .prediction-card strong {
    color: #27304e;
    font-family: 'Inter', Arial, sans-serif;
    font-size: 1.05rem;
    font-weight: 900;
}

.boutique-dashboard .analysis-summary p {
    color: #747c99;
    font-size: .72rem;
}

.boutique-dashboard .analysis-card-title {
    align-items: center;
    margin-bottom: 8px;
}

.boutique-dashboard .bar-chart {
    gap: 6px;
    min-height: 145px;
}

.boutique-dashboard .bar-track {
    background: #f0f1fb;
    border-radius: 0;
    height: 112px;
    width: 100%;
}

.boutique-dashboard .bar-track span {
    background: #6f73d2;
    border-radius: 0;
}

.boutique-dashboard .bar-item.is-top .bar-track span {
    background: #4e55bd;
}

.boutique-dashboard .bar-item strong,
.boutique-dashboard .bar-item small {
    color: #27304e;
    font-size: .66rem;
}

.boutique-dashboard .line-chart {
    background: #ffffff;
    border-radius: 4px;
    gap: 7px;
    min-height: 145px;
    padding: 8px;
}

.boutique-dashboard .line-point {
    background: linear-gradient(180deg, #b8a7f2, #6f73d2);
    border-radius: 2px 2px 0 0;
    min-height: 28px;
}

.boutique-dashboard .line-point strong,
.boutique-dashboard .line-point span {
    color: #fff;
    font-size: .62rem;
}

.boutique-dashboard .heat-calendar {
    gap: 6px;
    grid-template-columns: repeat(7, minmax(0, 1fr));
}

.boutique-dashboard .heat-day {
    border-radius: 6px;
    min-height: 42px;
}

.boutique-dashboard .heat-day.low { background: #eef0f8; color: #27304e; }
.boutique-dashboard .heat-day.medium { background: #c8b8f4; color: #27304e; }
.boutique-dashboard .heat-day.high { background: #7474d7; color: #fff; }

.funnel-row,
.horizontal-row {
    grid-template-columns: 82px minmax(0, 1fr) 34px;
}

.funnel-row span,
.horizontal-row span,
.funnel-row strong,
.horizontal-row strong {
    color: #27304e;
    font-size: .68rem;
}

.funnel-row div,
.horizontal-row div {
    background: #eef0f8;
    border-radius: 3px;
    height: 12px;
}

.funnel-row i,
.horizontal-row i {
    background: #6f73d2;
    border-radius: 3px;
}

.market-funnel-card .funnel-row:nth-child(1) i,
.market-funnel-card .funnel-row:nth-child(2) i,
.market-funnel-card .funnel-row:nth-child(3) i {
    background: #6f73d2;
}

.profit-donut {
    grid-template-columns: 82px minmax(0, 1fr);
}

.donut-ring {
    background:
        radial-gradient(circle, #fff 0 55%, transparent 56%),
        conic-gradient(#6f73d2 calc(var(--score) * 1%), #edf0fb 0);
}

.donut-ring strong {
    color: #27304e;
    font-family: 'Inter', Arial, sans-serif;
    font-size: 1.1rem;
}

.donut-ring span,
.donut-copy p {
    color: #747c99;
    font-size: .68rem;
}

.ranking-row,
.income-estimates div,
.boutique-dashboard .ai-insights p,
.quick-analysis-list p,
.future-estimates p {
    background: #f7f8ff;
    border: 1px solid #eceefa;
    border-radius: 6px;
    color: #27304e;
    font-size: .74rem;
    padding: 8px;
}

.ranking-row.is-top {
    background: #6f73d2;
    color: #fff;
}

.ranking-row.is-top strong {
    color: #fff;
}

.market-table table {
    min-width: 680px;
}

.market-table th,
.market-table td {
    border-bottom-color: #edf0fb;
    color: #27304e;
    font-size: .72rem;
    padding: 8px;
}

.market-table th {
    color: #747c99;
    font-size: .62rem;
}

.margin-pill {
    background: #eef0ff;
    color: #5f65c7;
}

.market-table p {
    background: #f1f3ff;
    border-radius: 6px;
    color: #27304e;
    font-size: .76rem;
    margin-top: 8px;
}

.boutique-dashboard .prediction-card {
    align-items: stretch;
    background: #ffffff;
    grid-template-columns: .65fr 1.35fr 70px;
}

.boutique-dashboard .prediction-card strong,
.boutique-dashboard .prediction-card p,
.boutique-dashboard .prediction-card span {
    color: #27304e;
}

.future-sticker {
    display: none;
}

.future-kpis {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-bottom: 8px;
}

.future-kpis article {
    background: #f7f8ff;
    border: 1px solid #eceefa;
    border-radius: 6px;
    padding: 8px;
}

.future-kpis span,
.future-kpis small {
    color: #747c99;
    display: block;
    font-size: .62rem;
    font-weight: 800;
}

.future-kpis strong {
    color: #27304e;
    display: block;
    font-family: 'Inter', Arial, sans-serif;
    font-size: .96rem;
    font-weight: 900;
    line-height: 1.1;
    margin: 4px 0;
}

.boutique-dashboard .reservation-grid,
.boutique-dashboard .activity-panel,
.boutique-dashboard .booking-panel,
.boutique-dashboard .reservations-panel {
    grid-column: span 12;
    order: 6 !important;
}

.boutique-dashboard .reservations-panel:not(.dashboard-quick-panel) {
    order: 8 !important;
}

.boutique-dashboard .dashboard-quick-panel {
    order: 7 !important;
}

.boutique-dashboard .reservation-grid {
    grid-template-columns: .55fr 1.45fr;
}

@media (max-width: 1240px) {
    .boutique-dashboard.reservas-admin-page nav {
        align-items: center;
        border-radius: 0 0 12px 12px;
        flex-direction: row;
        gap: 10px;
        left: 0;
        min-height: 58px;
        padding: 8px 12px;
        position: sticky;
        top: 0;
        width: 100%;
        z-index: 1000;
    }

    .boutique-dashboard .dashboard-shell {
        margin-left: 0;
        padding-top: 12px;
    }

    .boutique-dashboard .sidebar-brand {
        display: flex;
        flex: 0 0 auto;
        padding: 0;
    }

    .boutique-dashboard .sidebar-brand .logo-nav {
        height: 42px;
        width: 42px;
    }

    .boutique-dashboard .nav-toggle {
        background: #f2e4d0;
        border: 1px solid rgba(92, 61, 39, .12);
        border-radius: 8px;
        color: #5a3a25;
        display: inline-flex;
        font-size: .82rem;
        font-weight: 900;
        margin-left: auto;
        min-height: 38px;
        padding: 0 12px;
    }

    .boutique-dashboard .nav-links {
        background: #fffaf2;
        border: 1px solid rgba(92, 61, 39, .12);
        border-radius: 10px;
        box-shadow: 0 16px 34px rgba(76, 45, 22, .16);
        display: none;
        gap: 7px;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        padding: 8px;
        position: absolute;
        right: 12px;
        top: 58px;
        width: min(320px, calc(100vw - 24px));
    }

    .boutique-dashboard .nav-links.open {
        display: grid !important;
    }

    .boutique-dashboard .nav-links a {
        min-height: 38px;
    }
}

@media (max-width: 900px) {
    .boutique-dashboard .admin-dashboard,
    .boutique-dashboard .analysis-summary,
    .market-dashboard-strip,
    .boutique-dashboard .charts-grid,
    .boutique-dashboard .analysis-grid,
    .boutique-dashboard .prediction-card,
    .boutique-dashboard .reservation-grid,
    .future-kpis {
        grid-template-columns: 1fr;
    }

    .boutique-dashboard .dashboard-canvas {
        padding: 8px;
    }

    .boutique-dashboard .dashboard-title h2 {
        font-size: .95rem;
    }

    .boutique-dashboard .dashboard-title h2::after {
        display: none;
    }
}

@media (max-width: 640px) {
    .boutique-dashboard .dashboard-shell {
        padding: 10px 8px 18px;
    }

    .boutique-dashboard.reservas-admin-page nav {
        min-height: 52px;
        padding: 6px 8px;
    }

    .boutique-dashboard .sidebar-brand .logo-nav {
        height: 36px;
        width: 36px;
    }

    .boutique-dashboard .nav-links {
        grid-template-columns: 1fr;
        max-height: 70vh;
        overflow-y: auto;
        right: 8px;
        top: 52px;
        width: min(260px, calc(100vw - 16px));
    }

    .boutique-dashboard .admin-dashboard {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .boutique-dashboard .metric-card {
        min-height: 70px;
        padding: 9px;
    }
}

/* Warm Millaray palette over the analytics layout */
.boutique-dashboard.reservas-admin-page {
    background: #f3e3cf;
    color: #2a1a10;
}

.boutique-dashboard .dashboard-canvas {
    background: #f7ead8;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .64);
}

.boutique-dashboard.reservas-admin-page nav {
    background: #fffaf2;
    box-shadow: 0 10px 26px rgba(76, 45, 22, .14);
}

.boutique-dashboard .nav-links a {
    background: #f2e4d0;
    color: #5a3a25;
}

.boutique-dashboard .nav-links a.is-active,
.boutique-dashboard .nav-links a:hover {
    background: linear-gradient(135deg, #cf7442, #ddb778);
    color: #fff;
}

.boutique-dashboard .dashboard-title h2,
.boutique-dashboard .dashboard-title h2::after,
.boutique-dashboard .metric-card strong,
.boutique-dashboard .analysis-header h3,
.boutique-dashboard .analysis-summary strong,
.boutique-dashboard .analysis-card-title strong,
.boutique-dashboard .prediction-card strong,
.donut-ring strong,
.future-kpis strong,
.market-table th,
.market-table td,
.funnel-row span,
.horizontal-row span,
.funnel-row strong,
.horizontal-row strong {
    color: #2a1a10;
}

.boutique-dashboard .metric-card,
.boutique-dashboard .auth-panel,
.boutique-dashboard .cabins-panel,
.boutique-dashboard .booking-panel,
.boutique-dashboard .reservations-panel,
.boutique-dashboard .activity-panel,
.boutique-dashboard .intelligent-analysis-panel,
.boutique-dashboard .analysis-card,
.boutique-dashboard .prediction-card,
.boutique-dashboard .ai-insight-card,
.boutique-dashboard .analysis-summary article {
    background: #fffaf2;
    border-color: rgba(92, 61, 39, .12);
    box-shadow: 0 10px 22px rgba(76, 45, 22, .1);
}

.boutique-dashboard .intelligent-analysis-panel {
    background: #fbf1e3;
}

.boutique-dashboard .metric-card span,
.boutique-dashboard .analysis-summary span,
.boutique-dashboard .analysis-card-title span,
.boutique-dashboard .prediction-card span,
.boutique-dashboard .ai-insight-card span,
.future-kpis span,
.future-kpis small,
.donut-ring span,
.donut-copy p {
    color: #7a5a38;
}

.boutique-dashboard .metric-card small {
    color: #9d4d2d;
}

.boutique-dashboard .panel-kicker {
    color: #9d4d2d;
}

.boutique-dashboard .data-badge,
.margin-pill {
    background: #f2e4d0;
    border-color: rgba(207, 116, 66, .18);
    color: #9d4d2d;
}

.boutique-dashboard .bar-track,
.funnel-row div,
.horizontal-row div {
    background: #f1e4d3;
}

.boutique-dashboard .bar-track span,
.boutique-dashboard .bar-item.is-top .bar-track span,
.funnel-row i,
.horizontal-row i,
.market-funnel-card .funnel-row:nth-child(1) i,
.market-funnel-card .funnel-row:nth-child(2) i,
.market-funnel-card .funnel-row:nth-child(3) i {
    background: linear-gradient(180deg, #ddb778, #cf7442);
}

.donut-ring {
    background:
        radial-gradient(circle, #fffaf2 0 55%, transparent 56%),
        conic-gradient(#cf7442 calc(var(--score) * 1%), #f1e4d3 0);
}

.boutique-dashboard .line-point {
    background: linear-gradient(180deg, #8d9a68, #ddb778);
}

.boutique-dashboard .heat-day.low {
    background: #f1e4d3;
    color: #2a1a10;
}

.boutique-dashboard .heat-day.medium {
    background: #ddb778;
    color: #2a1a10;
}

.boutique-dashboard .heat-day.high {
    background: #cf7442;
    color: #fff;
}

.ranking-row,
.income-estimates div,
.boutique-dashboard .ai-insights p,
.quick-analysis-list p,
.future-estimates p,
.future-kpis article {
    background: #fff5e8;
    border-color: rgba(92, 61, 39, .1);
}

.ranking-row.is-top {
    background: #2a1a10;
    color: #fffaf2;
}

.ranking-row.is-top strong {
    color: #ddb778;
}

.market-table th,
.market-table td {
    border-bottom-color: #ead8c0;
}

.market-table p {
    background: #f2e4d0;
    color: #2a1a10;
}

/* Premium Hostal Millaray dashboard redesign */
.millaray-premium-dashboard.reservas-admin-page {
    --millaray-bg: #F7F3EB;
    --millaray-cream: #FFF9F0;
    --millaray-gold: #E3C28B;
    --millaray-terracotta: #C98C54;
    --millaray-coffee: #8C5A34;
    --millaray-dark: #3A2417;
    --millaray-olive: #7F9363;
    --millaray-ink: #332216;
    background:
        radial-gradient(circle at 22% 0%, rgba(227, 194, 139, .34), transparent 34%),
        linear-gradient(135deg, #F7F3EB 0%, #F3E6D3 48%, #EFE1CD 100%);
    color: var(--millaray-ink);
    font-family: 'Inter', Arial, sans-serif;
    min-height: 100vh;
    padding-top: 0;
}

.millaray-premium-dashboard::before {
    display: none;
}

.millaray-premium-dashboard .page-hero {
    display: none;
}

.millaray-premium-dashboard h1,
.millaray-premium-dashboard h2,
.millaray-premium-dashboard h3,
.millaray-premium-dashboard h4 {
    color: var(--millaray-dark);
    font-family: 'Playfair Display', Georgia, serif;
    letter-spacing: 0;
}

.millaray-premium-dashboard p {
    color: rgba(58, 36, 23, .68);
}

.millaray-premium-dashboard.reservas-admin-page nav {
    align-content: start;
    align-items: stretch;
    background:
        linear-gradient(165deg, rgba(58, 36, 23, .98), rgba(92, 55, 30, .96) 58%, rgba(139, 89, 51, .94)),
        radial-gradient(circle at 30% 8%, rgba(227, 194, 139, .32), transparent 30%);
    border: 1px solid rgba(255, 249, 240, .12);
    border-radius: 0;
    bottom: 0;
    box-shadow: 18px 0 42px rgba(58, 36, 23, .18);
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    gap: 18px;
    left: 0;
    min-height: 100vh;
    overflow: hidden;
    padding: 24px 18px;
    position: fixed;
    top: 0;
    width: 270px;
    z-index: 50;
}

.millaray-premium-dashboard .sidebar-brand {
    align-items: center;
    display: flex;
    gap: 12px;
    justify-items: start;
    padding: 0;
}

.millaray-premium-dashboard .sidebar-brand .logo-nav {
    background: rgba(255, 249, 240, .1);
    border: 1px solid rgba(255, 249, 240, .18);
    border-radius: 8px;
    height: 54px;
    margin: 0;
    object-fit: contain;
    padding: 6px;
    width: 54px;
}

.millaray-premium-dashboard .sidebar-brand div {
    display: grid;
}

.millaray-premium-dashboard .sidebar-brand span {
    color: rgba(255, 249, 240, .66);
    font-size: .76rem;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.millaray-premium-dashboard .sidebar-brand strong {
    color: #FFF9F0;
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 1.35rem;
    line-height: 1;
}

.millaray-premium-dashboard .nav-toggle {
    display: none;
}

.millaray-premium-dashboard .nav-links {
    align-items: stretch;
    display: grid;
    gap: 8px;
    width: 100%;
}

.millaray-premium-dashboard .nav-links a {
    align-items: center;
    background: rgba(255, 249, 240, .08);
    border: 1px solid rgba(255, 249, 240, .09);
    border-radius: 8px;
    color: rgba(255, 249, 240, .82);
    display: flex;
    font-size: .9rem;
    font-weight: 800;
    justify-content: flex-start;
    min-height: 42px;
    padding: 0 12px;
    text-align: left;
    transition: background .22s ease, color .22s ease, transform .22s ease;
}

.millaray-premium-dashboard .nav-links a::before {
    background: var(--millaray-gold);
    border-radius: 999px;
    content: "";
    display: block;
    height: 7px;
    margin-right: 10px;
    opacity: .8;
    width: 7px;
}

.millaray-premium-dashboard .nav-links a:hover,
.millaray-premium-dashboard .nav-links a.is-active {
    background: rgba(227, 194, 139, .22);
    color: #fff;
    transform: translateX(3px);
}

.millaray-premium-dashboard .sidebar-art {
    background: linear-gradient(180deg, rgba(255, 249, 240, .12), rgba(255, 249, 240, .06));
    border: 1px solid rgba(255, 249, 240, .1);
    border-radius: 8px;
    display: block;
    height: 150px;
    margin-top: auto;
    overflow: hidden;
    position: relative;
}

.millaray-premium-dashboard .sidebar-mountains {
    background:
        linear-gradient(135deg, transparent 48%, rgba(127, 147, 99, .72) 49% 74%, transparent 75%),
        linear-gradient(45deg, transparent 42%, rgba(227, 194, 139, .55) 43% 72%, transparent 73%);
    bottom: 28px;
    height: 80px;
    left: 18px;
    position: absolute;
    right: 18px;
}

.millaray-premium-dashboard .sidebar-cabin .roof {
    border-bottom: 28px solid #E3C28B;
    border-left: 42px solid transparent;
    border-right: 42px solid transparent;
    bottom: 46px;
    height: 0;
    left: 58px;
    position: absolute;
    width: 0;
}

.millaray-premium-dashboard .sidebar-cabin .house {
    background: #C98C54;
    border-radius: 4px 4px 6px 6px;
    bottom: 18px;
    height: 42px;
    left: 72px;
    position: absolute;
    width: 58px;
}

.millaray-premium-dashboard .sidebar-cabin .door {
    background: #3A2417;
    border-radius: 3px 3px 0 0;
    bottom: 18px;
    height: 25px;
    left: 94px;
    position: absolute;
    width: 14px;
}

.millaray-premium-dashboard .sidebar-cabin .window {
    background: #FFF9F0;
    border-radius: 2px;
    bottom: 38px;
    height: 10px;
    left: 114px;
    position: absolute;
    width: 10px;
}

.millaray-premium-dashboard .leaf {
    background: #E3C28B;
    border-radius: 70% 20% 70% 20%;
    display: block;
    height: 18px;
    opacity: .88;
    position: absolute;
    transform: rotate(-28deg);
    width: 11px;
}

.millaray-premium-dashboard .leaf-one { left: 26px; top: 24px; }
.millaray-premium-dashboard .leaf-two { right: 30px; top: 42px; transform: rotate(34deg); }
.millaray-premium-dashboard .leaf-three { left: 50%; top: 18px; transform: rotate(12deg); }

.millaray-premium-dashboard .sidebar-mini-panel {
    background: rgba(255, 249, 240, .11);
    border: 1px solid rgba(255, 249, 240, .12);
    border-radius: 8px;
    display: grid;
    gap: 6px;
    padding: 14px;
}

.millaray-premium-dashboard .sidebar-mini-panel span,
.millaray-premium-dashboard .sidebar-mini-panel small {
    color: rgba(255, 249, 240, .72);
    font-size: .76rem;
    font-weight: 800;
}

.millaray-premium-dashboard .sidebar-mini-panel strong {
    color: #FFF9F0;
    font-size: 2rem;
    line-height: 1;
}

.millaray-premium-dashboard .sidebar-mini-panel b {
    color: #E3C28B;
}

.millaray-premium-dashboard .sidebar-user {
    align-items: center;
    background: rgba(255, 249, 240, .08);
    border: 1px solid rgba(255, 249, 240, .1);
    border-radius: 8px;
    display: flex;
    gap: 10px;
    padding: 10px;
}

.millaray-premium-dashboard .user-avatar {
    align-items: center;
    background: #E3C28B;
    border-radius: 8px;
    color: #3A2417;
    display: inline-flex;
    font-weight: 900;
    height: 38px;
    justify-content: center;
    width: 38px;
}

.millaray-premium-dashboard .sidebar-user strong {
    color: #FFF9F0;
    display: block;
    font-size: .9rem;
}

.millaray-premium-dashboard .sidebar-user small {
    color: rgba(255, 249, 240, .62);
}

.millaray-premium-dashboard .dashboard-shell {
    margin-left: 270px;
    max-width: none;
    padding: 28px clamp(18px, 3vw, 42px) 42px;
}

.millaray-premium-dashboard .dashboard-topbar {
    align-items: center;
    background: transparent;
    display: flex;
    justify-content: space-between;
    margin: 0 0 22px;
}

.millaray-premium-dashboard .dashboard-title .eyebrow {
    color: var(--millaray-terracotta);
    display: block;
    font-size: .74rem;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.millaray-premium-dashboard .dashboard-title h2 {
    font-size: clamp(1.7rem, 2.6vw, 2.6rem);
    margin: 4px 0;
}

.millaray-premium-dashboard .dashboard-title h2::after {
    content: "";
}

.millaray-premium-dashboard .dashboard-title p {
    display: block;
    margin: 0;
}

.millaray-premium-dashboard .dashboard-actions {
    align-items: center;
    display: flex;
    gap: 10px;
}

.millaray-premium-dashboard .dashboard-search {
    background: rgba(255, 249, 240, .82);
    border: 1px solid rgba(92, 61, 39, .12);
    border-radius: 8px;
    display: flex;
    min-height: 46px;
    min-width: 260px;
    padding: 0 12px;
}

.millaray-premium-dashboard .dashboard-search span {
    color: var(--millaray-coffee);
    font-size: .76rem;
    font-weight: 900;
    margin-right: 8px;
}

.millaray-premium-dashboard .dashboard-search input {
    background: transparent;
    border: 0;
    color: var(--millaray-dark);
    font: inherit;
    outline: 0;
    width: 100%;
}

.millaray-premium-dashboard .dashboard-date {
    background: #FFF9F0;
    border: 1px solid rgba(92, 61, 39, .1);
    border-radius: 8px;
    color: var(--millaray-coffee);
    display: block;
    font-size: .84rem;
    font-weight: 900;
    padding: 13px 14px;
}

.millaray-premium-dashboard .btn-primary,
.millaray-premium-dashboard .dashboard-new-booking {
    background: linear-gradient(135deg, #C98C54, #E3C28B);
    border: 0;
    border-radius: 8px;
    box-shadow: 0 14px 30px rgba(201, 140, 84, .24);
    color: #3A2417;
    cursor: pointer;
    font: inherit;
    font-weight: 900;
    min-height: 46px;
    padding: 0 18px;
    text-decoration: none;
    transition: transform .22s ease, box-shadow .22s ease, filter .22s ease;
}

.millaray-premium-dashboard .btn-primary:hover,
.millaray-premium-dashboard .dashboard-new-booking:hover {
    box-shadow: 0 18px 34px rgba(201, 140, 84, .34);
    filter: saturate(1.05);
    transform: translateY(-2px);
}

.millaray-premium-dashboard .dashboard-canvas {
    align-items: start;
    background: rgba(255, 249, 240, .36);
    border: 1px solid rgba(255, 249, 240, .66);
    border-radius: 8px;
    box-shadow: 0 24px 70px rgba(58, 36, 23, .08);
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    padding: 18px;
}

.millaray-premium-dashboard .millaray-hero-card {
    background:
        linear-gradient(135deg, rgba(58, 36, 23, .96), rgba(140, 90, 52, .88)),
        radial-gradient(circle at 72% 12%, rgba(227, 194, 139, .45), transparent 33%);
    border: 0;
    border-radius: 8px;
    box-shadow: 0 22px 54px rgba(58, 36, 23, .2);
    display: grid;
    gap: 18px;
    grid-column: span 12;
    grid-template-columns: minmax(0, 1.1fr) minmax(360px, .9fr);
    min-height: 390px;
    overflow: hidden;
    padding: clamp(24px, 4vw, 44px);
    position: relative;
}

.millaray-premium-dashboard .millaray-hero-card::after {
    background:
        radial-gradient(circle, rgba(255, 249, 240, .26) 0 2px, transparent 3px),
        radial-gradient(circle, rgba(227, 194, 139, .18) 0 3px, transparent 4px);
    background-size: 42px 42px, 70px 70px;
    content: "";
    inset: 0;
    opacity: .36;
    pointer-events: none;
    position: absolute;
}

.millaray-premium-dashboard .hero-card-copy {
    align-content: center;
    display: grid;
    position: relative;
    z-index: 1;
}

.millaray-premium-dashboard .soft-pill {
    align-items: center;
    background: rgba(255, 249, 240, .12);
    border: 1px solid rgba(255, 249, 240, .16);
    border-radius: 999px;
    color: #E3C28B;
    display: inline-flex;
    font-size: .78rem;
    font-weight: 900;
    justify-self: start;
    letter-spacing: .04em;
    margin-bottom: 16px;
    padding: 8px 12px;
}

.millaray-premium-dashboard .hero-card-copy h1 {
    color: #FFF9F0;
    font-size: clamp(2.8rem, 5vw, 5.4rem);
    line-height: .94;
    margin: 0 0 12px;
    max-width: 720px;
}

.millaray-premium-dashboard .hero-card-copy > p {
    color: rgba(255, 249, 240, .78);
    font-size: 1.15rem;
    margin: 0 0 22px;
}

.millaray-premium-dashboard .hero-metrics-grid {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.millaray-premium-dashboard .hero-metrics-grid div {
    background: rgba(255, 249, 240, .12);
    border: 1px solid rgba(255, 249, 240, .14);
    border-radius: 8px;
    min-height: 92px;
    padding: 14px;
}

.millaray-premium-dashboard .hero-metrics-grid span {
    color: rgba(255, 249, 240, .7);
    display: block;
    font-size: .76rem;
    font-weight: 900;
    margin-bottom: 10px;
}

.millaray-premium-dashboard .hero-metrics-grid strong {
    color: #FFF9F0;
    font-size: clamp(1.55rem, 2.5vw, 2.5rem);
    line-height: 1;
}

.millaray-premium-dashboard .hero-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 22px;
}

.millaray-premium-dashboard .hero-actions span {
    color: rgba(255, 249, 240, .72);
    font-weight: 800;
}

.millaray-premium-dashboard .hero-actions span strong {
    color: #E3C28B;
}

.millaray-premium-dashboard .hero-illustration {
    background: linear-gradient(180deg, rgba(255, 249, 240, .24), rgba(255, 249, 240, .08));
    border: 1px solid rgba(255, 249, 240, .14);
    border-radius: 8px;
    display: block;
    min-height: 310px;
    overflow: hidden;
    position: relative;
    z-index: 1;
}

.millaray-premium-dashboard .sun-glow {
    background: radial-gradient(circle, #E3C28B 0 24%, rgba(227, 194, 139, .2) 25% 60%, transparent 62%);
    border-radius: 999px;
    height: 150px;
    position: absolute;
    right: 28px;
    top: 22px;
    width: 150px;
}

.millaray-premium-dashboard .mountain {
    bottom: 62px;
    clip-path: polygon(50% 0, 100% 100%, 0 100%);
    position: absolute;
}

.millaray-premium-dashboard .mountain-back {
    background: rgba(127, 147, 99, .62);
    height: 170px;
    left: 20px;
    width: 260px;
}

.millaray-premium-dashboard .mountain-front {
    background: rgba(227, 194, 139, .56);
    height: 135px;
    right: 40px;
    width: 230px;
}

.millaray-premium-dashboard .mini-cabin {
    bottom: 58px;
    height: 120px;
    left: 50%;
    position: absolute;
    transform: translateX(-50%);
    width: 210px;
}

.millaray-premium-dashboard .mini-roof {
    border-bottom: 58px solid #E3C28B;
    border-left: 105px solid transparent;
    border-right: 105px solid transparent;
    display: block;
    height: 0;
    width: 0;
}

.millaray-premium-dashboard .mini-house {
    background:
        linear-gradient(90deg, transparent 0 42%, #3A2417 43% 57%, transparent 58%),
        linear-gradient(#C98C54, #B87243);
    border-radius: 0 0 8px 8px;
    display: block;
    height: 80px;
    margin: 0 auto;
    width: 150px;
}

.millaray-premium-dashboard .hero-tree {
    background: #7F9363;
    bottom: 60px;
    clip-path: polygon(50% 0, 86% 45%, 68% 45%, 96% 84%, 58% 84%, 58% 100%, 42% 100%, 42% 84%, 4% 84%, 32% 45%, 14% 45%);
    height: 146px;
    position: absolute;
    width: 82px;
}

.millaray-premium-dashboard .tree-left { left: 34px; }
.millaray-premium-dashboard .tree-right { right: 28px; transform: scale(.85); }

.millaray-premium-dashboard .hero-suitcase {
    background: #8C5A34;
    border: 4px solid #3A2417;
    border-radius: 8px;
    bottom: 44px;
    height: 46px;
    left: 70px;
    position: absolute;
    width: 58px;
}

.millaray-premium-dashboard .hero-suitcase::before {
    border: 4px solid #3A2417;
    border-bottom: 0;
    border-radius: 10px 10px 0 0;
    content: "";
    height: 15px;
    left: 14px;
    position: absolute;
    top: -18px;
    width: 22px;
}

.millaray-premium-dashboard .hero-cup {
    background: #FFF9F0;
    border-radius: 0 0 14px 14px;
    bottom: 44px;
    height: 36px;
    position: absolute;
    right: 90px;
    width: 44px;
}

.millaray-premium-dashboard .hero-cup::after {
    border: 5px solid #FFF9F0;
    border-left: 0;
    border-radius: 0 12px 12px 0;
    content: "";
    height: 17px;
    position: absolute;
    right: -15px;
    top: 8px;
    width: 13px;
}

.millaray-premium-dashboard .hero-mini-chart {
    align-items: end;
    background: rgba(58, 36, 23, .26);
    border: 1px solid rgba(255, 249, 240, .12);
    border-radius: 8px;
    bottom: 18px;
    display: flex;
    gap: 6px;
    height: 86px;
    padding: 10px;
    position: absolute;
    right: 18px;
    width: 112px;
}

.millaray-premium-dashboard .hero-mini-chart span {
    animation: millarayBarIn .9s ease both;
    background: linear-gradient(180deg, #E3C28B, #C98C54);
    border-radius: 999px 999px 4px 4px;
    flex: 1;
}

.millaray-premium-dashboard .admin-dashboard {
    display: grid;
    gap: 14px;
    grid-column: span 12;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    order: unset !important;
}

.millaray-premium-dashboard .admin-dashboard[hidden],
.millaray-premium-dashboard .intelligent-analysis-panel[hidden],
.millaray-premium-dashboard .dashboard-quick-panel[hidden] {
    display: none;
}

.millaray-premium-dashboard .metric-card,
.millaray-premium-dashboard .auth-panel,
.millaray-premium-dashboard .cabins-panel,
.millaray-premium-dashboard .booking-panel,
.millaray-premium-dashboard .reservations-panel,
.millaray-premium-dashboard .activity-panel,
.millaray-premium-dashboard .intelligent-analysis-panel,
.millaray-premium-dashboard .analysis-card,
.millaray-premium-dashboard .prediction-card,
.millaray-premium-dashboard .ai-insight-card,
.millaray-premium-dashboard .analysis-summary article {
    background: rgba(255, 249, 240, .9);
    border: 1px solid rgba(92, 61, 39, .1);
    border-radius: 8px;
    box-shadow: 0 16px 34px rgba(58, 36, 23, .08);
}

.millaray-premium-dashboard .metric-card {
    min-height: 145px;
    padding: 20px;
    position: relative;
    transition: transform .22s ease, box-shadow .22s ease;
}

.millaray-premium-dashboard .metric-card:hover,
.millaray-premium-dashboard .analysis-card:hover,
.millaray-premium-dashboard .cabin-card:hover {
    box-shadow: 0 22px 42px rgba(58, 36, 23, .13);
    transform: translateY(-3px);
}

.millaray-premium-dashboard .metric-card i {
    background: rgba(201, 140, 84, .16);
    border-radius: 8px;
    display: block;
    height: 38px;
    margin-bottom: 18px;
    position: relative;
    width: 38px;
}

.millaray-premium-dashboard .metric-card i::before {
    background: var(--millaray-terracotta);
    border-radius: 5px;
    content: "";
    height: 16px;
    left: 11px;
    position: absolute;
    top: 11px;
    width: 16px;
}

.millaray-premium-dashboard .metric-card span,
.millaray-premium-dashboard .metric-card small {
    color: rgba(58, 36, 23, .62);
    display: block;
    font-size: .78rem;
    font-weight: 900;
}

.millaray-premium-dashboard .metric-card strong {
    color: var(--millaray-dark);
    display: block;
    font-family: 'Inter', Arial, sans-serif;
    font-size: clamp(1.55rem, 2.3vw, 2.25rem);
    font-weight: 900;
    line-height: 1.02;
    margin: 8px 0;
}

.millaray-premium-dashboard .compact-metric {
    display: none;
}

.millaray-premium-dashboard .intelligent-analysis-panel {
    display: grid;
    gap: 18px;
    grid-column: span 12;
    order: unset !important;
    padding: 0;
}

.millaray-premium-dashboard .analysis-header {
    align-items: center;
    border: 0;
    display: flex;
    justify-content: space-between;
    margin: 0;
    padding: 22px 24px 0;
}

.millaray-premium-dashboard .panel-kicker {
    color: var(--millaray-terracotta);
    font-size: .74rem;
    font-weight: 900;
    letter-spacing: .1em;
    text-transform: uppercase;
}

.millaray-premium-dashboard .panel-header h3,
.millaray-premium-dashboard .analysis-header h3 {
    font-size: clamp(1.25rem, 2vw, 1.85rem);
    margin: 3px 0 4px;
}

.millaray-premium-dashboard .panel-header {
    border-bottom: 1px solid rgba(92, 61, 39, .08);
    margin-bottom: 16px;
    padding-bottom: 12px;
}

.millaray-premium-dashboard .charts-grid,
.millaray-premium-dashboard .calendar-ai-layout,
.millaray-premium-dashboard .analysis-grid,
.millaray-premium-dashboard .market-dashboard-strip {
    display: grid;
    gap: 14px;
    margin: 0;
    padding: 0 18px;
}

.millaray-premium-dashboard .charts-grid {
    grid-template-columns: minmax(0, 1.45fr) minmax(300px, .85fr);
}

.millaray-premium-dashboard .calendar-ai-layout {
    grid-template-columns: minmax(360px, .95fr) minmax(0, 1.05fr);
}

.millaray-premium-dashboard .analysis-grid,
.millaray-premium-dashboard .market-dashboard-strip {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.millaray-premium-dashboard .analysis-summary {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    padding: 0 18px;
}

.millaray-premium-dashboard .analysis-card,
.millaray-premium-dashboard .ai-insight-card,
.millaray-premium-dashboard .prediction-card,
.millaray-premium-dashboard .analysis-summary article {
    padding: 18px;
}

.millaray-premium-dashboard .analysis-card-title {
    align-items: start;
    display: flex;
    justify-content: space-between;
    margin-bottom: 16px;
}

.millaray-premium-dashboard .analysis-card-title span,
.millaray-premium-dashboard .analysis-summary span,
.millaray-premium-dashboard .prediction-card span,
.millaray-premium-dashboard .ai-insight-card > span {
    color: var(--millaray-coffee);
    font-size: .78rem;
    font-weight: 900;
}

.millaray-premium-dashboard .analysis-card-title strong,
.millaray-premium-dashboard .analysis-summary strong,
.millaray-premium-dashboard .prediction-card strong {
    color: var(--millaray-dark);
    font-family: 'Inter', Arial, sans-serif;
    font-size: 1.1rem;
    font-weight: 900;
}

.millaray-premium-dashboard .bar-chart {
    align-items: end;
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    min-height: 260px;
}

.millaray-premium-dashboard .bar-item {
    align-items: center;
    display: grid;
    gap: 8px;
    justify-items: center;
}

.millaray-premium-dashboard .bar-track {
    align-items: end;
    background: #F0E3D2;
    border-radius: 999px;
    display: flex;
    height: 190px;
    overflow: hidden;
    padding: 5px;
    width: 100%;
}

.millaray-premium-dashboard .bar-track span {
    animation: millarayBarIn .9s ease both;
    background: linear-gradient(180deg, #E3C28B, #C98C54);
    border-radius: 999px;
    box-shadow: inset 0 -8px 14px rgba(58, 36, 23, .1);
    display: block;
    width: 100%;
}

.millaray-premium-dashboard .bar-item.is-top .bar-track span {
    background: linear-gradient(180deg, #7F9363, #C98C54);
}

.millaray-premium-dashboard .bar-item strong,
.millaray-premium-dashboard .bar-item small {
    color: var(--millaray-dark);
    font-size: .78rem;
    font-weight: 900;
}

.millaray-premium-dashboard .line-chart {
    align-items: end;
    background:
        linear-gradient(rgba(58, 36, 23, .06) 1px, transparent 1px) 0 0 / 100% 25%,
        #FFF6E9;
    border-radius: 8px;
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    min-height: 260px;
    padding: 14px;
}

.millaray-premium-dashboard .line-point {
    animation: millarayBarIn .9s ease both;
    background: linear-gradient(180deg, #7F9363, #E3C28B);
    border-radius: 999px 999px 8px 8px;
    display: grid;
    min-height: 42px;
    place-items: center;
    text-align: center;
}

.millaray-premium-dashboard .line-point strong,
.millaray-premium-dashboard .line-point span {
    color: #3A2417;
    font-size: .66rem;
    font-weight: 900;
}

.millaray-premium-dashboard .heat-calendar {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(7, minmax(0, 1fr));
}

.millaray-premium-dashboard .heat-day {
    border-radius: 8px;
    display: grid;
    min-height: 58px;
    padding: 8px;
    place-items: center;
    transition: transform .2s ease, box-shadow .2s ease;
}

.millaray-premium-dashboard .heat-day:hover {
    box-shadow: 0 12px 22px rgba(58, 36, 23, .12);
    transform: translateY(-2px);
}

.millaray-premium-dashboard .heat-day.low { background: #F0E3D2; color: #3A2417; }
.millaray-premium-dashboard .heat-day.medium { background: #E3C28B; color: #3A2417; }
.millaray-premium-dashboard .heat-day.high { background: #C98C54; color: #FFF9F0; }

.millaray-premium-dashboard .ai-insights {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: 14px;
}

.millaray-premium-dashboard .ai-insights p,
.millaray-premium-dashboard .quick-analysis-list p,
.millaray-premium-dashboard .ranking-row,
.millaray-premium-dashboard .income-estimates div,
.millaray-premium-dashboard .future-estimates p,
.millaray-premium-dashboard .future-kpis article {
    background: #FFF4E4;
    border: 1px solid rgba(92, 61, 39, .09);
    border-radius: 8px;
    color: var(--millaray-dark);
    font-size: .86rem;
    font-weight: 800;
    margin: 0;
    padding: 12px;
}

.millaray-premium-dashboard .prediction-card {
    align-items: center;
    display: grid;
    grid-template-columns: .45fr 1.2fr 90px;
    margin: 0 18px;
}

.millaray-premium-dashboard .market-table-card {
    margin: 0 18px 18px;
    overflow: hidden;
}

.millaray-premium-dashboard .market-table {
    overflow-x: auto;
}

.millaray-premium-dashboard .market-table table {
    border-collapse: collapse;
    min-width: 680px;
    width: 100%;
}

.millaray-premium-dashboard .market-table th,
.millaray-premium-dashboard .market-table td {
    border-bottom: 1px solid #EAD8C0;
    color: var(--millaray-dark);
    font-size: .82rem;
    padding: 10px;
    text-align: left;
}

.millaray-premium-dashboard .reservation-grid {
    display: grid;
    gap: 18px;
    grid-column: span 12;
    grid-template-columns: minmax(0, 1.2fr) minmax(320px, .8fr);
    order: unset !important;
}

.millaray-premium-dashboard .cabins-panel,
.millaray-premium-dashboard .activity-panel,
.millaray-premium-dashboard .dashboard-quick-panel,
.millaray-premium-dashboard .reservations-panel,
.millaray-premium-dashboard .auth-panel {
    grid-column: span 12;
    padding: 22px;
}

.millaray-premium-dashboard .reservation-grid .cabins-panel,
.millaray-premium-dashboard .reservation-grid .activity-panel {
    grid-column: auto;
}

.millaray-premium-dashboard .cabins-list {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.millaray-premium-dashboard .cabin-card {
    background: linear-gradient(180deg, #FFF9F0, #FFF2DF);
    border: 1px solid rgba(92, 61, 39, .1);
    border-radius: 8px;
    display: grid;
    gap: 14px;
    grid-template-columns: 110px minmax(0, 1fr);
    padding: 14px;
    transition: transform .22s ease, box-shadow .22s ease;
}

.millaray-premium-dashboard .cabin-card.selected {
    border-color: rgba(201, 140, 84, .72);
    box-shadow: 0 0 0 3px rgba(201, 140, 84, .18);
}

.millaray-premium-dashboard .cabin-thumb {
    background: linear-gradient(160deg, #F0E3D2, #E3C28B);
    border-radius: 8px;
    min-height: 118px;
    position: relative;
}

.millaray-premium-dashboard .cabin-icon-roof {
    border-bottom: 35px solid #8C5A34;
    border-left: 48px solid transparent;
    border-right: 48px solid transparent;
    display: block;
    left: 7px;
    position: absolute;
    top: 28px;
}

.millaray-premium-dashboard .cabin-icon-body {
    background: #C98C54;
    border-radius: 0 0 6px 6px;
    display: block;
    height: 44px;
    left: 23px;
    position: absolute;
    top: 63px;
    width: 64px;
}

.millaray-premium-dashboard .cabin-icon-door {
    background: #3A2417;
    display: block;
    height: 26px;
    left: 49px;
    position: absolute;
    top: 81px;
    width: 14px;
}

.millaray-premium-dashboard .cabin-card h4 {
    color: var(--millaray-dark);
    font-family: 'Inter', Arial, sans-serif;
    font-size: 1rem;
    font-weight: 900;
}

.millaray-premium-dashboard .cabin-card p,
.millaray-premium-dashboard .cabin-card li {
    color: rgba(58, 36, 23, .62);
    font-size: .82rem;
}

.millaray-premium-dashboard .cabin-card ul {
    display: none;
}

.millaray-premium-dashboard .cabin-meta span,
.millaray-premium-dashboard .reservation-meta span {
    background: #F0E3D2;
    border-radius: 999px;
    color: var(--millaray-coffee);
    font-size: .74rem;
    padding: 5px 8px;
}

.millaray-premium-dashboard .cabin-status {
    border-radius: 999px;
    font-size: .68rem;
    font-weight: 900;
    padding: 5px 8px;
}

.millaray-premium-dashboard .cabin-status.is-hot { background: rgba(201, 140, 84, .18); color: #9D4D2D; }
.millaray-premium-dashboard .cabin-status.is-soft { background: rgba(127, 147, 99, .18); color: #55653D; }
.millaray-premium-dashboard .cabin-status.is-pending { background: rgba(58, 36, 23, .1); color: #6B584C; }

.millaray-premium-dashboard .cabin-occupancy {
    background: #F0E3D2;
    border-radius: 999px;
    height: 8px;
    overflow: hidden;
}

.millaray-premium-dashboard .cabin-occupancy span {
    background: linear-gradient(90deg, #7F9363, #E3C28B, #C98C54);
    border-radius: inherit;
    display: block;
    height: 100%;
}

.millaray-premium-dashboard .activity-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.millaray-premium-dashboard .activity-grid article {
    background: #FFF4E4;
    border: 1px solid rgba(92, 61, 39, .08);
    border-radius: 8px;
    min-height: 112px;
    padding: 14px;
}

.millaray-premium-dashboard .activity-grid strong {
    color: var(--millaray-dark);
    display: block;
    margin: 8px 0 4px;
}

.millaray-premium-dashboard .avatar-stack {
    display: flex;
}

.millaray-premium-dashboard .avatar-stack span {
    align-items: center;
    background: #E3C28B;
    border: 2px solid #FFF9F0;
    border-radius: 999px;
    color: #3A2417;
    display: inline-flex;
    font-size: .68rem;
    font-weight: 900;
    height: 34px;
    justify-content: center;
    margin-right: -8px;
    width: 34px;
}

.millaray-premium-dashboard .activity-icon {
    background: #C98C54;
    border-radius: 8px;
    display: block;
    height: 34px;
    width: 34px;
}

.millaray-premium-dashboard .activity-icon.suitcase { background: #8C5A34; }
.millaray-premium-dashboard .activity-icon.coffee { background: #7F9363; }

.millaray-premium-dashboard .dashboard-quick-panel {
    order: unset !important;
}

.millaray-premium-dashboard .quick-analysis-list {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.millaray-premium-dashboard .reservations-list {
    display: grid;
    gap: 10px;
}

.millaray-premium-dashboard .reservation-card {
    background: #FFF6E9;
    border: 1px solid rgba(92, 61, 39, .08);
    border-radius: 8px;
    display: grid;
    gap: 8px;
    padding: 14px;
}

.millaray-premium-dashboard .auth-panel {
    max-width: 560px;
}

.booking-modal-shell[hidden] {
    display: none;
}

.booking-modal-shell {
    inset: 0;
    position: fixed;
    z-index: 2000;
}

.booking-modal-backdrop {
    background: rgba(28, 16, 9, .58);
    backdrop-filter: blur(8px);
    inset: 0;
    position: absolute;
}

.millaray-premium-dashboard .booking-modal-card {
    animation: millarayModalIn .24s ease both;
    background: #FFF9F0;
    border: 1px solid rgba(255, 249, 240, .7);
    border-radius: 8px;
    box-shadow: 0 26px 80px rgba(28, 16, 9, .28);
    box-sizing: border-box;
    max-height: calc(100vh - 36px);
    overflow-y: auto;
    padding: 24px;
    position: absolute;
    right: 18px;
    top: 18px;
    width: min(560px, calc(100vw - 36px));
}

.millaray-premium-dashboard .modal-close {
    background: #F0E3D2;
    border: 0;
    border-radius: 8px;
    color: var(--millaray-dark);
    cursor: pointer;
    font: inherit;
    font-size: .78rem;
    font-weight: 900;
    min-height: 36px;
    padding: 0 12px;
    position: absolute;
    right: 18px;
    top: 18px;
}

.millaray-premium-dashboard .stacked-form,
.millaray-premium-dashboard .reservation-form {
    display: grid;
    gap: 12px;
}

.millaray-premium-dashboard .form-row {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.millaray-premium-dashboard label {
    color: var(--millaray-dark);
    font-size: .82rem;
    font-weight: 900;
}

.millaray-premium-dashboard input,
.millaray-premium-dashboard textarea {
    background: #FFF6E9;
    border: 1px solid rgba(92, 61, 39, .14);
    border-radius: 8px;
    box-sizing: border-box;
    color: var(--millaray-dark);
    font: inherit;
    padding: 12px;
    width: 100%;
}

.millaray-premium-dashboard input:disabled,
.millaray-premium-dashboard textarea:disabled {
    background: #EEE4D6;
    color: rgba(58, 36, 23, .48);
}

.millaray-premium-dashboard .btn-secondary,
.millaray-premium-dashboard .reservation-card button,
.millaray-premium-dashboard .cabin-card button {
    background: #F0E3D2;
    border: 0;
    border-radius: 8px;
    color: var(--millaray-dark);
    cursor: pointer;
    font: inherit;
    font-weight: 900;
    min-height: 40px;
    padding: 0 14px;
}

.millaray-premium-dashboard .form-message {
    border-radius: 8px;
    color: var(--millaray-dark);
    font-weight: 900;
    padding: 10px 12px;
}

.millaray-premium-dashboard .form-message.ok {
    background: rgba(127, 147, 99, .18);
}

.millaray-premium-dashboard .form-message.error {
    background: rgba(201, 140, 84, .2);
}

.millaray-premium-dashboard footer {
    display: none;
}

@keyframes millarayBarIn {
    from {
        transform: scaleY(.22);
        transform-origin: bottom;
    }
    to {
        transform: scaleY(1);
        transform-origin: bottom;
    }
}

@keyframes millarayModalIn {
    from {
        opacity: 0;
        transform: translateX(24px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@media (max-width: 1180px) {
    .millaray-premium-dashboard.reservas-admin-page nav {
        align-items: center;
        border-radius: 0;
        flex-direction: row;
        min-height: 68px;
        padding: 8px 12px;
        position: sticky;
        width: 100%;
    }

    .millaray-premium-dashboard .sidebar-art,
    .millaray-premium-dashboard .sidebar-mini-panel,
    .millaray-premium-dashboard .sidebar-user {
        display: none;
    }

    .millaray-premium-dashboard .nav-toggle {
        background: rgba(255, 249, 240, .14);
        border: 1px solid rgba(255, 249, 240, .18);
        border-radius: 8px;
        color: #FFF9F0;
        display: inline-flex;
        font-size: .82rem;
        font-weight: 900;
        margin-left: auto;
        min-height: 40px;
        padding: 0 12px;
    }

    .millaray-premium-dashboard .nav-links {
        background: #3A2417;
        border-radius: 8px;
        display: none;
        padding: 10px;
        position: absolute;
        right: 12px;
        top: 68px;
        width: min(320px, calc(100vw - 24px));
    }

    .millaray-premium-dashboard .nav-links.open {
        display: grid !important;
    }

    .millaray-premium-dashboard .dashboard-shell {
        margin-left: 0;
    }
}

@media (max-width: 980px) {
    .millaray-premium-dashboard .dashboard-topbar,
    .millaray-premium-dashboard .dashboard-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .millaray-premium-dashboard .dashboard-search {
        min-width: 0;
        width: 100%;
    }

    .millaray-premium-dashboard .millaray-hero-card,
    .millaray-premium-dashboard .charts-grid,
    .millaray-premium-dashboard .calendar-ai-layout,
    .millaray-premium-dashboard .analysis-grid,
    .millaray-premium-dashboard .market-dashboard-strip,
    .millaray-premium-dashboard .analysis-summary,
    .millaray-premium-dashboard .reservation-grid,
    .millaray-premium-dashboard .prediction-card {
        grid-template-columns: 1fr;
    }

    .millaray-premium-dashboard .hero-metrics-grid,
    .millaray-premium-dashboard .admin-dashboard,
    .millaray-premium-dashboard .cabins-list,
    .millaray-premium-dashboard .activity-grid,
    .millaray-premium-dashboard .quick-analysis-list,
    .millaray-premium-dashboard .ai-insights {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* Lightweight premium refinement */
.millaray-premium-dashboard.reservas-admin-page nav {
    width: 220px;
    padding: 26px 14px;
}

.millaray-premium-dashboard .dashboard-shell {
    margin-left: 220px;
}

.millaray-premium-dashboard .sidebar-brand .logo-nav {
    height: 46px;
    width: 46px;
}

.millaray-premium-dashboard .sidebar-brand strong {
    font-size: 1.55rem;
}

.millaray-premium-dashboard .nav-links {
    gap: 6px;
}

.millaray-premium-dashboard .nav-links a {
    font-size: .9rem;
    min-height: 44px;
    padding: 0 12px;
}

.millaray-premium-dashboard .nav-links a::before {
    display: none;
}

.millaray-premium-dashboard .nav-icon {
    align-items: center;
    color: #E3C28B;
    display: inline-flex;
    flex: 0 0 24px;
    font-size: 1rem;
    justify-content: center;
    margin-right: 10px;
}

.millaray-premium-dashboard .sidebar-mini-panel {
    min-height: 90px;
    padding: 12px;
}

.millaray-premium-dashboard .sidebar-mini-panel strong {
    font-size: 1.55rem;
}

.millaray-premium-dashboard .dashboard-topbar {
    min-height: 150px;
    padding: 30px 38px 12px;
}

.millaray-premium-dashboard .dashboard-title h2 {
    font-size: clamp(2.6rem, 4.2vw, 4.15rem);
    max-width: 500px;
}

.millaray-premium-dashboard .dashboard-canvas {
    gap: 22px;
    padding: 0 36px 42px;
}

.millaray-premium-dashboard .millaray-hero-card {
    grid-template-columns: minmax(0, .64fr) minmax(440px, .92fr);
    margin-top: -62px;
    min-height: 245px;
}

.millaray-premium-dashboard .hero-illustration {
    min-height: 250px;
}

.millaray-premium-dashboard .hero-metrics-grid div {
    min-height: 96px;
    padding: 14px;
}

.millaray-premium-dashboard .hero-metrics-grid div::before {
    height: 34px;
    width: 34px;
}

.millaray-premium-dashboard .hero-metrics-grid strong {
    font-size: 1.65rem;
}

.millaray-premium-dashboard .hero-metrics-grid span {
    font-size: .78rem;
}

.millaray-premium-dashboard .admin-dashboard {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    order: 2;
}

.millaray-premium-dashboard .metric-card {
    min-height: 92px;
    padding: 16px;
}

.millaray-premium-dashboard .metric-card i {
    height: 38px;
    width: 38px;
}

.millaray-premium-dashboard .metric-card strong {
    font-size: 1.55rem;
}

.millaray-premium-dashboard .metric-card span,
.millaray-premium-dashboard .metric-card small {
    font-size: .72rem;
}

.millaray-premium-dashboard .intelligent-analysis-panel {
    order: 3;
}

.millaray-premium-dashboard .charts-grid {
    grid-template-columns: minmax(0, 1.35fr) minmax(260px, .65fr);
}

.millaray-premium-dashboard .analysis-card,
.millaray-premium-dashboard .ai-insight-card,
.millaray-premium-dashboard .prediction-card,
.millaray-premium-dashboard .analysis-summary article {
    border-radius: 14px;
    padding: 18px;
}

.millaray-premium-dashboard .bar-chart {
    gap: 10px;
    min-height: 185px;
}

.millaray-premium-dashboard .chart-card-large .bar-chart {
    min-height: 190px;
}

.millaray-premium-dashboard .bar-track {
    height: 138px;
}

.millaray-premium-dashboard .bar-track span {
    width: 28%;
}

.millaray-premium-dashboard .bar-item strong,
.millaray-premium-dashboard .bar-item small {
    font-size: .68rem;
}

.millaray-premium-dashboard .line-chart {
    min-height: 190px;
}

.millaray-premium-dashboard .calendar-ai-layout {
    grid-template-columns: minmax(0, .95fr) minmax(300px, .75fr);
}

.millaray-premium-dashboard .heat-calendar {
    gap: 6px;
    grid-template-columns: repeat(7, minmax(24px, 1fr));
}

.millaray-premium-dashboard .heat-calendar::before {
    color: rgba(58, 36, 23, .58);
    content: "Lun   Mar   Mie   Jue   Vie   Sab   Dom";
    display: grid;
    font-size: .7rem;
    font-weight: 900;
    grid-column: 1 / -1;
    letter-spacing: .08em;
    white-space: pre;
    word-spacing: clamp(6px, 1.1vw, 16px);
}

.millaray-premium-dashboard .heat-day {
    border-radius: 8px;
    font-size: .72rem;
    min-height: 30px;
    padding: 4px;
}

.millaray-premium-dashboard .heat-day span {
    display: none;
}

.millaray-premium-dashboard .heat-day strong {
    font-size: .72rem;
}

.millaray-premium-dashboard .insights-business-header {
    border: 0;
    display: block;
    margin: 4px 0 -8px;
    padding: 0;
}

.millaray-premium-dashboard .insights-business-header h3 {
    display: none;
}

.millaray-premium-dashboard .analysis-summary {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.millaray-premium-dashboard .analysis-summary article {
    min-height: 82px;
}

.millaray-premium-dashboard .analysis-summary article p {
    display: none;
}

.millaray-premium-dashboard .analysis-summary strong {
    display: block;
    font-size: 1.25rem;
    margin-top: 8px;
}

.millaray-premium-dashboard .secondary-analytics {
    display: none;
}

.millaray-premium-dashboard .report-details {
    grid-column: span 12;
    margin: 0;
    order: 7;
    padding: 0;
}

.millaray-premium-dashboard .report-details summary {
    align-items: center;
    background: rgba(255, 249, 240, .78);
    border: 1px solid rgba(92, 61, 39, .08);
    border-radius: 14px;
    box-shadow: 0 12px 30px rgba(58, 36, 23, .07);
    color: #3A2417;
    cursor: pointer;
    display: flex;
    font-weight: 900;
    min-height: 54px;
    padding: 0 18px;
}

.millaray-premium-dashboard .report-details .market-table {
    margin-top: 12px;
    padding: 16px;
}

.millaray-premium-dashboard .reservation-grid {
    grid-template-columns: 1fr;
    order: 8;
}

.millaray-premium-dashboard .cabins-list {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.millaray-premium-dashboard .cabin-card {
    border-radius: 14px;
    gap: 12px;
    grid-template-columns: 72px minmax(0, 1fr);
    min-height: 150px;
    padding: 12px;
}

.millaray-premium-dashboard .cabin-thumb {
    min-height: 74px;
}

.millaray-premium-dashboard .cabin-icon-roof {
    border-bottom-width: 24px;
    border-left-width: 34px;
    border-right-width: 34px;
    left: 2px;
    top: 18px;
}

.millaray-premium-dashboard .cabin-icon-body {
    height: 31px;
    left: 14px;
    top: 42px;
    width: 46px;
}

.millaray-premium-dashboard .cabin-icon-door {
    height: 18px;
    left: 32px;
    top: 55px;
    width: 10px;
}

.millaray-premium-dashboard .cabin-card-title {
    align-items: start;
    display: grid;
    gap: 6px;
}

.millaray-premium-dashboard .cabin-card h4 {
    font-size: .95rem;
}

.millaray-premium-dashboard .cabin-card ul,
.millaray-premium-dashboard .cabin-card p,
.millaray-premium-dashboard .cabin-meta span:nth-child(1),
.millaray-premium-dashboard .cabin-meta span:nth-child(2) {
    display: none;
}

.millaray-premium-dashboard .cabin-meta span:last-child {
    display: inline-flex;
}

.millaray-premium-dashboard .cabin-status {
    justify-self: start;
}

.millaray-premium-dashboard .cabin-occupancy {
    margin: 10px 0;
}

.millaray-premium-dashboard .cabin-card button {
    min-height: 34px;
    padding: 0 10px;
}

.millaray-premium-dashboard .activity-grid {
    display: grid;
    gap: 0;
    grid-template-columns: 1fr;
}

.millaray-premium-dashboard .activity-grid article {
    align-items: center;
    background: transparent;
    border: 0;
    border-bottom: 1px solid rgba(92, 61, 39, .09);
    border-radius: 0;
    box-shadow: none;
    display: grid;
    grid-template-columns: 58px 110px minmax(0, 1fr);
    min-height: 52px;
    padding: 0;
}

.millaray-premium-dashboard .activity-grid time {
    color: #8C5A34;
    font-size: .78rem;
    font-weight: 900;
}

.millaray-premium-dashboard .activity-grid strong {
    margin: 0;
}

.millaray-premium-dashboard .activity-grid p {
    margin: 0;
}

@media (max-width: 1180px) {
    .millaray-premium-dashboard.reservas-admin-page nav {
        width: 100%;
    }

    .millaray-premium-dashboard .dashboard-shell {
        margin-left: 0;
    }
}

@media (max-width: 980px) {
    .millaray-premium-dashboard .charts-grid,
    .millaray-premium-dashboard .calendar-ai-layout {
        grid-template-columns: 1fr;
    }

    .millaray-premium-dashboard .analysis-summary,
    .millaray-premium-dashboard .cabins-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 620px) {
    .millaray-premium-dashboard .hero-metrics-grid,
    .millaray-premium-dashboard .admin-dashboard,
    .millaray-premium-dashboard .analysis-summary,
    .millaray-premium-dashboard .cabins-list {
        grid-template-columns: 1fr;
    }
}

/* Technical layout repair: stable grid, no overlapping dashboard surfaces */
.millaray-premium-dashboard,
.millaray-premium-dashboard * ,
.millaray-premium-dashboard *::before,
.millaray-premium-dashboard *::after {
    box-sizing: border-box;
}

body.millaray-premium-dashboard.reservas-admin-page {
    background: #F7F3EB;
    color: #2F2118;
    display: grid;
    grid-template-columns: 220px minmax(0, 1fr);
    min-height: 100vh;
    overflow-x: hidden;
    padding: 0;
}

.millaray-premium-dashboard::before,
.millaray-premium-dashboard nav::before,
.millaray-premium-dashboard nav::after,
.millaray-premium-dashboard .millaray-hero-card::after {
    display: none !important;
}

.millaray-premium-dashboard.reservas-admin-page nav {
    align-self: start;
    background: linear-gradient(180deg, #2A1A10, #3A2417);
    border: 0;
    border-radius: 0;
    box-shadow: none;
    display: flex;
    flex-direction: column;
    gap: 20px;
    grid-column: 1;
    height: 100vh;
    left: auto;
    min-height: 0;
    overflow-y: auto;
    padding: 24px 14px;
    position: sticky;
    top: 0;
    transform: none;
    width: 220px;
    z-index: 1;
}

.millaray-premium-dashboard .page-hero,
.millaray-premium-dashboard footer {
    display: none;
}

.millaray-premium-dashboard .dashboard-shell {
    grid-column: 2;
    margin: 0;
    max-width: none;
    overflow-x: hidden;
    padding: 0;
    width: 100%;
}

.millaray-premium-dashboard .dashboard-shell > .dashboard-topbar,
.millaray-premium-dashboard .dashboard-shell > .dashboard-canvas {
    margin-left: auto;
    margin-right: auto;
    max-width: 1280px;
    width: 100%;
}

.millaray-premium-dashboard .dashboard-topbar {
    align-items: start;
    background: transparent;
    border-radius: 0;
    display: grid;
    gap: 24px;
    grid-template-columns: minmax(0, 1fr) auto;
    min-height: 0;
    padding: 32px 32px 20px;
    position: static;
    transform: none;
}

.millaray-premium-dashboard .dashboard-title {
    min-width: 0;
}

.millaray-premium-dashboard .dashboard-title h2 {
    color: #2A1A10;
    display: -webkit-box;
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(2.4rem, 4vw, 3.5rem);
    line-height: 1;
    margin: 8px 0 8px;
    max-width: 760px;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.millaray-premium-dashboard .dashboard-title p {
    margin: 0;
}

.millaray-premium-dashboard .dashboard-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: end;
    min-width: 0;
    position: static;
    z-index: auto;
}

.millaray-premium-dashboard .preview-pill,
.millaray-premium-dashboard .dashboard-date,
.millaray-premium-dashboard .dashboard-new-booking {
    max-width: 100%;
    position: static;
    transform: none;
}

.millaray-premium-dashboard .dashboard-canvas {
    align-items: stretch;
    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    display: grid;
    gap: 24px;
    grid-template-columns: 1fr;
    padding: 0 32px 40px;
}

.millaray-premium-dashboard .millaray-hero-card,
.millaray-premium-dashboard .admin-dashboard,
.millaray-premium-dashboard .intelligent-analysis-panel,
.millaray-premium-dashboard .reservation-grid,
.millaray-premium-dashboard .dashboard-quick-panel,
.millaray-premium-dashboard .reservations-panel,
.millaray-premium-dashboard .auth-panel {
    grid-column: auto;
    margin: 0;
    order: initial;
    width: 100%;
}

.millaray-premium-dashboard .millaray-hero-card {
    align-items: center;
    background: linear-gradient(135deg, #FFF9F0, #F2E2CC);
    border: 1px solid rgba(58, 36, 23, .08);
    border-radius: 18px;
    box-shadow: 0 18px 42px rgba(58, 36, 23, .08);
    display: grid;
    gap: 24px;
    grid-template-columns: minmax(0, 1.25fr) minmax(280px, .75fr);
    max-height: 320px;
    min-height: 0;
    overflow: hidden;
    padding: 22px;
    position: static;
    transform: none;
}

.millaray-premium-dashboard .hero-card-copy {
    align-content: center;
    min-width: 0;
    padding: 0;
    position: static;
    z-index: auto;
}

.millaray-premium-dashboard .hero-metrics-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    width: 100%;
}

.millaray-premium-dashboard .hero-metrics-grid div {
    background: rgba(255, 255, 255, .62);
    border: 1px solid rgba(58, 36, 23, .08);
    border-radius: 14px;
    box-shadow: none;
    min-height: 0;
    min-width: 0;
    overflow: hidden;
    padding: 14px;
    position: static;
}

.millaray-premium-dashboard .hero-metrics-grid div::before {
    display: none;
}

.millaray-premium-dashboard .hero-metrics-grid span {
    color: #6B5140;
    display: block;
    font-size: .78rem;
    font-weight: 800;
    margin: 0 0 8px;
}

.millaray-premium-dashboard .hero-metrics-grid strong {
    color: #2A1A10;
    display: block;
    font-size: clamp(1.35rem, 2vw, 1.75rem);
    line-height: 1.1;
}

.millaray-premium-dashboard .hero-illustration {
    align-self: stretch;
    background: linear-gradient(135deg, #F2E2CC, #FFF9F0);
    border: 0;
    border-radius: 16px;
    box-shadow: none;
    min-height: 220px;
    overflow: hidden;
    position: relative;
    transform: none;
    z-index: auto;
}

.millaray-premium-dashboard .sun-glow,
.millaray-premium-dashboard .mountain,
.millaray-premium-dashboard .mini-cabin,
.millaray-premium-dashboard .hero-tree,
.millaray-premium-dashboard .hero-suitcase,
.millaray-premium-dashboard .hero-cup {
    position: absolute;
}

.millaray-premium-dashboard .sun-glow {
    height: 96px;
    right: 28px;
    top: 18px;
    width: 96px;
}

.millaray-premium-dashboard .mountain-back {
    bottom: 52px;
    height: 140px;
    left: 24px;
    width: 210px;
}

.millaray-premium-dashboard .mountain-front {
    bottom: 48px;
    height: 110px;
    right: 18px;
    width: 190px;
}

.millaray-premium-dashboard .mini-cabin {
    bottom: 30px;
    height: 110px;
    left: 50%;
    transform: translateX(-50%);
    width: 210px;
}

.millaray-premium-dashboard .mini-roof {
    border-bottom-width: 48px;
    border-left-width: 105px;
    border-right-width: 105px;
}

.millaray-premium-dashboard .mini-house {
    height: 64px;
    width: 150px;
}

.millaray-premium-dashboard .tree-left {
    bottom: 42px;
    height: 112px;
    left: 18px;
    width: 58px;
}

.millaray-premium-dashboard .tree-right {
    bottom: 42px;
    height: 108px;
    right: 18px;
    width: 56px;
}

.millaray-premium-dashboard .hero-suitcase {
    bottom: 24px;
    height: 54px;
    right: 18px;
    width: 72px;
}

.millaray-premium-dashboard .hero-cup {
    bottom: 24px;
    height: 38px;
    right: 110px;
    width: 46px;
}

.millaray-premium-dashboard .admin-dashboard {
    display: grid;
    gap: 20px;
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.millaray-premium-dashboard .metric-card,
.millaray-premium-dashboard .analysis-card,
.millaray-premium-dashboard .ai-insight-card,
.millaray-premium-dashboard .prediction-card,
.millaray-premium-dashboard .analysis-summary article,
.millaray-premium-dashboard .cabins-panel,
.millaray-premium-dashboard .activity-panel,
.millaray-premium-dashboard .reservations-panel,
.millaray-premium-dashboard .auth-panel,
.millaray-premium-dashboard .cabin-card,
.millaray-premium-dashboard .reservation-card {
    background: #FFF9F0;
    border: 1px solid rgba(58, 36, 23, .08);
    border-radius: 18px;
    box-shadow: 0 16px 36px rgba(58, 36, 23, .07);
    min-height: 0;
    min-width: 0;
    overflow: hidden;
    position: static;
    transform: none;
    width: 100%;
}

.millaray-premium-dashboard .metric-card {
    display: block;
    padding: 18px;
}

.millaray-premium-dashboard .metric-card i {
    display: none;
    float: none;
}

.millaray-premium-dashboard .metric-card strong {
    color: #2A1A10;
    display: block;
    font-size: clamp(1.35rem, 2vw, 1.8rem);
    line-height: 1.1;
    margin: 8px 0;
}

.millaray-premium-dashboard .intelligent-analysis-panel {
    background: transparent;
    border: 0;
    box-shadow: none;
    display: grid;
    gap: 24px;
    padding: 0;
}

.millaray-premium-dashboard .charts-grid,
.millaray-premium-dashboard .calendar-ai-layout {
    display: grid;
    gap: 24px;
    grid-template-columns: 2fr 1fr;
    margin: 0;
    padding: 0;
}

.millaray-premium-dashboard .analysis-grid,
.millaray-premium-dashboard .market-dashboard-strip {
    display: grid;
    gap: 20px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    padding: 0;
}

.millaray-premium-dashboard .analysis-summary {
    display: grid;
    gap: 20px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin: 0;
    padding: 0;
}

.millaray-premium-dashboard .analysis-card,
.millaray-premium-dashboard .ai-insight-card,
.millaray-premium-dashboard .prediction-card,
.millaray-premium-dashboard .analysis-summary article {
    padding: 20px;
}

.millaray-premium-dashboard .bar-chart {
    align-items: end;
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    min-height: 180px;
}

.millaray-premium-dashboard .bar-track {
    align-items: end;
    background: #F2E2CC;
    border-radius: 999px;
    display: flex;
    height: 130px;
    justify-content: center;
    overflow: hidden;
    padding: 0;
    width: 100%;
}

.millaray-premium-dashboard .bar-track span {
    background: linear-gradient(180deg, #E3C28B, #C98C54);
    border-radius: 999px 999px 0 0;
    display: block;
    margin-top: auto;
    width: 34%;
}

.millaray-premium-dashboard .line-chart {
    min-height: 180px;
}

.millaray-premium-dashboard .heat-calendar {
    display: grid;
    gap: 6px;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    margin: 0;
}

.millaray-premium-dashboard .heat-calendar::before {
    color: #6B5140;
    content: "Lun   Mar   Mie   Jue   Vie   Sab   Dom";
    display: block;
    font-size: .7rem;
    font-weight: 900;
    grid-column: 1 / -1;
    letter-spacing: .06em;
    overflow: hidden;
    white-space: pre;
    word-spacing: 12px;
}

.millaray-premium-dashboard .heat-day {
    align-items: center;
    border-radius: 10px;
    display: flex;
    justify-content: center;
    min-height: 30px;
    padding: 4px;
}

.millaray-premium-dashboard .heat-day span {
    display: none;
}

.millaray-premium-dashboard .heat-day strong {
    font-size: .75rem;
}

.millaray-premium-dashboard .ai-insights {
    display: grid;
    gap: 10px;
    grid-template-columns: 1fr;
}

.millaray-premium-dashboard .ai-insights p {
    align-items: center;
    background: #FFF4E6;
    border: 0;
    border-radius: 12px;
    display: flex;
    margin: 0;
    min-height: 0;
    padding: 12px;
}

.millaray-premium-dashboard .ai-insights p::before {
    display: none;
}

.millaray-premium-dashboard .report-details {
    padding: 0;
}

.millaray-premium-dashboard .report-details summary {
    background: #FFF9F0;
    border: 0;
    border-radius: 18px;
    box-shadow: none;
    cursor: pointer;
    display: block;
    font-weight: 900;
    min-height: 0;
    padding: 18px 20px;
}

.millaray-premium-dashboard .report-details .market-table {
    padding: 0 20px 20px;
}

.millaray-premium-dashboard .reservation-grid {
    display: grid;
    gap: 24px;
    grid-template-columns: 1fr;
}

.millaray-premium-dashboard .cabins-panel,
.millaray-premium-dashboard .activity-panel,
.millaray-premium-dashboard .reservations-panel,
.millaray-premium-dashboard .auth-panel {
    padding: 20px;
}

.millaray-premium-dashboard .cabins-list {
    display: grid;
    gap: 20px;
    grid-template-columns: repeat(4, minmax(220px, 1fr));
}

.millaray-premium-dashboard .cabin-card {
    display: grid;
    gap: 16px;
    grid-template-columns: 90px minmax(0, 1fr);
    padding: 14px;
}

.millaray-premium-dashboard .cabin-thumb {
    align-self: start;
    background: linear-gradient(135deg, #F2E2CC, #E3C28B);
    border-radius: 14px;
    min-height: 90px;
    overflow: hidden;
    position: relative;
}

.millaray-premium-dashboard .cabin-card-copy {
    min-width: 0;
}

.millaray-premium-dashboard .cabin-card-title {
    align-items: start;
    display: grid;
    gap: 6px;
}

.millaray-premium-dashboard .cabin-card h4,
.millaray-premium-dashboard .cabin-card p {
    margin: 0;
}

.millaray-premium-dashboard .cabin-card p,
.millaray-premium-dashboard .cabin-card ul,
.millaray-premium-dashboard .cabin-meta span:nth-child(1),
.millaray-premium-dashboard .cabin-meta span:nth-child(2) {
    display: none;
}

.millaray-premium-dashboard .cabin-meta span:last-child {
    display: inline-flex;
}

.millaray-premium-dashboard .cabin-occupancy {
    margin: 12px 0;
}

.millaray-premium-dashboard .activity-grid {
    display: grid;
    gap: 0;
    grid-template-columns: 1fr;
}

.millaray-premium-dashboard .activity-grid article {
    align-items: center;
    background: transparent;
    border: 0;
    border-bottom: 1px solid rgba(58, 36, 23, .08);
    border-radius: 0;
    box-shadow: none;
    display: grid;
    gap: 12px;
    grid-template-columns: 64px 120px minmax(0, 1fr);
    min-height: 54px;
    padding: 0;
}

.millaray-premium-dashboard .activity-grid time,
.millaray-premium-dashboard .activity-grid strong,
.millaray-premium-dashboard .activity-grid p {
    margin: 0;
    min-width: 0;
}

.booking-modal-shell {
    z-index: 20;
}

.millaray-premium-dashboard .booking-modal-card {
    max-height: calc(100vh - 32px);
    overflow-y: auto;
    position: fixed;
    right: 16px;
    top: 16px;
    transform: none;
    width: min(560px, calc(100vw - 32px));
}

@media (max-width: 1200px) {
    body.millaray-premium-dashboard.reservas-admin-page {
        grid-template-columns: 220px minmax(0, 1fr);
    }

    .millaray-premium-dashboard .admin-dashboard {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .millaray-premium-dashboard .charts-grid,
    .millaray-premium-dashboard .calendar-ai-layout {
        grid-template-columns: 1fr;
    }

    .millaray-premium-dashboard .cabins-list {
        grid-template-columns: repeat(2, minmax(220px, 1fr));
    }

    .millaray-premium-dashboard .analysis-summary {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    body.millaray-premium-dashboard.reservas-admin-page {
        display: block;
    }

    .millaray-premium-dashboard.reservas-admin-page nav {
        height: auto;
        max-height: none;
        position: sticky;
        top: 0;
        width: 100%;
    }

    .millaray-premium-dashboard .nav-toggle {
        display: inline-flex;
    }

    .millaray-premium-dashboard .nav-links {
        display: none;
    }

    .millaray-premium-dashboard .nav-links.open {
        display: grid !important;
        position: static;
        width: 100%;
    }

    .millaray-premium-dashboard .dashboard-topbar,
    .millaray-premium-dashboard .dashboard-canvas {
        padding-left: 16px;
        padding-right: 16px;
    }

    .millaray-premium-dashboard .dashboard-topbar,
    .millaray-premium-dashboard .millaray-hero-card {
        grid-template-columns: 1fr;
    }

    .millaray-premium-dashboard .millaray-hero-card {
        max-height: none;
    }

    .millaray-premium-dashboard .hero-metrics-grid,
    .millaray-premium-dashboard .admin-dashboard,
    .millaray-premium-dashboard .analysis-summary,
    .millaray-premium-dashboard .cabins-list,
    .millaray-premium-dashboard .analysis-grid,
    .millaray-premium-dashboard .market-dashboard-strip {
        grid-template-columns: 1fr;
    }

    .millaray-premium-dashboard .activity-grid article {
        grid-template-columns: 58px minmax(0, 1fr);
    }

    .millaray-premium-dashboard .activity-grid p {
        grid-column: 2;
    }
}

@media (max-width: 620px) {
    .millaray-premium-dashboard .dashboard-shell {
        padding: 12px 8px 24px;
    }

    .millaray-premium-dashboard .dashboard-canvas {
        padding: 10px;
    }

    .millaray-premium-dashboard .hero-metrics-grid,
    .millaray-premium-dashboard .admin-dashboard,
    .millaray-premium-dashboard .cabins-list,
    .millaray-premium-dashboard .activity-grid,
    .millaray-premium-dashboard .quick-analysis-list,
    .millaray-premium-dashboard .ai-insights,
    .millaray-premium-dashboard .form-row {
        grid-template-columns: 1fr;
    }

    .millaray-premium-dashboard .millaray-hero-card {
        min-height: 0;
        padding: 22px;
    }

    .millaray-premium-dashboard .hero-illustration {
        min-height: 250px;
    }

    .millaray-premium-dashboard .cabin-card {
        grid-template-columns: 88px minmax(0, 1fr);
    }

    .millaray-premium-dashboard .cabin-thumb {
        min-height: 96px;
    }

    .millaray-premium-dashboard .booking-modal-card {
        inset: auto 10px 10px;
        max-height: calc(100vh - 20px);
        top: 10px;
        width: calc(100vw - 20px);
    }
}

/* Reference-style resort dashboard pass */
.millaray-premium-dashboard.reservas-admin-page {
    background:
        linear-gradient(90deg, rgba(247, 243, 235, 0) 0 280px, rgba(255, 249, 240, .82) 280px),
        radial-gradient(circle at 58% 4%, rgba(227, 194, 139, .28), transparent 25%),
        #F7F3EB;
}

.millaray-premium-dashboard.reservas-admin-page nav {
    background:
        linear-gradient(180deg, rgba(32, 20, 13, .97), rgba(46, 29, 18, .96)),
        radial-gradient(circle at 62% 62%, rgba(227, 194, 139, .22), transparent 24%);
    border: 0;
    border-radius: 0;
    box-shadow: 18px 0 45px rgba(58, 36, 23, .16);
    padding: 32px 22px;
    width: 282px;
}

.millaray-premium-dashboard.reservas-admin-page nav::before {
    background:
        linear-gradient(145deg, transparent 0 45%, rgba(227, 194, 139, .13) 46% 48%, transparent 49%),
        linear-gradient(35deg, transparent 0 52%, rgba(127, 147, 99, .18) 53% 55%, transparent 56%);
    bottom: 210px;
    content: "";
    height: 260px;
    left: 0;
    opacity: .8;
    position: absolute;
    right: 0;
}

.millaray-premium-dashboard.reservas-admin-page nav::after {
    background:
        radial-gradient(circle at 72% 12%, rgba(227, 194, 139, .9) 0 18px, transparent 19px),
        linear-gradient(135deg, transparent 48%, rgba(127, 147, 99, .38) 49% 74%, transparent 75%),
        linear-gradient(45deg, transparent 42%, rgba(201, 140, 84, .42) 43% 72%, transparent 73%);
    bottom: 265px;
    content: "";
    height: 160px;
    left: 24px;
    opacity: .9;
    position: absolute;
    right: 24px;
}

.millaray-premium-dashboard .sidebar-brand {
    position: relative;
    z-index: 2;
}

.millaray-premium-dashboard .sidebar-brand .logo-nav {
    background: transparent;
    border: 0;
    height: 60px;
    padding: 0;
    width: 60px;
}

.millaray-premium-dashboard .sidebar-brand strong {
    font-size: 2rem;
    line-height: .86;
}

.millaray-premium-dashboard .sidebar-brand span {
    color: #E3C28B;
    font-size: .67rem;
    letter-spacing: .16em;
}

.millaray-premium-dashboard .nav-links {
    gap: 12px;
    margin-top: 14px;
    position: relative;
    z-index: 2;
}

.millaray-premium-dashboard .nav-links a {
    background: transparent;
    border: 0;
    border-radius: 8px;
    color: rgba(255, 249, 240, .88);
    font-size: 1rem;
    min-height: 54px;
    padding: 0 18px;
}

.millaray-premium-dashboard .nav-links a::before {
    background: rgba(255, 249, 240, .16);
    border-radius: 7px;
    height: 26px;
    margin-right: 14px;
    width: 26px;
}

.millaray-premium-dashboard .nav-links a:hover,
.millaray-premium-dashboard .nav-links a.is-active {
    background: linear-gradient(135deg, #C98C54, #D96F3F);
    box-shadow: 0 12px 24px rgba(201, 140, 84, .28);
    transform: translateX(0);
}

.millaray-premium-dashboard .sidebar-art {
    display: none;
}

.millaray-premium-dashboard .sidebar-mini-panel {
    background: rgba(255, 249, 240, .1);
    border-color: rgba(255, 249, 240, .12);
    margin-top: auto;
    min-height: 112px;
    position: relative;
    z-index: 2;
}

.millaray-premium-dashboard .sidebar-mini-panel strong {
    font-size: 2.1rem;
}

.millaray-premium-dashboard .sidebar-user {
    background: rgba(255, 249, 240, .1);
    position: relative;
    z-index: 2;
}

.millaray-premium-dashboard .dashboard-shell {
    margin-left: 0;
    padding: 0;
}

.millaray-premium-dashboard .dashboard-topbar {
    background:
        linear-gradient(180deg, rgba(255, 249, 240, .96), rgba(255, 249, 240, .72)),
        radial-gradient(circle at 72% 30%, rgba(227, 194, 139, .22), transparent 28%);
    border-radius: 0 8px 0 0;
    margin: 0;
    min-height: 190px;
    padding: 38px 46px 18px;
    position: relative;
}

.millaray-premium-dashboard .dashboard-title .eyebrow {
    color: #C85F2F;
    font-size: .9rem;
    letter-spacing: 0;
    text-transform: none;
}

.millaray-premium-dashboard .dashboard-title h2 {
    color: #2A180F;
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(3.2rem, 5.2vw, 5.1rem);
    line-height: .93;
    margin: 12px 0 10px;
    max-width: 560px;
}

.millaray-premium-dashboard .dashboard-title p {
    color: rgba(58, 36, 23, .72);
    font-size: 1.08rem;
}

.millaray-premium-dashboard .dashboard-actions {
    align-self: start;
    gap: 18px;
    position: relative;
    z-index: 4;
}

.millaray-premium-dashboard .preview-pill,
.millaray-premium-dashboard .dashboard-date {
    align-items: center;
    background: rgba(255, 249, 240, .8);
    border: 1px solid rgba(92, 61, 39, .1);
    border-radius: 999px;
    box-shadow: 0 10px 24px rgba(58, 36, 23, .06);
    color: #3A2417;
    display: inline-flex;
    font-size: .88rem;
    font-weight: 900;
    min-height: 44px;
    padding: 0 18px;
}

.millaray-premium-dashboard .dashboard-new-booking {
    background: linear-gradient(135deg, #CF7B4E, #C65F34);
    border-radius: 8px;
    box-shadow: 0 14px 26px rgba(198, 95, 52, .28);
    color: #FFF9F0;
    font-size: 1.02rem;
    min-height: 58px;
    padding: 0 28px;
}

.millaray-premium-dashboard .dashboard-new-booking::before {
    content: "+";
    font-size: 1.55rem;
    line-height: 1;
    margin-right: 10px;
}

.millaray-premium-dashboard .dashboard-canvas {
    background: rgba(255, 249, 240, .72);
    border: 0;
    border-radius: 0 0 8px 0;
    box-shadow: none;
    gap: 16px;
    padding: 0 40px 32px;
}

.millaray-premium-dashboard .dashboard-canvas > .millaray-hero-card,
.millaray-premium-dashboard .dashboard-canvas > .admin-dashboard,
.millaray-premium-dashboard .dashboard-canvas > .intelligent-analysis-panel,
.millaray-premium-dashboard .dashboard-canvas > .reservation-grid,
.millaray-premium-dashboard .dashboard-canvas > .cabins-panel,
.millaray-premium-dashboard .dashboard-canvas > .activity-panel,
.millaray-premium-dashboard .dashboard-canvas > .dashboard-quick-panel,
.millaray-premium-dashboard .dashboard-canvas > .auth-panel,
.millaray-premium-dashboard .dashboard-canvas > #reservations-log {
    grid-column: 1 / -1 !important;
    width: 100%;
}

.millaray-premium-dashboard .reservation-grid > .cabins-panel,
.millaray-premium-dashboard .reservation-grid > .activity-panel {
    grid-column: 1 / -1 !important;
    width: 100%;
}

.millaray-premium-dashboard .millaray-hero-card {
    background: transparent;
    border: 0;
    box-shadow: none;
    grid-column: span 12;
    grid-template-columns: minmax(0, .55fr) minmax(520px, 1fr);
    margin-top: -92px;
    min-height: 310px;
    overflow: visible;
    padding: 0;
}

.millaray-premium-dashboard .millaray-hero-card::after {
    display: none;
}

.millaray-premium-dashboard .hero-card-copy {
    align-content: end;
    padding-bottom: 20px;
}

.millaray-premium-dashboard .hero-card-copy .soft-pill {
    display: none;
}

.millaray-premium-dashboard .hero-metrics-grid {
    gap: 12px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.millaray-premium-dashboard .hero-metrics-grid div {
    backdrop-filter: blur(18px);
    background: rgba(255, 249, 240, .82);
    border: 1px solid rgba(92, 61, 39, .1);
    box-shadow: 0 14px 36px rgba(58, 36, 23, .08);
    min-height: 118px;
    padding: 18px;
}

.millaray-premium-dashboard .hero-metrics-grid span {
    color: #2A180F;
    font-size: .9rem;
    margin: 12px 0 8px;
}

.millaray-premium-dashboard .hero-metrics-grid strong {
    color: #2A180F;
    font-size: 2rem;
}

.millaray-premium-dashboard .hero-metrics-grid div::before {
    background: #F8DFC6;
    border-radius: 10px;
    color: #8C5A34;
    content: "";
    display: block;
    height: 42px;
    width: 42px;
}

.millaray-premium-dashboard .hero-actions {
    display: none;
}

.millaray-premium-dashboard .hero-illustration {
    background:
        radial-gradient(ellipse at 70% 88%, rgba(201, 140, 84, .22) 0 36%, transparent 37%),
        radial-gradient(ellipse at 55% 78%, rgba(227, 194, 139, .32) 0 48%, transparent 49%);
    border: 0;
    box-shadow: none;
    min-height: 310px;
}

.millaray-premium-dashboard .sun-glow {
    right: 255px;
    top: 42px;
}

.millaray-premium-dashboard .mountain-back {
    background: rgba(196, 190, 178, .72);
    bottom: 82px;
    height: 210px;
    left: 130px;
    width: 300px;
}

.millaray-premium-dashboard .mountain-front {
    background: rgba(127, 147, 99, .38);
    bottom: 70px;
    height: 170px;
    right: 60px;
    width: 320px;
}

.millaray-premium-dashboard .mini-cabin {
    bottom: 62px;
    height: 170px;
    left: 54%;
    width: 330px;
}

.millaray-premium-dashboard .mini-roof {
    border-bottom-width: 78px;
    border-left-width: 165px;
    border-right-width: 165px;
}

.millaray-premium-dashboard .mini-house {
    height: 112px;
    width: 235px;
}

.millaray-premium-dashboard .hero-tree {
    height: 190px;
    width: 96px;
}

.millaray-premium-dashboard .tree-left {
    bottom: 82px;
    left: 90px;
}

.millaray-premium-dashboard .tree-right {
    bottom: 78px;
    right: 90px;
}

.millaray-premium-dashboard .hero-suitcase {
    background: linear-gradient(180deg, #B46A35, #8C4D28);
    bottom: 58px;
    height: 92px;
    left: auto;
    right: 52px;
    width: 120px;
}

.millaray-premium-dashboard .hero-cup {
    bottom: 58px;
    height: 56px;
    right: 258px;
    width: 66px;
}

.millaray-premium-dashboard .hero-mini-chart {
    display: none;
}

.millaray-premium-dashboard .admin-dashboard {
    gap: 14px;
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.millaray-premium-dashboard .metric-card {
    background: rgba(255, 249, 240, .78);
    box-shadow: 0 12px 30px rgba(58, 36, 23, .07);
    min-height: 112px;
    padding: 20px 22px;
}

.millaray-premium-dashboard .metric-card i {
    float: right;
    height: 52px;
    margin: 4px 0 0 14px;
    width: 52px;
}

.millaray-premium-dashboard .metric-card span {
    color: #2A180F;
    font-size: .84rem;
}

.millaray-premium-dashboard .metric-card strong {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 2rem;
}

.millaray-premium-dashboard .metric-card small {
    color: rgba(58, 36, 23, .62);
}

.millaray-premium-dashboard .intelligent-analysis-panel,
.millaray-premium-dashboard .cabins-panel,
.millaray-premium-dashboard .activity-panel,
.millaray-premium-dashboard .dashboard-quick-panel,
.millaray-premium-dashboard .reservations-panel,
.millaray-premium-dashboard .auth-panel {
    background: transparent;
    border: 0;
    box-shadow: none;
    padding: 0;
}

.millaray-premium-dashboard .charts-grid,
.millaray-premium-dashboard .calendar-ai-layout,
.millaray-premium-dashboard .analysis-grid,
.millaray-premium-dashboard .market-dashboard-strip,
.millaray-premium-dashboard .analysis-summary {
    padding: 0;
}

.millaray-premium-dashboard .analysis-header {
    display: none;
}

.millaray-premium-dashboard .analysis-card,
.millaray-premium-dashboard .ai-insight-card,
.millaray-premium-dashboard .prediction-card,
.millaray-premium-dashboard .analysis-summary article,
.millaray-premium-dashboard .activity-grid article,
.millaray-premium-dashboard .reservation-card,
.millaray-premium-dashboard .cabin-card {
    background: rgba(255, 249, 240, .78);
    border: 1px solid rgba(92, 61, 39, .08);
    box-shadow: 0 12px 30px rgba(58, 36, 23, .07);
}

.millaray-premium-dashboard .chart-card-large .bar-chart {
    min-height: 270px;
}

.millaray-premium-dashboard .bar-track {
    background: transparent;
    height: 210px;
    padding: 0;
}

.millaray-premium-dashboard .bar-track span {
    background: linear-gradient(180deg, #F2C78F, #D17041);
    border-radius: 999px 999px 0 0;
    margin: auto auto 0;
    width: 42%;
}

.millaray-premium-dashboard .heat-day {
    border-radius: 999px;
    min-height: 30px;
}

.millaray-premium-dashboard .calendar-ai-layout {
    grid-template-columns: minmax(0, 1.1fr) minmax(320px, .7fr);
}

.millaray-premium-dashboard .ai-insights {
    grid-template-columns: 1fr;
}

.millaray-premium-dashboard .ai-insights p {
    align-items: center;
    background: transparent;
    border: 0;
    border-bottom: 1px solid rgba(92, 61, 39, .08);
    border-radius: 0;
    display: flex;
    min-height: 54px;
}

.millaray-premium-dashboard .ai-insights p::before {
    background: #F8DFC6;
    border-radius: 10px;
    content: "";
    flex: 0 0 40px;
    height: 40px;
    margin-right: 14px;
    width: 40px;
}

.millaray-premium-dashboard .quick-analysis-list {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.millaray-premium-dashboard .booking-modal-card {
    border-radius: 12px;
}

@media (max-width: 1180px) {
    .millaray-premium-dashboard.reservas-admin-page nav {
        width: 100%;
    }

    .millaray-premium-dashboard.reservas-admin-page nav::before,
    .millaray-premium-dashboard.reservas-admin-page nav::after {
        display: none;
    }

    .millaray-premium-dashboard .dashboard-shell {
        margin-left: 0;
    }

    .millaray-premium-dashboard .dashboard-topbar {
        border-radius: 0;
    }

    .millaray-premium-dashboard .millaray-hero-card {
        margin-top: -44px;
    }
}

@media (max-width: 980px) {
    .millaray-premium-dashboard .dashboard-topbar {
        min-height: 0;
        padding: 24px 18px 60px;
    }

    .millaray-premium-dashboard .dashboard-canvas {
        padding: 0 14px 24px;
    }

    .millaray-premium-dashboard .millaray-hero-card {
        grid-template-columns: 1fr;
    }

    .millaray-premium-dashboard .hero-metrics-grid,
    .millaray-premium-dashboard .admin-dashboard {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* Stable dashboard rollback */
.millaray-premium-dashboard.reservas-admin-page {
    background: #f7f3eb;
    display: block;
    min-height: 100vh;
}

body.millaray-premium-dashboard.reservas-admin-page {
    display: block !important;
}

.millaray-premium-dashboard.reservas-admin-page nav::before,
.millaray-premium-dashboard.reservas-admin-page nav::after,
.millaray-premium-dashboard .dashboard-topbar::before,
.millaray-premium-dashboard .dashboard-topbar::after,
.millaray-premium-dashboard .millaray-hero-card::before,
.millaray-premium-dashboard .millaray-hero-card::after,
.millaray-premium-dashboard .metric-card::before,
.millaray-premium-dashboard .metric-card::after,
.millaray-premium-dashboard .analysis-card::before,
.millaray-premium-dashboard .analysis-card::after,
.millaray-premium-dashboard .cabin-card::before,
.millaray-premium-dashboard .cabin-card::after,
.millaray-premium-dashboard .heat-calendar::after,
.millaray-premium-dashboard .sidebar-art {
    display: none !important;
}

.millaray-premium-dashboard .dashboard-shell {
    margin-left: 282px;
    max-width: none;
    padding: 0;
    width: calc(100% - 282px);
}

.millaray-premium-dashboard #reservas.dashboard-shell {
    margin-left: 282px !important;
    max-width: none !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    width: calc(100vw - 282px) !important;
}

.millaray-premium-dashboard.reservas-admin-page nav {
    bottom: 0;
    left: 0;
    position: fixed;
    top: 0;
}

.millaray-premium-dashboard .dashboard-topbar {
    background: #fff9f0;
    border-radius: 0;
    display: flex;
    gap: 24px;
    justify-content: space-between;
    margin: 0;
    min-height: 0;
    padding: 24px 32px;
    position: static;
}

.millaray-premium-dashboard .dashboard-title h2 {
    font-family: Inter, Arial, sans-serif;
    font-size: 2rem;
    letter-spacing: 0;
    line-height: 1.15;
    margin: 8px 0;
    max-width: 100%;
}

.millaray-premium-dashboard .dashboard-canvas {
    background: #fff9f0;
    border-radius: 0;
    display: grid;
    gap: 24px;
    grid-template-columns: 1fr;
    padding: 24px 32px 40px;
}

.millaray-premium-dashboard .dashboard-canvas > .millaray-hero-card,
.millaray-premium-dashboard .dashboard-canvas > .admin-dashboard,
.millaray-premium-dashboard .dashboard-canvas > .intelligent-analysis-panel,
.millaray-premium-dashboard .dashboard-canvas > .reservation-grid,
.millaray-premium-dashboard .dashboard-canvas > .dashboard-quick-panel,
.millaray-premium-dashboard .dashboard-canvas > .auth-panel,
.millaray-premium-dashboard .dashboard-canvas > #reservations-log,
.millaray-premium-dashboard .reservation-grid > .cabins-panel,
.millaray-premium-dashboard .reservation-grid > .activity-panel {
    grid-column: 1 / -1 !important;
    grid-row: auto !important;
    width: 100%;
}

.millaray-premium-dashboard .dashboard-canvas *,
.millaray-premium-dashboard .dashboard-canvas *::before,
.millaray-premium-dashboard .dashboard-canvas *::after {
    box-sizing: border-box;
    max-width: 100%;
    transform: none !important;
}

.millaray-premium-dashboard .millaray-hero-card,
.millaray-premium-dashboard .millaray-hero-card *,
.millaray-premium-dashboard .admin-dashboard,
.millaray-premium-dashboard .admin-dashboard *,
.millaray-premium-dashboard .intelligent-analysis-panel,
.millaray-premium-dashboard .intelligent-analysis-panel *,
.millaray-premium-dashboard .cabins-panel,
.millaray-premium-dashboard .cabins-panel *,
.millaray-premium-dashboard .activity-panel,
.millaray-premium-dashboard .activity-panel * {
    position: static !important;
}

.millaray-premium-dashboard .millaray-hero-card {
    align-items: center;
    background: #ffffff;
    border: 1px solid rgba(58, 36, 23, .08);
    border-radius: 8px;
    box-shadow: none;
    display: grid;
    gap: 24px;
    grid-template-columns: minmax(0, 1fr) minmax(220px, 360px);
    margin: 0;
    max-height: 280px;
    min-height: 0;
    overflow: hidden;
    padding: 24px;
}

.millaray-premium-dashboard .hero-card-copy {
    align-content: start;
    display: grid;
    gap: 16px;
    padding: 0;
}

.millaray-premium-dashboard .hero-card-copy h1 {
    color: #2a180f;
    font-family: Inter, Arial, sans-serif;
    font-size: clamp(2rem, 4vw, 3rem);
    letter-spacing: 0;
    line-height: 1.05;
    margin: 0;
    max-width: 620px;
}

.millaray-premium-dashboard .hero-card-copy .soft-pill,
.millaray-premium-dashboard .hero-actions {
    display: none;
}

.millaray-premium-dashboard .hero-metrics-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.millaray-premium-dashboard .hero-metrics-grid div,
.millaray-premium-dashboard .metric-card,
.millaray-premium-dashboard .analysis-card,
.millaray-premium-dashboard .ai-insight-card,
.millaray-premium-dashboard .cabins-panel,
.millaray-premium-dashboard .activity-panel,
.millaray-premium-dashboard .dashboard-quick-panel,
.millaray-premium-dashboard .auth-panel,
.millaray-premium-dashboard .reservations-panel,
.millaray-premium-dashboard .cabin-card,
.millaray-premium-dashboard .activity-grid article,
.millaray-premium-dashboard .reservation-card {
    background: #ffffff;
    border: 1px solid rgba(58, 36, 23, .08);
    border-radius: 8px;
    box-shadow: none;
}

.millaray-premium-dashboard .hero-metrics-grid div {
    min-height: 0;
    padding: 14px;
}

.millaray-premium-dashboard .hero-metrics-grid span {
    display: block;
    font-size: .78rem;
    margin: 0 0 6px;
}

.millaray-premium-dashboard .hero-metrics-grid strong {
    font-family: Inter, Arial, sans-serif;
    font-size: 1.55rem;
}

.millaray-premium-dashboard .hero-illustration {
    align-items: center;
    background: #f1eadf;
    border-radius: 8px;
    display: flex;
    justify-content: center;
    min-height: 0;
    overflow: hidden;
}

.millaray-premium-dashboard .hero-illustration img {
    display: block;
    height: 220px;
    object-fit: contain;
    width: 100%;
}

.millaray-premium-dashboard .admin-dashboard {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.millaray-premium-dashboard .metric-card {
    min-height: 0;
    padding: 18px;
}

.millaray-premium-dashboard .metric-card i {
    display: none;
}

.millaray-premium-dashboard .intelligent-analysis-panel,
.millaray-premium-dashboard .cabins-panel,
.millaray-premium-dashboard .activity-panel,
.millaray-premium-dashboard .dashboard-quick-panel,
.millaray-premium-dashboard .auth-panel,
.millaray-premium-dashboard .reservations-panel {
    display: grid;
    gap: 18px;
    padding: 20px;
}

.millaray-premium-dashboard .analysis-header {
    display: block;
}

.millaray-premium-dashboard .charts-grid {
    display: grid;
    gap: 24px;
    grid-template-columns: 1.4fr 1fr;
}

.millaray-premium-dashboard .analytics-side {
    display: grid;
    gap: 24px;
    grid-template-columns: 1fr;
    min-width: 0;
}

.millaray-premium-dashboard .analysis-card,
.millaray-premium-dashboard .ai-insight-card {
    min-height: 0;
    padding: 18px;
}

.millaray-premium-dashboard.reservas-admin-page .admin-dashboard {
    gap: 12px;
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.millaray-premium-dashboard.reservas-admin-page .metric-card {
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-height: 136px;
    padding: 18px 18px 16px;
    position: relative;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card i {
    align-items: center;
    background: linear-gradient(135deg, rgba(227, 194, 139, .22), rgba(201, 111, 61, .14));
    border: 1px solid rgba(201, 111, 61, .12);
    border-radius: 16px;
    color: var(--terracotta);
    display: inline-flex;
    font-size: 1rem;
    font-style: normal;
    font-weight: 900;
    height: 42px;
    justify-content: center;
    letter-spacing: .02em;
    margin-bottom: 0;
    position: absolute;
    right: 16px;
    top: 16px;
    width: 46px;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card i::before,
.millaray-premium-dashboard.reservas-admin-page .metric-card i::after {
    content: none;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card span {
    color: rgba(62, 43, 29, .72);
    display: block;
    font-size: .74rem;
    font-weight: 700;
    letter-spacing: .08em;
    margin-bottom: 2px;
    max-width: 140px;
    text-transform: uppercase;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card strong {
    color: var(--coffee);
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(1.55rem, 2.4vw, 2.35rem);
    line-height: 1;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card small {
    color: rgba(62, 43, 29, .72);
    font-size: .76rem;
    font-weight: 700;
    margin-top: auto;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card-income {
    order: 1;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card-cabin {
    order: 2;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card-guests {
    order: 3;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card-day {
    order: 4;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card-bookings {
    order: 5;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card-active {
    display: none;
}

.millaray-premium-dashboard .chart-card-large .bar-chart,
.millaray-premium-dashboard .bar-chart {
    align-items: end;
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    min-height: 240px;
}

/* Chart canvas styling */
.bar-chart {
    padding: 8px 12px 6px;
    background: linear-gradient(180deg, rgba(255,250,244,0.6), transparent 60%);
    border-radius: 12px;
    box-shadow: inset 0 -2px 6px rgba(0,0,0,0.02);
}
.bar-chart canvas { width: 100% !important; height: 260px !important; display: block; }
.bar-chart .chartjs-render-monitor { border-radius: 10px; }

/* Heatmap styles */
.heatmap-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; padding: 8px; }
.heat-cell { border-radius: 8px; min-height: 44px; display:flex; align-items:flex-start; justify-content:flex-start; padding:6px; box-shadow: inset 0 -4px 10px rgba(0,0,0,0.02); }
.heat-cell .heat-day { font-size:.75rem; color:#2d1b12; font-weight:700; }

/* Doughnut container small */
#hourly-visitors-chart, #food-profit-chart { min-height:200px; }
#hourly-visitors-chart canvas, #food-profit-chart canvas { width:100% !important; height:220px !important; }

/* Gallery and image fallback refresh */
.image-fallback {
    align-items: center;
    background:
        linear-gradient(135deg, rgba(255, 250, 242, .94), rgba(240, 226, 205, .94));
    border: 1px solid rgba(137, 93, 55, .14);
    color: #6f4b2c;
    display: flex;
    flex-direction: column;
    font-weight: 800;
    gap: 8px;
    justify-content: center;
    min-height: 180px;
    text-align: center;
}

.image-fallback-icon {
    align-items: center;
    background: rgba(178, 124, 74, .14);
    border: 1px solid rgba(178, 124, 74, .2);
    border-radius: 999px;
    display: inline-flex;
    font-size: 1.8rem;
    height: 54px;
    justify-content: center;
    width: 54px;
}

.gallery-page {
    --gallery-cream: #fffaf2;
    --gallery-paper: #fffdf8;
    --gallery-coffee: #2f2118;
    --gallery-gold: #c7a36b;
    --gallery-terracotta: #b8663e;
    background: linear-gradient(180deg, #f8f1e8 0%, #efe2d1 100%);
    overflow-x: hidden;
}

.gallery-page *,
.gallery-page *::before,
.gallery-page *::after {
    box-sizing: border-box;
}

.gallery-page .page-hero.gallery-hero {
    align-items: center;
    background: linear-gradient(120deg, #2c1c13 0%, #4f3322 58%, #76533a 100%);
    isolation: isolate;
    min-height: 430px;
    overflow: hidden;
    padding-bottom: 78px;
    position: relative;
}

.gallery-page .page-hero.gallery-hero::after {
    background: url("logo_blanco_hd.png") center / contain no-repeat;
    content: "";
    inset: 52px max(24px, calc((100% - 1200px) / 2)) 36px auto;
    opacity: .1;
    pointer-events: none;
    position: absolute;
    width: min(360px, 42vw);
    z-index: 1;
}

.gallery-hero .hero-copy {
    max-width: min(640px, 100%);
    position: relative;
    z-index: 2;
}

.gallery-hero-watermark {
    height: min(320px, 46vw);
    opacity: .09;
    pointer-events: none;
    position: absolute;
    right: max(24px, calc((100% - 1200px) / 2));
    top: 50%;
    transform: translateY(-50%);
    width: auto;
    z-index: 1;
}

.gallery-tour-section,
.dining-feature {
    max-width: none;
    padding-left: max(20px, calc((100% - 1200px) / 2));
    padding-right: max(20px, calc((100% - 1200px) / 2));
}

.gallery-grid {
    display: grid;
    gap: 28px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.cabin-gallery-card {
    background: var(--gallery-cream);
    border: 1px solid rgba(95, 64, 42, .1);
    border-radius: 22px;
    box-shadow: 0 22px 55px rgba(66, 43, 27, .12);
    display: grid;
    overflow: hidden;
}

.cabin-main-photo,
.dining-main-photo {
    background: #f1e2ce;
    display: block;
    height: 260px;
    object-fit: cover;
    width: 100%;
}

.cabin-thumbnails,
.dining-thumbnails {
    background: rgba(255, 255, 255, .54);
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    padding: 12px;
}

.cabin-thumbnails img,
.dining-thumbnails img {
    aspect-ratio: 4 / 3;
    border-radius: 14px;
    display: block;
    height: 92px;
    object-fit: cover;
    width: 100%;
}

.cabin-gallery-copy {
    display: grid;
    gap: 16px;
    padding: 22px;
}

.cabin-gallery-copy h3 {
    color: var(--gallery-coffee);
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 1.72rem;
    line-height: 1;
    margin: 0 0 8px;
}

.cabin-gallery-copy p {
    color: rgba(47, 33, 24, .72);
    margin: 0;
}

.cabin-card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.cabin-card-meta span {
    background: #f3e4ce;
    border: 1px solid rgba(184, 102, 62, .12);
    border-radius: 999px;
    color: #6d4329;
    font-size: .84rem;
    font-weight: 800;
    padding: 7px 10px;
}

.cabin-gallery-card .btn-primary {
    justify-self: start;
    text-decoration: none;
}

.cabin-gallery-card.is-pending .cabin-placeholder {
    min-height: 260px;
}

.cabin-placeholder {
    align-items: center;
    background:
        linear-gradient(135deg, #fff8ed, #ead8bf);
    color: #765237;
    display: flex;
    flex-direction: column;
    font-weight: 800;
    gap: 10px;
    justify-content: center;
    text-align: center;
}

.cabin-placeholder-icon {
    align-items: center;
    background: rgba(184, 102, 62, .14);
    border-radius: 18px;
    display: inline-flex;
    font-size: 2rem;
    height: 64px;
    justify-content: center;
    width: 64px;
}

.btn-disabled {
    align-items: center;
    background: #ded0bd;
    border-radius: 8px;
    color: rgba(47, 33, 24, .62);
    cursor: not-allowed;
    display: inline-flex;
    font-weight: 800;
    justify-content: center;
    min-height: 42px;
    padding: 10px 16px;
    text-decoration: none;
}

.dining-feature {
    background: linear-gradient(180deg, rgba(255, 250, 242, .62), #f5eadb);
}

.dining-card {
    background: var(--gallery-cream);
    border: 1px solid rgba(95, 64, 42, .1);
    border-radius: 22px;
    box-shadow: 0 22px 55px rgba(66, 43, 27, .12);
    overflow: hidden;
}

.dining-main-photo {
    height: clamp(280px, 42vw, 460px);
}

.dining-thumbnails img {
    height: 130px;
}

@media (max-width: 900px) {
    .gallery-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .gallery-hero-watermark {
        height: 220px;
        right: 18px;
    }
}

@media (max-width: 680px) {
    .gallery-page nav {
        flex-wrap: nowrap;
        justify-content: space-between;
    }

    .gallery-page nav .logo-nav {
        margin-bottom: 0;
        max-width: 52px;
    }

    .gallery-page .nav-toggle {
        flex: 0 0 auto;
        font-size: 1rem;
        max-width: 82px;
    }

    .gallery-page .nav-links {
        left: 0;
        position: absolute;
        right: 0;
        top: 100%;
    }

    .gallery-page .page-hero.gallery-hero {
        min-height: 360px;
        padding-bottom: 48px;
    }

    .gallery-page .hero-copy,
    .gallery-page .section-heading,
    .gallery-page .gallery-grid,
    .gallery-page .dining-card {
        max-width: calc(100vw - 40px) !important;
        min-width: 0 !important;
        width: calc(100vw - 40px) !important;
    }

    .gallery-page h1,
    .gallery-page h2 {
        max-width: calc(100vw - 40px) !important;
        overflow-wrap: break-word !important;
        white-space: normal !important;
        word-break: normal;
    }

    .gallery-page .hero-copy p,
    .gallery-page .section-heading p {
        max-width: calc(100vw - 40px) !important;
        overflow-wrap: normal !important;
        white-space: normal !important;
        word-break: normal !important;
    }

    .gallery-page .hero-actions {
        max-width: calc(100vw - 40px);
    }

    .gallery-page .hero-actions a {
        max-width: 100%;
    }

    .gallery-page .page-hero.gallery-hero::after {
        inset: 96px -50px auto auto;
        opacity: .07;
        width: 230px;
    }

    .gallery-page .page-hero.gallery-hero h1 {
        font-size: 3.1rem;
    }

    .gallery-page h2 {
        font-size: clamp(2rem, 11vw, 2.75rem);
        line-height: 1.04;
        overflow-wrap: anywhere;
    }

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

    .cabin-main-photo {
        height: 230px;
    }

    .cabin-thumbnails,
    .dining-thumbnails {
        gap: 8px;
        padding: 10px;
    }

    .cabin-thumbnails img {
        height: 74px;
    }

    .dining-thumbnails {
        grid-template-columns: 1fr;
    }

    .dining-thumbnails img {
        height: 150px;
    }
}

.millaray-premium-dashboard .bar-track {
    align-items: end;
    background: #f1eadf;
    border-radius: 8px;
    display: flex;
    height: 180px;
    justify-content: center;
    padding: 0 6px;
}

.millaray-premium-dashboard .bar-track span {
    background: #c98c54;
    border-radius: 8px 8px 0 0;
    display: block;
    margin: 0;
    width: 100%;
}

.millaray-premium-dashboard .calendar-ai-layout,
.millaray-premium-dashboard .analysis-grid,
.millaray-premium-dashboard .market-dashboard-strip {
    display: none;
}

.millaray-premium-dashboard .heat-calendar {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    margin: 0;
}

.millaray-premium-dashboard .heat-calendar::before {
    content: "Lun Mar Mie Jue Vie Sab Dom";
    display: block;
    font-size: .72rem;
    grid-column: 1 / -1;
    overflow: hidden;
    white-space: nowrap;
    word-spacing: 10px;
}

.millaray-premium-dashboard .heat-day {
    align-items: center;
    border-radius: 8px;
    display: flex;
    justify-content: center;
    min-height: 34px;
    padding: 6px;
}

.millaray-premium-dashboard .ai-insights {
    display: grid;
    gap: 10px;
    grid-template-columns: 1fr;
}

.millaray-premium-dashboard .ai-insights p {
    background: #fff9f0;
    border: 1px solid rgba(58, 36, 23, .08);
    border-radius: 8px;
    margin: 0;
    min-height: 0;
    padding: 12px;
}

.millaray-premium-dashboard .ai-insights p::before {
    display: none;
}

.millaray-premium-dashboard .reservation-grid {
    display: contents;
}

.millaray-premium-dashboard .cabins-list {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.millaray-premium-dashboard .cabin-card {
    align-items: center;
    display: flex;
    gap: 16px;
    padding: 14px;
}

.millaray-premium-dashboard .cabin-thumb {
    aspect-ratio: 4 / 3;
    border-radius: 8px;
    display: block;
    flex: 0 0 120px;
    height: auto;
    min-height: 0;
    object-fit: cover;
    overflow: hidden;
    width: 120px;
}

.millaray-premium-dashboard .cabin-card-copy {
    display: grid;
    gap: 8px;
    min-width: 0;
}

.millaray-premium-dashboard .cabin-card p,
.millaray-premium-dashboard .cabin-card ul,
.millaray-premium-dashboard .cabin-meta span:nth-child(1),
.millaray-premium-dashboard .cabin-meta span:nth-child(2) {
    display: none;
}

.millaray-premium-dashboard .cabin-occupancy {
    margin: 4px 0;
}

.millaray-premium-dashboard .activity-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.millaray-premium-dashboard .activity-grid article {
    display: grid;
    gap: 8px;
    min-height: 0;
    padding: 14px;
}

.millaray-premium-dashboard .auth-panel {
    order: 7 !important;
}

.millaray-premium-dashboard #reservations-log {
    order: 8 !important;
}

.millaray-premium-dashboard .millaray-hero-card {
    order: 1 !important;
}

.millaray-premium-dashboard .admin-dashboard {
    order: 2 !important;
}

.millaray-premium-dashboard .intelligent-analysis-panel {
    order: 3 !important;
}

.millaray-premium-dashboard .cabins-panel {
    order: 4 !important;
}

.millaray-premium-dashboard .activity-panel {
    order: 5 !important;
}

.millaray-premium-dashboard .dashboard-quick-panel {
    order: 6 !important;
}

.millaray-premium-dashboard .section {
    outline: none;
}

@media (max-width: 1180px) {
    .millaray-premium-dashboard.reservas-admin-page nav {
        bottom: auto;
        position: sticky;
    }

    .millaray-premium-dashboard .dashboard-shell {
        margin-left: 0;
        width: 100%;
    }

    .millaray-premium-dashboard #reservas.dashboard-shell {
        margin-left: 0 !important;
        width: 100% !important;
    }

    .millaray-premium-dashboard .admin-dashboard {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 860px) {
    .millaray-premium-dashboard .dashboard-topbar {
        display: grid;
        padding: 20px 16px;
    }

    .millaray-premium-dashboard .dashboard-canvas {
        padding: 16px;
    }

    .millaray-premium-dashboard .millaray-hero-card {
        grid-template-columns: 1fr;
        max-height: 280px;
    }

    .millaray-premium-dashboard .admin-dashboard,
    .millaray-premium-dashboard .charts-grid,
    .millaray-premium-dashboard .cabins-list,
    .millaray-premium-dashboard .activity-grid {
        grid-template-columns: 1fr;
    }

    .millaray-premium-dashboard .hero-metrics-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .millaray-premium-dashboard .hero-illustration {
        display: none;
    }
}

/* Reservation dashboard BI refresh */
.millaray-premium-dashboard.reservas-admin-page {
    --cream: #F7F3EB;
    --paper: #FFF9F0;
    --coffee: #2D1B12;
    --terracotta: #C96F3D;
    --gold: #E3C28B;
    --olive: #7F9363;
    overflow-x: hidden;
}

.millaray-premium-dashboard .dashboard-canvas {
    max-width: 1280px;
}

.millaray-premium-dashboard [hidden] {
    display: none !important;
}

.millaray-premium-dashboard.reservas-admin-page .admin-dashboard {
    gap: 18px;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card {
    background:
        linear-gradient(135deg, rgba(255, 253, 248, .98), rgba(255, 246, 232, .96)) !important;
    border: 1px solid rgba(92, 61, 39, .1) !important;
    border-radius: 18px !important;
    box-shadow: 0 18px 40px rgba(58, 36, 23, .08) !important;
    display: grid !important;
    gap: 10px;
    grid-template-columns: 52px minmax(0, 1fr);
    min-height: 176px;
    overflow: hidden;
    padding: 18px !important;
    position: relative !important;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card::after {
    background: linear-gradient(180deg, rgba(201, 111, 61, .18), rgba(227, 194, 139, .06));
    border-radius: 999px;
    content: "";
    height: 110px;
    position: absolute;
    right: -46px;
    top: -44px;
    width: 110px;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card i {
    align-items: center;
    background: linear-gradient(135deg, #fff1dc, #ead0a4) !important;
    border: 1px solid rgba(201, 111, 61, .16) !important;
    border-radius: 16px !important;
    color: #9d4d2d !important;
    display: inline-flex !important;
    font-size: 1.25rem;
    font-style: normal;
    font-weight: 900;
    grid-row: 1 / span 4;
    height: 52px !important;
    justify-content: center;
    position: static !important;
    width: 52px !important;
    z-index: 1;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card i::before {
    background: transparent !important;
    border-radius: 0 !important;
    content: attr(data-icon) !important;
    display: block;
    height: auto !important;
    left: auto !important;
    line-height: 1;
    position: static !important;
    top: auto !important;
    width: auto !important;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card i::after {
    content: none !important;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card > span,
.millaray-premium-dashboard.reservas-admin-page .metric-card > strong,
.millaray-premium-dashboard.reservas-admin-page .metric-card > .metric-variation,
.millaray-premium-dashboard.reservas-admin-page .metric-card > small {
    grid-column: 2;
    min-width: 0;
    position: relative;
    z-index: 1;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card > span {
    color: rgba(45, 27, 18, .66) !important;
    font-size: .75rem !important;
    font-weight: 900;
    letter-spacing: .08em !important;
    line-height: 1.2;
    text-transform: uppercase;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card > strong {
    color: #21130c !important;
    font-family: Inter, Arial, sans-serif !important;
    font-size: clamp(2rem, 3.1vw, 3rem) !important;
    font-weight: 900;
    letter-spacing: 0;
    line-height: .95;
    overflow-wrap: anywhere;
}

.metric-variation {
    align-items: center;
    border-radius: 999px;
    display: inline-flex;
    font-size: .82rem;
    font-weight: 900;
    justify-self: start;
    line-height: 1;
    padding: 8px 10px;
}

.metric-variation.is-up {
    background: rgba(74, 139, 92, .13);
    color: #2f7a48;
}

.metric-variation.is-down {
    background: rgba(184, 76, 54, .13);
    color: #aa3e2c;
}

.metric-variation.is-neutral {
    background: rgba(145, 91, 48, .12);
    color: #74522f;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card > small {
    color: rgba(45, 27, 18, .58) !important;
    font-size: .78rem !important;
    font-weight: 800;
    line-height: 1.35;
    margin: 0 !important;
}

.millaray-premium-dashboard .hero-illustration img {
    height: 220px;
    object-fit: cover;
    width: 100%;
}

.millaray-premium-dashboard .millaray-hero-card {
    background: linear-gradient(135deg, #fffaf2, #f3e3cf);
    border-radius: 14px;
    display: grid !important;
    box-shadow: 0 14px 34px rgba(45, 27, 18, .08);
    max-height: none;
    order: 1 !important;
}

.millaray-premium-dashboard .admin-dashboard {
    display: grid !important;
    order: 2 !important;
}

.millaray-premium-dashboard .intelligent-analysis-panel {
    display: grid !important;
    order: 3 !important;
}

.millaray-premium-dashboard .reservation-grid {
    order: 4 !important;
}

.millaray-premium-dashboard .dashboard-quick-panel {
    order: 5 !important;
}

.millaray-premium-dashboard .business-intelligence {
    order: 6 !important;
}

.millaray-premium-dashboard .auth-panel {
    order: 7 !important;
}

.millaray-premium-dashboard #reservations-log {
    order: 8 !important;
}

.millaray-premium-dashboard .hero-metrics-grid div,
.millaray-premium-dashboard .metric-card,
.millaray-premium-dashboard .analysis-card,
.millaray-premium-dashboard .ai-insight-card,
.millaray-premium-dashboard .cabins-panel,
.millaray-premium-dashboard .activity-panel,
.millaray-premium-dashboard .dashboard-quick-panel,
.millaray-premium-dashboard .auth-panel,
.millaray-premium-dashboard .reservations-panel,
.millaray-premium-dashboard .business-intelligence,
.millaray-premium-dashboard .bi-card,
.millaray-premium-dashboard .bi-kpi-grid article {
    background: var(--paper);
    border: 1px solid rgba(45, 27, 18, .08);
    border-radius: 14px;
    box-shadow: 0 12px 28px rgba(45, 27, 18, .06);
}

.millaray-premium-dashboard.reservas-admin-page .metric-card-active {
    display: flex;
    order: 6;
}

.millaray-premium-dashboard.reservas-admin-page .admin-dashboard {
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.millaray-premium-dashboard .reservation-grid {
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(0, 1.2fr) minmax(320px, .8fr);
}

.millaray-premium-dashboard .cabins-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.millaray-premium-dashboard .cabin-card {
    align-items: center;
    min-height: 0;
}

.millaray-premium-dashboard .cabin-card-copy p,
.millaray-premium-dashboard .cabin-card-copy ul,
.millaray-premium-dashboard .cabin-meta span:nth-child(1),
.millaray-premium-dashboard .cabin-meta span:nth-child(2) {
    display: none;
}

.millaray-premium-dashboard .cabin-card-title {
    align-items: center;
    display: flex;
    gap: 10px;
    justify-content: space-between;
}

.millaray-premium-dashboard .cabin-status {
    background: rgba(127, 147, 99, .14);
    border-radius: 999px;
    color: #587044;
    font-size: .72rem;
    font-weight: 800;
    padding: 5px 8px;
}

.millaray-premium-dashboard .cabin-status.is-hot {
    background: rgba(201, 111, 61, .14);
    color: #9c4c27;
}

.millaray-premium-dashboard .cabin-status.is-pending {
    background: rgba(227, 194, 139, .2);
    color: #7a5a25;
}

.millaray-premium-dashboard .activity-grid {
    display: grid;
    gap: 10px;
    grid-template-columns: 1fr;
}

.millaray-premium-dashboard .activity-grid article {
    align-items: center;
    display: grid;
    gap: 8px;
    grid-template-columns: 56px 86px minmax(0, 1fr);
    min-height: 0;
    padding: 12px 14px;
}

.millaray-premium-dashboard .activity-grid article time {
    color: var(--terracotta);
    font-weight: 900;
}

.millaray-premium-dashboard .activity-grid article p {
    margin: 0;
}

.millaray-premium-dashboard .business-intelligence {
    display: grid;
    gap: 18px;
    padding: 20px;
}

.bi-header {
    align-items: center;
    display: flex;
    gap: 16px;
    justify-content: space-between;
}

.bi-filters {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.bi-filters label {
    display: grid;
    gap: 6px;
}

.bi-filters span {
    color: rgba(45, 27, 18, .72);
    font-size: .74rem;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.bi-filters select,
.bi-filters input {
    background: #fffdf8;
    border: 1px solid rgba(45, 27, 18, .14);
    border-radius: 10px;
    color: var(--coffee);
    font: inherit;
    min-height: 42px;
    padding: 9px 10px;
    width: 100%;
}

.bi-kpi-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.bi-kpi-grid article {
    display: grid;
    gap: 6px;
    padding: 16px;
}

.bi-kpi-grid span,
.bi-card .analysis-card-title span {
    color: rgba(45, 27, 18, .68);
    font-size: .75rem;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.bi-kpi-grid strong {
    color: var(--coffee);
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(1.65rem, 2.4vw, 2.35rem);
    line-height: 1;
}

.bi-kpi-grid small {
    color: rgba(45, 27, 18, .62);
    font-weight: 700;
}

.bi-tabs {
    align-items: center;
    background: #fff7eb;
    border: 1px solid rgba(145, 91, 48, .16);
    border-radius: 16px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 8px;
}

.bi-tab-button {
    background: transparent;
    border: 0;
    border-radius: 12px;
    color: rgba(45, 27, 18, .72);
    cursor: pointer;
    font-weight: 800;
    min-height: 42px;
    padding: 10px 14px;
    transition: background .2s ease, color .2s ease, transform .2s ease;
}

.bi-tab-button:hover,
.bi-tab-button:focus-visible {
    background: rgba(201, 111, 61, .12);
    color: var(--coffee);
    outline: none;
}

.bi-tab-button.is-active {
    background: var(--coffee);
    box-shadow: 0 12px 24px rgba(45, 27, 18, .16);
    color: #fffaf2;
}

.bi-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.bi-card[hidden] {
    display: none !important;
}

.bi-card {
    display: grid;
    gap: 12px;
    min-height: 280px;
    padding: 16px;
}

.bi-card-wide {
    grid-column: span 2;
}

.bi-chart {
    height: 220px;
    min-width: 0;
}

.bi-chart canvas {
    height: 220px !important;
    width: 100% !important;
}

.millaray-premium-dashboard .chart-card-large .bar-chart,
.millaray-premium-dashboard .bar-chart {
    display: block !important;
    height: 240px;
    min-height: 240px;
    width: 100%;
}

.millaray-premium-dashboard .bar-chart canvas {
    height: 240px !important;
    max-width: 100% !important;
    width: 100% !important;
}

.millaray-premium-dashboard .chart-card-large {
    align-content: stretch;
    display: flex !important;
    flex-direction: column;
    gap: 12px;
    min-height: 430px;
}

.millaray-premium-dashboard .intelligent-analysis-panel .analysis-header {
    order: 0 !important;
}

.millaray-premium-dashboard .intelligent-analysis-panel .charts-grid {
    order: 1 !important;
}

.millaray-premium-dashboard .chart-card-large .analysis-card-title {
    flex: 0 0 auto;
    order: 0;
}

.millaray-premium-dashboard #guests-bar-chart.bar-chart {
    display: block !important;
    flex: 1 1 360px;
    height: 360px !important;
    min-height: 360px !important;
    order: 1;
    padding: 8px 8px 0;
}

.millaray-premium-dashboard #guests-bar-chart canvas {
    display: block;
    height: 360px !important;
    min-height: 360px !important;
    width: 100% !important;
}

.bi-funnel {
    display: grid;
    gap: 12px;
}

.bi-funnel-row {
    align-items: center;
    display: grid;
    gap: 10px;
    grid-template-columns: 92px minmax(0, 1fr) 42px;
}

.bi-funnel-row span,
.bi-funnel-row strong {
    color: var(--coffee);
    font-weight: 800;
}

.bi-funnel-row div {
    background: #f0e3d1;
    border-radius: 999px;
    height: 14px;
    overflow: hidden;
}

.bi-funnel-row i {
    background: linear-gradient(90deg, var(--terracotta), var(--gold));
    border-radius: inherit;
    display: block;
    height: 100%;
}

.bi-annual-heatmap {
    display: grid;
    gap: 6px;
    grid-template-columns: repeat(12, minmax(0, 1fr));
}

.bi-annual-heatmap span {
    background: #efe2d0;
    border-radius: 8px;
    color: var(--coffee);
    display: grid;
    font-size: .72rem;
    gap: 2px;
    min-height: 42px;
    padding: 6px;
}

.bi-annual-heatmap span.medium {
    background: #ead3a8;
}

.bi-annual-heatmap span.high {
    background: #cf855b;
    color: #fffaf2;
}

.bi-profit-table {
    overflow-x: auto;
}

.bi-profit-table table {
    border-collapse: collapse;
    width: 100%;
}

.bi-profit-table th,
.bi-profit-table td {
    border-bottom: 1px solid rgba(45, 27, 18, .08);
    color: var(--coffee);
    padding: 10px;
    text-align: left;
    white-space: nowrap;
}

.bi-profit-table th {
    color: rgba(45, 27, 18, .62);
    font-size: .75rem;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.bi-prediction-copy {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.bi-prediction-copy p {
    background: #fffdf8;
    border: 1px solid rgba(45, 27, 18, .08);
    border-radius: 10px;
    color: rgba(45, 27, 18, .78);
    margin: 0;
    padding: 12px;
}

.bi-weekend-ranking {
    display: grid;
    gap: 10px;
}

.bi-weekend-ranking article {
    align-items: center;
    background: #fffdf8;
    border: 1px solid rgba(45, 27, 18, .08);
    border-radius: 10px;
    display: grid;
    gap: 10px;
    grid-template-columns: 1.2fr .8fr .8fr .8fr;
    padding: 12px;
}

.bi-weekend-ranking strong,
.bi-weekend-ranking span {
    color: var(--coffee);
    font-weight: 800;
}

.bi-occupancy-gauge {
    align-items: center;
    display: flex;
    justify-content: center;
    min-height: 220px;
}

.gauge-ring {
    align-items: center;
    background:
        radial-gradient(circle at center, #fff9f0 0 54%, transparent 55%),
        conic-gradient(var(--terracotta) calc(var(--value) * 1%), #eadfce 0);
    border-radius: 999px;
    display: flex;
    flex-direction: column;
    height: 176px;
    justify-content: center;
    width: 176px;
}

.gauge-ring strong {
    color: var(--coffee);
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 2.25rem;
    line-height: 1;
}

.gauge-ring span {
    color: rgba(45, 27, 18, .66);
    font-weight: 800;
}

.bi-mini-predictions {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.bi-mini-predictions article {
    background: #fffdf8;
    border: 1px solid rgba(45, 27, 18, .08);
    border-radius: 10px;
    display: grid;
    gap: 8px;
    padding: 14px;
}

.bi-mini-predictions span {
    color: rgba(45, 27, 18, .66);
    font-size: .75rem;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.bi-mini-predictions strong {
    color: var(--coffee);
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 1.35rem;
}

.bi-weekly-heatmap {
    display: grid;
    gap: 8px;
    grid-template-columns: 90px repeat(3, minmax(0, 1fr));
}

.bi-weekly-heatmap strong {
    color: var(--coffee);
    font-size: .82rem;
}

.bi-weekly-heatmap span {
    align-items: center;
    background: #efe2d0;
    border-radius: 9px;
    color: var(--coffee);
    display: flex;
    font-weight: 900;
    justify-content: center;
    min-height: 38px;
}

.bi-weekly-heatmap span.medium {
    background: #ead3a8;
}

.bi-weekly-heatmap span.high {
    background: #cf855b;
    color: #fffaf2;
}

.millaray-premium-dashboard .auth-panel {
    grid-template-columns: minmax(0, .8fr) minmax(280px, 1fr);
}

.millaray-premium-dashboard .reservations-list .preview-empty {
    min-height: 150px;
}

@media (max-width: 1180px) {
    .millaray-premium-dashboard.reservas-admin-page .admin-dashboard,
    .bi-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .millaray-premium-dashboard.reservas-admin-page .admin-dashboard {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .bi-filters,
    .bi-kpi-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 860px) {
    body.millaray-premium-dashboard.reservas-admin-page {
        max-width: 100vw;
        overflow-x: hidden;
    }

    .millaray-premium-dashboard.reservas-admin-page nav {
        align-items: center !important;
        border-radius: 0 !important;
        bottom: auto !important;
        flex-direction: row !important;
        gap: 12px !important;
        height: auto !important;
        min-height: 88px !important;
        overflow: visible !important;
        padding: 14px 18px !important;
        position: sticky !important;
        right: 0 !important;
        top: 0 !important;
        width: 100% !important;
    }

    .millaray-premium-dashboard .sidebar-brand {
        flex: 1 1 auto;
        min-width: 0;
    }

    .millaray-premium-dashboard .sidebar-mini-panel,
    .millaray-premium-dashboard .sidebar-user {
        display: none !important;
    }

    .millaray-premium-dashboard .nav-links {
        background: #2D1B12;
        left: 0;
        padding: 12px;
        position: absolute;
        right: 0;
        top: 100%;
        width: 100%;
    }

    .millaray-premium-dashboard #reservas.dashboard-shell,
    .millaray-premium-dashboard .dashboard-shell {
        margin-left: 0 !important;
        max-width: 100% !important;
        overflow-x: hidden;
        width: 100% !important;
    }

    .millaray-premium-dashboard .dashboard-canvas,
    .millaray-premium-dashboard .dashboard-topbar {
        padding-left: 16px;
        padding-right: 16px;
        width: 100%;
    }

    .millaray-premium-dashboard .dashboard-topbar {
        align-items: start;
        display: grid !important;
        gap: 18px;
        justify-content: stretch;
    }

    .millaray-premium-dashboard .dashboard-actions {
        display: grid;
        gap: 12px;
        justify-self: start;
        justify-items: center;
        max-width: 100%;
    }

    .millaray-premium-dashboard .dashboard-canvas > *,
    .millaray-premium-dashboard .dashboard-title,
    .millaray-premium-dashboard .dashboard-actions {
        max-width: calc(100vw - 32px) !important;
        min-width: 0 !important;
        width: calc(100vw - 32px) !important;
    }

    .millaray-premium-dashboard .dashboard-title h2 {
        font-size: 1.65rem;
        overflow-wrap: break-word;
        white-space: normal;
    }

    .millaray-premium-dashboard .millaray-hero-card {
        grid-template-columns: 1fr;
    }

    .millaray-premium-dashboard .hero-metrics-grid,
    .millaray-premium-dashboard.reservas-admin-page .admin-dashboard {
        grid-template-columns: 1fr;
    }

    .millaray-premium-dashboard.reservas-admin-page .admin-dashboard {
        grid-template-columns: 1fr !important;
    }

    .millaray-premium-dashboard .reservation-grid,
    .millaray-premium-dashboard .cabins-list,
    .bi-grid,
    .bi-filters,
    .bi-kpi-grid,
    .bi-prediction-copy,
    .millaray-premium-dashboard .auth-panel {
        grid-template-columns: 1fr;
    }

    .bi-card-wide {
        grid-column: span 1;
    }

    .bi-header {
        align-items: flex-start;
        flex-direction: column;
    }

    .bi-tabs {
        flex-wrap: nowrap;
        margin-left: -2px;
        overflow-x: auto;
        padding: 6px;
        scroll-snap-type: x proximity;
    }

    .bi-tab-button {
        flex: 0 0 auto;
        scroll-snap-align: start;
        white-space: nowrap;
    }

    .bi-annual-heatmap {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .bi-weekend-ranking article,
    .bi-mini-predictions {
        grid-template-columns: 1fr;
    }

    .bi-weekly-heatmap {
        grid-template-columns: 72px repeat(3, minmax(0, 1fr));
    }

    .millaray-premium-dashboard .chart-card-large {
        min-height: 400px;
    }

    .millaray-premium-dashboard #guests-bar-chart.bar-chart,
    .millaray-premium-dashboard #guests-bar-chart canvas {
        height: 320px !important;
        min-height: 320px !important;
    }

    .millaray-premium-dashboard .activity-grid article {
        grid-template-columns: 54px minmax(0, 1fr);
    }

    .millaray-premium-dashboard .activity-grid article p {
        grid-column: 1 / -1;
    }
}

/* Final premium dashboard overrides */
body.millaray-premium-dashboard.reservas-admin-page {
    background:
        radial-gradient(circle at 12% 0%, rgba(227, 194, 139, .18), transparent 28%),
        linear-gradient(180deg, #fbf7ef 0%, #f2eadf 52%, #efe6d8 100%) !important;
    color: #2d2118;
    font-family: Inter, Manrope, "Source Sans 3", Arial, sans-serif !important;
    line-height: 1.48;
}

.millaray-premium-dashboard h1,
.millaray-premium-dashboard h2,
.millaray-premium-dashboard h3,
.millaray-premium-dashboard .dashboard-title h2,
.millaray-premium-dashboard .hero-card-copy h1,
.millaray-premium-dashboard .panel-header h3,
.millaray-premium-dashboard .analysis-header h3 {
    color: #26170f;
    font-family: "Playfair Display", "Cormorant Garamond", Georgia, serif !important;
    font-weight: 600 !important;
    letter-spacing: 0 !important;
    line-height: 1.08;
    text-transform: none !important;
}

.millaray-premium-dashboard .dashboard-title h2 {
    font-size: clamp(2rem, 3vw, 3.15rem) !important;
    margin-bottom: 6px;
}

.millaray-premium-dashboard .dashboard-title p,
.millaray-premium-dashboard .panel-header p,
.millaray-premium-dashboard .analysis-header p {
    color: rgba(45, 33, 24, .68);
    font-size: .98rem;
    line-height: 1.55;
}

.millaray-premium-dashboard .eyebrow,
.millaray-premium-dashboard .panel-kicker,
.millaray-premium-dashboard .soft-pill,
.millaray-premium-dashboard .preview-pill {
    font-family: Inter, Manrope, Arial, sans-serif !important;
    font-size: .76rem !important;
    font-weight: 800 !important;
    letter-spacing: .045em !important;
    text-transform: none !important;
}

.millaray-premium-dashboard .dashboard-topbar {
    background: transparent !important;
    border: 0 !important;
    padding-bottom: 18px !important;
}

.millaray-premium-dashboard .dashboard-actions .preview-pill,
.millaray-premium-dashboard .dashboard-date {
    background: rgba(255, 253, 248, .78) !important;
    border: 1px solid rgba(92, 61, 39, .1) !important;
    box-shadow: 0 12px 24px rgba(58, 36, 23, .06) !important;
}

.millaray-premium-dashboard .millaray-hero-card {
    align-items: stretch !important;
    background: linear-gradient(115deg, rgba(45, 27, 18, .93) 0%, rgba(82, 54, 37, .82) 48%, rgba(201, 111, 61, .38) 100%) !important;
    border: 1px solid rgba(255, 249, 240, .38) !important;
    border-radius: 24px !important;
    box-shadow: 0 28px 70px rgba(45, 27, 18, .16) !important;
    color: #fffaf2;
    grid-template-columns: minmax(0, 1fr) minmax(340px, .72fr) !important;
    min-height: 360px;
    overflow: hidden;
    padding: 0 !important;
}

.millaray-premium-dashboard .hero-card-copy {
    align-content: center;
    display: grid;
    gap: 22px;
    padding: clamp(28px, 4vw, 48px) !important;
    position: relative;
    z-index: 1;
}

.millaray-premium-dashboard .hero-card-copy h1 {
    color: #fffaf2 !important;
    font-size: clamp(2.5rem, 5vw, 4.8rem) !important;
    max-width: 680px;
}

.millaray-premium-dashboard .hero-card-copy .soft-pill {
    background: rgba(255, 250, 242, .12) !important;
    border: 1px solid rgba(255, 250, 242, .18) !important;
    color: #f4d8aa !important;
    justify-self: start;
}

.millaray-premium-dashboard .hero-metrics-grid {
    gap: 12px !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.millaray-premium-dashboard .hero-metrics-grid div {
    background: rgba(255, 250, 242, .12) !important;
    border: 1px solid rgba(255, 250, 242, .16) !important;
    border-radius: 16px !important;
    box-shadow: none !important;
    min-height: 104px;
    padding: 16px !important;
}

.millaray-premium-dashboard .hero-metrics-grid span {
    color: rgba(255, 250, 242, .74) !important;
    font-size: .78rem;
    font-weight: 750;
}

.millaray-premium-dashboard .hero-metrics-grid strong {
    color: #fffaf2 !important;
    font-family: Inter, Manrope, Arial, sans-serif !important;
    font-size: clamp(1.75rem, 3vw, 2.45rem) !important;
    font-weight: 850;
}

.millaray-premium-dashboard .hero-illustration {
    border-radius: 0 !important;
    min-height: 360px;
    position: relative !important;
}

.millaray-premium-dashboard .hero-illustration::after {
    background: linear-gradient(90deg, rgba(45, 27, 18, .42), rgba(45, 27, 18, .04));
    content: "";
    inset: 0;
    position: absolute;
}

.millaray-premium-dashboard .hero-illustration img {
    height: 100% !important;
    object-fit: cover;
    width: 100%;
}

.millaray-premium-dashboard .hero-actions .btn-primary,
.millaray-premium-dashboard .dashboard-new-booking {
    border-radius: 14px !important;
    box-shadow: 0 18px 38px rgba(201, 111, 61, .22) !important;
    font-weight: 850;
}

.millaray-premium-dashboard .dashboard-canvas {
    gap: 26px !important;
}

.millaray-premium-dashboard.reservas-admin-page .admin-dashboard {
    gap: 18px !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card {
    background: linear-gradient(145deg, rgba(255, 253, 248, .98), rgba(249, 239, 224, .9)) !important;
    border-color: rgba(92, 61, 39, .12) !important;
    border-radius: 18px !important;
    box-shadow: 0 18px 45px rgba(45, 27, 18, .075) !important;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card > span,
.bi-kpi-grid span,
.bi-card .analysis-card-title span {
    letter-spacing: .055em !important;
    text-transform: none !important;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card > strong {
    font-size: clamp(2rem, 2.55vw, 2.65rem) !important;
}

.millaray-premium-dashboard .intelligent-analysis-panel,
.millaray-premium-dashboard .business-intelligence {
    background:
        linear-gradient(180deg, rgba(255, 253, 248, .96), rgba(251, 244, 234, .92)) !important;
    border: 1px solid rgba(92, 61, 39, .1) !important;
    border-radius: 24px !important;
    box-shadow: 0 24px 60px rgba(45, 27, 18, .08) !important;
    padding: clamp(22px, 3vw, 34px) !important;
}

.millaray-premium-dashboard .business-intelligence {
    background:
        linear-gradient(135deg, rgba(255, 253, 248, .98), rgba(245, 235, 220, .96)),
        radial-gradient(circle at 100% 0%, rgba(127, 147, 99, .18), transparent 32%) !important;
}

.bi-header {
    border-bottom: 1px solid rgba(45, 27, 18, .08);
    padding-bottom: 16px;
}

.bi-header h3,
.millaray-premium-dashboard .analysis-header h3 {
    font-size: clamp(1.7rem, 2.5vw, 2.45rem) !important;
}

.bi-tabs {
    background: rgba(255, 250, 242, .8) !important;
    border: 1px solid rgba(92, 61, 39, .1) !important;
    border-radius: 18px !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .7);
}

.bi-tab-button {
    border-radius: 13px !important;
    color: rgba(45, 33, 24, .68) !important;
    font-size: .86rem;
    font-weight: 800 !important;
}

.bi-tab-button.is-active {
    background: linear-gradient(135deg, #2d1b12, #76533a) !important;
    box-shadow: 0 14px 28px rgba(45, 27, 18, .18) !important;
    color: #fffaf2 !important;
}

.bi-grid {
    gap: 18px !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.bi-card,
.millaray-premium-dashboard .analysis-card,
.millaray-premium-dashboard .ai-insight-card {
    background: rgba(255, 253, 248, .92) !important;
    border: 1px solid rgba(92, 61, 39, .1) !important;
    border-radius: 18px !important;
    box-shadow: 0 18px 38px rgba(45, 27, 18, .065) !important;
}

.bi-card {
    min-height: 330px;
    padding: 18px !important;
}

.bi-card-wide {
    grid-column: span 2;
}

.analysis-card-title {
    align-items: start !important;
    gap: 14px;
}

.analysis-card-title strong,
.bi-kpi-grid strong {
    color: #26170f !important;
    font-family: Inter, Manrope, Arial, sans-serif !important;
    font-weight: 850 !important;
}

.bi-chart,
.bi-chart canvas {
    height: 250px !important;
}

.bi-funnel-row,
.bi-weekend-ranking article,
.bi-mini-predictions article,
.bi-prediction-copy p {
    background: rgba(255, 250, 242, .78) !important;
    border: 1px solid rgba(92, 61, 39, .08);
    border-radius: 14px !important;
}

.bi-annual-heatmap span,
.bi-weekly-heatmap span {
    border: 1px solid rgba(92, 61, 39, .08);
    box-shadow: inset 0 -10px 16px rgba(45, 27, 18, .035);
}

.bi-profit-table table {
    font-size: .86rem;
}

.bi-profit-table th {
    color: rgba(45, 33, 24, .58) !important;
    font-weight: 850;
    text-transform: none;
}

.bi-table-value {
    display: block;
    font-weight: 850;
    margin-bottom: 6px;
}

.bi-mini-bar {
    background: rgba(201, 111, 61, .12);
    border-radius: 999px;
    display: block;
    height: 6px;
    overflow: hidden;
    width: 86px;
}

.bi-mini-bar i {
    background: linear-gradient(90deg, #c96f3d, #e3c28b);
    display: block;
    height: 100%;
}

.bi-mini-bar.is-olive {
    background: rgba(127, 147, 99, .14);
}

.bi-mini-bar.is-olive i {
    background: linear-gradient(90deg, #7f9363, #d7c47d);
}

.millaray-premium-dashboard #guests-bar-chart.bar-chart {
    background: linear-gradient(180deg, rgba(255, 250, 242, .66), rgba(255, 250, 242, .24)) !important;
    border: 1px solid rgba(92, 61, 39, .08);
    border-radius: 16px;
    padding: 14px 16px 4px !important;
}

@media (max-width: 1180px) {
    .millaray-premium-dashboard.reservas-admin-page .admin-dashboard,
    .bi-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 860px) {
    .millaray-premium-dashboard .millaray-hero-card,
    .millaray-premium-dashboard .hero-metrics-grid,
    .millaray-premium-dashboard.reservas-admin-page .admin-dashboard,
    .bi-grid {
        grid-template-columns: 1fr !important;
    }

    .bi-card-wide {
        grid-column: span 1;
    }
}

/* Studio Tableau BI board */
.business-intelligence .bi-tabs,
.business-intelligence > .bi-grid {
    display: none !important;
}

.business-intelligence .bi-kpi-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.bi-studio-board {
    background:
        linear-gradient(180deg, rgba(255, 253, 248, .96), rgba(250, 246, 239, .98)),
        radial-gradient(circle at 50% 0%, rgba(227, 194, 139, .18), transparent 32%);
    border: 1px solid rgba(45, 27, 18, .12);
    border-radius: 18px;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .7);
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    padding: 14px;
}

.bi-studio-panel {
    background: rgba(255, 255, 255, .62);
    border: 1px solid rgba(45, 27, 18, .1);
    border-radius: 8px;
    box-shadow: 0 8px 18px rgba(45, 27, 18, .035);
    display: grid;
    gap: 8px;
    grid-column: span 3;
    min-height: 178px;
    overflow: hidden;
    padding: 10px;
}

.bi-studio-panel.bi-studio-wide {
    grid-column: span 6;
}

.bi-studio-summary {
    grid-column: span 3;
    grid-row: span 2;
    min-height: 366px;
}

.bi-studio-title {
    align-items: start;
    display: flex;
    gap: 8px;
    justify-content: space-between;
    min-height: 28px;
}

.bi-studio-title span {
    color: #2d1b12;
    font-size: .72rem;
    font-weight: 900;
    line-height: 1.15;
}

.bi-studio-title strong {
    color: rgba(45, 27, 18, .56);
    font-size: .64rem;
    font-weight: 850;
    line-height: 1.15;
    text-align: right;
}

.bi-studio-chart {
    height: 132px;
    min-width: 0;
}

.bi-studio-chart canvas {
    height: 132px !important;
    width: 100% !important;
}

.bi-studio-wide .bi-studio-chart {
    height: 150px;
}

.bi-studio-wide .bi-studio-chart canvas {
    height: 150px !important;
}

.bi-studio-donut {
    height: 146px;
}

.bi-studio-donut canvas {
    height: 146px !important;
}

.bi-studio-summary-grid {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.bi-studio-summary-grid div {
    background: rgba(255, 250, 242, .78);
    border: 1px solid rgba(45, 27, 18, .08);
    border-radius: 8px;
    min-height: 68px;
    padding: 9px;
}

.bi-studio-summary-grid span {
    color: rgba(45, 27, 18, .58);
    display: block;
    font-size: .66rem;
    font-weight: 850;
    margin-bottom: 4px;
}

.bi-studio-summary-grid strong {
    color: #2d1b12;
    display: block;
    font-family: Inter, Manrope, Arial, sans-serif;
    font-size: clamp(1rem, 1.5vw, 1.42rem);
    font-weight: 900;
    line-height: 1.05;
    overflow-wrap: anywhere;
}

.business-intelligence {
    max-width: 100%;
}

@media (max-width: 1180px) {
    .bi-studio-board {
        grid-template-columns: repeat(6, minmax(0, 1fr));
    }

    .bi-studio-panel,
    .bi-studio-panel.bi-studio-wide,
    .bi-studio-summary {
        grid-column: span 3;
    }
}

@media (max-width: 860px) {
    .business-intelligence .bi-kpi-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .bi-studio-board {
        grid-template-columns: 1fr;
    }

    .bi-studio-panel,
    .bi-studio-panel.bi-studio-wide,
    .bi-studio-summary {
        grid-column: span 1;
        grid-row: span 1;
        min-height: 220px;
    }

    .bi-studio-chart,
    .bi-studio-chart canvas,
    .bi-studio-wide .bi-studio-chart,
    .bi-studio-wide .bi-studio-chart canvas {
        height: 170px !important;
    }
}

/* Final BI-first dashboard hierarchy */
body.millaray-premium-dashboard.reservas-admin-page {
    background: #F7F3EB !important;
}

.millaray-premium-dashboard .dashboard-canvas {
    display: flex !important;
    flex-direction: column;
}

.millaray-premium-dashboard .millaray-hero-card { order: 1; }
.millaray-premium-dashboard .admin-dashboard { order: 2; }
.millaray-premium-dashboard .intelligent-analysis-panel { order: 3; }
.millaray-premium-dashboard .business-intelligence { order: 4; }
.millaray-premium-dashboard .reservation-grid { order: 5; }
.millaray-premium-dashboard #quick-analysis-panel { order: 6; }
.millaray-premium-dashboard .auth-panel { order: 7; }
.millaray-premium-dashboard #reservations-log { order: 8; }

.millaray-premium-dashboard .business-intelligence {
    background: #FFF9F0 !important;
    border-color: rgba(91, 58, 39, .18) !important;
}

.business-intelligence > .bi-studio-board:not(.bi-tableau-board) {
    display: none !important;
}

.business-intelligence .bi-tableau-board {
    background: #fffdf8;
    border-color: rgba(91, 58, 39, .16);
    display: grid !important;
    gap: 12px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.business-intelligence .bi-tableau-board .bi-studio-panel {
    grid-column: span 1;
    min-height: 238px;
}

.bi-studio-funnel {
    display: grid;
    gap: 10px;
    height: 100%;
    align-content: center;
}

.bi-studio-funnel-row {
    align-items: center;
    display: grid;
    gap: 8px;
    grid-template-columns: 88px minmax(0, 1fr) 34px;
}

.bi-studio-funnel-row span,
.bi-studio-funnel-row strong {
    color: #342217;
    font-size: .72rem;
    font-weight: 850;
}

.bi-studio-funnel-row i {
    background: linear-gradient(90deg, #7F9363, #C96F3D);
    border-radius: 999px;
    display: block;
    height: 12px;
}

.bi-studio-heatmap {
    align-content: start;
    display: grid;
    gap: 4px;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    padding-top: 8px;
}

.bi-studio-heatmap span {
    aspect-ratio: 1;
    background: #C96F3D;
    border-radius: 3px;
    box-shadow: inset 0 -5px 8px rgba(45, 27, 18, .08);
}

.millaray-premium-dashboard.reservas-admin-page .metric-variation.is-up {
    background: rgba(127, 147, 99, .16) !important;
    color: #52653e !important;
}

.millaray-premium-dashboard.reservas-admin-page .metric-variation.is-down {
    background: rgba(201, 111, 61, .16) !important;
    color: #A85833 !important;
}

.metric-sparkline {
    height: 36px;
    margin-top: auto;
    width: 100%;
}

.metric-sparkline svg {
    display: block;
    height: 36px;
    width: 100%;
}

.metric-sparkline polyline {
    stroke: #7F9363;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 4;
}

.metric-sparkline.is-down polyline {
    stroke: #C96F3D;
}

.millaray-premium-dashboard .reservation-grid {
    align-items: start;
    grid-template-columns: minmax(0, 1.1fr) minmax(320px, .9fr) !important;
}

.millaray-premium-dashboard .cabins-list {
    gap: 10px !important;
    grid-template-columns: 1fr !important;
}

.millaray-premium-dashboard .cabin-card {
    align-items: center !important;
    display: grid !important;
    gap: 12px !important;
    grid-template-columns: 116px minmax(0, 1fr) !important;
    min-height: 0 !important;
    padding: 12px !important;
}

.millaray-premium-dashboard .cabin-thumb {
    aspect-ratio: 4 / 3 !important;
    border-radius: 8px !important;
    height: 92px !important;
    object-fit: cover;
    width: 116px !important;
}

.millaray-premium-dashboard .cabin-card-copy {
    gap: 7px !important;
}

.millaray-premium-dashboard .cabin-card-copy ul,
.millaray-premium-dashboard .cabin-card-copy p:nth-of-type(1) {
    display: none !important;
}

.millaray-premium-dashboard .cabin-meta {
    gap: 6px !important;
}

.millaray-premium-dashboard .cabin-meta span {
    padding: 5px 7px !important;
}

.millaray-premium-dashboard .activity-grid {
    max-height: 356px;
    overflow: hidden;
}

.millaray-premium-dashboard .activity-grid article:nth-child(n + 5) {
    display: none !important;
}

@media (max-width: 860px) {
    .business-intelligence .bi-tableau-board,
    .millaray-premium-dashboard .reservation-grid {
        grid-template-columns: 1fr !important;
    }

    .millaray-premium-dashboard .cabin-card {
        grid-template-columns: 96px minmax(0, 1fr) !important;
    }

    .millaray-premium-dashboard .cabin-thumb {
        height: 82px !important;
        width: 96px !important;
    }
}

/* Boutique BI polish */
.millaray-premium-dashboard {
    --bg: #F7F1E8;
    --card: #FFFDF8;
    --espresso: #2A1811;
    --coffee: #4A2F23;
    --copper: #B8794A;
    --soft-copper: #D9A06F;
    --sand: #EAD8BD;
    --sage: #7F9363;
    --muted: #8B7A6B;
}

body.millaray-premium-dashboard.reservas-admin-page {
    background:
        radial-gradient(circle at 18% 0%, rgba(234, 216, 189, .42), transparent 30%),
        linear-gradient(180deg, var(--bg) 0%, #F4EBDD 100%) !important;
    color: var(--coffee);
}

.millaray-premium-dashboard.reservas-admin-page nav {
    background: linear-gradient(180deg, #2A1811 0%, #1F110C 100%) !important;
    border-right: 1px solid rgba(234, 216, 189, .12) !important;
    box-shadow: 10px 0 28px rgba(42, 24, 17, .08) !important;
    gap: 16px !important;
    max-width: 220px !important;
    padding: 22px 16px !important;
    width: 220px !important;
}

.millaray-premium-dashboard .dashboard-shell,
.millaray-premium-dashboard #reservas.dashboard-shell {
    margin-left: 220px !important;
}

.millaray-premium-dashboard .sidebar-brand {
    gap: 10px !important;
}

.millaray-premium-dashboard .sidebar-brand img {
    height: 38px !important;
}

.millaray-premium-dashboard .sidebar-brand span {
    color: rgba(255, 253, 248, .58) !important;
    font-size: .68rem !important;
}

.millaray-premium-dashboard .sidebar-brand strong {
    color: #FFFDF8 !important;
    font-size: 1rem !important;
}

.millaray-premium-dashboard .nav-links {
    gap: 6px !important;
}

.millaray-premium-dashboard .nav-links a {
    background: transparent !important;
    border: 1px solid transparent !important;
    border-radius: 12px !important;
    color: rgba(255, 253, 248, .66) !important;
    font-size: .82rem !important;
    font-weight: 650 !important;
    padding: 9px 10px !important;
    transition: background .18s ease, border-color .18s ease, color .18s ease, transform .18s ease;
}

.millaray-premium-dashboard .nav-links a:hover {
    background: rgba(255, 253, 248, .07) !important;
    border-color: rgba(217, 160, 111, .18) !important;
    color: #FFFDF8 !important;
    transform: translateX(2px);
}

.millaray-premium-dashboard .nav-links a.is-active {
    background: linear-gradient(135deg, rgba(217, 160, 111, .22), rgba(234, 216, 189, .08)) !important;
    border-color: rgba(217, 160, 111, .32) !important;
    color: #F6D4AC !important;
}

.millaray-premium-dashboard .nav-icon {
    color: rgba(217, 160, 111, .7) !important;
    font-size: .82rem !important;
    opacity: .8;
}

.millaray-premium-dashboard .sidebar-art {
    opacity: .38 !important;
}

.millaray-premium-dashboard .sidebar-mini-panel,
.millaray-premium-dashboard .sidebar-user {
    background: rgba(255, 253, 248, .055) !important;
    border-color: rgba(234, 216, 189, .12) !important;
    box-shadow: none !important;
}

.millaray-premium-dashboard .btn-primary,
.millaray-premium-dashboard .dashboard-new-booking,
.millaray-premium-dashboard .hero-actions .btn-primary {
    background: linear-gradient(135deg, var(--soft-copper), var(--copper)) !important;
    border: 1px solid rgba(74, 47, 35, .08) !important;
    box-shadow: 0 14px 30px rgba(184, 121, 74, .18) !important;
    color: #2A1811 !important;
    font-weight: 800 !important;
}

.millaray-premium-dashboard .btn-primary:hover,
.millaray-premium-dashboard .dashboard-new-booking:hover {
    filter: saturate(.96) brightness(1.02);
    transform: translateY(-1px);
}

.millaray-premium-dashboard .millaray-hero-card {
    background: linear-gradient(120deg, rgba(42, 24, 17, .94), rgba(74, 47, 35, .82) 58%, rgba(127, 147, 99, .32)) !important;
}

.millaray-premium-dashboard .dashboard-canvas {
    gap: 22px !important;
}

.millaray-premium-dashboard .chart-card-large {
    min-height: 340px !important;
}

.millaray-premium-dashboard #guests-bar-chart.bar-chart,
.millaray-premium-dashboard #guests-bar-chart canvas {
    height: 300px !important;
    max-height: 300px !important;
    min-height: 260px !important;
}

.millaray-premium-dashboard #guests-bar-chart.bar-chart {
    background: linear-gradient(180deg, rgba(255, 253, 248, .86), rgba(234, 216, 189, .24)) !important;
    border-color: rgba(74, 47, 35, .08) !important;
}

.millaray-premium-dashboard .business-intelligence {
    background: #FFF9F0 !important;
    box-shadow: 0 18px 42px rgba(42, 24, 17, .055) !important;
}

.business-intelligence .bi-kpi-grid article,
.business-intelligence .bi-tableau-board .bi-studio-panel {
    background: var(--card) !important;
    border: 1px solid rgba(74, 47, 35, .09) !important;
    border-radius: 18px !important;
    box-shadow: 0 12px 26px rgba(42, 24, 17, .045) !important;
}

.business-intelligence .bi-tableau-board {
    background: rgba(255, 253, 248, .58) !important;
    border-color: rgba(74, 47, 35, .08) !important;
    gap: 14px !important;
    padding: 14px !important;
}

.business-intelligence .bi-tableau-board .bi-studio-panel {
    min-height: 216px !important;
    padding: 14px !important;
    transition: transform .18s ease, box-shadow .18s ease;
}

.business-intelligence .bi-tableau-board .bi-studio-panel:hover {
    box-shadow: 0 18px 34px rgba(42, 24, 17, .07) !important;
    transform: translateY(-2px);
}

.bi-studio-title span {
    color: var(--coffee) !important;
    font-size: .76rem !important;
    font-weight: 760 !important;
}

.bi-studio-title strong {
    color: var(--copper) !important;
    font-size: .72rem !important;
    font-weight: 780 !important;
}

.bi-studio-chart,
.bi-studio-chart canvas {
    height: 138px !important;
}

.bi-studio-donut,
.bi-studio-donut canvas {
    height: 138px !important;
}

.bi-studio-funnel-row {
    grid-template-columns: 96px minmax(0, 1fr) 38px;
}

.bi-studio-funnel-row span,
.bi-studio-funnel-row strong {
    color: var(--coffee);
    font-weight: 720;
}

.bi-studio-funnel-row i {
    background: linear-gradient(90deg, var(--sage), var(--soft-copper));
    height: 10px;
}

.bi-studio-heatmap {
    grid-template-columns: repeat(14, minmax(0, 1fr));
}

.bi-studio-heatmap span {
    background: linear-gradient(135deg, var(--sage), var(--soft-copper));
    border-radius: 4px;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card {
    background: rgba(255, 253, 248, .9) !important;
    border-color: rgba(74, 47, 35, .09) !important;
    box-shadow: 0 12px 28px rgba(42, 24, 17, .05) !important;
}

.metric-sparkline polyline {
    stroke: var(--sage);
    stroke-width: 3;
}

.metric-sparkline.is-down polyline {
    stroke: var(--copper);
}

@media (max-width: 860px) {
    .millaray-premium-dashboard.reservas-admin-page nav {
        max-width: none !important;
        width: 100% !important;
    }

    .millaray-premium-dashboard .dashboard-shell,
    .millaray-premium-dashboard #reservas.dashboard-shell {
        margin-left: 0 !important;
    }
}

.millaray-premium-dashboard .dashboard-canvas {
    display: flex !important;
    flex-direction: column !important;
}

.millaray-premium-dashboard .dashboard-canvas > .millaray-hero-card { order: 1 !important; }
.millaray-premium-dashboard .dashboard-canvas > .admin-dashboard { order: 2 !important; }
.millaray-premium-dashboard .dashboard-canvas > .intelligent-analysis-panel { order: 3 !important; }
.millaray-premium-dashboard .dashboard-canvas > .business-intelligence { order: 4 !important; }
.millaray-premium-dashboard .dashboard-canvas > .reservation-grid { order: 5 !important; }
.millaray-premium-dashboard .dashboard-canvas > #quick-analysis-panel { order: 6 !important; }
.millaray-premium-dashboard .dashboard-canvas > .auth-panel { order: 7 !important; }
.millaray-premium-dashboard .dashboard-canvas > #reservations-log { order: 8 !important; }

.bi-legacy-board {
    display: none !important;
}

/* Boutique executive dashboard refactor */
.millaray-premium-dashboard {
    --millaray-cream: #fbf7ef;
    --millaray-paper: #fffdf8;
    --millaray-sand: #e8d7bd;
    --millaray-espresso: #24150f;
    --millaray-chocolate: #4a3125;
    --millaray-olive: #7b8761;
    --millaray-terracotta: #b87855;
    --millaray-muted: #827265;
}

body.millaray-premium-dashboard.reservas-admin-page {
    background: linear-gradient(180deg, #fbf7ef 0%, #f4ebdc 100%) !important;
    color: var(--millaray-chocolate) !important;
}

.millaray-premium-dashboard.reservas-admin-page nav {
    background: #24150f !important;
    border-right: 1px solid rgba(232, 215, 189, .12) !important;
    box-shadow: 6px 0 18px rgba(36, 21, 15, .06) !important;
    gap: 12px !important;
    max-width: 176px !important;
    padding: 18px 12px !important;
    width: 176px !important;
}

.millaray-premium-dashboard .dashboard-shell,
.millaray-premium-dashboard #reservas.dashboard-shell {
    margin-left: 176px !important;
    padding-left: clamp(24px, 4vw, 56px) !important;
    padding-right: clamp(24px, 4vw, 56px) !important;
}

.millaray-premium-dashboard .sidebar-brand {
    gap: 8px !important;
}

.millaray-premium-dashboard .sidebar-brand img {
    height: 30px !important;
}

.millaray-premium-dashboard .sidebar-brand span {
    font-size: .62rem !important;
}

.millaray-premium-dashboard .sidebar-brand strong {
    font-size: .88rem !important;
}

.millaray-premium-dashboard .nav-links {
    gap: 4px !important;
}

.millaray-premium-dashboard .nav-links a {
    border-radius: 9px !important;
    color: rgba(255, 253, 248, .62) !important;
    font-size: .76rem !important;
    font-weight: 620 !important;
    padding: 7px 8px !important;
}

.millaray-premium-dashboard .nav-links a.is-active {
    background: rgba(232, 215, 189, .1) !important;
    border-color: rgba(232, 215, 189, .14) !important;
    color: #fff7eb !important;
}

.millaray-premium-dashboard .nav-links a:hover {
    background: rgba(255, 253, 248, .06) !important;
    transform: none !important;
}

.millaray-premium-dashboard .nav-icon {
    font-size: .68rem !important;
    opacity: .56 !important;
}

.millaray-premium-dashboard .sidebar-art {
    display: none !important;
}

.millaray-premium-dashboard .sidebar-mini-panel,
.millaray-premium-dashboard .sidebar-user {
    background: rgba(255, 253, 248, .04) !important;
    border-color: rgba(232, 215, 189, .1) !important;
    box-shadow: none !important;
    padding: 10px !important;
}

.millaray-premium-dashboard .dashboard-topbar {
    padding: 26px 0 12px !important;
}

.millaray-premium-dashboard .dashboard-title h2 {
    font-size: clamp(1.8rem, 2.7vw, 2.7rem) !important;
}

.millaray-premium-dashboard .dashboard-title p {
    max-width: 54ch;
}

.millaray-premium-dashboard .dashboard-canvas {
    gap: 16px !important;
}

.millaray-premium-dashboard .dashboard-canvas > .millaray-hero-card { order: 1 !important; }
.millaray-premium-dashboard .dashboard-canvas > .admin-dashboard { order: 2 !important; }
.millaray-premium-dashboard .dashboard-canvas > #reservations-log { order: 3 !important; }
.millaray-premium-dashboard .dashboard-canvas > .reservation-grid { order: 4 !important; }
.millaray-premium-dashboard .dashboard-canvas > #quick-analysis-panel { order: 5 !important; }
.millaray-premium-dashboard .dashboard-canvas > .intelligent-analysis-panel { order: 6 !important; }
.millaray-premium-dashboard .dashboard-canvas > .auth-panel { order: 7 !important; }
.millaray-premium-dashboard .dashboard-canvas > .business-intelligence { order: 8 !important; }

.millaray-premium-dashboard .millaray-hero-card {
    background: var(--millaray-paper) !important;
    border: 1px solid rgba(74, 49, 37, .09) !important;
    border-radius: 14px !important;
    box-shadow: 0 12px 30px rgba(36, 21, 15, .055) !important;
    color: var(--millaray-chocolate) !important;
    grid-template-columns: minmax(0, 1.12fr) minmax(240px, .54fr) !important;
    min-height: 210px !important;
}

.millaray-premium-dashboard .hero-card-copy {
    gap: 12px !important;
    padding: clamp(20px, 2.7vw, 30px) !important;
}

.millaray-premium-dashboard .hero-card-copy h1 {
    color: var(--millaray-espresso) !important;
    font-size: clamp(2rem, 3.5vw, 3.25rem) !important;
}

.millaray-premium-dashboard .hero-card-copy p {
    color: var(--millaray-muted) !important;
    margin: -4px 0 2px;
    max-width: 52ch;
}

.millaray-premium-dashboard .hero-metrics-grid {
    gap: 8px !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.millaray-premium-dashboard .hero-metrics-grid div {
    background: #f7efe4 !important;
    border: 1px solid rgba(74, 49, 37, .08) !important;
    border-radius: 10px !important;
    min-height: 70px !important;
    padding: 11px 12px !important;
}

.millaray-premium-dashboard .hero-metrics-grid span {
    color: var(--millaray-muted) !important;
    font-size: .68rem !important;
}

.millaray-premium-dashboard .hero-metrics-grid strong {
    color: var(--millaray-espresso) !important;
    font-size: clamp(1.28rem, 2vw, 1.85rem) !important;
}

.millaray-premium-dashboard .hero-actions {
    font-size: .86rem !important;
}

.millaray-premium-dashboard .hero-illustration {
    min-height: 210px !important;
}

.millaray-premium-dashboard .hero-illustration::after {
    background: linear-gradient(90deg, rgba(255,253,248,.08), rgba(36,21,15,.18)) !important;
}

.millaray-premium-dashboard .btn-primary,
.millaray-premium-dashboard .dashboard-new-booking,
.millaray-premium-dashboard .hero-actions .btn-primary {
    background: #b87855 !important;
    border: 1px solid rgba(74, 49, 37, .1) !important;
    border-radius: 9px !important;
    box-shadow: 0 8px 18px rgba(184, 120, 85, .14) !important;
    color: #fffdf8 !important;
}

.millaray-premium-dashboard.reservas-admin-page .admin-dashboard {
    display: grid !important;
    gap: 10px !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.millaray-premium-dashboard .metric-card-guests,
.millaray-premium-dashboard .metric-card-active {
    display: none !important;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card {
    background: var(--millaray-paper) !important;
    border: 1px solid rgba(74, 49, 37, .08) !important;
    border-radius: 12px !important;
    box-shadow: none !important;
    min-height: 128px !important;
    padding: 16px !important;
}

.millaray-premium-dashboard.reservas-admin-page .metric-card > strong {
    color: var(--millaray-espresso) !important;
    font-size: clamp(1.55rem, 2.15vw, 2.05rem) !important;
}

.millaray-premium-dashboard .metric-card-cabin > span {
    font-size: 0 !important;
}

.millaray-premium-dashboard .metric-card-cabin > span::after {
    content: "Ocupacion";
    font-size: .76rem;
}

.millaray-premium-dashboard .metric-variation,
.millaray-premium-dashboard .metric-sparkline {
    display: none !important;
}

.millaray-premium-dashboard .reservations-panel,
.millaray-premium-dashboard .cabins-panel,
.millaray-premium-dashboard .activity-panel,
.millaray-premium-dashboard .dashboard-quick-panel,
.millaray-premium-dashboard .intelligent-analysis-panel,
.millaray-premium-dashboard .auth-panel {
    background: var(--millaray-paper) !important;
    border: 1px solid rgba(74, 49, 37, .08) !important;
    border-radius: 14px !important;
    box-shadow: 0 10px 24px rgba(36, 21, 15, .045) !important;
    padding: clamp(18px, 2.4vw, 26px) !important;
}

.millaray-premium-dashboard .reservations-list {
    display: grid !important;
    gap: 0 !important;
    position: relative;
}

.millaray-premium-dashboard .reservations-list::before {
    background: rgba(123, 135, 97, .18);
    bottom: 18px;
    content: "";
    left: 7px;
    position: absolute;
    top: 18px;
    width: 1px;
}

.millaray-premium-dashboard .reservation-card {
    align-items: center !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    display: grid !important;
    gap: 14px !important;
    grid-template-columns: 16px minmax(0, 1fr) auto !important;
    padding: 12px 0 12px 0 !important;
}

.millaray-premium-dashboard .reservation-timeline-dot {
    background: var(--millaray-olive);
    border: 3px solid var(--millaray-paper);
    border-radius: 999px;
    box-shadow: 0 0 0 1px rgba(123, 135, 97, .28);
    height: 11px;
    position: relative;
    width: 11px;
    z-index: 1;
}

.millaray-premium-dashboard .reservation-card h4 {
    color: var(--millaray-espresso) !important;
    font-family: Inter, Arial, sans-serif !important;
    font-size: .98rem !important;
    margin: 0 0 6px !important;
}

.millaray-premium-dashboard .reservation-meta {
    display: flex !important;
    flex-wrap: wrap;
    gap: 7px !important;
}

.millaray-premium-dashboard .reservation-meta span {
    background: #f7efe4 !important;
    border: 1px solid rgba(74, 49, 37, .07) !important;
    border-radius: 999px !important;
    color: var(--millaray-muted) !important;
    font-size: .72rem !important;
    padding: 5px 8px !important;
}

.millaray-premium-dashboard .reservation-meta .reservation-status {
    background: rgba(123, 135, 97, .13) !important;
    color: #586345 !important;
}

.millaray-premium-dashboard .reservation-card button {
    border-radius: 8px !important;
    padding: 7px 10px !important;
}

.millaray-premium-dashboard .reservation-grid {
    gap: 14px !important;
    grid-template-columns: minmax(0, .95fr) minmax(300px, .72fr) !important;
    padding: 0 !important;
}

.millaray-premium-dashboard .activity-grid {
    gap: 0 !important;
    max-height: none !important;
}

.millaray-premium-dashboard .activity-grid article {
    background: transparent !important;
    border: 0 !important;
    border-bottom: 1px solid rgba(74, 49, 37, .08) !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    display: grid !important;
    grid-template-columns: 52px minmax(0, 1fr) !important;
    padding: 11px 0 !important;
}

.millaray-premium-dashboard .activity-grid article:last-child {
    border-bottom: 0 !important;
}

.millaray-premium-dashboard .activity-grid time {
    color: var(--millaray-terracotta) !important;
    font-size: .72rem !important;
    grid-row: span 2;
}

.millaray-premium-dashboard .activity-grid strong {
    color: var(--millaray-espresso) !important;
    font-size: .88rem !important;
}

.millaray-premium-dashboard .activity-grid p {
    color: var(--millaray-muted) !important;
    font-size: .78rem !important;
}

.millaray-premium-dashboard .quick-analysis-list {
    display: grid !important;
    gap: 8px !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.millaray-premium-dashboard .quick-analysis-list p {
    background: #f7efe4 !important;
    border: 1px solid rgba(74, 49, 37, .07) !important;
    border-radius: 10px !important;
    color: var(--millaray-chocolate) !important;
    font-size: .84rem !important;
    margin: 0 !important;
    padding: 12px !important;
}

.millaray-premium-dashboard .charts-grid {
    gap: 12px !important;
    grid-template-columns: minmax(0, 1fr) minmax(260px, .52fr) !important;
}

.millaray-premium-dashboard .chart-card-large {
    min-height: 220px !important;
}

.millaray-premium-dashboard .chart-card-large .bar-chart,
.millaray-premium-dashboard #guests-bar-chart.bar-chart,
.millaray-premium-dashboard #guests-bar-chart canvas {
    height: 170px !important;
    max-height: 170px !important;
    min-height: 170px !important;
}

.millaray-premium-dashboard .heat-calendar {
    gap: 5px !important;
}

.millaray-premium-dashboard .heat-day {
    border-radius: 5px !important;
    min-height: 34px !important;
}

.millaray-premium-dashboard .business-intelligence {
    background: rgba(255, 253, 248, .72) !important;
    border-color: rgba(74, 49, 37, .06) !important;
    box-shadow: none !important;
    padding: clamp(18px, 2.4vw, 26px) !important;
}

.business-intelligence .bi-kpi-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.business-intelligence .bi-tableau-board {
    gap: 10px !important;
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    padding: 10px !important;
}

.business-intelligence .bi-tableau-board .bi-studio-panel {
    border-radius: 10px !important;
    box-shadow: none !important;
    min-height: 178px !important;
    padding: 10px !important;
}

.bi-studio-chart,
.bi-studio-chart canvas,
.bi-studio-donut,
.bi-studio-donut canvas {
    height: 108px !important;
}

@media (max-width: 1180px) {
    .business-intelligence .bi-tableau-board {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .millaray-premium-dashboard .quick-analysis-list {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 860px) {
    .millaray-premium-dashboard.reservas-admin-page nav {
        max-width: none !important;
        width: 100% !important;
    }

    .millaray-premium-dashboard .dashboard-shell,
    .millaray-premium-dashboard #reservas.dashboard-shell {
        margin-left: 0 !important;
    }

    .millaray-premium-dashboard .millaray-hero-card,
    .millaray-premium-dashboard .hero-metrics-grid,
    .millaray-premium-dashboard.reservas-admin-page .admin-dashboard,
    .millaray-premium-dashboard .reservation-grid,
    .millaray-premium-dashboard .charts-grid,
    .millaray-premium-dashboard .quick-analysis-list,
    .business-intelligence .bi-kpi-grid,
    .business-intelligence .bi-tableau-board {
        grid-template-columns: 1fr !important;
    }

    .millaray-premium-dashboard .hero-illustration {
        max-height: 190px !important;
    }
}

.millaray-premium-dashboard.reservas-admin-page #admin-dashboard > .metric-card-guests,
.millaray-premium-dashboard.reservas-admin-page #admin-dashboard > .metric-card-active {
    display: none !important;
}

.millaray-premium-dashboard.reservas-admin-page #admin-dashboard {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.millaray-premium-dashboard.reservas-admin-page #admin-dashboard > .metric-card-cabin > span {
    font-size: 0 !important;
}

.millaray-premium-dashboard.reservas-admin-page #admin-dashboard > .metric-card-cabin > span::after {
    content: "Ocupacion";
    font-size: .76rem !important;
}

.millaray-premium-dashboard.reservas-admin-page #admin-dashboard > .metric-card-day strong {
    overflow-wrap: anywhere;
}

.millaray-premium-dashboard.reservas-admin-page #admin-dashboard > .metric-card-bookings { order: 1; }
.millaray-premium-dashboard.reservas-admin-page #admin-dashboard > .metric-card-cabin { order: 2; }
.millaray-premium-dashboard.reservas-admin-page #admin-dashboard > .metric-card-income { order: 3; }
.millaray-premium-dashboard.reservas-admin-page #admin-dashboard > .metric-card-day { order: 4; }

.millaray-premium-dashboard.reservas-admin-page #admin-dashboard > .metric-card {
    align-content: start !important;
    display: grid !important;
    gap: 10px !important;
    min-height: 118px !important;
}

.millaray-premium-dashboard.reservas-admin-page #admin-dashboard > .metric-card i {
    display: none !important;
}

.millaray-premium-dashboard.reservas-admin-page #admin-dashboard > .metric-card > span {
    color: var(--millaray-muted) !important;
    font-size: .75rem !important;
    letter-spacing: 0 !important;
    line-height: 1.2 !important;
}

.millaray-premium-dashboard.reservas-admin-page #admin-dashboard > .metric-card > strong {
    font-size: clamp(1.55rem, 2.2vw, 2rem) !important;
    line-height: 1.05 !important;
}

.millaray-premium-dashboard.reservas-admin-page #admin-dashboard > .metric-card-income > strong {
    font-size: clamp(1.38rem, 1.9vw, 1.7rem) !important;
    overflow-wrap: anywhere;
}

.millaray-premium-dashboard.reservas-admin-page #admin-dashboard > .metric-card-day > strong {
    font-size: clamp(1.28rem, 1.75vw, 1.62rem) !important;
}

.millaray-premium-dashboard.reservas-admin-page #admin-dashboard > .metric-card > small {
    color: var(--millaray-muted) !important;
    font-size: .74rem !important;
    line-height: 1.25 !important;
}

.millaray-premium-dashboard .hero-metrics-grid div::before,
.millaray-premium-dashboard .hero-metrics-grid div::after {
    display: none !important;
}

.millaray-premium-dashboard.reservas-admin-page #admin-dashboard > .metric-card.metric-card-guests,
.millaray-premium-dashboard.reservas-admin-page #admin-dashboard > .metric-card.metric-card-active {
    display: none !important;
}

.millaray-premium-dashboard.reservas-admin-page #admin-dashboard > .metric-card.metric-card-cabin > span {
    font-size: 0 !important;
}

.millaray-premium-dashboard.reservas-admin-page #admin-dashboard > .metric-card.metric-card-cabin > span::after {
    content: "Ocupacion";
    font-size: .75rem !important;
}

@media (max-width: 860px) {
    body.millaray-premium-dashboard.reservas-admin-page {
        overflow-x: hidden !important;
    }

    .millaray-premium-dashboard .dashboard-shell,
    .millaray-premium-dashboard #reservas.dashboard-shell {
        box-sizing: border-box !important;
        margin-left: 0 !important;
        max-width: 100% !important;
        overflow-x: hidden !important;
        padding-left: 20px !important;
        padding-right: 20px !important;
    }

    .millaray-premium-dashboard .dashboard-canvas,
    .millaray-premium-dashboard .dashboard-canvas > *,
    .millaray-premium-dashboard .hero-card-copy,
    .millaray-premium-dashboard .panel-header,
    .millaray-premium-dashboard .reservations-list {
        box-sizing: border-box !important;
        max-width: 100% !important;
        min-width: 0 !important;
        width: 100% !important;
    }

    .millaray-premium-dashboard .dashboard-canvas > .millaray-hero-card,
    .millaray-premium-dashboard .dashboard-canvas > .admin-dashboard,
    .millaray-premium-dashboard .dashboard-canvas > #reservations-log,
    .millaray-premium-dashboard .dashboard-canvas > .reservation-grid,
    .millaray-premium-dashboard .dashboard-canvas > #quick-analysis-panel,
    .millaray-premium-dashboard .dashboard-canvas > .intelligent-analysis-panel,
    .millaray-premium-dashboard .dashboard-canvas > .auth-panel,
    .millaray-premium-dashboard .dashboard-canvas > .business-intelligence {
        width: calc(100vw - 40px) !important;
    }

    .millaray-premium-dashboard .dashboard-topbar,
    .millaray-premium-dashboard .dashboard-actions {
        align-items: stretch !important;
        display: grid !important;
        gap: 12px !important;
        grid-template-columns: 1fr !important;
        width: 100% !important;
    }

    .millaray-premium-dashboard .dashboard-date,
    .millaray-premium-dashboard .dashboard-new-booking {
        justify-self: stretch !important;
        min-width: 0 !important;
        width: 100% !important;
    }

    .millaray-premium-dashboard .millaray-hero-card {
        grid-template-columns: 1fr !important;
        max-width: 100% !important;
    }

    .millaray-premium-dashboard .hero-illustration {
        display: none !important;
    }

    .millaray-premium-dashboard .hero-metrics-grid,
    .millaray-premium-dashboard.reservas-admin-page #admin-dashboard,
    .millaray-premium-dashboard .quick-analysis-list,
    .millaray-premium-dashboard .charts-grid,
    .business-intelligence .bi-kpi-grid,
    .business-intelligence .bi-tableau-board {
        grid-template-columns: 1fr !important;
    }

    .millaray-premium-dashboard.reservas-admin-page #admin-dashboard > .metric-card {
        min-height: 0 !important;
    }
}
