/* ════════════════════════════════════════════
   New Dawn — Dashboard
   ════════════════════════════════════════════ */

/* ── Header ── */
.dash-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .65rem 1.25rem;
  background: linear-gradient(180deg, #1a0e04, #120a02);
  border-bottom: 1px solid rgba(184,134,11,.35);
  position: sticky; top: 0; z-index: 100;
  gap: 1rem;
}

.dash-logo {
  font-family: 'Cinzel', serif;
  font-size: 1.05rem; font-weight: 700;
  color: var(--gold-light); letter-spacing: .12em;
  white-space: nowrap;
}

.dash-user-info {
  display: flex; align-items: center; gap: .6rem; flex-wrap: wrap; justify-content: flex-end;
}

.dash-username {
  font-family: 'Crimson Text', serif;
  color: var(--parchment); font-size: .95rem;
  cursor: pointer; text-underline-offset: 2px;
}
.dash-username:hover { color: var(--gold-light); text-decoration: underline; }

.dash-role-badge {
  font-family: 'Cinzel', serif;
  font-size: .65rem; font-weight: 600; letter-spacing: .1em;
  padding: 2px 9px; border-radius: 2px; border: 1px solid; white-space: nowrap;
}
.role-dm     { background: rgba(184,134,11,.15); border-color: var(--gold);    color: var(--gold-light); }
.role-player { background: rgba(60,100,180,.15); border-color: #5a7ab8;        color: #8aace0; }

.dash-logout-btn {
  font-family: 'Cinzel', serif; font-size: .68rem; font-weight: 600; letter-spacing: .06em;
  padding: 4px 11px; border-radius: 2px;
  border: 1px solid rgba(184,134,11,.4); background: transparent;
  color: var(--parchment-deep); cursor: pointer; transition: all .15s;
}
.dash-logout-btn:hover { border-color: var(--gold); color: var(--gold-light); }

/* ── Content ── */
.dash-content {
  max-width: 1100px; margin: 0 auto;
  padding: 1.5rem 1rem 3rem;
}

/* ── Section ── */
.dash-section { margin-bottom: 2.2rem; }

.dash-section-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: .5rem 0; border-bottom: 1px solid rgba(184,134,11,.28);
  margin-bottom: 1rem;
}

.dash-section-title {
  font-family: 'Cinzel', serif; font-size: .88rem; font-weight: 600;
  color: var(--gold-light); letter-spacing: .12em; text-transform: uppercase;
}

.dash-btn-new {
  font-family: 'Cinzel', serif; font-size: .7rem; font-weight: 600;
  padding: 5px 13px; border-radius: 2px;
  border: 1px solid var(--gold);
  background: linear-gradient(160deg, var(--gold), #9a7008);
  color: var(--ink); cursor: pointer; letter-spacing: .07em; transition: all .15s;
  white-space: nowrap;
}
.dash-btn-new:hover { background: linear-gradient(160deg, var(--gold-light), var(--gold)); }

/* ── Cards grid ── */
.dash-cards {
  display: grid; grid-template-columns: 1fr; gap: .75rem;
}
@media (min-width: 520px)  { .dash-cards { grid-template-columns: repeat(2,1fr); } }
@media (min-width: 860px)  { .dash-cards { grid-template-columns: repeat(3,1fr); } }

.dash-card {
  background: linear-gradient(160deg, #1e0e05, #130a02);
  border: 1px solid rgba(184,134,11,.25); border-radius: 4px;
  padding: .9rem 1rem; display: flex; flex-direction: column; gap: .35rem;
  transition: border-color .15s;
}
.dash-card:hover { border-color: rgba(184,134,11,.55); }

.dash-card-name {
  font-family: 'Cinzel', serif; font-size: .88rem; font-weight: 600;
  color: var(--gold-light); letter-spacing: .05em;
}

.dash-card-meta {
  font-family: 'Crimson Text', serif; font-size: .88rem; color: var(--parchment-deep);
  line-height: 1.4;
}

.dash-card-badges {
  display: flex; flex-wrap: wrap; gap: .3rem; margin-top: .15rem;
}

/* ── Badges ── */
.badge {
  font-family: 'Cinzel', serif; font-size: .62rem; font-weight: 600;
  padding: 2px 7px; border-radius: 2px; letter-spacing: .04em; white-space: nowrap;
}
.badge-active   { background: rgba(58,112,40,.22);  border: 1px solid rgba(70,130,50,.45); color: #90c070; }
.badge-archived { background: rgba(70,70,70,.2);    border: 1px solid rgba(120,120,120,.35); color: #999; }
.badge-invited  { background: rgba(130,100,20,.2);  border: 1px solid rgba(180,140,40,.35); color: #c8a844; }
.badge-pc       { background: rgba(60,100,180,.2);  border: 1px solid rgba(90,122,184,.35); color: #8aace0; }
.badge-npc      { background: rgba(100,80,20,.22);  border: 1px solid rgba(160,130,40,.35); color: #c8a844; }
.badge-monster  { background: rgba(140,20,20,.22);  border: 1px solid rgba(180,50,50,.35);  color: #e07070; }
.badge-lv       { background: rgba(60,50,20,.3);    border: 1px solid rgba(120,100,40,.35); color: var(--parchment-deep); }
.badge-dm       { background: rgba(184,134,11,.14); border: 1px solid rgba(184,134,11,.4);  color: var(--gold-light); }
.badge-player   { background: rgba(60,100,180,.14); border: 1px solid rgba(90,122,184,.35); color: #8aace0; }
.badge-campaign { background: rgba(80,60,20,.2);    border: 1px solid rgba(140,110,40,.35); color: var(--parchment-deep); }

/* ── Card actions ── */
.dash-card-actions {
  display: flex; gap: .4rem; margin-top: .35rem; flex-wrap: wrap;
}

.dash-action-btn {
  font-family: 'Cinzel', serif; font-size: .64rem; font-weight: 600;
  padding: 4px 9px; border-radius: 2px; cursor: pointer;
  letter-spacing: .04em; transition: all .15s; white-space: nowrap;
}
.btn-edit   { border: 1px solid rgba(184,134,11,.45); background: rgba(184,134,11,.07); color: var(--gold-light); }
.btn-edit:hover   { background: rgba(184,134,11,.18); border-color: var(--gold); }
.btn-delete { border: 1px solid rgba(180,40,40,.35);  background: rgba(140,20,20,.07); color: #e07070; }
.btn-delete:hover { background: rgba(140,20,20,.2); }
.btn-view   { border: 1px solid rgba(60,100,180,.4);  background: rgba(60,100,180,.07); color: #8aace0; }
.btn-view:hover   { background: rgba(60,100,180,.18); }

/* ── Empty / loading ── */
.dash-empty {
  font-family: 'Crimson Text', serif; font-style: italic;
  color: var(--ink-faint); padding: .75rem 0; font-size: .9rem;
}
.dash-loading {
  font-family: 'Crimson Text', serif; font-style: italic;
  color: var(--parchment-deep); padding: 3rem; text-align: center; font-size: 1rem;
}

/* ── MODALS ── */
.dash-modal-overlay {
  position: fixed; inset: 0; z-index: 2000;
  background: rgba(0,0,0,.78);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none; transition: opacity .18s;
  padding: 1rem;
}
.dash-modal-overlay.open { opacity: 1; pointer-events: all; }

.dash-modal {
  background: linear-gradient(160deg, #2a1a08, #1a0e04);
  border: 1px solid rgba(184,134,11,.45); border-radius: 4px;
  width: 100%; max-width: 460px;
  max-height: 90vh; overflow-y: auto;
}

.dash-modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: .85rem 1.2rem;
  border-bottom: 1px solid rgba(184,134,11,.2);
}

.dash-modal-title {
  font-family: 'Cinzel', serif; font-size: .88rem; font-weight: 700;
  color: var(--gold-light); letter-spacing: .1em;
}

.dash-modal-body {
  padding: 1.1rem 1.2rem;
  display: flex; flex-direction: column; gap: .8rem;
}

.dash-modal-footer {
  padding: .8rem 1.2rem;
  display: flex; justify-content: flex-end; gap: .5rem;
  border-top: 1px solid rgba(184,134,11,.2);
}

/* ── Form fields ── */
.field-group { display: flex; flex-direction: column; gap: .3rem; }
.field-row   { display: flex; gap: .6rem; }
.field-row .field-group { flex: 1; }

.field-label {
  font-family: 'Cinzel', serif; font-size: .68rem; font-weight: 600;
  color: var(--parchment-deep); letter-spacing: .07em; text-transform: uppercase;
}
.field-input, .field-select, .field-textarea {
  font-family: 'Crimson Text', serif; font-size: .95rem;
  padding: .48rem .75rem; border-radius: 2px;
  border: 1px solid rgba(184,134,11,.35);
  background: rgba(15,8,2,.7); color: var(--parchment);
  width: 100%;
}
.field-input:focus, .field-select:focus, .field-textarea:focus {
  outline: none; border-color: var(--gold);
}
.field-textarea { min-height: 72px; resize: vertical; }
.field-select option { background: #1a0e04; }

.field-error {
  color: var(--red-wax); font-family: 'Crimson Text', serif;
  font-style: italic; font-size: .88rem; min-height: 1.2em;
}

/* ── Modal cancel btn ── */
.dash-btn-cancel {
  font-family: 'Cinzel', serif; font-size: .7rem; font-weight: 600;
  padding: 6px 14px; border-radius: 2px;
  border: 1px solid rgba(184,134,11,.3);
  background: transparent; color: var(--parchment-deep);
  cursor: pointer; letter-spacing: .06em; transition: all .15s;
}
.dash-btn-cancel:hover { border-color: rgba(184,134,11,.6); color: var(--parchment); }

.dash-btn-save {
  font-family: 'Cinzel', serif; font-size: .7rem; font-weight: 600;
  padding: 6px 16px; border-radius: 2px;
  border: 1px solid var(--gold);
  background: linear-gradient(160deg, var(--gold), #9a7008);
  color: var(--ink); cursor: pointer; letter-spacing: .07em; transition: all .15s;
}
.dash-btn-save:hover { background: linear-gradient(160deg, var(--gold-light), var(--gold)); }

/* ── Geography tree ── */
.geo-tree { padding: .25rem 0; }

.geo-continent { margin-bottom: .75rem; }
.geo-region    { margin: .35rem 0 .35rem 1.2rem; }
.geo-city      { margin: .25rem 0 .25rem 2.4rem; display: flex; align-items: center; flex-wrap: wrap; gap: .35rem; }

.geo-node-row {
  display: flex; align-items: center; flex-wrap: wrap; gap: .4rem;
  padding: .3rem 0;
}

.geo-node-icon { font-size: .95rem; flex-shrink: 0; color: antiquewhite; }

.geo-node-name {
  font-family: 'Cinzel', serif; font-size: .82rem; font-weight: 600;
  color: var(--parchment); letter-spacing: .04em;
}
.geo-continent .geo-node-name { color: var(--gold-light); font-size: .88rem; }
.geo-region    .geo-node-name { color: var(--parchment); }
.geo-city      .geo-node-name { color: var(--parchment-deep); font-size: .78rem; }

.geo-desc {
  font-family: 'Crimson Text', serif; font-size: .82rem; font-style: italic;
  color: var(--ink-faint); flex-basis: 100%; padding-left: 1.6rem;
}

.geo-gest-badge {
  font-family: 'Cinzel', serif; font-size: .6rem; font-weight: 600;
  padding: 1px 6px; border-radius: 2px;
  background: rgba(58,112,40,.2); border: 1px solid rgba(70,130,50,.4); color: #90c070;
  letter-spacing: .04em;
}

.geo-actions {
  display: flex; gap: .3rem; flex-shrink: 0; align-items: center; margin-left: .6rem;
}

.geo-kmenu { position: relative; }
.geo-kmenu-btn {
  background: none; border: none; cursor: pointer;
  color: rgba(184,134,11,.4); font-size: 1rem; line-height: 1;
  padding: 1px 4px; border-radius: 2px; transition: color .15s;
}
.geo-kmenu-btn:hover { color: var(--gold-light); }

.geo-kdrop {
  display: none; position: absolute; right: 0; top: 100%;
  background: #1a0e04; border: 1px solid rgba(184,134,11,.35);
  border-radius: 3px; min-width: 120px; z-index: 100;
  box-shadow: 0 4px 12px rgba(0,0,0,.5);
}
.geo-kdrop.open { display: block; }
.geo-kdrop button {
  display: block; width: 100%; text-align: left;
  background: none; border: none; cursor: pointer;
  font-family: 'Cinzel', serif; font-size: .65rem; font-weight: 600;
  letter-spacing: .04em; color: var(--parchment-deep);
  padding: 7px 12px; transition: background .12s;
}
.geo-kdrop button:hover { background: rgba(184,134,11,.12); color: var(--gold-light); }
.geo-kdrop .kdrop-delete { color: #e07070; }
.geo-kdrop .kdrop-delete:hover { background: rgba(140,20,20,.2); color: #f09090; }

.geo-btn {
  font-family: 'Cinzel', serif; font-size: .62rem; font-weight: 600;
  padding: 2px 7px; border-radius: 2px; cursor: pointer;
  letter-spacing: .04em; transition: all .15s; white-space: nowrap;
}
.geo-btn-add  { border: 1px solid rgba(184,134,11,.4); background: rgba(184,134,11,.07); color: var(--gold-light); }
.geo-btn-add:hover  { background: rgba(184,134,11,.18); }
.geo-btn-edit { border: 1px solid rgba(184,134,11,.3); background: transparent; color: var(--parchment-deep); }
.geo-btn-edit:hover { background: rgba(184,134,11,.1); color: var(--gold-light); }
.geo-btn-del  { border: 1px solid rgba(180,40,40,.3);  background: transparent; color: rgba(220,80,80,.7); }
.geo-btn-del:hover  { background: rgba(140,20,20,.15); color: #e07070; }

.geo-add-root {
  margin-top: .75rem; padding-top: .75rem;
  border-top: 1px dashed rgba(184,134,11,.2);
}

.geo-empty {
  font-family: 'Crimson Text', serif; font-style: italic;
  color: var(--ink-faint); font-size: .9rem; padding: .5rem 0;
}

.geo-children { border-left: 1px solid rgba(184,134,11,.12); margin-left: .6rem; padding-left: .5rem; }

/* ── Calendar edit modal ── */
.cal-edit-table {
  display: flex; flex-direction: column; gap: .3rem;
}

.cal-edit-head {
  display: grid;
  grid-template-columns: 1.5rem 1fr 1.2fr 3.5rem 1.8rem;
  gap: .4rem; align-items: center;
  padding: 0 .2rem .35rem;
  border-bottom: 1px solid rgba(184,134,11,.2);
  font-family: 'Cinzel', serif; font-size: .65rem; font-weight: 600;
  color: var(--parchment-deep); letter-spacing: .07em; text-transform: uppercase;
}

.cal-edit-row {
  display: grid;
  grid-template-columns: 1.5rem 1fr 1.2fr 3.5rem 1.8rem;
  gap: .4rem; align-items: center;
}

.cal-edit-num {
  font-family: 'Cinzel', serif; font-size: .72rem; color: var(--ink-faint); text-align: center;
}

.cal-edit-days { padding-left: .4rem !important; }

.cal-edit-summary {
  font-family: 'Crimson Text', serif; font-size: .9rem;
  color: var(--parchment-deep); margin-top: .65rem;
  padding-top: .5rem; border-top: 1px dashed rgba(184,134,11,.15);
}
.cal-edit-summary b { color: var(--gold-light); }

.cal-edit-footer {
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: .5rem;
  padding: .8rem 1.2rem;
  border-top: 1px solid rgba(184,134,11,.2);
}

/* ── Village back bar ── */
.village-back-bar {
  display: flex; align-items: center; gap: .85rem;
  padding: .55rem 1.25rem;
  background: linear-gradient(180deg, #1a0e04, #120a02);
  border-bottom: 1px solid rgba(184,134,11,.25);
  position: sticky; top: 0; z-index: 100;
}

.village-back-btn {
  font-family: 'Cinzel', serif; font-size: .68rem; font-weight: 600;
  letter-spacing: .06em; padding: 4px 11px; border-radius: 2px;
  border: 1px solid rgba(184,134,11,.45);
  background: rgba(184,134,11,.07); color: var(--gold-light);
  cursor: pointer; transition: all .15s;
}
.village-back-btn:hover { background: rgba(184,134,11,.18); }

.village-back-label {
  font-family: 'Cinzel', serif; font-size: .82rem;
  color: var(--parchment-deep); letter-spacing: .08em;
}

.village-content {
  max-width: 980px; margin: 0 auto; padding: 0 1.5rem 4rem;
}
@media (max-width: 640px) { .village-content { padding: 0 .75rem 3rem; } }

/* ── Campaign card: date row ── */
.dash-card-date {
  font-family: 'Crimson Text', serif; font-size: .85rem;
  color: rgba(184,134,11,.75); margin-top: .1rem;
}
.dash-card-date[onclick] { cursor: pointer; }
.dash-card-date[onclick]:hover { color: var(--gold-light); }

/* ── Campaign card: three-dot menu ── */
.dash-card { position: relative; }
.dash-card-name { padding-right: 1.6rem; }

.dash-kmenu {
  position: absolute; top: .55rem; right: .6rem;
}
.dash-kmenu-btn {
  background: none; border: none; cursor: pointer;
  color: rgba(184,134,11,.45); font-size: 1.1rem; line-height: 1;
  padding: 2px 5px; border-radius: 2px; transition: color .15s;
}
.dash-kmenu-btn:hover { color: var(--gold-light); }

.dash-kdrop {
  display: none; position: absolute; right: 0; top: 100%;
  background: #1a0e04; border: 1px solid rgba(184,134,11,.35);
  border-radius: 3px; min-width: 130px; z-index: 50;
  box-shadow: 0 4px 12px rgba(0,0,0,.5);
}
.dash-kdrop.open { display: block; }
.dash-kdrop button {
  display: block; width: 100%; text-align: left;
  background: none; border: none; cursor: pointer;
  font-family: 'Cinzel', serif; font-size: .68rem; font-weight: 600;
  letter-spacing: .04em; color: var(--parchment-deep);
  padding: 8px 14px; transition: background .12s;
}
.dash-kdrop button:hover { background: rgba(184,134,11,.12); color: var(--gold-light); }
.dash-kdrop .kdrop-delete { color: #e07070; }
.dash-kdrop .kdrop-delete:hover { background: rgba(140,20,20,.2); color: #f09090; }

/* ── Campaign card: clickable body ── */
.dash-card-body { cursor: pointer; border-radius: 3px; transition: background .12s; }
.dash-card-body:hover { background: rgba(184,134,11,.05); }

/* ── Campaign view ── */
#camp-view { min-height: 100vh; }

.camp-back-bar {
  display: flex; align-items: center; gap: .85rem;
  padding: .55rem 1.25rem;
  background: linear-gradient(180deg, #1a0e04, #120a02);
  border-bottom: 1px solid rgba(184,134,11,.25);
  position: sticky; top: 0; z-index: 100;
}
.camp-back-btn {
  font-family: 'Cinzel', serif; font-size: .68rem; font-weight: 600;
  letter-spacing: .06em; padding: 4px 11px; border-radius: 2px;
  border: 1px solid rgba(184,134,11,.45);
  background: rgba(184,134,11,.07); color: var(--gold-light);
  cursor: pointer; transition: all .15s;
}
.camp-back-btn:hover { background: rgba(184,134,11,.18); }
.camp-back-label {
  font-family: 'Cinzel', serif; font-size: .82rem;
  color: var(--parchment-deep); letter-spacing: .08em;
}
.camp-content {
  max-width: 680px; margin: 0 auto; padding: 1.5rem 1.5rem 4rem;
}
@media (max-width: 640px) { .camp-content { padding: 1rem .75rem 3rem; } }

.camp-section {
  background: rgba(255,255,255,.022);
  border: 1px solid rgba(184,134,11,.2); border-radius: 4px;
  margin-bottom: 1rem; overflow: hidden;
}
.camp-section-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: .65rem 1rem;
  border-bottom: 1px solid rgba(184,134,11,.15);
  font-family: 'Cinzel', serif; font-size: .76rem; font-weight: 700;
  color: var(--gold-light); letter-spacing: .06em;
}
.camp-sec-btn {
  font-family: 'Cinzel', serif; font-size: .63rem; font-weight: 600;
  letter-spacing: .04em; cursor: pointer;
  background: rgba(184,134,11,.07); border: 1px solid rgba(184,134,11,.35);
  color: var(--gold-light); border-radius: 2px; padding: 3px 9px;
  transition: all .15s;
}
.camp-sec-btn:hover { background: rgba(184,134,11,.18); }

/* Camp info */
.camp-info-grid { padding: .65rem 1rem .8rem; display: flex; flex-direction: column; gap: .45rem; }
.camp-info-row {
  display: flex; align-items: baseline; gap: .6rem;
  font-family: 'Crimson Text', serif; font-size: .92rem; color: var(--parchment-deep);
}
.camp-info-label {
  font-family: 'Cinzel', serif; font-size: .67rem; font-weight: 700;
  color: rgba(184,134,11,.6); letter-spacing: .05em; min-width: 96px; flex-shrink: 0;
}
.camp-info-date { color: rgba(184,134,11,.85); }
.camp-info-date[onclick] { cursor: pointer; }
.camp-info-date[onclick]:hover { color: var(--gold-light); }

.camp-desc {
  font-family: 'Crimson Text', serif; font-size: .9rem; font-style: italic;
  color: var(--ink-faint); margin: .15rem 0 0; line-height: 1.5;
  padding: 0 1rem .75rem;
}

.camp-edit-textarea {
  resize: vertical; min-height: 64px; line-height: 1.45;
  font-family: 'Crimson Text', serif; font-size: .9rem;
}

/* Members add tabs */
.camp-add-tabs {
  display: flex; padding: 0 1rem;
  border-bottom: 1px solid rgba(184,134,11,.15);
}
.camp-add-tab {
  font-family: 'Cinzel', serif; font-size: .63rem; font-weight: 600;
  letter-spacing: .04em; padding: .45rem .8rem; cursor: pointer;
  background: none; border: none; border-bottom: 2px solid transparent;
  color: var(--parchment-deep); transition: all .12s;
}
.camp-add-tab.active { color: var(--gold-light); border-bottom-color: var(--gold-light); }
.camp-add-tab:not(.active):hover { color: var(--parchment); }

/* Members */
.camp-add-row {
  display: flex; gap: .5rem; align-items: center;
  padding: .6rem 1rem; border-bottom: 1px solid rgba(184,134,11,.1);
  flex-wrap: wrap;
}
.camp-member-row {
  display: flex; align-items: center; gap: .55rem;
  padding: .42rem 1rem;
  border-bottom: 1px solid rgba(184,134,11,.08);
  font-family: 'Crimson Text', serif; font-size: .9rem;
}
.camp-member-row:last-child { border-bottom: none; }
.camp-member-name { flex: 1; color: var(--parchment); }
.camp-member-del {
  background: none; border: none; cursor: pointer;
  color: rgba(220,80,80,.45); font-size: .8rem;
  padding: 2px 5px; border-radius: 2px; transition: color .12s;
}
.camp-member-del:hover { color: #e07070; }

/* Profile modal */
.profile-avatar {
  width: 58px; height: 58px; border-radius: 50%;
  background: rgba(184,134,11,.12); border: 2px solid rgba(184,134,11,.4);
  display: inline-flex; align-items: center; justify-content: center;
  font-family: 'Cinzel', serif; font-size: 1.5rem; font-weight: 700;
  color: var(--gold-light);
}
.profile-readonly {
  font-family: 'Crimson Text', serif; font-size: .92rem;
  color: var(--parchment-deep); opacity: .65;
}

/* Camp info edit form */
.camp-edit-form { padding: .7rem 1rem .9rem; display: flex; flex-direction: column; gap: .5rem; }
.camp-edit-row {
  display: flex; align-items: center; gap: .6rem;
}
.camp-edit-row .field-input,
.camp-edit-row .field-select { flex: 1; min-width: 0; }
