/* Import USC font */
@font-face {
    font-family: "BerlingskeSans";
    src: url("data/BerlingskeSansBold.woff2") format("woff2");
    font-weight: normal;
    font-style: normal;
}

:root{ --bg:#f4f6f8; --card:#ffffff; --ink:#111827; --muted:#6b7280; --accent:#73000a; --border:#e5e7eb; }
*{box-sizing:border-box}
body{font-family:"BerlingskeSans",system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;background:var(--bg);color:var(--ink);margin:0}
.wrap{max-width:1100px;margin:20px auto;padding:0 16px}
.header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.header h2{margin:0}
.header button{padding:6px 10px;border:1px solid var(--border);background:#fff;border-radius:8px;cursor:pointer}

.layout{display:grid;grid-template-columns:2fr 300px;gap:14px}
@media (max-width: 900px){ .layout{grid-template-columns:1fr} }

.calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;background:var(--card);padding:10px;border:1px solid var(--border);border-radius:12px;width:fit-content;justify-self:start}
.dow{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;padding:6px 4px;text-align:center}
.day{background:#fff;border:1px solid var(--border);width:120px;height:120px;padding:6px;border-radius:10px;position:relative;cursor:pointer;overflow:hidden}
.day.faded{opacity:.45}
.day.selected{outline:2px solid var(--accent);outline-offset:-2px}
.day-number{font-weight:600}
.event{background:rgba(124,92,255,.12);border:1px solid rgba(124,92,255,.35);color:#3f3a72;padding:2px 6px;border-radius:999px;font-size:12px;margin-top:4px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

aside{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:12px}
.aside-head{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.muted{color:var(--muted)}
.list{display:flex;flex-direction:column;gap:8px}
.card{border:1px solid var(--border);border-radius:10px;padding:8px}
.card h4{margin:0 0 4px 0}
.when{font-size:12px;color:var(--muted)}
.row{display:flex;gap:8px;align-items:center}
.spacer{flex:1}
.btn{padding:6px 10px;border:1px solid var(--border);background:#fff;border-radius:8px;cursor:pointer}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.danger{background:#ef4444;border-color:#ef4444;color:#fff}


/* prevent wrapping of selected date */
#selDateText{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* btn link for navigation */
  .btn-link {
    padding: 10px;
    background: var(--accent, #73000a);
    color: #fff;
    border-radius: 8px;
    text-decoration: none;
    font-size: 16px;
    font-weight: 600;
  }
  .btn-link:hover {
    background: #73000aa3;
  }

/* Sidebar event details */
  .card .note {
    display: block;
    margin-top: 6px;
    line-height: 1.4;
  }

/* Page layout for header + 2x2 grid on index.html */
  :root { --pad: 12px; }
  html, body { height: 100%; }
  body {
    margin: 0;
    font-family: "BerlingskeSans",system-ui, sans-serif;
    background: var(--bg, #f4f6f8);
    display: flex;
    flex-direction: column;
    min-height: 100vh;
  }
  .site-header {
    background: #fff;
    border-bottom: 1px solid var(--border, #e5e7eb);
    padding: 16px;
    text-align: center;
  }
  .site-header h1 { margin: 0; }
  .grid {
    flex: 1;
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr;
    gap: var(--pad);
    padding: var(--pad);
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
  }
  .quad {
    background: #fff;
    border: 1px solid var(--border, #e5e7eb);
    border-radius: 12px;
    padding: 16px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    overflow: auto;
  }

/* Small helper for stacking links in TL box */
  .stack { display: flex; flex-direction: column; gap: 12px; }

/* Change color of homepage header */
.site-header {
    background: #73000a;
    color: #ffffff;
    padding: 20px;
    text-align: center;
}

/* Container for all attachments */
  .attachments {
    margin-top: 0.5em;
    display: flex;
    flex-direction: column; /* stack vertically */
    gap: 0.4em;
  }
  /* Each attachment link */
  .attachments .btn-link {
    display: inline-block;
    padding: 0.35em 0.6em;
    border-radius: 6px;
    background: #f5f5f5;
    color: #73000a;
    font-size: 0.9em;
    text-decoration: none;
    transition: background 0.2s ease, color 0.2s ease;
  }
  /* Hover effect */
  .attachments .btn-link:hover {
    background: #e9ecef;
    color: #73000aa3;
  }

/* Panel resources grid */
  .panel-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    margin: 2rem;
  }

  .panel-card,
  .resources-bar {
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 8px;
    padding: 1.5rem;
    box-shadow: 0 2px 6px rgba(0,0,0,0.05);
  }

  .resources-bar {
    margin: 2rem;
    margin-bottom: 0; /* sits flush with grid spacing */
    text-align: center;
  }

  .resources-bar h2 {
    margin: 0;
    font-size: 1.4rem;
    color: #333;
  }


