:root{
  --bg:#ffffff;
  --bg2:#f6f9fc;
  --card:#ffffff;
  --text:#0b1220;
  --muted:#4b5565;
  --line:#e6edf5;
  --brand:#0b4a7a;
  --brand2:#126aa8;
  --shadow:0 10px 30px rgba(11,18,32,.08);
  --radius:18px;
  --radius2:26px;
  --max:1120px;
}
*{box-sizing:border-box}
html{color-scheme:light}
body{
  margin:0;
  font-family:ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--text);
  background:linear-gradient(180deg, #ffffff 0%, #ffffff 35%, var(--bg2) 100%);
  line-height:1.55;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--max);margin:0 auto;padding:0 18px}
.skip-link{
  position:absolute;left:-999px;top:12px;background:#fff;color:#000;padding:10px 12px;border-radius:12px;box-shadow:var(--shadow)
}
.skip-link:focus{left:12px;z-index:9999}

.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.76);
  backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid rgba(230,237,245,.7);
}
.header-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 18px}
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{
  width:34px;height:34px;border-radius:12px;
  background:radial-gradient(70% 70% at 30% 30%, #2aa7ff 0%, var(--brand) 55%, #063457 100%);
  box-shadow:0 10px 22px rgba(11,74,122,.18);
}
.brand-text{font-weight:750;letter-spacing:-.02em}

.nav{display:flex;align-items:center;gap:12px}
.nav-toggle{
  display:none;border:1px solid var(--line);background:#fff;border-radius:14px;padding:10px 12px;font-weight:650
}
.nav-menu{display:flex;gap:18px;align-items:center}
.nav-menu a{
  padding:8px 10px;border-radius:12px;color:var(--muted);font-weight:650
}
.nav-menu a:hover{color:var(--text);background:rgba(230,237,245,.65)}

/* Banking dropdown (details/summary) */
.nav-dd{position:relative}
.nav-dd summary{
  list-style:none;
  padding:8px 10px;
  border-radius:12px;
  color:var(--muted);
  font-weight:650;
  cursor:pointer;
  user-select:none;
}
.nav-dd summary::-webkit-details-marker{display:none}
.nav-dd summary:hover{color:var(--text);background:rgba(230,237,245,.65)}
.nav-dd[open] summary{color:var(--text);background:rgba(230,237,245,.65)}
.nav-dd .sub{
  position:absolute;
  top:calc(100% + 10px);
  left:0;
  min-width:260px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  box-shadow:var(--shadow);
  padding:10px;
  display:none;
  gap:6px;
  z-index:80;
}
.nav-dd[open] .sub{display:grid}

/* Fly-out behavior on desktop: show submenu on hover/focus and position to the side */
@media (min-width: 721px){
  .nav-dd:hover .sub,
  .nav-dd:focus-within .sub{
    display:grid;
  }
  .nav-dd .sub{
    top:-6px;
    left:calc(100% + 10px);
  }
}
.nav-dd .sub a{
  padding:10px 10px;
  border-radius:12px;
  color:var(--muted);
  font-weight:650;
  display:block;
}
.nav-dd .sub a:hover{color:var(--text);background:rgba(230,237,245,.65)}

/* Wider dropdown for large menus (e.g., Credit Cards) */
.nav-dd--wide .sub{min-width:520px}
@media (min-width: 721px){
  .nav-dd--wide .sub{grid-template-columns:repeat(2, minmax(0, 1fr))}
}
.nav-dd--wide .sub .subhead{
  grid-column:1 / -1;
  font-size:.78rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--muted);
  padding:10px 10px 4px;
}

@media (max-width: 720px){
  .nav-dd{width:100%}
  .nav-dd .sub{
    position:static;
    min-width:0;
    box-shadow:none;
    border-radius:14px;
    padding:8px;
    display:none;
  }
  .nav-dd[open] .sub{display:grid}
  .nav-dd--wide .sub{grid-template-columns:1fr}
  .nav-dd--wide .sub .subhead{padding:10px 10px 4px}
}

.hero{padding:34px 0 12px}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:26px;align-items:center}
.kicker{color:var(--brand2);font-weight:750;margin:0 0 10px}
h1{font-size:clamp(30px, 3.6vw, 48px);line-height:1.08;margin:0 0 12px;letter-spacing:-.03em}
.lede{margin:0 0 18px;color:var(--muted);max-width:52ch}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin:0 0 16px}
.hero-search{margin:14px 0 14px;max-width:640px}
.search-form{
  display:flex;gap:10px;align-items:center;
  background:#fff;border:1px solid var(--line);
  border-radius:18px;padding:10px;
  box-shadow:var(--shadow);
}
.search-form input{
  width:100%;
  border:0;
  outline:0;
  font-size:16px;
  padding:10px 10px;
  background:transparent;
  color:var(--text);
}
.search-form input::placeholder{color:rgba(51,69,88,.65)}
.search-form .search-btn{
  border:1px solid transparent;
  border-radius:14px;
  padding:10px 12px;
  font-weight:900;
  color:#fff;
  background:linear-gradient(180deg, var(--brand2), var(--brand));
  cursor:pointer;
  white-space:nowrap;
}

.search-grid{display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:14px}
@media (max-width: 720px){.search-grid{grid-template-columns:1fr}}
.search-card{
  display:block;
  border:1px solid var(--line);
  border-radius:18px;
  background:#fff;
  box-shadow:var(--shadow);
  padding:14px 14px 12px;
  color:inherit;
  text-decoration:none;
}
.search-card:hover{background:rgba(246,249,252,.65)}
.search-card__kicker{font-size:12px;font-weight:900;color:var(--brand);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}
.search-card__title{margin:0 0 6px;font-size:1.05rem;line-height:1.2}
.search-card__desc{margin:0;color:var(--muted)}


/* Blog grid (Learn & Grow) */
.blog-cats{display:flex;flex-wrap:wrap;gap:10px;margin:14px 0 16px}
.blog-cats--hero{margin:14px 0 0}
.cat-btn{
  border:1px solid var(--line);
  background:#fff;
  border-radius:999px;
  padding:12px 14px;
  font-weight:900;
  letter-spacing:-.01em;
  font-size:clamp(15px, 1.6vw, 18px);
  color:var(--text);
  cursor:pointer;
  box-shadow:var(--shadow);
}
.cat-btn:hover{background:rgba(246,249,252,.85)}
.cat-btn.is-active{
  border-color:rgba(17,115,184,.35);
  background:linear-gradient(180deg, rgba(17,115,184,.18), rgba(11,74,122,.08));
}
.post-empty{
  border:1px dashed var(--line);
  border-radius:18px;
  background:rgba(246,249,252,.65);
  padding:18px;
  color:var(--muted);
  grid-column:1/-1;
}
.post-grid{display:grid;grid-template-columns:repeat(3, minmax(0, 1fr));gap:16px}
@media (max-width: 980px){.post-grid{grid-template-columns:repeat(2, minmax(0, 1fr))}}
@media (max-width: 640px){.post-grid{grid-template-columns:1fr}}
.post-card{
  display:block;
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  background:#fff;
  box-shadow:var(--shadow);
  color:inherit;
  text-decoration:none;
}
.post-card img{width:100%;height:auto;display:block;aspect-ratio:3/2;object-fit:cover}
.post-body{padding:12px 12px 14px}
.post-title{margin:0 0 8px;font-size:1.02rem;line-height:1.25}
.post-excerpt{margin:0;color:var(--muted)}
.pager{display:flex;gap:8px;align-items:center;justify-content:center;flex-wrap:wrap;margin-top:18px}
.pager-btn,.pager-num{
  border:1px solid var(--line);
  background:#fff;
  border-radius:12px;
  padding:10px 12px;
  font-weight:750;
  color:var(--text);
}
.pager-btn:disabled{opacity:.5;cursor:not-allowed}
.pager-num.is-active{background:rgba(230,237,245,.85)}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:16px;padding:12px 14px;font-weight:750;border:1px solid transparent;
}
.btn.primary{background:linear-gradient(180deg, var(--brand2), var(--brand));color:#fff;box-shadow:0 14px 28px rgba(18,106,168,.22)}
.btn.primary:hover{filter:brightness(1.02)}
.btn.ghost{background:#fff;border-color:var(--line);color:var(--text)}
.btn.ghost:hover{background:rgba(246,249,252,.8)}

.pill-row{display:flex;gap:10px;flex-wrap:wrap}
.pill{background:#fff;border:1px solid var(--line);border-radius:999px;padding:7px 10px;font-weight:650;color:var(--muted)}
.pill-link{display:inline-flex;align-items:center;text-decoration:none;color:inherit}
.pill-link:hover{background:rgba(246,249,252,.85);color:var(--text)}
.quick-links-grid{max-height:360px;overflow:auto;padding:2px}

.hero-media{
  border-radius:var(--radius2);
  background:linear-gradient(180deg, rgba(230,237,245,.4), rgba(230,237,245,.15));
  border:1px solid rgba(230,237,245,.85);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.hero-media img{width:100%;height:auto}

.section{padding:34px 0}
.section.alt{background:linear-gradient(180deg, rgba(246,249,252,.35), rgba(246,249,252,.9))}
.section.soft{padding:18px 0 42px}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-bottom:16px}
h2{margin:0;font-size:clamp(20px, 2.2vw, 28px);letter-spacing:-.02em}
.muted{color:var(--muted);margin:6px 0 0}

.card-grid{
  display:grid;grid-template-columns:repeat(12,1fr);gap:14px
}
.card{
  grid-column:span 4;
  background:rgba(255,255,255,.86);
  border:1px solid rgba(230,237,245,.92);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:0 10px 30px rgba(11,18,32,.06);
  transition:transform .15s ease, box-shadow .15s ease;
}
.card-link{display:block;color:inherit;text-decoration:none}
.card-link:focus-visible{outline:3px solid rgba(17,115,184,.35);outline-offset:3px}
.card:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(11,18,32,.10)}
.card img{aspect-ratio:3/2;object-fit:cover}
.card-body{padding:14px 14px 16px}
.card-body h3{margin:0 0 6px;font-size:18px;letter-spacing:-.01em}
.card-body p{margin:0;color:var(--muted)}

.split{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:center}
.list{margin:12px 0 0;padding-left:18px}
.list li{margin:8px 0;color:var(--muted)}
.list a{color:var(--brand);font-weight:750}
.promo{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius2);
  box-shadow:var(--shadow);overflow:hidden
}
.promo img{aspect-ratio:10/7;object-fit:cover}

.article-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.article{
  grid-column:span 4;
  background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;
  box-shadow:0 10px 28px rgba(11,18,32,.06);
}
.article img{aspect-ratio:3/2;object-fit:cover}
.article-body{padding:14px 14px 16px}
.meta{margin:0 0 6px;color:var(--muted);font-weight:650;font-size:13px}
.article h3{margin:0;font-size:18px;letter-spacing:-.01em}

.notice{
  display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:flex-start;
  background:#fff;border:1px solid rgba(230,237,245,.95);
  border-radius:var(--radius2);box-shadow:var(--shadow);
  padding:16px
}
.notice-icon{
  width:42px;height:42px;border-radius:14px;
  background:radial-gradient(80% 80% at 30% 30%, #bfe6ff 0%, #2aa7ff 60%, #0b4a7a 100%);
}
.notice p{margin:6px 0 0;color:var(--muted)}

.site-footer{padding:26px 0 18px;border-top:1px solid rgba(230,237,245,.9);background:#fff}
.footer-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:18px;align-items:start}
.footer-brand{margin:0 0 6px;font-weight:800}
.footer-links{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.footer-links a{color:var(--muted);font-weight:650}
.footer-links a:hover{color:var(--text)}
.footer-bottom{padding-top:12px}
.footer-bottom p{margin:0}

/* Minimal footer */
.footer-mini{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.footer-mini p{margin:0}
.footer-mini__links{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.footer-mini__links a{color:var(--muted);font-weight:650}
.footer-mini__links a:hover{color:var(--text)}

@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr;gap:14px}
  .split{grid-template-columns:1fr}
  .card{grid-column:span 6}
  .article{grid-column:span 6}
}

@media (max-width: 720px){
  /* Mobile: burger icon controls menu */
  .nav-toggle{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    cursor:pointer;
  }

  .nav-menu{display:none}
  .nav-menu.is-open{
    display:flex;
    position:fixed;
    top:72px;
    left:12px;
    right:12px;
    z-index:999;
    flex-direction:column;
    align-items:stretch;
    gap:8px;
    background:#fff;
    border:1px solid var(--line);
    border-radius:18px;
    padding:12px;
    box-shadow:var(--shadow);
    max-height:calc(100vh - 92px);
    overflow:auto;
  }

  .nav-menu a{width:100%;padding:12px 12px}
  .nav-dd{width:100%}
  .nav-dd summary{width:100%;padding:12px 12px}
  .nav-dd .sub{
    position:static;
    top:auto;left:auto;
    min-width:0;
    border:1px solid var(--line);
    border-radius:14px;
    box-shadow:none;
    padding:8px;
    margin:6px 0 0;
  }
  .nav-dd[open] .sub{display:grid}

  .header-row{position:static}
  .card{grid-column:span 12}
  .article{grid-column:span 12}
  .section-head{flex-direction:column;align-items:flex-start}
  .footer-grid{grid-template-columns:1fr}
  .footer-mini{flex-direction:column;align-items:flex-start}
  .footer-mini__links{justify-content:flex-start}
}

/* =========================
   Energize With Crystals additions
   ========================= */
.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  border:1px solid rgba(17,115,184,.26);
  background:linear-gradient(180deg, rgba(17,115,184,.12), rgba(11,74,122,.06));
  border-radius:999px;
  padding:10px 12px;
  font-weight:900;
  color:var(--text);
}

.hero-media{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius2);
  box-shadow:var(--shadow);
  overflow:hidden;
  position:relative;
}
.hero-media__img{width:100%;height:auto}
.hero-media__badge{
  position:absolute;
  left:12px;
  bottom:12px;
  right:12px;
  background:rgba(255,255,255,.86);
  border:1px solid rgba(230,237,245,.9);
  border-radius:999px;
  padding:10px 12px;
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:800;
  color:var(--muted);
  backdrop-filter:saturate(180%) blur(12px);
}
.dot{
  width:10px;height:10px;border-radius:999px;
  background:radial-gradient(70% 70% at 30% 30%, #2aa7ff 0%, var(--brand) 55%, #063457 100%);
  box-shadow:0 10px 16px rgba(11,74,122,.16);
}

.topic-grid{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:16px;
}
.topic-card{
  grid-column:span 4;
  display:block;
  border:1px solid var(--line);
  border-radius:18px;
  background:#fff;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.topic-card img{aspect-ratio: 3 / 2;object-fit:cover}
.topic-card:hover{background:rgba(246,249,252,.75)}
.topic-body{padding:14px 14px 16px}
.topic-body h3{margin:0 0 6px;letter-spacing:-.02em}
.topic-body p{margin:0}
.topic-card--finder{
  border-color:rgba(17,115,184,.35);
  box-shadow:0 18px 50px rgba(11,74,122,.12);
}
@media (max-width: 980px){
  .topic-card{grid-column:span 6}
}
@media (max-width: 640px){
  .topic-card{grid-column:span 12}
}

.finder-preview{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  align-items:stretch;
}
@media (max-width: 980px){
  .finder-preview{grid-template-columns:1fr}
}
.pill-row{display:flex;flex-wrap:wrap;gap:10px}
.pill--drag{
  border:1px solid var(--line);
  background:#fff;
  color:var(--text);
  border-radius:999px;
  padding:10px 12px;
  font-weight:900;
}
.dropbox{
  border:2px dashed rgba(11,74,122,.24);
  background:rgba(214,240,255,.35);
  border-radius:22px;
  padding:16px;
  min-height:110px;
  display:grid;
  gap:6px;
  align-content:center;
}
.dropbox__title{margin:0;font-weight:950;letter-spacing:-.02em}
.dropbox__hint{margin:0;color:var(--muted)}
.preview-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}

.rule{height:1px;background:var(--line);margin:14px 0}
.mini-list{display:grid;gap:10px}
.mini-link{
  display:block;
  padding:10px 10px;
  border-radius:14px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--text);
  font-weight:850;
}
.mini-link:hover{background:rgba(246,249,252,.85)}

.cards--tight{gap:12px}
.card.mini{
  border:1px solid var(--line);
  border-radius:18px;
  background:#fff;
  box-shadow:var(--shadow);
}
.card.mini .card-body{padding:14px}

.finder-grid{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:16px;
  margin-top:14px;
}
.finder-col{grid-column:span 6}
@media (max-width: 980px){
  .finder-col{grid-column:span 12}
}

/* Crystal Finder wizard (Template 2) */
.finder-wizard{margin-top:14px}
.wizard-steps{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:10px;
}
.wizard-step{
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 12px;
  border-radius:18px;
  border:1px solid var(--line);
  background:#fff;
  box-shadow:var(--shadow);
  cursor:pointer;
  user-select:none;
}
.wizard-step:hover{background:rgba(246,249,252,.85)}
.wizard-step.is-active{border-color:rgba(17,115,184,.45);box-shadow:0 18px 50px rgba(11,74,122,.12)}
.wizard-step.is-done{opacity:.92}
.wizard-dot{
  width:36px;height:36px;border-radius:14px;
  display:grid;place-items:center;
  font-weight:950;
  color:#fff;
  background:radial-gradient(80% 80% at 30% 30%, #bfe6ff 0%, #2aa7ff 60%, #0b4a7a 100%);
  box-shadow:0 10px 20px rgba(11,74,122,.16);
  flex:0 0 auto;
}
.wizard-label{margin:0;font-weight:950;letter-spacing:-.02em}
.wizard-hint{margin:2px 0 0;color:var(--muted);font-size:13px}
.wizard-panel{
  margin-top:12px;
  border:1px solid var(--line);
  border-radius:22px;
  background:#fff;
  box-shadow:var(--shadow);
  padding:16px;
}
.wizard-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.vibe-grid{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:10px;
  margin-top:12px;
}
.vibe{
  grid-column:span 4;
  border:1px solid var(--line);
  background:#fff;
  border-radius:999px;
  padding:12px 14px;
  font-weight:950;
  cursor:pointer;
  box-shadow:var(--shadow);
}
.vibe:hover{background:rgba(246,249,252,.85)}
.vibe.is-selected{border-color:rgba(17,115,184,.45);background:rgba(214,240,255,.38)}
@media (max-width: 720px){
  .wizard-steps{grid-template-columns:1fr}
  .vibe{grid-column:span 6}
}
.issue-list{display:flex;flex-wrap:wrap;gap:10px}
.issue{
  border:1px solid var(--line);
  background:#fff;
  border-radius:999px;
  padding:12px 14px;
  font-weight:950;
  cursor:pointer;
  box-shadow:var(--shadow);
  font-size:16px;
}
.issue:hover{background:rgba(246,249,252,.85)}
.issue.is-dragging{opacity:.55}
select{
  border:1px solid var(--line);
  border-radius:14px;
  padding:12px 12px;
  font-size:16px;
  background:#fff;
}

.drop-area{
  border:2px dashed rgba(11,74,122,.24);
  background:rgba(214,240,255,.35);
  border-radius:22px;
  padding:16px;
  min-height:140px;
  display:grid;
  align-content:start;
  gap:6px;
}
.drop-area.is-over{border-color:rgba(17,115,184,.48);background:rgba(214,240,255,.55)}
.drop-title{margin:0;font-weight:950;letter-spacing:-.02em}
.drop-hint{margin:0}
.picked{margin-top:8px}
.picked-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid rgba(17,115,184,.26);
  background:linear-gradient(180deg, rgba(17,115,184,.12), rgba(11,74,122,.06));
  font-weight:950;
  cursor:pointer;
}
.picked-pill span{opacity:.65}
.picked-pill:hover{filter:brightness(1.02)}

.drop-area.is-shake{animation:shake .26s ease-in-out}
@keyframes shake{
  0%,100%{transform:translateX(0)}
  25%{transform:translateX(-6px)}
  50%{transform:translateX(6px)}
  75%{transform:translateX(-4px)}
}

.result-box{
  margin-top:14px;
  border:1px solid var(--line);
  border-radius:22px;
  background:#fff;
  padding:16px;
  box-shadow:var(--shadow);
}
.crystal-list{display:grid;grid-template-columns:repeat(12, 1fr);gap:12px;margin-top:10px}
.crystal-card{
  grid-column:span 6;
  border:1px solid var(--line);
  border-radius:18px;
  background:linear-gradient(180deg, rgba(246,249,252,.8), #fff);
  padding:14px;
}
.crystal-name{margin:0;font-weight:950;letter-spacing:-.02em}
@media (max-width: 720px){
  .crystal-card{grid-column:span 12}
}


/* Cards container (used for blog grids) */
.cards{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:14px
}

/* Medium images for homepage blog grid */
.cards--blog .card img{
  width:100%;
  max-height:240px;
  object-fit:cover
}


/* Crystal benefits TOC */
.aside-sticky{position:sticky;top:86px}
@media (max-width: 980px){.aside-sticky{position:static}}
.toc{display:grid;gap:10px;margin-top:10px}
.toc a{display:block;padding:10px 10px;border-radius:14px;border:1px solid var(--line);background:#fff;color:var(--muted);font-weight:850}
.toc a:hover{background:rgba(246,249,252,.85);color:var(--text)}
