
:root {
  --jdp-ink: #231a17;
  --jdp-cocoa: #8f746b;
  --jdp-rose: #d77f8b;
  --jdp-blush: #f5d9d4;
  --jdp-milk: #fffaf4;
  --jdp-cream: #f6efe6;
  --jdp-mist: #e8ece8;
  --jdp-champagne: #ead6bf;
  --jdp-clay: #b8887e;
  --jdp-plum: #5e4a49;
  --jdp-radius: 2.6rem;
  --jdp-shadow: 0 28px 100px rgba(73, 49, 40, 0.12), inset 0 1px 0 rgba(255,255,255,0.72);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body.jdp-body {
  margin: 0;
  min-height: 100vh;
  color: var(--jdp-ink);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", "Microsoft YaHei", sans-serif;
  background:
    radial-gradient(circle at 12% 8%, rgba(255,255,255,0.98), transparent 26rem),
    radial-gradient(circle at 86% 4%, rgba(226,188,176,0.34), transparent 34rem),
    radial-gradient(circle at 76% 78%, rgba(234,214,191,0.42), transparent 32rem),
    linear-gradient(135deg, #fffaf4 0%, #f7efe7 46%, #f1ded5 100%);
  overflow-x: hidden;
}
body.jdp-body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: .38;
  background-image:
    linear-gradient(rgba(35,26,23,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(35,26,23,.035) 1px, transparent 1px);
  background-size: 4rem 4rem;
  mask-image: linear-gradient(to bottom, black, transparent 78%);
}
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
button { cursor: pointer; }
img, video { max-width: 100%; display: block; }
.jdp-nav {
  position: sticky;
  top: 0;
  z-index: 50;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.2rem;
  padding: 1rem clamp(1rem, 5vw, 5rem);
  background: rgba(255,250,244,.68);
  border-bottom: 1px solid rgba(255,255,255,.7);
  backdrop-filter: blur(24px);
}
.jdp-brand {
  display: inline-flex;
  align-items: center;
  gap: .8rem;
  min-width: max-content;
}
.jdp-brand-mark {
  display: grid;
  place-items: center;
  width: 3rem;
  height: 3rem;
  border-radius: 1.15rem;
  color: white;
  background: linear-gradient(145deg, var(--jdp-ink), #5e4a49);
  box-shadow: 0 18px 45px rgba(35,26,23,.18);
  font-weight: 900;
  letter-spacing: -.05em;
}
.jdp-brand strong { display: block; font-size: .98rem; letter-spacing: -.02em; }
.jdp-brand small { display: block; margin-top: .12rem; color: var(--jdp-cocoa); font-size: .72rem; text-transform: uppercase; letter-spacing: .16em; }
.jdp-menu {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: .5rem;
}
.jdp-menu a {
  padding: .75rem 1rem;
  border-radius: 999px;
  color: var(--jdp-cocoa);
  background: rgba(255,255,255,.38);
  border: 1px solid rgba(255,255,255,.55);
  transition: .2s ease;
}
.jdp-menu a:hover { color: var(--jdp-ink); background: rgba(255,255,255,.78); transform: translateY(-1px); }
.jdp-page {
  position: relative;
  z-index: 1;
  padding: clamp(1.2rem, 4vw, 3.5rem) clamp(1rem, 5vw, 5rem) 5rem;
}
.jdp-home { padding-top: 2rem; }
.jdp-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, .72fr);
  gap: clamp(1.4rem, 3vw, 3rem);
  align-items: stretch;
  min-height: 640px;
}
.jdp-hero-copy,
.jdp-panel,
.jdp-feature-card,
.jdp-visual-card,
.jdp-form-card,
.jdp-record-card,
.jdp-calendar-card,
.jdp-lightbox-inner {
  background: rgba(255, 250, 244, 0.74);
  border: 1px solid rgba(255, 255, 255, 0.76);
  box-shadow: var(--jdp-shadow);
  backdrop-filter: blur(26px);
}
.jdp-hero-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  border-radius: var(--jdp-radius);
  padding: clamp(2rem, 5vw, 5rem);
  overflow: hidden;
  position: relative;
}
.jdp-hero-copy::after {
  content: "";
  position: absolute;
  inset: auto -12rem -16rem auto;
  width: 32rem;
  height: 32rem;
  background: radial-gradient(circle, rgba(215,127,139,.24), transparent 68%);
  pointer-events: none;
}
.jdp-kicker {
  margin: 0;
  color: var(--jdp-clay);
  font-size: .76rem;
  letter-spacing: .19em;
  text-transform: uppercase;
  font-weight: 800;
}
.jdp-hero h1 {
  margin: 1rem 0 0;
  font-size: clamp(4rem, 10vw, 9.2rem);
  line-height: .86;
  letter-spacing: -.09em;
  font-weight: 950;
}
.jdp-hero h1 span { display: block; }
.jdp-hero-intro {
  margin: 1.8rem 0 0;
  max-width: 45rem;
  font-size: clamp(1.05rem, 1.8vw, 1.35rem);
  line-height: 1.9;
  color: var(--jdp-cocoa);
}
.jdp-hero-actions { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 2rem; }
.jdp-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 999px;
  padding: .95rem 1.35rem;
  font-weight: 850;
  transition: .2s ease;
}
.jdp-btn:hover { transform: translateY(-2px); }
.jdp-btn-dark { color: white; background: var(--jdp-ink); box-shadow: 0 18px 44px rgba(35,26,23,.2); }
.jdp-btn-soft { color: var(--jdp-ink); background: rgba(255,255,255,.75); border: 1px solid rgba(255,255,255,.85); }
.jdp-stat-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .9rem;
  margin-top: 2.5rem;
}
.jdp-stat-row article,
.jdp-state-grid article {
  border-radius: 1.8rem;
  padding: 1.2rem;
  background: rgba(255,255,255,.52);
  border: 1px solid rgba(255,255,255,.68);
}
.jdp-stat-row span,
.jdp-feature-card span {
  display: block;
  color: var(--jdp-clay);
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .15em;
  font-weight: 850;
}
.jdp-stat-row strong { display: block; margin-top: .45rem; font-size: 1.2rem; }
.jdp-stat-row small { display: block; margin-top: .35rem; color: var(--jdp-cocoa); line-height: 1.55; }
.jdp-visual-card {
  position: relative;
  overflow: hidden;
  border-radius: var(--jdp-radius);
  min-height: 36rem;
}
.jdp-visual-card img { width: 100%; height: 100%; object-fit: cover; }
.jdp-visual-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(35,26,23,.36), transparent 48%);
}
.jdp-visual-caption {
  position: absolute;
  left: 1.4rem;
  right: 1.4rem;
  bottom: 1.4rem;
  z-index: 2;
  border-radius: 2rem;
  padding: 1.2rem;
  color: white;
  background: rgba(35,26,23,.48);
  backdrop-filter: blur(18px);
}
.jdp-visual-caption span { color: rgba(255,255,255,.72); font-size: .76rem; text-transform: uppercase; letter-spacing: .16em; }
.jdp-visual-caption strong { display: block; margin-top: .35rem; font-size: 1.35rem; }
.jdp-home-grid {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 1.4rem;
  margin-top: 1.4rem;
}
.jdp-panel {
  border-radius: var(--jdp-radius);
  padding: clamp(1.4rem, 3vw, 2.4rem);
}
.jdp-panel h2, .jdp-page-intro h1 {
  margin: .6rem 0 0;
  font-size: clamp(2rem, 4vw, 4rem);
  line-height: .95;
  letter-spacing: -.06em;
}
.jdp-muted { color: var(--jdp-cocoa); line-height: 1.8; }
.jdp-latest-list { display: grid; gap: .8rem; margin-top: 1.4rem; }
.jdp-latest-item {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem;
  border-radius: 1.45rem;
  background: rgba(255,255,255,.52);
  border: 1px solid rgba(255,255,255,.68);
}
.jdp-latest-item strong { display: block; }
.jdp-latest-item small { color: var(--jdp-cocoa); }
.jdp-state-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .8rem;
  margin-top: 1.4rem;
}
.jdp-state-grid strong { display: block; font-size: 2rem; letter-spacing: -.06em; }
.jdp-state-grid span { color: var(--jdp-cocoa); }
.jdp-feature-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.2rem;
  margin-top: 1.4rem;
}
.jdp-feature-card {
  border-radius: 2.2rem;
  padding: 1.45rem;
  min-height: 16rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: .22s ease;
}
.jdp-feature-card:hover { transform: translateY(-4px); box-shadow: 0 28px 100px rgba(73, 49, 40, 0.18); }
.jdp-feature-card h3 { margin: .85rem 0 .6rem; font-size: 1.55rem; letter-spacing: -.045em; }
.jdp-feature-card p { margin: 0; color: var(--jdp-cocoa); line-height: 1.8; }
.jdp-feature-card small { margin-top: 1.2rem; font-weight: 850; }
.jdp-page-intro {
  max-width: 980px;
  margin: 0 auto 2rem;
  text-align: center;
}
.jdp-page-intro p:last-child {
  margin: 1rem auto 0;
  color: var(--jdp-cocoa);
  line-height: 1.9;
  max-width: 48rem;
}
.jdp-studio-root { min-height: 32rem; }
.jdp-grid-2 {
  display: grid;
  grid-template-columns: minmax(300px, .82fr) minmax(0, 1.18fr);
  gap: 1.35rem;
  align-items: start;
}
.jdp-form-card, .jdp-record-card, .jdp-calendar-card {
  border-radius: var(--jdp-radius);
  padding: clamp(1.3rem, 3vw, 2rem);
}
.jdp-form-card h2 { margin: .6rem 0 1rem; font-size: 2rem; letter-spacing: -.045em; }
.jdp-form-card p { color: var(--jdp-cocoa); line-height: 1.8; }
.jdp-form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: .8rem; }
.jdp-field, .jdp-textarea, .jdp-select {
  width: 100%;
  border: 1px solid rgba(255,255,255,.76);
  background: rgba(255,255,255,.72);
  color: var(--jdp-ink);
  border-radius: 999px;
  padding: .95rem 1.1rem;
  outline: none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.75);
}
.jdp-textarea {
  min-height: 8rem;
  resize: vertical;
  border-radius: 1.7rem;
  line-height: 1.7;
}
.jdp-file-box {
  display: block;
  border-radius: 1.8rem;
  border: 1px dashed rgba(143,116,107,.36);
  background: rgba(255,255,255,.44);
  padding: 1.1rem;
}
.jdp-file-box input { margin-top: .8rem; max-width: 100%; }
.jdp-actions { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 1rem; }
.jdp-record-list { display: grid; gap: 1rem; }
.jdp-record-card {
  overflow: hidden;
}
.jdp-card-head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
  margin-bottom: 1rem;
}
.jdp-card-head h3 { margin: .35rem 0 0; font-size: 1.65rem; letter-spacing: -.045em; }
.jdp-meta { color: var(--jdp-cocoa); font-size: .9rem; line-height: 1.7; }
.jdp-badge {
  display: inline-flex;
  gap: .45rem;
  align-items: center;
  padding: .45rem .75rem;
  border-radius: 999px;
  background: rgba(255,255,255,.6);
  border: 1px solid rgba(255,255,255,.7);
  font-size: .82rem;
  font-weight: 850;
}
.jdp-avatar {
  width: 1.5rem; height: 1.5rem; border-radius: 999px;
  display: inline-grid; place-items: center;
  color: white; background: var(--jdp-ink);
  font-size: .68rem;
}
.jdp-badge.is-jingze .jdp-avatar { background: var(--jdp-rose); }
.jdp-badge.is-chubao .jdp-avatar { background: var(--jdp-ink); }
.jdp-badge.is-visitor .jdp-avatar { background: #fff; color: var(--jdp-cocoa); border: 1px solid rgba(143,116,107,.2); }
.jdp-media-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .75rem;
  margin: 1rem 0;
}
.jdp-media-grid.is-nine { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.jdp-media-thumb {
  position: relative;
  aspect-ratio: 1 / 1;
  width: 100%;
  border: 0;
  padding: 0;
  border-radius: 1.35rem;
  overflow: hidden;
  background: rgba(255,255,255,.42);
}
.jdp-media-thumb img, .jdp-media-thumb video { width: 100%; height: 100%; object-fit: cover; }
.jdp-media-thumb .jdp-play {
  position: absolute; inset: 0; display: grid; place-items: center;
  color: white; background: rgba(35,26,23,.26);
  font-size: 2rem; font-weight: 900;
}
.jdp-comment-box {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(143,116,107,.16);
}
.jdp-comment-list { display: grid; gap: .7rem; margin-top: .8rem; }
.jdp-comment {
  border-radius: 1.2rem;
  padding: .9rem;
  background: rgba(255,255,255,.48);
}
.jdp-delete {
  border: 0;
  border-radius: 999px;
  padding: .68rem .95rem;
  background: rgba(35,26,23,.08);
  color: var(--jdp-cocoa);
  font-weight: 850;
}
.jdp-delete:hover { background: rgba(35,26,23,.14); color: var(--jdp-ink); }
.jdp-gallery-groups { display: grid; gap: 2rem; }
.jdp-date-heading { display: flex; align-items: end; justify-content: space-between; gap: 1rem; margin: .5rem 0 1rem; }
.jdp-date-heading h2 { margin: 0; font-size: 2rem; letter-spacing: -.055em; }
.jdp-masonry {
  columns: 3 260px;
  column-gap: 1rem;
}
.jdp-gallery-card {
  display: inline-block;
  width: 100%;
  margin: 0 0 1rem;
  overflow: hidden;
  border-radius: 2rem;
  background: rgba(255,250,244,.74);
  border: 1px solid rgba(255,255,255,.72);
  box-shadow: 0 16px 46px rgba(73,49,40,.1);
}
.jdp-gallery-card .jdp-media-thumb { border-radius: 0; aspect-ratio: 4 / 3; }
.jdp-gallery-card:nth-child(3n+1) .jdp-media-thumb { aspect-ratio: 3 / 4; }
.jdp-gallery-card:nth-child(4n+2) .jdp-media-thumb { aspect-ratio: 16 / 10; }
.jdp-gallery-caption { padding: 1rem; }
.jdp-gallery-caption h3 { margin: .35rem 0 .3rem; letter-spacing: -.03em; }
.jdp-gallery-caption p { margin: 0; color: var(--jdp-cocoa); line-height: 1.65; }
.jdp-calendar-layout {
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  gap: 1.3rem;
  align-items: start;
}
.jdp-calendar-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .8rem;
}
.jdp-calendar-head h2 { margin: 0; font-size: 2rem; letter-spacing: -.055em; }
.jdp-calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: .45rem;
  margin-top: 1rem;
}
.jdp-weekday { text-align: center; color: var(--jdp-cocoa); font-size: .78rem; font-weight: 850; }
.jdp-day-cell {
  min-height: 5.2rem;
  border: 1px solid rgba(255,255,255,.68);
  border-radius: 1.2rem;
  background: rgba(255,255,255,.48);
  color: var(--jdp-ink);
  padding: .6rem;
  text-align: left;
}
.jdp-day-cell.is-muted { opacity: .45; }
.jdp-day-cell.is-selected { background: var(--jdp-ink); color: white; }
.jdp-day-cell.has-items::after {
  content: "";
  display: block;
  width: .45rem;
  height: .45rem;
  margin-top: .55rem;
  border-radius: 999px;
  background: var(--jdp-rose);
}
.jdp-upcoming { display: grid; gap: .8rem; margin-top: 1rem; }
.jdp-countdown-card {
  border-radius: 1.6rem;
  padding: 1rem;
  background: rgba(255,255,255,.52);
  border: 1px solid rgba(255,255,255,.7);
}
.jdp-countdown-card strong { display: block; font-size: 1.15rem; }
.jdp-countdown-card em { font-style: normal; color: var(--jdp-rose); font-weight: 900; }
.jdp-message-grid { display: grid; grid-template-columns: .78fr 1.22fr; gap: 1.3rem; align-items: start; }
.jdp-message-list { display: grid; gap: 1rem; }
.jdp-message-card {
  border-radius: 2.2rem;
  padding: 1.4rem;
  background: rgba(255,250,244,.74);
  border: 1px solid rgba(255,255,255,.72);
  box-shadow: 0 16px 46px rgba(73,49,40,.1);
}
.jdp-lightbox {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: none;
  place-items: center;
  padding: 1.2rem;
  background: rgba(35,26,23,.56);
  backdrop-filter: blur(14px);
}
.jdp-lightbox.is-open { display: grid; }
.jdp-lightbox-inner {
  width: min(1100px, 96vw);
  max-height: 92vh;
  border-radius: 2rem;
  overflow: hidden;
  position: relative;
  padding: 1rem;
}
.jdp-lightbox-inner img, .jdp-lightbox-inner video {
  width: 100%;
  max-height: 78vh;
  object-fit: contain;
  border-radius: 1.35rem;
  background: rgba(35,26,23,.08);
}
.jdp-lightbox-close {
  position: absolute;
  top: .8rem;
  right: .8rem;
  border: 0;
  width: 2.7rem; height: 2.7rem;
  border-radius: 999px;
  background: rgba(35,26,23,.88);
  color: white;
  font-size: 1.3rem;
}
.jdp-toast {
  position: fixed;
  z-index: 200;
  left: 50%;
  bottom: 2rem;
  transform: translateX(-50%);
  padding: .9rem 1.2rem;
  border-radius: 999px;
  background: rgba(35,26,23,.92);
  color: white;
  box-shadow: 0 18px 52px rgba(35,26,23,.25);
}
.jdp-progress {
  height: .5rem;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(255,255,255,.55);
}
.jdp-progress span { display: block; height: 100%; width: 0%; background: var(--jdp-rose); transition: width .2s ease; }
.jdp-footer {
  position: relative;
  z-index: 1;
  margin: 0 clamp(1rem, 5vw, 5rem) 2rem;
  padding: 1.4rem;
  border-radius: 2rem;
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  color: var(--jdp-cocoa);
  background: rgba(255,250,244,.56);
  border: 1px solid rgba(255,255,255,.72);
}
.jdp-footer strong { color: var(--jdp-ink); }
.jdp-footer p { margin: .25rem 0 0; }
@media (max-width: 1080px) {
  .jdp-hero, .jdp-home-grid, .jdp-grid-2, .jdp-calendar-layout, .jdp-message-grid { grid-template-columns: 1fr; }
  .jdp-feature-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .jdp-visual-card { min-height: 28rem; }
}
@media (max-width: 720px) {
  .jdp-nav { align-items: flex-start; flex-direction: column; }
  .jdp-menu { justify-content: flex-start; }
  .jdp-menu a { font-size: .9rem; padding: .65rem .85rem; }
  .jdp-hero h1 { font-size: clamp(3.3rem, 18vw, 5.5rem); }
  .jdp-stat-row, .jdp-feature-grid, .jdp-form-grid, .jdp-state-grid { grid-template-columns: 1fr; }
  .jdp-media-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .jdp-calendar-grid { gap: .3rem; }
  .jdp-day-cell { min-height: 4.1rem; border-radius: 1rem; }
  .jdp-footer { flex-direction: column; }
}
