body { background: #f8f9fa; }
.card { border: 0; box-shadow: 0 0.125rem 0.5rem rgba(0,0,0,.05); }
.summary-card { min-height: 8rem; }
.table td, .table th { vertical-align: middle; }
.opacity-50 { opacity: .6; }
code { white-space: nowrap; }

a { text-decoration: none; }
a:hover { text-decoration: underline; }

.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: .75rem;
}
.calendar-head {
  font-weight: 600;
  font-size: .95rem;
  color: #495057;
}
.calendar-cell {
  background: #fff;
  border-radius: .75rem;
  min-height: 12rem;
  padding: .75rem;
  box-shadow: 0 0.125rem 0.5rem rgba(0,0,0,.05);
  transition: box-shadow .15s ease, transform .15s ease;
}
.calendar-cell.is-muted { opacity: .65; }
.calendar-date-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: .5rem;
}
.calendar-pill {
  display: block;
  text-decoration: none;
  border-radius: .6rem;
  padding: .45rem .55rem;
  margin-bottom: .45rem;
  font-size: .82rem;
  line-height: 1.25;
}
.calendar-pill-time {
  font-weight: 700;
  font-size: .74rem;
}
.item-card {
  display: block;
  text-decoration: none;
  color: inherit;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-left: .4rem solid #6c757d;
  border-radius: .45rem;
  padding: .75rem;
  margin-bottom: .75rem;
}
.legend { display: flex; flex-wrap: wrap; gap: .75rem; align-items: center; }
.legend-title { font-weight: 600; }
.legend-item { display: inline-flex; align-items: center; gap: .4rem; font-size: .92rem; }
.legend-swatch, .color-chip { width: .9rem; height: .9rem; border-radius: 999px; display: inline-block; vertical-align: middle; box-shadow: inset 0 0 0 1px rgba(0,0,0,.12); }

.schedule-drop-zone.drop-target,
.calendar-cell.drop-target,
.card.drop-target {
  outline: 3px dashed rgba(13,110,253,.45);
  outline-offset: 2px;
  background: #eef5ff;
}
.task-chip { cursor: grab; }
.task-chip.dragging { opacity: .45; }
.print-wrap { max-width: 1100px; margin: 0 auto; padding: 1rem; background: #fff; }
.print-table { background: #fff; }

@media print {
  body { background: #fff; }
  .navbar, .btn, form, .alert, .legend, .small.text-muted { display: none !important; }
  .container-fluid { padding: 0 !important; }
  .card, .calendar-cell, .item-card { box-shadow: none !important; border: 1px solid #ddd !important; }
  a { color: #000 !important; text-decoration: none !important; }
}

@media (max-width: 991.98px) {
  .calendar-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 575.98px) {
  .calendar-grid { grid-template-columns: 1fr; }
}


.brand-lockup {
  display: inline-flex;
  align-items: center;
  gap: .7rem;
  text-decoration: none;
}
.brand-logo {
  width: 2.6rem;
  height: 2.6rem;
  object-fit: contain;
  padding: 0;
}
.brand-title {
  font-weight: 700;
  letter-spacing: .01em;
}


.active-filters { display:flex; flex-wrap:wrap; gap:.5rem; align-items:center; }
.filter-panel summary, .legend-panel summary, .calendar-group-summary { cursor:pointer; }
.filter-panel summary::marker, .legend-panel summary::marker, .calendar-group-summary::marker { display:none; }
.calendar-group { background: rgba(248,249,250,.65); border:1px solid rgba(0,0,0,.06); border-radius:.6rem; padding:.35rem .45rem; }
.calendar-group-summary { list-style:none; display:flex; align-items:center; justify-content:space-between; gap:.5rem; border-left:.35rem solid var(--group-color, #6c757d); padding:.3rem .45rem; border-radius:.3rem; background:#fff; }
.calendar-group-name { font-size:.78rem; font-weight:700; line-height:1.2; }
.calendar-group-items .calendar-pill { margin-bottom:.35rem; }
.calendar-cell .calendar-pill { font-size:.76rem; }
@media print { .active-filters { display:none !important; } }


.comm-type-grid { display: grid; gap: .75rem; }
.comm-type-option { position: relative; }
.comm-type-input { position: absolute; opacity: 0; pointer-events: none; }
.comm-type-tile {
  display: block;
  width: 100%;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: .85rem;
  padding: .9rem 1rem;
  background: #fff;
  color: #212529;
  transition: background-color .15s ease, color .15s ease, border-color .15s ease, box-shadow .15s ease, transform .15s ease;
  cursor: pointer;
  box-shadow: 0 0.125rem 0.5rem rgba(0,0,0,.03);
}
.comm-type-tile:hover { text-decoration: none; border-color: color-mix(in srgb, var(--tile-color, #0d6efd) 45%, white); box-shadow: 0 0.35rem 1rem rgba(0,0,0,.06); }
.comm-type-title { display: block; font-weight: 700; line-height: 1.25; margin-bottom: .2rem; }
.comm-type-description { display: block; font-size: .92rem; color: #6c757d; line-height: 1.35; }
.comm-type-input:checked + .comm-type-tile {
  background: var(--tile-color, #0d6efd);
  border-color: var(--tile-color, #0d6efd);
  color: #fff;
  box-shadow: 0 0.5rem 1rem rgba(0,0,0,.08);
}
.comm-type-input:checked + .comm-type-tile .comm-type-description { color: rgba(255,255,255,.88); }
.comm-type-input:focus-visible + .comm-type-tile { outline: 3px solid rgba(13,110,253,.28); outline-offset: 2px; }
.comm-type-option-sm .comm-type-tile { padding: .55rem .75rem; border-radius: .7rem; }
.comm-type-option-sm .comm-type-title { margin-bottom: 0; font-size: .95rem; }
.comm-type-option-sm .comm-type-description { display: none; }


.comm-type-grid.compact-grid { gap: .55rem; }
.comm-type-tile { position: relative; padding-right: 2.2rem; }
.comm-type-topline { display:flex; align-items:center; gap:.45rem; margin-bottom:.2rem; }
.comm-type-icon { display:inline-flex; align-items:center; justify-content:center; width:1.35rem; height:1.35rem; border-radius:999px; background: color-mix(in srgb, var(--tile-color, #0d6efd) 12%, white); color: var(--tile-color, #0d6efd); font-size:.82rem; line-height:1; flex:0 0 auto; }
.comm-type-check { position:absolute; top:.7rem; right:.8rem; width:1.15rem; height:1.15rem; border-radius:999px; display:inline-flex; align-items:center; justify-content:center; background:rgba(13,110,253,.08); color:transparent; font-size:.8rem; font-weight:700; box-shadow: inset 0 0 0 1px rgba(0,0,0,.08); }
.comm-type-input:checked + .comm-type-tile .comm-type-check { background: rgba(255,255,255,.22); color:#fff; box-shadow: inset 0 0 0 1px rgba(255,255,255,.35); }
.comm-type-input:checked + .comm-type-tile .comm-type-icon { background: rgba(255,255,255,.18); color:#fff; }
.comm-type-option-sm .comm-type-check { top:.6rem; right:.65rem; }
.comm-type-option-sm .comm-type-tile { padding: .5rem .7rem; padding-right: 2rem; }
.comm-type-option-sm .comm-type-topline { margin-bottom: 0; }
@media (max-width: 1199.98px) {
  .comm-type-grid { gap: .6rem; }
  .comm-type-tile { padding: .75rem .85rem; padding-right: 2rem; }
  .comm-type-description { font-size: .87rem; }
}


.selector-grid { display:grid; gap:.6rem; grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); }
.selector-grid-sm { max-height: 18rem; overflow:auto; padding-right:.15rem; }
.selector-option { position:relative; }
.selector-input { position:absolute; opacity:0; pointer-events:none; }
.selector-tile {
  display:block;
  width:100%;
  border:1px solid rgba(0,0,0,.12);
  border-radius:.85rem;
  padding:.85rem .95rem;
  padding-right:2.15rem;
  background:#fff;
  color:#212529;
  transition: background-color .15s ease, color .15s ease, border-color .15s ease, box-shadow .15s ease, transform .15s ease;
  cursor:pointer;
  box-shadow: 0 0.125rem 0.5rem rgba(0,0,0,.03);
  min-height: 100%;
}
.selector-tile:hover { text-decoration:none; border-color: color-mix(in srgb, var(--selector-color, #6c757d) 45%, white); box-shadow: 0 0.35rem 1rem rgba(0,0,0,.06); }
.selector-topline { display:flex; align-items:center; gap:.45rem; margin-bottom:.2rem; }
.selector-title { display:block; font-weight:700; line-height:1.25; margin-bottom:.15rem; }
.selector-description { display:block; font-size:.9rem; color:#6c757d; line-height:1.35; }
.selector-icon { display:inline-flex; align-items:center; justify-content:center; width:1.35rem; height:1.35rem; border-radius:999px; background: color-mix(in srgb, var(--selector-color, #6c757d) 12%, white); color: var(--selector-color, #6c757d); font-size:.82rem; line-height:1; flex:0 0 auto; }
.selector-check { position:absolute; top:.7rem; right:.8rem; width:1.15rem; height:1.15rem; border-radius:999px; display:inline-flex; align-items:center; justify-content:center; background:rgba(13,110,253,.08); color:transparent; font-size:.8rem; font-weight:700; box-shadow: inset 0 0 0 1px rgba(0,0,0,.08); }
.selector-input:checked + .selector-tile {
  background: var(--selector-color, #6c757d);
  border-color: var(--selector-color, #6c757d);
  color:#fff;
  box-shadow: 0 0.5rem 1rem rgba(0,0,0,.08);
}
.selector-input:checked + .selector-tile .selector-description { color: rgba(255,255,255,.88); }
.selector-input:checked + .selector-tile .selector-check { background: rgba(255,255,255,.22); color:#fff; box-shadow: inset 0 0 0 1px rgba(255,255,255,.35); }
.selector-input:checked + .selector-tile .selector-icon { background: rgba(255,255,255,.18); color:#fff; }
.selector-input:focus-visible + .selector-tile { outline: 3px solid rgba(13,110,253,.28); outline-offset: 2px; }
@media (max-width: 1199.98px) {
  .selector-grid { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
}


.color-palette-grid { display:grid; gap:.6rem; grid-template-columns: repeat(auto-fit, minmax(110px, 1fr)); }
.color-option { position:relative; }
.color-input { position:absolute; opacity:0; pointer-events:none; }
.color-tile {
  display:flex; align-items:center; gap:.65rem; width:100%;
  border:1px solid rgba(0,0,0,.12); border-radius:.85rem; background:#fff; color:#212529;
  padding:.7rem .85rem; cursor:pointer; box-shadow: 0 0.125rem 0.5rem rgba(0,0,0,.03);
  transition: background-color .15s ease, color .15s ease, border-color .15s ease, box-shadow .15s ease;
}
.color-tile:hover { border-color: color-mix(in srgb, var(--swatch-color, #6c757d) 45%, white); box-shadow: 0 0.35rem 1rem rgba(0,0,0,.06); }
.color-chip { width:1.4rem; height:1.4rem; border-radius:999px; background:var(--swatch-color, #6c757d); box-shadow: inset 0 0 0 1px rgba(0,0,0,.08); flex:0 0 auto; }
.color-label { font-weight:600; line-height:1.2; }
.color-input:checked + .color-tile { background: var(--swatch-color, #6c757d); border-color: var(--swatch-color, #6c757d); color:#fff; box-shadow: 0 0.5rem 1rem rgba(0,0,0,.08); }
.color-input:checked + .color-tile .color-chip { box-shadow: inset 0 0 0 2px rgba(255,255,255,.45); }
.color-input:focus-visible + .color-tile { outline:3px solid rgba(13,110,253,.28); outline-offset:2px; }


.planner-week-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:1rem}.planner-day-card{background:#fff;border:1px solid #dee2e6;border-radius:.75rem;padding:.75rem;min-height:14rem}.planner-day-header{font-weight:700;margin-bottom:.5rem}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:.5rem}.calendar-heading{font-weight:700;padding:.5rem;text-align:center;background:#f8f9fa;border-radius:.5rem}.calendar-cell{background:#fff;border:1px solid #dee2e6;border-radius:.75rem;padding:.5rem;min-height:9rem}.calendar-cell.muted{opacity:.55}.calendar-date{font-weight:700;margin-bottom:.35rem}.calendar-pill{border-radius:999px;padding:.2rem .45rem;font-size:.8rem;margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-chip{cursor:grab}.task-chip.dragging{opacity:.6}.settings-export-tools .form-control-sm{width:auto;min-width:220px}@media (max-width: 991px){.planner-week-grid,.calendar-grid{grid-template-columns:1fr}}


.poster-thumb { width: 56px !important; height: 78px !important; object-fit: contain !important; object-position: center center; border-radius: .35rem; border: 1px solid rgba(0,0,0,.12); background: #fff; padding: .2rem; flex: 0 0 auto; display:block; }
.poster-thumb-lg { width: 96px !important; height: 132px !important; object-fit: contain !important; object-position: center center; border-radius: .4rem; border: 1px solid rgba(0,0,0,.12); background: #fff; padding: .25rem; flex: 0 0 auto; display:block; }
.asset-thumb { width: 112px !important; height: 84px !important; object-fit: contain !important; object-position: center center; border-radius: .4rem; border: 1px solid rgba(0,0,0,.12); background: #fff; padding: .25rem; flex: 0 0 auto; display:block; }
.asset-thumb-lg { width: 160px !important; height: 120px !important; object-fit: contain !important; object-position: center center; border-radius: .45rem; border: 1px solid rgba(0,0,0,.12); background: #fff; padding: .3rem; flex: 0 0 auto; display:block; }
.text-break { word-break: break-word; }

.calendar-rect{border-radius:.5rem;padding:.45rem .55rem;font-size:.8rem;margin-bottom:.35rem;white-space:normal;overflow:visible}.standalone-task-card{box-shadow:inset 0 0 0 1px rgba(255,255,255,.2)}



.schedule-task-card {
  display: block;
  text-decoration: none;
  color: inherit;
  background: #fff;
  border: 1px solid #dfe5ec;
  border-radius: .7rem;
  padding: .55rem .65rem;
  margin-bottom: .45rem;
  line-height: 1.25;
  box-shadow: 0 1px 2px rgba(15, 23, 42, .04);
}
.schedule-task-card.option-b {
  background: var(--task-tint, rgba(13,110,253,.08));
}
.task-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: .6rem;
  margin: 0 0 .15rem 0;
  padding: 0;
  border-bottom: 0;
  border-radius: 0;
}
.task-card-title-wrap {
  display: flex;
  gap: .55rem;
  min-width: 0;
  flex: 1 1 auto;
}
.task-card-rail {
  width: .28rem;
  border-radius: 999px;
  background: var(--task-rail, #6c757d);
  align-self: stretch;
  min-height: 1.35rem;
  flex: 0 0 auto;
}
.schedule-task-title {
  font-size: .78rem !important;
  font-weight: 600 !important;
  line-height: 1.2 !important;
  color: #1f2937;
}
.schedule-task-title a {
  font-size: inherit !important;
  font-weight: inherit !important;
  line-height: inherit !important;
  color: inherit !important;
  text-decoration: none;
}
.schedule-task-title a:hover {
  text-decoration: underline;
}
.task-card-status .badge,
.schedule-task-card .badge {
  font-size: .66rem;
}
.task-card-body {
  margin-left: .83rem;
}
.task-card-meta-badges .badge {
  font-weight: 500;
}
.schedule-task-card a {
  color: #2563eb;
  text-decoration: none;
}
.schedule-task-card a:hover {
  text-decoration: underline;
}
.calendar-group-items .schedule-task-card:last-child,
.ps-2 .schedule-task-card:last-child {
  margin-bottom: 0;
}

.task-card-actions { display:none !important; }
.task-icon-actions { display:none !important; }
.task-icon-btn { display:none !important; }
.calendar-group-items { overflow:visible; }

.poster-thumb-gallery { display:flex; flex-direction:row; flex-wrap:wrap; gap:.5rem; align-items:flex-start; }

.task-context-menu {
  position: fixed;
  z-index: 1080;
  background: #fff;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: .65rem;
  padding: .55rem;
  min-width: 11rem;
}
.task-context-title {
  font-size: .75rem;
  font-weight: 700;
  color: #6b7280;
  margin-bottom: .35rem;
}
.task-context-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: .35rem;
}
.task-context-grid .btn {
  min-width: 2rem;
  padding: .3rem .4rem;
  line-height: 1;
}
.calendar-event-line {
  display: block;
  color: inherit;
  text-decoration: none;
  padding: .16rem .2rem .16rem .45rem;
  margin-bottom: .18rem;
  border-left: 4px solid var(--event-color, #6c757d);
  border-radius: .25rem;
  line-height: 1.2;
  font-size: .8rem;
}
.calendar-event-line:hover {
  text-decoration: none;
  background: rgba(0,0,0,.035);
}
.calendar-event-time {
  font-weight: 700;
  margin-right: .35rem;
}


.events-month-item {
  display: block;
  text-decoration: none;
  color: inherit;
  border-radius: .45rem;
  padding: .2rem .35rem .2rem .45rem;
  margin-bottom: .25rem;
  border-left: 4px solid var(--event-color, #6c757d);
  background: transparent;
  line-height: 1.15;
}
.events-month-item .event-month-time {
  font-size: .66rem;
  color: #4b5563;
}
.events-month-item .event-month-title {
  font-size: .72rem;
  font-weight: 600;
  color: #1f2937;
}
.schedule-context-menu {
  position: fixed;
  z-index: 3000;
  min-width: 180px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: .5rem;
  box-shadow: 0 8px 24px rgba(0,0,0,.16);
  padding: .35rem;
  display: none;
}
.schedule-context-menu.show {
  display: block;
}
.schedule-context-menu button,
.schedule-context-menu a {
  display: block;
  width: 100%;
  text-align: left;
  border: 0;
  background: transparent;
  padding: .45rem .55rem;
  border-radius: .35rem;
  color: #1f2937;
  text-decoration: none;
  font-size: .82rem;
}
.schedule-context-menu button:hover,
.schedule-context-menu a:hover {
  background: #f3f4f6;
}
