/* ============================================================
   Clock + Calendar — bangun.neocities.org/clock.html
   Analog + digital clock, calendar with Indonesian holidays,
   stopwatch, timer, pomodoro. Theme-aware.
   ============================================================ */

.clock-app {
  --clk-bg:       var(--bg, #1a0d1a);
  --clk-fg:       var(--fg, #ffd6e7);
  --clk-fg-dim:   var(--fg-dim, #b08a9c);
  --clk-accent:   var(--hot-pink, #ff77c8);
  --clk-accent-2: var(--cyan, #7af0ff);
  --clk-accent-3: var(--amber, #ffc857);
  --clk-lime:     var(--lime, #a8ff60);
  --clk-border:   var(--border, #4a2c3f);
  --clk-danger:   #ff5577;
  --clk-islam:    #5fd97a;
  --clk-cuti:     #ffa847;
  --clk-face-1:   #2a1325;
  --clk-face-2:   #110510;
  --clk-tick:     var(--fg-dim, #b08a9c);
  --clk-tick-major: var(--hot-pink, #ff77c8);
  --clk-hand-hour:   var(--hot-pink, #ff77c8);
  --clk-hand-minute: var(--cyan, #7af0ff);
  --clk-hand-second: var(--amber, #ffc857);
  --clk-pivot:    var(--hot-pink, #ff77c8);
  --clk-today-bg: var(--hot-pink, #ff77c8);
  --clk-today-fg: var(--bg, #1a0d1a);
  --clk-holiday-fg: var(--bg, #1a0d1a);

  --clk-mono:    var(--font-mono, "VT323", monospace);
  --clk-display: var(--font-display, "Press Start 2P", monospace);
  --clk-body:    var(--font-body, "Source Serif 4", Georgia, serif);

  display: block;
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 0 60px;
  color: var(--clk-fg);
  font-family: var(--clk-mono);
}

/* ============================================================
   Header
   ============================================================ */
.clock-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 0 18px;
  flex-wrap: wrap;
  gap: 12px;
  border-bottom: 1px dashed var(--clk-border);
  margin-bottom: 24px;
}
.clock-header__left,
.clock-header__right { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.clock-title {
  font-family: var(--clk-display);
  font-size: 16px;
  color: var(--clk-accent);
  margin: 0;
  letter-spacing: 1px;
  text-shadow: 0 0 8px var(--clk-accent);
}
.clock-greet {
  font-family: var(--clk-mono);
  font-size: 17px;
  color: var(--clk-fg-dim);
  font-style: italic;
}
.clock-tz {
  font-family: var(--clk-mono);
  font-size: 14px;
  color: var(--clk-fg-dim);
  border: 1px dashed var(--clk-border);
  padding: 2px 8px;
  cursor: pointer;
  transition: all 0.12s;
}
.clock-tz:hover {
  color: var(--clk-accent);
  border-color: var(--clk-accent);
}
.clock-toggle {
  background: transparent;
  border: 1px solid var(--clk-border);
  color: var(--clk-fg);
  padding: 2px 10px;
  font-family: var(--clk-mono);
  font-size: 14px;
  cursor: pointer;
  transition: all 0.12s;
}
.clock-toggle:hover {
  border-color: var(--clk-accent);
  color: var(--clk-accent);
}
.clock-toggle.is-on {
  border-color: var(--clk-accent);
  color: var(--clk-accent);
  background: rgba(255, 119, 200, 0.08);
}

/* ============================================================
   Grid
   ============================================================ */
.clock-grid {
  display: grid;
  grid-template-columns: minmax(360px, 1fr) minmax(360px, 1.2fr);
  gap: 18px;
  margin-bottom: 18px;
}
@media (max-width: 900px) {
  .clock-grid { grid-template-columns: 1fr; }
}

.clock-card {
  border: 1px solid var(--clk-border);
  background: rgba(0, 0, 0, 0.18);
  padding: 20px 22px;
  position: relative;
}
.clock-card::before {
  content: "";
  position: absolute;
  top: -1px; left: -1px; right: -1px; bottom: -1px;
  border: 1px solid var(--clk-accent);
  opacity: 0.18;
  pointer-events: none;
}

/* ============================================================
   Analog clock (SVG)
   ============================================================ */
.analog-wrap {
  display: flex;
  justify-content: center;
  padding: 10px 0 18px;
}
.analog {
  width: 100%;
  max-width: 320px;
  height: auto;
  filter: drop-shadow(0 4px 24px rgba(255, 119, 200, 0.18));
  transition: transform 0.05s linear;
}
.clk-ring-outer {
  fill: url(#clockFace);
  stroke: var(--clk-accent);
  stroke-width: 1.5;
}
.clk-ring-inner {
  fill: none;
  stroke: var(--clk-border);
  stroke-width: 0.5;
}
.clk-tick {
  stroke: var(--clk-tick);
  stroke-width: 0.6;
  stroke-linecap: round;
}
.clk-tick--major {
  stroke: var(--clk-tick-major);
  stroke-width: 1.5;
}
.clk-num {
  fill: var(--clk-fg);
  font-family: var(--clk-display);
  font-size: 10px;
  text-anchor: middle;
  dominant-baseline: central;
  fill-opacity: 0.92;
}
.clk-hand {
  stroke-linecap: round;
  transition: transform 0.06s cubic-bezier(0.4, 2, 0.5, 0.8);
}
.clk-hand--hour   { stroke: var(--clk-hand-hour);   stroke-width: 3.5; }
.clk-hand--minute { stroke: var(--clk-hand-minute); stroke-width: 2.5; }
.clk-hand--second { stroke: var(--clk-hand-second); stroke-width: 1.2; }
.clk-pivot       { fill: var(--clk-pivot); }
.clk-pivot-inner { fill: var(--clk-bg); }

/* Subtle animation when second hand moves (no ticking) */
.analog.ticking .clk-hand--second {
  transition: transform 0.15s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ============================================================
   Digital readout
   ============================================================ */
.digital {
  text-align: center;
  margin: 6px 0 14px;
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 6px;
  font-family: var(--clk-display);
}
.digital__time {
  font-size: 42px;
  color: var(--clk-accent);
  text-shadow: 0 0 10px var(--clk-accent);
  letter-spacing: 2px;
  line-height: 1;
}
.digital__ampm {
  font-family: var(--clk-mono);
  font-size: 18px;
  color: var(--clk-accent-2);
}

.digital-meta {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 6px;
  margin-bottom: 18px;
  border-top: 1px dashed var(--clk-border);
  border-bottom: 1px dashed var(--clk-border);
  padding: 8px 0;
}
.digital-meta__row {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}
.digital-meta__lbl {
  font-size: 11px;
  color: var(--clk-fg-dim);
  text-transform: uppercase;
  letter-spacing: 1px;
  font-family: var(--clk-display);
}
.digital-meta__val {
  font-size: 17px;
  color: var(--clk-fg);
  font-family: var(--clk-mono);
}

/* ============================================================
   World clock
   ============================================================ */
.world {
  border-top: 1px dashed var(--clk-border);
  padding-top: 10px;
}
.world__add {
  background: transparent;
  border: 1px dashed var(--clk-border);
  color: var(--clk-fg-dim);
  padding: 1px 8px;
  font-family: var(--clk-mono);
  font-size: 13px;
  cursor: pointer;
  margin-bottom: 8px;
  display: block;
  width: 100%;
  transition: all 0.12s;
}
.world__add:hover {
  color: var(--clk-accent);
  border-color: var(--clk-accent);
}
.world__list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px 18px;
  font-size: 15px;
}
.world__row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 2px 0;
  border-bottom: 1px dotted var(--clk-border);
}
.world__city { color: var(--clk-fg-dim); }
.world__time { color: var(--clk-fg); font-variant-numeric: tabular-nums; }
.world__row.is-day  .world__time::before { content: "☀ "; color: var(--clk-accent-3); }
.world__row.is-night .world__time::before { content: "☾ "; color: var(--clk-accent-2); }

@media (max-width: 480px) {
  .world__list { grid-template-columns: 1fr; }
}

/* ============================================================
   Calendar
   ============================================================ */
.clock-card--cal { padding: 18px 18px; }

.cal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}
.cal-title {
  text-align: center;
  flex: 1;
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 8px;
}
.cal-month {
  font-family: var(--clk-display);
  font-size: 22px;
  color: var(--clk-accent);
  text-shadow: 0 0 8px var(--clk-accent);
  letter-spacing: 2px;
}
.cal-year {
  font-family: var(--clk-display);
  font-size: 14px;
  color: var(--clk-fg-dim);
  letter-spacing: 1px;
}
.cal-nav {
  background: transparent;
  border: 1px solid var(--clk-border);
  color: var(--clk-fg);
  font-family: var(--clk-display);
  font-size: 18px;
  width: 36px;
  height: 36px;
  cursor: pointer;
  transition: all 0.12s;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cal-nav:hover {
  border-color: var(--clk-accent);
  color: var(--clk-accent);
}

.cal-weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
  margin-bottom: 4px;
  font-family: var(--clk-display);
  font-size: 10px;
  color: var(--clk-fg-dim);
  text-align: center;
  letter-spacing: 1px;
  padding: 4px 0;
  border-bottom: 1px dashed var(--clk-border);
}
.cal-weekdays span { padding: 4px 0; }

.cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 3px;
  margin-bottom: 10px;
}
.cal-day {
  position: relative;
  aspect-ratio: 1 / 1;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--clk-mono);
  font-size: 18px;
  color: var(--clk-fg);
  border: 1px solid transparent;
  cursor: pointer;
  transition: all 0.1s;
  background: rgba(255, 255, 255, 0.01);
  user-select: none;
}
.cal-day:hover {
  background: rgba(255, 255, 255, 0.05);
  border-color: var(--clk-accent);
}
.cal-day.is-other { color: var(--clk-fg-dim); opacity: 0.35; }
/* Today wins over holiday background */
.cal-day.is-today {
  background: var(--clk-today-bg) !important;
  color: var(--clk-today-fg) !important;
  font-weight: bold;
  border-color: var(--clk-accent) !important;
  box-shadow: 0 0 0 2px var(--clk-accent), 0 0 12px var(--clk-accent);
  z-index: 2;
}
.cal-day.is-sun:not(.is-today) { color: var(--clk-danger); }
.cal-day.is-sat:not(.is-today) { color: var(--clk-accent-2); }

/* Holiday color coding via bottom border + dot */
.cal-day.has-holiday {
  font-weight: bold;
}
.cal-day.has-holiday::after {
  content: "";
  position: absolute;
  bottom: 4px;
  left: 50%;
  transform: translateX(-50%);
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--clk-accent);
  box-shadow: 0 0 6px currentColor;
}
.cal-day.has-holiday.is-islam::after   { background: var(--clk-islam); }
.cal-day.has-holiday.is-cuti::after    { background: var(--clk-cuti); }
.cal-day.has-holiday.is-nasional::after { background: var(--clk-accent); }
.cal-day.has-holiday.is-kristen::after { background: var(--clk-accent-2); }
.cal-day.has-holiday.is-budha::after   { background: var(--clk-accent-3); }
.cal-day.has-holiday.is-hindu::after   { background: var(--clk-lime); }

.cal-day.has-holiday {
  background: rgba(255, 119, 200, 0.07);
  border-color: var(--clk-accent);
}
.cal-day.has-holiday.is-islam    { background: rgba(95, 217, 122, 0.08); border-color: var(--clk-islam); }
.cal-day.has-holiday.is-cuti     { background: rgba(255, 168, 71, 0.10); border-color: var(--clk-cuti); }
.cal-day.has-holiday.is-kristen  { background: rgba(122, 240, 255, 0.08); border-color: var(--clk-accent-2); }
.cal-day.has-holiday.is-budha    { background: rgba(255, 200, 87, 0.08); border-color: var(--clk-accent-3); }
.cal-day.has-holiday.is-hindu    { background: rgba(168, 255, 96, 0.08); border-color: var(--clk-lime); }

.cal-day.is-today.has-holiday { color: var(--clk-today-fg); }
.cal-day.is-today.has-holiday::after { background: var(--clk-today-fg); }

/* Selected day */
.cal-day.is-selected {
  outline: 2px solid var(--clk-accent-2);
  outline-offset: -2px;
  z-index: 1;
}

/* Foot: today + legend */
.cal-foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  padding-top: 8px;
  border-top: 1px dashed var(--clk-border);
}
.cal-today {
  background: transparent;
  border: 1px solid var(--clk-border);
  color: var(--clk-fg);
  padding: 3px 14px;
  font-family: var(--clk-mono);
  font-size: 14px;
  cursor: pointer;
  transition: all 0.12s;
}
.cal-today:hover {
  border-color: var(--clk-accent);
  color: var(--clk-accent);
}
.cal-legend {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  font-size: 12px;
  color: var(--clk-fg-dim);
  font-family: var(--clk-mono);
}
.leg {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-right: 3px;
  vertical-align: middle;
}
.leg--nasional { background: var(--clk-accent); }
.leg--cuti     { background: var(--clk-cuti); }
.leg--islam    { background: var(--clk-islam); }
.leg--kristen  { background: var(--clk-accent-2); }
.leg--budha    { background: var(--clk-accent-3); }
.leg--today    { background: var(--clk-today-bg); border: 1px solid var(--clk-accent); }

/* Upcoming holidays list */
.cal-upcoming {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px dashed var(--clk-border);
}
.cal-upcoming h3 {
  font-family: var(--clk-display);
  font-size: 11px;
  color: var(--clk-accent);
  margin: 0 0 8px;
  letter-spacing: 1px;
}
.cal-upcoming ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-family: var(--clk-mono);
  font-size: 15px;
  max-height: 180px;
  overflow-y: auto;
}
.cal-upcoming li {
  display: flex;
  gap: 10px;
  align-items: baseline;
  padding: 3px 0;
  border-bottom: 1px dotted var(--clk-border);
}
.upc-date {
  color: var(--clk-accent);
  font-family: var(--clk-display);
  font-size: 11px;
  min-width: 60px;
}
.upc-dot {
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  margin-right: 6px;
  vertical-align: middle;
}
.upc-dot--nasional { background: var(--clk-accent); }
.upc-dot--islam    { background: var(--clk-islam); }
.upc-dot--cuti     { background: var(--clk-cuti); }
.upc-dot--kristen  { background: var(--clk-accent-2); }
.upc-dot--budha    { background: var(--clk-accent-3); }
.upc-dot--hindu    { background: var(--clk-lime); }
.upc-name { color: var(--clk-fg); flex: 1; }
.upc-count {
  color: var(--clk-fg-dim);
  font-size: 12px;
  font-variant-numeric: tabular-nums;
}

/* Selected day popup / tooltip area */
.cal-day-detail {
  margin-top: 12px;
  padding: 10px 14px;
  border-left: 3px solid var(--clk-accent);
  background: rgba(255, 119, 200, 0.06);
  font-family: var(--clk-mono);
  font-size: 15px;
}
.cal-day-detail__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 4px;
}
.cal-day-detail__date {
  color: var(--clk-accent);
  font-family: var(--clk-display);
  font-size: 11px;
  letter-spacing: 1px;
}
.cal-day-detail__close {
  background: transparent;
  border: none;
  color: var(--clk-fg-dim);
  cursor: pointer;
  font-family: var(--clk-mono);
  font-size: 16px;
  padding: 0 4px;
}
.cal-day-detail__close:hover { color: var(--clk-accent); }
.cal-day-detail__holidays {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.cal-day-detail__holidays li {
  display: flex;
  align-items: baseline;
  gap: 6px;
  color: var(--clk-fg);
}
.cal-day-detail__type {
  font-family: var(--clk-display);
  font-size: 9px;
  padding: 1px 5px;
  border: 1px solid currentColor;
  color: var(--clk-fg-dim);
  text-transform: uppercase;
}
.cal-day-detail__type--nasional { color: var(--clk-accent); }
.cal-day-detail__type--islam    { color: var(--clk-islam); }
.cal-day-detail__type--cuti     { color: var(--clk-cuti); }
.cal-day-detail__type--kristen  { color: var(--clk-accent-2); }
.cal-day-detail__type--budha    { color: var(--clk-accent-3); }
.cal-day-detail__type--hindu    { color: var(--clk-lime); }
.cal-day-detail__none {
  color: var(--clk-fg-dim);
  font-style: italic;
}

/* ============================================================
   Tools row (stopwatch / timer / pomodoro)
   ============================================================ */
.clock-card--tools {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  padding: 18px 20px;
  margin-top: 0;
}
@media (max-width: 760px) {
  .clock-card--tools { grid-template-columns: 1fr; }
}
.tool {
  border: 1px dashed var(--clk-border);
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.tool__title {
  font-family: var(--clk-display);
  font-size: 11px;
  color: var(--clk-accent);
  letter-spacing: 1px;
}
.tool__display {
  font-family: var(--clk-display);
  font-size: 30px;
  color: var(--clk-fg);
  text-align: center;
  padding: 8px 0;
  border-top: 1px dashed var(--clk-border);
  border-bottom: 1px dashed var(--clk-border);
  letter-spacing: 2px;
  font-variant-numeric: tabular-nums;
  text-shadow: 0 0 6px var(--clk-accent);
}
.tool.is-running .tool__display { color: var(--clk-lime); text-shadow: 0 0 6px var(--clk-lime); }
.tool.is-paused  .tool__display { color: var(--clk-accent-3); }
.tool.is-done    .tool__display { color: var(--clk-danger); animation: tool-blink 0.6s ease-in-out infinite; }
@keyframes tool-blink {
  50% { opacity: 0.4; }
}
.tool__btns {
  display: flex;
  gap: 6px;
  justify-content: center;
}
.tool__btn {
  background: transparent;
  border: 1px solid var(--clk-border);
  color: var(--clk-fg);
  padding: 4px 12px;
  font-family: var(--clk-mono);
  font-size: 15px;
  cursor: pointer;
  transition: all 0.12s;
  flex: 1;
}
.tool__btn:hover:not(:disabled) {
  border-color: var(--clk-accent);
  color: var(--clk-accent);
}
.tool__btn--primary {
  border-color: var(--clk-accent);
  color: var(--clk-accent);
}
.tool__btn--primary:hover:not(:disabled) {
  background: var(--clk-accent);
  color: var(--clk-bg);
}
.tool__btn:disabled { opacity: 0.3; cursor: not-allowed; }

.tool__presets {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  justify-content: center;
}
.tool__chip {
  background: transparent;
  border: 1px solid var(--clk-border);
  color: var(--clk-fg-dim);
  padding: 2px 8px;
  font-family: var(--clk-mono);
  font-size: 13px;
  cursor: pointer;
  transition: all 0.12s;
}
.tool__chip:hover {
  border-color: var(--clk-accent);
  color: var(--clk-accent);
}
.tool__chip.is-active {
  background: var(--clk-accent);
  color: var(--clk-bg);
  border-color: var(--clk-accent);
}
.tool__custom {
  display: flex;
  gap: 4px;
  align-items: center;
  justify-content: center;
  font-family: var(--clk-mono);
  font-size: 18px;
  color: var(--clk-fg-dim);
}
.tool__input {
  width: 50px;
  background: rgba(0, 0, 0, 0.3);
  border: 1px solid var(--clk-border);
  color: var(--clk-fg);
  padding: 4px 6px;
  font-family: var(--clk-mono);
  font-size: 18px;
  text-align: center;
  outline: none;
}
.tool__input:focus { border-color: var(--clk-accent); }

.tool__laps {
  list-style: none;
  margin: 4px 0 0;
  padding: 0;
  max-height: 120px;
  overflow-y: auto;
  font-family: var(--clk-mono);
  font-size: 13px;
  color: var(--clk-fg-dim);
  border-top: 1px dotted var(--clk-border);
  padding-top: 6px;
}
.tool__laps li {
  display: flex;
  justify-content: space-between;
  padding: 2px 0;
}
.tool__laps li:nth-child(1) { color: var(--clk-accent); }
.tool__laps li:nth-child(2) { color: var(--clk-accent-2); }
.tool__laps li:nth-child(3) { color: var(--clk-accent-3); }

.tool__phase {
  text-align: center;
  font-family: var(--clk-display);
  font-size: 10px;
  color: var(--clk-fg-dim);
  text-transform: uppercase;
  letter-spacing: 1px;
}
.tool__phase.is-work     { color: var(--clk-accent); }
.tool__phase.is-rest     { color: var(--clk-islam); }
.tool__phase.is-long     { color: var(--clk-accent-2); }
.tool__phase.is-done     { color: var(--clk-lime); }

.tool__hint {
  text-align: center;
  font-size: 12px;
  color: var(--clk-fg-dim);
  font-style: italic;
}

/* ============================================================
   Theme overrides — tweak per theme
   ============================================================ */

/* CRT (default) — keep the magenta/cyan/amber */
html[data-theme="crt"] {
  --clk-face-1: #2a1325;
  --clk-face-2: #110510;
}

/* Amber — orange monochrome */
html[data-theme="amber"] {
  --clk-accent:   #ffaa3b;
  --clk-accent-2: #ffd180;
  --clk-accent-3: #ffeb99;
  --clk-tick-major: #ffaa3b;
  --clk-hand-hour:   #ffaa3b;
  --clk-hand-minute: #ffd180;
  --clk-hand-second: #ffeb99;
  --clk-pivot:    #ffaa3b;
  --clk-today-bg: #ffaa3b;
  --clk-face-1:   #2a1605;
  --clk-face-2:   #110803;
  --clk-tick:     #c9853a;
}

/* Matrix — green */
html[data-theme="matrix"] {
  --clk-accent:   #5fd97a;
  --clk-accent-2: #a8ff60;
  --clk-accent-3: #c8ff90;
  --clk-tick-major: #5fd97a;
  --clk-hand-hour:   #5fd97a;
  --clk-hand-minute: #a8ff60;
  --clk-hand-second: #c8ff90;
  --clk-pivot:    #5fd97a;
  --clk-today-bg: #5fd97a;
  --clk-face-1:   #0a1a0e;
  --clk-face-2:   #000500;
  --clk-tick:     #2a4a30;
  --clk-lime:     #c8ff90;
}

/* Midnight — cool blue */
html[data-theme="midnight"] {
  --clk-accent:   #6db3ff;
  --clk-accent-2: #a8d8ff;
  --clk-accent-3: #b8e6ff;
  --clk-tick-major: #6db3ff;
  --clk-hand-hour:   #6db3ff;
  --clk-hand-minute: #a8d8ff;
  --clk-hand-second: #b8e6ff;
  --clk-pivot:    #6db3ff;
  --clk-today-bg: #6db3ff;
  --clk-face-1:   #0a1428;
  --clk-face-2:   #02060f;
  --clk-tick:     #4a6890;
}

/* Paper — light theme, dark accents */
html[data-theme="paper"] {
  --clk-accent:   #b8427a;
  --clk-accent-2: #2a7a8a;
  --clk-accent-3: #b87a2a;
  --clk-tick-major: #b8427a;
  --clk-hand-hour:   #b8427a;
  --clk-hand-minute: #2a7a8a;
  --clk-hand-second: #b87a2a;
  --clk-pivot:    #b8427a;
  --clk-today-bg: #b8427a;
  --clk-today-fg: #f4ecd8;
  --clk-face-1:   #fff8e8;
  --clk-face-2:   #ebe0c4;
  --clk-tick:     #a89878;
  --clk-fg:       #2a1a14;
  --clk-fg-dim:   #6a5444;
  --clk-border:   #c8b890;
  --clk-danger:   #c8404a;
  --clk-islam:    #3a8a4a;
  --clk-cuti:     #c8782a;
  --clk-lime:     #4a8a2a;
  --clk-holiday-fg: #f4ecd8;
  --clk-card-bg:  rgba(255, 255, 255, 0.4);
}

/* ============================================================
   Reduced motion
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  .clk-hand, .analog, .tool__btn, .tool__chip,
  .cal-day, .cal-nav, .cal-today, .clock-toggle,
  .clock-tz, .world__add {
    transition: none !important;
  }
  .tool.is-done .tool__display { animation: none !important; }
}
