/* ============================================================
   Claudia Heidelberger — Atelier Dark
   Home page styles. Palette: copper / navy / teal on slate.
   ============================================================ */

:root {
  --ch-slate:    #1F2A33;  /* page ground            */
  --ch-slate-2:  #13202A;  /* de colores band        */
  --ch-slate-3:  #0F1A20;  /* footer                 */
  --ch-cream:    #EFE6D5;  /* primary text / light   */
  --ch-copper:   #C47A47;  /* accent / CTAs          */
  --ch-teal:     #3A8C84;  /* secondary accent       */
  --ch-red:      #B23A2E;  /* complementary accent    */
  --ch-navy:     #25404D;  /* gallery navy tile      */
  --ch-line:     rgba(239,230,213,0.13);
  --ch-maxw:     1320px;
}

.ch-body {
  margin: 0;
  background: var(--ch-slate);
  color: var(--ch-cream);
  font-family: 'Hanken Grotesk', sans-serif;
  -webkit-font-smoothing: antialiased;
}
.ch-body a { -webkit-tap-highlight-color: transparent; }

/* ---------- Masthead ---------- */
.ch-keyline { height: 4px; background: var(--ch-red); }
.ch-masthead { border-bottom: 1px solid var(--ch-line); }
.ch-masthead-inner {
  max-width: var(--ch-maxw);
  margin: 0 auto;
  padding: 46px 48px 30px;
  text-align: center;
}
.ch-eyebrow {
  font-family: 'Space Mono', monospace;
  font-size: 12px; letter-spacing: 0.34em;
  color: var(--ch-copper); text-transform: uppercase;
}
.ch-sitetitle {
  font-family: 'Bodoni Moda', serif; font-style: italic; font-weight: 600;
  font-size: 64px; line-height: 1; margin: 18px 0 24px; letter-spacing: 0.01em;
}
.ch-sitetitle a { color: var(--ch-cream); text-decoration: none; }

.ch-nav, .ch-foot-nav {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-wrap: wrap; gap: 30px; justify-content: center;
}
.ch-nav a {
  font-size: 13px; letter-spacing: 0.16em; text-transform: uppercase;
  color: rgba(239,230,213,0.85); text-decoration: none; transition: color .15s;
}
.ch-nav a:hover { color: var(--ch-copper); }
.ch-nav .ch-nav-cta, .ch-nav-cta a { color: var(--ch-red); font-weight: 700; }
.ch-nav-cta a:hover { color: var(--ch-cream); }

/* Dropdown submenus */
.ch-nav li { position: relative; }
.ch-nav .menu-item-has-children > a::after {
  content: '▾'; margin-left: 7px; font-size: 9px; opacity: 0.6; vertical-align: middle;
}
.ch-nav .sub-menu {
  list-style: none; margin: 0; padding: 8px 0;
  position: absolute; top: 100%; left: 50%; transform: translateX(-50%);
  min-width: 190px; background: var(--ch-slate-2);
  border: 1px solid var(--ch-line); box-shadow: 0 14px 34px rgba(0,0,0,0.4);
  opacity: 0; visibility: hidden; transition: opacity .15s; z-index: 200;
}
.ch-nav li:hover > .sub-menu,
.ch-nav li:focus-within > .sub-menu { opacity: 1; visibility: visible; }
.ch-nav .sub-menu li { display: block; }
.ch-nav .sub-menu a {
  display: block; text-align: left; white-space: nowrap;
  padding: 10px 18px; font-size: 12px; letter-spacing: 0.12em;
  color: rgba(239,230,213,0.85);
}
.ch-nav .sub-menu a:hover { color: var(--ch-copper); background: rgba(239,230,213,0.04); }
.ch-nav .sub-menu .menu-item-has-children > a::after { content: '▸'; float: right; }
/* Third level: fly out to the side */
.ch-nav .sub-menu .sub-menu { top: -9px; left: 100%; transform: none; }

/* ---------- Gallery ---------- */
.ch-gallery-head {
  max-width: var(--ch-maxw); margin: 0 auto;
  padding: 22px 48px 0;
  display: flex; justify-content: space-between; align-items: center;
}
.ch-gallery-cap {
  font-family: 'Space Mono', monospace; font-size: 12px;
  letter-spacing: 0.12em; color: rgba(239,230,213,0.55);
}
.ch-shuffle {
  font-family: 'Space Mono', monospace; font-size: 12px; letter-spacing: 0.12em;
  color: var(--ch-copper); text-decoration: none; transition: color .15s;
}
.ch-shuffle:hover { color: var(--ch-cream); }

.ch-gallery-wrap { max-width: var(--ch-maxw); margin: 0 auto; padding: 16px 48px 10px; }

/* Justified rows are assembled by justify.js, which sets each row's flex-basis.
   Until JS runs, tiles fall back to a sensible flexible grid. */
.ch-gallery { display: flex; flex-wrap: wrap; gap: 14px; }
.ch-tile {
  position: relative; overflow: hidden; cursor: pointer;
  flex: 1 1 220px; min-height: 200px;
  background-size: cover; background-position: center;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.07);
  display: flex; align-items: flex-end; text-decoration: none;
  transition: filter .15s;
}
.ch-tile:hover { filter: brightness(1.08); }
.ch-tile-probe { position: absolute; width: 1px; height: 1px; opacity: 0; pointer-events: none; }
.ch-tile-label {
  font-family: 'Space Mono', monospace; font-size: 11px; letter-spacing: 0.1em;
  color: var(--ch-cream); padding: 11px 13px;
  text-shadow: 0 1px 6px rgba(0,0,0,0.5); opacity: 0.95;
}
.ch-tile-num {
  position: absolute; top: 9px; right: 12px;
  font-family: 'Space Mono', monospace; font-size: 10px;
  color: var(--ch-cream); opacity: 0.6; text-shadow: 0 1px 6px rgba(0,0,0,0.5);
}
.ch-gallery-empty {
  max-width: var(--ch-maxw); margin: 0 auto; padding: 40px 48px;
  font-family: 'Space Mono', monospace; font-size: 14px; color: rgba(239,230,213,0.6);
}

/* ---------- Shared type ---------- */
.ch-kicker {
  font-family: 'Space Mono', monospace; font-size: 12px;
  letter-spacing: 0.26em; text-transform: uppercase;
}
.ch-kicker-teal { color: var(--ch-teal); }
.ch-h2 {
  font-family: 'Bodoni Moda', serif; font-style: italic; font-weight: 600;
  font-size: 46px; line-height: 1.05; color: var(--ch-cream); margin: 16px 0 18px;
}
.ch-h2-light { font-weight: 500; }
.ch-lead { font-size: 17px; line-height: 1.65; color: rgba(239,230,213,0.72); margin: 0 0 30px; max-width: 480px; }
.ch-btn {
  display: inline-block; font-family: 'Space Mono', monospace; font-size: 13px;
  letter-spacing: 0.1em; text-transform: uppercase; color: var(--ch-slate-2);
  background: var(--ch-copper); padding: 16px 30px; text-decoration: none; transition: background .15s;
}
.ch-btn:hover { background: var(--ch-cream); }

/* ---------- De Colores ---------- */
.ch-decolores { background: var(--ch-slate-2); border-top: 1px solid rgba(239,230,213,0.1); margin-top: 30px; }
.ch-decolores-inner {
  max-width: var(--ch-maxw); margin: 0 auto; padding: 72px 48px;
  display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 56px; align-items: center;
}
.ch-decolores-media {
  height: 300px; position: relative; overflow: hidden;
  background: repeating-linear-gradient(135deg, rgba(0,0,0,0.12) 0 7px, transparent 7px 15px), var(--ch-teal);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.08);
  display: flex; align-items: flex-end;
}
.ch-decolores-img { width: 100%; height: 100%; object-fit: cover; }
.ch-media-ph { font-family: 'Space Mono', monospace; font-size: 11px; letter-spacing: 0.12em; color: #08201e; padding: 13px 15px; }

/* ---------- Newsletter ---------- */
.ch-newsletter { background: var(--ch-slate); border-top: 1px solid rgba(239,230,213,0.1); }
.ch-newsletter-inner { max-width: var(--ch-maxw); margin: 0 auto; padding: 72px 48px; text-align: center; }
.ch-news-sub { font-size: 16px; color: rgba(239,230,213,0.65); margin: 10px auto 28px; max-width: 460px; }
.ch-news-form { display: flex; gap: 12px; max-width: 540px; margin: 0 auto 16px; }
.ch-news-input {
  flex: 1; background: var(--ch-cream); color: var(--ch-slate);
  border: 1px solid var(--ch-copper); border-radius: 2px; padding: 16px 18px;
  font-family: 'Hanken Grotesk', sans-serif; font-size: 16px; outline: none;
}
.ch-news-input::placeholder { color: rgba(31,42,51,0.45); }
.ch-news-btn {
  font-family: 'Space Mono', monospace; font-size: 13px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--ch-slate-2); background: var(--ch-copper);
  border: none; padding: 0 30px; cursor: pointer; transition: background .15s;
}
.ch-news-btn:hover { background: var(--ch-cream); }
.ch-news-consent {
  display: flex; gap: 10px; justify-content: center; align-items: center;
  font-family: 'Space Mono', monospace; font-size: 12px; color: rgba(239,230,213,0.5); cursor: pointer;
}
.ch-news-consent input { accent-color: var(--ch-copper); width: 15px; height: 15px; }

/* ---------- Journal ---------- */
.ch-journal { border-top: 1px solid rgba(239,230,213,0.1); }
.ch-journal-inner { max-width: var(--ch-maxw); margin: 0 auto; padding: 72px 48px; }
.ch-journal-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 34px; }
.ch-allposts {
  font-family: 'Space Mono', monospace; font-size: 12px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--ch-copper); text-decoration: none; transition: color .15s;
}
.ch-allposts:hover { color: var(--ch-cream); }
.ch-journal-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.ch-post-thumb {
  position: relative; display: block; height: 190px; overflow: hidden;
  background: repeating-linear-gradient(135deg, rgba(0,0,0,0.14) 0 6px, transparent 6px 13px), var(--ch-copper);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.07);
}
.ch-post-img { width: 100%; height: 100%; object-fit: cover; }
.ch-post-tag {
  position: absolute; left: 0; bottom: 0;
  font-family: 'Space Mono', monospace; font-size: 10px; letter-spacing: 0.1em;
  color: #22150c; padding: 11px 12px; background: rgba(196,122,71,0.0);
}
.ch-post-date { font-family: 'Space Mono', monospace; font-size: 11px; letter-spacing: 0.12em; color: var(--ch-teal); margin: 16px 0 7px; }
.ch-post-title { font-family: 'Bodoni Moda', serif; font-weight: 500; font-size: 24px; line-height: 1.2; margin: 0 0 9px; }
.ch-post-title a { color: var(--ch-cream); text-decoration: none; }
.ch-post-title a:hover { color: var(--ch-copper); }
.ch-post-excerpt { font-size: 15px; line-height: 1.55; color: rgba(239,230,213,0.6); margin: 0; }

/* ---------- Footer ---------- */
.ch-footer { background: var(--ch-slate-3); border-top: 1px solid rgba(239,230,213,0.08); }
.ch-footer-inner {
  max-width: var(--ch-maxw); margin: 0 auto; padding: 46px 48px;
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 20px;
}
.ch-footer-name { font-family: 'Bodoni Moda', serif; font-style: italic; font-size: 24px; color: var(--ch-cream); }
.ch-footer-meta { font-family: 'Space Mono', monospace; font-size: 11px; letter-spacing: 0.1em; color: rgba(239,230,213,0.45); margin-top: 5px; }
.ch-foot-nav a {
  font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(239,230,213,0.6); text-decoration: none; transition: color .15s;
}
.ch-foot-nav a:hover { color: var(--ch-copper); }
.ch-footer-credit { font-family: 'Space Mono', monospace; font-size: 11px; letter-spacing: 0.08em; color: rgba(239,230,213,0.3); }

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
  .ch-sitetitle { font-size: 44px; }
  .ch-decolores-inner { grid-template-columns: 1fr; gap: 32px; }
  .ch-journal-grid { grid-template-columns: 1fr; }
  .ch-h2 { font-size: 34px; }
}
@media (max-width: 600px) {
  .ch-masthead-inner, .ch-gallery-head, .ch-gallery-wrap,
  .ch-decolores-inner, .ch-newsletter-inner, .ch-journal-inner, .ch-footer-inner {
    padding-left: 22px; padding-right: 22px;
  }
  .ch-news-form { flex-direction: column; }
  .ch-news-btn { padding: 14px 0; }
}
