@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Urbanist:wght@300;400;500&display=swap');

*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
:root{
  --bg:#121214;
  --surface:#1c1c1e;
  --surface2:#2c2c2e;
  --surface3:#38383a;
  --gold:#D4AF37;
  --gold2:#e0bf4a;
  --gold3:#b8952e;
  --goldfaint:rgba(212,175,55,0.08);
  --text:#FFFFFF;
  --text2:#d1d1d6;
  --text3:#8e8e93;
  --text4:#48484a;
  --border:#2c2c2e;
  --border2:#38383a;
  --nav-h:60px;--top-h:62px;--radius:14px;--radius-sm:10px;
  --brand-accent:#deff9a;
  --font-brand:'Playfair Display',Georgia,'Times New Roman',serif;
  --font-brand-sub:'Urbanist',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --shadow:0 2px 16px rgba(0,0,0,0.45);
}
html,body{height:100%;background:var(--bg);color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Noto Sans KR',sans-serif;overflow:hidden;}
#app{width:100%;max-width:430px;height:100%;margin:0 auto;position:relative;
  display:flex;flex-direction:column;overflow:hidden;background:var(--bg);}
#topbar{height:var(--top-h);min-height:var(--top-h);display:flex;align-items:center;
  justify-content:space-between;padding:0 16px;background:var(--bg);
  border-bottom:1px solid var(--border);z-index:50;flex-shrink:0;}
.logo-wrap{display:flex;align-items:center;cursor:pointer;user-select:none;-webkit-user-select:none;padding:1px 0;}
.brand-lockup{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:4px;line-height:1;}
.logo-wordmark{display:flex;align-items:baseline;gap:0;
  font-family:var(--font-brand);font-size:23px;font-weight:500;letter-spacing:.02em;line-height:1;}
.logo-y,.logo-s{color:#fff;font-family:var(--font-brand);font-weight:500;font-style:normal;}
.logo-amp{color:var(--brand-accent);font-family:var(--font-brand);font-weight:400;font-style:italic;
  margin:0 1px;transform:translateY(-1px);}
.logo-sub{font-family:var(--font-brand-sub);font-size:7px;font-weight:400;
  letter-spacing:5px;color:rgba(255,255,255,.42);text-transform:uppercase;padding-left:1px;
  white-space:nowrap;-webkit-font-smoothing:antialiased;}
.upload-progress-wrap{margin-top:12px;display:none;}
.upload-progress-wrap.active{display:block;}
.upload-progress-label{font-size:12px;color:var(--text3);text-align:center;margin-bottom:6px;letter-spacing:.02em;}
.upload-progress-bar{height:2px;background:var(--surface2);border-radius:1px;overflow:hidden;}
.upload-progress-fill{height:100%;background:var(--brand-accent);width:0%;transition:width .25s ease;border-radius:1px;}
.top-actions{display:flex;align-items:center;gap:4px;}
.icon-btn{width:36px;height:36px;border-radius:50%;border:none;background:transparent;
  color:var(--text3);font-size:17px;cursor:pointer;display:flex;align-items:center;
  justify-content:center;transition:background .15s;}
.icon-btn:hover{background:var(--surface2);}
.notif-dot{position:relative;}
.notif-dot::after{content:'';position:absolute;top:7px;right:7px;width:7px;height:7px;
  background:var(--gold);border-radius:50%;border:2px solid var(--bg);}
.lang-pill{font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px;
  border:1.5px solid var(--gold);color:var(--gold);background:transparent;
  cursor:pointer;letter-spacing:.6px;transition:all .15s;}
.lang-pill:hover{background:var(--goldfaint);}
#screen{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;
  padding-bottom:calc(var(--nav-h) + 8px);}
#screen::-webkit-scrollbar{display:none;}
#nav{height:var(--nav-h);display:flex;align-items:center;background:var(--bg);
  border-top:1px solid var(--border);flex-shrink:0;z-index:50;}
.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;cursor:pointer;padding:6px 0;border:none;background:transparent;
  color:var(--text4);transition:color .15s;font-size:9px;font-weight:600;letter-spacing:.4px;
  text-transform:uppercase;}
.nav-item.active{color:var(--gold);}
.nav-icon{font-size:20px;line-height:1;}
.feed{padding:0;}
.feed-card{background:var(--surface);border-bottom:1px solid var(--border);
  padding:16px;transition:box-shadow .6s;}
@keyframes goldShimmer{
  0%{box-shadow:0 0 0 rgba(212,175,55,0);}
  40%{box-shadow:0 0 0 3px rgba(212,175,55,0.35),0 0 24px rgba(212,175,55,0.2);}
  100%{box-shadow:0 0 0 rgba(212,175,55,0);}
}
.respect-flash{animation:goldShimmer .7s ease;}
.post-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;}
.avatar{width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold3),var(--gold));
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:14px;color:#111;flex-shrink:0;}
.avatar.sm{width:30px;height:30px;font-size:11px;}
.post-meta{flex:1;min-width:0;}
.post-name{font-size:14px;font-weight:700;color:var(--text);}
.post-handle{font-size:12px;color:var(--text3);}
.owner-actions{display:flex;gap:6px;align-self:flex-start;flex-shrink:0;}
.owner-btn{border:1px solid var(--border2);background:var(--surface2);color:var(--text3);
  border-radius:20px;padding:5px 9px;font-size:11px;font-weight:700;cursor:pointer;}
.owner-btn:hover{border-color:var(--gold);color:var(--gold);}
.owner-btn.danger:hover{border-color:#ff453a;color:#ff453a;}
.verified-badge{font-size:10px;color:var(--gold);border:1px solid rgba(212,175,55,.4);
  border-radius:20px;padding:1px 7px;font-weight:700;background:var(--goldfaint);}
.post-body{font-size:15px;line-height:1.65;color:var(--text2);margin-bottom:10px;}
.post-image{width:100%;display:block;border-radius:var(--radius-sm);margin:0 0 12px;
  object-fit:cover;max-height:430px;background:var(--surface2);}
.post-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px;}
.tag{font-size:12px;color:var(--gold);font-weight:600;}
.post-actions{display:flex;gap:4px;flex-wrap:wrap;}
.post-action{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text3);
  cursor:pointer;border:none;background:transparent;padding:6px 10px;
  border-radius:20px;transition:all .15s;font-weight:600;}
.post-action:hover{background:var(--surface2);color:var(--text2);}
.post-action.active{color:var(--gold);}
.respect-btn{border:1px solid var(--border2);}
.respect-btn.active{border-color:rgba(212,175,55,.4);background:var(--goldfaint);}
.ai-card{background:var(--surface2);border-left:3px solid var(--gold);
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;
  padding:14px 14px 14px 16px;margin:8px 0 10px;}
.ai-badge{font-size:10px;font-weight:800;letter-spacing:.8px;color:var(--gold);
  text-transform:uppercase;margin-bottom:7px;display:flex;align-items:center;gap:6px;}
.ai-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:5px;}
.ai-body{font-size:13px;line-height:1.65;color:var(--text2);}
.story-strip{display:flex;gap:12px;padding:14px 16px;overflow-x:auto;
  border-bottom:1px solid var(--border);}
.story-strip::-webkit-scrollbar{display:none;}
.story-item{display:flex;flex-direction:column;align-items:center;gap:5px;
  cursor:pointer;flex-shrink:0;}
.story-ring{width:52px;height:52px;border-radius:50%;padding:2px;
  background:var(--surface2);}
.story-ring.new{background:linear-gradient(135deg,var(--gold3),var(--gold2));}
.story-ring.mine{background:linear-gradient(135deg,var(--gold3),var(--gold2));}
.story-avatar{width:100%;height:100%;border-radius:50%;background:var(--surface3);
  border:2px solid var(--bg);display:flex;align-items:center;justify-content:center;
  font-size:18px;position:relative;}
.story-plus{position:absolute;right:-3px;bottom:-3px;width:18px;height:18px;border-radius:50%;
  background:var(--gold);color:#111;border:2px solid var(--bg);display:flex;align-items:center;
  justify-content:center;font-size:13px;font-weight:900;line-height:1;}
.story-name{font-size:10px;color:var(--text3);max-width:52px;text-align:center;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.story-view-media{width:100%;display:block;border-radius:var(--radius-sm);background:#000;
  max-height:70vh;object-fit:contain;}
.pill{font-size:12px;font-weight:600;padding:6px 14px;border-radius:20px;
  background:var(--surface2);color:var(--text3);border:1px solid var(--border2);
  cursor:pointer;transition:all .15s;white-space:nowrap;}
.pill:hover,.pill.active{background:var(--goldfaint);color:var(--gold);
  border-color:rgba(212,175,55,.4);}
.pill-row{display:flex;gap:8px;overflow-x:auto;padding:12px 16px;}
.pill-row::-webkit-scrollbar{display:none;}
.form-group{margin-bottom:16px;}
.form-label{display:block;font-size:12px;font-weight:600;color:var(--text3);
  margin-bottom:6px;letter-spacing:.4px;text-transform:uppercase;}
.form-input{width:100%;background:var(--surface2);border:1.5px solid var(--border2);
  border-radius:var(--radius-sm);padding:13px 14px;font-size:15px;color:var(--text);
  outline:none;transition:border .15s;-webkit-user-select:text;user-select:text;}
.form-input:focus{border-color:var(--gold);}
.form-input::placeholder{color:var(--text4);}
.image-preview{display:none;position:relative;margin-bottom:12px;border-radius:var(--radius-sm);
  overflow:hidden;border:1px solid var(--border2);background:var(--surface2);}
.image-preview img{width:100%;display:block;max-height:280px;object-fit:cover;}
.image-preview video{width:100%;display:block;max-height:320px;object-fit:cover;}
.image-preview button{position:absolute;top:8px;right:8px;width:30px;height:30px;border-radius:50%;
  border:none;background:rgba(0,0,0,.7);color:#fff;cursor:pointer;font-size:14px;}
.short-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;margin-bottom:16px;}
.short-media{width:100%;display:block;background:#000;max-height:620px;object-fit:cover;}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;
  font-weight:700;border:none;cursor:pointer;transition:all .18s;letter-spacing:.2px;}
.btn.gold{background:linear-gradient(135deg,var(--gold3),var(--gold));color:#111111;
  border-radius:var(--radius-sm);padding:15px 24px;font-size:15px;width:100%;}
.btn.gold:hover{filter:brightness(1.08);box-shadow:0 4px 18px rgba(212,175,55,.3);}
.btn.ghost{background:transparent;color:var(--text2);border:1.5px solid var(--border2);
  border-radius:var(--radius-sm);padding:10px 16px;font-size:13px;}
.btn.ghost:hover{border-color:var(--gold);color:var(--gold);}
.btn.outline-gold{background:transparent;color:var(--gold);
  border:1.5px solid rgba(212,175,55,.6);border-radius:var(--radius-sm);
  padding:11px 24px;font-size:14px;width:100%;}
.btn.outline-gold:hover{background:var(--goldfaint);}
.btn.danger{background:#3a1a1a;color:#ff453a;border:1.5px solid #3d1a1a;
  border-radius:var(--radius-sm);padding:13px 24px;font-size:14px;width:100%;}
.btn.danger:hover{background:#4a2020;}
.btn.sm{padding:8px 14px;font-size:12px;}
.btn.lg{padding:16px 24px;font-size:16px;}
#modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;
  display:none;align-items:flex-end;justify-content:center;}
#modal-overlay.open{display:flex;}
#modal-box{width:100%;max-width:430px;max-height:92vh;background:var(--surface);
  border-radius:var(--radius) var(--radius) 0 0;overflow:hidden;
  display:flex;flex-direction:column;animation:slideUp .22s ease;}
@keyframes slideUp{from{transform:translateY(100%);}to{transform:translateY(0);}}
#modal-header{display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0;}
#modal-title{font-size:16px;font-weight:700;color:var(--text);}
#modal-close{width:30px;height:30px;border-radius:50%;border:none;
  background:var(--surface2);color:var(--text3);font-size:16px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;}
#modal-body{overflow-y:auto;padding:20px;flex:1;}
#modal-body::-webkit-scrollbar{display:none;}
#toast{position:fixed;bottom:calc(var(--nav-h)+80px);left:50%;
  transform:translateX(-50%) translateY(16px);background:var(--surface3);
  color:var(--text);padding:10px 22px;border-radius:30px;font-size:14px;
  font-weight:600;z-index:300;opacity:0;transition:all .28s;pointer-events:none;
  border:1px solid var(--border2);white-space:nowrap;}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.onboard-wrap{min-height:100%;display:flex;flex-direction:column;align-items:center;
  justify-content:center;padding:40px 28px;text-align:center;position:relative;}
.ob-lang{position:absolute;top:20px;right:16px;}
.onboard-icon{font-size:60px;margin-bottom:22px;line-height:1;}
.onboard-title{font-size:26px;font-weight:900;line-height:1.2;margin-bottom:12px;
  background:linear-gradient(135deg,var(--gold3),var(--gold2));
  background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.onboard-sub{font-size:15px;color:var(--text3);line-height:1.75;margin-bottom:32px;
  max-width:300px;}
.onboard-dots{display:flex;gap:8px;justify-content:center;margin-bottom:32px;}
.dot{width:7px;height:7px;border-radius:50%;background:var(--surface3);}
.dot.active{background:var(--gold);width:22px;border-radius:4px;}
.profile-header{padding:24px 16px 16px;text-align:center;}
.profile-avatar-big{width:78px;height:78px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold3),var(--gold));
  display:flex;align-items:center;justify-content:center;
  font-size:28px;font-weight:700;color:#111;margin:0 auto 12px;}
.profile-name{font-size:19px;font-weight:800;margin-bottom:4px;}
.profile-handle{font-size:13px;color:var(--text3);margin-bottom:10px;}
.profile-bio{font-size:14px;color:var(--text2);line-height:1.6;margin-bottom:14px;}
.profile-stats{display:flex;justify-content:center;gap:28px;padding:16px 0;
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.stat-item{text-align:center;}
.stat-num{font-size:19px;font-weight:800;color:var(--gold);}
.stat-label{font-size:11px;color:var(--text3);margin-top:2px;}
.settings-section{margin-bottom:4px;}
.settings-label{font-size:10px;font-weight:700;color:var(--text4);letter-spacing:.9px;
  text-transform:uppercase;padding:16px 16px 6px;}
.settings-item{display:flex;align-items:center;gap:12px;padding:13px 16px;
  cursor:pointer;transition:background .12s;}
.settings-item:hover{background:var(--surface2);}
.settings-icon{width:34px;height:34px;border-radius:9px;display:flex;
  align-items:center;justify-content:center;font-size:17px;flex-shrink:0;}
.settings-text{flex:1;}
.settings-title{font-size:15px;font-weight:600;color:var(--text);}
.settings-sub{font-size:12px;color:var(--text3);margin-top:1px;}
.settings-arrow{color:var(--text4);font-size:15px;}
.lang-toggle-row{display:flex;gap:8px;margin-top:10px;}
.lang-opt{flex:1;padding:10px;border-radius:var(--radius-sm);border:1.5px solid var(--border2);
  background:var(--surface2);color:var(--text3);font-size:14px;font-weight:700;
  cursor:pointer;text-align:center;transition:all .15s;}
.lang-opt.active{border-color:var(--gold);color:var(--gold);background:var(--goldfaint);}
.dash-card{background:var(--surface);border-radius:var(--radius);padding:16px;
  margin:8px 16px;border:1px solid var(--border);}
.dash-title{font-size:11px;font-weight:700;color:var(--text3);letter-spacing:.7px;
  text-transform:uppercase;margin-bottom:12px;}
.growth-journal-card{background:var(--surface);border:1px solid rgba(212,175,55,.22);
  border-radius:var(--radius);padding:16px;box-shadow:0 4px 24px rgba(0,0,0,.18);}
.growth-journal-head{display:flex;align-items:center;gap:12px;margin-bottom:14px;}
.growth-journal-icon{font-size:28px;line-height:1;}
.growth-journal-title{font-size:15px;font-weight:800;color:var(--text);}
.growth-journal-sub{font-size:12px;color:var(--gold);margin-top:2px;}
.growth-journal-prompt{padding:28px 12px;text-align:center;}
.growth-vis-row{display:flex;align-items:center;justify-content:space-between;margin-top:12px;gap:10px;flex-wrap:wrap;}
.growth-vis-toggle{display:flex;gap:8px;}
.growth-vis-btn{padding:8px 14px;border-radius:20px;border:1.5px solid var(--border2);
  background:var(--surface2);color:var(--text3);font-size:12px;font-weight:700;cursor:pointer;transition:all .15s;}
.growth-vis-btn.active{border-color:var(--gold);color:var(--gold);background:var(--goldfaint);}
.growth-timeline-wrap{margin-top:4px;}
.growth-log-card{background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:14px 16px;margin-bottom:10px;
  border-left:3px solid var(--gold3);transition:transform .12s ease;}
.growth-log-card:active{transform:scale(.99);}
.growth-log-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:8px;}
.growth-log-card-icon{font-size:22px;flex-shrink:0;}
.growth-log-card-meta{flex:1;min-width:0;}
.growth-log-card-title{font-size:15px;font-weight:700;color:var(--text);line-height:1.35;}
.growth-log-card-date{font-size:11px;color:var(--text4);margin-top:3px;}
.growth-log-card-body{font-size:13px;color:var(--text2);line-height:1.65;white-space:pre-wrap;word-break:break-word;}
.growth-log-badge{font-size:10px;font-weight:700;padding:4px 8px;border-radius:12px;flex-shrink:0;}
.growth-log-badge.private{background:rgba(120,120,130,.2);color:var(--text3);}
.growth-log-badge.public{background:var(--goldfaint);color:var(--gold);}
.growth-log-feed-link{margin-top:10px;background:none;border:none;color:var(--gold);
  font-size:12px;font-weight:700;cursor:pointer;padding:0;}
.growth-log-empty{padding:24px 12px;text-align:center;color:var(--text4);font-size:13px;line-height:1.6;}
.growth-photo-row{display:flex;flex-wrap:wrap;align-items:flex-start;gap:10px;margin:12px 0 4px;}
.growth-photo-btn{flex-shrink:0;}
.growth-log-image-preview{position:relative;width:100%;max-width:220px;border-radius:var(--radius-sm);
  overflow:hidden;border:1px solid var(--border2);background:var(--surface2);}
.growth-log-image-preview img{width:100%;height:auto;max-height:160px;object-fit:cover;display:block;}
.growth-log-preview-clear{position:absolute;top:6px;right:6px;width:28px;height:28px;border-radius:50%;
  border:none;background:rgba(0,0,0,.65);color:#fff;font-size:14px;cursor:pointer;line-height:1;}
.growth-log-thumb{width:100%;max-height:200px;object-fit:cover;border-radius:var(--radius-sm);
  margin:0 0 10px;border:1px solid var(--border);}
.growth-log-cat-chip{font-size:11px;font-weight:700;color:var(--gold);background:var(--goldfaint);
  padding:4px 10px;border-radius:14px;border:1px solid rgba(212,175,55,.25);}
.growth-timeline-section{margin-top:4px;}
.growth-timeline-rail{display:flex;flex-direction:column;gap:0;}
.growth-timeline-item{display:flex;gap:12px;align-items:stretch;}
.growth-timeline-track{display:flex;flex-direction:column;align-items:center;width:18px;flex-shrink:0;padding-top:18px;}
.growth-timeline-dot{width:10px;height:10px;border-radius:50%;background:var(--gold);
  box-shadow:0 0 8px rgba(212,175,55,.55);flex-shrink:0;}
.growth-timeline-line{flex:1;width:2px;min-height:24px;background:linear-gradient(180deg,var(--gold3),var(--border));
  margin-top:4px;}
.growth-timeline-item .growth-log-card{flex:1;margin-bottom:14px;}
.dash-cal-card{padding:14px 12px 12px;}
.dash-cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.dash-cal-month{font-size:14px;font-weight:800;color:var(--text);}
.dash-cal-nav{background:var(--surface2);border:1px solid var(--border2);color:var(--text2);
  width:32px;height:32px;border-radius:8px;cursor:pointer;font-size:14px;}
.dash-cal-filter-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;
  font-size:12px;color:var(--text3);}
.dash-cal-clear{background:none;border:none;color:var(--gold);font-size:12px;font-weight:700;cursor:pointer;}
.dash-cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px;}
.dash-cal-wd{text-align:center;font-size:10px;font-weight:700;color:var(--text4);padding:4px 0;}
.dash-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;}
.dash-cal-day{position:relative;aspect-ratio:1;border:none;border-radius:10px;background:var(--surface2);
  color:var(--text2);font-size:12px;font-weight:600;cursor:pointer;transition:all .12s;}
.dash-cal-day.empty{background:transparent;cursor:default;}
.dash-cal-day.today{border:1.5px solid var(--gold);}
.dash-cal-day.has-growth{color:var(--gold);}
.dash-cal-day.selected{background:var(--goldfaint);color:var(--gold);border:1.5px solid var(--gold);}
.dash-cal-dot{position:absolute;bottom:4px;left:50%;transform:translateX(-50%);width:5px;height:5px;
  border-radius:50%;background:var(--gold2);box-shadow:0 0 6px var(--gold);}
.dash-week-key{color:var(--gold);font-weight:700;}
.dash-streak-inline{margin-bottom:12px;}
.weekly-goal-add-row{display:flex;gap:8px;margin-bottom:12px;align-items:stretch;flex-wrap:nowrap;}
.weekly-goal-add-row .form-input,
#weeklyGoalInput,
#weeklyGoalEditInput{
  flex:1;min-width:0;background:#1a1a1a;color:#ffffff;
  border:1.5px solid var(--border2);padding:10px 12px;font-size:14px;
  -webkit-text-fill-color:#ffffff;}
.weekly-goal-add-row .form-input:focus,
#weeklyGoalInput:focus,
#weeklyGoalEditInput:focus{
  border-color:var(--brand-accent);box-shadow:0 0 0 1px rgba(222,255,154,.25);outline:none;}
.weekly-goal-add-row .form-input::placeholder,
#weeklyGoalInput::placeholder,
#weeklyGoalEditInput::placeholder{color:rgba(255,255,255,.35);}
.weekly-goal-add-row .btn.gold{
  width:auto;flex-shrink:0;padding:10px 14px;font-size:14px;font-weight:600;
  border-radius:10px;white-space:nowrap;min-height:40px;}
.weekly-goal-edit-row .form-input{background:#1a1a1a;color:#ffffff;-webkit-text-fill-color:#ffffff;}
.weekly-goal-edit-row .form-input:focus{border-color:var(--brand-accent);box-shadow:0 0 0 1px rgba(222,255,154,.25);}
.weekly-goal-list{list-style:none;margin:0;padding:0;}
.weekly-goal-item{padding:10px 0;border-bottom:1px solid var(--border);}
.weekly-goal-item.editing{padding:12px 0;}
.weekly-goal-item.done .weekly-goal-text{text-decoration:line-through;color:var(--text4);}
.weekly-goal-row{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;}
.weekly-goal-edit-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px;}
.weekly-goal-label{display:flex;align-items:flex-start;gap:10px;cursor:pointer;flex:1;min-width:0;}
.weekly-goal-actions{display:flex;gap:4px;flex-shrink:0;}
.dash-action-btn{background:var(--surface2);border:1px solid var(--border2);border-radius:8px;
  width:32px;height:32px;font-size:14px;cursor:pointer;line-height:1;padding:0;transition:all .12s;}
.dash-action-btn:hover{border-color:var(--gold);background:var(--goldfaint);}
.dash-action-btn.danger:hover{border-color:#e55;color:#e55;background:rgba(229,85,85,.12);}
.growth-log-card-top-right{display:flex;align-items:center;gap:8px;margin-left:auto;}
.growth-log-card-actions{display:flex;gap:4px;}
.weekly-goal-label input{margin-top:3px;accent-color:var(--gold);flex-shrink:0;}
.weekly-goal-text{font-size:14px;color:var(--text2);line-height:1.5;}
.weekly-goal-empty{padding:16px 0;text-align:center;color:var(--text4);font-size:13px;}
.progress-item{margin-bottom:14px;}
.progress-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;}
.progress-name{font-size:14px;font-weight:600;color:var(--text2);}
.progress-pct{font-size:13px;font-weight:700;color:var(--gold);}
.progress-bar{height:5px;background:var(--surface2);border-radius:3px;overflow:hidden;}
.progress-fill{height:100%;border-radius:3px;
  background:linear-gradient(90deg,var(--gold3),var(--gold2));transition:width .9s ease;}
.streak-badge{display:flex;align-items:center;gap:12px;padding:14px 16px;
  background:var(--surface);border:1px solid rgba(212,175,55,.25);
  border-radius:var(--radius);margin:0 16px 8px;}
.streak-num{font-size:30px;font-weight:900;color:var(--gold);line-height:1;}
.streak-text{font-size:14px;color:var(--text2);}
.streak-sub{font-size:12px;color:var(--text3);margin-top:2px;}
.explore-search{margin:14px 16px;position:relative;}
.search-input{width:100%;background:var(--surface2);border:1.5px solid var(--border2);
  border-radius:30px;padding:11px 16px 11px 42px;font-size:15px;color:var(--text);
  outline:none;-webkit-user-select:text;user-select:text;}
.search-input:focus{border-color:var(--gold);}
.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);
  color:var(--text4);font-size:16px;}
.trend-item{display:flex;align-items:center;padding:12px 16px;cursor:pointer;
  border-bottom:1px solid var(--border);transition:background .12s;}
.trend-item:hover{background:var(--surface2);}
.trend-rank{font-size:13px;font-weight:800;color:var(--gold);width:26px;}
.trend-content{flex:1;}
.trend-tag{font-size:15px;font-weight:700;color:var(--text);}
.trend-count{font-size:12px;color:var(--text3);margin-top:2px;}
.dm-item{display:flex;align-items:center;gap:12px;padding:13px 16px;cursor:pointer;
  border-bottom:1px solid var(--border);transition:background .12s;}
.dm-item:hover{background:var(--surface2);}
.dm-info{flex:1;min-width:0;}
.dm-name{font-size:14px;font-weight:700;color:var(--text);}
.dm-preview{font-size:13px;color:var(--text3);overflow:hidden;text-overflow:ellipsis;
  white-space:nowrap;margin-top:2px;}
.dm-time{font-size:11px;color:var(--text4);}
.unread-dot{width:7px;height:7px;background:var(--gold);border-radius:50%;flex-shrink:0;}
.section-header{display:flex;align-items:center;justify-content:space-between;
  padding:16px 16px 8px;}
.section-title{font-size:16px;font-weight:800;color:var(--text);}
.section-more{font-size:13px;color:var(--gold);font-weight:600;cursor:pointer;}
.legal-section{margin-bottom:18px;}
.legal-h{font-size:14px;font-weight:700;color:var(--gold);margin-bottom:7px;}
.legal-p{font-size:13px;line-height:1.75;color:var(--text2);}
.founder-card{background:var(--surface2);border-left:3px solid var(--gold);
  border-radius:0 var(--radius) var(--radius) 0;padding:18px 18px 18px 20px;margin-bottom:20px;}
.founder-quote{font-size:15px;font-style:italic;line-height:1.8;color:var(--text2);margin-bottom:12px;}
.founder-sig{font-size:13px;font-weight:700;color:var(--gold);}
.gold-bar{height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:8px 0;}
.copyright{font-size:11px;color:var(--text4);text-align:center;padding:16px;line-height:1.7;}

/* ── CATEGORY BAR ── */
.cat-bar{display:flex;gap:6px;padding:10px 16px;overflow-x:auto;flex-shrink:0;
  border-bottom:1px solid var(--border);scroll-behavior:smooth;}
.cat-bar::-webkit-scrollbar{display:none;}
.cat-btn{flex-shrink:0;padding:7px 13px;border-radius:20px;border:1.5px solid var(--border2);
  background:transparent;color:var(--text3);font-size:13px;font-weight:600;cursor:pointer;
  transition:all .18s;white-space:nowrap;line-height:1;}
.cat-btn.active{background:linear-gradient(135deg,var(--gold3),var(--gold));
  border-color:var(--gold);color:#111;font-weight:700;}
.cat-btn:hover:not(.active){border-color:var(--gold);color:var(--gold);}
.subcat-bar{display:flex;gap:6px;padding:0 16px;overflow-x:auto;overflow-y:hidden;
  max-height:0;transition:max-height .25s ease,padding .25s ease;}
.subcat-bar::-webkit-scrollbar{display:none;}
.subcat-bar.open{max-height:50px;padding:8px 16px;}
.subcat-btn{flex-shrink:0;padding:5px 11px;border-radius:20px;border:1.5px solid var(--border2);
  background:transparent;color:var(--text3);font-size:12px;font-weight:600;cursor:pointer;
  transition:all .18s;white-space:nowrap;line-height:1;}
.subcat-btn.active{background:var(--gold3);border-color:var(--gold3);color:#fff;}
.subcat-btn:hover:not(.active){border-color:var(--gold3);color:var(--gold3);}

/* ── AGE NOTICE & AGREE ── */
.age-notice{display:flex;align-items:flex-start;gap:8px;
  background:rgba(212,175,55,0.10);border:1px solid rgba(212,175,55,0.35);
  border-radius:var(--radius-sm);padding:11px 14px;margin-bottom:16px;
  font-size:13px;color:var(--text2);line-height:1.55;}
.age-notice-icon{font-size:15px;flex-shrink:0;margin-top:1px;color:var(--gold);}
.age-notice strong{color:var(--gold);font-weight:700;}
.age-agree-label{display:flex;align-items:flex-start;gap:10px;cursor:pointer;
  background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-sm);
  padding:12px 14px;font-size:13px;color:var(--text2);line-height:1.6;}
.age-agree-label:hover{border-color:var(--gold);}
.age-agree-link{color:var(--gold);text-decoration:underline;cursor:pointer;}

/* ── PROFILE PHOTO ── */
.profile-avatar-photo{width:78px;height:78px;border-radius:50%;overflow:hidden;
  margin:0 auto 12px;border:2.5px solid var(--gold);flex-shrink:0;}
.profile-avatar-photo img{width:100%;height:100%;object-fit:cover;display:block;}

/* ── HEADER ACTION BUTTONS ── */
.post-quick-btn{font-size:18px;font-weight:700;color:var(--gold);
  width:34px;height:34px;border-radius:50%;}
.post-quick-btn:hover{background:var(--goldfaint);}
.dm-btn{font-size:17px;width:34px;height:34px;
  background:linear-gradient(135deg,var(--gold3),var(--gold));
  border-radius:50%;color:#111 !important;}
.dm-btn:hover{opacity:.82;}

/* ── CHAT LIST ── */
.chat-list-header{display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px 10px;border-bottom:1px solid var(--border);}

/* ── CHAT ROOM ── */
.chat-header{display:flex;align-items:center;gap:10px;padding:10px 12px;
  border-bottom:1px solid var(--border);background:var(--bg);
  position:sticky;top:0;z-index:10;}
.chat-messages{flex:1;overflow-y:auto;padding:12px 14px;
  display:flex;flex-direction:column;gap:8px;
  min-height:calc(100vh - 170px);max-height:calc(100vh - 170px);}
.chat-messages::-webkit-scrollbar{display:none;}
.chat-msg-row{display:flex;align-items:flex-end;}
.chat-msg-row.mine{justify-content:flex-end;}
.chat-msg-row.theirs{justify-content:flex-start;}
.chat-meta-col{display:flex;flex-direction:column;justify-content:flex-end;padding:0 4px 6px;}
.read-badge{font-size:10px;white-space:nowrap;line-height:1.2;}
.read-badge.read{color:var(--gold);}
.read-badge.unread{color:var(--text4);}
.chat-bubble{max-width:72%;padding:10px 13px;border-radius:18px;
  font-size:14px;line-height:1.5;word-break:break-word;position:relative;}
.chat-msg-row.mine .chat-bubble{
  background:linear-gradient(135deg,var(--gold3),var(--gold));color:#111;
  border-bottom-right-radius:4px;}
.chat-msg-row.theirs .chat-bubble{
  background:var(--surface2);color:var(--text);
  border-bottom-left-radius:4px;}
.chat-msg-img{max-width:200px;border-radius:12px;display:block;
  margin-bottom:4px;cursor:pointer;object-fit:cover;}
.chat-time{font-size:10px;opacity:.6;margin-top:4px;text-align:right;}
.chat-input-bar{display:flex;align-items:center;gap:6px;padding:8px 10px;
  border-top:1px solid var(--border);background:var(--bg);
  position:sticky;bottom:0;}
.chat-text-input{flex:1;background:var(--surface2);border:1.5px solid var(--border2);
  border-radius:22px;padding:10px 15px;font-size:14px;color:var(--text);
  outline:none;-webkit-user-select:text;user-select:text;}
.chat-text-input:focus{border-color:var(--gold);}
.chat-send-btn{width:38px;height:38px;border-radius:50%;border:none;
  background:linear-gradient(135deg,var(--gold3),var(--gold));
  color:#111;font-size:16px;cursor:pointer;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;}

/* ── EXPLORE USER ROW ── */
.explore-user-row{display:flex;align-items:center;gap:12px;padding:12px 16px;
  border-bottom:1px solid var(--border);transition:background .12s;}
.explore-user-row:hover{background:var(--surface2);}
