/* Plaza Noble · Public Web · detail-styles CSS
   Migrated from app/resources/views/pn/_partials/detail-styles.blade.php
*/

.pn-hotel { background: var(--pn-pearl); }

    /* Top bar */
    .pn-hotel-top {
        padding-top: var(--pn-s5);
        display: flex; align-items: center; justify-content: space-between;
        gap: var(--pn-s4); flex-wrap: wrap;
    }
    .pn-hotel-crumb {
        font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
        display: flex; gap: 6px; align-items: center; flex-wrap: wrap;
    }
    .pn-hotel-crumb a { color: inherit; text-decoration: none; }
    .pn-hotel-crumb a:hover { color: var(--pn-emerald); }
    .pn-hotel-actions { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
    .pn-hotel-actbtn {
        background: transparent; border: 1px solid var(--pn-divider);
        padding: 8px 14px; border-radius: 999px;
        display: inline-flex; align-items: center; gap: 6px;
        cursor: pointer; font-size: 13px;
        color: var(--pn-text); font-family: inherit; text-decoration: none;
    }
    .pn-hotel-actbtn:hover { border-color: var(--pn-ink); }
    .pn-hotel-actbtn__back { transform: rotate(180deg); }

    /* Header */
    .pn-hotel-header { padding-top: var(--pn-s6); }
    .pn-hotel-header__tags {
        display: flex; align-items: center; gap: var(--pn-s4);
        margin-bottom: var(--pn-s4); flex-wrap: wrap;
    }
    .pn-hotel-header__where {
        display: inline-flex; align-items: center; gap: 6px;
        font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase;
    }
    .pn-hotel-header__row {
        display: grid; grid-template-columns: 1fr auto;
        gap: var(--pn-s7); align-items: end;
    }
    .pn-hotel-title {
        font-size: clamp(48px, 6vw, 72px);
        font-weight: 500; letter-spacing: 0.03em;
        margin: 0; line-height: 0.95;
        text-transform: uppercase;
    }
    .pn-hotel-title .pn-accent { font-style: normal; }
    .pn-hotel-header__rating {
        display: flex; align-items: center; gap: 10px; justify-content: flex-end;
    }
    .pn-hotel-header__rbadge {
        padding: 6px 12px; background: var(--pn-ink);
        color: var(--pn-pearl); border-radius: 8px;
        font-size: 18px; font-weight: 500;
    }
    .pn-hotel-header__rlabel { font-size: 16px; font-weight: 500; }
    .pn-hotel-header__rreviews { font-size: 12px; }

    /* Gallery */
    .pn-hotel-gallery {
        margin-top: var(--pn-s5);
        display: grid;
        grid-template-columns: 2fr 1fr 1fr;
        grid-template-rows: 1fr 1fr;
        gap: 8px; height: 560px;
    }
    .pn-hotel-gallery__cell {
        border-radius: var(--pn-r-md); overflow: hidden;
        position: relative; background: var(--pn-pearl-warm);
    }
    .pn-hotel-gallery__cell--big { grid-row: span 2; }
    .pn-hotel-gallery__cell img {
        width: 100%; height: 100%; object-fit: cover; display: block;
    }
    .pn-hotel-gallery__viewall {
        position: absolute; right: 14px; bottom: 14px;
        background: var(--pn-pearl); color: var(--pn-ink);
        border: 0; padding: 10px 16px; border-radius: 999px;
        font-size: 13px; display: inline-flex; align-items: center; gap: 8px;
        cursor: pointer; font-family: inherit;
    }

    /* Main grid */
    .pn-hotel-main {
        padding-bottom: var(--pn-s10);
        display: grid; grid-template-columns: 1fr 380px;
        gap: var(--pn-s8); align-items: flex-start;
    }

    .pn-hotel-section {
        padding: var(--pn-s9) 0;
        border-bottom: 1px solid var(--pn-divider);
    }
    .pn-hotel-section--last { border-bottom: 0; }
    .pn-hotel-section__head { margin-bottom: var(--pn-s6); }
    .pn-hotel-section__title {
        font-family: var(--pn-font-display);
        font-size: 32px; font-weight: 500;
        letter-spacing: 0.04em; text-transform: uppercase;
        margin: 8px 0 0;
    }

    /* About */
    .pn-hotel-about {
        display: grid; grid-template-columns: 1fr 1fr;
        gap: var(--pn-s7);
        font-size: 15px; line-height: 1.65; color: var(--pn-text);
    }
    .pn-hotel-about p { margin: 0; }
    .pn-hotel-stats {
        display: grid; grid-template-columns: repeat(4, 1fr);
        gap: 0; margin-top: var(--pn-s7);
        border-top: 1px solid var(--pn-divider);
        padding-top: var(--pn-s5);
    }
    .pn-hotel-stats__cell { padding-right: 16px; }
    .pn-hotel-stats__n {
        font-family: var(--pn-font-display);
        font-size: 36px; font-weight: 500;
        letter-spacing: 0.02em; line-height: 1;
        color: var(--pn-emerald);
    }
    .pn-hotel-stats__l { font-size: 11px; margin-top: 6px; letter-spacing: 0.1em; text-transform: uppercase; }

    /* Amenities */
    .pn-hotel-amen { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--pn-s4); }
    .pn-hotel-amen__item {
        display: flex; align-items: center; gap: var(--pn-s4);
        padding: 14px 16px;
        background: #fff; border: 1px solid var(--pn-divider);
        border-radius: var(--pn-r-md);
        font-size: 14px;
    }
    .pn-hotel-amen__more { margin-top: var(--pn-s4); display: inline-flex; }

    /* Rooms */
    .pn-hotel-rooms { display: flex; flex-direction: column; gap: var(--pn-s3); }
    .pn-hotel-room {
        display: grid; grid-template-columns: 160px 1fr auto;
        gap: var(--pn-s5); padding: var(--pn-s5);
        background: #fff; border: 1px solid var(--pn-divider);
        border-radius: var(--pn-r-md); align-items: center;
    }
    .pn-hotel-room__img {
        width: 160px; height: 120px;
        border-radius: 6px; overflow: hidden;
        background: var(--pn-pearl-warm);
    }
    .pn-hotel-room__img img { width: 100%; height: 100%; object-fit: cover; }
    .pn-hotel-room__head { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
    .pn-hotel-room__name {
        font-family: var(--pn-font-display);
        font-size: 20px; letter-spacing: 0.03em; text-transform: uppercase;
    }
    .pn-hotel-room__meta {
        display: flex; gap: 10px; margin-top: 8px;
        font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase;
        flex-wrap: wrap;
    }
    .pn-hotel-room__cancel {
        margin-top: 10px; font-size: 13px; color: var(--pn-text);
        display: flex; align-items: center; gap: 6px;
    }
    .pn-hotel-room__pricebox {
        text-align: right; display: flex; flex-direction: column;
        align-items: flex-end; gap: 8px;
    }
    .pn-hotel-room__kicker { font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; }
    .pn-hotel-room__price {
        font-family: var(--pn-font-display);
        font-size: 24px; font-weight: 500;
        letter-spacing: 0.02em;
    }

    /* Reviews */
    .pn-hotel-reviews-summary {
        display: grid; grid-template-columns: auto 1fr;
        gap: var(--pn-s8); margin-bottom: var(--pn-s7);
    }
    .pn-hotel-reviews-summary__score {
        font-family: var(--pn-font-display);
        font-size: 96px; font-weight: 500;
        letter-spacing: 0.02em; line-height: 1;
        color: var(--pn-emerald);
    }
    .pn-hotel-reviews-summary__label { font-size: 18px; font-weight: 500; margin-top: 8px; }
    .pn-hotel-reviews-summary__based { font-size: 12px; margin-top: 4px; letter-spacing: 0.06em; }
    .pn-hotel-reviews-summary__bars {
        display: grid; grid-template-columns: repeat(2, 1fr);
        gap: 14px var(--pn-s7); align-self: center;
    }
    .pn-hotel-reviews-bar__head {
        display: flex; justify-content: space-between;
        font-size: 13px; margin-bottom: 4px;
    }
    .pn-hotel-reviews-bar__val { font-weight: 500; }
    .pn-hotel-reviews-bar__track {
        height: 4px; background: var(--pn-divider);
        border-radius: 999px; overflow: hidden;
    }
    .pn-hotel-reviews-bar__fill {
        height: 100%; background: var(--pn-ink); border-radius: 999px;
    }
    .pn-hotel-reviews-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--pn-s4); }
    .pn-hotel-review {
        padding: var(--pn-s5); background: #fff;
        border: 1px solid var(--pn-divider);
        border-radius: var(--pn-r-md);
    }
    .pn-hotel-review__head {
        display: flex; justify-content: space-between; align-items: center;
        margin-bottom: var(--pn-s4);
    }
    .pn-hotel-review__user { font-size: 14px; font-weight: 500; }
    .pn-hotel-review__where { font-size: 11px; margin-top: 2px; letter-spacing: 0.08em; text-transform: uppercase; }
    .pn-hotel-review__rbadge {
        padding: 4px 8px; background: var(--pn-ink);
        color: var(--pn-pearl); border-radius: 6px;
        font-size: 12px; font-weight: 500;
    }
    .pn-hotel-review__txt {
        font-size: 13.5px; line-height: 1.55;
        color: var(--pn-text); margin: 0;
    }
    .pn-hotel-review__tags { display: flex; gap: 6px; margin-top: var(--pn-s4); flex-wrap: wrap; }

    /* Map */
    .pn-hotel-map {
        position: relative; height: 340px;
        border-radius: var(--pn-r-md); overflow: hidden;
        border: 1px solid var(--pn-divider); background: #dfd9cb;
    }
    .pn-hotel-map__bg { width: 100%; height: 100%; object-fit: cover; opacity: 0.55; filter: saturate(0.55); }
    .pn-hotel-map__pin {
        position: absolute; top: 40%; left: 46%; transform: translate(-50%, -50%);
        background: var(--pn-ink); color: var(--pn-pearl);
        padding: 8px 12px; border-radius: 999px;
        font-size: 13px; display: inline-flex; align-items: center; gap: 8px;
    }
    .pn-hotel-nearby {
        display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
        margin-top: var(--pn-s6);
        border-top: 1px solid var(--pn-divider);
        padding-top: var(--pn-s5);
    }
    .pn-hotel-nearby__cell { padding-right: 16px; }
    .pn-hotel-nearby__place { font-size: 13px; font-weight: 500; }
    .pn-hotel-nearby__dist { font-size: 11px; margin-top: 4px; letter-spacing: 0.08em; text-transform: uppercase; }

    /* Booking widget */
    .pn-hotel-side {
        position: sticky; top: 80px;
        align-self: flex-start;
        margin-top: var(--pn-s7);
    }
    .pn-hotel-book {
        background: #fff; border: 1px solid var(--pn-divider);
        border-radius: var(--pn-r-lg);
        padding: var(--pn-s6);
        box-shadow: 0 12px 32px -16px rgba(0,0,0,0.2);
    }
    .pn-hotel-book__head {
        display: flex; align-items: baseline; justify-content: space-between;
        margin-bottom: var(--pn-s5);
    }
    .pn-hotel-book__kicker { font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; }
    .pn-hotel-book__price {
        font-family: var(--pn-font-display);
        font-size: 36px; font-weight: 500;
        letter-spacing: 0.02em; margin-top: 2px;
    }
    .pn-hotel-book__rbadge {
        padding: 4px 8px; background: var(--pn-ink);
        color: var(--pn-pearl); border-radius: 6px;
        font-size: 12px; font-weight: 500;
    }
    .pn-hotel-book__pickers {
        border: 1px solid var(--pn-divider);
        border-radius: var(--pn-r-md);
        overflow: hidden;
    }
    .pn-hotel-book__pickerrow {
        display: grid; grid-template-columns: 1fr 1fr;
        border-bottom: 1px solid var(--pn-divider);
    }
    .pn-hotel-book__picker { padding: 12px 14px; }
    .pn-hotel-book__pickerrow .pn-hotel-book__picker:first-child {
        border-right: 1px solid var(--pn-divider);
    }
    .pn-hotel-book__plabel { font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; }
    .pn-hotel-book__pvalue { font-size: 14px; margin-top: 4px; }

    .pn-hotel-book__breakdown {
        padding: var(--pn-s5) 0 0;
        display: flex; flex-direction: column; gap: 10px;
        font-size: 13px;
    }
    .pn-hotel-book__line { display: flex; justify-content: space-between; color: var(--pn-text); }
    .pn-hotel-book__total {
        display: flex; justify-content: space-between;
        padding-top: var(--pn-s4);
        border-top: 1px solid var(--pn-divider);
        margin-top: 6px;
        font-size: 14px; font-weight: 500;
    }
    .pn-hotel-book__totalval {
        font-family: var(--pn-font-display);
        font-size: 22px; font-weight: 500;
        letter-spacing: 0.02em;
    }
    .pn-hotel-book__installments {
        font-size: 11px; letter-spacing: 0.06em; text-align: right;
    }
    .pn-hotel-book__cta {
        margin-top: var(--pn-s5);
        min-height: 56px;
        font-size: 15px;
        justify-content: center;
    }
    .pn-hotel-book__features {
        margin-top: var(--pn-s4);
        display: flex; flex-direction: column; gap: 8px;
        font-size: 12px; color: var(--pn-text);
    }
    .pn-hotel-book__features span {
        display: inline-flex; align-items: center; gap: 8px;
    }

    .pn-hotel-pkgteaser {
        margin-top: var(--pn-s4);
        padding: 14px 18px;
        background: var(--pn-ink); color: var(--pn-pearl);
        border-radius: var(--pn-r-md);
        display: flex; gap: var(--pn-s4); align-items: center;
        text-decoration: none;
    }
    .pn-hotel-pkgteaser__title { font-size: 13px; font-weight: 500; }
    .pn-hotel-pkgteaser__sub {
        font-size: 11px; color: rgba(245, 243, 238, 0.6);
        letter-spacing: 0.06em; margin-top: 2px;
    }

    /* Shared "info card" pattern (also used by voo policy, carro policy, restaurante info) */
    .pn-voo-policy { display: grid; grid-template-columns: 1fr 1fr; gap: var(--pn-s3); }
    .pn-voo-policy__item {
        padding: 16px 18px;
        background: #fff; border: 1px solid var(--pn-divider);
        border-radius: var(--pn-r-sm);
    }
    .pn-voo-policy__l { font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; }
    .pn-voo-policy__v { font-size: 13.5px; margin-top: 6px; line-height: 1.5; }

    @media (max-width: 1023px) {
        .pn-hotel-main { grid-template-columns: 1fr; }
        .pn-hotel-side { position: static; margin-top: 0; }
        .pn-hotel-about { grid-template-columns: 1fr; gap: var(--pn-s4); }
        .pn-hotel-stats { grid-template-columns: repeat(2, 1fr); row-gap: var(--pn-s5); }
        .pn-hotel-reviews-grid { grid-template-columns: 1fr; }
        .pn-hotel-reviews-summary { grid-template-columns: 1fr; gap: var(--pn-s5); }
        .pn-hotel-reviews-summary__bars { grid-template-columns: 1fr 1fr; }
        .pn-hotel-nearby { grid-template-columns: repeat(2, 1fr); row-gap: var(--pn-s4); }
    }
    @media (max-width: 767px) {
        .pn-hotel-header__row { grid-template-columns: 1fr; gap: var(--pn-s4); }
        .pn-hotel-gallery { grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr 1fr; height: 480px; }
        .pn-hotel-gallery__cell--big { grid-row: span 2; grid-column: span 2; }
        .pn-hotel-amen { grid-template-columns: 1fr; }
        .pn-hotel-room { grid-template-columns: 1fr; }
        .pn-hotel-room__img { width: 100%; height: 180px; }
        .pn-hotel-room__pricebox { flex-direction: row; justify-content: space-between; align-items: center; }
        .pn-hotel-stats { grid-template-columns: 1fr 1fr; }
        .pn-hotel-nearby { grid-template-columns: 1fr 1fr; }
        .pn-voo-policy { grid-template-columns: 1fr; }
    }
