/* ============================================================
   SSB MCC Manager – Frontend Styles v1.0.0
   ============================================================ */

:root {
  --mcc-red:        #A93226;
  --mcc-red-dark:   #7B241C;
  --mcc-red-light:  #FADBD8;
  --mcc-blue:       #1B4F72;
  --mcc-blue-light: #D6EAF8;
  --mcc-green:      #1A7A2E;
  --mcc-green-bg:   #D5F5E3;
  --mcc-orange:     #CA6F1E;
  --mcc-orange-bg:  #FDEBD0;
  --mcc-grey:       #F4F6F7;
  --mcc-border:     #D5DBDB;
  --mcc-text:       #1C2833;
  --mcc-muted:      #717D7E;
  --mcc-radius:     8px;
  --mcc-shadow:     0 2px 8px rgba(0,0,0,.10);
}

.mcc-app { font-family: Arial, sans-serif; font-size: 15px; color: var(--mcc-text); max-width: 960px; }

.mcc-loading { text-align:center; padding:3rem; color:var(--mcc-muted); }
.mcc-spinner { display:inline-block; width:36px; height:36px; border:4px solid var(--mcc-red-light); border-top-color:var(--mcc-red); border-radius:50%; animation:mcc-spin .8s linear infinite; margin-bottom:.5rem; }
@keyframes mcc-spin { to { transform:rotate(360deg); } }

/* ── Auth ── */
.mcc-auth { background:#fff; border:1px solid var(--mcc-border); border-radius:var(--mcc-radius); padding:2.5rem; max-width:420px; margin:2rem auto; box-shadow:var(--mcc-shadow); }
.mcc-auth h2 { color:var(--mcc-red-dark); margin:0 0 .5rem; font-size:1.3rem; }
.mcc-auth .mcc-event-name { color:var(--mcc-muted); font-size:.9rem; margin:0 0 1.5rem; }
.mcc-auth label { display:block; font-weight:bold; margin-bottom:.4rem; color:var(--mcc-red-dark); }
.mcc-auth input[type=password], .mcc-auth input[type=email] { width:100%; padding:.6rem .8rem; border:1px solid var(--mcc-border); border-radius:6px; font-size:1rem; box-sizing:border-box; }
.mcc-auth input:focus { border-color:var(--mcc-red); outline:none; box-shadow:0 0 0 2px var(--mcc-red-light); }
.mcc-auth-error { color:var(--mcc-red); background:var(--mcc-red-light); border-radius:5px; padding:.5rem .8rem; font-size:.9rem; margin-top:.8rem; display:none; }

/* ── Header ── */
.mcc-header { background:linear-gradient(135deg, var(--mcc-red-dark), var(--mcc-red)); color:#fff; border-radius:var(--mcc-radius) var(--mcc-radius) 0 0; padding:1rem 1.5rem; display:flex; align-items:center; justify-content:space-between; }
.mcc-header h2 { margin:0; font-size:1.15rem; }
.mcc-header .mcc-role-badge { background:rgba(255,255,255,.2); border-radius:20px; padding:.2rem .8rem; font-size:.85rem; }
.mcc-header .mcc-logout { background:none; border:1px solid rgba(255,255,255,.5); color:#fff; border-radius:20px; padding:.2rem .7rem; font-size:.8rem; cursor:pointer; margin-left:.5rem; }
.mcc-header .mcc-logout:hover { background:rgba(255,255,255,.15); }
.mcc-container { background:#fff; border:1px solid var(--mcc-border); border-top:none; border-radius:0 0 var(--mcc-radius) var(--mcc-radius); padding:1.5rem; }

/* ── Buttons ── */
.mcc-btn { display:inline-block; padding:.5rem 1.1rem; border-radius:6px; font-size:.9rem; font-weight:bold; cursor:pointer; border:none; transition:opacity .15s; }
.mcc-btn:hover { opacity:.85; }
.mcc-btn-primary   { background:var(--mcc-red);       color:#fff; }
.mcc-btn-success   { background:var(--mcc-green);      color:#fff; }
.mcc-btn-danger    { background:#922B21;               color:#fff; }
.mcc-btn-warning   { background:var(--mcc-orange);     color:#fff; }
.mcc-btn-secondary { background:var(--mcc-grey);       color:var(--mcc-text); border:1px solid var(--mcc-border); }
.mcc-btn-lock      { background:#784212;               color:#fff; }
.mcc-btn-sm        { padding:.3rem .7rem; font-size:.82rem; }

/* ── Tabs ── */
.mcc-tabs { display:flex; border-bottom:2px solid var(--mcc-border); margin-bottom:1.5rem; }
.mcc-tab { padding:.6rem 1.2rem; cursor:pointer; font-weight:bold; color:var(--mcc-muted); border-bottom:3px solid transparent; margin-bottom:-2px; font-size:.9rem; }
.mcc-tab:hover { color:var(--mcc-red); }
.mcc-tab.active { color:var(--mcc-red-dark); border-bottom-color:var(--mcc-red); }
.mcc-tab-content { display:none; }
.mcc-tab-content.active { display:block; }

/* ── Stats ── */
.mcc-stats { display:flex; gap:1rem; margin-bottom:1.5rem; flex-wrap:wrap; }
.mcc-stat-card { background:var(--mcc-red-light); border-radius:8px; padding:.8rem 1.2rem; text-align:center; min-width:100px; }
.mcc-stat-card .num { font-size:2rem; font-weight:bold; color:var(--mcc-red-dark); line-height:1; }
.mcc-stat-card .lbl { font-size:.8rem; color:var(--mcc-muted); margin-top:.2rem; }

/* ── Slot cards ── */
.mcc-slots-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:1rem; }
.mcc-slot-card { border:1px solid var(--mcc-border); border-radius:var(--mcc-radius); padding:1rem; }
.mcc-slot-card.available { border-left:4px solid var(--mcc-green); }
.mcc-slot-card.full { border-left:4px solid var(--mcc-muted); opacity:.7; }
.mcc-slot-card.locked { border-left:4px solid #784212; background:#fdf2e9; }
.mcc-slot-date { font-weight:bold; color:var(--mcc-red-dark); font-size:1rem; }
.mcc-slot-time { color:var(--mcc-text); font-size:1.05rem; margin:.2rem 0; }
.mcc-slot-notes { color:var(--mcc-muted); font-size:.85rem; margin-bottom:.6rem; }

/* ── Form ── */
.mcc-form-panel { background:var(--mcc-grey); border-radius:var(--mcc-radius); padding:1.2rem; margin-bottom:1.5rem; }
.mcc-form-panel h3 { margin:0 0 1rem; color:var(--mcc-red-dark); font-size:1rem; }
.mcc-form-row { display:flex; gap:.8rem; flex-wrap:wrap; align-items:flex-end; }
.mcc-form-group { display:flex; flex-direction:column; gap:.3rem; }
.mcc-form-group.flex-1 { flex:1; min-width:140px; }
.mcc-form-group label { font-size:.85rem; font-weight:bold; color:var(--mcc-red-dark); }
.mcc-form-group input,.mcc-form-group textarea,.mcc-form-group select {
  padding:.45rem .7rem; border:1px solid var(--mcc-border); border-radius:6px; font-size:.9rem; font-family:inherit;
}
.mcc-form-group input:focus,.mcc-form-group textarea:focus,.mcc-form-group select:focus {
  border-color:var(--mcc-red); outline:none; box-shadow:0 0 0 2px var(--mcc-red-light);
}

/* ── Table ── */
.mcc-table { width:100%; border-collapse:collapse; font-size:.9rem; }
.mcc-table th { background:var(--mcc-red-dark); color:#fff; padding:.6rem .8rem; text-align:left; font-size:.85rem; }
.mcc-table td { padding:.55rem .8rem; border-bottom:1px solid var(--mcc-border); }
.mcc-table tr:hover td { background:var(--mcc-grey); }
.mcc-table-wrap { overflow-x:auto; }

/* ── Modal ── */
.mcc-modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.45); z-index:9999; align-items:center; justify-content:center; }
.mcc-modal-overlay.open { display:flex; }
.mcc-modal { background:#fff; border-radius:var(--mcc-radius); padding:2rem; max-width:500px; width:95%; max-height:90vh; overflow-y:auto; box-shadow:0 8px 30px rgba(0,0,0,.2); }
.mcc-modal h3 { margin:0 0 1.2rem; color:var(--mcc-red-dark); }
.mcc-modal .mcc-form-group { margin-bottom:.8rem; }
.mcc-modal label { display:block; font-size:.85rem; font-weight:bold; color:var(--mcc-red-dark); margin-bottom:.3rem; }
.mcc-modal input,.mcc-modal textarea,.mcc-modal select { width:100%; padding:.5rem .7rem; border:1px solid var(--mcc-border); border-radius:6px; font-size:.9rem; font-family:inherit; box-sizing:border-box; }
.mcc-modal .required { color:var(--mcc-red); }
.mcc-modal-actions { display:flex; gap:.7rem; justify-content:flex-end; margin-top:1.2rem; }
.mcc-modal-error { color:var(--mcc-red); background:var(--mcc-red-light); border-radius:5px; padding:.5rem .8rem; font-size:.88rem; margin-top:.8rem; display:none; }
.mcc-team-fields { background:var(--mcc-blue-light); border-radius:6px; padding:.8rem; margin-top:.5rem; display:none; }

/* ── Confirmation ── */
.mcc-confirmation { background:var(--mcc-green-bg); border:1px solid var(--mcc-green); border-radius:var(--mcc-radius); padding:1.5rem; }
.mcc-confirmation h3 { color:var(--mcc-green); margin:0 0 1rem; }
.mcc-confirmation .mcc-notice { background:#fff3cd; border:1px solid #ffc107; border-radius:5px; padding:.7rem 1rem; margin-top:1rem; font-size:.88rem; color:#856404; }

/* ── Teilnehmerbereich ── */
.mcc-tn-header { background:linear-gradient(135deg, var(--mcc-red-dark), var(--mcc-red)); color:#fff; border-radius:8px; padding:1.2rem 1.5rem; margin-bottom:1.5rem; }
.mcc-tn-header h3 { margin:0 0 .2rem; font-size:1.1rem; }
.mcc-tn-header .mcc-tn-email { font-size:.9rem; opacity:.85; }
.mcc-doc-section { margin-bottom:1.5rem; }
.mcc-doc-section h4 { color:var(--mcc-red-dark); border-bottom:2px solid var(--mcc-red-light); padding-bottom:.4rem; margin-bottom:.8rem; }
.mcc-doc-card { display:flex; align-items:center; gap:1rem; padding:.7rem 1rem; border:1px solid var(--mcc-border); border-radius:6px; margin-bottom:.4rem; background:#fff; }
.mcc-doc-card:hover { border-color:var(--mcc-red); background:var(--mcc-red-light); }
.mcc-doc-icon { font-size:1.5rem; flex-shrink:0; }
.mcc-doc-info { flex:1; }
.mcc-doc-info .mcc-doc-title { font-weight:bold; font-size:.95rem; }
.mcc-doc-info .mcc-doc-desc { font-size:.82rem; color:var(--mcc-muted); }
.mcc-doc-download { flex-shrink:0; }
.mcc-doc-badge { display:inline-flex; align-items:center; margin-left:.45rem; padding:.1rem .45rem; border-radius:999px; font-size:.68rem; font-weight:700; line-height:1.2; vertical-align:middle; border:1px solid var(--mcc-border); background:var(--mcc-grey); color:var(--mcc-text); }
.mcc-doc-badge-mac { background:#eef2f7; color:#1C2833; }
.mcc-doc-badge-windows { background:var(--mcc-blue-light); color:var(--mcc-blue); }

.mcc-doc-cat-dmx .mcc-doc-card { border-left:4px solid #784212; }
.mcc-doc-cat-personal .mcc-doc-card { border-left:4px solid var(--mcc-red); }
.mcc-email-form { background:var(--mcc-grey); border-radius:8px; padding:1.2rem; margin-bottom:1.2rem; }
.mcc-email-form h3 { margin:0 0 .8rem; color:var(--mcc-red-dark); font-size:1rem; }

/* ── Checklist ── */
.mcc-checklist-filters { display:flex; gap:.7rem; flex-wrap:wrap; margin-bottom:1.2rem; align-items:center; }
.mcc-checklist-filters label { font-size:.85rem; font-weight:bold; color:var(--mcc-red-dark); }
.mcc-checklist-filters select { padding:.35rem .6rem; border:1px solid var(--mcc-border); border-radius:6px; font-size:.88rem; }
.mcc-progress-bar-wrap { background:var(--mcc-border); border-radius:99px; height:10px; overflow:hidden; margin-top:.4rem; }
.mcc-progress-bar { background:var(--mcc-green); height:100%; border-radius:99px; transition:width .4s; }
.mcc-section-title { color:var(--mcc-red-dark); font-size:1rem; font-weight:bold; margin:1.5rem 0 .7rem; padding-bottom:.3rem; border-bottom:2px solid var(--mcc-red-light); }
.mcc-item-card { border:1px solid var(--mcc-border); border-radius:var(--mcc-radius); margin-bottom:.4rem; overflow:hidden; }
.mcc-item-header { display:flex; align-items:center; padding:.7rem 1rem; gap:.7rem; cursor:pointer; background:#fff; }
.mcc-item-header:hover { background:var(--mcc-grey); }
.mcc-item-title { flex:1; font-size:.9rem; font-weight:bold; }
.mcc-item-body { padding:.8rem 1rem 1rem; border-top:1px solid var(--mcc-border); background:var(--mcc-grey); display:none; }
.mcc-item-body.open { display:block; }
.mcc-item-desc { color:var(--mcc-muted); font-size:.85rem; margin-bottom:.7rem; }
.mcc-item-meta { font-size:.78rem; color:var(--mcc-muted); margin-bottom:.7rem; }
.mcc-status { display:inline-flex; align-items:center; gap:.3rem; border-radius:20px; padding:.18rem .65rem; font-size:.78rem; font-weight:bold; white-space:nowrap; }
.mcc-status-open        { background:var(--mcc-red-light);   color:var(--mcc-red-dark); }
.mcc-status-in_progress { background:var(--mcc-orange-bg);   color:var(--mcc-orange); }
.mcc-status-done        { background:var(--mcc-green-bg);    color:var(--mcc-green); }
.mcc-status-na          { background:var(--mcc-grey);        color:var(--mcc-muted); }
.mcc-owner { display:inline-block; border-radius:4px; padding:.1rem .5rem; font-size:.73rem; font-weight:bold; margin-right:.3rem; }
.mcc-owner-ssb    { background:#D6EAF8; color:#1B4F72; }
.mcc-owner-therme { background:#D5F5E3; color:#1A7A2E; }
.mcc-owner-both   { background:#F5CBA7; color:#784212; }
.mcc-comments { margin-top:.8rem; }
.mcc-comment { background:#fff; border-left:3px solid var(--mcc-red); border-radius:0 4px 4px 0; padding:.5rem .8rem; margin-bottom:.4rem; font-size:.85rem; }
.mcc-comment .mcc-comment-meta { font-size:.77rem; color:var(--mcc-muted); margin-bottom:.2rem; }
.mcc-edit-form { background:#fff; border:1px solid var(--mcc-border); border-radius:6px; padding:1rem; margin-top:.8rem; }
.mcc-edit-form label { display:block; font-size:.83rem; font-weight:bold; color:var(--mcc-red-dark); margin-bottom:.3rem; }
.mcc-edit-form select,.mcc-edit-form textarea { width:100%; box-sizing:border-box; padding:.4rem .6rem; border:1px solid var(--mcc-border); border-radius:5px; font-family:inherit; font-size:.88rem; margin-bottom:.7rem; }
.mcc-edit-form textarea { min-height:60px; resize:vertical; }
.mcc-msg { padding:.7rem 1rem; border-radius:6px; margin:.8rem 0; font-size:.9rem; display:none; }
.mcc-msg.success { background:var(--mcc-green-bg); color:var(--mcc-green); }
.mcc-msg.error   { background:var(--mcc-red-light); color:var(--mcc-red-dark); }
.mcc-badge-locked { background:#784212; color:#fff; border-radius:4px; padding:.1rem .5rem; font-size:.75rem; }

@media (max-width:600px) {
  .mcc-stats,.mcc-form-row { flex-direction:column; }
  .mcc-slots-grid { grid-template-columns:1fr; }
  .mcc-doc-card { flex-wrap:wrap; }
}

/* ── Submission System ─────────────────────────────────────── */
.mcc-sub-progress { background:var(--mcc-grey); border-radius:8px; padding:1rem 1.2rem; margin-bottom:1.2rem; }
.mcc-sub-progress-text { display:flex; justify-content:space-between; align-items:center; margin-bottom:.4rem; font-size:.9rem; color:#555; }
.mcc-sub-hint { font-size:.82rem; color:var(--mcc-muted); margin:.4rem 0 0; }
.mcc-sub-tabs { display:flex; border-bottom:2px solid var(--mcc-border); margin-bottom:1.2rem; }
.mcc-sub-tab-content { display:none; }
.mcc-sub-tab-content.active { display:block; }
.mcc-sub-section-title { color:var(--mcc-red-dark); font-size:.95rem; font-weight:bold; margin:1rem 0 .6rem; padding-bottom:.3rem; border-bottom:1px solid var(--mcc-red-light); }
.mcc-field-card { border:2px solid var(--mcc-border); border-radius:var(--mcc-radius); padding:1rem 1.1rem; margin-bottom:.6rem; transition:box-shadow .15s; }
.mcc-field-card:hover { box-shadow:var(--mcc-shadow); }
.mcc-field-header { display:flex; align-items:center; justify-content:space-between; gap:.7rem; flex-wrap:wrap; margin-bottom:.4rem; }
.mcc-field-label { font-weight:bold; font-size:.95rem; color:var(--mcc-text); }
.mcc-required { color:var(--mcc-red); }
.mcc-optional { color:var(--mcc-muted); font-size:.8rem; font-weight:normal; }
.mcc-field-hint { font-size:.82rem; color:var(--mcc-muted); margin-bottom:.5rem; }
.mcc-sub-status { display:inline-block; border-radius:20px; padding:.15rem .7rem; font-size:.78rem; font-weight:bold; white-space:nowrap; }
.mcc-sub-pending  { background:#f4f6f7; color:#717d7e; }
.mcc-sub-review   { background:var(--mcc-orange-bg); color:var(--mcc-orange); }
.mcc-sub-accepted { background:var(--mcc-green-bg); color:var(--mcc-green); }
.mcc-sub-value { background:#f8f9fa; border-radius:5px; padding:.6rem .8rem; font-size:.88rem; margin:.4rem 0; word-break:break-word; max-height:120px; overflow-y:auto; }
.mcc-sub-empty { font-style:italic; color:#bbb; font-size:.88rem; margin:.3rem 0; }
.mcc-sub-timestamps { font-size:.77rem; color:var(--mcc-muted); margin-top:.3rem; }
.mcc-sub-ssb-note { font-size:.82rem; color:var(--mcc-blue); background:var(--mcc-blue-light); border-radius:4px; padding:.25rem .6rem; margin-top:.3rem; display:inline-block; }
.mcc-ssb-accept-form { display:flex; align-items:center; gap:.4rem; flex-wrap:wrap; margin-top:.5rem; }
.mcc-ssb-notes-input { padding:.4rem .6rem; border:1px solid var(--mcc-border); border-radius:5px; font-size:.88rem; min-width:200px; }

.mcc-oil-row{display:flex;gap:.8rem;align-items:flex-end;margin-bottom:.7rem}.mcc-oil-row .mcc-form-group{margin-bottom:0;flex:0 0 120px}@media(max-width:600px){.mcc-oil-row{flex-direction:column;align-items:stretch}.mcc-oil-row .mcc-form-group{flex:1}}

.mcc-oil-actions{display:flex;align-items:flex-end;gap:.4rem}.mcc-sub-tabs{overflow:auto;gap:.35rem}.mcc-sub-tabs .mcc-tab{white-space:nowrap}

.mcc-checkbox-row{display:flex !important;align-items:center;gap:.55rem;font-weight:bold;color:var(--mcc-red-dark);margin:0}.mcc-checkbox-row input{width:auto !important;flex:0 0 auto;margin:0}.mcc-checkbox-row span{display:inline-block}

/* v3.2.8 – Sonderwünsche vollständig anzeigen, kein Innen-Scroll */
.mcc-special-requests-view,
.mcc-special-requests-list,
.mcc-special-list,
.mcc-special-items,
.mcc-special-preview,
.mcc-special-display,
.mcc-field-special-requests .mcc-field-content,
.mcc-field-special-requests .mcc-submission-content,
.mcc-field-special-requests .mcc-card-content,
.mcc-field-card[data-field="special_requests"] .mcc-field-content,
.mcc-field-card[data-field="special_requests"] .mcc-submission-content,
.mcc-field-card[data-field="special_requests"] .mcc-card-content {
    max-height: none !important;
    height: auto !important;
    overflow: visible !important;
    overflow-y: visible !important;
}

.mcc-field-card[data-field="special_requests"],
.mcc-field-special-requests {
    height: auto !important;
    min-height: auto !important;
}


/* v3.2.9 – formatierte Sonderwunsch-Ausgabe */
.mcc-special-requests-list {
    margin: 0.5rem 0 0 1.25rem;
    padding-left: 1rem;
}
.mcc-special-request-item {
    margin-bottom: 0.85rem;
    padding-bottom: 0.5rem;
}
.mcc-special-request-title {
    font-weight: 600;
    margin-bottom: 0.25rem;
}
.mcc-special-request-status {
    font-weight: 700;
    margin-bottom: 0.25rem;
}
.mcc-special-request-status.mcc-status-approved {
    color: #148033;
}
.mcc-special-request-status.mcc-status-rejected {
    color: #b00000;
}
.mcc-special-request-status.mcc-status-pending {
    color: #8a6d00;
}
.mcc-special-request-note {
    display: inline-block;
    background: #dff0ff;
    color: #b00000;
    padding: 0.35rem 0.55rem;
    border-radius: 4px;
    margin: 0.2rem 0;
}
.mcc-special-request-file {
    margin-top: 0.25rem;
}

/* Teilnehmer-Popup / verbindliche Hinweise */
.mcc-popup-overlay{
  position:fixed;
  inset:0;
  z-index:99999;
  background:rgba(0,0,0,.55);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:1rem;
}
.mcc-popup-box{
  width:min(760px,100%);
  max-height:90vh;
  overflow:auto;
  background:#fff;
  border-radius:18px;
  box-shadow:0 24px 80px rgba(0,0,0,.28);
  padding:1.6rem;
}
.mcc-popup-box h2{margin:0 0 .35rem;font-size:1.35rem;line-height:1.25;color:var(--mcc-dark,#111827)}
.mcc-popup-version{display:inline-block;margin:.2rem 0 1rem;padding:.25rem .6rem;border-radius:999px;background:#f3f4f6;color:#374151;font-size:.85rem;font-weight:700}
.mcc-popup-content{font-size:.95rem;line-height:1.55;color:#374151;margin:.4rem 0 1.2rem}
.mcc-popup-content p{margin:.65rem 0}
.mcc-popup-content a{font-weight:700;color:var(--mcc-red,#b42318)}
.mcc-popup-check{display:flex;gap:.65rem;align-items:flex-start;background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:.9rem;margin:1rem 0;font-weight:700;color:#111827}
.mcc-popup-check input{margin-top:.18rem;transform:scale(1.15)}
.mcc-popup-box #mcc-popup-confirm-btn{width:100%;margin-top:.3rem}
.mcc-popup-box #mcc-popup-confirm-btn:disabled{opacity:.5;cursor:not-allowed}
@media (max-width:600px){.mcc-popup-box{padding:1.1rem;border-radius:14px}.mcc-popup-box h2{font-size:1.15rem}}

/* Timetable */
.mcc-timetable-legend{display:flex;flex-wrap:wrap;gap:.6rem 1rem;margin:.4rem 0 1rem;font-size:.82rem;color:#444}
.mcc-timetable-legend span{display:inline-flex;align-items:center;gap:.3rem}
.mcc-tt-dot{display:inline-block;width:12px;height:12px;border-radius:50%;border:1px solid #bbb}
.mcc-tt-free{background:#fff}.mcc-tt-reserved{background:#fff3cd}.mcc-tt-confirmed{background:#d5f5e3}.mcc-tt-booked{background:#f8d7da}.mcc-tt-ssb{background:#dbeafe}.mcc-tt-locked{background:#e5e7eb}
.mcc-tt-day{margin:1rem 0 1.3rem}.mcc-tt-day h5{margin:.2rem 0 .6rem;color:var(--mcc-red-dark);font-size:1rem}.mcc-tt-day h5 span{font-weight:400;color:#666;margin-left:.4rem}
.mcc-tt-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(135px,1fr));gap:.65rem}
.mcc-tt-card{border:1px solid #d0d5dd;border-radius:10px;padding:.75rem;background:#fff;min-height:92px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.mcc-tt-card.available{border-color:#98a2b3}.mcc-tt-card.reserved{background:#fff3cd;border-color:#f1c40f}.mcc-tt-card.confirmed{background:#d5f5e3;border-color:#27ae60}.mcc-tt-card.booked{background:#f8d7da;border-color:#d92d20;color:#842029}.mcc-tt-card.ssb{background:#dbeafe;border-color:#2563eb;color:#1e3a8a}.mcc-tt-card.locked{background:#e5e7eb;color:#667085}.mcc-tt-card.mine{box-shadow:0 0 0 2px rgba(39,174,96,.15)}
.mcc-tt-time{font-weight:800;font-size:1.05rem}.mcc-tt-allowed{font-size:.72rem;color:#667085;margin:.15rem 0 0}.mcc-tt-status{font-size:.82rem;margin:.35rem 0;color:inherit;font-weight:700}.mcc-tt-card .mcc-btn{align-self:flex-start;margin-top:.3rem}
.mcc-tt-ceremony{background:#f8f9fa;border:1px solid #d0d5dd;border-radius:10px;padding:1rem;margin:1.2rem 0;color:#344054}
.mcc-tt-wait{font-size:.78rem;color:#667085;font-weight:700;margin-top:.3rem;display:inline-block}

/* Q&A */
.mcc-qna-form{background:#fff;border:1px solid #e7e2dc;border-radius:14px;padding:1rem;margin:1rem 0;display:grid;gap:.75rem}
.mcc-qna-form select,.mcc-qna-form textarea{width:100%;border:1px solid #d9d2c9;border-radius:10px;padding:.65rem;font:inherit}
.mcc-qna-list{display:grid;gap:.75rem;margin-top:1rem}
.mcc-qna-category-block{display:grid;gap:.75rem;margin:0 0 1.1rem}
.mcc-qna-category-title{margin:.35rem 0 0;color:var(--mcc-red-dark);font-size:1rem}
.mcc-qna-item{background:#fff;border:1px solid #e7e2dc;border-radius:14px;padding:1rem;box-shadow:0 4px 14px rgba(0,0,0,.04)}
.mcc-qna-item.important{border-color:#c9a84d}
.mcc-qna-head{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;margin-bottom:.5rem}
.mcc-qna-cat{background:#f3efe9;border-radius:999px;padding:.2rem .55rem;font-size:.82rem;font-weight:700;color:#6c3a2c}
.mcc-qna-important{background:#fff3cd;border-radius:999px;padding:.2rem .55rem;font-size:.82rem;font-weight:700;color:#7a5a00}
.mcc-qna-date{margin-left:auto;color:#777;font-size:.82rem}
.mcc-qna-question{font-weight:700;margin:.35rem 0 .55rem;line-height:1.45}
.mcc-qna-toggle{border:0;background:transparent;color:var(--mcc-red-dark);font-weight:700;cursor:pointer;padding:.25rem 0;margin:.25rem 0}
.mcc-qna-answer{background:#f8f6f2;border-left:4px solid var(--mcc-red-dark);border-radius:10px;padding:.75rem;margin-top:.5rem;line-height:1.45}
.mcc-qna-pending{display:inline-block;background:#f3f3f3;color:#666;border-radius:999px;padding:.25rem .6rem;font-size:.86rem;font-weight:700}


/* Timetable status boxes */
.mcc-info-success{border-left:4px solid #238636;background:#f2fbf4}
.mcc-info-warning{border-left:4px solid #b42318;background:#fff6f4}
.mcc-info-neutral{border-left:4px solid #2f6f9f;background:#f3f8fc}
.mcc-doc-cat-software .mcc-doc-card { border-left:4px solid var(--mcc-blue); }
