/* ============================================================
   Butler — bright gradient mockup design system
   Memory-cheap: CSS gradients + system fonts + emoji glyphs.
   No external fonts, no images, no JS frameworks.
   ============================================================ */
:root{
  --canvas:#FAF7F2;
  --surface:#FFFFFF;
  --ink:#1C1917;
  --ink-2:#6B6258;
  --ink-3:#A39A8D;
  --line:#EFE9E0;
  --line-2:#E4DCD0;
  --shadow-sm:0 1px 3px rgba(70,50,30,.05), 0 4px 14px rgba(70,50,30,.05);
  --shadow:0 2px 8px rgba(70,50,30,.06), 0 18px 40px rgba(70,50,30,.08);
  --radius:22px;
  --radius-sm:14px;

  /* signature gradients per domain */
  --g-catalog:linear-gradient(135deg,#FF7E5F 0%,#FFB457 100%);
  --g-leads:linear-gradient(135deg,#3B9DFF 0%,#22E0D6 100%);
  --g-outreach:linear-gradient(135deg,#9C5BFF 0%,#FF6FD8 100%);
  --g-watch:linear-gradient(135deg,#2BD974 0%,#2BE0C0 100%);
  --g-brand:linear-gradient(135deg,#FF8A4C 0%,#FF5E7E 50%,#A45BFF 100%);
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;
  background:var(--canvas);
  color:var(--ink);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
  position:relative;
  overflow-x:hidden;
}
/* decorative gradient mesh — fixed, blurred, GPU only */
body::before,body::after{
  content:"";position:fixed;border-radius:50%;
  filter:blur(80px);opacity:.30;z-index:0;pointer-events:none;
}
body::before{width:520px;height:520px;top:-180px;right:-120px;
  background:radial-gradient(circle,#FFB457,#FF5E7E 70%);}
body::after{width:460px;height:460px;bottom:-160px;left:-140px;
  background:radial-gradient(circle,#9C5BFF,#22E0D6 70%);}

.wrap{max-width:860px;margin:0 auto;padding:0 18px 80px;position:relative;z-index:1}

/* ---- mockup switcher bar ---- */
.switch{
  position:sticky;top:0;z-index:50;backdrop-filter:saturate(1.4) blur(10px);
  background:rgba(250,247,242,.82);border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:8px;padding:11px 18px;margin-bottom:14px;
}
.switch .seg{display:flex;gap:4px;background:var(--surface);border:1px solid var(--line-2);
  border-radius:12px;padding:4px}
.switch a{font-size:13px;font-weight:600;color:var(--ink-2);text-decoration:none;
  padding:6px 13px;border-radius:9px;transition:.15s}
.switch a.on{background:var(--g-brand);color:#fff;box-shadow:0 4px 12px rgba(255,94,126,.3)}
.switch a:not(.on):hover{background:var(--canvas)}
.switch .tag{margin-left:auto;font-size:11px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:var(--ink-3);
  background:var(--surface);border:1px dashed var(--line-2);padding:4px 10px;border-radius:20px}

/* ---- greeting hero ---- */
.hero{padding:26px 6px 18px}
.hero .sun{font-size:13px;font-weight:600;color:var(--ink-3);letter-spacing:.03em;margin-bottom:6px}
.hero h1{font-size:clamp(28px,5vw,40px);font-weight:800;letter-spacing:-.03em;line-height:1.08}
.hero h1 .grad{background:var(--g-brand);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent}
.hero p{font-size:16px;color:var(--ink-2);margin-top:8px}

/* ---- ask bar ---- */
.ask{display:flex;align-items:center;gap:12px;background:var(--surface);
  border:1px solid var(--line-2);border-radius:18px;padding:15px 18px;margin:16px 6px 8px;
  box-shadow:var(--shadow-sm);cursor:text;transition:.15s}
.ask:hover{box-shadow:var(--shadow);border-color:#D9CFBF}
.ask .ic{width:22px;height:22px;flex:0 0 auto;background:var(--g-brand);border-radius:7px;
  display:grid;place-items:center;color:#fff;font-size:13px}
.ask input{border:0;background:0;outline:0;font-size:15.5px;color:var(--ink);width:100%;
  font-family:inherit}
.ask input::placeholder{color:var(--ink-3)}
.ask .kbd{font-size:11px;color:var(--ink-3);border:1px solid var(--line-2);border-radius:6px;
  padding:3px 7px;font-weight:600;flex:0 0 auto}

/* ---- section label ---- */
.lbl{display:flex;align-items:center;gap:9px;margin:26px 6px 12px;font-size:12.5px;
  font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-3)}
.lbl .dot{width:7px;height:7px;border-radius:50%}
.lbl .n{margin-left:auto;font-weight:700;color:var(--ink-3)}
.lbl.warn{color:#E0651F}

/* ---- harvest cards ---- */
.harvest{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:560px){.harvest{grid-template-columns:1fr}}
.hcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:.18s}
.hcard:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.hcard .glyph{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;
  font-size:23px;margin-bottom:13px;box-shadow:0 6px 16px rgba(0,0,0,.12)}
.hcard .big{font-size:24px;font-weight:800;letter-spacing:-.02em;line-height:1.1}
.hcard .sub{font-size:13.5px;color:var(--ink-2);margin-top:3px}
.hcard .go{display:inline-flex;align-items:center;gap:5px;margin-top:13px;font-size:13px;
  font-weight:700;color:var(--ink);text-decoration:none;border:1px solid var(--line-2);
  background:var(--canvas);padding:7px 13px;border-radius:10px;transition:.15s}
.hcard .go:hover{background:#fff;border-color:#D9CFBF}
.hcard .when{position:absolute;top:18px;right:18px;font-size:11px;color:var(--ink-3)}

/* ---- approval rows ---- */
.appr{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);overflow:hidden}
.arow{display:flex;align-items:center;gap:14px;padding:16px 18px;border-bottom:1px solid var(--line)}
.arow:last-child{border-bottom:0}
.arow .ag{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;font-size:19px;flex:0 0 auto}
.arow .body{flex:1;min-width:0}
.arow .t{font-size:15px;font-weight:700;letter-spacing:-.01em}
.arow .d{font-size:13px;color:var(--ink-2);margin-top:2px}
.arow .btn{flex:0 0 auto;font-size:13px;font-weight:700;color:#fff;text-decoration:none;
  background:var(--g-brand);padding:9px 16px;border-radius:11px;box-shadow:0 5px 14px rgba(255,94,126,.28);
  transition:.15s}
.arow .btn:hover{filter:brightness(1.05);transform:translateY(-1px)}
.arow .btn.ghost{background:var(--canvas);color:var(--ink);border:1px solid var(--line-2);box-shadow:none}

/* ---- recipe gallery ---- */
.recipes{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:720px){.recipes{grid-template-columns:1fr 1fr}}
.recipe{border-radius:var(--radius);padding:18px;color:#fff;position:relative;overflow:hidden;
  min-height:130px;display:flex;flex-direction:column;justify-content:space-between;
  text-decoration:none;box-shadow:var(--shadow);transition:.18s;cursor:pointer}
.recipe:hover{transform:translateY(-4px) scale(1.015)}
.recipe::after{content:"";position:absolute;inset:0;
  background:radial-gradient(120px 80px at 80% 0%,rgba(255,255,255,.35),transparent 70%);
  pointer-events:none}
.recipe .ricon{font-size:30px;filter:drop-shadow(0 3px 8px rgba(0,0,0,.25))}
.recipe .rname{font-size:16.5px;font-weight:800;letter-spacing:-.01em;line-height:1.15}
.recipe .rsub{font-size:12px;opacity:.92;margin-top:3px;font-weight:500}
.recipe.big{grid-column:span 2;min-height:150px}
@media(max-width:720px){.recipe.big{grid-column:span 2}}

/* gradient fills */
.g-catalog{background:var(--g-catalog)} .g-leads{background:var(--g-leads)}
.g-outreach{background:var(--g-outreach)} .g-watch{background:var(--g-watch)}
.g-brand{background:var(--g-brand)}
.soft-catalog{background:linear-gradient(135deg,#FFF1E9,#FFE8D6)}
.soft-leads{background:linear-gradient(135deg,#E8F4FF,#DEF8F6)}
.soft-outreach{background:linear-gradient(135deg,#F3ECFF,#FFEAF8)}
.soft-watch{background:linear-gradient(135deg,#E6FBEF,#E3FBF4)}
.tx-catalog{color:#E0651F}.tx-leads{color:#1E7FD6}.tx-outreach{color:#8A3FE0}.tx-watch{color:#129E63}

/* ---- footer / backstage strip ---- */
.backstage{display:flex;align-items:center;gap:12px;margin-top:30px;padding:16px 18px;
  background:var(--surface);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-sm);
  font-size:13.5px;color:var(--ink-2)}
.backstage .live{width:9px;height:9px;border-radius:50%;background:#2BD974;
  box-shadow:0 0 0 4px rgba(43,217,116,.18);flex:0 0 auto}
.backstage .bar{flex:1;height:6px;border-radius:3px;background:var(--canvas);overflow:hidden;max-width:120px}
.backstage .bar span{display:block;height:100%;width:62%;background:var(--g-catalog);
  border-radius:3px;animation:shimmer 1.6s linear infinite;
  background-size:200% 100%}
@keyframes shimmer{to{background-position:-200% 0}}
.backstage a{margin-left:auto;color:var(--ink);font-weight:700;text-decoration:none;flex:0 0 auto}
.backstage a:hover{text-decoration:underline}

/* ---- pills, misc ---- */
.pill{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px}
.pill.run{background:#FFF1E9;color:#E0651F}
.pill.ok{background:#E6FBEF;color:#129E63}
.note{text-align:center;font-size:12px;color:var(--ink-3);margin-top:28px;line-height:1.6}

/* launcher-specific big hero recipes */
.lgrid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.lgrid{grid-template-columns:1fr}}
.lcard{border-radius:var(--radius);padding:24px;color:#fff;position:relative;overflow:hidden;
  min-height:180px;display:flex;flex-direction:column;justify-content:space-between;
  text-decoration:none;box-shadow:var(--shadow);transition:.18s}
.lcard:hover{transform:translateY(-5px)}
.lcard::after{content:"";position:absolute;inset:0;
  background:radial-gradient(160px 110px at 85% 5%,rgba(255,255,255,.4),transparent 70%)}
.lcard .ricon{font-size:40px;filter:drop-shadow(0 4px 10px rgba(0,0,0,.25))}
.lcard .rname{font-size:21px;font-weight:800;letter-spacing:-.02em}
.lcard .rsub{font-size:13.5px;opacity:.94;margin-top:5px;max-width:90%}

/* inbox-specific */
.inbox-big{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:hidden;margin-top:4px}
.ibrow{display:flex;gap:15px;padding:20px;border-bottom:1px solid var(--line);align-items:flex-start}
.ibrow:last-child{border-bottom:0}
.ibrow .ag{width:44px;height:44px;border-radius:13px;display:grid;place-items:center;font-size:21px;flex:0 0 auto}
.ibrow .t{font-size:16px;font-weight:800;letter-spacing:-.01em}
.ibrow .preview{font-size:13.5px;color:var(--ink-2);margin-top:6px;
  background:var(--canvas);border:1px solid var(--line);border-radius:12px;padding:12px 14px;line-height:1.55}
.ibrow .acts{display:flex;gap:8px;margin-top:12px}
.fab{position:fixed;right:22px;bottom:22px;width:58px;height:58px;border-radius:50%;
  background:var(--g-brand);color:#fff;font-size:28px;display:grid;place-items:center;
  box-shadow:0 10px 28px rgba(255,94,126,.4);z-index:40;text-decoration:none}
@media(max-width:720px){.fab{bottom:86px}}

/* ============================================================
   Unified app navigation (top = desktop, bottom = mobile)
   ============================================================ */
.topnav{position:sticky;top:0;z-index:50;backdrop-filter:saturate(1.4) blur(10px);
  background:rgba(250,247,242,.85);border-bottom:1px solid var(--line);
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:6px;
  padding:11px 18px;margin-bottom:6px}
.topnav .brand{justify-self:start;font-weight:800;letter-spacing:-.02em;font-size:15px;
  display:flex;align-items:center;gap:7px;white-space:nowrap}
.topnav .brand .logo{width:24px;height:24px;border-radius:7px;background:var(--g-brand);
  display:grid;place-items:center;color:#fff;font-size:13px}
.topnav .links{display:flex;gap:3px;justify-self:center}
.topnav .links a{font-size:13.5px;font-weight:600;color:var(--ink-2);text-decoration:none;
  padding:7px 13px;border-radius:10px;transition:.15s;display:flex;align-items:center;gap:6px;white-space:nowrap}
.topnav .links a.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm);
  border:1px solid var(--line-2)}
.topnav .links a:not(.on):hover{background:var(--canvas)}
.topnav .tag{justify-self:end;font-size:10.5px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:var(--ink-3);background:var(--surface);
  border:1px dashed var(--line-2);padding:4px 9px;border-radius:20px;white-space:nowrap}
@media(max-width:720px){.topnav .links{display:none}}

.botnav{position:fixed;left:0;right:0;bottom:0;z-index:50;display:none;
  grid-template-columns:repeat(5,1fr);gap:2px;
  padding:8px 6px calc(8px + env(safe-area-inset-bottom));
  background:rgba(255,255,255,.93);backdrop-filter:blur(12px);border-top:1px solid var(--line)}
.botnav a{display:flex;flex-direction:column;align-items:center;gap:3px;text-decoration:none;
  font-size:10.5px;font-weight:600;color:var(--ink-3);padding:4px 2px;border-radius:10px}
.botnav a .bi{font-size:20px;line-height:1}
.botnav a.on{color:var(--ink)}
@media(max-width:720px){.botnav{display:grid}body{padding-bottom:74px}}

.see-all{margin-left:auto;font-size:12px;font-weight:700;color:var(--ink);text-decoration:none}
.see-all:hover{text-decoration:underline}
