/* =========================================
   BRP BOOKMARKS – FRONTEND STYLES
   ========================================= */

:root{
  --brp-bm-bg: #f6f3ef;
  --brp-bm-card: #ffffff;
  --brp-bm-border: #d8d8d8;
  --brp-bm-border-dark: #797979;
  --brp-bm-shadow: 0 2px 10px -2px rgba(27, 27, 27, 0.18);
  --brp-bm-shadow-strong: -1px 0px 10px -2px rgba(27, 27, 27, 0.35);

  --brp-bm-heading: #0C2C43;
  --brp-bm-text: #425466;
  --brp-bm-muted: #5A5A5A;

  --brp-bm-accent: #F37748;
  --brp-bm-accent-dark: #e56b3c;
  --brp-bm-accent-soft: #fff1eb;
  --brp-bm-accent-soft-2: #F3774885;

  --brp-bm-success-bg: #eef8f0;
  --brp-bm-success-text: #2e6b3f;

  --brp-bm-muted-pill-bg: #f2f2f2;
  --brp-bm-muted-pill-text: #666666;

  --brp-bm-head-font: "Roboto Slab", serif;
  --brp-bm-note-font: "Lora", serif;
  --brp-bm-body-font: Georgia, "Times New Roman", serif;
}

/* =========================================
   GENERAL WRAPPERS
   ========================================= */

.brp-bookmarks-actions,
.brp-bookmarks-manager-wrap,
.brp-bookmarks-starred-card,
.brp-bookmarks-notice,
.brp-bookmarks-empty-state,
.brp-bookmarks-starred-empty{
  font-family: var(--brp-bm-body-font);
  color: var(--brp-bm-text);
}

/* =========================================
   GUEST / RESTRICTED NOTICES
   ========================================= */

.brp-bookmarks-notice{
  display: block;
  width: 100%;
  background: #fff;
  border: 1px solid var(--brp-bm-border);
  border-radius: 14px;
  box-shadow: var(--brp-bm-shadow);
  padding: 14px 16px;
  margin: 10px 0 0 0;
}

.brp-bookmarks-notice-text{
  display: block;
  font-family: var(--brp-bm-note-font);
  font-size: 16px;
  font-style: italic;
  font-weight: 600;
  line-height: 1.45;
  letter-spacing: -0.3px;
  color: var(--brp-bm-muted);
}

.brp-bookmarks-notice-login{
  border-left: 4px solid var(--brp-bm-accent);
}

.brp-bookmarks-notice-restricted{
  border-left: 4px solid var(--brp-bm-heading);
}

/* =========================================
   POST ACTION BUTTONS
   ========================================= */

.brp-bookmarks-actions{
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin: 12px 0 0 0;
}

.brp-bookmarks-btn{
  appearance: none;
  -webkit-appearance: none;
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  overflow: hidden;
  border: 1px solid #d4d4d4;
  background: #fff;
  color: #3f3f3f;
  border-radius: 10px;
  min-height: 42px;
  padding: 10px 16px;
  font-family: var(--brp-bm-body-font);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.1px;
  line-height: 1.2;
  cursor: pointer;
  box-shadow: 0 2px 10px rgba(0,0,0,.06);
  text-shadow: none;
  transition:
    transform 0.16s ease,
    box-shadow 0.16s ease,
    background 0.16s ease,
    color 0.16s ease,
    border-color 0.16s ease,
    opacity 0.16s ease;
}

.brp-bookmarks-btn:hover{
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(0,0,0,.10);
  background: #F3774885 !important;
  border-color: #F3774885 !important;
  color: #0C2C43 !important;
}

.brp-bookmarks-btn:disabled,
.brp-bookmarks-btn.is-busy{
  opacity: 0.7;
  cursor: not-allowed;
  transform: none;
}

.brp-bookmarks-btn:focus{
  outline: none;
  box-shadow: 0 0 0 2px rgba(243, 119, 72, 0.18) !important;
}

.brp-bookmarks-actions .brp-bookmarks-btn-text{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  position: relative;
  z-index: 2;
}

/* Bookmark icon */
.brp-bookmarks-btn-bookmark .brp-bookmarks-btn-text::before{
  content: "🔖";
  font-size: 15px;
  line-height: 1;
  filter: grayscale(.35);
  opacity: .95;
}

/* Star icon */
.brp-bookmarks-btn-star .brp-bookmarks-btn-text::before{
  content: "★";
  font-size: 15px;
  line-height: 1;
  color: #767676;
}

/* Bookmarked state */
.brp-bookmarks-btn-bookmark.is-active{
  background: #fff7f3;
  border-color: #F3774885;
  color: var(--brp-bm-accent);
}

.brp-bookmarks-btn-bookmark.is-active .brp-bookmarks-btn-text::before{
  filter: none;
  opacity: .95;
}

/* Star default */
.brp-bookmarks-btn-star{
  background: #fff;
}

/* Star active */
.brp-bookmarks-btn-star.is-active{
  background: #f7f7f7;
  color: #4a4a4a;
  border-color: transparent;
}

.brp-bookmarks-btn-star.is-active::before{
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 10px;
  padding: 2px;
  background: linear-gradient(
    90deg,
    #e97b7b,
    #e9b07b,
    #e9df7b,
    #86e0a3,
    #7fd7e6,
    #8aa7ea,
    #b59ae8,
    #e88fc9
  );
  -webkit-mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity: .75;
  pointer-events: none;
}

.brp-bookmarks-btn-star.is-active .brp-bookmarks-btn-text::before{
  background: #f37748 !important;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  filter: none;
}

.brp-bookmarks-btn.is-active:hover,
.brp-bookmarks-btn-bookmark.is-active:hover,
.brp-bookmarks-btn-star.is-active:hover{
  background: #f37748 !important;
  border-color: #f37748 !important;
  color: #fff !important;
}

.brp-bookmarks-btn-delete{
  background: #797979 !important;
  color: #fff !important;
  border: 1px solid #797979 !important;
  box-shadow: none;
  min-height: 36px;
  padding: 8px 12px;
  border-radius: 10px !important;
}

.brp-bookmarks-btn-delete:hover{
  background: #F3774885 !important;
  border-color: #F3774885 !important;
  color: #0C2C43 !important;
}

.brp-bookmarks-btn-open{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none !important;
  background: var(--brp-bm-accent);
  border-color: var(--brp-bm-accent);
  color: #fff !important;
  text-shadow: none;
  font-family: "Roboto", sans-serif;
  font-weight: 600;
  padding: 10px 20px;
  border-radius: 10px !important;
}

.brp-bookmarks-btn-open:hover{
  background: var(--brp-bm-accent-dark);
  border-color: var(--brp-bm-accent-dark);
  color: #fff !important;
}

/* =========================================
   BOOKMARKS MANAGER TABLE
   ========================================= */

.brp-bookmarks-manager-wrap{
  background: var(--brp-bm-card);
  border: 1px solid var(--brp-bm-border);
  border-radius: 10px !important;
  box-shadow: var(--brp-bm-shadow);
  padding: 0 !important;
  overflow: hidden;
  overflow-x: auto;
}

.brp-bookmarks-table{
  width: 100%;
  min-width: 820px;
  border-collapse: separate;
  border-spacing: 0;
  background: #fff;
  border: 1px solid var(--brp-bm-border);
  border-radius: 10px !important;
  overflow: hidden;
}

.brp-bookmarks-table thead th{
  background: #F3774885;
  color: var(--brp-bm-heading);
  font-family: var(--brp-bm-head-font);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.2px;
  text-align: left;
  padding: 13px 12px;
  white-space: nowrap;
  border-right: 1px solid rgba(12,44,67,0.08);
  border-bottom: 1px solid #ead6cf;
}

.brp-bookmarks-table thead th:last-child{
  border-right: none;
}

.brp-bookmarks-table tbody td{
  font-size: 14px;
  line-height: 1.55;
  color: var(--brp-bm-text);
  padding: 14px 12px;
  vertical-align: middle;
  border-top: 1px solid #eee8e3;
  background: #fff;
}

.brp-bookmarks-table tbody tr:nth-child(even) td{
  background: #fcfaf8;
}

.brp-bookmarks-table tbody tr:hover td{
  background: #fff8f4;
}

.brp-bookmarks-col-title{
  min-width: 260px;
}

.brp-bookmarks-col-title a{
  color: var(--brp-bm-heading);
  text-decoration: none;
  font-weight: 700;
  word-break: break-word;
}

.brp-bookmarks-col-title a:hover{
  color: var(--brp-bm-accent);
  text-decoration: underline;
}

.brp-bookmarks-col-subject,
.brp-bookmarks-col-date,
.brp-bookmarks-col-starred,
.brp-bookmarks-col-action{
  white-space: nowrap;
}

.brp-bookmarks-col-tags{
  min-width: 180px;
}

.brp-bookmarks-pill{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
}

.brp-bookmarks-pill-starred{
  background: var(--brp-bm-accent-soft);
  color: var(--brp-bm-accent);
  border: 1px solid rgba(243,119,72,0.28);
}

.brp-bookmarks-pill-muted{
  background: var(--brp-bm-muted-pill-bg);
  color: var(--brp-bm-muted-pill-text);
  border: 1px solid #dddddd;
}

/* =========================================
   TAGS
   ========================================= */

.brp-bookmarks-tags,
.brp-bookmarks-tags-wrap{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
}

.brp-bookmarks-tag{
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border: 1px solid #d9d9d9;
  border-radius: 10px;
  background: #fff;
  color: #0C2C43;
  font-size: 12px;
  font-weight: 600;
  line-height: 1.2;
  white-space: nowrap;
  box-shadow: 0 1px 2px rgba(12, 44, 67, 0.06);
}

.brp-bookmarks-tags-more{
  display: inline-block;
}

.brp-bookmarks-tags-more summary{
  cursor: pointer;
  list-style: none;
  color: var(--brp-bm-accent);
  font-size: 12px;
  font-weight: 600;
  user-select: none;
}

.brp-bookmarks-tags-more summary::-webkit-details-marker{
  display: none;
}

.brp-bookmarks-tags-more-list{
  margin-top: 6px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.brp-bookmarks-no-tags{
  color: #797979;
  font-size: 12px;
  font-style: italic;
}

.brp-tags-extra{
  display: none;
}

.brp-bookmarks-tags-wrap.is-expanded .brp-tags-extra{
  display: inline-flex;
  flex-wrap: wrap;
  gap: 6px;
}

.brp-tags-toggle{
  display: inline-flex;
  align-items: center;
  padding: 4px 8px;
  border-radius: 10px;
  color: #F37748;
  font-size: 12px;
  font-weight: 600;
  line-height: 1.2;
  text-decoration: none;
  cursor: pointer;
  transition: background-color 0.2s ease, color 0.2s ease;
}

.brp-tags-toggle:hover,
.brp-tags-toggle:focus{
  background: #F3774885;
  color: #0C2C43;
  text-decoration: none;
  outline: none;
}

.brp-bookmarks-tags-wrap.is-expanded .brp-tags-toggle{
  order: 999;
}

/* =========================================
   STARRED HIGHLIGHT CARD
   ========================================= */

.brp-bookmarks-starred-card{
  position: relative;
  background: #faf7f2;
  border: 1px solid var(--brp-bm-border);
  border-radius: 18px;
  box-shadow: var(--brp-bm-shadow);
  padding: 15px;
  padding-top: 18px;
  overflow: hidden;
}

.brp-bookmarks-starred-card::before{
  display: none;
}

.brp-bookmarks-starred-badge{
  display: none !important;
}

.brp-bookmarks-starred-title{
  margin: 0 0 10px 0 !important;
  padding-top: 0 !important;
  font-family: var(--brp-bm-head-font);
  font-size: 20px !important;
  font-weight: 800;
  letter-spacing: 0.4px;
  line-height: 1.15;
  color: var(--brp-bm-heading);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.brp-bookmarks-starred-title a{
  color: var(--brp-bm-heading);
  text-decoration: none;
}

.brp-bookmarks-starred-title a:hover{
  color: var(--brp-bm-accent);
  text-decoration: underline;
}

.brp-bookmarks-starred-meta{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
  margin: 0 0 12px 0;
  color: var(--brp-bm-muted);
}

.brp-bookmarks-starred-subject,
.brp-bookmarks-starred-date,
.brp-bookmarks-starred-tags{
  display: inline-flex;
  align-items: center;
  min-height: 28px;
}

.brp-bookmarks-starred-date,
.brp-bookmarks-starred-tags{
  padding-left: 12px;
  border-left: 1px solid #cfcfcf;
}

.brp-bookmarks-starred-excerpt{
  margin: 0 0 16px 0;
  font-family: var(--brp-bm-body-font);
  font-size: 15px;
  line-height: 1.7;
  color: var(--brp-bm-text);
}

.brp-bookmarks-starred-actions{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.brp-bookmarks-starred-actions .brp-bookmarks-btn.brp-bookmarks-btn-open{
  border-radius: 10px;
  padding: 10px;
  font-size: 13px;
  font-weight: 600;
}

/* =========================================
   EMPTY STATES
   ========================================= */

.brp-bookmarks-empty-state,
.brp-bookmarks-starred-empty{
  background: #fff;
  border: 1px dashed var(--brp-bm-border);
  border-radius: 14px;
  padding: 18px 16px;
  text-align: center;
}

.brp-bookmarks-empty-state p,
.brp-bookmarks-starred-empty p{
  margin: 0;
  font-family: var(--brp-bm-note-font);
  font-size: 17px;
  font-style: italic;
  font-weight: 600;
  color: var(--brp-bm-muted);
}

/* =========================================
   INLINE CONTEXT IMPROVEMENTS
   ========================================= */

.brp-bookmarks-table .brp-bookmarks-btn{
  min-height: 36px;
  padding: 8px 12px;
  font-size: 13px;
  text-shadow: none;
}

/* =========================================
   RESPONSIVE
   ========================================= */

@media (max-width: 1024px){
  .brp-bookmarks-starred-title{
    font-size: 20px !important;
  }

  .brp-bookmarks-table thead th,
  .brp-bookmarks-table tbody td{
    font-size: 13px;
    padding: 10px 8px;
  }

  .brp-bookmarks-btn{
    min-height: 38px;
    padding: 9px 13px;
    font-size: 13px;
  }
}

@media (max-width: 640px){
  .brp-bookmarks-actions{
    gap: 8px;
  }

  .brp-bookmarks-btn{
    width: 100%;
    justify-content: center;
  }

  .brp-bookmarks-starred-title{
    font-size: 20px !important;
  }

  .brp-bookmarks-starred-card{
    padding: 16px;
    padding-top: 18px;
  }

  .brp-bookmarks-starred-meta{
    gap: 8px;
  }

  .brp-bookmarks-starred-date,
  .brp-bookmarks-starred-tags{
    padding-left: 0;
    border-left: none;
  }
}