/* Aikuto Stream Pro - v3.2.2 */

/* --------------------
   Variables
-------------------- */
:root{
  --sp-accent: #8b5e34;
  --sp-radius: 18px;

  --sp-ink: #0f172a;
  --sp-muted: #64748b;
  --sp-line: rgba(15,23,42,.12);

  --sp-bg-overlay: .12;
  --sp-bg-image: none;
  --sp-bg-size: cover;
  --sp-bg-position: center center;
  --sp-bg-repeat: no-repeat;
  --sp-bg-attachment: fixed;

  --sp-paper-url: none;
  --sp-noise-url: none;
  --sp-noise-opacity: .10;

  --sp-hero-h: 280px;
  --sp-hero-w: 1180px;
  --sp-hero-bg: none;
  --sp-hero-bg-color: #111827;
  --sp-hero-overlay: .28;
  --sp-hero-text: #ffffff;

  --sp-font-cjk: system-ui, -apple-system, "PingFang SC", "Hiragino Sans GB", "Microsoft Yahei";
  --sp-font-latin: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial;
  --sp-header-h: 62px;
}

/* --------------------
   Base
-------------------- */
*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  font-size: var(--sp-body-font-size, 16px);
  margin:0;
  color: var(--sp-ink);
  font-family: var(--sp-font-latin), var(--sp-font-cjk);
  background: #f5f4f1;
  position: relative;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-2;
  background-image: var(--sp-bg-image), var(--sp-paper-url), var(--sp-noise-url);
  background-size: var(--sp-bg-size), 680px, 320px;
  background-position: var(--sp-bg-position), center center, center center;
  background-repeat: var(--sp-bg-repeat), repeat, repeat;
  background-attachment: var(--sp-bg-attachment), fixed, fixed;
  opacity: 1;
  pointer-events:none;
}
body::after{
  content:"";
  position:fixed;
  inset:0;
  z-index:-1;
  background: rgba(15,23,42,var(--sp-bg-overlay));
  pointer-events:none;
}
a{ color: inherit; text-decoration:none; }
a:hover{ color: var(--sp-accent); }
img{ max-width:100%; height:auto; }

.sp-main{
  padding: 0 16px 56px;
}

/* --------------------
   Header
-------------------- */
.sp-header{
  position: sticky;
  top: 0;
  z-index: 70;
  height: var(--sp-header-h);
  backdrop-filter: blur(10px);
  background: rgba(245,244,241,.72);
  border-bottom: 1px solid rgba(15,23,42,.10);
}
.sp-header__inner{
  height: var(--sp-header-h);
  max-width: 1180px;
  margin: 0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
  padding: 0 16px;
}
.sp-brand{ display:flex; align-items:center; gap:10px; }
.sp-brand__link{ display:flex; align-items:center; gap:10px; }
.sp-mark{
  width: 34px; height: 34px;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(139,94,52,.22), rgba(15,23,42,.10));
  border: 1px solid rgba(15,23,42,.12);
  box-shadow: 0 18px 44px rgba(2,6,23,.10);
}
.sp-logo-img{
  height: 34px;
  width: auto;
  border-radius: 10px;
  box-shadow: 0 16px 40px rgba(2,6,23,.10);
}
.sp-brand__name{ font-weight: 900; letter-spacing: .02em; }
.sp-brand__tag{ color: var(--sp-muted); font-size: 12px; margin-left: 4px; }

.sp-nav{ display:flex; gap: 10px; align-items:center; }
.sp-nav a{
  padding: 8px 10px;
  border-radius: 999px;
  color: rgba(15,23,42,.92);
  font-weight: 800;
}
.sp-nav a:hover{ background: rgba(15,23,42,.06); }

/* --------------------
   Hero
-------------------- */
.sp-hero{
  position: relative;
  height: var(--sp-hero-h);
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  overflow: hidden;
}
.sp-hero.is-sticky{
  position: sticky;
  top: var(--sp-header-h);
  z-index: 60;
}
.sp-hero__bg{
  position:absolute; inset:0;
  background-color: var(--sp-hero-bg-color);
  background-image: var(--sp-hero-bg);
  background-size: cover;
  background-position:center;
  filter: saturate(1.05) contrast(1.05);
  transform: scale(1.02);
}
.sp-hero__overlay{
  position:absolute; inset:0;
  background: radial-gradient(1400px 520px at 20% 0%, rgba(255,255,255,.06), transparent 55%),
              radial-gradient(900px 420px at 80% 0%, rgba(139,94,52,.14), transparent 60%),
              rgba(0,0,0,var(--sp-hero-overlay));
}
.sp-hero__canvas{
  position:absolute; inset:0;
  width:100%; height:100%;
  opacity: .55;
}
.sp-hero__inner{
  height:100%;
  max-width: var(--sp-hero-w);
  margin: 0 auto;
  padding: 0 16px;
  display:flex;
  align-items: var(--sp-hero-valign, flex-end);
  justify-content: var(--sp-hero-justify, center);
}
.sp-hero__text{
  width: 100%;
  padding-bottom: 22px;
  color: var(--sp-hero-text);
  text-shadow: 0 16px 50px rgba(0,0,0,.42);
  text-align: var(--sp-hero-align, left);
}
.sp-hero__title{
  font-size: clamp(var(--sp-hero-title-min, 20px), 3.4vw, var(--sp-hero-title-max, 34px));
  font-weight: var(--sp-hero-title-weight, 900);
  letter-spacing: .02em;
  line-height: 1.18;
  color: var(--sp-hero-text);
  position: relative;
  z-index: 2;
  font-family: var(--sp-hero-font-latin, var(--sp-font-latin, ui-sans-serif, system-ui, -apple-system, sans-serif)),
               var(--sp-hero-font-cjk, var(--sp-font-cjk, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif));
}

.sp-hero__sub{
  margin-top: 8px;
  font-size: var(--sp-hero-sub-size, 13px);
  font-weight: var(--sp-hero-sub-weight, 700);
  letter-spacing: .12em;
  opacity: .90;
  font-family: var(--sp-hero-font-latin, var(--sp-font-latin, ui-sans-serif, system-ui, -apple-system, sans-serif)),
               var(--sp-hero-font-cjk, var(--sp-font-cjk, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif));
}

/* Typewriter caret */
.sp-hero.is-typing .sp-hero__title:after{
  content:"";
  display:inline-block;
  width: 10px;
  height: 1.1em;
  margin-left: 6px;
  background: rgba(255,255,255,.78);
  transform: translateY(3px);
  animation: sp-blink 1s steps(1,end) infinite;
}
@keyframes sp-blink{ 50%{ opacity:0; } }

/* Cursor effects for hero */
.sp-hero__spot{
  position:absolute; inset:0;
  pointer-events:none;
  opacity: 0;
  transition: opacity .18s ease;
  background: radial-gradient(220px 220px at var(--spot-x, 50%) var(--spot-y, 50%),
              rgba(255,255,255,var(--spot-opacity, .25)),
              transparent 70%);
  mix-blend-mode: overlay;
}
#sp-hero.is-cursor-on .sp-hero__spot{ opacity: 1; }

.sp-hero__trail{
  position:absolute; inset:0;
  pointer-events:none;
  opacity:0;
  transition: opacity .12s ease;
}
.sp-hero__dot{
  position:absolute;
  left: 0; top: 0;
  border-radius: 999px;
  transform: translate(-50%, -50%);
  filter: blur(.1px);
  box-shadow: 0 10px 40px rgba(0,0,0,.12);
}
.sp-hero__textflag{
  position:absolute;
  left:0; top:0;
  font-weight: 900;
  letter-spacing: .08em;
  font-size: 12px;
  pointer-events:none;
  opacity:0;
  transform: translate(0,0);
  white-space: nowrap;
  text-shadow: 0 10px 40px rgba(0,0,0,.24);
}

/* --------------------
   Layout
-------------------- */
.sp-container{
  max-width: 1180px;
  margin: 0 auto;
  padding: 18px 0 0;
}
.sp-pagehead{
  margin: 10px 0 14px;
  padding: 14px 16px;
  border:1px solid var(--sp-line);
  border-radius: calc(var(--sp-radius) + 2px);
  background: rgba(255,255,255,.76);
  box-shadow: 0 18px 60px rgba(2,6,23,.08);
}
.sp-pagehead h1{
  margin:0;
  font-size: 18px;
  font-weight: 900;
}
.sp-pagehead p{
  margin: 6px 0 0;
  color: var(--sp-muted);
}

/* --------------------
   Tabs
-------------------- */
.sp-tabs{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px 10px;
  border:1px solid var(--sp-line);
  border-radius: calc(var(--sp-radius) + 2px);
  background: rgba(255,255,255,.76);
  box-shadow: 0 18px 60px rgba(2,6,23,.08);
}
.sp-tabbtn{
  appearance:none;
  border:none;
  background: transparent;
  padding: 10px 14px;
  border-radius: 999px;
  font-weight: 900;
  cursor:pointer;
  color: rgba(15,23,42,.86);
}
.sp-tabbtn:hover{ background: rgba(15,23,42,.06); }
.sp-tabbtn.is-active{
  background: rgba(139,94,52,.16);
  color: rgba(15,23,42,.96);
  border:1px solid rgba(139,94,52,.22);
}
.sp-tabs__right{
  margin-left:auto;
  display:flex;
  gap: 8px;
  align-items:center;
  font-size: 12px;
  color: var(--sp-muted);
}
.sp-tablink{
  padding: 8px 10px;
  border-radius: 999px;
}
.sp-tablink:hover{ background: rgba(15,23,42,.06); color: rgba(15,23,42,.92); }
.sp-dot-sep{ opacity:.5; }

/* --------------------
   Stream / Timeline
-------------------- */
.sp-stream{
  margin-top: 14px;
  display:flex;
  flex-direction:column;
  gap: 12px;
}
.sp-item{
  position: relative;
  display:grid;
  grid-template-columns: 22px 1fr;
  gap: 10px;
}
.sp-timeline{
  position: relative;
  width: 22px;
  display:flex;
  justify-content:center;
}
.sp-dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--sp-accent);
  border: 2px solid rgba(255,255,255,.92);
  box-shadow: 0 10px 30px rgba(2,6,23,.12);
  margin-top: 20px;
}
.sp-line{
  position:absolute;
  top: 34px;
  bottom: -14px;
  width: 2px;
  background: rgba(15,23,42,.08);
  border-radius: 999px;
}
.sp-stream .sp-item:last-child .sp-line{ display:none; }

.sp-note__card,
.sp-post__card{
  border:1px solid var(--sp-line);
  border-radius: calc(var(--sp-radius) + 2px);
  background: rgba(255,255,255,.80);
  box-shadow: 0 18px 60px rgba(2,6,23,.08);
  padding: 14px 14px 10px;
}

/* Timeline plain mode (no cards) */
.sp-timeline-plain .sp-note__card,
.sp-timeline-plain .sp-post__card{
  background: transparent;
  border: none;
  box-shadow: none;
  padding: 0;
}

.sp-timeline-plain .sp-note__head,
.sp-timeline-plain .sp-post__head{
  padding: 0;
}

.sp-timeline-plain .sp-note__content,
.sp-timeline-plain .sp-post__excerpt{
  margin-top: 8px;
}

.sp-timeline-plain .sp-note__actions{
  margin-top: 10px;
  padding: 0;
  opacity: .92;
  background: transparent;
  border: none;
}

.sp-timeline-plain .sp-item{
  gap: 14px;
}

.sp-timeline-plain .sp-stream{
  gap: 18px;
}

.sp-timeline-plain .sp-dot{
  border-color: rgba(255,255,255,.98);
}

.sp-note__head,
.sp-timeline-plain .sp-post__head{
  padding: 0;
}
.sp-timeline-plain .sp-note__content,
.sp-timeline-plain .sp-post__excerpt{
  margin-top: 8px;
}
.sp-timeline-plain .sp-note__actions{
  margin-top: 10px;
  padding: 0;
  opacity: .9;
}
.sp-timeline-plain .sp-stream{ gap: 22px; }
.sp-timeline-plain .sp-item{ gap: 14px; }
.sp-timeline-plain .sp-dot{ border-color: rgba(255,255,255,.98); }
.sp-note__head,
.sp-post__head{
  display:flex;
  align-items:center;
  gap: 10px;
  color: var(--sp-muted);
  font-size: 12px;
}
.sp-note__time,
.sp-post__time{
  color: var(--sp-muted);
}
.sp-note__time:hover,
.sp-post__time:hover{ color: var(--sp-accent); }

.sp-badge{
  margin-left:auto;
  padding: 4px 8px;
  border-radius: 999px;
  border:1px solid rgba(15,23,42,.12);
  background: rgba(15,23,42,.04);
  color: rgba(15,23,42,.72);
  font-weight: 800;
  font-size: 11px;
}
.sp-badge--pin{
  border-color: rgba(139,94,52,.22);
  background: rgba(139,94,52,.12);
}

.sp-note__content{
  margin-top: 10px;
  line-height: 1.85;
  font-size: 15px;
  letter-spacing: .01em;
}
.sp-note__content p{ margin: 0 0 10px; }
.sp-note__content p:last-child{ margin-bottom: 0; }

/* clamp */
.sp-note__content.is-clamped{
  max-height: var(--sp-clamp-max, 360px);
  overflow: hidden;
  position: relative;
}
.sp-note__content.is-clamped:after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:0;
  height: 86px;
  background: linear-gradient(180deg, rgba(255,255,255,0), rgba(255,255,255,.92) 65%, rgba(255,255,255,.98));
  pointer-events:none;
}
.sp-note__content.is-open{
  max-height: none;
}
.sp-note__content.is-open:after{ display:none; }

.sp-more{
  margin-left:auto;
  border: 1px solid rgba(15,23,42,.12);
  background: rgba(255,255,255,.92);
  border-radius: 999px;
  padding: 7px 12px;
  font-weight: 900;
  cursor:pointer;
}
.sp-more:hover{ border-color: rgba(139,94,52,.40); color: var(--sp-accent); }

.sp-note__actions,
.sp-post__foot{
  margin-top: 10px;
  display:flex;
  gap: 10px;
  align-items:center;
  flex-wrap: wrap;
}
.sp-note__actions--single{ padding-top: 8px; border-top: 1px dashed rgba(15,23,42,.10); }

.sp-action{
  display:inline-flex;
  align-items:center;
  gap: 6px;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.70);
  cursor:pointer;
  font-weight: 800;
  color: rgba(15,23,42,.80);
}
.sp-action:hover{ border-color: rgba(139,94,52,.40); color: rgba(15,23,42,.95); }
.sp-action:disabled{ opacity:.55; cursor:not-allowed; }
.sp-ico{ font-size: 13px; line-height: 1; }
.sp-like.is-liked{ border-color: rgba(139,94,52,.55); background: rgba(139,94,52,.14); }
.sp-like.is-liked .sp-ico{ color: #b91c1c; }

.sp-post__title{
  margin: 10px 0 8px;
  font-size: 17px;
  line-height: 1.35;
  font-weight: 900;
}
.sp-post__title a{ color: rgba(15,23,42,.92); }
.sp-post__excerpt{ color: rgba(15,23,42,.72); font-size: 14px; line-height: 1.75; }
.sp-readmore{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.12);
  background: rgba(255,255,255,.78);
  font-weight: 900;
}
.sp-readmore:hover{ border-color: rgba(139,94,52,.40); }

/* --------------------
   Load More / Pager
-------------------- */
.sp-loadmore{
  margin: 14px auto 0;
  display:block;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.12);
  background: rgba(255,255,255,.86);
  padding: 10px 16px;
  font-weight: 900;
  cursor:pointer;
  box-shadow: 0 18px 60px rgba(2,6,23,.08);
}
.sp-loadmore:hover{ border-color: rgba(139,94,52,.40); color: var(--sp-accent); }
.sp-loadmore:disabled{ opacity:.6; cursor:not-allowed; }

.sp-pager{
  margin: 18px 0 0;
  text-align:center;
}
.sp-pager .page-numbers{
  display:inline-block;
  padding: 8px 10px;
  margin: 0 4px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.78);
}
.sp-pager .page-numbers.current{
  background: rgba(139,94,52,.16);
  border-color: rgba(139,94,52,.22);
}

/* --------------------
   Article
-------------------- */
.sp-article{ padding-top: 14px; }
.sp-article__card{
  border:1px solid var(--sp-line);
  border-radius: calc(var(--sp-radius) + 2px);
  background: rgba(255,255,255,.86);
  box-shadow: 0 18px 60px rgba(2,6,23,.08);
  padding: 18px;
}
.sp-article__head{ margin-bottom: 14px; }
.sp-article__title{
  margin: 0;
  font-size: 22px;
  line-height: 1.22;
  font-weight: 950;
}
.sp-article__meta{
  margin-top: 10px;
  color: var(--sp-muted);
  font-size: 12px;
  display:flex;
  gap:8px;
  flex-wrap: wrap;
  align-items:center;
}
.sp-article__content{
  line-height: 1.9;
  font-size: 15px;
}
.sp-article__content h2,
.sp-article__content h3{
  margin: 26px 0 10px;
  font-weight: 950;
}
.sp-article__content code{
  background: rgba(15,23,42,.06);
  padding: 2px 6px;
  border-radius: 8px;
}
.sp-article__content pre{
  background: rgba(2,6,23,.86);
  color: #fff;
  padding: 14px;
  border-radius: 16px;
  overflow:auto;
}
.sp-article__foot{
  margin-top: 16px;
  padding-top: 12px;
  border-top: 1px dashed rgba(15,23,42,.10);
}
.sp-article__cats a{
  display:inline-block;
  margin-right: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.80);
}

/* --------------------
   Comments
-------------------- */
.sp-comments{ margin-top: 14px; }
.sp-comments__card{
  border:1px solid var(--sp-line);
  border-radius: calc(var(--sp-radius) + 2px);
  background: rgba(255,255,255,.86);
  box-shadow: 0 18px 60px rgba(2,6,23,.08);
  padding: 16px;
}
.sp-comments__title{
  margin:0 0 14px;
  font-size: 16px;
  font-weight: 950;
  display:flex;
  align-items:center;
  gap: 10px;
}
.sp-comments__count{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width: 26px;
  height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  border:1px solid rgba(15,23,42,.12);
  background: rgba(15,23,42,.04);
  font-size: 12px;
}
.sp-commentlist{ margin:0; padding:0; list-style:none; display:flex; flex-direction:column; gap: 12px; }
.sp-commentlist .comment{
  border:1px solid rgba(15,23,42,.10);
  border-radius: 16px;
  background: rgba(255,255,255,.78);
  padding: 12px 12px 10px;
}
.sp-commentlist .comment .comment-body{ margin:0; }
.sp-commentlist .comment .comment-meta{ color: var(--sp-muted); font-size: 12px; }
.sp-commentlist .comment .comment-author{ display:flex; align-items:center; gap: 10px; font-weight: 900; }
.sp-commentlist .comment .avatar{ border-radius: 999px; }
.sp-commentlist .comment .comment-content{ margin-top: 8px; line-height: 1.75; }
.sp-commentlist .comment .reply a{ font-weight: 900; color: rgba(15,23,42,.74); }
.sp-commentlist .comment .reply a:hover{ color: var(--sp-accent); }
.sp-commentform textarea{
  width: 100%;
  border-radius: 16px;
  border: 1px solid rgba(15,23,42,.14);
  padding: 12px;
  background: rgba(255,255,255,.96);
}
.sp-btn,
.sp-commentform input[type="submit"]{
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.12);
  background: rgba(255,255,255,.88);
  padding: 10px 16px;
  font-weight: 950;
  cursor:pointer;
}
.sp-commentform input[type="submit"]:hover{ border-color: rgba(139,94,52,.40); color: var(--sp-accent); }

/* --------------------
   Compose button
-------------------- */
.sp-compose{
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 80;
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.12);
  background: rgba(255,255,255,.88);
  box-shadow: 0 18px 70px rgba(2,6,23,.16);
  font-weight: 950;
}
.sp-compose:hover{ border-color: rgba(139,94,52,.45); color: rgba(15,23,42,.95); }
.sp-compose__dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(139,94,52,.65);
  box-shadow: 0 0 0 6px rgba(139,94,52,.16);
}

/* --------------------
   Footer
-------------------- */
.sp-footer{
  padding: 22px 16px 28px;
  color: rgba(15,23,42,.70);
}
.sp-footer__inner{
  max-width: 1180px;
  margin: 0 auto;
  font-size: 12px;
}

/* --------------------
   Toast
-------------------- */
.sp-toast{
  position: fixed;
  left: 50%;
  bottom: 86px;
  transform: translateX(-50%) translateY(10px);
  opacity: 0;
  z-index: 90;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.12);
  background: rgba(255,255,255,.92);
  box-shadow: 0 18px 70px rgba(2,6,23,.18);
  font-weight: 900;
  transition: opacity .18s ease, transform .18s ease;
}
.sp-toast.is-on{
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* --------------------
   Responsive
-------------------- */
@media (max-width: 900px){
  .sp-header__inner{ padding: 0 14px; }
  .sp-hero__sub{ letter-spacing: .06em; }
  .sp-item{ grid-template-columns: 18px 1fr; }
  .sp-dot{ margin-top: 18px; }
}
@media (max-width: 600px){
  .sp-nav{ gap: 6px; }
  .sp-nav a{ padding: 8px 8px; font-size: 13px; }
  .sp-tabs{ flex-wrap: wrap; }
  .sp-tabs__right{ width:100%; margin-left:0; justify-content:flex-start; }
}



/* --------------------
   Home Classic (v3.0 style)
-------------------- */
.sp-home-grid{
  display:grid;
  grid-template-columns: var(--sp-home-col-left, 1fr) var(--sp-home-col-right, 360px);
  gap: var(--sp-home-gap, 22px);
  align-items:start;
  margin-top: 16px;
  padding-bottom: 40px;
}
.sp-home-grid.sp-home-layout-stack{
  grid-template-columns: 1fr;
}
@media (max-width: 980px){
  .sp-home-grid{ grid-template-columns: 1fr; }
  .sp-home-aside{ order: 2; }
}

.sp-panel{
  background: rgba(255,255,255,.76);
  border:1px solid var(--sp-line);
  border-radius: calc(var(--sp-radius) + 6px);
  box-shadow: 0 18px 60px rgba(2,6,23,.08);
  overflow: hidden;
}

.sp-panel__hd{
  padding: 18px 18px 14px;
  border-bottom: 1px solid var(--sp-line);
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 12px;
}
.sp-panel__hd h1,
.sp-panel__hd h2{
  margin:0;
  font-size: 22px;
  letter-spacing: .02em;
}
.sp-panel__hd p{
  margin: 8px 0 0;
  color: var(--sp-muted);
  font-size: 13px;
}

.sp-panel__bd{
  padding: 14px 14px 16px;
}

.sp-panel__ft{
  margin-top: 14px;
  display:flex;
  justify-content:space-between;
  gap: 10px;
  flex-wrap: wrap;
  align-items:center;
}

.sp-pill{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.12);
  background: rgba(255,255,255,.62);
  color: rgba(15,23,42,.80);
  font-weight: 800;
  font-size: 12px;
  text-decoration:none;
  cursor: default;
}
.sp-pill--link{ cursor: pointer; }
.sp-pill .dot{
  width: 8px; height: 8px; border-radius: 999px;
  background: var(--sp-accent);
  box-shadow: 0 10px 30px rgba(2,6,23,.12);
}

.sp-empty{
  margin: 10px 4px 0;
  color: var(--sp-muted);
  font-size: 14px;
}

.sp-tip{
  margin: 10px 2px 0;
  color: var(--sp-muted);
  font-size: 12px;
}

/* Make posts list look like cards (no timeline) */
.sp-panel--plain .sp-item{
  grid-template-columns: 1fr;
}
.sp-panel--plain .sp-timeline{
  display:none;
}
.sp-panel--plain .sp-post__card{
  padding: 14px 14px 12px;
}

/* Search form inside panel */
.sp-panel--search form.search-form{
  display:flex;
  gap: 10px;
}
.sp-panel--search input.search-field{
  flex:1;
  min-width: 0;
  padding: 12px 14px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.12);
  background: rgba(255,255,255,.92);
  outline: none;
}
.sp-panel--search input.search-field:focus{
  border-color: rgba(139,94,52,.40);
  box-shadow: 0 0 0 6px rgba(139,94,52,.12);
}
.sp-panel--search input.search-submit{
  padding: 12px 16px;
  border-radius: 999px;
  border: 1px solid rgba(139,94,52,.22);
  background: rgba(139,94,52,.12);
  color: rgba(15,23,42,.92);
  font-weight: 900;
  cursor:pointer;
}
.sp-panel--search input.search-submit:hover{
  background: rgba(139,94,52,.18);
}

.sp-sentinel{ height: 1px; }

/* ---------------------------------------------
   Plain timeline style (no cards / no pill buttons)
   --------------------------------------------- */
.sp-timeline-plain .sp-card,
.sp-timeline-plain .sp-post__card,
.sp-timeline-plain .sp-note__card{
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}
.sp-timeline-plain .sp-post__card{ padding: 14px 0; border-bottom: 1px solid rgba(15,23,42,.10) !important; }
.sp-timeline-plain .sp-post__card:last-child{ border-bottom: none !important; }

.sp-timeline-plain .sp-action,
.sp-timeline-plain .sp-readmore,
.sp-timeline-plain .sp-loadmore,
.sp-timeline-plain .sp-pill,
.sp-timeline-plain a.sp-pill{
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
}
.sp-timeline-plain .sp-action:hover,
.sp-timeline-plain .sp-readmore:hover,
.sp-timeline-plain .sp-loadmore:hover,
.sp-timeline-plain a.sp-pill:hover{ text-decoration: underline; }

.sp-timeline-plain .sp-loadmore{ display: inline-flex; font-weight: 900; cursor: pointer; }
.sp-timeline-plain .sp-loadmore--text{ font-size: 14px; }

/* Plain homepage layout */
.sp-container--plainhome{ padding-top: 14px; }
.sp-home-plain{ max-width: 980px; margin: 0 auto; padding: 0 18px 24px; }
.sp-home-plain__search{ margin: 0 0 18px; }
.sp-home-plain__search form.search-form{ display:flex; gap: 10px; align-items: center; }
.sp-home-plain__search input.search-field{
  flex: 1;
  padding: 12px 14px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.14);
  background: rgba(255,255,255,.70);
}
.sp-home-plain__search input.search-submit{
  padding: 12px 16px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.14);
  background: rgba(15,23,42,.06);
  font-weight: 900;
  cursor:pointer;
}
.sp-home-plain__divider{ height: 22px; }

.sp-panel--plain{ background: transparent !important; border: none !important; box-shadow: none !important; }
.sp-panel__hd--plain{ padding: 8px 0 10px; border: none; }
.sp-panel__bd--plain{ padding: 0; }
.sp-panel__ft--plain{ padding: 12px 0 0; }
.sp-panel__hd--plain h1,
.sp-panel__hd--plain h2{ margin: 0 0 4px; }
.sp-panel__hd--plain p{ margin: 0; opacity: .75; }
.sp-link{ font-weight: 900; }
.sp-link:hover{ text-decoration: underline; }

/* ---------------------------------------------
   Plain homepage layout (timeline_style=plain)
   Front-page uses: .sp-container--plain, .sp-home-plain-top, .sp-home-grid--plain, .sp-panel--ghost
   --------------------------------------------- */
.sp-container--plain{ padding: 18px 0 56px; }
.sp-home-plain-top{ max-width: 980px; margin: 0 auto; padding: 0 18px; }
.sp-home-plain-search{ margin-bottom: 18px; }
.sp-home-plain-search .searchform,
.sp-home-plain-search form.search-form{ margin: 0; }
.sp-home-plain-search input[type="search"]{ width: 100%; max-width: 520px; }
.sp-home-grid--plain{
  display:grid;
  grid-template-columns: var(--sp-home-col-left, 1fr) var(--sp-home-col-right, 360px);
  gap: var(--sp-home-gap, 26px);
  max-width: 980px;
  margin: 0 auto;
  padding: 0 18px;
}
.sp-home-grid--plain.sp-home-layout-stack{
  grid-template-columns: 1fr;
}
@media (max-width: 980px){
  .sp-home-grid--plain{ grid-template-columns: 1fr; }
}

/* Make ghost panels look like plain page blocks */
.sp-panel--ghost{
  background: transparent;
  border: none;
  box-shadow: none;
  padding: 0;
}
.sp-panel--ghost .sp-panel__bd{ padding: 0; }
.sp-panel--ghost .sp-panel__hd{ padding: 0 0 12px; border-bottom: 1px solid rgba(17,24,39,.08); }
.sp-panel--ghost .sp-panel__ft{ padding: 12px 0 0; }

.sp-plain-hd{ display:flex; align-items:flex-end; justify-content:space-between; gap: 12px; }
.sp-plain-title{ margin:0; font-size: 22px; letter-spacing:.02em; }
.sp-plain-sub{ margin: 6px 0 0; color: rgba(17,24,39,.55); font-size: 13px; }
.sp-plain-link{ color: rgba(17,24,39,.65); text-decoration:none; font-weight: 700; }
.sp-plain-link:hover{ text-decoration: underline; }

/* Loadmore as text (no pill) */
.sp-loadmore--plain{
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
  font-weight: 800;
  color: rgba(17,24,39,.7);
}
.sp-loadmore--plain:hover{ text-decoration: underline; }

/* Post list separators in plain mode */
.sp-timeline-plain .sp-post.sp-card,
.sp-timeline-plain .sp-note.sp-card{
  padding: 18px 0;
  border-bottom: 1px solid rgba(17,24,39,.08);
}
.sp-timeline-plain .sp-panel--ghost .sp-post.sp-card:last-child,
.sp-timeline-plain .sp-panel--ghost .sp-note.sp-card:last-child{
  border-bottom: none;
}

/* Remove all pill/button visual treatments in plain mode */
.sp-timeline-plain .sp-btn,
.sp-timeline-plain .sp-pill,
.sp-timeline-plain .sp-readmore,
.sp-timeline-plain .sp-action{
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
}
.sp-timeline-plain .sp-readmore:hover,
.sp-timeline-plain .sp-action:hover{ text-decoration: underline; }

