/*
 * ConjuresUp – Grimoire Library
 * Theme: dark purple + gold (matches ConjuresUp portal styling)
 * NOTE: Keep this file front-end safe. Do NOT rely on theme body classes.
 */

:root{
  --cgl-bg-0: rgba(18, 10, 36, 0.92);
  --cgl-bg-1: rgba(34, 18, 62, 0.88);
  --cgl-bg-2: rgba(120, 94, 166, 0.22);
  --cgl-gold: #f0d48a;
  --cgl-cream: #f5e6c8;
  --cgl-ink: #0f0a1e;
  --cgl-line: rgba(240, 212, 138, 0.22);
  --cgl-shadow: rgba(0,0,0,.35);
}

.cgl-wrap{max-width:1160px;margin:0 auto;padding:28px 16px 42px;}

/* Hero */
.cgl-hero{
  padding:26px 22px;
  border-radius:22px;
  background:linear-gradient(180deg, rgba(160,134,210,.28), rgba(18,10,36,.68));
  border:1px solid rgba(240,212,138,.22);
  box-shadow:0 18px 44px var(--cgl-shadow);
}
.cgl-hero-title{
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--cgl-cream);
  text-shadow:0 2px 12px rgba(0,0,0,.75);
  font-size:18px;
}
.cgl-hero-sub{
  margin-top:4px;
  color:rgba(245,230,200,.92);
  text-shadow:0 2px 10px rgba(0,0,0,.70);
  font-weight:700;
}

/* Intro blurb */
.cgl-intro{
  max-width:980px;
  margin:14px auto 10px;
  padding:14px 16px;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(34,18,62,.78), rgba(18,10,36,.70));
  border:1px solid rgba(240,212,138,.18);
  color:rgba(245,230,200,.92);
  box-shadow:0 18px 48px rgba(0,0,0,.28);
}

/* Old intro bar is no longer used (we inject a shorter tagline above search). */
.cgl-intro{ display:none !important; }

/* Tagline above search */
.cgl-tagline{
  width:100%;
  text-align:center;
  font-weight:800;
  letter-spacing:0.02em;
  color: rgba(255,255,255,0.88);
  text-shadow: 0 2px 10px rgba(0,0,0,0.45);
  margin-bottom: 2px;
}

/* Intro text above the search bar: improve contrast */
.cgl-intro,
.cgl-intro p{
  color: rgba(255, 255, 255, 0.78);
}

/* Tighter spacing between controls and grid */
.cgl-controls{ padding-top: 18px; }
.cgl-grid{ margin-top: 22px; }

/* Modal readability polish */
.cgl-modal-body{
  line-height: 1.6;
}

.cgl-modal-body h3,
.cgl-modal-body .cgl-section-title{
  letter-spacing: 0.04em;
  line-height: 1.15;
  position: relative;
  padding-left: 22px;
}

.cgl-modal-body h3::before,
.cgl-modal-body .cgl-section-title::before{
  content: "✦";
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0.65;
}

.cgl-intro p{margin:0;}

/* Controls */
.cgl-controls{margin-top:16px;display:flex;flex-direction:column;gap:12px;align-items:center;max-width:980px;width:100%;margin-left:auto;margin-right:auto;padding:18px 16px;border-radius:18px;background:linear-gradient(180deg, rgba(34,18,62,.64), rgba(18,10,36,.46));border:1px solid rgba(240,212,138,.18);box-shadow:0 18px 44px rgba(0,0,0,.22);margin-bottom:8px;}
.cgl-controls-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:center;width:100%;}

.cgl-search{
  flex:1 1 520px;
  max-width:560px;
  width:100%;
  padding:12px 16px;
  border-radius:999px;
  border:1px solid rgba(240,212,138,.26);
  background:rgba(255,255,255,.78);
  color:var(--cgl-ink);
  outline:none;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.80);
}
.cgl-search::placeholder{color:rgba(15,10,30,.55);}

/* Remove dropdown row UI per request (keep JS functional) */
.cgl-controls-row .cgl-select,
.cgl-controls-row #cglClear{display:none !important;}

/* Tag pills */
.cgl-tags{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;align-items:center;margin-top:10px;max-height:124px;overflow:auto;padding:6px 4px 2px;scrollbar-width:thin;}
.cgl-pill{
  appearance:none; -webkit-appearance:none;
  border-radius:999px;
  padding:10px 14px;
  border:1px solid rgba(240,212,138,.22);
  background:rgba(255,255,255,.10);
  color:rgba(245,230,200,.92);
  cursor:pointer;
  font-weight:700;
  line-height:1;
  transition:transform .12s ease, background .12s ease, border-color .12s ease;
}
.cgl-pill:hover{background:rgba(255,255,255,.18);}
.cgl-pill.is-active{background:rgba(240,212,138,.16);border-color:rgba(240,212,138,.40);transform:translateY(-1px);}

.cgl-meta{margin-top:6px;text-align:center;font-size:14px;color:rgba(245,230,200,.78);}

/* Grid */
.cgl-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-top:12px;}
@media (max-width:980px){.cgl-grid{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media (max-width:620px){.cgl-grid{grid-template-columns:1fr;}.cgl-search{flex-basis:100%;max-width:100%;}}

/* Cards */
.cgl-card{
  display:block;
  width:100%;
  box-sizing:border-box;
  text-align:left;
  border:1px solid rgba(240,212,138,.18);
  border-radius:20px;
  padding:16px 16px 14px;
  background:linear-gradient(180deg, rgba(34,18,62,.72), rgba(18,10,36,.86));
  box-shadow:0 14px 34px rgba(0,0,0,.28);
  color:rgba(245,230,200,.94);
  cursor:pointer;
  transition:transform .12s ease, border-color .12s ease, box-shadow .12s ease;
}

/* Wrapper lets us place a separate Journal CTA without nesting interactive elements */
.cgl-card-wrap{ position: relative; width:100%; display:block; }

.cgl-journal-cta{
  position: absolute;
  right: 12px;
  bottom: 12px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content:center;
  gap: 0;
  width: 36px;
  height: 36px;
  padding: 0;
  border-radius: 999px;
  font-size: 0; /* hide any stray text nodes */
  font-weight: 700;
  letter-spacing: 0.03em;
  text-decoration: none;
  color: rgba(255,255,255,0.9);
  background: rgba(0,0,0,0.22);
  border: 1px solid rgba(255,215,160,0.25);
  backdrop-filter: blur(4px);
}

.cgl-journal-cta:hover{
  background: rgba(0,0,0,0.28);
  border-color: rgba(255,215,160,0.42);
  transform: translateY(-1px);
}

.cgl-journal-cta .cgl-journal-ico{ opacity: 0.9; font-size:14px; line-height:1; }
.cgl-card:hover{transform:translateY(-2px);border-color:rgba(240,212,138,.34);box-shadow:0 18px 44px rgba(0,0,0,.35);}
.cgl-card:focus{outline:2px solid rgba(240,212,138,.45);outline-offset:2px;}

.cgl-card-head{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px;}
.cgl-card-icon{
  width:38px;height:38px;flex:0 0 38px;
  border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(180deg, rgba(240,212,138,.18), rgba(255,255,255,.06));
  border:1px solid rgba(240,212,138,.22);
  color:var(--cgl-gold);
  font-size:18px;
  line-height:1;
}
.cgl-card-title{font-weight:900;letter-spacing:.01em;line-height:1.15;font-size:18px;color:rgba(245,230,200,.96);}

.cgl-card-excerpt{margin-top:2px;color:rgba(245,230,200,.82);line-height:1.45;}
.cgl-card-meta{margin-top:10px;font-size:12px;color:rgba(245,230,200,.72);opacity:.95;}

/* Modal */
.cgl-modal{display:none;position:fixed;inset:0;z-index:99999;}
.cgl-modal[aria-hidden="false"]{display:block;}
.cgl-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.62);}
.cgl-modal-card{
  position:relative;
  max-width:960px;
  margin:6vh auto 0;
  border-radius:22px;
  background:linear-gradient(180deg, rgba(34,18,62,.96), rgba(18,10,36,.96));
  border:1px solid rgba(240,212,138,.22);
  box-shadow:0 26px 80px rgba(0,0,0,.55);
  padding:22px;
  max-height:88vh;
  overflow:auto;
  color:rgba(245,230,200,.92);
}
.cgl-modal-close{
  position:absolute;top:14px;right:14px;
  width:40px;height:40px;border-radius:999px;
  border:1px solid rgba(240,212,138,.22);
  background:rgba(255,255,255,.10);
  color:rgba(245,230,200,.95);
  cursor:pointer;font-size:22px;line-height:1;
}
.cgl-modal-close:hover{background:rgba(255,255,255,.16);}
.cgl-modal-title{font-size:26px;font-weight:900;margin:0;color:rgba(245,230,200,.98);}
.cgl-modal-meta{margin-top:6px;color:rgba(245,230,200,.72);font-size:13px;}
.cgl-modal-body{margin-top:16px;}
.cgl-modal-body h3{margin:16px 0 6px;font-size:18px;color:rgba(245,230,200,.96);}
.cgl-modal-body p{margin:0 0 10px;line-height:1.6;color:rgba(245,230,200,.86);}

body.cgl-modal-open{overflow:hidden;}

/* Safety: hide theme titles/byline when shortcode is used */
.cgl-shortcode-hide-title .entry-header,
.cgl-shortcode-hide-title .page-header,
.cgl-shortcode-hide-title .post-header,
.cgl-shortcode-hide-title .entry-title,
.cgl-shortcode-hide-title .entry-meta,
.cgl-shortcode-hide-title .post-meta,
.cgl-shortcode-hide-title .byline,
.cgl-shortcode-hide-title .comment-metadata{display:none !important;}
