/* ============================================================
   "Make a Calendar" builder — controls panel + live preview.
   Preview theming uses its own --pv-* tokens so the chosen
   palette never leaks into the site chrome.
   ============================================================ */

.builder {
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr);
  gap: var(--sp-6);
  align-items: start;
  padding-block: var(--sp-6) var(--sp-5);
}

/* ---------- Controls panel ---------- */
.builder-panel {
  position: sticky;
  top: var(--sp-4);
  background: var(--paper-raised);
  border: 1px solid var(--line);
  border-radius: var(--r-3);
  box-shadow: var(--shadow-1);
  padding: var(--sp-5);
}

.builder-heading {
  font-size: var(--text-xl);
  margin-bottom: var(--sp-1);
}
.builder-sub {
  margin: 0 0 var(--sp-4);
  font-size: var(--text-sm);
  color: var(--ink-soft);
}

.bgroup { margin-bottom: var(--sp-4); }

.blabel {
  display: block;
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-bottom: var(--sp-2);
}
.bhint {
  font-size: var(--text-xs);
  color: var(--ink-faint);
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
}

.field-text {
  width: 100%;
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  color: var(--ink);
  background: var(--paper-raised);
  border: 1px solid var(--line);
  border-radius: var(--r-2);
  padding: 0.55em 0.9em;
  transition: border-color var(--t-fast) var(--ease);
}
.field-text:hover { border-color: var(--ink-faint); }
.field-text::placeholder { color: var(--ink-faint); }

/* Month chips */
.chip-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-1);
}
.chip {
  font-family: var(--font-ui);
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--ink-soft);
  background: var(--paper-sunken);
  border: 1px solid var(--line);
  border-radius: var(--r-1);
  padding: 0.45em 0;
  cursor: pointer;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease),
              border-color var(--t-fast) var(--ease);
}
.chip:hover { border-color: var(--ink-faint); color: var(--ink); }
.chip[aria-pressed="true"] {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}
.chip-shortcuts {
  margin-top: var(--sp-2);
  font-size: var(--text-xs);
  color: var(--ink-faint);
  display: flex;
  gap: var(--sp-2);
  align-items: center;
}
.linklike {
  background: none;
  border: none;
  padding: 0;
  font: inherit;
  font-weight: 500;
  color: var(--accent-deep);
  cursor: pointer;
}
.linklike:hover { color: var(--accent); }

/* Segmented buttons (builder variant uses <button>) */
.seg button {
  font-family: var(--font-ui);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--ink-soft);
  background: none;
  border: none;
  border-radius: var(--r-pill);
  padding: 0.4em 1em;
  cursor: pointer;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.seg button:hover { color: var(--ink); }
.seg button[aria-pressed="true"] {
  background: var(--paper-raised);
  color: var(--ink);
  box-shadow: var(--shadow-1);
}

/* Theme swatches */
.swatch-row { display: flex; gap: var(--sp-2); }
.swatch {
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  background: var(--sw);
  border: 2px solid transparent;
  box-shadow: inset 0 0 0 2px var(--paper-raised);
  cursor: pointer;
  transition: transform var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
}
.swatch:hover { transform: scale(1.08); }
.swatch[aria-pressed="true"] { border-color: var(--ink); }

.bcheck {
  display: flex;
  gap: var(--sp-2);
  align-items: center;
  font-size: var(--text-sm);
  color: var(--ink);
  cursor: pointer;
}
.bcheck input { accent-color: var(--accent); width: 1rem; height: 1rem; }

/* Two tidy rows: Print + Download, then Share + Reset. */
.builder-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-2);
  margin: var(--sp-5) 0 var(--sp-3);
}
.builder-actions .btn {
  justify-content: center;
  white-space: nowrap;
  padding-block: 0.65em;
}
.builder-actions .btn svg { flex: none; }

/* ---------- Photo calendar ---------- */
.photo-tiles {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-1);
  margin-top: var(--sp-2);
}
.photo-tile {
  position: relative;
  aspect-ratio: 4 / 3;
  border-radius: var(--r-1);
  overflow: hidden;
  background-size: cover;
  background-position: center;
}
.photo-tile .photo-pick {
  position: absolute;
  inset: 0;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1px;
  border: 1px dashed var(--line);
  border-radius: var(--r-1);
  background: var(--paper-sunken);
  color: var(--ink-faint);
  font-size: var(--text-md);
  cursor: pointer;
  transition: border-color var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.photo-tile .photo-pick:hover { border-color: var(--accent); color: var(--ink); }
.photo-tile .photo-pick span { font-size: var(--text-xs); font-weight: 500; }
.photo-tile .photo-pick b { font-weight: 400; line-height: 1; }
.photo-tile.has-img .photo-pick {
  background: transparent;
  border: none;
  justify-content: flex-end;
  padding-bottom: 2px;
  color: #fff;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.7);
}
.photo-tile .photo-x {
  position: absolute;
  top: 3px;
  right: 3px;
  width: 18px;
  height: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  border-radius: 50%;
  background: rgba(25, 21, 16, 0.75);
  color: #fff;
  font-size: 12px;
  line-height: 1;
  cursor: pointer;
}

.pv-photo { margin: 0 0 var(--sp-3); }
.pv-photo img {
  display: block;
  width: 100%;
  height: clamp(180px, 30vw, 340px);
  object-fit: cover;
  border-radius: var(--r-3);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-2);
}

/* ---------- Preview ---------- */
.builder-preview { min-width: 0; }

.builder-preview[data-theme="terracotta"] { --pv-accent: #c05b33; --pv-accent-deep: #9a411d; }
.builder-preview[data-theme="teal"]       { --pv-accent: #31695e; --pv-accent-deep: #224b43; }
.builder-preview[data-theme="plum"]       { --pv-accent: #7a3e62; --pv-accent-deep: #5a2c48; }
.builder-preview[data-theme="ink"]        { --pv-accent: #4a4540; --pv-accent-deep: #2e2a26; }

.builder-preview[data-font="serif"] { --pv-display: var(--font-display); }
.builder-preview[data-font="sans"]  { --pv-display: var(--font-ui); }

/* --pv-* fallbacks let these styles work outside the builder (year view). */
.pv-custom-title {
  font-family: var(--pv-display, var(--font-display));
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--pv-accent-deep, var(--accent-deep));
  margin-bottom: var(--sp-4);
}

.pv-page { margin-bottom: var(--sp-7); }
.pv-page:last-child { margin-bottom: 0; }

.pv-page-title {
  font-family: var(--pv-display, var(--font-display));
  font-size: 1.7rem;
  font-weight: 600;
  color: var(--pv-accent, var(--accent));
  margin-bottom: var(--sp-3);
}

.pv-months { display: grid; gap: var(--sp-4); }
.pv-per-1  .pv-months { grid-template-columns: 1fr; }
.pv-per-2  .pv-months { grid-template-columns: 1fr; }
.pv-per-4  .pv-months,
.pv-per-6  .pv-months { grid-template-columns: repeat(2, 1fr); }
.pv-per-12 .pv-months { grid-template-columns: repeat(3, 1fr); }

/* Compact mini-months when several share a page */
.pv-per-2 .pv-day { min-height: clamp(34px, 4.5vw, 56px); }
.pv-per-4 .pv-day,
.pv-per-6 .pv-day { min-height: clamp(24px, 3vw, 38px); padding: 2px 5px; }
.pv-per-12 .pv-day { min-height: clamp(18px, 2vw, 28px); padding: 1px 4px; }

.pv-per-2 .pv-title { font-size: 1.3rem; }
.pv-per-4 .pv-title,
.pv-per-6 .pv-title { font-size: 1.05rem; margin-bottom: var(--sp-2); }
.pv-per-12 .pv-title { font-size: 0.95rem; margin-bottom: var(--sp-1); }

.pv-per-4 .pv-day .num,
.pv-per-6 .pv-day .num,
.pv-per-12 .pv-day .num { font-size: var(--text-xs); }
.pv-per-12 .pv-dow > div,
.pv-per-4 .pv-dow > div,
.pv-per-6 .pv-dow > div { padding: 4px 5px; letter-spacing: 0.04em; font-size: 0.6rem; }
.pv-per-4 .pv-day.is-today .num,
.pv-per-6 .pv-day.is-today .num,
.pv-per-12 .pv-day.is-today .num { width: 1.6em; height: 1.6em; }

.pv-month { min-width: 0; }

.pv-title {
  font-family: var(--pv-display, var(--font-display));
  font-size: 1.7rem;
  font-weight: 600;
  margin-bottom: var(--sp-3);
}
.pv-title span {
  font-weight: 400;
  color: var(--pv-accent, var(--accent));
  font-style: italic;
}
.pv-title a { color: inherit; }
.pv-title a:hover { color: var(--pv-accent, var(--accent)); }
.builder-preview[data-font="sans"] .pv-title span { font-style: normal; }

.pv-grid {
  background: var(--paper-raised);
  border: 1px solid var(--line);
  border-radius: var(--r-3);
  box-shadow: var(--shadow-2);
  overflow: hidden;
}

.pv-dow {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  border-bottom: 1px solid var(--line);
}
.pv-dow > div {
  padding: var(--sp-2) var(--sp-3);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--ink-faint);
  text-align: right;
}

.pv-week {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
}
.pv-week + .pv-week .pv-day { border-top: 1px solid var(--line-soft); }
.pv-day + .pv-day { border-left: 1px solid var(--line-soft); }

.pv-day {
  min-height: clamp(48px, 7.5vw, 96px);
  padding: var(--sp-1) var(--sp-2);
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}
.pv-day .num {
  font-size: var(--text-sm);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum";
  padding: 0.3em 0;
}
.pv-day.is-weekend { background: var(--c-weekend); }
.pv-day.is-outside .num { color: var(--ink-faint); opacity: 0.55; font-weight: 400; }
.pv-day.is-today .num {
  background: var(--pv-accent, var(--accent));
  color: #fff;
  font-weight: 600;
  width: 1.8em;
  height: 1.8em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  padding: 0;
}

.pv-notes {
  margin-top: var(--sp-3);
  border: 1px solid var(--line);
  border-radius: var(--r-2);
  background:
    repeating-linear-gradient(
      to bottom,
      transparent 0,
      transparent 27px,
      var(--line-soft) 27px,
      var(--line-soft) 28px
    ),
    var(--paper-raised);
  min-height: 140px;
  padding: var(--sp-2) var(--sp-3);
}
.pv-notes span {
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--ink-faint);
}

.pv-empty { padding: var(--sp-5) 0; }

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
  .builder { grid-template-columns: 1fr; }
  .builder-panel { position: static; }
}

@media (max-width: 640px) {
  .pv-per-4 .pv-months,
  .pv-per-6 .pv-months { grid-template-columns: 1fr; }
  .pv-per-12 .pv-months { grid-template-columns: repeat(2, 1fr); }
}

/* ---------- Print: only the preview, one month per page ---------- */
@media print {
  .builder {
    display: block;
    padding: 0;
  }
  .builder-panel { display: none !important; }

  .pv-custom-title {
    font-size: 22pt;
    color: #111;
  }

  .pv-page {
    break-inside: avoid;
    break-after: page;
    margin: 0;
  }
  .pv-page:last-child { break-after: auto; }
  .pv-page-title { color: #111; font-size: 20pt; }

  .pv-title { color: #111; font-size: 22pt; }
  .pv-per-2 .pv-title { font-size: 15pt; }
  .pv-per-4 .pv-title,
  .pv-per-6 .pv-title { font-size: 12pt; }
  .pv-per-12 .pv-title { font-size: 10pt; }
  .pv-title span { color: var(--pv-accent, #555); }

  .pv-grid {
    border: 1px solid #999;
    border-radius: 0;
    box-shadow: none;
    background: #fff;
  }
  .pv-dow { border-bottom: 1px solid #999; }
  .pv-dow > div { color: #444; }
  .pv-week + .pv-week .pv-day { border-top: 1px solid #ccc; }
  .pv-day + .pv-day { border-left: 1px solid #ccc; }
  .pv-day { background: #fff !important; }
  .pv-day .num { color: #111; }
  .pv-day.is-outside .num { color: #bbb; opacity: 1; }
  .pv-day.is-today .num {
    background: none;
    color: #111;
    border: 1.5pt solid #111;
  }

  .pv-per-1.pv-page .pv-weeks-4 .pv-day { height: 1.7in; }
  .pv-per-1.pv-page .pv-weeks-5 .pv-day { height: 1.35in; }
  .pv-per-1.pv-page .pv-weeks-6 .pv-day { height: 1.1in; }

  /* Photo months: image on top, compressed grid below, one page total */
  .pv-photo { margin-bottom: 0.18in; }
  .pv-photo img {
    height: 3.3in;
    border-radius: 0;
    box-shadow: none;
    border: 1px solid #999;
  }
  .pv-per-1.pv-page .has-photo.pv-weeks-4 .pv-day { height: 1.05in; }
  .pv-per-1.pv-page .has-photo.pv-weeks-5 .pv-day { height: 0.85in; }
  .pv-per-1.pv-page .has-photo.pv-weeks-6 .pv-day { height: 0.7in; }
  .has-photo .pv-title { font-size: 16pt; }
  .pv-per-2 .pv-day { height: 0.55in; min-height: 0; }
  .pv-per-4 .pv-day,
  .pv-per-6 .pv-day { height: 0.32in; min-height: 0; padding: 2pt 4pt; }
  .pv-per-12 .pv-day { height: 0.22in; min-height: 0; padding: 1pt 3pt; }
  .pv-per-12 .pv-day .num,
  .pv-per-4 .pv-day .num,
  .pv-per-6 .pv-day .num { font-size: 7pt; }

  .pv-notes {
    background:
      repeating-linear-gradient(
        to bottom,
        transparent 0,
        transparent 27px,
        #ddd 27px,
        #ddd 28px
      ),
      #fff;
    border-color: #999;
    border-radius: 0;
  }
}
