:root {
  --bg: #fbf8f6;
  --surface: #fffdfc;
  --surface-soft: #f8f1f2;
  --ink: #2d292d;
  --muted: #887e82;
  --line: #eadfe1;
  --berry: #b9687f;
  --berry-dark: #8d4e61;
  --pink: #efc4cf;
  --pink-soft: #f8e7eb;
  --cream: #f7ead7;
  --sage: #b8cbb9;
  --shadow: 0 18px 60px rgba(93, 64, 73, .08);
  --radius-lg: 28px;
  --radius-md: 20px;
  --font: Inter, ui-sans-serif, -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Microsoft YaHei", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-height: 100vh;
  color: var(--ink);
  background:
    radial-gradient(circle at 88% 4%, rgba(239,196,207,.22), transparent 24%),
    radial-gradient(circle at 36% 95%, rgba(247,234,215,.28), transparent 28%),
    var(--bg);
  font-family: var(--font);
  -webkit-font-smoothing: antialiased;
}
button, input, textarea, select { font: inherit; }
button { cursor: pointer; }
button:focus-visible, input:focus-visible, textarea:focus-visible, select:focus-visible {
  outline: 3px solid rgba(185,104,127,.2);
  outline-offset: 2px;
}

.app-shell { min-height: 100vh; display: grid; grid-template-columns: 245px minmax(0, 1fr); }
.sidebar {
  position: fixed;
  inset: 0 auto 0 0;
  width: 245px;
  padding: 34px 24px 22px;
  display: flex;
  flex-direction: column;
  background: rgba(255,253,252,.88);
  border-right: 1px solid var(--line);
  backdrop-filter: blur(18px);
  z-index: 20;
}
.brand { display: flex; align-items: center; gap: 12px; color: var(--ink); text-decoration: none; padding: 0 6px; }
.brand-mark {
  width: 41px; height: 41px; display: grid; place-items: center;
  border-radius: 14px 14px 14px 5px; color: white; background: var(--berry);
  font-family: Georgia, serif; font-size: 22px; font-style: italic; box-shadow: 0 8px 20px rgba(185,104,127,.22);
}
.brand b { display: block; font-family: Georgia, "Times New Roman", serif; font-size: 22px; letter-spacing: .01em; }
.brand small { display: block; color: var(--muted); font-size: 10px; letter-spacing: .16em; text-transform: uppercase; margin-top: 2px; }
.main-nav { display: grid; gap: 7px; margin-top: 54px; }
.nav-item {
  border: 0; background: transparent; color: var(--muted); border-radius: 15px;
  min-height: 48px; display: flex; align-items: center; gap: 14px; padding: 0 15px; font-weight: 650; text-align: left;
}
.nav-item:hover { background: var(--surface-soft); color: var(--ink); }
.nav-item.active { background: var(--pink-soft); color: var(--berry-dark); }
.nav-icon { width: 23px; font-size: 21px; font-weight: 400; text-align: center; }
.sidebar-note { margin-top: auto; padding: 20px; border-radius: 20px; background: var(--surface-soft); border: 1px solid #f0e2e5; }
.note-kicker, .section-kicker, .eyebrow { color: var(--berry); font-size: 10px; font-weight: 800; letter-spacing: .16em; text-transform: uppercase; }
.sidebar-note p { margin: 10px 0 0; color: #6e6266; font-size: 13px; line-height: 1.65; }
.profile-chip { margin-top: 16px; padding: 8px 6px; border: 0; background: transparent; display: grid; grid-template-columns: 36px 1fr auto; align-items: center; gap: 9px; text-align: left; color: var(--ink); border-radius: 14px; }
.profile-chip:hover { background: var(--surface-soft); }
.avatar { width: 36px; height: 36px; display: grid; place-items: center; border-radius: 50%; background: var(--cream); color: #8b6a45; font-weight: 800; }
.profile-chip b, .profile-chip small { display: block; }
.profile-chip b { font-size: 12px; }
.profile-chip small { color: var(--muted); margin-top: 3px; font-size: 9px; }
.more { color: var(--muted); letter-spacing: 1px; }

.main-content { grid-column: 2; width: min(1220px, 100%); margin: 0 auto; padding: 38px 46px 70px; }
.topbar { display: flex; align-items: center; justify-content: space-between; gap: 24px; margin-bottom: 27px; }
.eyebrow { margin: 0 0 7px; }
.topbar h1 { margin: 0; font-size: clamp(25px, 3vw, 38px); font-family: Georgia, "Noto Serif SC", serif; font-weight: 500; letter-spacing: -.035em; }
.topbar-actions { display: flex; align-items: center; gap: 10px; }
.date-picker { height: 43px; display: flex; align-items: center; gap: 8px; padding: 0 12px; border: 1px solid var(--line); border-radius: 13px; background: rgba(255,253,252,.9); color: var(--muted); font-size: 12px; }
.date-picker input { width: 124px; border: 0; background: transparent; color: var(--ink); outline: 0; font-size: 12px; }
.icon-button { width: 43px; height: 43px; border: 0; border-radius: 13px; background: var(--berry); color: white; font-size: 25px; line-height: 1; box-shadow: 0 9px 25px rgba(185,104,127,.22); }
.page { display: none; animation: fadeIn .28s ease; }
.page.active { display: block; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }

.week-strip { display: grid; grid-template-columns: repeat(7, 1fr); gap: 8px; margin-bottom: 18px; }
.week-day { min-height: 66px; border: 1px solid transparent; border-radius: 17px; background: transparent; color: var(--muted); display: grid; place-items: center; align-content: center; gap: 6px; }
.week-day span { font-size: 11px; }
.week-day b { color: var(--ink); font-size: 15px; }
.week-day:hover { background: rgba(255,255,255,.7); border-color: var(--line); }
.week-day.active { background: var(--surface); border-color: var(--line); box-shadow: 0 8px 30px rgba(93,64,73,.06); }
.week-day.active b { width: 31px; height: 31px; border-radius: 50%; display: grid; place-items: center; color: white; background: var(--berry); }
.week-day.has-data::after { content: ""; width: 4px; height: 4px; border-radius: 50%; background: var(--pink); }

.hero-card {
  position: relative; overflow: hidden; min-height: 230px; padding: 44px 52px;
  border-radius: 33px; background: linear-gradient(125deg, #f5e1e6 0%, #f1d6de 65%, #edccd5 100%);
  display: flex; align-items: center; justify-content: space-between; gap: 40px; box-shadow: var(--shadow);
}
.hero-card::after { content: ""; position: absolute; width: 340px; height: 340px; right: -125px; top: -160px; border: 1px solid rgba(255,255,255,.48); border-radius: 50%; box-shadow: 0 0 0 36px rgba(255,255,255,.08), 0 0 0 72px rgba(255,255,255,.06); }
.hero-copy { position: relative; z-index: 2; flex: 1; max-width: 700px; }
.soft-badge { display: inline-flex; padding: 6px 10px; border-radius: 99px; background: rgba(255,255,255,.56); color: var(--berry-dark); font-size: 9px; font-weight: 850; letter-spacing: .15em; }
.hero-copy h2 { margin: 17px 0 6px; font-size: 17px; font-weight: 650; }
.intention-input { width: 100%; padding: 6px 0 9px; border: 0; border-bottom: 1px solid rgba(141,78,97,.26); background: transparent; color: var(--ink); font-size: clamp(22px, 3.3vw, 36px); font-family: Georgia, "Noto Serif SC", serif; outline: none; }
.intention-input::placeholder { color: rgba(81,56,65,.38); }
.hero-copy p { margin: 13px 0 0; color: #755e66; font-size: 12px; }
.progress-orbit { --progress: 0deg; position: relative; z-index: 2; width: 138px; aspect-ratio: 1; flex: 0 0 auto; display: grid; place-items: center; border-radius: 50%; background: conic-gradient(var(--berry) var(--progress), rgba(255,255,255,.58) 0); box-shadow: inset 0 0 0 1px rgba(255,255,255,.55); }
.progress-orbit::before { content: ""; width: 112px; aspect-ratio: 1; position: absolute; border-radius: 50%; background: rgba(250,241,242,.92); }
.progress-orbit div { position: relative; text-align: center; }
.progress-orbit strong, .progress-orbit span { display: block; }
.progress-orbit strong { font-size: 30px; font-family: Georgia, serif; font-weight: 500; }
.progress-orbit span { color: var(--muted); font-size: 10px; margin-top: 3px; }
.hero-spark { position: absolute; color: rgba(255,255,255,.68); font-family: Georgia, serif; }
.spark-one { right: 205px; top: 36px; font-size: 25px; }.spark-two { left: 35px; bottom: 18px; font-size: 32px; }

.dashboard-grid { display: grid; grid-template-columns: minmax(0, 1.65fr) minmax(260px, .75fr); gap: 18px; margin-top: 18px; }
.right-stack { display: grid; gap: 18px; }
.card { background: rgba(255,253,252,.92); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 26px; box-shadow: 0 12px 45px rgba(93,64,73,.055); }
.section-heading { display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.section-heading h2, .card > h2 { margin: 5px 0 0; font-family: Georgia, "Noto Serif SC", serif; font-size: 23px; font-weight: 500; letter-spacing: -.02em; }
.section-heading.compact h2 { font-size: 20px; }
.text-button { border: 0; background: transparent; color: var(--berry); font-size: 12px; font-weight: 700; padding: 7px; }
.timeline { position: relative; margin-top: 21px; }
.timeline::before { content: ""; position: absolute; left: 50px; top: 15px; bottom: 15px; width: 1px; background: var(--line); }
.timeline-item { position: relative; display: grid; grid-template-columns: 39px 22px minmax(0,1fr) auto; align-items: center; gap: 9px; min-height: 67px; }
.timeline-time { color: var(--muted); font-size: 11px; text-align: right; }
.timeline-dot { position: relative; z-index: 2; width: 10px; height: 10px; margin-left: 5px; border-radius: 50%; background: var(--surface); border: 2px solid var(--pink); }
.timeline-item.done .timeline-dot { border-color: var(--sage); background: var(--sage); }
.timeline-copy b { display: block; font-size: 13px; font-weight: 700; }
.timeline-copy small { display: block; margin-top: 5px; color: var(--muted); font-size: 10px; }
.check-button { width: 30px; height: 30px; border: 1px solid var(--line); border-radius: 50%; background: var(--surface); color: transparent; }
.done .check-button { background: #edf3ed; border-color: #ccdacc; color: #678069; }
.done .timeline-copy b { text-decoration: line-through; color: var(--muted); }
.empty-state { padding: 28px 12px; color: var(--muted); font-size: 13px; text-align: center; border: 1px dashed var(--line); border-radius: 18px; }

.streak-card { min-height: 145px; overflow: hidden; position: relative; background: linear-gradient(140deg, #fff8f5, #f6e5df); display: flex; justify-content: space-between; align-items: center; }
.streak-copy strong { display: block; margin-top: 10px; color: var(--berry-dark); font-family: Georgia, serif; font-size: 31px; font-weight: 500; }
.streak-copy p { margin: 5px 0 0; color: var(--muted); font-size: 11px; }
.streak-flower { position: relative; width: 77px; height: 77px; flex: 0 0 auto; }
.streak-flower span { position: absolute; width: 34px; height: 42px; border-radius: 60% 60% 48% 48%; background: rgba(185,104,127,.24); transform-origin: 50% 95%; left: 22px; top: 1px; }
.streak-flower span:nth-child(2) { transform: rotate(90deg); }.streak-flower span:nth-child(3) { transform: rotate(180deg); }.streak-flower span:nth-child(4) { transform: rotate(270deg); }
.streak-flower i { position: absolute; width: 18px; height: 18px; border-radius: 50%; background: var(--berry); left: 30px; top: 29px; }
.quick-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 17px; }
.quick-action { min-height: 90px; display: flex; flex-direction: column; align-items: flex-start; justify-content: center; border: 1px solid var(--line); border-radius: 17px; background: var(--surface); color: var(--ink); padding: 13px; }
.quick-action:hover { transform: translateY(-1px); box-shadow: 0 8px 22px rgba(93,64,73,.07); }
.quick-action > span { width: 25px; height: 25px; display: grid; place-items: center; border-radius: 8px; background: var(--pink-soft); color: var(--berry); font-size: 10px; font-weight: 800; }
.quick-action b { margin-top: 8px; font-size: 13px; }.quick-action small { color: var(--muted); font-size: 9px; margin-top: 4px; }
.task-card { margin-top: 18px; }
.task-list { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 20px; }
.task-item { min-height: 76px; display: grid; grid-template-columns: 30px minmax(0,1fr) auto; gap: 11px; align-items: center; padding: 13px 15px; border: 1px solid var(--line); border-radius: 18px; background: var(--surface); }
.task-check { width: 24px; height: 24px; border: 1.5px solid #d8c7cb; border-radius: 8px; background: white; color: transparent; }
.task-item.done .task-check { color: white; border-color: var(--berry); background: var(--berry); }
.task-item.done .task-copy b { text-decoration: line-through; color: var(--muted); }
.task-copy b { display: block; font-size: 13px; }.task-copy small { display: block; color: var(--muted); margin-top: 5px; font-size: 10px; }
.category-tag { padding: 5px 8px; border-radius: 99px; background: var(--surface-soft); color: var(--berry-dark); font-size: 9px; font-weight: 750; }
.delete-mini { opacity: 0; border: 0; background: transparent; color: #aa8f96; font-size: 17px; padding: 3px; }
.task-item:hover .delete-mini, .plan-item:hover .delete-mini { opacity: 1; }

.button { min-height: 42px; border: 1px solid transparent; border-radius: 13px; padding: 0 17px; font-weight: 750; font-size: 12px; }
.button.primary { background: var(--berry); color: white; box-shadow: 0 8px 22px rgba(185,104,127,.17); }
.button.primary:hover { background: var(--berry-dark); }
.button.secondary { background: var(--surface); border-color: var(--line); color: var(--ink); }
.button.secondary:hover { border-color: #d8c3c8; background: #fff; }
.button.danger { background: #fff3f3; border-color: #f1d0d0; color: #a24e55; }
.button.full { width: 100%; }.small-button { min-height: 36px; padding: 0 13px; }
.page-intro { display: flex; justify-content: space-between; align-items: end; gap: 24px; margin-bottom: 24px; padding: 8px 3px; }
.page-intro h2 { margin: 8px 0 6px; font-family: Georgia, "Noto Serif SC", serif; font-size: 30px; font-weight: 500; }.page-intro p { margin: 0; color: var(--muted); font-size: 13px; }
.button-row { display: flex; gap: 8px; }
.plan-layout { display: grid; grid-template-columns: minmax(0,1.55fr) minmax(270px,.7fr); gap: 18px; }
.plan-aside { display: grid; gap: 18px; align-content: start; }
.count-pill { padding: 7px 10px; border-radius: 99px; background: var(--surface-soft); color: var(--muted); font-size: 10px; }
.plan-list { display: grid; gap: 10px; margin-top: 22px; }
.plan-item { display: grid; grid-template-columns: 95px 5px minmax(0,1fr) auto auto; align-items: center; gap: 13px; min-height: 78px; padding: 12px 13px; border: 1px solid var(--line); border-radius: 18px; background: var(--surface); }
.plan-time { font-size: 11px; color: var(--muted); }.plan-color { height: 38px; border-radius: 99px; background: var(--pink); }.plan-copy b { display: block; font-size: 13px; }.plan-copy small { display: block; color: var(--muted); margin-top: 5px; font-size: 10px; }
.edit-mini { border: 0; background: transparent; color: var(--berry); font-size: 11px; font-weight: 700; }
textarea, input, select { color: var(--ink); }
.mini-goal-card textarea, .import-card textarea, .review-grid textarea { width: 100%; margin-top: 15px; padding: 13px 14px; resize: vertical; border: 1px solid var(--line); border-radius: 15px; background: var(--surface); line-height: 1.6; outline: 0; font-size: 13px; }
.save-hint { color: var(--muted); font-size: 10px; text-align: right; margin: 8px 3px 0; }
.import-card p { color: var(--muted); font-size: 11px; line-height: 1.55; }.import-card code { color: var(--berry-dark); }

.focus-layout { display: grid; grid-template-columns: minmax(0,1.5fr) minmax(260px,.6fr); gap: 18px; }
.focus-panel { min-height: 660px; border-radius: 34px; padding: 52px; text-align: center; background: linear-gradient(150deg, #f4e1e6, #fbf6f2 58%, #f3e7dc); border: 1px solid var(--line); box-shadow: var(--shadow); }
.focus-panel h2 { margin: 18px 0 15px; font-family: Georgia, "Noto Serif SC", serif; font-size: clamp(25px,4vw,36px); font-weight: 500; }
.focus-task-input { width: min(520px,100%); border: 0; border-bottom: 1px solid rgba(141,78,97,.25); background: transparent; text-align: center; padding: 8px; outline: 0; font-size: 14px; }
.timer-ring { --timer-progress: 360deg; width: 255px; aspect-ratio: 1; margin: 38px auto 25px; display: grid; place-items: center; border-radius: 50%; background: conic-gradient(var(--berry) var(--timer-progress), rgba(255,255,255,.7) 0); box-shadow: 0 18px 60px rgba(128,83,97,.15); }
.timer-ring::before { content: ""; position: absolute; width: 224px; aspect-ratio: 1; border-radius: 50%; background: rgba(255,253,252,.94); }
.timer-inner { position: relative; }.timer-inner span { display: block; font-family: Georgia, serif; font-size: 57px; letter-spacing: -.04em; }.timer-inner small { display: block; margin-top: 7px; color: var(--muted); }
.timer-presets { display: flex; justify-content: center; gap: 8px; }.preset { min-height: 34px; border: 1px solid rgba(185,104,127,.16); border-radius: 99px; background: rgba(255,255,255,.45); color: var(--muted); padding: 0 13px; font-size: 11px; }.preset.active { color: var(--berry-dark); background: white; border-color: var(--pink); }
.timer-actions { display: flex; justify-content: center; gap: 9px; margin-top: 24px; }.timer-main { min-width: 140px; }
.focus-aside { display: grid; gap: 18px; align-content: start; }.focus-stat-card strong { display: block; color: var(--berry-dark); margin-top: 19px; font-family: Georgia, serif; font-size: 43px; font-weight: 500; }.focus-stat-card strong small { font-size: 13px; color: var(--muted); }.mini-progress { height: 7px; margin: 17px 0 10px; background: var(--surface-soft); border-radius: 99px; overflow: hidden; }.mini-progress span { display: block; height: 100%; width: 0; background: var(--berry); border-radius: inherit; transition: width .3s ease; }.focus-stat-card p, .focus-tips p { color: var(--muted); font-size: 11px; line-height: 1.6; }.focus-tips label { display: flex; align-items: flex-start; gap: 9px; color: #6d6266; font-size: 12px; line-height: 1.5; margin-top: 15px; }.focus-tips input { accent-color: var(--berry); margin-top: 2px; }

.growth-grid { display: grid; grid-template-columns: minmax(0,1.6fr) minmax(230px,.5fr); gap: 18px; }.bar-chart { height: 245px; margin-top: 26px; display: grid; grid-template-columns: repeat(7,1fr); gap: 14px; align-items: end; border-bottom: 1px solid var(--line); }.bar-column { height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: end; gap: 9px; }.bar-column b { color: var(--muted); font-size: 9px; font-weight: 650; }.bar { width: min(38px,70%); min-height: 5px; border-radius: 11px 11px 2px 2px; background: linear-gradient(180deg, var(--pink), var(--berry)); transition: height .4s ease; }.bar-column span { height: 18px; color: var(--muted); font-size: 10px; }.summary-card { background: linear-gradient(145deg,#f8e9e5,#fffaf7); }.summary-number { display: flex; align-items: baseline; gap: 8px; padding: 19px 0; border-bottom: 1px solid rgba(185,104,127,.12); }.summary-number:last-child { border: 0; }.summary-number strong { color: var(--berry-dark); font-family: Georgia,serif; font-size: 36px; font-weight: 500; }.summary-number span { color: var(--muted); font-size: 11px; }.review-card { margin-top: 18px; }.review-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; margin-top: 22px; }.review-grid label > span, .mood-row > span { font-size: 12px; font-weight: 700; }.review-grid textarea { margin-top: 8px; min-height: 135px; }.mood-row { display: flex; align-items: center; gap: 15px; margin-top: 16px; padding-top: 18px; border-top: 1px solid var(--line); }.mood-options { display: flex; gap: 6px; flex: 1; }.mood-options button { border: 1px solid var(--line); border-radius: 99px; background: var(--surface); color: var(--muted); padding: 7px 10px; font-size: 10px; }.mood-options button.active { background: var(--pink-soft); color: var(--berry-dark); border-color: var(--pink); }

.mobile-nav { display: none; }
.modal { width: min(480px, calc(100% - 30px)); border: 1px solid var(--line); border-radius: 25px; background: var(--surface); color: var(--ink); padding: 0; box-shadow: 0 30px 100px rgba(61,42,48,.2); }.modal::backdrop { background: rgba(46,34,39,.24); backdrop-filter: blur(4px); }.modal form { padding: 25px; }.modal-head { display: flex; justify-content: space-between; align-items: start; gap: 15px; }.modal-head h2 { margin: 5px 0 0; font-family: Georgia,"Noto Serif SC",serif; font-weight: 500; }.close-button { width: 34px; height: 34px; border: 1px solid var(--line); border-radius: 50%; background: white; color: var(--muted); font-size: 20px; }.field { display: block; margin-top: 16px; }.field > span { display: block; color: var(--muted); font-size: 11px; margin-bottom: 7px; }.field input, .field textarea, .field select { width: 100%; border: 1px solid var(--line); border-radius: 13px; background: white; padding: 11px 12px; outline: 0; font-size: 13px; }.field textarea { resize: vertical; }.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }.hidden { display: none !important; }.modal-actions { display: flex; justify-content: flex-end; gap: 8px; margin-top: 22px; }.modal-copy { color: var(--muted); font-size: 12px; line-height: 1.65; }.settings-actions { display: grid; gap: 9px; margin-top: 20px; }.file-button { display: grid; place-items: center; }.file-button input { display: none; }.toast { position: fixed; z-index: 100; left: 50%; bottom: 26px; transform: translate(-50%,20px); padding: 11px 16px; border-radius: 99px; background: #342e31; color: white; font-size: 12px; opacity: 0; pointer-events: none; transition: .25s ease; box-shadow: 0 12px 35px rgba(0,0,0,.18); }.toast.show { opacity: 1; transform: translate(-50%,0); }

@media (max-width: 1020px) {
  .app-shell { grid-template-columns: 86px minmax(0,1fr); }
  .sidebar { width: 86px; padding: 28px 14px 20px; align-items: center; }
  .brand span:last-child, .nav-item > span:last-child, .sidebar-note, .profile-chip span:not(.avatar) { display: none; }
  .main-nav { width: 100%; }.main-nav .nav-item { justify-content: center; padding: 0; }.profile-chip { grid-template-columns: 36px; padding: 6px; }
  .main-content { grid-column: 2; padding-inline: 28px; }
  .dashboard-grid, .plan-layout, .focus-layout { grid-template-columns: 1fr; }.right-stack { grid-template-columns: 1fr 1fr; }.plan-aside, .focus-aside { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 720px) {
  body { padding-bottom: 76px; }.app-shell { display: block; }.sidebar { display: none; }.main-content { width: 100%; padding: 22px 15px 30px; }.topbar { align-items: flex-start; margin-bottom: 18px; }.topbar h1 { font-size: 25px; max-width: 250px; }.date-picker span { display: none; }.date-picker { padding: 0 8px; }.date-picker input { width: 108px; }.icon-button { display: none; }
  .week-strip { gap: 3px; }.week-day { min-height: 57px; border-radius: 13px; }.week-day span { font-size: 9px; }.week-day b { font-size: 12px; }.week-day.active b { width: 27px; height: 27px; }
  .hero-card { min-height: 320px; padding: 30px 24px; flex-direction: column; align-items: flex-start; gap: 25px; }.progress-orbit { width: 104px; align-self: flex-end; margin-top: -5px; }.progress-orbit::before { width: 84px; }.progress-orbit strong { font-size: 24px; }.hero-copy p { line-height: 1.5; }.intention-input { font-size: 24px; }
  .dashboard-grid { grid-template-columns: 1fr; }.right-stack, .plan-aside, .focus-aside { grid-template-columns: 1fr; }.card { padding: 21px; border-radius: 23px; }.task-list { grid-template-columns: 1fr; }.delete-mini { opacity: 1; }
  .page-intro { align-items: flex-start; flex-direction: column; }.page-intro h2 { font-size: 26px; }.button-row { width: 100%; }.button-row .button { flex: 1; }
  .plan-item { grid-template-columns: 73px 4px minmax(0,1fr) auto; gap: 9px; }.plan-item .edit-mini { display: none; }.plan-time { font-size: 9px; }
  .focus-panel { min-height: 570px; padding: 34px 18px; }.timer-ring { width: 215px; }.timer-ring::before { width: 188px; }.timer-inner span { font-size: 48px; }
  .growth-grid { grid-template-columns: 1fr; }.bar-chart { gap: 7px; }.review-grid { grid-template-columns: 1fr; }.mood-row { align-items: flex-start; flex-direction: column; }.mood-options { width: 100%; overflow-x: auto; }.mood-options button { white-space: nowrap; }.mood-row .button { width: 100%; }
  .mobile-nav { position: fixed; display: grid; grid-template-columns: repeat(4,1fr); z-index: 50; left: 10px; right: 10px; bottom: 9px; min-height: 61px; padding: 6px; border: 1px solid var(--line); border-radius: 20px; background: rgba(255,253,252,.94); backdrop-filter: blur(18px); box-shadow: 0 10px 40px rgba(61,42,48,.14); }.mobile-nav .nav-item { min-height: 48px; padding: 4px; justify-content: center; flex-direction: column; gap: 2px; border-radius: 14px; }.mobile-nav .nav-item span { font-size: 19px; }.mobile-nav .nav-item small { font-size: 9px; }
}

@media (prefers-reduced-motion: reduce) { *, *::before, *::after { scroll-behavior: auto !important; animation-duration: .01ms !important; transition-duration: .01ms !important; } }
