/* Don Macaron Ops — admin calendar (brand design system) */
:root {
  --cream: #faf5ec;
  --paper: #fbf7ef;
  --sky: #eaf1f5;
  --powder: #cbd8e1;
  --powder-deep: #9fb4c3;
  --navy: #304555;
  --navy-2: #3a5165;
  --ink: #2a3b47;
  --slate: #4a5862;
  --rose: #c27674;
  --rose-soft: #f1dad6;
  --wine: #752f39;
  --line: #e7dccb;
  --line-sky: #cfdde5;
  --ok: #5e7d5a;
  --display: "Cormorant Garamond", Georgia, serif;
  --body: "Jost", "Helvetica Neue", system-ui, sans-serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; height: 100%; }
body {
  background: var(--cream);
  color: var(--slate);
  font-family: var(--body);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
.hidden { display: none !important; }

.brand { font-family: var(--display); font-weight: 600; letter-spacing: 0.18em; color: var(--navy); font-size: 1.05rem; }
.brand-sub { font-size: 0.62rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--rose); margin-left: 0.6rem; }

/* ── buttons / inputs ── */
.btn {
  font-family: var(--body); font-size: 0.78rem; font-weight: 500;
  letter-spacing: 0.14em; text-transform: uppercase;
  padding: 0.7rem 1.3rem; border-radius: 1px; border: 1px solid transparent;
  cursor: pointer; transition: all 0.2s ease;
}
.btn-primary { background: var(--navy); color: var(--cream); }
.btn-primary:hover { background: var(--navy-2); transform: translateY(-1px); }
.btn-ghost { background: transparent; border-color: rgba(48,69,85,0.3); color: var(--navy); }
.btn-ghost:hover { background: var(--navy); color: var(--cream); }
.btn-danger { background: transparent; border-color: rgba(117,47,57,0.4); color: var(--wine); }
.btn-danger:hover { background: var(--wine); color: var(--cream); }

.input, select.input, textarea.input {
  width: 100%; background: var(--paper); border: 1px solid var(--line); border-radius: 1px;
  padding: 0.7rem 0.85rem; font-family: var(--body); font-size: 1rem; color: var(--ink);
}
.input:focus { outline: none; border-color: var(--navy); box-shadow: 0 0 0 1px var(--navy); }
textarea.input { resize: vertical; min-height: 4.5rem; }
.label { display: block; font-size: 0.68rem; letter-spacing: 0.2em; text-transform: uppercase; font-weight: 500; color: var(--ink); margin: 0 0 0.4rem; }

.iconbtn {
  background: none; border: 1px solid var(--line); border-radius: 1px; color: var(--navy);
  font-size: 1rem; line-height: 1; padding: 0.5rem 0.75rem; cursor: pointer; transition: all 0.2s;
}
.iconbtn:hover { border-color: var(--navy); }
.todaybtn { background: none; border: 1px solid var(--line); color: var(--navy); font-family: var(--body); font-size: 0.68rem; letter-spacing: 0.12em; text-transform: uppercase; padding: 0.55rem 0.9rem; cursor: pointer; }
.todaybtn:hover { border-color: var(--navy); }

/* ── login ── */
.login { position: fixed; inset: 0; display: grid; place-items: center; background: var(--cream); z-index: 50; }
.login-card { width: min(320px, 88vw); text-align: center; display: grid; gap: 0.9rem; }
.login-sub { font-size: 0.66rem; letter-spacing: 0.24em; text-transform: uppercase; color: var(--slate); margin: -0.4rem 0 0.6rem; }
.login-err { color: var(--wine); font-size: 0.85rem; margin: 0; }

/* ── layout ── */
.app { display: flex; flex-direction: column; height: 100dvh; }
.topbar {
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  padding: 0.8rem 1.2rem; background: var(--cream); border-bottom: 1px solid var(--line);
  flex-wrap: wrap;
}
.topbar-left { display: flex; align-items: baseline; }
.topbar-center { display: flex; align-items: center; gap: 0.6rem; }
.cursor-label { font-family: var(--display); font-weight: 500; font-size: 1.75rem; color: var(--ink); margin: 0; min-width: 12rem; text-align: center; }
.topbar-right { display: flex; align-items: center; gap: 0.6rem; }

.viewtoggle { display: flex; border: 1px solid var(--line); border-radius: 1px; overflow: hidden; }
.viewtoggle button {
  background: none; border: none; font-family: var(--body); font-size: 0.72rem; font-weight: 500;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--slate); padding: 0.6rem 1rem; cursor: pointer;
}
.viewtoggle button.active { background: var(--navy); color: var(--cream); }
.count {
  display: inline-block; min-width: 16px; padding: 1px 5px; margin-left: 4px;
  border-radius: 99px; background: var(--rose); color: #fff; font-size: 0.6rem; text-align: center;
}
.viewtoggle button.active .count { background: var(--cream); color: var(--navy); }

.legend { display: flex; gap: 1.1rem; flex-wrap: wrap; padding: 0.55rem 1.2rem; font-size: 0.8rem; letter-spacing: 0.06em; color: var(--slate); border-bottom: 1px solid var(--line); background: var(--paper); }
.legend span { display: inline-flex; align-items: center; gap: 0.4rem; }
.legend i { width: 9px; height: 9px; border-radius: 99px; display: inline-block; }

.view { flex: 1; overflow: auto; padding: 1rem 1.2rem 2rem; }

/* ── month grid ── */
.cal { display: grid; grid-template-columns: repeat(7, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); min-width: 720px; }
.cal-head { background: var(--paper); padding: 0.55rem 0.7rem; font-size: 0.74rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--slate); }
.cal-day { background: var(--cream); min-height: 128px; padding: 0.5rem 0.55rem; position: relative; }
.cal-day.out { background: var(--paper); color: var(--powder-deep); }
.cal-day.today { box-shadow: inset 0 0 0 2px var(--navy); }
.cal-num { font-family: var(--display); font-size: 1.2rem; color: var(--ink); }
.cal-day.out .cal-num { color: var(--powder-deep); }
.chips { display: grid; gap: 3px; margin-top: 0.3rem; }
.chip {
  display: block; width: 100%; text-align: left; border: none; cursor: pointer;
  font-family: var(--body); font-size: 0.88rem; line-height: 1.35; color: #fff;
  padding: 5px 9px; border-radius: 2px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  transition: transform 0.15s ease;
}
.chip:hover { transform: translateX(2px); }
.chip-more { background: none; border: none; color: var(--navy); font-size: 0.8rem; cursor: pointer; padding: 1px 6px; text-align: left; }

/* status colors */
.st-new { background: var(--rose); }
.st-confirmed { background: var(--navy); }
.st-in_production { background: var(--wine); }
.st-ready { background: var(--ok); }
.st-done { background: var(--powder-deep); }
.st-cancelled { background: #b9b2a6; text-decoration: line-through; }

/* ── list view ── */
.list { display: grid; gap: 1.4rem; max-width: 880px; }
.list-day h3 { font-family: var(--display); font-size: 1.45rem; font-weight: 600; color: var(--ink); margin: 0 0 0.5rem; border-bottom: 1px solid var(--line); padding-bottom: 0.3rem; }
.row {
  display: flex; align-items: flex-start; gap: 0.9rem; width: 100%; text-align: left;
  background: var(--paper); border: 1px solid var(--line); border-radius: 1px;
  padding: 0.7rem 0.9rem; cursor: pointer; transition: border-color 0.15s, transform 0.15s; margin-bottom: 6px;
  font-family: var(--body);
}
.row:hover { border-color: var(--navy); transform: translateX(2px); }
.row .dot { width: 10px; height: 10px; border-radius: 99px; flex-shrink: 0; margin-top: 0.45rem; }
.row .who { font-weight: 500; color: var(--ink); min-width: 9rem; flex-shrink: 0; margin-top: 0.1rem; }
.row .what {
  flex: 1; min-width: 0; color: var(--slate); font-size: 0.98rem; line-height: 1.5;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
/* List mode only: up to 3 lines, then … (full text via hover title / click) */
.list--clamp .row .what {
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical;
  white-space: normal; overflow-wrap: anywhere; text-overflow: clip;
}
.row .meta { font-size: 0.78rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--slate); flex-shrink: 0; margin-top: 0.25rem; }
.empty { text-align: center; color: var(--slate); padding: 3rem 1rem; font-family: var(--display); font-style: italic; font-size: 1.35rem; }

/* ── drawer ── */
.drawer-backdrop { position: fixed; inset: 0; background: rgba(42, 59, 71, 0.35); z-index: 40; }
.drawer {
  position: fixed; top: 0; right: 0; bottom: 0; width: min(460px, 100vw); z-index: 45;
  background: var(--cream); border-left: 1px solid var(--line); box-shadow: -30px 0 60px -40px rgba(42,59,71,0.5);
  overflow-y: auto; padding: 1.3rem 1.4rem 2rem;
}
.drawer h3 { font-family: var(--display); font-weight: 600; font-size: 1.85rem; color: var(--ink); margin: 0; }
.drawer .sub { font-size: 0.68rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--slate); margin: 0.2rem 0 1rem; }
.fgrid { display: grid; grid-template-columns: 1fr 1fr; gap: 0.8rem; }
.fgrid .full { grid-column: 1 / -1; }
.frow { margin-top: 0.8rem; }
.drawer-actions { display: flex; gap: 0.6rem; margin-top: 1.2rem; flex-wrap: wrap; }
.statusbar { display: flex; flex-wrap: wrap; gap: 4px; margin: 0.6rem 0 0.2rem; }
.statusbar button {
  border: 1px solid var(--line); background: var(--paper); border-radius: 2px; cursor: pointer;
  font-family: var(--body); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; padding: 0.45rem 0.7rem; color: var(--slate);
}
.statusbar button.on { color: #fff; border-color: transparent; }
.quicklinks { display: flex; gap: 0.8rem; margin-top: 0.5rem; font-size: 0.85rem; }
.quicklinks a { color: var(--navy); }
.checkline { display: flex; align-items: center; gap: 0.5rem; font-size: 0.9rem; color: var(--ink); }
.checkline input { width: 15px; height: 15px; accent-color: var(--navy); }

/* ── modal ── */
.modal { position: fixed; inset: 0; display: grid; place-items: center; background: rgba(42,59,71,0.35); z-index: 60; }
.modal-card { width: min(520px, 92vw); background: var(--cream); border: 1px solid var(--line); padding: 1.4rem 1.5rem; display: grid; gap: 0.8rem; }
.modal-card h3 { font-family: var(--display); font-weight: 600; font-size: 1.4rem; color: var(--ink); margin: 0; }
.modal-actions { display: flex; gap: 0.6rem; }

@media (max-width: 760px) {
  .topbar { padding: 0.7rem 0.8rem; gap: 0.5rem; }
  .cursor-label { font-size: 1.15rem; min-width: 0; }
  .view { padding: 0.7rem 0.5rem 2rem; }
  .cal { min-width: 0; }
  .cal-day { min-height: 78px; padding: 0.25rem; }
  .chip { font-size: 0.6rem; padding: 2px 4px; }
  .row .who { min-width: 6rem; }
}
