/* ==========================================================================
   GRP Public Portal — portal.css
   Design: Clean, professional, polished. Built for business audiences.
   Fully scoped to .grp-wrap — zero theme bleed.
   ========================================================================== */

/* --------------------------------------------------------------------------
   Design Tokens
   Overridden at runtime by GRP_Appearance::output_css_vars()
   -------------------------------------------------------------------------- */
:root {
  --grp-primary:      #1e40af;
  --grp-primary-dark: #1e3a8a;
  --grp-primary-pale: #eff6ff;
  --grp-danger:       #dc2626;
  --grp-success:      #16a34a;
  --grp-warning:      #d97706;
  --grp-text:         #1e293b;
  --grp-text-muted:   #64748b;
  --grp-border:       #e2e8f0;
  --grp-bg:           #f8fafc;
  --grp-surface:      #ffffff;
  --grp-radius:       6px;
  --grp-radius-sm:    4px;
  --grp-font:         -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', sans-serif;
  --grp-shadow:       0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --grp-shadow-md:    0 4px 12px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.04);
  --grp-shadow-hover: 0 8px 20px rgba(0,0,0,.09), 0 3px 6px rgba(0,0,0,.05);
  --grp-transition:   all .15s ease;
}

/* --------------------------------------------------------------------------
   Scoped Reset — inside .grp-wrap only
   -------------------------------------------------------------------------- */
.grp-wrap,
.grp-wrap *,
.grp-wrap *::before,
.grp-wrap *::after { box-sizing: border-box; }

.grp-wrap h1, .grp-wrap h2, .grp-wrap h3,
.grp-wrap h4, .grp-wrap h5, .grp-wrap h6 {
  font-family: var(--grp-font); font-weight: 600; line-height: 1.3;
  margin: 0; padding: 0; color: var(--grp-text);
  text-transform: none; letter-spacing: normal;
  border: none; background: none; box-shadow: none;
}
.grp-wrap p {
  font-family: var(--grp-font); font-size: 15px; line-height: 1.65;
  margin: 0; padding: 0; color: var(--grp-text);
}
.grp-wrap a {
  color: var(--grp-primary); text-decoration: none;
  background: none; border: none; padding: 0; margin: 0;
  font-family: var(--grp-font); box-shadow: none;
}
.grp-wrap a:hover { color: var(--grp-primary-dark); text-decoration: underline; }

.grp-wrap button {
  font-family: var(--grp-font); font-size: 14px; font-weight: 400;
  line-height: 1; color: inherit; background: none; border: none;
  border-radius: 0; padding: 0; margin: 0; cursor: pointer;
  text-transform: none; letter-spacing: normal;
  box-shadow: none; text-shadow: none;
  -webkit-appearance: none; appearance: none;
}
.grp-wrap input, .grp-wrap select, .grp-wrap textarea {
  font-family: var(--grp-font); font-size: 14px; line-height: 1.5;
  color: var(--grp-text); background: var(--grp-surface);
  border: 1px solid var(--grp-border); border-radius: var(--grp-radius-sm);
  padding: 0; margin: 0; box-shadow: none;
  -webkit-appearance: none; appearance: none; outline: none;
}
.grp-wrap ul, .grp-wrap ol { list-style: none; margin: 0; padding: 0; }
.grp-wrap img { max-width: 100%; height: auto; display: block; border: none; vertical-align: middle; }
.grp-wrap table { border-collapse: collapse; width: 100%; }
.grp-wrap strong { font-weight: 600; }
.grp-wrap em     { font-style: italic; }

/* --------------------------------------------------------------------------
   Base wrap
   -------------------------------------------------------------------------- */
.grp-wrap {
  max-width:   1200px;
  margin:      0 auto;
  padding:     32px 20px;
  font-family: var(--grp-font);
  font-size:   15px;
  line-height: 1.65;
  color:       var(--grp-text);
  background:  transparent;
}

/* --------------------------------------------------------------------------
   Buttons — clean, sharp, professional
   -------------------------------------------------------------------------- */
.grp-button {
  display:            inline-flex;
  align-items:        center;
  justify-content:    center;
  gap:                6px;
  padding:            9px 18px;
  border-radius:      var(--grp-radius-sm);
  font-family:        var(--grp-font);
  font-size:          14px;
  font-weight:        500;
  line-height:        1;
  cursor:             pointer;
  text-decoration:    none;
  border:             1px solid transparent;
  white-space:        nowrap;
  text-transform:     none;
  letter-spacing:     normal;
  box-shadow:         none;
  text-shadow:        none;
  -webkit-appearance: none;
  appearance:         none;
  transition:         background .12s ease, border-color .12s ease,
                      color .12s ease, box-shadow .12s ease;
}
.grp-button:hover { text-decoration: none; }

.grp-button--primary {
  background: var(--grp-primary); color: #fff !important;
  border-color: var(--grp-primary);
}
.grp-button--primary:hover {
  background: var(--grp-primary-dark); border-color: var(--grp-primary-dark);
  color: #fff !important; box-shadow: 0 2px 6px rgba(30,64,175,.2);
}
.grp-button--ghost {
  background: transparent; color: var(--grp-primary) !important;
  border-color: var(--grp-border);
}
.grp-button--ghost:hover {
  border-color: var(--grp-primary); background: var(--grp-primary-pale);
  color: var(--grp-primary) !important;
}
.grp-button--sm     { padding: 6px 12px; font-size: 13px; }
.grp-button--danger { background: var(--grp-danger); color: #fff !important; border-color: var(--grp-danger); }
.grp-button--danger:hover { background: #b91c1c; border-color: #b91c1c; }

/* --------------------------------------------------------------------------
   Forms
   -------------------------------------------------------------------------- */
.grp-form { display: flex; flex-direction: column; gap: 18px; }
/* Form grid — column layout controlled by grp_form_columns setting */
.grp-form-grid {
  display: grid;
  gap: 0 16px; /* column gap only; row gap comes from .grp-form field margin */
  margin-bottom: 16px;
}
.grp-form-grid--1 { grid-template-columns: 1fr; }
.grp-form-grid--2 { grid-template-columns: repeat(2, 1fr); }
.grp-form-grid--3 { grid-template-columns: repeat(3, 1fr); }
.grp-form-grid--4 { grid-template-columns: repeat(4, 1fr); }

/* On narrow containers (tabs, sidebars) collapse to 1 column */
@media (max-width: 480px) {
  .grp-form-grid--2,
  .grp-form-grid--3,
  .grp-form-grid--4 { grid-template-columns: 1fr; }
  .grp-form-grid > .grp-form-field { grid-column: span 1 !important; }
}
@media (min-width: 481px) and (max-width: 680px) {
  .grp-form-grid--3,
  .grp-form-grid--4 { grid-template-columns: repeat(2, 1fr); }
}


.grp-form-field { display: flex; flex-direction: column; gap: 5px; }
.grp-form-field label {
  font-family: var(--grp-font); font-size: 13px; font-weight: 500;
  color: var(--grp-text); line-height: 1.4; display: block;
  margin: 0; padding: 0; background: none; border: none;
  cursor: default; text-transform: none; letter-spacing: normal;
}
.grp-form-field label .required { color: var(--grp-danger); }
.grp-field-hint { font-size: 12px; color: var(--grp-text-muted); line-height: 1.4; margin: 0; }

.grp-form-field input[type="text"],
.grp-form-field input[type="email"],
.grp-form-field input[type="password"],
.grp-form-field input[type="url"],
.grp-form-field input[type="tel"],
.grp-form-field input[type="number"],
.grp-form-field input[type="search"],
.grp-form-field select,
.grp-form-field textarea {
  width: 100%; padding: 9px 12px;
  border: 1px solid var(--grp-border); border-radius: var(--grp-radius-sm);
  font-family: var(--grp-font); font-size: 14px; line-height: 1.5;
  color: var(--grp-text); background: var(--grp-surface);
  box-shadow: none; outline: none; margin: 0; display: block;
  transition: border-color .15s ease, box-shadow .15s ease;
  -webkit-appearance: none; appearance: none;
}
.grp-form-field select {
  background-image:    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2364748b' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:   no-repeat;
  background-position: right 10px center;
  padding-right:       32px;
}
.grp-form-field input:focus,
.grp-form-field select:focus,
.grp-form-field textarea:focus {
  border-color: var(--grp-primary);
  box-shadow:   0 0 0 3px rgba(30,64,175,.10);
  outline:      none;
}
.grp-form-field textarea { resize: vertical; min-height: 96px; }
.grp-form-field--checkbox { flex-direction: row; align-items: flex-start; gap: 10px; }
.grp-form .grp-form-field--checkbox,
.grp-form .grp-button { margin-top: 4px; }
.grp-form-field--checkbox input[type="checkbox"],
.grp-radio-label input[type="checkbox"],
.grp-radio-label input[type="radio"],
.grp-checkbox-label input[type="checkbox"] {
  -webkit-appearance: checkbox !important;
  appearance: checkbox !important;
  width: 16px !important; height: 16px !important;
  min-width: 16px; padding: 0 !important;
  border: 1px solid var(--grp-border) !important;
  border-radius: 3px !important;
  background: var(--grp-surface) !important;
  box-shadow: none !important;
  display: inline-block !important;
  flex-shrink: 0; margin-top: 2px; cursor: pointer;
}

.grp-radio-group { display: flex; flex-direction: column; gap: 8px; }
.grp-radio-label, .grp-checkbox-label {
  display: flex; align-items: flex-start; gap: 8px; cursor: pointer;
  font-family: var(--grp-font); font-size: 14px; font-weight: normal;
  color: var(--grp-text); margin: 0; padding: 0;
  background: none; border: none; line-height: 1.5;
  text-transform: none; letter-spacing: normal;
}
.grp-radio-label input, .grp-checkbox-label input { margin-top: 3px; flex-shrink: 0; }

.grp-form-message {
  padding: 11px 14px; border-radius: var(--grp-radius-sm);
  font-family: var(--grp-font); font-size: 14px; line-height: 1.5;
  margin-bottom: 4px; border: 1px solid transparent;
}
.grp-form-message.is-success { background: #f0fdf4; color: #14532d; border-color: #bbf7d0; }
.grp-form-message.is-error   { background: #fef2f2; color: #7f1d1d; border-color: #fecaca; }

/* --------------------------------------------------------------------------
   Notices
   -------------------------------------------------------------------------- */
.grp-notice, .grp-gated-notice, .grp-access-denied {
  padding:     14px 18px;
  background:  var(--grp-bg);
  border-left: 3px solid var(--grp-primary);
  border-radius: 0 var(--grp-radius-sm) var(--grp-radius-sm) 0;
  font-family: var(--grp-font);
  font-size:   14px;
  color:       var(--grp-text);
  line-height: 1.6;
}
.grp-access-denied { border-color: var(--grp-warning); background: #fffbeb; }

/* --------------------------------------------------------------------------
   Registration + Login
   -------------------------------------------------------------------------- */
.grp-register-wrap, .grp-login-wrap { max-width: 480px; }

/* Footer link below register / login forms ("Already have access? Sign in." etc.) */
.grp-pending-wrap        { max-width: 620px; margin: 0 auto; text-align: center; padding: 48px 24px; }
.grp-pending-body        { margin-bottom: 28px; }
.grp-pending-body h2     { font-size: 22px; font-weight: 700; color: var(--grp-text); margin: 0 0 12px; }
.grp-pending-body p      { font-size: 15px; color: var(--grp-text-muted); line-height: 1.65; margin: 0 0 8px; }
.grp-pending-actions     { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

.grp-form-footer-link,
.grp-login-register-link {
  margin-top:  14px;
  font-size:   14px;
  color:       var(--grp-text-muted);
  text-align:  center;
}
.grp-form-footer-link a,
.grp-login-register-link a {
  color:           var(--grp-primary);
  text-decoration: none;
  font-weight:     500;
}
.grp-form-footer-link a:hover,
.grp-login-register-link a:hover { text-decoration: underline; }
.grp-login-wrap .login-submit .button-primary {
  background: var(--grp-primary); border-color: var(--grp-primary-dark);
  border-radius: var(--grp-radius-sm); padding: 9px 18px; width: 100%;
  font-family: var(--grp-font); font-size: 14px; font-weight: 500;
  box-shadow: none; text-shadow: none;
}

/* --------------------------------------------------------------------------
   Library controls + grid
   -------------------------------------------------------------------------- */
.grp-library-controls {
  display:     flex;
  flex-wrap:   wrap;
  align-items: center;
  gap:         10px;
  margin-bottom: 20px;
}
.grp-search-form {
  display:     flex;
  flex-wrap:   wrap;
  gap:         8px;
  align-items: center;
  flex:        1;
}

.grp-search-input {
  flex: 1; min-width: 200px; padding: 8px 12px; height: 38px;
  border: 1px solid var(--grp-border); border-radius: var(--grp-radius-sm);
  font-family: var(--grp-font); font-size: 14px; color: var(--grp-text);
  background: var(--grp-surface); box-shadow: none; outline: none;
  transition: border-color .15s; -webkit-appearance: none; appearance: none;
}
.grp-search-input:focus { border-color: var(--grp-primary); box-shadow: 0 0 0 3px rgba(30,64,175,.10); }

.grp-filter-select {
  padding: 8px 36px 8px 12px;
  height: 38px;
  border: 1px solid var(--grp-border); border-radius: var(--grp-radius-sm);
  font-family: var(--grp-font); font-size: 14px; color: var(--grp-text);
  background: var(--grp-surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2364748b' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 12px center;
  box-shadow: none; outline: none; cursor: pointer;
  -webkit-appearance: none; appearance: none;
  min-width: 160px;
}
.grp-filter-select:focus { border-color: var(--grp-primary); box-shadow: 0 0 0 3px rgba(30,64,175,.10); }
.grp-filter-select option { padding: 8px 12px; line-height: 1.8; }

/* View toggle buttons */
.grp-view-toggle {
  display:     flex;
  align-items: center;
  gap:         2px;
  padding:     3px;
  background:  var(--grp-bg);
  border:      1px solid var(--grp-border);
  border-radius: var(--grp-radius-sm);
  flex-shrink: 0;
}
.grp-view-btn {
  display:       inline-flex;
  align-items:   center;
  justify-content: center;
  width:         32px;
  height:        30px;
  border:        none;
  border-radius: 4px;
  background:    transparent;
  color:         var(--grp-text-muted);
  cursor:        pointer;
  transition:    background .12s, color .12s;
  padding:       0;
}
.grp-view-btn:hover  { background: var(--grp-surface); color: var(--grp-text); }
.grp-view-btn.is-active { background: var(--grp-surface); color: var(--grp-primary); box-shadow: 0 1px 3px rgba(0,0,0,.10); }

/* Grid layout */
.grp-grid { display: grid; gap: 18px; }
.grp-grid--4 { grid-template-columns: repeat(4,1fr); }
.grp-grid--3 { grid-template-columns: repeat(3,1fr); }
.grp-grid--2 { grid-template-columns: repeat(2,1fr); }
.grp-grid--1 { grid-template-columns: 1fr; }

@media (max-width: 1100px) { .grp-grid--4 { grid-template-columns: repeat(3,1fr); } }
@media (max-width: 900px)  { .grp-grid--4, .grp-grid--3 { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 600px)  { .grp-grid--4, .grp-grid--3, .grp-grid--2 { grid-template-columns: 1fr; } }

/* --------------------------------------------------------------------------
   Cards — grid mode
   -------------------------------------------------------------------------- */
.grp-card {
  background:      var(--grp-surface);
  border:          1px solid var(--grp-border);
  border-radius:   var(--grp-radius);
  overflow:        hidden;
  display:         flex;
  flex-direction:  column;
  transition:      box-shadow .18s ease, border-color .18s ease, transform .18s ease;
  box-shadow:      var(--grp-shadow);
  cursor:          pointer;
  margin: 0; padding: 0;
}
.grp-card:hover {
  box-shadow:    0 8px 24px rgba(0,0,0,.10), 0 2px 6px rgba(0,0,0,.06);
  border-color:  #cbd5e1;
  transform:     translateY(-2px);
}
.grp-card--minimal { box-shadow: none; }
.grp-card--minimal:hover { box-shadow: var(--grp-shadow-md); }
.grp-card--bordered { border: 2px solid var(--grp-primary); box-shadow: none; }
.grp-card--bordered:hover { box-shadow: var(--grp-shadow-md); }

/* Thumbnail — locked 16:9 aspect ratio */
.grp-card__header {
  position:     relative;
  overflow:     hidden;
  aspect-ratio: 16/9;
  background:   var(--grp-bg);
  flex-shrink:  0;
  margin: 0; padding: 0;
}
.grp-card__thumb {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center top;
  display: block; border: none; margin: 0; padding: 0;
  transition: transform .25s ease;
}
.grp-card:hover .grp-card__thumb { transform: scale(1.03); }
.grp-card__thumb--placeholder {
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #f1f5f9 0%, #e2e8f0 100%);
  width: 100%; height: 100%;
}
.grp-card__thumb--placeholder .grp-icon::before { font-size: 36px; }
.grp-icon--article::before { content: "📄"; }
.grp-icon--pdf::before     { content: "📋"; }
.grp-icon--video::before   { content: "🎬"; }
.grp-icon--embed::before   { content: "🖥"; }
.grp-icon--image::before   { content: "🖼"; }
.grp-icon--tool::before    { content: "🔧"; }

/* Card body */
.grp-card__body {
  padding:        12px 14px 10px;
  flex:           1;
  display:        flex;
  flex-direction: column;
  gap:            6px;
  background:     none;
  border:         none;
}

/* Meta-top row: type badge + category tags side by side */
.grp-card__meta-top {
  display:     flex;
  flex-wrap:   wrap;
  align-items: center;
  gap:         5px;
}

/* Type badge — inline, not overlaid on image */
.grp-badge {
  display:        inline-flex;
  align-items:    center;
  padding:        2px 7px;
  border-radius:  var(--grp-radius-xs, 3px);
  font-family:    var(--grp-font);
  font-size:      10px !important;
  font-weight:    700;
  text-transform: uppercase;
  letter-spacing: .06em;
  background:     rgba(0,0,0,.55);
  color:          #fff !important;
  border:         none;
  line-height:    1.5;
  white-space:    nowrap;
  flex-shrink:    0;
}
.grp-badge--pdf     { background: #b91c1c; }
.grp-badge--video   { background: #1e40af; }
.grp-badge--tool    { background: #15803d; }
.grp-badge--article { background: #6b21a8; }
.grp-badge--embed   { background: #b45309; }
.grp-badge--image   { background: #0369a1; }

/* Category tags */
.grp-tag {
  font-family:     var(--grp-font);
  font-size:       11px !important;
  font-weight:     500;
  line-height:     1;
  padding:         2px 7px;
  background:      var(--grp-bg);
  color:           var(--grp-text-muted) !important;
  border-radius:   var(--grp-radius-sm);
  border:          1px solid var(--grp-border);
  text-decoration: none;
  display:         inline-block;
  transition:      var(--grp-transition);
  white-space:     nowrap;
}
.grp-tag:hover { background: var(--grp-primary); color: #fff !important; border-color: var(--grp-primary); text-decoration: none; }

/* Title — !important to override any theme h3 styles */
.grp-card__title {
  font-family:    var(--grp-font) !important;
  font-size:      14px !important;
  font-weight:    600 !important;
  line-height:    1.4 !important;
  margin:         0 !important;
  padding:        0 !important;
  color:          var(--grp-text) !important;
  background:     none !important;
  border:         none !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  display:        -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow:       hidden;
}

/* Excerpt — only show when present, no gap when absent */
.grp-card__excerpt {
  font-family:    var(--grp-font);
  font-size:      12px !important;
  line-height:    1.5;
  color:          var(--grp-text-muted);
  margin:         0;
  flex:           1;
  display:        -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow:       hidden;
}

/* Footer */
.grp-card__footer {
  padding:         8px 14px;
  border-top:      1px solid var(--grp-border);
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  gap:             8px;
  background:      none;
}
.grp-card__meta {
  display:     flex;
  align-items: center;
  gap:         8px;
  font-family: var(--grp-font);
  font-size:   12px;
  color:       var(--grp-text-muted);
}
.grp-views { display: flex; align-items: center; gap: 3px; }

/* --------------------------------------------------------------------------
   List view — compact rows
   -------------------------------------------------------------------------- */
.grp-grid.grp-view--list {
  grid-template-columns: 1fr !important;
  gap: 8px !important;
}
.grp-view--list .grp-card {
  flex-direction: row !important;
  align-items:    stretch !important;
  transform:      none !important;
  min-height:     80px;
}
.grp-view--list .grp-card:hover { transform: none !important; }
.grp-view--list .grp-card__header {
  width:        90px !important;
  min-width:    90px !important;
  aspect-ratio: auto !important;
  height:       auto !important;
  border-bottom: none !important;
  border-right: 1px solid var(--grp-border) !important;
  flex-shrink:  0;
}
.grp-view--list .grp-card__thumb { object-position: center center; }
.grp-view--list .grp-card__thumb--placeholder .grp-icon::before { font-size: 24px; }
.grp-view--list .grp-card__body {
  flex:           1;
  flex-direction: row !important;
  align-items:    center !important;
  gap:            12px !important;
  padding:        10px 14px !important;
  min-width:      0;
}
.grp-view--list .grp-card__body-main {
  flex:      1;
  min-width: 0;
  display:   flex;
  flex-direction: column;
  gap:       4px;
}
.grp-view--list .grp-card__footer {
  border-top:  none !important;
  border-left: 1px solid var(--grp-border) !important;
  padding:     10px 14px !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  gap:         6px !important;
  min-width:   90px;
  flex-shrink: 0;
}
/* In list view, excerpt shows more words */
.grp-view--list .grp-card__excerpt { -webkit-line-clamp: 1 !important; }
.grp-view--list .grp-card__title   { -webkit-line-clamp: 1 !important; font-size: 13px !important; }

/* Wrap title/excerpt in list view */
.grp-card__body-main { display: contents; }
.grp-view--list .grp-card__body-main { display: flex; flex-direction: column; gap: 3px; flex: 1; min-width: 0; }

/* --------------------------------------------------------------------------
   Stars
   -------------------------------------------------------------------------- */
.grp-rating-stars { display: flex; align-items: center; gap: 2px; }
.grp-star         { font-size: 13px; color: var(--grp-border); line-height: 1; }
.grp-star--filled { color: #f59e0b; }

/* --------------------------------------------------------------------------
   Pagination — clean numbered nav
   -------------------------------------------------------------------------- */
.grp-pagination { display: flex; justify-content: center; gap: 3px; margin-top: 36px; }
.grp-pagination .page-numbers {
  display:         inline-flex;
  align-items:     center;
  justify-content: center;
  min-width:       34px; height: 34px;
  padding:         0 8px;
  border:          1px solid var(--grp-border);
  border-radius:   var(--grp-radius-sm);
  font-family:     var(--grp-font);
  font-size:       13px;
  font-weight:     500;
  text-decoration: none;
  color:           var(--grp-text);
  background:      var(--grp-surface);
  transition:      var(--grp-transition);
  line-height:     1;
}
.grp-pagination .page-numbers.current,
.grp-pagination .page-numbers:hover {
  background:      var(--grp-primary);
  color:           #fff;
  border-color:    var(--grp-primary);
  text-decoration: none;
}

/* --------------------------------------------------------------------------
   Empty / hint states
   -------------------------------------------------------------------------- */
.grp-empty      { text-align: center; padding: 52px 24px; color: var(--grp-text-muted); font-family: var(--grp-font); font-size: 14px; }
.grp-empty-hint { color: var(--grp-text-muted); font-family: var(--grp-font); font-size: 13px; font-style: italic; }

/* --------------------------------------------------------------------------
   Modal
   -------------------------------------------------------------------------- */
/* --------------------------------------------------------------------------
   Resource modal
   -------------------------------------------------------------------------- */
.grp-modal { position: fixed; inset: 0; z-index: 99999; display: flex; align-items: center; justify-content: center; }
.grp-modal__overlay { position: absolute; inset: 0; background: rgba(0,0,0,.45); backdrop-filter: blur(2px); }
.grp-modal__dialog {
  position:      relative;
  background:    var(--grp-surface);
  border:        1px solid var(--grp-border);
  border-radius: var(--grp-radius);
  max-width:     760px; width: 94vw; max-height: 88vh;
  overflow-y:    auto;
  box-shadow:    0 20px 48px rgba(0,0,0,.14), 0 4px 12px rgba(0,0,0,.08);
  display:       flex;
  flex-direction: column;
}

/* Close button — anchored inside dialog, not floating gold circle */
.grp-modal__close {
  position:      absolute;
  top:           10px; right: 10px;
  background:    rgba(0,0,0,.45);
  border:        none;
  border-radius: 50%;
  width:         28px; height: 28px;
  font-size:     16px; cursor: pointer; line-height: 1;
  display:       flex; align-items: center; justify-content: center;
  color:         #fff;
  z-index:       10;
  box-shadow:    none; text-shadow: none; padding: 0;
  transition:    background .15s;
}
.grp-modal__close:hover { background: rgba(0,0,0,.7); }

/* Hero thumbnail — fixed height, cropped */
.grp-modal__hero {
  width:         100%;
  height:        220px;
  overflow:      hidden;
  flex-shrink:   0;
  background:    var(--grp-bg);
  border-radius: var(--grp-radius) var(--grp-radius) 0 0;
}
.grp-modal__hero-img {
  width:          100% !important;
  height:         100% !important;
  object-fit:     cover !important;
  object-position: center top !important;
  display:        block !important;
  margin:         0 !important;
  border-radius:  0 !important;
}

/* Body area below hero */
.grp-modal__body {
  padding:    22px 26px 24px;
  flex:       1;
  min-height: 0;
}

/* Badge + tag row */
.grp-modal__meta-top {
  display:     flex;
  flex-wrap:   wrap;
  align-items: center;
  gap:         6px;
  margin-bottom: 10px;
}

/* Title — clamped, !important to beat theme h2 styles */
.grp-modal__title {
  font-family:    var(--grp-font) !important;
  font-size:      20px !important;
  font-weight:    700 !important;
  line-height:    1.3 !important;
  color:          var(--grp-text) !important;
  margin:         0 0 8px !important;
  padding:        0 !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  background:     none !important;
  border:         none !important;
}

/* Excerpt */
.grp-modal__excerpt {
  font-family: var(--grp-font);
  font-size:   14px;
  line-height: 1.6;
  color:       var(--grp-text-muted);
  margin:      0 0 16px;
}

/* Media block (PDF embed, video, image) */
.grp-modal__media { margin-bottom: 16px; }
.grp-modal__pdf   { width: 100%; min-height: 500px; border-radius: var(--grp-radius-sm); border: none; display: block; }
.grp-modal__video { width: 100%; border-radius: var(--grp-radius-sm); display: block; }
.grp-modal__image { max-width: 100%; border-radius: var(--grp-radius-sm); display: block; }

/* Non-previewable file notice (Word, Excel, etc.) */
.grp-modal__download-notice {
  display:       flex;
  align-items:   center;
  gap:           16px;
  padding:       20px;
  background:    var(--grp-bg);
  border:        1px solid var(--grp-border);
  border-radius: var(--grp-radius);
  flex-wrap:     wrap;
}
.grp-modal__download-notice-icon {
  font-size:  36px;
  line-height: 1;
  flex-shrink: 0;
}
.grp-modal__download-notice-text {
  flex:       1;
  min-width:  180px;
  font-family: var(--grp-font);
}
.grp-modal__download-notice-text strong {
  display:     block;
  font-size:   14px;
  font-weight: 600;
  color:       var(--grp-text);
  margin-bottom: 4px;
}
.grp-modal__download-notice-text p {
  font-size:  13px;
  color:      var(--grp-text-muted);
  margin:     0;
  line-height: 1.5;
}

/* Article content */
.grp-resource-content { margin-bottom: 16px; line-height: 1.7; font-family: var(--grp-font); font-size: 14px; color: var(--grp-text); }

/* Tags row */
.grp-modal__tags { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 16px; }

/* Footer row: views/rating + download button inline */
.grp-modal__footer-row {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  gap:             12px;
  padding:         12px 0;
  border-top:      1px solid var(--grp-border);
  border-bottom:   1px solid var(--grp-border);
  margin-bottom:   16px;
}
.grp-modal__stats {
  display:     flex;
  align-items: center;
  gap:         14px;
  font-family: var(--grp-font);
  font-size:   13px;
  color:       var(--grp-text-muted);
}
.grp-modal__views     { display: flex; align-items: center; gap: 4px; }
.grp-modal__avg-rating { display: flex; align-items: center; gap: 3px; }

/* --------------------------------------------------------------------------
   Rating widget — tighter
   -------------------------------------------------------------------------- */
.grp-rating-widget       { margin-top: 4px; padding-top: 16px; }
.grp-rating-widget h4    { font-family: var(--grp-font); font-size: 13px !important; font-weight: 600; margin: 0 0 8px !important; color: var(--grp-text); padding: 0 !important; background: none !important; border: none !important; }
.grp-star-picker         { display: flex; gap: 3px; margin-bottom: 10px; cursor: pointer; }
.grp-star-picker .grp-star-pick { font-size: 20px !important; color: var(--grp-border); transition: color .1s; cursor: pointer; line-height: 1; }
.grp-star-picker .grp-star-pick.is-active,
.grp-star-picker .grp-star-pick:hover { color: #f59e0b; }
.grp-rating-feedback {
  width: 100%; border: 1px solid var(--grp-border); border-radius: var(--grp-radius-sm);
  padding: 8px 10px; font-family: var(--grp-font); font-size: 13px; color: var(--grp-text);
  margin-bottom: 8px; resize: vertical; background: var(--grp-surface); box-shadow: none; outline: none;
}
.grp-rating-feedback:focus { border-color: var(--grp-primary); box-shadow: 0 0 0 3px rgba(30,64,175,.10); }
.grp-rating-avg { font-family: var(--grp-font); font-size: 12px; color: var(--grp-text-muted); margin-top: 6px; }

/* --------------------------------------------------------------------------
   Dashboard
   -------------------------------------------------------------------------- */
.grp-dashboard-header {
  display: flex; align-items: center; gap: 16px;
  padding: 20px 24px;
  background: var(--grp-surface); border: 1px solid var(--grp-border);
  border-radius: var(--grp-radius); box-shadow: var(--grp-shadow);
  margin-bottom: 24px;
}
.grp-avatar { border-radius: 50%; display: block; }
.grp-dashboard-welcome h2 {
  font-family: var(--grp-font); font-size: 18px; font-weight: 600;
  margin: 0; color: var(--grp-text); line-height: 1.3;
  text-transform: none; letter-spacing: normal;
}
.grp-dashboard-org { font-family: var(--grp-font); margin: 2px 0 0; font-size: 13px; color: var(--grp-text-muted); }
.grp-dashboard-header .grp-button { margin-left: auto; }

.grp-dashboard-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
@media (max-width: 700px) { .grp-dashboard-grid { grid-template-columns: 1fr; } }

.grp-dashboard-section {
  background: var(--grp-surface); border: 1px solid var(--grp-border);
  border-radius: var(--grp-radius); box-shadow: var(--grp-shadow); padding: 18px 22px;
}
.grp-dashboard-section h3 {
  font-family: var(--grp-font); margin: 0 0 14px; font-size: 14px; font-weight: 600;
  color: var(--grp-text); text-transform: none; letter-spacing: normal;
  border-bottom: 1px solid var(--grp-border); padding-bottom: 10px;
}

.grp-dashboard-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; }
.grp-dashboard-list__item {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 0; border-bottom: 1px solid var(--grp-border);
  font-family: var(--grp-font); font-size: 13px;
}
.grp-dashboard-list__item:last-child { border-bottom: none; }
.grp-dashboard-list__icon  { font-size: 15px; flex-shrink: 0; }
.grp-dashboard-list__title { flex: 1; font-weight: 500; color: var(--grp-text); }
.grp-dashboard-list__date  { color: var(--grp-text-muted); font-size: 12px; white-space: nowrap; }

.grp-bookmark-btn--sm {
  background: none; border: none; cursor: pointer;
  color: var(--grp-text-muted); font-size: 13px; padding: 2px 4px;
  box-shadow: none; text-shadow: none; line-height: 1;
}
.grp-bookmark-btn--sm:hover { color: var(--grp-danger); }

/* --------------------------------------------------------------------------
   Welcome banner (library top)
   -------------------------------------------------------------------------- */
.grp-welcome-banner {
  background:    linear-gradient(135deg, var(--grp-primary) 0%, var(--grp-primary-dark) 100%);
  color:         #fff;
  padding:       14px 18px;
  border-radius: var(--grp-radius);
  margin-bottom: 20px;
  font-family:   var(--grp-font);
  font-size:     14px;
  font-weight:   500;
  line-height:   1.5;
  border:        none;
}
.grp-welcome-banner a { color: #fff; text-decoration: underline; }

/* --------------------------------------------------------------------------
   Responsive
   -------------------------------------------------------------------------- */
@media (max-width: 600px) {
  .grp-wrap             { padding: 20px 14px; }
  .grp-form-row         { flex-direction: column; }
  .grp-library-controls { flex-direction: column; }
  .grp-search-form      { flex-direction: column; }
  .grp-search-input     { min-width: 100%; }
  .grp-modal__hero      { height: 160px; }
  .grp-modal__body      { padding: 16px 18px 20px; }
  .grp-modal__title     { font-size: 17px !important; }
  .grp-modal__footer-row { flex-direction: column; align-items: flex-start; gap: 10px; }
}

/* ==========================================================================
   [portal_account] — Member self-service account page
   ========================================================================== */

/* ── Expiry banner ── */
.grp-account-expiry {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border-radius: var(--grp-radius-sm);
  font-family: var(--grp-font);
  font-size: 14px;
  line-height: 1.5;
  margin-bottom: 24px;
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  color: #1e40af;
}
.grp-account-expiry--expired {
  background: #fff7ed;
  border-color: #fed7aa;
  color: #9a3412;
}
.grp-account-expiry__icon { font-size: 16px; flex-shrink: 0; }

/* ── Sections ── */
.grp-account-section {
  background: var(--grp-surface);
  border: 1px solid var(--grp-border);
  border-radius: var(--grp-radius);
  padding: 24px 28px;
  margin-bottom: 20px;
}
.grp-account-section__title {
  font-family: var(--grp-font);
  font-size: 16px;
  font-weight: 600;
  color: var(--grp-text);
  margin: 0 0 4px;
  padding: 0;
}
.grp-account-section__desc {
  font-family: var(--grp-font);
  font-size: 13px;
  color: var(--grp-text-muted);
  margin: 0 0 16px;
}

/* ── Two-column responsive grid inside each section ── */
.grp-account-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0 16px;
  margin-bottom: 16px;
}
.grp-account-grid__full { grid-column: span 2; }

/* ── Actions row (button + spinner) ── */
.grp-account-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

/* ── Inline spinner (reuse grp-spinner if defined, else define here) ── */
.grp-account-wrap .grp-spinner {
  display: inline-block;
  width: 18px;
  height: 18px;
  border: 2px solid var(--grp-border);
  border-top-color: var(--grp-primary);
  border-radius: 50%;
  animation: grp-spin 0.7s linear infinite;
  flex-shrink: 0;
}
@keyframes grp-spin { to { transform: rotate(360deg); } }

/* ── Responsive ── */
@media (max-width: 600px) {
  .grp-account-grid         { grid-template-columns: 1fr; }
  .grp-account-grid__full   { grid-column: span 1; }
  .grp-account-section      { padding: 18px 16px; }
}
