.pct-front {
--pct-primary: #24a0bd;
--pct-primary-dark: #0d6578;
--pct-primary-light: #b1ecff;
--pct-on-surface: #1a1a1a;
--pct-muted: #456870;
--pct-surface: #f4f7f8;
--pct-surface-low: #eef3f5;
--pct-surface-high: #e2eaed;
--pct-surface-white: #ffffff;
--pct-g-primary: linear-gradient(135deg, #48c9e5 0%, #24a0bd 100%);
--pct-sh-sm: 0 2px 12px rgba(0, 0, 0, 0.08);
--pct-sh-md: 0 4px 20px rgba(0, 0, 0, 0.1);
--pct-r-sm: 12px;
--pct-r-md: 16px;
--pct-r-xl: 32px;
font-family: 'Proxima Nova', 'ProximaNova', 'Nunito Sans', -apple-system, BlinkMacSystemFont, sans-serif;
color: var(--pct-on-surface);
line-height: 1.6;
box-sizing: border-box;
}
.pct-front *,
.pct-front *::before,
.pct-front *::after {
box-sizing: border-box;
}
.pct-front .container {
width: 100%;
max-width: 1240px;
margin: 0 auto;
padding: 0 20px;
}
.pct-front.section {
padding: 72px 0;
}
.pct-front.section--white {
background: var(--pct-surface-white);
}
.pct-front.section--gray {
background: var(--pct-surface-low);
}
.pct-front .section-label {
display: block;
font-size: 11px;
font-weight: 700;
letter-spacing: 2px;
text-transform: uppercase;
color: var(--pct-primary);
margin-bottom: 8px;
}
.pct-front .section-title {
font-size: 26px;
font-weight: 800;
color: var(--pct-on-surface);
line-height: 1.2;
margin: 0;
}
@media (min-width: 768px) {
.pct-front .section-title {
font-size: 36px;
}
}
.pct-front .section-line {
width: 64px;
height: 3px;
background: var(--pct-primary-light);
border-radius: 2px;
margin-top: 16px;
}
.pct-front .section-header {
margin-bottom: 48px;
} .pct-front .material-symbols-outlined,
.phuket-yndx-lightbox .material-symbols-outlined {
font-family: 'Material Symbols Outlined' !important;
font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24 !important;
font-style: normal !important;
font-weight: normal !important;
font-size: 24px;
display: inline-block !important;
vertical-align: middle;
line-height: 1;
text-transform: none !important;
letter-spacing: normal !important;
word-wrap: normal !important;
white-space: nowrap !important;
direction: ltr !important;
-webkit-font-smoothing: antialiased !important;
} .pct-front .icon-filled {
font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 24 !important;
} .pct-front .btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 8px;
padding: 14px 24px;
border-radius: var(--pct-r-sm);
font-family: inherit;
font-size: 15px;
font-weight: 700;
border: none;
cursor: pointer;
transition: opacity 0.2s, transform 0.15s, box-shadow 0.2s;
text-decoration: none;
}
.pct-front .btn:active {
opacity: 0.88;
transform: scale(0.97);
}
.pct-front .btn--primary {
background: var(--pct-g-primary);
color: #fff;
}
.pct-front .btn--primary:hover {
box-shadow: 0 6px 24px rgba(0, 103, 124, 0.35);
}
.pct-front .btn--dark {
background: var(--pct-on-surface);
color: #fff;
}
.pct-front .btn--full {
width: 100%;
} .pct-front .timeline {
display: flex;
flex-direction: column;
}
.pct-front .timeline__item {
display: flex;
gap: 20px;
padding-bottom: 28px;
position: relative;
}
.pct-front .timeline__item:not(:last-child)::after {
content: '';
position: absolute;
left: 22px;
top: 44px;
bottom: 0;
width: 2px;
background: var(--pct-primary-light);
}
.pct-front .timeline__year {
width: 44px;
height: 44px;
flex-shrink: 0;
background: var(--pct-g-primary);
color: #fff;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
font-size: 11px;
font-weight: 800;
text-align: center;
line-height: 1.15;
box-shadow: 0 4px 12px rgba(0, 103, 124, 0.3);
transition: transform 0.25s;
}
.pct-front .timeline__year--today {
font-size: 9px;
}
.pct-front .timeline__item:hover .timeline__year {
transform: scale(1.1);
}
.pct-front .timeline__body h3 {
font-size: 16px;
font-weight: 700;
margin: 0 0 4px;
line-height: 1.2;
}
.pct-front .timeline__body p {
font-size: 14px;
color: var(--pct-muted);
margin: 0;
}
@media (min-width: 768px) {
.pct-front .timeline {
flex-direction: row;
position: relative;
}
.pct-front .timeline::before {
content: '';
position: absolute;
top: 22px;
left: 22px;
right: 22px;
height: 2px;
background: var(--pct-surface-high);
}
.pct-front .timeline__item {
flex: 1;
flex-direction: column;
padding-bottom: 0;
padding-right: 24px;
}
.pct-front .timeline__item:not(:last-child)::after {
display: none;
}
.pct-front .timeline__year {
margin-bottom: 16px;
}
} .pct-front .reviews-layout {
display: grid;
grid-template-columns: 1fr;
gap: 32px;
}
@media (min-width: 820px) {
.pct-front .reviews-layout {
grid-template-columns: 280px 1fr;
}
}
.pct-front .platform-card {
background: var(--pct-surface-white);
border-radius: var(--pct-r-xl);
padding: 28px;
box-shadow: var(--pct-sh-md);
}
.pct-front .platform-card__logo {
width: 52px;
height: 52px;
border-radius: var(--pct-r-sm);
display: flex;
align-items: center;
justify-content: center;
font-weight: 900;
font-size: 22px;
margin-bottom: 14px;
}
.pct-front .platform-card__logo--yandex {
background: #fc3f1d;
color: #fff;
}
.pct-front .platform-card__title {
font-size: 20px;
font-weight: 800;
margin-bottom: 6px;
}
.pct-front .platform-card__score {
font-size: 52px;
font-weight: 900;
color: var(--pct-primary);
line-height: 1;
margin-bottom: 6px;
}
.pct-front .platform-card__stars {
color: #ffd700;
font-size: 20px;
letter-spacing: 2px;
margin-bottom: 8px;
}
.pct-front .platform-card__count {
font-size: 13px;
color: var(--pct-muted);
margin: 0 0 20px;
}
@media (max-width: 819px) {
.pct-front .platform-card {
display: grid;
grid-template-columns: 46px 1fr 56px;
grid-template-rows: auto auto auto auto;
column-gap: 12px;
row-gap: 0;
padding: 14px 16px;
align-items: center;
}
.pct-front .platform-card__logo {
grid-column: 1;
grid-row: 1 / 3;
width: 46px;
height: 46px;
font-size: 18px;
margin-bottom: 0;
align-self: center;
}
.pct-front .platform-card__title {
grid-column: 2;
grid-row: 1;
font-size: 13px;
font-weight: 700;
margin-bottom: 0;
align-self: end;
}
.pct-front .platform-card__score {
grid-column: 3;
grid-row: 1 / 3;
font-size: 30px;
margin-bottom: 0;
text-align: right;
align-self: center;
}
.pct-front .platform-card__stars {
grid-column: 2;
grid-row: 2;
font-size: 12px;
margin-bottom: 0;
align-self: start;
}
.pct-front .platform-card__count {
grid-column: 1 / 4;
grid-row: 3;
font-size: 11px;
margin: 6px 0 10px;
}
.pct-front .platform-card .btn {
grid-column: 1 / 4;
grid-row: 4;
width: 100%;
padding: 10px 14px;
font-size: 13px;
}
}
.pct-front .review-cards--grid {
display: grid;
grid-template-columns: 1fr;
gap: 12px;
margin-top: 20px;
}
@media (min-width: 600px) {
.pct-front .review-cards--grid {
grid-template-columns: 1fr 1fr;
}
}
.pct-front .review-card {
background: var(--pct-surface-white);
border-radius: var(--pct-r-md);
padding: 20px;
box-shadow: var(--pct-sh-sm);
transition: box-shadow 0.2s;
display: flex;
flex-direction: column;
}
.pct-front .review-card:hover {
box-shadow: var(--pct-sh-md);
}
.pct-front .review-card__header {
display: flex;
align-items: center;
gap: 10px;
margin-bottom: 10px;
}
.pct-front .review-avatar {
width: 38px;
height: 38px;
border-radius: 50%;
background: var(--pct-primary);
color: #fff;
display: flex;
align-items: center;
justify-content: center;
font-size: 15px;
font-weight: 700;
flex-shrink: 0;
}
.pct-front .review-avatar--orange {
background: #e8821a;
}
.pct-front .review-avatar--green {
background: #2d6a4f;
}
.pct-front .review-avatar--pink {
background: #c94fbb;
}
.pct-front .review-card__name {
font-size: 14px;
font-weight: 700;
}
.pct-front .review-card__date {
font-size: 11px;
color: var(--pct-muted);
}
.pct-front .review-card__stars {
color: #ffd700;
font-size: 13px;
margin-bottom: 6px;
}
.pct-front .review-card__text {
font-size: 13px;
color: var(--pct-muted);
line-height: 1.6;
font-style: italic;
flex: 1;
margin: 0;
}
.pct-front .review-card__photos {
display: grid;
grid-template-columns: repeat(3, 56px);
gap: 6px;
margin-top: 12px;
justify-content: start;
}
.pct-front .review-card__photo-thumb {
display: block;
width: 56px;
height: 56px;
flex-shrink: 0;
border: none;
padding: 0;
margin: 0;
border-radius: 6px;
overflow: hidden;
background: var(--pct-surface-low);
box-shadow: var(--pct-sh-sm);
cursor: zoom-in;
-webkit-tap-highlight-color: transparent;
}
.pct-front .review-card__photo-thumb img {
width: 100%;
height: 100%;
min-width: 100%;
min-height: 100%;
object-fit: cover;
display: block;
pointer-events: none;
background-color: var(--pct-surface-low);
}
.pct-front .review-card--hidden {
display: none;
} @media (max-width: 599px) {
#reviews.pct-front .reviews-layout__main {
overflow: hidden;
}
.pct-front .review-cards--grid {
display: flex !important;
overflow-x: scroll;
scroll-snap-type: x mandatory;
scroll-padding-inline: 20px;
-webkit-overflow-scrolling: touch;
overscroll-behavior-x: contain;
gap: 12px;
padding: 8px 20px 16px;
margin: 16px -20px 0;
scrollbar-width: none;
}
.pct-front .review-cards--grid::-webkit-scrollbar {
display: none;
}
.pct-front .review-cards--grid .review-card {
flex: 0 0 calc(100vw - 72px);
max-width: none;
scroll-snap-align: start;
scroll-margin-inline: 0;
display: flex !important;
flex-direction: column;
}
.pct-front .review-cards--grid .review-card--hidden {
display: none !important;
}
.pct-front .review-card--action {
flex: 0 0 calc(100vw - 72px) !important;
min-height: 180px;
display: flex !important;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 12px;
background: var(--pct-surface-white);
border: 2px dashed var(--pct-primary);
border-radius: var(--pct-r-md);
padding: 20px 16px;
text-align: center;
scroll-snap-align: start;
cursor: pointer;
}
.pct-front .review-card--action .ra-icon {
font-size: 32px;
color: var(--pct-primary);
}
.pct-front .review-card--action .ra-text {
font-size: 14px;
font-weight: 700;
color: var(--pct-primary);
line-height: 1.4;
}
.pct-front .review-card--action .ra-sub {
font-size: 12px;
color: var(--pct-muted);
}
.pct-front .yandex-action-final {
display: flex;
flex-direction: column;
align-items: center;
gap: 10px;
width: 100%;
text-align: center;
}
.pct-front .yandex-maps-action-logo {
display: block;
flex-shrink: 0;
width: 48px;
height: 48px;
border-radius: 12px;
}
.pct-front .yandex-action-final__link {
color: var(--pct-primary) !important;
text-decoration: none;
font-weight: 700;
font-size: 14px;
line-height: 1.35;
}
.pct-front .yandex-desktop-load-more {
display: none;
}
}
@media (min-width: 600px) {
.pct-front .review-card--action:not(.review-card--google-cta) {
display: none;
}
} .phuket-yndx-lightbox {
position: fixed;
inset: 0;
z-index: 100050;
display: flex;
align-items: center;
justify-content: center;
padding: 16px;
box-sizing: border-box;
}
.phuket-yndx-lightbox[hidden] {
display: none !important;
}
.phuket-yndx-lightbox__backdrop {
position: absolute;
inset: 0;
background: rgba(0, 0, 0, 0.92);
cursor: pointer;
}
.phuket-yndx-lightbox__stage {
position: relative;
z-index: 2;
max-width: min(96vw, 1200px);
max-height: 88vh;
display: flex;
align-items: center;
justify-content: center;
}
.phuket-yndx-lightbox__stage img {
max-width: 100%;
max-height: 88vh;
width: auto;
height: auto;
object-fit: contain;
border-radius: var(--pct-r-sm, 12px);
box-shadow: 0 8px 40px rgba(0, 0, 0, 0.45);
}
.phuket-yndx-lightbox__close,
.phuket-yndx-lightbox__prev,
.phuket-yndx-lightbox__next {
position: absolute;
z-index: 3;
border: none;
cursor: pointer;
display: flex;
align-items: center;
justify-content: center;
color: #fff;
background: rgba(255, 255, 255, 0.12);
border-radius: 50%;
width: 44px;
height: 44px;
transition: background 0.2s;
}
.phuket-yndx-lightbox__close:hover,
.phuket-yndx-lightbox__prev:hover,
.phuket-yndx-lightbox__next:hover {
background: rgba(255, 255, 255, 0.22);
}
.phuket-yndx-lightbox__close {
top: 12px;
right: 12px;
}
.phuket-yndx-lightbox__close .material-symbols-outlined {
font-size: 28px !important;
}
.phuket-yndx-lightbox__prev {
left: 8px;
top: 50%;
transform: translateY(-50%);
}
.phuket-yndx-lightbox__next {
right: 8px;
top: 50%;
transform: translateY(-50%);
}
.phuket-yndx-lightbox__prev .material-symbols-outlined,
.phuket-yndx-lightbox__next .material-symbols-outlined {
font-size: 36px !important;
}
.phuket-yndx-lightbox__counter {
position: absolute;
z-index: 3;
bottom: 20px;
left: 50%;
transform: translateX(-50%);
color: rgba(255, 255, 255, 0.85);
font-size: 14px;
font-weight: 600;
text-shadow: 0 1px 4px rgba(0, 0, 0, 0.8);
}
@media (max-width: 599px) {
.phuket-yndx-lightbox__prev {
left: 4px;
width: 40px;
height: 40px;
}
.phuket-yndx-lightbox__next {
right: 4px;
width: 40px;
height: 40px;
}
} .pct-hero-wrap {
--pct-primary: #24A0BD;
--pct-primary-dark: #0d6578;
--pct-primary-light: #b1ecff;
--pct-cyan: #48d8f0;
--pct-tertiary: #b5007b;
--pct-surface: #f4f7f8;
--pct-on-surface: #1a1a1a;
--pct-muted: #456870;
--pct-g-primary: linear-gradient(135deg, #48c9e5 0%, #24A0BD 100%);
--pct-g-hero: linear-gradient(160deg, #0a4a58 0%, #0d6578 35%, #24A0BD 70%, #48C9E5 100%);
--pct-g-tertiary: linear-gradient(50deg, #f102a5 10%, #ff3281 50%);
--pct-sh-lg: 0 8px 40px rgba(0, 0, 0, .16);
--pct-r-sm: 12px;
--pct-r-md: 16px;
--pct-r-lg: 24px;
--pct-r-full: 9999px;
font-family: 'Proxima Nova', 'ProximaNova', sans-serif;
}
.pct-hero-wrap *,
.pct-hero-wrap *::before,
.pct-hero-wrap *::after { box-sizing: border-box; margin: 0; padding: 0; }
.pct-hero-wrap a:not(.pct-btn) { text-decoration: none; color: #fff; }
.pct-hero-wrap .pct-btn { text-decoration: none; }
.pct-hero-wrap img { display: block; max-width: 100%; } .pct-hero-wrap button:not(.pct-btn):not(.pct-book-btn):not(.pct-book-popup__close) {
cursor: pointer; font-family: inherit; border: none; background: none;
}
.pct-hero-wrap .pct-container {
width: 100%; max-width: 1240px; margin: 0 auto; padding: 0 20px;
}
.pct-hero { position: relative; overflow: hidden; }
.pct-hero__bg { position: absolute; inset: 0; z-index: 0; background: var(--pct-g-hero); }
.pct-hero__lcp-img {
position: absolute; inset: 0; z-index: 1;
width: 100%; height: 100%;
object-fit: cover; object-position: 50% 60%;
opacity: .5; pointer-events: none;
}
.pct-hero__body { position: relative; z-index: 3; display: flex; flex-direction: column; }
.pct-hero__content-wrap { padding: 100px 0 44px; }
.pct-hero__grid { display: grid; grid-template-columns: 1fr; gap: 40px; align-items: center; }
.pct-hero__tag {
display: inline-flex; align-items: center; gap: 8px;
background: rgba(255, 255, 255, .18); border: 1px solid rgba(255, 255, 255, .25);
border-radius: var(--pct-r-full); color: #fff;
font-size: 12px; font-weight: 700; letter-spacing: .3px;
padding: 7px 16px; margin-bottom: 22px;
}
.pct-hero__title {
font-size: 28px; font-weight: 900; color: #fff;
line-height: 1.2; margin-bottom: 16px;
text-shadow: 0 2px 12px rgba(0, 0, 0, .3);
}
.pct-hero__title em { font-style: italic; color: var(--pct-cyan); }
.pct-hero__subtitle {
font-size: 16px; color: rgba(255, 255, 255, .9);
line-height: 1.6; margin-bottom: 24px;
}
.pct-hero__trust { display: flex; flex-direction: column; gap: 8px; margin-bottom: 28px; }
.pct-hero__trust-item {
display: flex; align-items: center; gap: 10px;
background: rgba(255, 255, 255, .14); border: 1px solid rgba(255, 255, 255, .2);
border-radius: var(--pct-r-sm); padding: 10px 14px;
font-size: 13px; font-weight: 600; color: #fff;
backdrop-filter: blur(6px);
}
.pct-hero__trust-item i { font-size: 14px; color: #FFD700; }
.pct-hero__buttons { display: flex; flex-direction: column; gap: 10px; margin-bottom: 20px; }
.pct-hero__buttons .pct-btn { width: 100%; }
@media (min-width: 480px) {
.pct-hero__buttons { flex-direction: row; }
.pct-hero__buttons .pct-btn { flex: 1; width: auto; }
}
.pct-hero-wrap .pct-btn,
.pct-catalog-wrap .pct-btn,
.pct-rating-wrap .pct-btn {
display: inline-flex; align-items: center; justify-content: center; gap: 8px;
padding: 14px 24px; border-radius: var(--pct-r-sm);
font-size: 15px; font-weight: 700; border: none; cursor: pointer;
transition: opacity .2s, transform .15s, box-shadow .2s;
text-decoration: none !important; font-family: inherit;
}
.pct-hero-wrap .pct-btn:active,
.pct-catalog-wrap .pct-btn:active,
.pct-rating-wrap .pct-btn:active { opacity: .8; transform: scale(.97); }
.pct-hero-wrap .pct-btn--white,
.pct-catalog-wrap .pct-btn--white { background: #fff !important; color: var(--pct-primary) !important; }
.pct-hero-wrap .pct-btn--white:hover,
.pct-catalog-wrap .pct-btn--white:hover { box-shadow: 0 6px 24px rgba(0, 103, 124, .25); }
.pct-hero-wrap .pct-btn--accent,
.pct-catalog-wrap .pct-btn--accent { background: var(--pct-g-tertiary) !important; color: #fff !important; }
.pct-hero-wrap .pct-btn--accent:hover,
.pct-catalog-wrap .pct-btn--accent:hover { box-shadow: 0 6px 24px rgba(241, 2, 165, .35); } .pct-hero-wrap a.pct-hero__video-btn {
display: inline-flex; align-items: center; gap: 12px;
color: rgba(255, 255, 255, .9) !important;
font-size: 13px; font-weight: 600;
padding: 10px 16px; margin-top: 4px;
background: rgba(255, 255, 255, .12);
border: 1px solid rgba(255, 255, 255, .25);
border-radius: 50px;
cursor: pointer; text-decoration: none !important;
transition: background .2s;
}
.pct-hero-wrap a.pct-hero__video-btn:hover {
background: rgba(255, 255, 255, .2);
}
.pct-hero__play {
width: 32px; height: 32px;
background: rgba(255, 255, 255, .25);
border-radius: 50%; display: flex; align-items: center; justify-content: center;
flex-shrink: 0; color: #fff;
}
.pct-hero__play i { font-size: 12px; }
.pct-hero__image-col { display: none; position: relative; }
.pct-hero__image-card {
border-radius: 40px; overflow: hidden;
transform: rotate(2deg); transition: transform .5s ease;
box-shadow: var(--pct-sh-lg); position: relative;
}
.pct-hero__image-card:hover { transform: rotate(0deg); }
.pct-hero__image-card img { width: 100%; height: 480px; object-fit: cover; display: block; }
.pct-hero__video-overlay-btn {
position: absolute; inset: 0; z-index: 2;
display: flex; flex-direction: column;
align-items: center; justify-content: center; gap: 10px;
background: rgba(0, 0, 0, .18); border: none; cursor: pointer;
transition: background .3s; width: 100%;
}
.pct-hero__image-card:hover .pct-hero__video-overlay-btn { background: rgba(0, 0, 0, .32); }
.pct-hero__video-circle {
width: 64px; height: 64px; border-radius: 50%;
background: rgba(255, 255, 255, .9);
display: flex; align-items: center; justify-content: center;
box-shadow: 0 4px 24px rgba(0, 0, 0, .3);
transition: transform .2s; color: var(--pct-primary);
}
.pct-hero__video-overlay-btn:hover .pct-hero__video-circle { transform: scale(1.1); }
.pct-hero__video-circle i { font-size: 22px; }
.pct-hero__video-overlay-label {
color: #fff; font-size: 13px; font-weight: 700;
background: rgba(0, 0, 0, .4); backdrop-filter: blur(6px);
padding: 5px 14px; border-radius: var(--pct-r-full);
}
.pct-hero__badge {
position: absolute; bottom: -16px; left: -16px; z-index: 4;
background: rgba(255, 255, 255, .92); backdrop-filter: blur(12px);
border-radius: var(--pct-r-md); padding: 12px 18px;
box-shadow: var(--pct-sh-lg);
display: flex; align-items: center; gap: 8px;
font-weight: 700; font-size: 14px;
}
.pct-hero__badge-icon { font-size: 18px; }
.pct-hero__badge-icon .fa-certificate { color: var(--pct-tertiary); }
.pct-hero__badge-icon .fa-check { font-size: .55em; }
.pct-hero__stats {
position: relative; z-index: 3;
background: rgba(0, 0, 0, .28); backdrop-filter: blur(12px);
border-top: 1px solid rgba(255, 255, 255, .1);
}
.pct-hero__stats-grid {
display: grid; grid-template-columns: repeat(4, 1fr); padding: 14px 0;
}
.pct-hero__stat {
display: flex; flex-direction: column;
align-items: center; justify-content: center;
text-align: center; padding: 6px 8px;
border-right: 1px solid rgba(255, 255, 255, .12); gap: 4px;
}
.pct-hero__stat:last-child { border-right: none; }
.pct-hero__stat-icon { color: rgba(255, 255, 255, .9); display: flex; align-items: center; justify-content: center; }
.pct-hero__stat-icon i { font-size: 18px; }
.pct-hero__stat-num { font-size: 17px; font-weight: 800; color: #fff; line-height: 1; }
.pct-hero__stat-label { font-size: 10px; color: rgba(255, 255, 255, .65); }
@media (min-width: 900px) {
.pct-hero__grid { grid-template-columns: 1fr 1fr; gap: 64px; }
.pct-hero__image-col { display: block; }
.pct-hero__title { font-size: 38px; }
.pct-hero__content-wrap { padding: 160px 0 56px; }
.pct-hero__stat-num { font-size: 20px; }
.pct-hero__stat-label { font-size: 11px; }
.pct-hero-wrap a.pct-hero__video-btn { display: none !important; }
}
@media (min-width: 1100px) {
.pct-hero__title { font-size: 44px; }
} .pct-book-overlay {
display: none; position: fixed; inset: 0; z-index: 9999;
background: rgba(0, 0, 0, .55); backdrop-filter: blur(4px);
align-items: center; justify-content: center; padding: 20px 10px;
}
.pct-book-overlay.active { display: flex; }
.pct-book-popup {
background: #fff; border-radius: 24px; padding: 32px 28px;
width: 100%; max-width: 400px; position: relative;
box-shadow: 0 16px 64px rgba(0, 0, 0, .25);
animation: pctPopIn .28s cubic-bezier(.34, 1.56, .64, 1);
}
@keyframes pctPopIn {
from { opacity: 0; transform: scale(.88) translateY(16px); }
to   { opacity: 1; transform: none; }
}
.pct-book-popup__close {
position: absolute; top: 14px; right: 16px;
width: 32px; height: 32px; border-radius: 50%;
background: #f0f4f6; border: none; cursor: pointer;
display: flex; align-items: center; justify-content: center;
font-size: 16px; color: #456870; transition: background .2s;
}
.pct-book-popup__close:hover { background: #e2eaed; }
.pct-book-popup__head { text-align: center; margin-bottom: 8px; }
.pct-book-popup__icon {
width: 56px; height: 56px;
background: linear-gradient(135deg, #48c9e5, #24A0BD);
border-radius: 50%; display: flex; align-items: center; justify-content: center;
margin: 0 auto 14px; color: #fff;
}
.pct-book-popup__icon i { font-size: 24px; color: #fff; }
.pct-book-popup__title { font-size: 20px; font-weight: 800; color: #1a1a1a; margin-bottom: 4px; }
.pct-book-popup__sub { font-size: 14px; color: #456870; text-align: center; margin-bottom: 20px; }
.pct-book-popup__btns { display: flex; flex-direction: column; gap: 9px; }
.pct-book-btn {
display: flex; align-items: center; justify-content: flex-start; gap: 12px;
padding: 11px 16px; border-radius: 12px;
font-size: 15px; font-weight: 600; color: #fff !important; text-decoration: none !important;
background: linear-gradient(135deg, #48c9e5, #24A0BD) !important;
transition: opacity .2s, transform .12s;
border: none; cursor: pointer; width: 100%; box-sizing: border-box;
}
.pct-book-btn:hover { opacity: .85 !important; color: #fff !important; }
.pct-book-btn:active { transform: scale(.97); } .pct-book-btn__icon {
width: 34px; height: 34px; border-radius: 8px;
background: #fff; flex-shrink: 0;
display: flex; align-items: center; justify-content: center;
}
.pct-book-btn__icon i { font-size: 18px; } .pct-catalog-wrap {
--pct-primary: #24A0BD;
--pct-primary-dark: #0d6578;
--pct-primary-light: #b1ecff;
--pct-tertiary: #b5007b;
--pct-on-surface: #1a1a1a;
--pct-muted: #456870;
--pct-surface-low: #eef3f5;
--pct-surface-high: #e2eaed;
--pct-surface-white: #ffffff;
--pct-g-primary: linear-gradient(135deg, #48c9e5 0%, #24A0BD 100%);
--pct-g-tertiary: linear-gradient(50deg, #f102a5 10%, #ff3281 50%);
--pct-sh-sm: 0 2px 12px rgba(0, 0, 0, .08);
--pct-sh-lg: 0 8px 40px rgba(0, 0, 0, .16);
--pct-r-sm: 12px;
--pct-r-md: 16px;
--pct-r-lg: 24px;
--pct-r-xl: 32px;
--pct-r-full: 9999px;
font-family: 'Proxima Nova', 'ProximaNova', sans-serif;
color: var(--pct-on-surface);
line-height: 1.6;
}
.pct-catalog-wrap *,
.pct-catalog-wrap *::before,
.pct-catalog-wrap *::after { box-sizing: border-box; margin: 0; padding: 0; }
.pct-catalog-wrap a { text-decoration: none; color: inherit; }
.pct-catalog-wrap img { display: block; max-width: 100%; }
.pct-catalog-section { background: var(--pct-surface-low); padding: 72px 0; }
.pct-container-cat { width: 100%; max-width: 1240px; margin: 0 auto; padding: 0 20px; } .pct-catalog-header {
display: flex; flex-direction: column; gap: 12px; margin-bottom: 36px;
}
@media (min-width: 768px) {
.pct-catalog-header {
display: grid;
grid-template-columns: 1fr 1.4fr;
grid-template-rows: auto auto;
row-gap: 0;
column-gap: 0;
}
.pct-catalog-header__text {
grid-column: 1 / -1; grid-row: 1;
}
.pct-chips-outer {
grid-column: 2; grid-row: 2;
width: 100%;
}
}
.pct-catalog-header__text { display: flex; flex-direction: column; }
.pct-section-label {
display: block; font-size: 11px; font-weight: 700;
letter-spacing: 2px; text-transform: uppercase;
color: var(--pct-primary); margin-bottom: 8px;
}
.pct-section-title { font-size: 26px; font-weight: 800; color: var(--pct-on-surface); line-height: 1.2; margin: 0; }
.pct-section-title em { font-style: normal; color: var(--pct-primary); }
@media (min-width: 768px) { .pct-section-title { font-size: 32px; } }
.pct-section-subtitle { font-size: 15px; color: var(--pct-muted); margin-top: 8px; margin-bottom: 10px; }
.pct-section-line { width: 64px; height: 3px; background: var(--pct-primary-light); border-radius: 2px; margin-top: 16px; } .pct-chips-outer {
display: flex; align-items: center; gap: 6px; width: 100%; min-width: 0;
}
@media (min-width: 768px) {
.pct-chips-outer { width: 100%; }
}
.pct-chips {
display: flex; gap: 8px;
overflow-x: auto; scroll-behavior: smooth;
scrollbar-width: none; padding: 4px 0;
flex: 1; min-width: 0;
}
.pct-chips::-webkit-scrollbar { display: none; }
.pct-chip {
white-space: nowrap; padding: 9px 18px; border-radius: var(--pct-r-full);
font-family: inherit; font-size: 13px; font-weight: 600;
color: var(--pct-muted); background: var(--pct-surface-high);
border: none; cursor: pointer; flex-shrink: 0; transition: all .2s;
}
.pct-chip.active,
.pct-chip:hover { background: var(--pct-g-primary); color: #fff; } .pct-chips-arrow {
display: none;
}
@media (min-width: 768px) {
.pct-chips-arrow {
flex-shrink: 0; width: 32px; height: 32px;
border-radius: 50%; border: 1.5px solid var(--pct-surface-high);
background: var(--pct-surface-white); color: var(--pct-muted);
display: flex; align-items: center; justify-content: center;
cursor: pointer; font-size: 12px;
transition: border-color .2s, color .2s, box-shadow .2s;
box-shadow: var(--pct-sh-sm);
}
.pct-chips-arrow:hover { border-color: var(--pct-primary); color: var(--pct-primary); }
.pct-chips-arrow.hidden { opacity: 0; pointer-events: none; }
} .pct-cat-content { display: none; }
.pct-cat-content.active { display: block; }
.pct-cards-grid { display: grid; grid-template-columns: 1fr; gap: 20px; margin-top: 24px; }
@media (min-width: 600px) { .pct-cards-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 960px) { .pct-cards-grid { grid-template-columns: repeat(3, 1fr); } }
.pct-tour-card {
background: var(--pct-surface-white); border-radius: var(--pct-r-lg);
overflow: hidden; box-shadow: var(--pct-sh-sm);
transition: box-shadow .3s, transform .3s;
display: flex; flex-direction: column;
}
.pct-tour-card:hover { box-shadow: var(--pct-sh-lg); transform: translateY(-4px); }
.pct-tour-card__img { position: relative; height: 220px; overflow: hidden; flex-shrink: 0; }
.pct-tour-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.pct-tour-card:hover .pct-tour-card__img img { transform: scale(1.08); }
.pct-tour-card__img-placeholder { width: 100%; height: 100%; background: linear-gradient(135deg, #48c9e5, #0d6578); }
.pct-tour-card__rating {
position: absolute; top: 12px; left: 12px;
background: #FFD700; color: #333;
font-size: 12px; font-weight: 700; padding: 4px 9px; border-radius: var(--pct-r-full);
}
.pct-tour-card__cat {
position: absolute; bottom: 12px; left: 12px;
background: rgba(0, 0, 0, .42); backdrop-filter: blur(6px);
color: #fff; padding: 5px 12px; border-radius: var(--pct-r-full);
font-size: 12px; font-weight: 600;
}
.pct-tour-card__body { padding: 20px; display: flex; flex-direction: column; flex: 1; }
.pct-tour-card__title { font-size: 17px; font-weight: 700; margin-bottom: 6px; color: var(--pct-on-surface); }
.pct-tour-card__desc { font-size: 13px; color: var(--pct-muted); margin-bottom: 12px; line-height: 1.5; flex: 1; }
.pct-tour-card__footer {
display: flex; justify-content: space-between; align-items: center;
padding-top: 14px; border-top: 1px solid var(--pct-surface-high);
gap: 10px; margin-top: auto;
}
.pct-tour-prices { display: flex; flex-direction: column; gap: 3px; }
.pct-tour-price-row { display: flex; gap: 8px; align-items: center; }
.pct-tour-price-type { font-size: 11px; color: var(--pct-muted); min-width: 54px; }
.pct-tour-price-val { font-weight: 700; font-size: 14px; color: var(--pct-primary); } .pct-card-btn {
display: inline-flex; align-items: center; gap: 6px;
padding: 8px 14px; border-radius: 10px;
font-size: 13px; font-weight: 700; color: #fff;
background: var(--pct-g-primary); flex-shrink: 0;
transition: opacity .2s;
}
.pct-card-btn i { font-size: 11px; }
.pct-card-btn:hover { opacity: .88; } .pct-catalog-view-all { text-align: center; margin-top: 28px; } .pct-catalog-wrap .pct-btn--outline {
background: transparent !important;
color: var(--pct-primary) !important;
border: 2px solid var(--pct-primary) !important;
}
.pct-catalog-wrap .pct-btn--outline:hover {
background: var(--pct-primary) !important; color: #fff !important;
}
.pct-catalog-wrap .pct-btn--primary {
background: var(--pct-g-primary) !important; color: #fff !important;
}
.pct-catalog-wrap .pct-btn--primary:hover { opacity: .9; } .pct-help-callout {
margin-top: 48px; padding: 28px 24px;
background: rgba(0, 103, 124, .05); border-radius: var(--pct-r-xl);
border: 2px dashed rgba(177, 236, 255, .8);
display: flex; flex-direction: column; align-items: center;
gap: 20px; text-align: center;
}
.pct-help-callout__icon {
width: 60px; height: 60px; border-radius: 50%;
background: var(--pct-g-primary); color: #fff;
display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.pct-help-callout__icon i { font-size: 22px; }
.pct-help-callout__left { display: flex; flex-direction: column; align-items: center; gap: 16px; }
.pct-help-callout h4 { font-size: 20px; font-weight: 800; margin-bottom: 4px; }
.pct-help-callout p { font-size: 14px; color: var(--pct-muted); }
@media (min-width: 768px) {
.pct-help-callout { flex-direction: row; text-align: left; justify-content: space-between; }
.pct-help-callout__left { flex-direction: row; align-items: center; }
} .pct-rating-wrap {
--pct-primary: #24A0BD;
--pct-primary-dark: #0d6578;
--pct-primary-light: #b1ecff;
--pct-on-surface: #1a1a1a;
--pct-muted: #456870;
--pct-surface-white: #ffffff;
--pct-surface-low: #eef3f5;
--pct-g-primary: linear-gradient(135deg, #48c9e5 0%, #24A0BD 100%);
--pct-g-tertiary: linear-gradient(50deg, #f102a5 10%, #ff3281 50%);
--pct-sh-sm: 0 2px 12px rgba(0, 0, 0, .08);
--pct-sh-lg: 0 8px 40px rgba(0, 0, 0, .16);
--pct-r-sm: 12px;
--pct-r-md: 16px;
--pct-r-xl: 32px;
--pct-r-full: 9999px;
font-family: 'Proxima Nova', 'ProximaNova', sans-serif;
color: var(--pct-on-surface); line-height: 1.6;
}
.pct-rating-wrap *,
.pct-rating-wrap *::before,
.pct-rating-wrap *::after { box-sizing: border-box; margin: 0; padding: 0; }
.pct-rating-wrap a { text-decoration: none; color: #fff; }
.pct-rating-section { background: var(--pct-surface-white); padding: 72px 0; }
.pct-container-rat { width: 100%; max-width: 1240px; margin: 0 auto; padding: 0 20px; }
.pct-popular-grid { display: grid; grid-template-columns: 1fr; gap: 48px; }
@media (min-width: 900px) {
.pct-popular-grid { grid-template-columns: 1fr 1fr; align-items: center; }
}
.pct-rating-wrap .pct-section-subtitle { margin-bottom: 28px; }
.pct-rating-list { display: flex; flex-direction: column; gap: 10px; }
.pct-rating-item {
display: flex; align-items: center; gap: 14px;
background: var(--pct-surface-low); border-radius: var(--pct-r-sm);
padding: 14px 16px; transition: transform .2s, box-shadow .2s;
}
.pct-rating-item:hover { transform: translateX(5px); box-shadow: var(--pct-sh-sm); }
.pct-rating-item__num {
font-size: 20px; font-weight: 900; color: var(--pct-primary-light);
min-width: 36px; font-variant-numeric: tabular-nums;
flex-shrink: 0; line-height: 1;
}
.pct-rating-item:first-child .pct-rating-item__num { color: var(--pct-primary); }
.pct-rating-item__info { flex: 1; min-width: 0; }
.pct-rating-item__title {
font-size: 15px; font-weight: 700; color: var(--pct-on-surface);
white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.pct-rating-item__meta { font-size: 12px; color: var(--pct-muted); margin-top: 2px; }
.pct-rating-item__meta strong { color: var(--pct-primary); }
.pct-rating-btn {
display: inline-flex; align-items: center; gap: 5px;
padding: 7px 14px; border-radius: 10px;
font-family: inherit; font-size: 12px; font-weight: 700;
background: var(--pct-g-primary); color: #fff;
text-decoration: none; flex-shrink: 0; transition: opacity .2s;
}
.pct-rating-btn:hover { opacity: .85; } .pct-popular-cta { margin-top: 24px; }
.pct-rating-wrap .pct-btn--outline {
background: transparent !important; color: var(--pct-primary) !important;
border: 2px solid var(--pct-primary) !important;
}
.pct-rating-wrap .pct-btn--outline:hover {
background: var(--pct-primary) !important; color: #fff !important;
} .pct-popular-mosaic {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 10px;
}
@media (min-width: 900px) {
.pct-popular-mosaic { gap: 14px; }
}
.pct-popular-mosaic__col { display: flex; flex-direction: column; gap: 10px; }
@media (min-width: 900px) {
.pct-popular-mosaic__col { gap: 14px; }
.pct-popular-mosaic__col--offset { padding-top: 48px; }
}
.pct-popular-mosaic__photo {
border-radius: var(--pct-r-md); overflow: hidden; flex-shrink: 0;
}
.pct-popular-mosaic__photo img {
width: 100%; height: 100%; object-fit: cover; display: block;
transition: transform .5s ease;
}
.pct-popular-mosaic__photo:hover img { transform: scale(1.05); } .pct-popular-mosaic__photo--h1 { height: 150px; }
.pct-popular-mosaic__photo--h2 { height: 100px; }
.pct-popular-mosaic__photo--h3 { height: 115px; }
.pct-popular-mosaic__photo--h4 { height: 135px; } @media (min-width: 900px) {
.pct-popular-mosaic__photo--h1 { height: 290px; }
.pct-popular-mosaic__photo--h2 { height: 190px; }
.pct-popular-mosaic__photo--h3 { height: 220px; }
.pct-popular-mosaic__photo--h4 { height: 260px; }
} .pct-webcam-wrap {
--pct-primary: #24A0BD;
--pct-primary-dark: #0d6578;
--pct-primary-light: #b1ecff;
--pct-on-surface: #1a1a1a;
--pct-muted: #456870;
--pct-surface-low: #eef3f5;
--pct-surface-white: #ffffff;
--pct-r-sm: 12px;
--pct-r-md: 16px;
--pct-r-xl: 32px;
--pct-sh-md: 0 4px 24px rgba(0,0,0,.12);
font-family: 'Proxima Nova', 'ProximaNova', sans-serif;
color: var(--pct-on-surface);
}
.pct-webcam-wrap *,
.pct-webcam-wrap *::before,
.pct-webcam-wrap *::after { box-sizing: border-box; margin: 0; padding: 0; }
.pct-webcam-wrap a { text-decoration: none; color: inherit; }
.pct-webcam-section { background: var(--pct-surface-low); padding: 72px 0; }
.pct-container-wc { width: 100%; max-width: 1240px; margin: 0 auto; padding: 0 20px; }
.pct-webcam-wrap .pct-section-label   { display: block; font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--pct-primary); margin-bottom: 8px; }
.pct-webcam-wrap .pct-section-title   { font-size: 26px; font-weight: 800; color: var(--pct-on-surface); line-height: 1.2; margin-bottom: 8px; }
.pct-webcam-wrap .pct-section-subtitle { font-size: 15px; color: var(--pct-muted); margin-bottom: 32px; }
@media (min-width: 768px) {
.pct-webcam-wrap .pct-section-title { font-size: 36px; }
} .pct-weather-card {
background: var(--pct-surface-white);
border-radius: var(--pct-r-xl); overflow: hidden;
box-shadow: var(--pct-sh-md);
display: grid; grid-template-columns: 1fr;
}
@media (min-width: 900px) {
.pct-weather-card { grid-template-columns: 1fr 1fr; }
} .pct-weather-card__info { padding: 36px 32px; display: flex; flex-direction: column; align-items: flex-start; gap: 0; } .pct-live-badge {
display: inline-flex; align-items: center; gap: 6px;
background: #fee2e2; color: #dc2626;
border-radius: 999px; padding: 5px 12px;
font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px;
margin-bottom: 16px;
animation: pctBlink 2s infinite;
}
.pct-live-badge__dot { width: 8px; height: 8px; background: #dc2626; border-radius: 50%; flex-shrink: 0; }
@keyframes pctBlink { 0%,100% { opacity:1; } 50% { opacity:.6; } }
.pct-weather-card__title { font-size: 22px; font-weight: 800; color: var(--pct-on-surface); margin-bottom: 8px; }
.pct-weather-card__desc  { font-size: 14px; color: var(--pct-muted); line-height: 1.6; margin-bottom: 24px; } .pct-weather-temps { display: flex; gap: 12px; margin-bottom: 28px; width: 100%; }
.pct-weather-temp  { flex: 1; background: var(--pct-surface-low); border-radius: var(--pct-r-sm); padding: 14px; text-align: center; }
.pct-weather-temp__val   { font-size: 24px; font-weight: 800; color: var(--pct-primary); line-height: 1.1; }
.pct-weather-temp__label { font-size: 11px; color: var(--pct-muted); margin-top: 4px; } .pct-webcam-wrap .pct-btn--primary {
display: inline-flex; align-items: center; gap: 8px;
padding: 12px 22px; border-radius: var(--pct-r-sm);
background: linear-gradient(135deg, #48c9e5, #24A0BD) !important;
color: #fff !important; font-size: 14px; font-weight: 700;
text-decoration: none; transition: opacity .2s;
}
.pct-webcam-wrap .pct-btn--primary:hover { opacity: .88; }
.pct-webcam-wrap .pct-btn--primary i { font-size: 14px; } .pct-weather-card__cam {
position: relative; min-height: 300px;
background: linear-gradient(180deg, #48C9E5 0%, #006B7D 60%, #003d4d 100%);
display: flex; align-items: center; justify-content: center;
overflow: hidden;
}
@media (min-width: 900px) { .pct-weather-card__cam { min-height: 360px; } }
.pct-weather-card__cam-preview {
position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: .85;
}
.pct-weather-cam-label {
position: absolute; top: 12px; left: 14px; z-index: 2;
color: #fff; font-size: 11px; font-weight: 700;
text-shadow: 0 1px 4px rgba(0,0,0,.5);
background: rgba(0,0,0,.35); border-radius: 6px; padding: 3px 8px;
}
.pct-weather-play-btn {
position: relative; z-index: 2;
width: 72px; height: 72px;
background: rgba(255,255,255,.2); backdrop-filter: blur(12px);
border-radius: 50%; border: 2px solid rgba(255,255,255,.5);
display: flex; align-items: center; justify-content: center;
color: #fff; cursor: pointer; transition: transform .2s, background .2s;
outline: none;
}
.pct-weather-play-btn:hover { transform: scale(1.1); background: rgba(255,255,255,.3); }
.pct-weather-play-btn i { font-size: 26px; margin-left: 4px; }