/*
Theme Name: HP 2026
Description: Hotel Professionals redesign — bgslaw.ch-inspired premium boutique look on official HP brand colors.
Template: generatepress
Version: 0.1.0
Author: Pat + Claude
*/

:root {
  --hp-teal: #00ACA6;        /* Pantone 3265C */
  --hp-teal-soft: #BBDEDB;   /* 3265C 35% */
  --hp-teal-tint: #E6F3F2;   /* 3265C 12% */
  --hp-slate: #333C40;       /* Pantone 432C */
  --hp-slate-deep: #262d31;
  --hp-green: #004D42;       /* Pantone 3305C */
  --hp-ink: #232121;         /* Neutral Black C */
  --hp-gray: #DDE0E3;        /* 432C 17% */
  --hp-gray-mid: #7E7D7D;
  --hp-paper: #F7F8F8;
  --font-display: "Fraunces", Georgia, serif;
  --font-body: "Inter", -apple-system, "Helvetica Neue", Arial, sans-serif;
  --space: clamp(4rem, 9vw, 8.5rem);
  --pad-x: clamp(1.25rem, 5vw, 4.5rem);
}

/* ---------- base ---------- */
.hp body, body.hp-front {
  margin: 0;
  font-family: var(--font-body);
  color: var(--hp-ink);
  background: var(--hp-paper);
  -webkit-font-smoothing: antialiased;
  font-size: 1.0625rem;
  line-height: 1.65;
}
body.hp-front h1, body.hp-front h2, body.hp-front h3 {
  font-family: var(--font-display);
  font-weight: 340;
  line-height: 1.05;
  letter-spacing: -0.015em;
  margin: 0 0 1.5rem;
}
body.hp-front a { color: inherit; text-decoration: none; }
body.hp-front .site-header, body.hp-front .site-footer { display: none; } /* hide GP defaults on front page */

.hp-section { padding: var(--space) var(--pad-x); }
.hp-kicker {
  display: block;
  font-family: var(--font-body);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--hp-teal);
  margin-bottom: 1.75rem;
}
.hp-h2 { font-size: clamp(2.2rem, 5vw, 3.8rem); max-width: 18ch; }

/* ---------- reveal on scroll ---------- */
.hp-reveal { opacity: 0; transform: translateY(28px); transition: opacity .8s ease, transform .8s cubic-bezier(.2,.6,.2,1); }
.hp-reveal.is-in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .hp-reveal { opacity: 1; transform: none; transition: none; } }

/* ---------- header ---------- */
.hp-nav {
  position: fixed; inset: 0 0 auto 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.1rem var(--pad-x);
  transition: background .35s ease, box-shadow .35s ease;
}
.hp-nav.is-scrolled { background: rgba(38,45,49,.92); backdrop-filter: blur(10px); box-shadow: 0 1px 0 rgba(255,255,255,.06); }
body.hp-front .hp-logo { font-family: var(--font-body); font-weight: 700; font-size: 1.15rem; letter-spacing: -0.01em; color: #fff; }
body.hp-front .hp-logo em { font-style: normal; color: var(--hp-teal); }
body.hp-front .hp-logo small { display: block; font-weight: 400; font-size: 0.62rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--hp-teal-soft); opacity: .85; }
.hp-nav-links { display: flex; gap: 2.2rem; align-items: center; }
body.hp-front .hp-nav-links a { color: rgba(255,255,255,.85); font-size: 0.92rem; font-weight: 500; transition: color .2s; }
body.hp-front .hp-nav-links a:hover { color: var(--hp-teal); }
body.hp-front .hp-nav-lang { border: 1px solid rgba(255,255,255,.25); border-radius: 999px; padding: .3rem .85rem; font-size: .8rem; color: #fff; }
@media (max-width: 760px) { .hp-nav-links a:not(.hp-nav-lang) { display: none; } }

/* ---------- hero ---------- */
.hp-hero {
  position: relative; min-height: 100svh;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: var(--space) var(--pad-x) clamp(3rem, 7vw, 5.5rem);
  color: #fff; overflow: hidden;
  background: linear-gradient(160deg, var(--hp-slate) 0%, var(--hp-slate-deep) 55%, var(--hp-green) 130%);
}
.hp-hero video, .hp-hero .hp-hero-img {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: .42;
}
.hp-hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(35,33,33,.78), rgba(51,60,64,.25) 55%); }
.hp-hero > * { position: relative; z-index: 2; }
.hp-hero h1 {
  font-size: clamp(2.9rem, 8.5vw, 7rem);
  max-width: 14ch; margin-bottom: 1.2rem;
}
.hp-hero h1 .accent { color: var(--hp-teal); }
.hp-hero-sub { font-size: clamp(1.05rem, 1.8vw, 1.35rem); max-width: 44ch; color: var(--hp-gray); margin: 0 0 2.4rem; }
.hp-cta {
  display: inline-flex; align-items: center; gap: .7rem;
  background: var(--hp-teal); color: #fff !important;
  padding: 1rem 1.9rem; border-radius: 999px;
  font-weight: 600; font-size: .95rem;
  transition: background .25s, transform .25s;
}
.hp-cta:hover { background: #009b95; transform: translateY(-2px); }
.hp-cta--ghost { background: transparent; border: 1px solid rgba(255,255,255,.35); }
.hp-cta--ghost:hover { background: rgba(255,255,255,.08); }
.hp-hero-ctas { display: flex; gap: 1rem; flex-wrap: wrap; }

/* ---------- intro ---------- */
.hp-intro p {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 3vw, 2.3rem);
  font-weight: 340; line-height: 1.35;
  max-width: 30ch; margin: 0;
}
.hp-intro p strong { color: var(--hp-teal); font-weight: 340; }

/* ---------- services (numbered) ---------- */
.hp-services { background: #fff; }
.hp-service-list { list-style: none; margin: 3rem 0 0; padding: 0; border-top: 1px solid var(--hp-gray); }
.hp-service-list li { border-bottom: 1px solid var(--hp-gray); }
.hp-service-list a {
  display: grid; grid-template-columns: 4rem 1fr auto; gap: 1.5rem; align-items: baseline;
  padding: 1.9rem 0.5rem; transition: background .25s, padding-left .25s;
}
.hp-service-list a:hover { background: var(--hp-teal-tint); padding-left: 1.2rem; }
.hp-service-num { font-family: var(--font-display); font-size: 1rem; color: var(--hp-teal); }
.hp-service-title { font-family: var(--font-display); font-size: clamp(1.3rem, 2.6vw, 1.9rem); font-weight: 360; }
.hp-service-arrow { color: var(--hp-teal); font-size: 1.3rem; transition: transform .25s; }
.hp-service-list a:hover .hp-service-arrow { transform: translateX(6px); }
@media (max-width: 600px) { .hp-service-list a { grid-template-columns: 2.6rem 1fr auto; gap: .8rem; padding: 1.3rem .25rem; } }

/* ---------- case studies / clients ---------- */
.hp-cases { background: var(--hp-slate); color: #fff; }
.hp-cases .hp-h2 { color: #fff; }
.hp-case-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(265px, 1fr)); border-top: 1px solid rgba(255,255,255,.14); border-left: 1px solid rgba(255,255,255,.14); margin-top: 3rem; }
.hp-case-card { background: var(--hp-slate); border-right: 1px solid rgba(255,255,255,.14); border-bottom: 1px solid rgba(255,255,255,.14); padding: 2.2rem 1.8rem; min-height: 11rem; display: flex; flex-direction: column; justify-content: space-between; transition: background .3s; }
.hp-case-card:hover { background: var(--hp-green); }
.hp-case-card h3 { font-size: 1.25rem; margin: 0; color: #fff; }
.hp-case-card span { font-size: .8rem; letter-spacing: .16em; text-transform: uppercase; color: var(--hp-teal-soft); }

/* ---------- team ---------- */
.hp-team { background: #fff; }
.hp-team-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 2.2rem 1.6rem; margin-top: 3rem; }
.hp-team-card img { width: 100%; aspect-ratio: 4/5; object-fit: cover; filter: grayscale(28%); transition: filter .35s; display: block; }
.hp-team-ph { width: 100%; aspect-ratio: 4/5; display: flex; align-items: center; justify-content: center; background: linear-gradient(160deg, var(--hp-slate), var(--hp-green)); color: var(--hp-teal-soft); font-family: var(--font-display); font-size: 2.6rem; }
.hp-team-card:hover img { filter: grayscale(0%); }
.hp-team-card h3 { font-size: 1.15rem; margin: 1rem 0 0.15rem; }
.hp-team-card p { margin: 0; font-size: .85rem; color: var(--hp-gray-mid); }

/* ---------- contact ---------- */
.hp-contact { background: var(--hp-green); color: #fff; }
.hp-contact .hp-h2 { color: #fff; font-size: clamp(2.4rem, 6vw, 4.6rem); }
.hp-contact a.hp-mail { font-family: var(--font-display); font-size: clamp(1.4rem, 3.4vw, 2.6rem); color: var(--hp-teal-soft); border-bottom: 1px solid currentColor; transition: color .25s; }
.hp-contact a.hp-mail:hover { color: #fff; }
.hp-contact-meta { display: flex; gap: 3.5rem; flex-wrap: wrap; margin-top: 3.5rem; font-size: .95rem; color: var(--hp-teal-soft); }
.hp-contact-meta strong { display: block; color: #fff; font-weight: 600; margin-bottom: .3rem; }

/* ---------- footer ---------- */
.hp-foot { background: var(--hp-ink); color: var(--hp-gray-mid); padding: 2.2rem var(--pad-x); font-size: .85rem; display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.hp-foot a:hover { color: var(--hp-teal); }
