/* Field Notes Flight — hotel (property) + room single-page layout.
   Uses the fly tokens (fly-base.css + fieldnotes.css + palette). Loaded on
   single property/room pages only. Hero text stays light (over the image);
   section/panel text uses --ink / --ink-soft so light palettes work.
   (okkarhotel home-flythrough) */

.phf, .phr{max-width:1200px;margin:0 auto;padding:118px 32px 80px;color:var(--ink)}
@media(max-width:820px){.phf,.phr{padding-top:96px;padding-left:20px;padding-right:20px}}

.phf-crumb,.phr-crumb{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);display:flex;flex-wrap:wrap;gap:8px;margin:0 0 22px}
.phf-crumb a,.phr-crumb a{color:var(--muted)}
.phf-crumb a:hover,.phr-crumb a:hover{color:var(--accent)}

/* ── HOTEL hero (text over the image → always light) ── */
.phf-hero{position:relative;border-radius:22px;overflow:hidden;border:1px solid var(--line);min-height:clamp(320px,52vh,560px);display:flex;align-items:flex-end;background:#15130d}
.phf-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.phf-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(8,7,4,.92) 4%,rgba(8,7,4,.35) 45%,rgba(8,7,4,.15) 100%)}
.phf-hero__in{position:relative;z-index:2;padding:clamp(22px,4vw,48px);width:100%}
.phf-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.phf-title{font-family:var(--disp);font-weight:800;font-size:clamp(34px,5.2vw,68px);line-height:.96;letter-spacing:-.03em;color:#fff;margin:12px 0 0;text-wrap:balance}
.phf-addr{display:inline-flex;align-items:center;gap:7px;margin-top:14px;font-size:14px;color:#e9e0cf}
.phf-chips{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0 0;padding:0;list-style:none}
.phf-chips li{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:#f0e8d8;border:1px solid rgba(255,255,255,.28);border-radius:999px;padding:6px 12px}

/* ── at-a-glance ── */
.phf-glance{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin:28px 0}
.phf-glance__cell{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px}
.phf-glance__label{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.phf-glance__value{font-family:var(--disp);font-weight:700;font-size:24px;color:var(--ink);margin-top:6px;line-height:1}
.phf-glance__hint{font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-top:5px}

/* ── shared section heads ── */
.phf-sec{margin:46px 0}
.phf-eye{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.phf-h{font-family:var(--disp);font-weight:800;font-size:clamp(24px,3vw,38px);letter-spacing:-.02em;line-height:1.04;color:var(--ink);margin:10px 0 0}
.phf-h em{font-style:normal;color:var(--accent)}
.phf-body{color:var(--ink-soft);font-size:16px;line-height:1.7;margin-top:14px;max-width:64ch}

/* ── rooms grid (on hotel page) ── */
.phf-rooms{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-top:22px}
.phf-room{display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line);border-radius:18px;overflow:hidden;transition:transform .25s,border-color .25s,box-shadow .25s}
.phf-room:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:0 18px 44px rgba(0,0,0,.4)}
.phf-room__media{display:block;aspect-ratio:16/10;overflow:hidden;background:linear-gradient(135deg,#241d10,#15130d)}
.phf-room__media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1s ease}
.phf-room:hover .phf-room__media img{transform:scale(1.05)}
.phf-room__body{display:flex;flex-direction:column;gap:8px;padding:18px;flex:1}
.phf-room__title{font-family:var(--disp);font-weight:700;font-size:18px;line-height:1.15}
.phf-room__title a{color:var(--ink)}.phf-room__title a:hover{color:var(--accent)}
.phf-room__meta{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:6px}
.phf-room__desc{color:var(--muted);font-size:13.5px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.phf-room__cta{margin-top:auto;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}

/* ── good to know ── */
.phf-gtk{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:22px}
@media(max-width:680px){.phf-gtk{grid-template-columns:1fr}}
.phf-gtk h3{font-family:var(--disp);font-weight:700;font-size:16px;color:var(--ink);margin:0 0 12px}
.phf-gtk ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px}
.phf-gtk li{display:flex;align-items:flex-start;gap:9px;font-size:14px;color:var(--ink-soft)}
.phf-gtk li svg{flex:0 0 16px;width:16px;height:16px;color:var(--accent);margin-top:2px}

/* booking block spacing on these pages */
.phf-book,.phr-book{margin:28px 0}

/* ── ROOM page ── */
.phr-head h1{font-family:var(--disp);font-weight:800;font-size:clamp(30px,4.2vw,52px);line-height:1;letter-spacing:-.025em;color:var(--ink);margin:0 0 8px}
.phr-prop{color:var(--muted);font-size:15px;margin:0}
.phr-prop a{color:var(--accent)}
.phr-gallery{position:relative;margin:22px 0}
.phr-gallery__track{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;border-radius:18px;-webkit-overflow-scrolling:touch}
.phr-gallery__track::-webkit-scrollbar{height:6px}.phr-gallery__track::-webkit-scrollbar-thumb{background:var(--line);border-radius:999px}
.phr-gallery__slide{flex:0 0 100%;aspect-ratio:16/9;scroll-snap-align:start;border-radius:18px;overflow:hidden;border:1px solid var(--line);background:var(--panel)}
.phr-gallery__slide img{width:100%;height:100%;object-fit:cover;display:block}
.phr-gallery__nav{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:44px;height:44px;border-radius:50%;border:1px solid var(--line);background:var(--panel);color:var(--ink);font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(6px)}
.phr-gallery__nav:hover{border-color:var(--accent);color:var(--accent)}
.phr-gallery__nav--prev{left:12px}.phr-gallery__nav--next{right:12px}
@media(max-width:820px){.phr-gallery__nav{display:none}}
.phr-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:14px;margin:24px 0}
.phr-stat{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px}
.phr-stat strong{display:block;font-family:var(--disp);font-weight:700;font-size:24px;color:var(--ink);line-height:1}
.phr-stat span{display:block;margin-top:6px;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.phr-sec{margin:34px 0}
.phr-sec h2{font-family:var(--disp);font-weight:800;font-size:22px;letter-spacing:-.01em;color:var(--ink);margin:0 0 12px}
.phr-desc{color:var(--ink-soft);font-size:16px;line-height:1.7}
.phr-desc p{margin:0 0 12px}.phr-desc a{color:var(--accent);text-decoration:underline}
.phr-amen{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:9px 18px}
.phr-amen li{display:flex;align-items:center;gap:9px;font-size:14.5px;color:var(--ink-soft)}
.phr-amen svg{width:16px;height:16px;flex-shrink:0;color:var(--accent)}
.phr-tags{display:flex;flex-wrap:wrap;gap:7px;list-style:none;padding:0;margin:0}
.phr-tags li{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);background:var(--panel);border:1px solid var(--line);border-radius:999px;padding:6px 12px}
.phr-terms{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:20px 22px;color:var(--ink-soft);font-size:14.5px;line-height:1.7}
.phr-terms p{margin:0 0 8px}.phr-terms p:last-child{margin-bottom:0}.phr-terms strong{color:var(--ink)}
