/* AmSC Resources plugin styles
   Updated to align with theme tokens in style.css (glass, borders, typography).
*/

/* -----------------------------
   Token bridge (theme -> plugin)
   ----------------------------- */
:root {
  /* If theme tokens exist, use them; else fallback to prior plugin values */
  --amsc-border: var(--border, rgba(255, 255, 255, .12));
  --amsc-stroke: var(--stroke2, rgba(255, 255, 255, .10));
  --amsc-surface: var(--glass, rgba(255, 255, 255, .04));
  --amsc-surface2: var(--glass2, rgba(255, 255, 255, .06));
  --amsc-text: var(--text, rgba(255, 255, 255, .92));
  --amsc-text2: var(--text-2, rgba(255, 255, 255, .72));
  --amsc-text3: var(--text-3, rgba(255, 255, 255, .55));
  --amsc-shadow: var(--shadow, 0 20px 50px rgba(0, 0, 0, .45));
  --amsc-inset: var(--inset, inset 0 0 0 1px rgba(255, 255, 255, .03));

  --amsc-radius: var(--radius, 20px);
  --amsc-radius-sm: var(--radius-sm, 12px);

  --amsc-font-sans: var(--font-sans, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial);
  --amsc-font-mono: var(--font-mono, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);

  /* Accent + gradient */
  --amsc-accent: var(--accent, #d37a66);
  --amsc-grad: var(--amsc-link-grad, linear-gradient(90deg,
        rgba(211, 122, 102, 1) 0%,
        rgba(255, 120, 80, 1) 40%,
        rgba(8, 214, 229, .95) 100%));

  /* Small UI sizing (match your “pill / chip” vibe) */
  --amsc-ui: 13px;
  --amsc-ui-lh: 16px;
}


/* -----------------------------
   Section header + toolbar
   ----------------------------- */
.amsc-resources__header {
  margin-bottom: 18px;
  font-family: var(--amsc-font-sans);
  color: var(--amsc-text);
}

.amsc-resources__toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}

.amsc-chipBtn {
  font-family: var(--amsc-font-mono);
  font-size: 11px;
  line-height: 1;
  letter-spacing: .10em;
  text-transform: uppercase;

  border: 1px solid var(--amsc-border);
  background: rgba(255, 255, 255, .04);
  color: var(--amsc-text2);
  border-radius: 999px;
  padding: 9px 12px;
  cursor: pointer;

  transition: background .2s ease, border-color .2s ease, color .2s ease, transform .15s ease, box-shadow .2s ease;
}

.amsc-chipBtn:hover {
  background: rgba(255, 255, 255, .06);
  transform: translateY(-1px);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, .06) inset;
}

.amsc-chipBtn[aria-pressed="true"] {
  background: rgba(255, 255, 255, .08);
  color: var(--amsc-text);
  border-color: rgba(255, 255, 255, .18);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, .07) inset;
}

/* -----------------------------
   Layout grid
   ----------------------------- */
.amsc-resources__grid {
  display: grid;
  grid-template-columns: 1.6fr .9fr;
  gap: 18px;
  align-items: start;
  margin-top: 18px;
}

@media (max-width: 980px) {
  .amsc-resources__grid {
    grid-template-columns: 1fr;
  }
}

/* -----------------------------
   Panels (Events + News)
   ----------------------------- */
.amsc-rail,
.amsc-ann {
  border: 1px solid var(--amsc-stroke);
  background: linear-gradient(180deg, rgba(255, 255, 255, .05) 0%, rgba(255, 255, 255, .03) 100%);
  border-radius: var(--amsc-radius);
  box-shadow: var(--amsc-shadow), var(--amsc-inset);
  overflow: hidden;
  font-family: var(--amsc-font-sans);
  color: var(--amsc-text);
}

.amsc-rail__top,
.amsc-ann__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  border-bottom: 1px solid rgba(255, 255, 255, .08);
  background: rgba(0, 0, 0, .12);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

/* Title text consistency */
.amsc-rail__title,
.amsc-ann__top {
  font-weight: 650;
  letter-spacing: -.01em;
}

/* Keep dot + text nicely aligned */
.amsc-rail__title {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.amsc-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: rgba(8, 214, 229, .9);
  box-shadow: 0 0 0 6px rgba(8, 214, 229, .14);
  margin-right: 0;
}

/* Controls */
.amsc-rail__controls {
  display: flex;
  gap: 10px;
}

.amsc-iconBtn {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, .14);
  background: rgba(255, 255, 255, .04);
  color: var(--amsc-text);
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: transform .15s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.amsc-iconBtn:hover {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, .06);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, .06) inset;
}

/* -----------------------------
   Events rail
   ----------------------------- */
.amsc-rail__track {
  display: flex;
  gap: 14px;
  padding: 16px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-padding-left: 16px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.amsc-rail__track::-webkit-scrollbar {
  height: 0;
}

.amsc-eventCard {
  flex: 0 0 calc(45% - 7px);
  min-width: 320px;
  scroll-snap-align: start;

  border: 1px solid rgba(255, 255, 255, .10);
  background: linear-gradient(180deg, rgba(255, 255, 255, .06), rgba(255, 255, 255, .025));
  border-radius: 18px;
  box-shadow: var(--amsc-inset);
  overflow: hidden;

  display: flex;
  flex-direction: column;
  min-height: 230px;
}

@media (max-width: 980px) {
  .amsc-eventCard {
    flex-basis: 80%;
  }
}

.amsc-eventMeta {
  padding: 14px 14px 10px;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.amsc-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 11px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, .14);
  background: rgba(0, 0, 0, .18);
  color: var(--amsc-text2);
  font-family: var(--amsc-font-mono);
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  white-space: nowrap;
}

.amsc-tag--upcoming {
  border-color: rgba(8, 214, 229, .35);
}

.amsc-tag--past {
  border-color: rgba(255, 255, 255, .18);
}

.amsc-tag--featured {
  border-color: rgba(255, 120, 80, .40);
  box-shadow: 0 0 0 1px rgba(255, 120, 80, .08) inset;
}

.amsc-date {
  font-family: var(--amsc-font-mono);
  font-size: 12px;
  color: var(--amsc-text3);
  margin-top: 4px;
  white-space: nowrap;
}

.amsc-eventBody {
  padding: 0 14px 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}

.amsc-eventTitle {
  margin: 0;
  font-size: 16px;
  line-height: 1.35;
  font-weight: 700;
  letter-spacing: -.01em;
  color: var(--amsc-text);
}

.amsc-eventDesc {
  margin: 0;
  color: var(--amsc-text2);
  line-height: 1.6;
  font-size: 14px;
  flex: 1;
}

/* Resources chips */
.amsc-resourcesRow {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 6px;
}

.amsc-resLink {
  border: 1px solid rgba(255, 255, 255, .14);
  background: rgba(255, 255, 255, .04);
  color: var(--amsc-text);
  padding: 8px 10px;
  border-radius: 999px;
  font-size: 13px;
  text-decoration: none;
  transition: background .2s ease, transform .15s ease, border-color .2s ease, box-shadow .2s ease;
}

.amsc-resLink:hover {
  background: rgba(255, 255, 255, .06);
  transform: translateY(-1px);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, .06) inset;
}

.amsc-resLink[data-type="slides"] {
  border-color: rgba(255, 255, 255, .18);
}

.amsc-resLink[data-type="video"] {
  border-color: rgba(8, 214, 229, .30);
}

.amsc-resLink[data-type="q&a"] {
  border-color: rgba(255, 120, 80, .28);
}

/* -----------------------------
   News list
   ----------------------------- */
.amsc-ann__list {
  margin: 0;
  padding: 10px 0;
  list-style: none;
}

.amsc-annItem {
  padding: 12px 16px;
  border-top: 1px solid rgba(255, 255, 255, .06);
}

.amsc-annItem:first-child {
  border-top: none;
}

.amsc-annLink {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  text-decoration: none;
  color: var(--amsc-text);
}

.amsc-annLink:hover {
  opacity: 0.95;
}

.amsc-annText {
  min-width: 0;
}

p.amsc-annTitle {
  padding-bottom: 0 !important;
}

.amsc-annTitle {
  margin: 0;
  font-size: 16px;
  font-weight: 650;
  line-height: 1.35;
  letter-spacing: -.01em;
  text-decoration: underline;
}

.amsc-annDesc {
  margin: 6px 0 0;
  font-size: 13px;
  color: var(--amsc-text2);
  line-height: 1.55;
}

.amsc-annDate {
  font-family: var(--amsc-font-mono);
  font-size: 12px;
  color: var(--amsc-text3);
  white-space: nowrap;
  margin-top: 2px;
}

/* Fix News header alignment (dot + title left aligned) */
.amsc-ann__top {
  justify-content: flex-start;
}

/* -----------------------------
   Pagination controls
   ----------------------------- */
.amsc-ann__pager {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 12px 14px 14px;
  border-top: 1px solid rgba(255, 255, 255, .06);
  background: rgba(0, 0, 0, .10);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.amsc-ann__pageBtn {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, .14);
  background: rgba(255, 255, 255, .04);
  color: var(--amsc-text);
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: transform .15s ease, background .2s ease, border-color .2s ease, opacity .2s ease, box-shadow .2s ease;
}

.amsc-ann__pageBtn:hover {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, .06);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, .06) inset;
}

.amsc-ann__pageBtn:disabled {
  opacity: .35;
  cursor: default;
  transform: none;
  box-shadow: none;
}

.amsc-ann__pageDots {
  display: flex;
  align-items: center;
  gap: 8px;
}

.amsc-ann__pageDot {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, .18);
  background: rgba(255, 255, 255, .05);
  cursor: pointer;
  padding: 0;
  transition: transform .15s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.amsc-ann__pageDot:hover {
  transform: scale(1.06);
  background: rgba(255, 255, 255, .08);
}

.amsc-ann__pageDot[aria-current="true"] {
  border-color: rgba(8, 214, 229, .40);
  background: rgba(8, 214, 229, .22);
  box-shadow: 0 0 0 3px rgba(8, 214, 229, .12);
}

/* -----------------------------
   Gradient link utility (optional)
   Keep for quick inline use
   ----------------------------- */
.amsc-gradText {
  background: var(--amsc-grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* Glass underline style */
.amsc-gradLink {
  text-decoration: none;
  border-bottom: 1px solid rgba(255, 255, 255, .22);
}

.amsc-gradLink:hover {
  border-bottom-color: rgba(255, 255, 255, .38);
}

/* Empty states */
.amsc-rail__empty,
.amsc-ann__empty {
  padding: 14px 16px;
  color: var(--amsc-text2);
}

/* Make the atmo band truly full-bleed, even inside contained rows */
.wpb_row.amsc-atmo-band {
  position: relative;
  overflow: visible;
  /* allow the full-bleed bg to extend */
}

.wpb_row.amsc-atmo-band>.row-bg-wrap {
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: 100vw !important;
  max-width: 100vw !important;

  position: absolute !important;
  top: 0;
  bottom: 0;
  right: auto !important;
  /* prevent conflicting rules */
}

/* If Salient sets inner-wrap widths, force them full-bleed too */
.wpb_row.amsc-atmo-band>.row-bg-wrap>.inner-wrap {
  width: 100% !important;
  max-width: 100% !important;
}

/* -----------------------------
   Mobile tweaks (News & Announcements)
   - Hide descriptions
   - Place date above title
   ----------------------------- */
@media (max-width: 1024px) {

  /* 1) Hide the announcement description on mobile */
  .amsc-annDesc {
    display: none !important;
  }

  /* 2) Move the date above the title on mobile */
  .amsc-annLink {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }

  .amsc-annDate {
    order: 0;
    margin: 0;
  }

  .amsc-annText {
    order: 1;
  }

  /* Optional: reduce underline awkwardness when stacked */
  .amsc-annTitle {
    text-underline-offset: 2px;
  }
}