/* ===== Watchful Sentinel — site styles ===== */

/* Color system */
:root{
  --primary:#0b2142;
  --primary-2:#0f2750;
  --accent:#dff6ff;
  --surface:#ffffff;
  --muted:#6b7280;
  --border:#e5e7eb;
  --text:#111827;
  --bg:#f5f7fb;
  --card:#f8fafc;
}

/* Reset */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
img{max-width:100%;display:block}

/* Base typography */
body{
  font:16px/1.55 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,"Helvetica Neue",Arial,"Noto Sans","Apple Color Emoji","Segoe UI Emoji";
  color:var(--text);
  background:var(--bg);
}
h1,h2,h3{color:var(--primary);margin:0 0 .5rem}
h1{font-size:clamp(28px,4vw,44px);line-height:1.15}
h2{font-size:clamp(22px,3vw,30px)}
h3{font-size:clamp(18px,2.2vw,22px)}
p{margin:.5rem 0}
.small{font-size:.9rem;color:var(--muted)}
.sub{color:#2c3c56}

/* Layout helpers */
.wrap{max-width:1100px;margin:0 auto;padding:0 20px}
.grid{display:grid;gap:24px;grid-template-columns:1.2fr .8fr}
.grid-2{display:grid;gap:24px;grid-template-columns:1fr 1fr}
.cards{display:grid;gap:16px;grid-template-columns:repeat(3,minmax(0,1fr))}
@media (max-width:900px){
  .grid,.grid-2,.cards{grid-template-columns:1fr}
}

/* Header / nav */
header{
  background:var(--surface);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:50;
}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:10px}
.brand a{color:var(--primary);font-weight:700;text-decoration:none}
.badge{
  width:32px;height:32px;border-radius:10px;
  background:#f3f4f6;color:#374151;display:grid;place-items:center;font-weight:700
}
.links a{
  color:var(--primary);text-decoration:none;margin-left:18px;font-weight:600
}
.links a.btn{margin-left:24px}

/* Hero */
.hero{
  background:linear-gradient(180deg,#ffffff,#f1f6ff);
  padding:48px 0;
}
.kicker{letter-spacing:.06em;color:#8aa7d6;font-weight:700;text-transform:uppercase;margin-bottom:8px}
.lead{font-size:1.05rem;color:#223655}

/* Buttons */
.btn{
  display:inline-block;text-align:center;padding:10px 14px;border-radius:10px;
  text-decoration:none;border:1px solid transparent;font-weight:700
}
.btn.primary{background:#512da8;color:#fff}
.btn.ghost{background:#fff;border-color:var(--border);color:#111827}
.btn:focus,.btn:hover{filter:brightness(.97)}

/* Side card + tick list */
.hero-card{
  background:#fff;border:1px solid var(--border);border-radius:14px;padding:16px;
  box-shadow:0 8px 24px rgba(0,0,0,.06)
}
.hero-list{list-style:none;padding-left:0;margin:0}
.hero-list li{display:flex;align-items:flex-start;gap:10px;margin:.4rem 0}
.tick{
  display:inline-grid;place-items:center;min-width:22px;height:22px;border-radius:999px;
  background:var(--accent);color:var(--primary);font-weight:900
}

/* Stripe section */
.stripe{
  background:var(--primary);color:#e7eefb;padding:40px 0;margin:40px 0
}
.stripe .wrap{color:#e7eefb}
.stripe a.btn.ghost{color:#1b1b1b;background:#e7eefb;border-color:#d6e5ff}

/* Program cards */
.card{
  background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px;
  box-shadow:0 6px 18px rgba(0,0,0,.04)
}
.eyebrow{font-size:.85rem;color:#6b7ea2;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}

/* Pricing */
.pricing{display:grid;gap:16px;grid-template-columns:repeat(3,minmax(0,1fr))}
.price{background:#fff;border:1px solid var(--border);border-radius:12px;padding:16px}
.price .tag{
  display:inline-block;margin:.25rem 0 .5rem;padding:2px 8px;border-radius:9999px;
  background:#eef2ff;color:#3730a3;font-size:.85rem;font-weight:700
}
@media (max-width:900px){.pricing{grid-template-columns:1fr}}

/* Sections */
section{padding:28px 0}

/* Footer */
footer{
  background:#0a1a36;color:#d7e2ff;margin-top:40px;border-top:1px solid #0b2142
}
.foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 20px}
footer .btn{background:#132a56;color:#fff;border-color:#243b6d}

/* Contact form */
form label{display:block;margin:6px 0}
input,textarea{
  width:100%;padding:10px 12px;border-radius:10px;border:1px solid var(--border);
  background:#fff;color:var(--text)
}
textarea{min-height:120px;resize:vertical}
.cta{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}

/* Accessibility */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{
  outline:3px solid #94c6ff;outline-offset:2px
}

/* ===== Loretta bubble + panel ===== */

#loretta{position:fixed;right:20px;bottom:20px;z-index:9999}

/* Bubble uses her photo */
#loretta-bubble{
  width:64px;height:64px;border-radius:9999px;border:0;cursor:pointer;
  box-shadow:0 6px 18px rgba(0,0,0,.18);
  background:#512da8;               /* fallback */
  background-image:url("loretta-avatar.jpg");
  background-size:cover;
  background-position:center;
  color:transparent;                /* hide “L” */
}
#loretta-bubble::before{content:""}

#loretta-panel{
  position:fixed;right:20px;bottom:96px;width:320px;
  max-width:calc(100vw - 40px);
  background:#fff;border:1px solid #e5e7eb;border-radius:14px;overflow:hidden;
  box-shadow:0 12px 32px rgba(0,0,0,.18)
}
#loretta-panel .lp-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 12px;background:#f8fafc;border-bottom:1px solid #e5e7eb
}
#loretta-close{background:transparent;border:0;font-size:22px;cursor:pointer}
#loretta-panel .btn-row{display:grid;gap:8px;padding:0 12px 12px}
.btn{display:inline-block;text-align:center;padding:10px 12px;border-radius:10px;text-decoration:none}
.btn.primary{background:#512da8;color:#fff}
.btn.ghost{border:1px solid #cbd5e1;color:#111827}

/* Tiny round avatar in header */
.lp-avatar{
  width:28px;height:28px;border-radius:9999px;object-fit:cover;
  border:1px solid #e5e7eb
}
