/*!**************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[5].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[5].use[3]!./src/components/ui/UserStatusBar.module.css ***!
  \**************************************************************************************************************************************************************************************************************************************************************************************/
.UserStatusBar_bar__25A3v {
  display: flex;
  align-items: center;
  gap: 16px;
}

.UserStatusBar_credits__YtLDw {
  display: flex;
  align-items: baseline;
  gap: 4px;
  padding: 4px 12px;
  background: var(--sand);
  border-radius: 2px;
  cursor: pointer;
  transition: background 0.15s;
}
.UserStatusBar_credits__YtLDw:hover { background: var(--sand-deep); }

.UserStatusBar_creditValue__zD1dY {
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  font-weight: 500;
  color: var(--gold-dark);
}

.UserStatusBar_creditLabel___o55b {
  font-size: 10px;
  color: var(--ink-ghost);
  letter-spacing: 0.5px;
}

.UserStatusBar_creditPlus__s_OFM {
  font-family: 'Cormorant Garamond', serif;
  font-size: 16px;
  color: var(--gold);
  margin-left: 4px;
  line-height: 1;
}

.UserStatusBar_userName__Ml_49 {
  font-size: 13px;
  color: var(--ink-soft);
  font-weight: 300;
}

.UserStatusBar_logoutBtn__stkUW {
  font-size: 11px;
  color: var(--ink-ghost);
  background: none;
  border: none;
  cursor: pointer;
  font-family: 'Noto Sans SC', sans-serif;
}
.UserStatusBar_logoutBtn__stkUW:hover { color: var(--ink-mute); }

/*!**************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[5].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[5].use[3]!./src/components/ui/ConfirmDialog.module.css ***!
  \**************************************************************************************************************************************************************************************************************************************************************************************/
.ConfirmDialog_backdrop__3jorQ {
  position: fixed;
  inset: 0;
  background: rgba(26, 23, 20, 0.32);
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: ConfirmDialog_fadeIn__3CJFb .15s ease;
  font-family: 'Noto Sans SC', sans-serif;
}

.ConfirmDialog_card__4HrSV {
  width: min(440px, 92vw);
  background: var(--cream);
  border: 1px solid var(--sand-deep);
  border-radius: 8px;
  box-shadow: 0 16px 40px rgba(26, 23, 20, 0.14);
  padding: 24px 28px 20px;
  animation: ConfirmDialog_cardIn__6cHdb .2s ease;
}

.ConfirmDialog_icon__I2Cmx {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  font-size: 18px;
  margin-bottom: 14px;
}

.ConfirmDialog_iconDefault__vyAn9 {
  background: rgba(184, 152, 106, 0.15);
  color: var(--gold-dark);
}

.ConfirmDialog_iconDanger__v3dj2 {
  background: rgba(196, 92, 92, 0.12);
  color: var(--error);
}

.ConfirmDialog_title__cAKek {
  margin: 0 0 10px;
  font-size: 17px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.35;
}

.ConfirmDialog_message__gbDAA {
  margin: 0 0 22px;
  font-size: 13.5px;
  color: var(--ink-soft);
  line-height: 1.65;
  white-space: pre-wrap;
}

.ConfirmDialog_message__gbDAA strong {
  color: var(--ink);
  font-weight: 600;
}

.ConfirmDialog_actions__UANTw {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}

.ConfirmDialog_btn__S89Ij {
  padding: 8px 20px;
  font-size: 13px;
  border-radius: 4px;
  cursor: pointer;
  font-family: 'Noto Sans SC', sans-serif;
  font-weight: 500;
  transition: background .15s, border-color .15s;
  letter-spacing: 0.5px;
}

.ConfirmDialog_btnCancel__uK_Af {
  background: var(--white);
  border: 1px solid var(--sand-deep);
  color: var(--ink-mute);
}

.ConfirmDialog_btnCancel__uK_Af:hover {
  border-color: var(--ink-ghost);
  color: var(--ink-soft);
}

.ConfirmDialog_btnConfirm__cb8mM {
  background: var(--gold);
  border: 1px solid var(--gold);
  color: var(--white);
  font-weight: 600;
}

.ConfirmDialog_btnConfirm__cb8mM:hover {
  background: var(--gold-dark);
  border-color: var(--gold-dark);
}

.ConfirmDialog_btnDanger__pEg53 {
  background: var(--error);
  border: 1px solid var(--error);
  color: var(--white);
  font-weight: 600;
}

.ConfirmDialog_btnDanger__pEg53:hover {
  background: #a64949;
  border-color: #a64949;
}

@keyframes ConfirmDialog_fadeIn__3CJFb {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes ConfirmDialog_cardIn__6cHdb {
  from { opacity: 0; transform: translateY(8px) scale(0.98); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

/*!*******************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[5].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[5].use[3]!./src/app/page.module.css ***!
  \*******************************************************************************************************************************************************************************************************************************************************************/
.page_container__aoG4z {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* ── Nav ── */
.page_nav__zpG_3 {
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--cream);
  border-bottom: 1px solid var(--sand-deep);
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 56px;
  padding: 0 48px;
}

.page_logo__7fc9l {
  font-family: 'Cormorant Garamond', serif;
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 2px;
  color: var(--ink);
}

.page_logo__7fc9l em { font-style: normal; color: var(--gold); }

.page_navRight__xjCX3 {
  display: flex;
  align-items: center;
  gap: 20px;
}

.page_credits__J_uTH {
  display: flex;
  align-items: baseline;
  gap: 4px;
  padding: 4px 12px;
  background: var(--sand);
  border-radius: 2px;
}

.page_creditValue__lRLR1 {
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  font-weight: 500;
  color: var(--gold-dark);
}

.page_creditLabel__uik6T {
  font-size: 10px;
  color: var(--ink-ghost);
  letter-spacing: 0.5px;
}

.page_userName__JJW9p {
  font-size: 13px;
  color: var(--ink-soft);
  font-weight: 300;
}

.page_logoutBtn__W5nCV {
  font-size: 11px;
  color: var(--ink-ghost);
  background: none;
  border: none;
  cursor: pointer;
  font-family: 'Noto Sans SC', sans-serif;
}

.page_logoutBtn__W5nCV:hover { color: var(--ink-mute); }

/* ── Main ── */
.page_main__GlU4n {
  flex: 1 1;
  max-width: 960px;
  margin: 0 auto;
  padding: 48px 48px;
  width: 100%;
}

.page_header__kVzhN {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 32px;
}

.page_title__3jonF {
  font-family: 'Cormorant Garamond', serif;
  font-size: 36px;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 4px;
}

.page_subtitle__iAJUg {
  font-size: 13px;
  color: var(--ink-mute);
  font-weight: 300;
}

.page_newBtn__NX5Kf {
  padding: 10px 32px;
  font-size: 13px;
  font-family: 'Noto Sans SC', sans-serif;
  background: var(--ink);
  color: var(--cream);
  border: none;
  border-radius: 2px;
  letter-spacing: 0.5px;
  cursor: pointer;
  transition: all 0.2s ease;
}

.page_newBtn__NX5Kf:hover { background: var(--ink-soft); }

/* ── Empty ── */
.page_empty__94dW_ {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 80px 0;
  gap: 12px;
}

.page_emptyIcon__dVLpt {
  font-family: 'Cormorant Garamond', serif;
  font-size: 36px;
  font-weight: 300;
  color: var(--sand-deep);
  width: 64px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px dashed var(--sand-deep);
  border-radius: 4px;
}

.page_emptyText__ZIypX {
  font-size: 13px;
  color: var(--ink-mute);
  font-weight: 300;
}

.page_loading__Q7rym {
  text-align: center;
  padding: 80px 0;
  color: var(--ink-mute);
  font-size: 13px;
  font-weight: 300;
}

/* ── Project grid ── */
.page_grid__f5Kdy {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-gap: 16px;
  gap: 16px;
}

.page_card__QV0Om {
  border: 1px solid var(--sand-deep);
  border-radius: 4px;
  overflow: hidden;
  cursor: pointer;
  transition: border-color 0.2s ease;
}

.page_card__QV0Om:hover { border-color: var(--ink-ghost); }

.page_cardThumb__E2buK {
  aspect-ratio: 16 / 10;
  background: var(--sand);
  overflow: hidden;
}

.page_thumbImg__ff80z {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.page_thumbPlaceholder__1n5Ir {
  width: 100%;
  height: 100%;
  background: var(--sand);
}

.page_cardBody__v_3HE {
  padding: 12px 16px;
}

.page_cardTitle__wyNTT {
  font-size: 14px;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 8px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.page_cardMeta__5MUA9 {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  color: var(--ink-ghost);
  font-weight: 300;
}

.page_status___nccx {
  padding: 1px 6px;
  border-radius: 2px;
  font-size: 10px;
  letter-spacing: 0.5px;
}

.page_status_draft__nvHu3 { background: var(--sand); color: var(--ink-mute); }
.page_status_generating__UNHKh { background: rgba(184,152,106,0.1); color: var(--gold-dark); }
.page_status_completed__3dn_7 { background: rgba(106,154,106,0.1); color: var(--success); }
.page_status_failed__l3abI { background: rgba(196,92,92,0.06); color: var(--error); }

.page_stepInfo__SrsxK {
  font-family: 'DM Sans', sans-serif;
}

.page_creditInfo__ZiaRZ {
  font-family: 'DM Sans', sans-serif;
  color: var(--gold-dark);
}


/* ── 模板弹窗 ── */
.page_tplOverlay__ywbEu {
  position: fixed; inset: 0; background: rgba(20,20,20,0.55); z-index: 9999;
  display: flex; align-items: center; justify-content: center;
  padding: 48px 24px; -webkit-backdrop-filter: blur(2px); backdrop-filter: blur(2px);
}
.page_tplModal__y0IUc {
  background: var(--cream); width: min(880px, 100%); max-height: calc(100vh - 96px);
  display: flex; flex-direction: column; border-radius: 4px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.25);
}
.page_tplHead__Bpn4X {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 24px; border-bottom: 1px solid var(--sand-deep);
}
.page_tplTitle__xZyJB {
  font-family: 'Cormorant Garamond', serif; font-size: 22px; color: var(--ink);
}
.page_tplClose__xzrCS {
  background: none; border: none; font-size: 24px; color: var(--ink-mute);
  cursor: pointer; padding: 0 4px;
}
.page_tplBody__DvYnf { padding: 16px 24px 24px; overflow-y: auto; }

.page_tplSection__EdBPb { margin-bottom: 24px; }
.page_tplSectionLabel__T2gFx {
  font-size: 11px; letter-spacing: 1.5px; color: var(--ink-ghost);
  text-transform: uppercase; margin-bottom: 12px;
}
.page_tplEmpty__Yc2Pm {
  padding: 32px; text-align: center; color: var(--ink-ghost);
  font-size: 12px; background: var(--sand); border-radius: 3px;
}

.page_tplGrid__1RIki {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  grid-gap: 12px;
  gap: 12px;
}
.page_tplCard__i4B_4 {
  border: 1px solid var(--sand-deep); border-radius: 4px;
  overflow: hidden; cursor: pointer;
  transition: transform 0.15s, border-color 0.15s;
  background: var(--cream);
}
.page_tplCard__i4B_4:hover { border-color: var(--gold); transform: translateY(-2px); }
.page_tplCover__4LbgF {
  aspect-ratio: 16/9; background: var(--sand); overflow: hidden;
}
.page_tplCover__4LbgF img { width: 100%; height: 100%; object-fit: cover; }
.page_tplCoverEmpty__l_2VW {
  width: 100%; height: 100%; display: flex; align-items: center;
  justify-content: center; color: var(--ink-ghost);
  font-family: 'Cormorant Garamond', serif; font-size: 18px;
}
.page_tplCardName__iMDL8 {
  padding: 8px 12px 4px; font-size: 13px; color: var(--ink);
}
.page_tplCardDesc__zX8f1, .page_tplCardMeta___hDJY {
  padding: 0 12px 8px; font-size: 11px; color: var(--ink-mute); font-weight: 300;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.page_tplCardMeta___hDJY { color: var(--ink-ghost); }


@media (max-width: 768px) {
  .page_nav__zpG_3 { padding: 0 16px; height: 48px; }
  .page_main__GlU4n { padding: 24px 16px; }
  .page_header__kVzhN { flex-direction: column; align-items: stretch; gap: 12px; }
  .page_grid__f5Kdy { grid-template-columns: 1fr; }
  .page_tplModal__y0IUc { max-height: calc(100vh - 32px); }
  .page_tplBody__DvYnf { padding: 12px 16px; }
}

