@import url('https://fonts.googleapis.com/css2?family=Anton&family=Special+Gothic:wght@400;500;600;700&family=DM+Mono:wght@500&family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,700;0,9..40,800;1,9..40,400;1,9..40,500;1,9..40,700&display=swap');

/* Tell every browser Anton only has one weight/style — prevents faux bold */
@font-face {
  font-family: 'Anton';
  font-style: normal;
  font-weight: 100 900;
  src: local('Anton');
}

/* Prevent faux bold on Anton — it has no bold variant */
* { font-synthesis: none; }

/* "Royal Guild" / "Royal Guild Space" branding — Anton, weight 400 */
.logo, .hero h1 {
  font-family: 'Anton','DM Sans',sans-serif;
  font-weight: 400;
  font-style: normal;
  font-synthesis: none;
  -webkit-font-smoothing: antialiased;
}

/* All other page/section titles — Special Gothic 700 */
.title-special,
.admin-page-title, .nav-modal-title, .log-title,
.nt-title, .nt-admin-title, .rr-title, .rr-page-title,
.subs-page-title, .signup-title {
  font-family: 'Special Gothic','DM Sans',sans-serif;
  font-weight: 700;
  font-synthesis: none;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}

/* ── Full-page cream — no gray anywhere ── */
html,body{
  background:#FFFCF5;
  min-height:100%;
}
body{
  font-family:'DM Sans',sans-serif;
  color:#1a1a1a;
}

/* Default all text to black unless overridden */

.page{
  max-width:720px;
  margin:0 auto;
  padding:1.5rem 2rem 3rem;
  min-height:100vh;
  background:#FFFCF5;
}
.page-wide{
  max-width:1100px;
}

/* ── Admin bar ── */
.admin-bar{
  background:#AB5050;color:#fff;
  text-align:center;padding:4px 0;
  font-family:'DM Mono',monospace;font-size:.7rem;letter-spacing:.05em;
  margin:-1.5rem -2rem 1.25rem;
}
.admin-bar a{color:#ffd5d5;text-decoration:underline;}

/* ── Header ── */
.site-header{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:1rem;
}

.logo{
  color:#AB5050;
  font-size:1.1rem;text-decoration:none;
}

.admin-link{
  font-family:'DM Mono',monospace;font-size:.72rem;
  color:#1a1a1a;text-decoration:none;
}
.admin-link:hover{color:#AB5050;}

/* ── Language switcher ── */
.lang-switcher{
  display:flex;align-items:center;gap:2px;
  font-family:'DM Mono',monospace;font-size:.72rem;
}
.lang-switcher a{
  text-decoration:none;color:#555;padding:2px 7px;border-radius:20px;
}
.lang-switcher a.active{background:#DED4FF;color:#1a1a1a;}
.lang-switcher .sep{color:#bbb;}

/* ── Homepage hero ── */
.hero{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;padding:3rem 1rem 2rem;
}
.hero h1{
  color:#AB5050;
  font-size:2.75rem;line-height:1.1;margin-bottom:.6rem;
}
.hero .subtitle{font-style:italic;color:#1a1a1a;font-size:.95rem;margin-bottom:2.5rem;}
.hero-spacer{flex:1;min-height:4rem;}
.hero .cta{font-style:italic;color:#1a1a1a;font-size:.9rem;}
.hero .cta a{color:#1a1a1a;}

/* ── Resource listing ── */
.section-heading{
  font-weight:700;font-size:1rem;
  text-align:center;margin:1.5rem 0 1.25rem;
}

.resource-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1.25rem;justify-items:center;
}

.resource-card-wrap{width:100%;max-width:310px;}

.resource-card{
  background:#fff;border:2px solid #1a1a1a;
  border-radius:14px;overflow:hidden;
  width:100%;display:block;text-decoration:none;color:inherit;
  transition:transform .15s,box-shadow .15s;
}
.resource-card:hover{transform:translateY(-2px);box-shadow:0 4px 14px rgba(0,0,0,.1);}

.resource-card-img{
  width:100%;height:230px;object-fit:cover;
  display:block;background:#d5d5d5;
}
.resource-card-img.placeholder{background:#d5d5d5;}

.resource-card-label{padding:.6rem .85rem .7rem;font-weight:700;font-size:.95rem;}
.resource-card-actions{padding:.4rem .85rem .75rem;display:flex;gap:.5rem;}

/* ── Individual resource ── */
.resource-nav{
  display:flex;justify-content:space-between;
  align-items:center;margin-bottom:1.25rem;
}
.back-link{
  font-family:'DM Mono',monospace;font-size:.75rem;
  color:#555;text-decoration:none;
}
.back-link:hover{color:#AB5050;}
.resource-page-title{font-weight:700;font-size:1.4rem;}

.resource-content-box{
  background:#fff;border:1.5px solid #d5d5d5;
  border-radius:14px;overflow:hidden;
}
.resource-layout{display:flex;}

/* Desktop sidebar */
.tab-sidebar{
  min-width:190px;max-width:190px;
  border-right:1px solid #ebebeb;
  padding:1.25rem 0;flex-shrink:0;
}
.tab-btn{
  display:block;width:100%;text-align:left;
  padding:.65rem 1.1rem;
  font-family:'DM Mono',monospace;font-size:.78rem;
  background:none;border:none;border-bottom:1px solid #ebebeb;
  cursor:pointer;color:#444;text-decoration:none;
  transition:background .1s;
}
.tab-btn:last-child{border-bottom:none;}
.tab-btn.active{font-weight:600;color:#1a1a1a;}
.tab-btn:hover:not(.active){background:#f9f9f9;}

/* Mobile tabs */
.tab-buttons-mobile{
  display:none;flex-wrap:wrap;gap:.4rem;
  padding:.85rem;border-bottom:1px solid #ebebeb;
}
.tab-buttons-mobile .tab-btn{
  display:inline-block;width:auto;
  border:1.5px solid #d5d5d5;border-radius:8px;
  padding:.35rem .65rem;font-size:.72rem;
}

.tab-content{flex:1;padding:1.5rem;min-width:0;}
.tab-panel{display:none;}
.tab-panel.active{display:block;}

.section-img{
  width:100%;max-width:300px;
  margin:0 auto 1.25rem;display:block;border-radius:8px;
}
.section-img-placeholder{
  width:100%;max-width:300px;height:200px;
  background:#ebebeb;border-radius:8px;
  margin:0 auto 1.25rem;
  display:flex;align-items:center;justify-content:center;
  color:#aaa;font-family:'DM Mono',monospace;font-size:.75rem;
}

.tab-text p{font-size:.875rem;line-height:1.65;margin-bottom:.9rem;color:#333;}
.tab-text p:last-child{margin-bottom:0;}
.tab-text strong{font-weight:700;}
.tab-text em{font-style:italic;}

.section-images{display:flex;flex-wrap:wrap;gap:.75rem;margin:1rem 0;}
.section-images img{border-radius:6px;max-height:180px;width:auto;}

.admin-controls{margin-top:1rem;display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;}

/* ── Buttons ── */
.btn{
  font-family:'DM Mono',monospace;font-size:.8rem;
  padding:.55rem 1.25rem;border:1.5px solid #1a1a1a;
  border-radius:8px;background:#fff;color:#1a1a1a;
  cursor:pointer;text-decoration:none;display:inline-block;text-align:center;
  transition:background .15s;
}
.btn:hover{background:#f0f0f0;}

.btn-save{
  background:#C9E55A;border-color:#A8C43A;
  color:#1a1a1a;font-weight:600;
}
.btn-save:hover{background:#BAD84E;}

.btn-edit{
  font-family:'DM Mono',monospace;font-size:.72rem;
  background:#fff;border:1.5px solid #AB5050;color:#AB5050;
  padding:3px 12px;border-radius:20px;cursor:pointer;
  text-decoration:none;display:inline-block;
  transition:background .15s,color .15s;
}
.btn-edit:hover{background:#AB5050;color:#fff;}

/* Delete button — softer hover */
.btn-edit[style*="#888"]:hover,
.btn-delete:hover {
  background:#DBDCDE !important;
  color:#AB5050 !important;
  border-color:#AB5050 !important;
}

.btn-add-section{
  font-family:'DM Mono',monospace;font-size:.72rem;
  background:none;border:1.5px dashed #AB5050;color:#AB5050;
  padding:3px 12px;border-radius:20px;cursor:pointer;
}
.btn-add-section:hover{background:#fff0f0;}

/* ── Inline editor ── */
.section-edit-form{
  display:none;margin-top:1rem;
  border:1.5px dashed #d5d5d5;border-radius:10px;
  padding:1rem;background:#fafafa;
}
.section-edit-form.open{display:block;}

.editor-wrap{border:1.5px solid #d5d5d5;border-radius:8px;overflow:hidden;margin-bottom:.65rem;}
.editor-toolbar{
  display:flex;align-items:center;gap:.35rem;
  padding:.35rem .65rem;background:#fafafa;border-bottom:1px solid #ebebeb;
}
.toolbar-btn{
  font-family:'DM Sans',sans-serif;font-weight:700;font-size:.85rem;
  padding:2px 7px;border:none;background:none;cursor:pointer;border-radius:4px;color:#333;
}
.toolbar-btn:hover{background:#e5e5e5;}
.t-italic{font-style:italic;font-weight:400;}
.t-underline{text-decoration:underline;}
.upload-pill{
  font-family:'DM Mono',monospace;font-size:.7rem;
  padding:3px 10px;border:1.5px solid #d5d5d5;border-radius:20px;
  background:#fff;cursor:pointer;color:#555;margin-left:auto;
}
.upload-pill:hover{background:#f0f0f0;}
.editor-area{
  min-height:180px;padding:.75rem;
  font-family:'DM Sans',sans-serif;font-size:.875rem;line-height:1.6;
  outline:none;color:#333;
}
.form-actions{display:flex;justify-content:flex-end;align-items:center;gap:.5rem;margin-top:.5rem;}

/* ── Modal ── */
.modal-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.45);z-index:200;
  align-items:center;justify-content:center;padding:1rem;
}
.modal-overlay.open{display:flex;}

/* ── Admin pages ── */
.admin-page-title{
  color:#AB5050;
  font-size:2rem;text-transform:uppercase;
  text-align:center;margin:2rem 0 1.75rem;
}
.admin-login-form{
  display:flex;flex-direction:column;gap:.65rem;
  max-width:380px;margin:0 auto;
}
.admin-login-form input{
  font-family:'DM Mono',monospace;font-size:.8rem;
  padding:.6rem 1rem;border:1.5px solid #d5d5d5;
  border-radius:8px;background:#fff;color:#333;width:100%;
}
.admin-login-form input::placeholder{color:#bbb;text-transform:uppercase;letter-spacing:.05em;}
.admin-login-form input:focus{outline:none;border-color:#AB5050;}

.admin-dashboard-btns{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem 0;}
.admin-dashboard-btns .btn{width:220px;}

/* ── Add resource ── */
.add-resource-wrap h2{font-weight:700;font-size:1.15rem;margin-bottom:1rem;}
.form-card{
  background:#fff;border:1.5px solid #d5d5d5;
  border-radius:12px;padding:1.25rem;
  position:relative;max-width:480px;margin:0 auto;
  width:calc(100% - 2rem); overflow:hidden;
  box-sizing:border-box;
}
.form-field{margin-bottom:.65rem;}
.form-input{
  width:100%;font-family:'DM Mono',monospace;font-size:.8rem;
  padding:.55rem .85rem;border:1.5px solid #d5d5d5;
  border-radius:8px;background:#fff;color:#333;
  box-sizing:border-box; max-width:100%;
}
input[type="date"].form-input {
  -webkit-appearance: none; appearance: none;
  min-width: 0; width: 100%; max-width: 100%;
}
.form-input:focus{outline:none;border-color:#AB5050;}
.close-btn{
  position:absolute;top:.75rem;right:.75rem;
  background:none;border:none;font-size:1.1rem;cursor:pointer;color:#888;
  width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:50%;
}
.close-btn:hover{background:#f0f0f0;color:#333;}

/* ── Alerts ── */
.alert{padding:.65rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.83rem;}
.alert-error{background:#fee2e2;color:#991b1b;}
.alert-success{background:#d1fae5;color:#065f46;}

/* ── Responsive ── */
@media(max-width:620px){
  .page{padding:1rem .85rem 2rem;}
  .admin-bar{margin:-1rem -.85rem 1rem;}
  .hero h1{font-size:2rem;}
  .hero{padding:2rem .5rem 1rem;}
  .resource-grid{grid-template-columns:1fr;}
  .resource-card-wrap{max-width:100%;}
  .resource-card-img{height:220px;}
  .resource-nav{flex-direction:column;gap:.35rem;align-items:flex-start;}
  .tab-sidebar{display:none;}
  .tab-buttons-mobile{display:flex;}
  .resource-layout{flex-direction:column;}
  .tab-content{padding:1rem;}
  .admin-page-title{font-size:1.6rem;}
  .site-header{flex-direction:column;gap:.4rem;align-items:flex-start;}
}

/* ── Section header image with delete button ── */
.section-img-wrap {
  position: relative;
  width: 100%;
  max-width: 300px;
  margin: 0 auto 1.25rem;
}
.section-img-wrap .section-img {
  max-width: 100%;
  margin: 0;
  display: block;
}
.img-delete-btn {
  position: absolute;
  top: .4rem; right: .4rem;
  background: rgba(0,0,0,.55);
  color: #fff;
  border: none;
  border-radius: 50%;
  width: 24px; height: 24px;
  font-size: .75rem;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s;
}
.img-delete-btn:hover { background: #AB5050; }

/* ════════════════════════════════════
   NAV BUTTON + MODAL
════════════════════════════════════ */
.header-row { display:flex; justify-content:space-between; align-items:flex-start; width:100%; }
.header-right-col { display:flex; flex-direction:column; align-items:flex-end; gap:.4rem; }
.nav-toggle-btn { margin-top:5px;
  font-family:'DM Mono',monospace; font-size:.72rem;
  background:#FFEAFA; border:1.5px solid #dbbfdb; border-radius:20px;
  padding:4px 16px; cursor:pointer; color:#333; transition:background .15s;
}
.nav-toggle-btn:hover { background:#f5d8f5; }
.nav-modal {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.45); z-index:300;
  align-items:center; justify-content:center; padding:1rem;
}
.nav-modal.open { display:flex; }
.nav-modal-inner {
  background:#fff; border-radius:14px; padding:1.5rem;
  max-width:360px; width:100%; position:relative;
  max-height:90vh; overflow-y:auto;
}
.nav-close-btn {
  position:absolute; top:.75rem; right:.75rem;
  background:none; border:none; font-family:'DM Mono',monospace;
  font-size:.72rem; cursor:pointer; color:#888;
}
.nav-close-btn:hover { color:#333; }
.nav-modal-title { font-family:'Special Gothic','DM Sans',sans-serif; font-weight:700; font-size:1.5rem; color:#1a1a1a; text-align:center; margin-bottom:1rem; font-synthesis:none; }
.nav-link-btn {
  display:block; width:100%; text-align:center;
  padding:.6rem 1rem; margin-bottom:.5rem;
  background:#FFEAFA; border:1.5px solid #dbbfdb; border-radius:20px;
  font-family:'DM Mono',monospace; font-size:.75rem;
  color:#333; text-decoration:none; transition:background .15s; line-height:1.4;
}
.nav-link-btn:hover { background:#f5d8f5; }
.nav-link-btn:active, .nav-link-btn:focus { font-weight:400; outline:none; }
.nav-note { display:block; font-size:.65rem; color:#999; font-style:italic; }

/* ════════════════════════════════════
   TITLE RANKINGS
════════════════════════════════════ */
.rankings-page { padding-top:.5rem; }
.rankings-header { display:flex; justify-content:space-between; align-items:flex-start; flex-wrap:wrap; gap:.75rem; margin-bottom:1.25rem; }
.rankings-title { font-family:'DM Sans',sans-serif; font-weight:700; font-size:1.75rem; color:#2940A6; }
.rankings-controls { display:flex; align-items:center; gap:.65rem; flex-wrap:wrap; }
.view-toggle { display:flex; border:1.5px solid #d5d5d5; border-radius:8px; overflow:hidden; }
.toggle-btn { font-family:'DM Mono',monospace; font-size:.72rem; padding:.4rem .85rem; background:#fff; color:#555; text-decoration:none; border:none; transition:background .15s; }
.toggle-btn.active { background:#FAE9DB; color:#1a1a1a; font-weight:600; }
.toggle-btn:hover:not(.active) { background:#f5f5f5; }
.btn-new-ranking { font-family:'DM Mono',monospace; font-size:.75rem; background:#fff; border:1.5px solid #2940A6; color:#2940A6; padding:.4rem 1rem; border-radius:8px; cursor:pointer; transition:background .15s; }
.btn-new-ranking:hover { background:#2940A6; color:#fff; }

.filter-row { display:flex; flex-wrap:wrap; align-items:center; gap:.4rem; margin-bottom:1.25rem; }
.filter-label { font-family:'DM Mono',monospace; font-size:.72rem; color:#4D4D4D; display:flex; align-items:center; gap:.25rem; margin-right:.25rem; }
.filter-chip { font-family:'DM Mono',monospace; font-size:.72rem; padding:3px 12px; border:1.5px solid transparent; border-radius:20px; cursor:pointer; color:#4D4D4D; -webkit-appearance:none; appearance:none; transition:border-color .15s,opacity .15s; opacity:.75; }
.filter-chip.active { border-color:#555; opacity:1; color:#1a1a1a; }
.filter-chip:hover { opacity:1; }

.rankings-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; }
.ranking-card { background:#fff; border:1.5px solid #d5d5d5; border-radius:12px; padding:1rem; display:flex; flex-direction:column; gap:.5rem; }
.ranking-card-title { font-family:'DM Sans',sans-serif; font-weight:700; font-size:.95rem; line-height:1.3; }
.ranking-card-meta { font-family:'DM Mono',monospace; font-size:.7rem; color:#444; display:flex; gap:.35rem; flex-wrap:wrap; }
.meta-label { color:#595959; }
.meta-value { color:#1a1a1a; }
.end-date { color:#595959; font-size:.65rem; }
.ranking-card-footer { display:flex; align-items:center; margin-top:.25rem; }
.assigned-row { margin-top:.4rem; }
.ranking-admin-btns-row { margin-top:auto; padding-top:.5rem; }
.status-badge { font-family:'DM Mono',monospace; font-size:.65rem; padding:2px 10px; border-radius:20px; font-weight:600; }
.status-taken { background:#FFEDE1; color:#8B4513; }
.status-available { background:#EDFFC6; color:#2d6a00; }
.ranking-admin-btns { display:flex; gap:.35rem; }

.cal-nav { display:flex; align-items:center; justify-content:center; gap:1.5rem; margin-bottom:1rem; }
.cal-nav-btn { font-size:1.1rem; color:#2940A6; text-decoration:none; padding:2px 8px; border-radius:4px; }
.cal-nav-btn:hover { background:#f0f0f0; }
.cal-month-label { font-family:'DM Sans',sans-serif; font-weight:700; font-size:1.4rem; color:#2940A6; min-width:200px; text-align:center; }
.cal-scroll-wrap { overflow-x:auto; -webkit-overflow-scrolling:touch; width:100%; padding-bottom:.5rem; }
.cal-scroll-wrap::-webkit-scrollbar { height:4px; }
.cal-scroll-wrap::-webkit-scrollbar-thumb { background:#d5d5d5; border-radius:4px; }
.cal-grid { display:grid; grid-template-columns:repeat(7,minmax(110px,1fr)); border:1px solid #1a1a1a; border-radius:10px; overflow:hidden; min-width:630px; width:100%; }
.cal-day-header { font-family:'DM Mono',monospace; font-size:.7rem; text-align:center; padding:.4rem 0; background:#f7f7f7; color:#1a1a1a; border-bottom:1px solid #1a1a1a; font-weight:700; }
.cal-cell { min-height:110px; height:auto; padding:.5rem; border-right:1px solid #1a1a1a; border-bottom:1px solid #1a1a1a; background:#fff; vertical-align:top; }
.cal-cell:nth-child(7n) { border-right:none; }
.cal-empty { background:#fafafa; }
.cal-today { background:#FFFCF5; }
.cal-day-num { font-family:'DM Mono',monospace; font-size:.78rem; color:#1a1a1a; font-weight:700; margin-bottom:.3rem; }
.cal-today .cal-day-num { color:#AB5050; font-weight:700; }
.cal-event { font-family:'DM Sans',sans-serif; font-size:.62rem; font-weight:600; padding:2px 5px; border-radius:4px; margin-bottom:2px; white-space:normal; word-break:break-word; line-height:1.3; cursor:pointer; }

.field-label { display:block; font-family:'DM Mono',monospace; font-size:.72rem; color:#777; margin-bottom:.3rem; }
.two-col { display:grid; grid-template-columns:1fr 1fr; gap:.65rem; }
.checkbox-group { display:flex; flex-wrap:wrap; gap:.5rem; }
.check-label { font-family:'DM Mono',monospace; font-size:.75rem; display:flex; align-items:center; gap:.3rem; cursor:pointer; }

/* ════════════════════════════════════
   LINKS PAGE
════════════════════════════════════ */
.links-title { font-family:'DM Sans',sans-serif; font-weight:700; font-size:1.75rem; text-align:center; margin:1.5rem 0 1.25rem; }
.links-list { display:flex; flex-direction:column; align-items:center; gap:.5rem; max-width:320px; margin:0 auto; }
.links-btn { display:block; width:100%; text-align:center; padding:.6rem 1.5rem; background:#E0FFF5; border:1.5px solid #AAEEDD; border-radius:20px; font-family:'DM Mono',monospace; font-size:.75rem; color:#333; text-decoration:none; transition:background .15s; }
.links-btn:hover { background:#c8fff0; }
.links-btn:active, .links-btn:focus { font-weight:400; outline:none; }
.links-note { font-family:'DM Mono',monospace; font-size:.65rem; color:#999; font-style:italic; text-align:center; margin-top:.2rem; }

/* ════════════════════════════════════
   CS TEAMS
════════════════════════════════════ */
.teams-title { font-family:'DM Sans',sans-serif; font-weight:700; font-size:1.75rem; color:#8224C5; text-align:center; margin:1.5rem 0 1.25rem; }
.teams-card { background:#fff; border:1.5px solid #d5d5d5; border-radius:14px; padding:1.5rem; max-width:520px; margin:0 auto; }
.teams-content { font-family:'DM Sans',sans-serif; font-size:.875rem; line-height:1.8; color:#333; }
.teams-textarea { width:100%; min-height:220px; font-family:'DM Sans',sans-serif; font-size:.875rem; line-height:1.8; border:1px solid #e5e5e5; border-radius:8px; padding:.75rem; resize:vertical; color:#333; outline:none; }
.teams-textarea:focus { border-color:#8224C5; }
.teams-actions { display:flex; align-items:center; gap:.75rem; margin-top:.75rem; justify-content:flex-end; }

.cal-swipe-hint { display:none; }

@media(max-width:620px) {
  .rankings-grid { grid-template-columns:1fr; }
  .rankings-header { flex-direction:column; }
  .cal-cell { min-height:70px; padding:.4rem; }
  .cal-event { font-size:.66rem; }
  .cal-day-header { font-size:.7rem; }
  .cal-day-num { font-size:.8rem; }
  .cal-nav { gap:1rem; }
  .cal-nav-btn { font-size:1.4rem; }
  .cal-month-label { font-size:1.25rem; min-width:0; }
  .two-col { grid-template-columns:1fr; }
  .cal-swipe-hint {
    display:block; text-align:center;
    font-family:'DM Mono',monospace; font-size:.7rem;
    color:#1a1a1a; margin:.5rem 0 .75rem;
  }
}

.cal-filter-row { display:flex; flex-wrap:wrap; align-items:center; gap:.4rem; margin-bottom:.75rem; }
.cal-filter-btn { font-family:'DM Mono',monospace; font-size:.72rem; padding:3px 12px; border:1.5px solid transparent; border-radius:20px; cursor:pointer; color:#4D4D4D; transition:border-color .15s,opacity .15s; opacity:.75; }
.cal-filter-btn.active { border-color:#555; color:#1a1a1a; opacity:1; }
.cal-filter-btn:hover { opacity:1; }

/* ════════════════════════════════════
   ADMIN NAV
════════════════════════════════════ */
.admin-nav-btn {
  font-family:'DM Mono',monospace; font-size:.72rem;
  background:#FFFED4; border:1.5px solid #d4cc70;
  border-radius:20px; padding:4px 16px;
  cursor:pointer; color:#333;
  transition:background .15s; margin-top:5px;
  -webkit-appearance:none; appearance:none;
}
.admin-nav-btn:hover { background:#f5f2b0; }

.adm-nav-link {
  display:block; width:100%; text-align:center;
  padding:.55rem 1rem; margin-bottom:.45rem;
  border-radius:20px; border:1.5px solid rgba(0,0,0,.08);
  font-family:'DM Mono',monospace; font-size:.75rem;
  color:#333; text-decoration:none;
  transition:filter .15s;
}
.adm-nav-link:hover { filter:brightness(.95); }
.adm-nav-link:active { font-weight:400; }

/* ════════════════════════════════════
   v7 FIXES
════════════════════════════════════ */

/* Force button appearance reset globally (iOS Safari fix) */
button { -webkit-appearance: none; appearance: none; }

/* Dot menu dropdown — stay on screen on mobile */
@media (max-width: 620px) {
  .dot-menu-dropdown,
  .dot-menu-dd {
    right: auto !important;
    left: 0 !important;
  }
}

/* Expanded card X button — don't overlap text */
.rr-card-expanded { padding-right: 2.5rem; }
.ntr-expanded     { padding-right: 2.5rem; padding-top: 2.25rem; }

/* Assigned member badge (admin/staff only) */
.assigned-badge {
  font-family:'DM Mono',monospace; font-size:.68rem;
  color:#666; background:#F3F4FF; border:1px solid #d8dcff;
  border-radius:20px; padding:2px 10px; font-weight:600;
}