/* onboard.css — Oxford-themed styles for the onboarding tip card + FAQ help slide-over.
 * Scoped under .ob-* class names. No global element overrides. Loaded on the dashboard.
 * Tokens mirror the Oxford design system (navy/oxford/gold/cream, Merriweather + Open Sans).
 */
:root{
  --ob-navy:#1a2744; --ob-oxford:#002147; --ob-gold:#c8a84b; --ob-cream:#faf8f3;
  --ob-white:#ffffff; --ob-text:#2c3e50; --ob-muted:#6c757d; --ob-border:#e8e0d0;
}

/* ───────────────── Tip card ───────────────── */
.ob-tip{
  position:fixed; z-index:99000; bottom:18px; inset-inline-end:18px;
  width:min(360px, calc(100vw - 36px));
  background:var(--ob-white); color:var(--ob-text);
  border:1px solid var(--ob-border); border-inline-start:4px solid var(--ob-gold);
  border-radius:14px; box-shadow:0 10px 30px rgba(26,39,68,.18);
  font-family:'Open Sans','Cairo',sans-serif; direction:rtl; line-height:1.7;
  padding:14px 16px 12px; opacity:0; transform:translateY(14px);
  transition:opacity .25s ease, transform .25s ease;
}
.ob-tip.ob-show{ opacity:1; transform:translateY(0); }
.ob-tip__head{
  display:flex; align-items:center; justify-content:space-between; gap:8px; margin-bottom:6px;
}
.ob-tip__title{
  font-family:'Merriweather',serif; font-weight:700; font-size:14px; color:var(--ob-oxford);
}
.ob-tip__close{
  appearance:none; border:none; background:transparent; cursor:pointer;
  font-size:18px; line-height:1; color:var(--ob-muted); padding:2px 4px; border-radius:6px;
}
.ob-tip__close:hover{ color:var(--ob-oxford); background:#f1ece0; }
.ob-tip__body{ font-size:14px; color:var(--ob-text); }
.ob-tip__body b, .ob-tip__body strong{ color:var(--ob-oxford); }
.ob-tip__foot{
  display:flex; align-items:center; justify-content:space-between; gap:8px;
  margin-top:10px; padding-top:8px; border-top:1px dashed var(--ob-border);
}
.ob-tip__off{
  appearance:none; border:none; background:transparent; cursor:pointer;
  font-size:12px; color:var(--ob-muted); text-decoration:underline; padding:0;
}
.ob-tip__off:hover{ color:var(--ob-oxford); }
.ob-tip__cta{
  background:var(--ob-gold); color:var(--ob-oxford); font-weight:700; text-decoration:none;
  font-size:13px; padding:6px 14px; border-radius:18px; white-space:nowrap;
}

/* ───────────────── FAQ floating button ───────────────── */
.ob-faq-btn{
  position:fixed; z-index:98000; bottom:18px; inset-inline-start:18px;
  display:inline-flex; align-items:center; gap:7px;
  background:linear-gradient(160deg,var(--ob-oxford),var(--ob-navy)); color:#fff;
  border:1px solid rgba(200,168,75,.5); border-radius:26px; cursor:pointer;
  font-family:'Open Sans','Cairo',sans-serif; font-weight:700; font-size:14px;
  padding:11px 18px; box-shadow:0 8px 22px rgba(26,39,68,.28); direction:rtl;
  transition:transform .15s ease, box-shadow .15s ease;
}
.ob-faq-btn:hover{ transform:translateY(-2px); box-shadow:0 12px 28px rgba(26,39,68,.34); }
.ob-faq-btn .ob-faq-btn__icon{ color:var(--ob-gold); font-size:16px; }

/* ───────────────── FAQ slide-over ───────────────── */
.ob-faq-overlay{
  position:fixed; inset:0; z-index:99500; background:rgba(10,14,26,.55);
  opacity:0; pointer-events:none; transition:opacity .25s ease;
}
.ob-faq-overlay.ob-open{ opacity:1; pointer-events:auto; }
.ob-faq-panel{
  position:fixed; top:0; right:0; left:auto; z-index:99600; height:100vh;
  width:min(460px, 92vw); background:var(--ob-cream); direction:rtl;
  font-family:'Open Sans','Cairo',sans-serif; color:var(--ob-text);
  box-shadow:-12px 0 40px rgba(10,14,26,.3);
  transform:translateX(110%); pointer-events:none; transition:transform .28s ease;
  display:flex; flex-direction:column;
}
.ob-faq-panel.ob-open{ transform:translateX(0); pointer-events:auto; }
.ob-faq-panel__head{
  background:linear-gradient(160deg,var(--ob-oxford),var(--ob-navy)); color:#fff;
  padding:18px 20px; flex:0 0 auto;
}
.ob-faq-panel__badge{ color:var(--ob-gold); font-size:12px; font-weight:600; letter-spacing:.5px; }
.ob-faq-panel__title{ font-family:'Merriweather',serif; font-size:20px; margin-top:4px; }
.ob-faq-panel__close{
  position:absolute; top:14px; inset-inline-start:14px; appearance:none; border:none;
  background:rgba(255,255,255,.12); color:#fff; width:34px; height:34px; border-radius:50%;
  cursor:pointer; font-size:18px; line-height:34px; text-align:center;
}
.ob-faq-panel__close:hover{ background:rgba(255,255,255,.22); }
.ob-faq-panel__body{ overflow-y:auto; padding:16px 16px 28px; flex:1 1 auto; }
.ob-faq-item{
  background:var(--ob-white); border:1px solid var(--ob-border); border-radius:12px;
  margin-bottom:10px; overflow:hidden; box-shadow:0 2px 8px rgba(26,39,68,.04);
}
.ob-faq-item summary{
  cursor:pointer; padding:14px 44px 14px 16px; font-weight:700; color:var(--ob-oxford);
  font-size:15px; list-style:none; position:relative;
}
.ob-faq-item summary::-webkit-details-marker{ display:none; }
.ob-faq-item summary::before{
  content:'+'; position:absolute; inset-inline-end:14px; top:13px; width:22px; height:22px;
  background:var(--ob-oxford); color:var(--ob-gold); border-radius:50%; text-align:center;
  line-height:22px; font-size:15px;
}
.ob-faq-item[open] summary::before{ content:'\2212'; }
.ob-faq-item__a{ padding:0 16px 16px; font-size:14px; color:var(--ob-text); line-height:1.8; }
.ob-faq-item__a b, .ob-faq-item__a strong{ color:var(--ob-oxford); }
.ob-faq-item__cta{
  display:inline-block; margin-top:8px; background:var(--ob-gold); color:var(--ob-oxford);
  font-weight:700; text-decoration:none; padding:5px 14px; border-radius:18px; font-size:13px;
}
.ob-faq-panel__foot{
  flex:0 0 auto; padding:14px 16px; border-top:1px solid var(--ob-border); background:var(--ob-cream);
  text-align:center;
}
.ob-faq-panel__wa{
  display:inline-block; background:#25D366; color:#fff; font-weight:700; text-decoration:none;
  padding:10px 22px; border-radius:22px; font-size:14px;
}
.ob-faq-panel__full{ display:block; margin-top:10px; color:var(--ob-oxford); font-size:13px; font-weight:600; text-decoration:none; }

@media (max-width:420px){
  .ob-tip{ inset-inline-end:10px; inset-inline-start:10px; width:auto; bottom:12px; }
  .ob-faq-btn{ bottom:12px; inset-inline-start:12px; padding:10px 15px; font-size:13px; }
}
