:root{
  --ink:#0E1B2C;--ink-soft:#1A2C44;--paper:#FBF9F4;--paper-dim:#F1EDE3;
  --brass:#C9A24B;--brass-deep:#A8842F;--blue:#2D5BFF;--muted:#5B6B80;
  --line:rgba(14,27,44,.12);--radius:18px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
/* warm paper with faint ruled-manuscript lines (ported from the original hero).
   `html body` raises specificity so it wins over each page's inlined `body{background}`. */
html body{
  background:
    repeating-linear-gradient(to bottom, transparent 0, transparent 31px, rgba(14,27,44,.045) 31px, rgba(14,27,44,.045) 32px),
    var(--paper);}
.page-head,.hero{position:relative}
h1,h2,h3,.serif{font-family:'Fraunces',serif}
.hand{font-family:'Caveat',cursive}
a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:var(--brass-deep);display:flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:28px;height:1px;background:var(--brass)}
section{padding:96px 0}
@media(max-width:760px){section{padding:64px 0}}

nav{position:fixed;top:0;left:0;right:0;z-index:50;backdrop-filter:blur(14px);background:rgba(251,249,244,.82);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:68px}
.logo{font-family:'Fraunces',serif;font-weight:700;font-size:20px;display:flex;align-items:center;gap:9px}
.logo .seal{width:30px;height:30px;border-radius:50%;background:var(--ink);color:var(--brass);display:grid;place-items:center;font-family:'Caveat',cursive;font-size:18px;line-height:1}
.nav-links{display:flex;gap:28px;font-size:14px;font-weight:500;color:var(--muted)}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 26px;border-radius:999px;font-weight:600;font-size:15px;border:none;cursor:pointer;transition:transform .25s,box-shadow .25s;font-family:'Inter',sans-serif}
.btn:active{transform:scale(.97)}
.btn-ink{background:var(--ink);color:var(--paper)}
.btn-ink:hover{box-shadow:0 10px 28px rgba(14,27,44,.28);transform:translateY(-2px)}
.btn-brass{background:var(--brass);color:var(--ink)}
.btn-brass:hover{box-shadow:0 10px 26px rgba(201,162,75,.45);transform:translateY(-2px)}
.btn-ghost{background:transparent;border:1.5px solid var(--line);color:var(--ink)}
.nav-cta{padding:10px 20px;font-size:14px}
.burger{display:none;background:none;border:none;cursor:pointer;width:40px;height:40px}
.burger span{display:block;width:22px;height:2px;background:var(--ink);margin:5px auto;transition:.3s}
@media(max-width:920px){
  .nav-links{position:fixed;inset:68px 0 auto 0;background:var(--paper);flex-direction:column;padding:24px;gap:18px;border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .35s;box-shadow:0 20px 40px rgba(14,27,44,.08)}
  .nav-links.open{transform:translateY(0)}
  .burger{display:block}
  .nav-cta{display:none}
}

/* page hero band */
.page-head{padding:150px 0 70px}
@media(max-width:760px){.page-head{padding:120px 0 50px}}
.page-head h1{font-size:clamp(34px,4.8vw,56px);font-weight:600;line-height:1.08;margin-top:14px;letter-spacing:-.01em}
.page-head p.lede{margin-top:18px;font-size:17px;color:var(--muted);max-width:560px}

/* forms */
.field{margin-bottom:14px}
.field label{display:block;font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.field select,.field input,.field textarea{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:12px;background:var(--paper);font:inherit;font-size:15px;color:var(--ink)}
.field select{appearance:none}
.field select:focus,.field input:focus,.field textarea:focus{outline:2px solid var(--brass);outline-offset:1px;border-color:transparent}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:560px){.row2{grid-template-columns:1fr}}

/* cards */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px}

/* footer */
footer{background:var(--ink);color:rgba(251,249,244,.6);padding:56px 0 36px;font-size:13.5px}
.f-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:32px;margin-bottom:40px}
@media(max-width:980px){.f-grid{grid-template-columns:1fr 1fr 1fr}}
@media(max-width:640px){.f-grid{grid-template-columns:1fr 1fr}}
footer h4{color:var(--paper);font-size:13px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px;font-family:'Inter',sans-serif}
footer a{display:block;margin-bottom:9px}
footer a:hover{color:var(--brass)}
.f-bottom{border-top:1px solid rgba(251,249,244,.12);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}

.reveal{opacity:0;transform:translateY(34px)}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}

/* ═══════════ AI chatbot widget (left side) ═══════════ */
#sphbot-launch{position:fixed;left:22px;bottom:22px;z-index:80;display:flex;align-items:center;gap:10px;
  background:var(--ink);color:var(--paper);border:none;cursor:pointer;border-radius:999px;padding:13px 20px 13px 16px;
  font-family:'Inter',sans-serif;font-weight:600;font-size:14.5px;box-shadow:0 12px 32px rgba(14,27,44,.32);transition:transform .25s,box-shadow .25s}
#sphbot-launch:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(14,27,44,.4)}
#sphbot-launch .seal{width:28px;height:28px;border-radius:50%;background:var(--brass);color:var(--ink);display:grid;place-items:center;font-family:'Caveat',cursive;font-size:17px}
#sphbot-launch.hide{display:none}
#sphbot{position:fixed;left:22px;bottom:22px;z-index:81;width:min(380px,calc(100vw - 32px));height:min(560px,calc(100vh - 44px));
  background:var(--paper);border:1px solid var(--line);border-radius:20px;box-shadow:0 24px 70px rgba(14,27,44,.34);
  display:none;flex-direction:column;overflow:hidden}
#sphbot.open{display:flex}
.sphbot-head{background:var(--ink);color:var(--paper);padding:16px 18px;display:flex;align-items:center;gap:12px}
.sphbot-head .seal{width:34px;height:34px;border-radius:50%;background:var(--brass);color:var(--ink);display:grid;place-items:center;font-family:'Caveat',cursive;font-size:19px;flex-shrink:0}
.sphbot-head .ttl{flex:1;line-height:1.25}
.sphbot-head .ttl b{font-family:'Fraunces',serif;font-size:16px;display:block}
.sphbot-head .ttl span{font-size:11.5px;color:rgba(251,249,244,.65)}
.sphbot-head .ttl span::before{content:"";display:inline-block;width:7px;height:7px;border-radius:50%;background:#3ECf8E;margin-right:6px;vertical-align:middle}
.sphbot-x{background:none;border:none;color:rgba(251,249,244,.7);font-size:22px;cursor:pointer;line-height:1;padding:2px 6px}
.sphbot-x:hover{color:#fff}
.sphbot-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;background:linear-gradient(rgba(241,237,227,.5),rgba(241,237,227,.5)),var(--paper)}
.sphbot-msg{max-width:84%;padding:10px 13px;border-radius:14px;font-size:14px;line-height:1.5;white-space:pre-wrap;word-wrap:break-word}
.sphbot-msg.bot{align-self:flex-start;background:#fff;border:1px solid var(--line);border-bottom-left-radius:4px;color:var(--ink)}
.sphbot-msg.me{align-self:flex-end;background:var(--ink);color:var(--paper);border-bottom-right-radius:4px}
.sphbot-msg.bot a{color:var(--brass-deep);text-decoration:underline}
.sphbot-typing{align-self:flex-start;display:flex;gap:4px;padding:12px 14px;background:#fff;border:1px solid var(--line);border-radius:14px}
.sphbot-typing i{width:7px;height:7px;border-radius:50%;background:var(--muted);animation:sphbob 1s infinite}
.sphbot-typing i:nth-child(2){animation-delay:.15s}.sphbot-typing i:nth-child(3){animation-delay:.3s}
@keyframes sphbob{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}
.sphbot-chips{display:flex;flex-wrap:wrap;gap:7px;padding:0 16px 10px}
.sphbot-chips button{background:#fff;border:1.5px solid var(--line);border-radius:999px;padding:7px 13px;font:inherit;font-size:12.5px;color:var(--ink-soft);cursor:pointer;transition:border-color .2s,color .2s}
.sphbot-chips button:hover{border-color:var(--brass);color:var(--ink)}
.sphbot-foot{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line);background:var(--paper)}
.sphbot-foot input{flex:1;padding:11px 14px;border:1.5px solid var(--line);border-radius:999px;font:inherit;font-size:14px;background:#fff;color:var(--ink)}
.sphbot-foot input:focus{outline:2px solid var(--brass);outline-offset:1px;border-color:transparent}
.sphbot-foot button{background:var(--ink);color:var(--paper);border:none;border-radius:50%;width:42px;height:42px;cursor:pointer;font-size:17px;flex-shrink:0}
@media(max-width:760px){#sphbot{left:0;right:0;bottom:0;width:100vw;height:78vh;border-radius:18px 18px 0 0}#sphbot-launch{left:16px;font-size:13.5px;padding:11px 16px 11px 14px}}
/* on the order page the launcher sits above the sticky price/Next bar so it never overlaps it */
#sphbot-launch.lift{bottom:88px}
@media(max-width:560px){#sphbot-launch.lift{bottom:80px}}

/* ═══════════ premium polish: keep header CTAs visible + add hover feedback ═══════════ */
/* higher specificity (nav .nav-cta) beats each page's inlined `.nav-cta{display:none}` */
@media(max-width:920px){
  nav .nav-cta{display:inline-flex !important;padding:9px 14px;font-size:13px;white-space:nowrap}
  nav .nav-ava{display:inline-flex !important}
  nav .logo{font-size:17px}
  nav .logo .seal{width:26px;height:26px}
}
@media(max-width:520px){
  nav .nav-cta{padding:8px 11px;font-size:12px}
  nav .logo{font-size:15.5px}
  nav .nav-in{gap:6px}
  nav .nav-ava{display:none !important}          /* drop the avatar chip first, keep both buttons */
}
.btn{transition:transform .18s var(--ease,ease),box-shadow .22s,background-color .2s,opacity .2s}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0) scale(.97)}
.btn-ghost:hover{background:var(--paper-dim);border-color:var(--brass)}
.svc:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(14,27,44,.12);border-color:var(--brass)}
/* review cards get a border-glow hover so the section no longer feels flat */
.q{transition:border-color .22s,transform .22s,box-shadow .22s}
.q:hover{border-color:rgba(201,162,75,.6);transform:translateY(-3px);box-shadow:0 16px 36px rgba(0,0,0,.22)}

/* writer-assignment picker inside the order view (admin) */
.ov-assign-pop{position:fixed;inset:0;background:rgba(14,27,44,.45);z-index:90;display:flex;align-items:center;justify-content:center;padding:18px}
.ov-assign-pop .box{background:var(--paper);border-radius:16px;padding:22px;width:100%;max-width:380px;box-shadow:0 24px 60px rgba(14,27,44,.3)}
.ov-assign-pop h4{font-family:'Fraunces',serif;font-size:18px;margin-bottom:14px}
.ov-assign-pop select{width:100%;padding:11px 13px;border:1.5px solid var(--line);border-radius:10px;font:inherit;font-size:14px;background:#fff;margin-bottom:16px}
.ov-assign-pop .acts{display:flex;gap:10px;justify-content:flex-end}

/* ───────── platform additions ───────── */
html{scroll-padding-top:84px} /* anchors land below the fixed nav */
.nav-ava{width:38px;height:38px;border-radius:50%;background:var(--ink);color:var(--brass);display:grid;place-items:center;font-weight:700;font-size:13px;letter-spacing:.02em}
.nav-ava:hover{box-shadow:0 6px 16px rgba(14,27,44,.3)}

/* footer extras */
.f-contact{margin-top:16px;font-size:13.5px}
.f-contact a,.f-contact span{display:block;margin-bottom:6px}
.f-contact a:hover{color:var(--brass)}
.badge-row{display:flex;gap:14px;flex-wrap:wrap;margin:6px 0 22px;color:rgba(251,249,244,.75)}
.tbadge{width:118px;height:40px;flex-shrink:0}
.f-disclaimer{font-size:12px;color:rgba(251,249,244,.45);max-width:860px;margin-bottom:22px;line-height:1.55}

/* status pills (shared) */
.pill{font-size:11px;font-weight:700;padding:5px 12px;border-radius:999px;white-space:nowrap;display:inline-block}
.pill.brass{background:rgba(201,162,75,.16);color:var(--brass-deep)}
.pill.amber{background:rgba(176,122,18,.13);color:#B07A12}
.pill.green{background:rgba(31,138,76,.12);color:#1F8A4C}
.pill.blue{background:rgba(45,91,255,.1);color:var(--blue)}
.pill.red{background:rgba(199,58,58,.12);color:#C73A3A}
.pill.muted{background:rgba(91,107,128,.12);color:var(--muted)}

/* auth */
.auth-wrap{max-width:440px;margin:0 auto;padding:130px 20px 90px}
.auth-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:34px;box-shadow:0 24px 60px rgba(14,27,44,.08);position:relative}
.auth-card::before{content:"";position:absolute;inset:9px;border:1px dashed rgba(201,162,75,.45);border-radius:15px;pointer-events:none}
.auth-card h1{font-size:26px;margin-bottom:6px}
.auth-card .sub{font-size:14px;color:var(--muted);margin-bottom:22px}
.auth-tabs{display:flex;border:1px solid var(--line);border-radius:999px;overflow:hidden;margin-bottom:22px;background:var(--paper)}
.auth-tabs button{flex:1;padding:11px;border:none;background:none;font:inherit;font-size:13.5px;font-weight:600;color:var(--muted);cursor:pointer}
.auth-tabs button.active{background:var(--ink);color:var(--paper)}
.auth-msg{font-size:13px;border-radius:10px;padding:11px 14px;margin-bottom:14px;display:none}
.auth-msg.err{display:block;background:rgba(199,58,58,.08);color:#C73A3A}
.auth-msg.ok{display:block;background:rgba(31,138,76,.1);color:#1F8A4C}
.divider{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:12px;margin:18px 0}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--line)}
.btn-google{width:100%;background:#fff;border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center;gap:10px}
.btn-google:hover{border-color:var(--brass)}
.auth-foot{text-align:center;font-size:13px;color:var(--muted);margin-top:18px}
.auth-foot a{color:var(--brass-deep);font-weight:600}

/* blog */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:980px){.post-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.post-grid{grid-template-columns:1fr}}
.post-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s}
.post-card:hover{transform:translateY(-5px);box-shadow:0 18px 40px rgba(14,27,44,.1)}
.post-card .tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.post-card .tags span{font-size:11px;background:var(--paper);border:1px solid var(--line);padding:4px 10px;border-radius:999px;color:var(--brass-deep);font-weight:600}
.post-card h3{font-size:19px;line-height:1.3;margin-bottom:10px}
.post-card p{font-size:14px;color:var(--muted);flex:1}
.post-card .meta{font-size:12.5px;color:var(--muted);margin-top:16px;padding-top:14px;border-top:1px dashed var(--line)}

/* article typography — true WYSIWYG rendering of admin editor content */
.article{max-width:720px;margin:0 auto;font-size:17px;line-height:1.75;color:var(--ink-soft)}
.article>*+*{margin-top:1.15em}
.article h1,.article h2,.article h3,.article h4,.article h5,.article h6{font-family:'Fraunces',serif;color:var(--ink);line-height:1.25;margin-top:1.7em}
.article h1{font-size:34px}.article h2{font-size:27px}.article h3{font-size:22px}
.article h4{font-size:19px}.article h5{font-size:17px}.article h6{font-size:15px;letter-spacing:.04em;text-transform:uppercase}
.article p{margin-top:1.15em}
.article a{color:var(--blue);text-decoration:underline;text-underline-offset:3px}
.article ul,.article ol{padding-left:1.5em;margin-top:1.15em}
.article li{margin-top:.5em}
.article blockquote{border-left:3px solid var(--brass);padding:6px 0 6px 22px;font-family:'Fraunces',serif;font-size:1.1em;color:var(--ink);font-style:italic}
.article img{max-width:100%;border-radius:14px;display:block;margin:1.4em auto}
.article figcaption{text-align:center;font-size:13px;color:var(--muted);margin-top:.5em}
.article table{width:100%;border-collapse:collapse;font-size:15px;margin-top:1.2em}
.article th,.article td{border:1px solid var(--line);padding:10px 14px;text-align:left}
.article th{background:var(--paper-dim);font-weight:600}
.article hr{border:none;border-top:1px dashed var(--line);margin:2em 0}
.article pre,.article code{background:var(--paper-dim);border-radius:8px;font-size:.9em}
.article pre{padding:16px;overflow-x:auto}
.article code{padding:2px 6px}
.article .callout{background:#fff;border:1px solid var(--line);border-left:4px solid var(--brass);border-radius:12px;padding:18px 22px;font-size:15.5px}
@media(max-width:620px){.article{font-size:16px}.article h1{font-size:28px}.article h2{font-size:23px}.article h3{font-size:19px}}
