/* ============================================================
   Page-specific styles (inner pages)
   ============================================================ */

/* SKI AREAS --------------------------------------------------- */
.region-tabs { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--ink); border-bottom: 1px solid var(--ink); }
.region-tab {
  display: flex; align-items: center; gap: 14px;
  padding: 22px 24px; text-align: left;
  border-right: 1px solid var(--line);
  cursor: pointer;
  background: var(--paper);
  transition: background .2s, color .2s;
}
.region-tab:last-child { border-right: 0; }
.region-tab .mono { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--smoke); min-width: 28px; }
.region-tab .lbl { font-family: var(--font-display); font-weight: 600; font-size: 18px; letter-spacing: -0.01em; flex: 1; }
.region-tab .ct { font-family: var(--font-mono); font-size: 12px; color: var(--smoke); }
.region-tab:hover { background: var(--paper-2); }
.region-tab.active { background: var(--ink); color: var(--paper); }
.region-tab.active .mono { color: var(--red); }
.region-tab.active .ct { color: var(--smoke-2); }

.resort-table { border-top: 1px solid var(--ink); }
.resort-row {
  display: grid; grid-template-columns: 2.6fr 0.8fr 1fr 0.7fr 0.7fr 1fr;
  align-items: center;
  padding: 22px 0;
  border-bottom: 1px solid var(--line);
  cursor: default;
  transition: padding .2s, background .2s;
}
.resort-row:not(.head):hover { padding-left: 12px; background: linear-gradient(90deg, var(--paper-2), transparent); }
.resort-row.head { padding: 14px 0; border-bottom: 1px solid var(--ink); }
.resort-row .name { font-family: var(--font-display); font-weight: 600; font-size: 22px; letter-spacing: -0.015em; }
.resort-row span:not(.name):not(.cta):not(.mono) { font-family: var(--font-mono); font-size: 13px; color: var(--ink); }
.resort-row .cta { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--red); text-align: right; opacity: 0; transition: opacity .2s; }
.resort-row:not(.head):hover .cta { opacity: 1; }

@media (max-width: 760px) {
  .region-tabs { grid-template-columns: repeat(2, 1fr); }
  .region-tab:nth-child(2) { border-right: 0; }
  .resort-row { grid-template-columns: 1fr 0.6fr 0.7fr; gap: 8px; }
  .resort-row > *:nth-child(n+4) { display: none; }
}

/* PROGRAMS ---------------------------------------------------- */
.program-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center;
  padding-block: 56px;
  border-bottom: 1px solid var(--line);
}
.program-row:first-child { padding-top: 0; }
.program-row:last-child { border-bottom: 0; }
.program-row.flip .program-media { order: 2; }
.program-media { position: relative; }
.program-media .ph-img { aspect-ratio: 4/5; }
.program-stat {
  position: absolute; bottom: -28px; right: -28px;
  background: var(--ink); color: var(--paper); padding: 24px 28px; min-width: 220px;
  border-radius: 4px;
}
.program-row.flip .program-stat { right: auto; left: -28px; background: var(--red); }
.program-stat .big { font-family: var(--font-display); font-weight: 700; font-size: 56px; letter-spacing: -0.035em; line-height: 1; display: block; }
.program-stat .lbl { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; opacity: 0.75; display: block; margin-top: 6px; max-width: 18ch; }

@media (max-width: 900px) {
  .program-row { grid-template-columns: 1fr; gap: 32px; }
  .program-row.flip .program-media { order: 0; }
  .program-stat { right: 16px; bottom: 16px; min-width: auto; padding: 16px 20px; }
  .program-row.flip .program-stat { left: auto; right: 16px; }
}

/* STATISTICS ------------------------------------------------- */
.chart-grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: 32px; }
.big-chart, .donut-card { border: 1px solid var(--line); padding: 32px; background: var(--paper); }
.chart-head { display: flex; justify-content: space-between; align-items: baseline; }

.donut-legend { display: grid; gap: 10px; margin-top: 16px; }
.donut-legend .row { display: grid; grid-template-columns: 14px 1fr auto; gap: 10px; align-items: center; padding: 6px 0; border-bottom: 1px dashed var(--line); }
.donut-legend .row:last-child { border-bottom: 0; }
.donut-legend .sw { width: 12px; height: 12px; }
.donut-legend .lbl { font-size: 13px; }
.donut-legend .v { font-family: var(--font-mono); font-size: 12px; color: var(--ink); }

.persona-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.persona-card {
  padding: 32px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--paper);
}
.persona-card .bar { height: 6px; }

.method-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; margin-top: 56px; border-top: 1px solid rgba(255,255,255,0.14); }
.method-card { padding: 32px 24px; border-right: 1px solid rgba(255,255,255,0.14); }
.method-card:last-child { border-right: 0; }

@media (max-width: 960px) {
  .chart-grid { grid-template-columns: 1fr; }
  .persona-grid { grid-template-columns: repeat(2, 1fr); }
  .method-grid { grid-template-columns: repeat(2, 1fr); }
}

/* RESOURCES -------------------------------------------------- */
.resource-toolbar { display: flex; justify-content: space-between; align-items: center; gap: 24px; margin-bottom: 32px; flex-wrap: wrap; }
.filters { display: flex; flex-wrap: wrap; gap: 8px; }
.chip {
  padding: 10px 16px; border-radius: 999px; border: 1px solid var(--line);
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase;
  cursor: pointer; transition: background .2s, color .2s, border-color .2s;
}
.chip:hover { border-color: var(--ink); }
.chip.active { background: var(--ink); color: var(--paper); border-color: var(--ink); }

.resource-list { border-top: 1px solid var(--ink); }
.resource-row {
  display: grid; grid-template-columns: 64px 100px 1fr 200px 130px;
  gap: 24px; align-items: center;
  padding: 26px 0;
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  transition: padding .2s, background .25s;
}
.resource-row:hover { padding-left: 12px; background: linear-gradient(90deg, var(--paper-2), transparent); }
.resource-row .year { color: var(--red); font-size: 13px; }
.resource-row .type { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; padding: 4px 10px; border: 1px solid var(--ink); justify-self: start; border-radius: 999px; }
.resource-row .meta h3 { font-family: var(--font-display); font-weight: 600; font-size: 22px; letter-spacing: -0.015em; line-height: 1.2; }
.resource-row .meta p { color: var(--smoke); font-size: 14px; line-height: 1.5; margin-top: 6px; max-width: 64ch; }
.resource-row .size { color: var(--smoke); font-size: 11px; }
.resource-row .dl {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
  text-align: right; color: var(--ink);
  transition: color .2s, gap .2s;
}
.resource-row:hover .dl { color: var(--red); }

.locked-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.15);
  padding: 32px;
}
.locked-card .lock-row { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--red); }
.locked-card .lock-rows { display: grid; gap: 0; border-top: 1px solid rgba(255,255,255,0.12); }
.locked-card .lock-feature {
  display: grid; grid-template-columns: 32px 1fr 24px; gap: 12px; align-items: center;
  padding: 14px 0; border-bottom: 1px solid rgba(255,255,255,0.08);
  font-size: 14px; color: rgba(246,243,238,0.8);
}
.locked-card .lock-feature .mono { color: var(--smoke-2); font-size: 11px; }

@media (max-width: 800px) {
  .resource-row { grid-template-columns: 1fr; gap: 8px; padding: 20px 0; }
  .resource-row .type { justify-self: start; }
  .resource-row .dl { text-align: left; }
  .section-dark .container > div { grid-template-columns: 1fr !important; }
}

/* NEWS -------------------------------------------------------- */
.news-toolbar { display: flex; justify-content: space-between; align-items: center; gap: 24px; margin-bottom: 48px; flex-wrap: wrap; }

.news-feature {
  display: grid; grid-template-columns: 1.2fr 1fr; gap: 48px; align-items: center;
  padding-block: 8px;
}
.news-feature .ph-img { aspect-ratio: 4/3; }
.news-feature .meta { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--smoke); display: flex; gap: 12px; flex-wrap: wrap; }
.news-feature .meta .tag { color: var(--red); }
.news-feature h2 { transition: color .2s; }
.news-feature:hover h2 { color: var(--red); }

@media (max-width: 900px) { .news-feature { grid-template-columns: 1fr; gap: 24px; } }

/* CONTACT ----------------------------------------------------- */
.contact-grid { display: grid; grid-template-columns: 0.9fr 1.6fr; gap: 64px; align-items: start; }
.contact-side { display: grid; gap: 36px; padding-right: 24px; border-right: 1px solid var(--line); }
.contact-block .mono { display: block; margin-bottom: 12px; color: var(--smoke); }
.contact-block .addr { font-size: 16px; line-height: 1.6; }
.contact-block .contact-list { list-style: none; display: grid; gap: 12px; }
.contact-block .contact-list li { display: grid; grid-template-columns: 80px 1fr; gap: 12px; align-items: baseline; padding: 8px 0; border-bottom: 1px dashed var(--line); }
.contact-block .contact-list li span { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--smoke); }
.contact-block .contact-list li a { font-size: 15px; }
.contact-block .contact-list li a:hover { color: var(--red); }

.contact-form-wrap { }
.contact-form { display: grid; gap: 28px; }
.contact-form .form-head { display: grid; gap: 8px; padding-bottom: 16px; border-bottom: 1px solid var(--ink); }
.contact-form .form-head .mono { color: var(--smoke); }
.contact-form .field { display: grid; gap: 10px; }
.contact-form label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink); }
.contact-form input, .contact-form textarea {
  background: var(--paper); border: 1px solid var(--line); border-bottom: 1px solid var(--ink);
  padding: 14px 0; font-family: var(--font-text); font-size: 18px; color: var(--ink);
  outline: none; transition: border-color .2s, padding .2s;
  border-radius: 0;
}
.contact-form input { border-left: 0; border-right: 0; border-top: 0; }
.contact-form textarea {
  border: 1px solid var(--line); padding: 14px 16px; resize: vertical;
  font-family: var(--font-text);
}
.contact-form input:focus, .contact-form textarea:focus { border-color: var(--red); }
.contact-form input.err, .contact-form textarea.err { border-color: var(--red); background: var(--red-tint); }
.contact-form input::placeholder, .contact-form textarea::placeholder { color: var(--smoke-2); }
.contact-form .field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }
.contact-form .err-text { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--red); }

.topic-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.topic-chip {
  padding: 14px 16px; border: 1px solid var(--line);
  font-family: var(--font-text); font-size: 14px; text-align: left;
  cursor: pointer; transition: background .2s, color .2s, border-color .2s;
  background: var(--paper);
}
.topic-chip:hover { border-color: var(--ink); }
.topic-chip.active { background: var(--ink); color: var(--paper); border-color: var(--ink); }

.contact-form .form-foot {
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  padding-top: 16px; border-top: 1px solid var(--line);
}

.contact-success {
  padding: 48px;
  background: var(--paper-2);
  border: 1px solid var(--ink);
}

@media (max-width: 900px) {
  .contact-grid { grid-template-columns: 1fr; gap: 48px; }
  .contact-side { padding-right: 0; border-right: 0; padding-bottom: 32px; border-bottom: 1px solid var(--line); }
  .contact-form .field-row { grid-template-columns: 1fr; gap: 28px; }
  .topic-grid { grid-template-columns: repeat(2, 1fr); }
}
