@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;600;700&family=Noto+Sans+SC:wght@400;500;700&display=swap');

:root {
  --bg:        #0d1117;
  --surface:   #161b22;
  --surface2:  #21262d;
  --border:    #30363d;
  --accent:    #58a6ff;
  --accent2:   #3fb950;
  --warning:   #d29922;
  --danger:    #f85149;
  --text:      #e6edf3;
  --text-sub:  #8b949e;
  --radius:    12px;
  --shadow:    0 4px 24px rgba(0,0,0,.45);
  --mood-happy:  #3fb950;
  --mood-normal: #58a6ff;
  --mood-sad:    #8b949e;
  --mood-hungry: #d29922;
  --mood-sick:   #f85149;
  --hunger-clr:    #f0883e;
  --happiness-clr: #58a6ff;
  --health-clr:    #3fb950;
  --exp-clr:       #bc8cff;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 15px; }
body {
  font-family: 'Sora', 'Noto Sans SC', sans-serif;
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
  line-height: 1.6;
}
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

/* Navbar */
.navbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .75rem 2rem;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 100;
}
.nav-brand { font-size: 1.2rem; font-weight: 700; color: var(--text); letter-spacing: -.02em; }
.nav-links { display: flex; align-items: center; gap: 1.4rem; }
.nav-links a { color: var(--text-sub); font-size: .9rem; font-weight: 500; transition: color .2s; }
.nav-links a:hover, .nav-links a.active { color: var(--text); text-decoration: none; }
.coin-badge {
  background: rgba(210,153,34,.15);
  color: var(--warning);
  padding: .25rem .7rem;
  border-radius: 20px;
  font-size: .85rem;
  font-weight: 600;
  border: 1px solid rgba(210,153,34,.3);
}
.btn-logout {
  background: rgba(248,81,73,.12);
  color: var(--danger) !important;
  padding: .3rem .8rem;
  border-radius: 8px;
  border: 1px solid rgba(248,81,73,.25);
  transition: background .2s;
}
.btn-logout:hover { background: rgba(248,81,73,.25); text-decoration: none !important; }

/* Main */
.main-content { max-width: 1100px; margin: 0 auto; padding: 2rem 1.5rem; }

/* Messages */
.messages { margin-bottom: 1rem; }
.message, .alert { padding: .75rem 1rem; border-radius: var(--radius); margin-bottom: .5rem; font-size: .9rem; }
.alert-error, .message-error { background: rgba(248,81,73,.12); border: 1px solid rgba(248,81,73,.3); color: #ffa198; }
.alert-success, .message-success { background: rgba(63,185,80,.1); border: 1px solid rgba(63,185,80,.3); color: #56d364; }

/* Buttons */
.btn-primary {
  display: inline-flex; align-items: center; gap: .4rem;
  background: var(--accent); color: #0d1117;
  font-weight: 700; font-size: .95rem;
  padding: .6rem 1.4rem; border-radius: 8px;
  border: none; cursor: pointer;
  transition: opacity .2s, transform .1s;
}
.btn-primary:hover { opacity: .85; text-decoration: none; color: #0d1117; }
.btn-primary:active { transform: scale(.97); }
.btn-primary.btn-full { width: 100%; justify-content: center; padding: .8rem; font-size: 1rem; }
.btn-secondary {
  display: inline-flex; align-items: center;
  background: var(--surface2); color: var(--text);
  font-weight: 600; font-size: .95rem;
  padding: .6rem 1.4rem; border-radius: 8px;
  border: 1px solid var(--border); cursor: pointer;
  transition: background .2s;
}
.btn-secondary:hover { background: var(--border); }
.btn-back {
  color: var(--text-sub); font-size: .9rem;
  padding: .3rem .6rem; border-radius: 6px;
  background: var(--surface2); border: 1px solid var(--border);
}
.btn-back:hover { color: var(--text); text-decoration: none; }

/* Cards */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.4rem;
  margin-bottom: 1rem;
}
.card h3, .card h4 { margin-bottom: .9rem; color: var(--text-sub); text-transform: uppercase; letter-spacing: .05em; font-size: .8rem; }

/* Auth */
.auth-wrapper { display: flex; justify-content: center; align-items: flex-start; padding-top: 4rem; }
.auth-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 2.5rem 2rem;
  width: 100%; max-width: 480px;
  box-shadow: var(--shadow);
}
.auth-header { text-align: center; margin-bottom: 2rem; }
.auth-icon { font-size: 3rem; margin-bottom: .5rem; }
.auth-header h1 { font-size: 1.6rem; font-weight: 700; margin-bottom: .3rem; }
.auth-header p { color: var(--text-sub); font-size: .95rem; }
.auth-footer { text-align: center; margin-top: 1.5rem; color: var(--text-sub); font-size: .9rem; }
.auth-form, .profile-form { display: flex; flex-direction: column; gap: .9rem; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: .9rem; }
.form-group { display: flex; flex-direction: column; gap: .35rem; }
.form-group label { font-size: .85rem; color: var(--text-sub); font-weight: 500; }
.form-group input, .form-group select, .form-group textarea {
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: 8px; color: var(--text);
  padding: .6rem .9rem; font-size: .95rem; font-family: inherit;
  transition: border-color .2s;
}
.form-group input:focus, .form-group select:focus { outline: none; border-color: var(--accent); }
.required { color: var(--danger); }

/* Page Layout */
.page-container { max-width: 1000px; margin: 0 auto; }
.page-header { display: flex; align-items: center; gap: 1rem; margin-bottom: 2rem; flex-wrap: wrap; }
.page-header h2 { font-size: 1.5rem; font-weight: 700; flex: 1; }
.sub-text { color: var(--text-sub); font-size: .9rem; }

/* Pet Grid */
.pet-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 1.2rem; }
.pet-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 1.3rem;
  cursor: pointer; position: relative; display: block; color: var(--text);
  transition: border-color .2s, transform .2s, box-shadow .2s;
}
.pet-card:hover {
  border-color: var(--accent); transform: translateY(-3px);
  box-shadow: 0 8px 32px rgba(88,166,255,.15);
  text-decoration: none; color: var(--text);
}
.pet-card.pet-dead { opacity: .5; }
.pet-card-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: .8rem; }
.pet-type-badge {
  background: rgba(88,166,255,.15); color: var(--accent);
  padding: .2rem .6rem; border-radius: 20px;
  font-size: .75rem; font-weight: 600;
  border: 1px solid rgba(88,166,255,.25);
}
.pet-avatar-large { font-size: 3.5rem; text-align: center; margin: .5rem 0; }
.pet-name { font-size: 1.1rem; font-weight: 700; text-align: center; margin-bottom: .3rem; }
.pet-level { text-align: center; color: var(--text-sub); font-size: .82rem; margin-bottom: .9rem; }
.dead-overlay {
  position: absolute; inset: 0;
  background: rgba(13,17,23,.7); border-radius: var(--radius);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; color: var(--danger); font-size: 1.1rem; letter-spacing: .05em;
}

/* Stat Bars */
.pet-stats { display: flex; flex-direction: column; gap: .45rem; }
.stat-row { display: grid; grid-template-columns: 60px 1fr 28px; align-items: center; gap: .5rem; }
.stat-label { font-size: .75rem; color: var(--text-sub); }
.stat-bar { height: 7px; background: var(--surface2); border-radius: 4px; overflow: hidden; }
.stat-fill { height: 100%; border-radius: 4px; transition: width .4s ease; }
.stat-fill.hunger    { background: var(--hunger-clr); }
.stat-fill.happiness { background: var(--happiness-clr); }
.stat-fill.health    { background: var(--health-clr); }
.stat-fill.exp       { background: var(--exp-clr); }
.stat-val { font-size: .75rem; color: var(--text-sub); text-align: right; }
.stat-row-lg { display: grid; grid-template-columns: 90px 1fr 56px; align-items: center; gap: .7rem; margin-bottom: .7rem; }
.stat-label-lg { font-size: .85rem; color: var(--text-sub); }
.stat-bar-lg { height: 10px; background: var(--surface2); border-radius: 5px; overflow: hidden; }
.stat-num { font-size: .82rem; color: var(--text-sub); text-align: right; }

/* Mood Tags */
.pet-mood, .mood-tag { font-size: .75rem; font-weight: 600; padding: .2rem .55rem; border-radius: 20px; }
.mood-happy  { background: rgba(63,185,80,.15);  color: var(--mood-happy);  border: 1px solid rgba(63,185,80,.25); }
.mood-normal { background: rgba(88,166,255,.12); color: var(--mood-normal); border: 1px solid rgba(88,166,255,.2); }
.mood-sad    { background: rgba(139,148,158,.12);color: var(--mood-sad);    border: 1px solid rgba(139,148,158,.2); }
.mood-hungry { background: rgba(210,153,34,.15); color: var(--mood-hungry); border: 1px solid rgba(210,153,34,.25); }
.mood-sick   { background: rgba(248,81,73,.12);  color: var(--mood-sick);   border: 1px solid rgba(248,81,73,.2); }

/* Pet Detail */
.detail-layout { display: grid; grid-template-columns: 340px 1fr; gap: 1.5rem; }
@media (max-width: 700px) { .detail-layout { grid-template-columns: 1fr; } }
.pet-display {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 2rem 1.5rem;
  text-align: center; margin-bottom: 1.2rem;
}
.pet-avatar-xl { font-size: 6rem; margin-bottom: .5rem; }
.pet-name-lg { font-size: 1.6rem; font-weight: 700; margin-bottom: .5rem; }
.level-badge {
  display: inline-block;
  background: rgba(188,140,255,.15); color: #bc8cff;
  padding: .25rem .8rem; border-radius: 20px;
  font-size: .85rem; font-weight: 700; margin-top: .5rem;
  border: 1px solid rgba(188,140,255,.25);
}
.action-panel { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.2rem; }
.action-panel h4 { color: var(--text-sub); font-size: .8rem; text-transform: uppercase; letter-spacing: .05em; margin-bottom: .9rem; }
.action-btns { display: flex; flex-direction: column; gap: .7rem; }
.action-btn {
  display: flex; flex-direction: column; align-items: flex-start;
  width: 100%; padding: .85rem 1.1rem;
  border-radius: 10px; border: 1px solid var(--border);
  background: var(--surface2); color: var(--text);
  font-family: inherit; font-size: .95rem; font-weight: 600;
  cursor: pointer; transition: border-color .2s, background .2s;
}
.action-btn .action-sub { font-size: .75rem; color: var(--text-sub); font-weight: 400; margin-top: .15rem; }
.feed-btn:hover  { border-color: var(--hunger-clr); background: rgba(240,136,62,.08); }
.play-btn:hover  { border-color: var(--happiness-clr); background: rgba(88,166,255,.08); }
.heal-btn:hover  { border-color: var(--health-clr); background: rgba(63,185,80,.08); }
.dead-notice { text-align: center; color: var(--danger); padding: 1.5rem; font-size: 1rem; }
.info-row { display: flex; justify-content: space-between; padding: .5rem 0; border-bottom: 1px solid var(--border); font-size: .9rem; }
.info-row:last-child { border-bottom: none; }
.info-row .label { color: var(--text-sub); }
.coins { color: var(--warning); font-weight: 700; }

/* Profile */
.profile-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 1.5rem;
  display: flex; align-items: center; gap: 1.5rem; margin-bottom: 1.5rem;
}
.profile-avatar img { width: 72px; height: 72px; border-radius: 50%; object-fit: cover; }
.avatar-placeholder {
  width: 72px; height: 72px; border-radius: 50%;
  background: var(--accent); color: #0d1117;
  display: flex; align-items: center; justify-content: center;
  font-size: 2rem; font-weight: 700;
}
.profile-info { display: flex; flex-direction: column; gap: .4rem; }

/* Adopt / Pet Types */
.pet-type-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 1.2rem; }
.pet-type-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 1.3rem;
  cursor: pointer; text-align: center;
  transition: border-color .2s, transform .2s;
}
.pet-type-card:hover { border-color: var(--accent); transform: translateY(-2px); }
.pt-image { margin-bottom: .8rem; }
.pt-image img { width: 80px; height: 80px; object-fit: cover; border-radius: 8px; }
.pt-emoji { font-size: 3.5rem; }
.pet-type-card h3 { font-size: 1.05rem; margin-bottom: .4rem; }
.pet-type-card p { font-size: .82rem; color: var(--text-sub); margin-bottom: .8rem; }
.pt-cost { margin-top: auto; }
.free-badge { background: rgba(63,185,80,.15); color: var(--accent2); padding: .2rem .7rem; border-radius: 20px; font-size: .8rem; font-weight: 600; border: 1px solid rgba(63,185,80,.25); }
.cost-badge { background: rgba(210,153,34,.12); color: var(--warning); padding: .2rem .7rem; border-radius: 20px; font-size: .8rem; font-weight: 600; border: 1px solid rgba(210,153,34,.25); }

/* Modal */
.modal-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.65); backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  z-index: 1000;
}
.modal {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 16px; padding: 2rem;
  width: 100%; max-width: 420px;
  box-shadow: var(--shadow);
  animation: modalIn .2s ease;
}
@keyframes modalIn { from { opacity:0; transform: scale(.95) translateY(8px); } to { opacity:1; transform: none; } }
.modal-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 1.2rem; }
.modal-header h3 { font-size: 1.1rem; font-weight: 700; }
.modal-close { background: none; border: none; color: var(--text-sub); font-size: 1.4rem; cursor: pointer; padding: 0 .3rem; line-height: 1; }
.modal-close:hover { color: var(--text); }
.modal-cost { color: var(--warning); font-size: .9rem; margin: .8rem 0; }
.modal-actions { display: flex; gap: .8rem; justify-content: flex-end; margin-top: 1.2rem; }

/* Leaderboard */
.leaderboard-table-wrap { overflow-x: auto; }
.leaderboard-table { width: 100%; border-collapse: collapse; }
.leaderboard-table th {
  background: var(--surface2); color: var(--text-sub);
  font-size: .8rem; text-transform: uppercase; letter-spacing: .05em;
  padding: .75rem 1rem; text-align: left;
  border-bottom: 1px solid var(--border);
}
.leaderboard-table td { padding: .75rem 1rem; border-bottom: 1px solid var(--border); font-size: .9rem; }
.leaderboard-table tr:hover td { background: var(--surface2); }
.leaderboard-table .rank { font-size: 1.1rem; }
.leaderboard-table .pet-name-cell a { color: var(--accent); }
.leaderboard-table .top-1 td { background: rgba(210,153,34,.07); }
.leaderboard-table .top-2 td { background: rgba(139,148,158,.07); }
.leaderboard-table .top-3 td { background: rgba(240,136,62,.07); }
.empty-row { text-align: center; color: var(--text-sub); padding: 3rem !important; }

/* Empty State */
.empty-state { text-align: center; padding: 4rem 2rem; }
.empty-icon { font-size: 4rem; margin-bottom: 1rem; }
.empty-state h3 { font-size: 1.3rem; margin-bottom: .5rem; }
.empty-state p { color: var(--text-sub); margin-bottom: 1.5rem; }

/* Food Shop */
.food-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.2rem; }
.food-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.3rem;
  display: grid;
  grid-template-columns: 64px 1fr auto;
  align-items: start;
  gap: 1rem;
  transition: border-color .2s, transform .2s;
}
.food-card:hover { border-color: var(--accent); transform: translateY(-2px); }
.food-icon { font-size: 2.8rem; text-align: center; line-height: 1; padding-top: .2rem; }
.food-info h3 { font-size: 1rem; font-weight: 700; margin-bottom: .3rem; }
.food-desc { font-size: .82rem; color: var(--text-sub); margin-bottom: .6rem; }
.food-effects { display: flex; flex-wrap: wrap; gap: .35rem; }
.effect-tag { font-size: .72rem; font-weight: 600; padding: .15rem .5rem; border-radius: 20px; }
.hunger-tag  { background: rgba(240,136,62,.15); color: var(--hunger-clr);    border: 1px solid rgba(240,136,62,.25); }
.happy-tag   { background: rgba(88,166,255,.12); color: var(--happiness-clr); border: 1px solid rgba(88,166,255,.2); }
.health-tag  { background: rgba(63,185,80,.12);  color: var(--health-clr);    border: 1px solid rgba(63,185,80,.2); }
.exp-tag     { background: rgba(188,140,255,.12);color: var(--exp-clr);       border: 1px solid rgba(188,140,255,.2); }
.food-buy { display: flex; flex-direction: column; align-items: flex-end; gap: .6rem; white-space: nowrap; }
.food-price { color: var(--warning); font-weight: 700; font-size: .9rem; }
.btn-buy { padding: .45rem 1rem; font-size: .85rem; }
.btn-buy:disabled { opacity: .4; cursor: not-allowed; }

/* Shop Layout */
.shop-layout { display: grid; grid-template-columns: 240px 1fr; gap: 1.5rem; align-items: start; }
@media (max-width: 700px) { .shop-layout { grid-template-columns: 1fr; } }

/* Inventory Panel (shop sidebar) */
.inventory-panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  position: sticky;
  top: 72px;
}
.inventory-header {
  padding: .85rem 1rem;
  border-bottom: 1px solid var(--border);
  background: var(--surface2);
}
.inventory-header h3 { font-size: .9rem; font-weight: 700; margin: 0; }
.inventory-list { list-style: none; padding: .5rem 0; margin: 0; }
.inventory-item {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .55rem 1rem;
  border-bottom: 1px solid var(--border);
  font-size: .88rem;
}
.inventory-item:last-child { border-bottom: none; }
.inv-icon { font-size: 1.3rem; flex-shrink: 0; }
.inv-name { flex: 1; color: var(--text); }
.inv-qty {
  background: rgba(88,166,255,.15);
  color: var(--accent);
  padding: .1rem .5rem;
  border-radius: 20px;
  font-size: .78rem;
  font-weight: 700;
  border: 1px solid rgba(88,166,255,.25);
}
.inv-empty { padding: 2rem 1rem; text-align: center; color: var(--text-sub); }
.inv-empty span { font-size: 2rem; display: block; margin-bottom: .5rem; }
.inv-empty p { font-size: .85rem; margin: 0; }
.inv-hint { font-size: .75rem !important; margin-top: .3rem !important; opacity: .6; }

/* Inventory feed panel (pet detail) */
.inv-feed-panel {
  margin-top: 1rem;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.inv-feed-panel h4 {
  padding: .7rem 1rem;
  margin: 0;
  background: var(--surface2);
  border-bottom: 1px solid var(--border);
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-sub);
}
.inv-feed-list { display: flex; flex-direction: column; gap: 0; }
.inv-feed-btn {
  display: flex;
  align-items: center;
  gap: .7rem;
  width: 100%;
  padding: .65rem 1rem;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--border);
  color: var(--text);
  font-family: inherit;
  font-size: .9rem;
  cursor: pointer;
  text-align: left;
  transition: background .15s;
}
.inv-feed-btn:last-child { border-bottom: none; }
.inv-feed-btn:hover { background: var(--surface2); }
.inv-feed-icon { font-size: 1.4rem; flex-shrink: 0; }
.inv-feed-name { flex: 1; font-weight: 500; }
.inv-feed-qty {
  background: rgba(63,185,80,.12);
  color: var(--health-clr);
  padding: .15rem .5rem;
  border-radius: 20px;
  font-size: .78rem;
  font-weight: 700;
  border: 1px solid rgba(63,185,80,.2);
}
.inv-feed-empty {
  margin-top: 1rem;
  padding: .75rem 1rem;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-size: .85rem;
  color: var(--text-sub);
  text-align: center;
}

/* Tasks Page */
.tasks-meta { display: flex; align-items: center; gap: .8rem; flex-wrap: wrap; }
.date-badge { background: var(--surface2); border: 1px solid var(--border); color: var(--text-sub); padding: .25rem .7rem; border-radius: 20px; font-size: .85rem; }

.coin-progress-wrap { display: flex; align-items: center; gap: .8rem; margin-bottom: 1.8rem; }
.coin-progress-bar { flex: 1; height: 12px; background: var(--surface2); border-radius: 6px; overflow: hidden; border: 1px solid var(--border); }
.coin-progress-fill { height: 100%; background: linear-gradient(90deg, var(--warning), #f0a030); border-radius: 6px; transition: width .5s ease; min-width: 4px; }
.coin-progress-label { font-size: .85rem; color: var(--warning); font-weight: 700; white-space: nowrap; }

.task-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 1.1rem; }
.task-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.2rem; transition: border-color .2s; }
.task-card.task-confirmed { border-color: rgba(63,185,80,.4); background: rgba(63,185,80,.04); }
.task-card.task-rejected  { border-color: rgba(248,81,73,.3); opacity: .6; }
.task-card.task-pending   { border-color: rgba(210,153,34,.4); }

.task-card-top { display: flex; gap: .9rem; margin-bottom: .9rem; }
.task-icon { font-size: 2rem; flex-shrink: 0; line-height: 1.2; }
.task-info h3 { font-size: 1rem; font-weight: 700; margin-bottom: .25rem; }
.task-info p  { font-size: .82rem; color: var(--text-sub); margin-bottom: .4rem; }
.task-meta-row { display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; }
.task-reward { color: var(--warning); font-weight: 700; font-size: .85rem; }
.task-badge { font-size: .72rem; font-weight: 600; padding: .15rem .5rem; border-radius: 20px; }
.auto-badge   { background: rgba(63,185,80,.12);  color: var(--accent2); border: 1px solid rgba(63,185,80,.25); }
.parent-badge { background: rgba(210,153,34,.12); color: var(--warning); border: 1px solid rgba(210,153,34,.25); }

.task-card-action { display: flex; flex-direction: column; gap: .6rem; border-top: 1px solid var(--border); padding-top: .9rem; }
.task-status-tag { display: inline-flex; align-items: center; font-size: .85rem; font-weight: 600; padding: .3rem .8rem; border-radius: 20px; }
.task-status-tag.confirmed { background: rgba(63,185,80,.12);  color: var(--accent2); }
.task-status-tag.rejected  { background: rgba(248,81,73,.1);   color: var(--danger); }
.task-status-tag.pending   { background: rgba(210,153,34,.12); color: var(--warning); }
.task-status-tag.limit     { background: var(--surface2); color: var(--text-sub); }

.btn-confirm-toggle { font-size: .85rem; padding: .35rem .9rem; }
.confirm-panel { background: var(--surface2); border: 1px solid var(--border); border-radius: 8px; padding: .9rem; margin-top: .3rem; }
.confirm-panel input[type=password] { width: 100%; background: var(--surface); border: 1px solid var(--border); border-radius: 6px; color: var(--text); padding: .5rem .8rem; font-size: .9rem; font-family: inherit; margin-bottom: .6rem; }
.confirm-panel input[type=password]:focus { outline: none; border-color: var(--accent); }
.confirm-btns { display: flex; gap: .6rem; }

.btn-sm { padding: .35rem .9rem !important; font-size: .85rem !important; }
.btn-danger { display: inline-flex; align-items: center; background: rgba(248,81,73,.15); color: var(--danger); font-weight: 700; font-size: .95rem; padding: .6rem 1.4rem; border-radius: 8px; border: 1px solid rgba(248,81,73,.3); cursor: pointer; transition: background .2s; }
.btn-danger:hover { background: rgba(248,81,73,.28); }

.parent-pw-tip { margin-top: 2rem; padding: .8rem 1rem; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); font-size: .85rem; color: var(--text-sub); }

/* Profile page tabs */
#profileTabs .nav-link.active {
  color: var(--accent) !important;
  border-color: var(--border) var(--border) var(--surface) !important;
  background: var(--surface) !important;
}
#profileTabs .nav-link:hover:not(.active) {
  color: var(--text) !important;
  border-color: transparent !important;
  background: var(--surface2) !important;
}
.required { color: var(--danger); margin-left: 2px; }

/* Parent password list */
.parent-pw-list { display: flex; flex-direction: column; gap: .5rem; margin-bottom: 1.2rem; }
.parent-pw-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: .7rem 1rem;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 8px;
}
.parent-pw-item-info { display: flex; align-items: center; gap: .8rem; flex-wrap: wrap; }
.parent-pw-label { font-weight: 700; font-size: .95rem; color: var(--text); }
.parent-pw-dots { font-size: 1rem; color: var(--text-sub); letter-spacing: .15em; }
.parent-pw-date { font-size: .75rem; color: var(--text-sub); }
.parent-pw-add { border-top: 1px solid var(--border); padding-top: 1.2rem; margin-top: .4rem; }
.parent-pw-add h4 { font-size: .95rem; font-weight: 700; margin-bottom: .9rem; color: var(--text); }

/* Coins Ledger */
.coin-badge[href] { text-decoration: none; cursor: pointer; transition: opacity .15s; }
.coin-badge[href]:hover { opacity: .8; }

.ledger-table-wrap { overflow-x: auto; }
.ledger-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .9rem;
}
.ledger-table thead tr {
  background: var(--surface2);
  border-bottom: 2px solid var(--border);
}
.ledger-table th {
  padding: .65rem 1rem;
  text-align: left;
  font-weight: 700;
  color: var(--text-sub);
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  white-space: nowrap;
}
.ledger-table td {
  padding: .6rem 1rem;
  border-bottom: 1px solid var(--border);
  color: var(--text);
}
.ledger-table tbody tr:last-child td { border-bottom: none; }
.ledger-table tbody tr:hover td { background: var(--surface2); }
.ledger-coin {
  display: inline-block;
  background: rgba(210,153,34,.15);
  color: var(--warning);
  font-weight: 700;
  padding: .15rem .6rem;
  border-radius: 20px;
  border: 1px solid rgba(210,153,34,.3);
  font-size: .85rem;
}
.ledger-empty {
  text-align: center;
  color: var(--text-sub);
  padding: 2rem !important;
  font-size: .9rem;
}

/* Inventory feed button effect tags */
.inv-feed-effects { display: flex; flex-wrap: wrap; gap: .25rem; align-items: center; flex: 1; }
.eff { font-size: .72rem; font-weight: 600; padding: .1rem .35rem; border-radius: 10px; white-space: nowrap; }
.hunger-eff  { background: rgba(230,160,60,.15);  color: #e6a03c; border: 1px solid rgba(230,160,60,.3); }
.happy-eff   { background: rgba(88,166,255,.12);  color: var(--accent); border: 1px solid rgba(88,166,255,.25); }
.health-eff  { background: rgba(63,185,80,.12);   color: var(--accent2); border: 1px solid rgba(63,185,80,.25); }
.exp-eff     { background: rgba(210,153,34,.12);  color: var(--warning); border: 1px solid rgba(210,153,34,.25); }

/* Feed log */
.feed-log-card { margin-top: 1rem; }
.feed-log-list { display: flex; flex-direction: column; gap: .4rem; max-height: 320px; overflow-y: auto; }
.feed-log-item {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: .55rem .75rem;
  background: var(--surface2);
  border-radius: 8px;
  border: 1px solid var(--border);
}
.feed-log-icon { font-size: 1.3rem; flex-shrink: 0; }
.feed-log-info { flex: 1; display: flex; flex-direction: column; gap: .2rem; }
.feed-log-name { font-size: .88rem; font-weight: 600; color: var(--text); }
.feed-log-effects { display: flex; flex-wrap: wrap; gap: .2rem; }
.feed-log-meta { display: flex; flex-direction: column; align-items: flex-end; gap: .15rem; flex-shrink: 0; }
.feed-log-user { font-size: .75rem; color: var(--accent); font-weight: 600; }
.feed-log-time { font-size: .72rem; color: var(--text-sub); white-space: nowrap; }
.feed-log-empty { text-align: center; color: var(--text-sub); padding: 1.5rem; font-size: .88rem; }

/* Friends */
.friends-layout { display: grid; grid-template-columns: 1fr 280px; gap: 1.5rem; }
@media (max-width: 768px) { .friends-layout { grid-template-columns: 1fr; } }
.friends-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 1rem; margin-top: .75rem; }
.friend-card {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 1rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .5rem;
  text-align: center;
  transition: border-color .2s;
}
.friend-card:hover { border-color: var(--accent); }
.friend-avatar-link { display: block; }
.friend-avatar { width: 64px; height: 64px; border-radius: 50%; object-fit: cover; border: 2px solid var(--border); }
.friend-avatar-placeholder {
  width: 64px; height: 64px; border-radius: 50%;
  background: var(--accent); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.6rem; font-weight: 700;
}
.friend-info { display: flex; flex-direction: column; gap: .1rem; }
.friend-name { font-weight: 700; color: var(--text); font-size: .95rem; }
.friend-username { font-size: .78rem; color: var(--text-sub); }
.friend-actions { display: flex; gap: .4rem; flex-wrap: wrap; justify-content: center; }
.btn-sm { padding: .25rem .65rem; border-radius: 6px; font-size: .8rem; font-weight: 600; cursor: pointer; border: 1px solid var(--border); background: var(--surface); color: var(--text); text-decoration: none; transition: background .15s; }
.btn-sm:hover { background: var(--surface2); }
.btn-outline { border-color: var(--accent); color: var(--accent); }
.btn-outline:hover { background: rgba(88,166,255,.1); }
.btn-success { background: rgba(63,185,80,.15); border-color: var(--accent2); color: var(--accent2); }
.btn-danger-outline { border-color: var(--danger); color: var(--danger); }
.btn-danger-outline:hover { background: rgba(248,81,73,.1); }
.friends-empty { color: var(--text-sub); padding: 2rem; text-align: center; font-size: .9rem; }
.friend-request-item {
  display: flex; align-items: center; gap: .6rem; flex-wrap: wrap;
  padding: .6rem .5rem; border-bottom: 1px solid var(--border);
}
.friend-request-item:last-child { border-bottom: none; }
.friend-req-name { font-weight: 700; color: var(--text); font-size: .9rem; }
.friend-req-user { color: var(--text-sub); font-size: .78rem; flex: 1; }
.friend-req-btns { display: flex; gap: .3rem; }

/* Friend pets */
.friend-pets-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 1.2rem; }
.friend-pet-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: .75rem;
}
.friend-pet-header { display: flex; align-items: center; gap: .75rem; }
.friend-pet-name { font-weight: 700; color: var(--text); font-size: 1rem; }
.friend-pet-stats { display: flex; flex-direction: column; gap: .35rem; }
.stat-row-sm { display: flex; align-items: center; gap: .5rem; }
.stat-bar-sm { flex: 1; height: 7px; background: var(--surface2); border-radius: 4px; overflow: hidden; }
.stat-num-sm { font-size: .78rem; color: var(--text-sub); width: 28px; text-align: right; }
.friend-feed-details summary {
  cursor: pointer;
  color: var(--accent);
  font-size: .85rem;
  font-weight: 600;
  padding: .3rem 0;
  list-style: none;
  user-select: none;
}
.friend-feed-details summary::-webkit-details-marker { display: none; }

/* pet-type-card as button reset */
button.pet-type-card {
  width: 100%;
  font-family: inherit;
  font-size: inherit;
  text-align: center;
  background: var(--surface);
  color: var(--text);
}

/* Friend request count badge in navbar */
.friend-req-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--danger);
  color: #fff;
  font-size: .68rem;
  font-weight: 700;
  min-width: 16px;
  height: 16px;
  border-radius: 8px;
  padding: 0 .3rem;
  margin-left: .25rem;
  vertical-align: middle;
  line-height: 1;
}

/* Growth chart */
.growth-chart-wrap {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.2rem;
  margin-bottom: 1rem;
}
.growth-chart-wrap canvas { max-height: 320px; }

/* Marketplace */
.market-layout { display: grid; grid-template-columns: 300px 1fr; gap: 1.5rem; }
@media (max-width: 768px) { .market-layout { grid-template-columns: 1fr; } }
.market-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 1.2rem; }
.market-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 1.1rem;
  display: flex;
  flex-direction: column;
  gap: .75rem;
  transition: border-color .2s, transform .2s;
}
.market-card:hover { border-color: var(--accent); transform: translateY(-2px); }
.market-card-own { border-color: rgba(210,153,34,.4); }
.market-card-header { display: flex; align-items: center; gap: .75rem; }
.market-pet-name { font-weight: 700; color: var(--text); font-size: 1rem; }
.market-pet-stats { display: flex; flex-direction: column; gap: .3rem; }
.market-desc { font-size: .82rem; color: var(--text-sub); font-style: italic; padding: .4rem .6rem; background: var(--surface2); border-radius: 6px; }
.market-card-footer { display: flex; align-items: center; justify-content: space-between; gap: .5rem; flex-wrap: wrap; margin-top: auto; }
.market-price { font-size: 1rem; font-weight: 700; color: var(--warning); }
.market-seller { font-size: .75rem; color: var(--text-sub); display: block; margin-top: .15rem; }
.my-listing-item {
  display: flex; align-items: center; justify-content: space-between;
  gap: .5rem; padding: .6rem 0;
  border-bottom: 1px solid var(--border);
}
.my-listing-item:last-child { border-bottom: none; }
.my-listing-info { display: flex; align-items: center; gap: .4rem; flex-wrap: wrap; }
.mb-3 { margin-bottom: 1rem; }

/* Coin ledger */
.ledger-table-wrap { overflow-x: auto; }
.ledger-table { width: 100%; border-collapse: collapse; font-size: .9rem; }
.ledger-table th { background: var(--surface2); color: var(--text-sub); font-size: .78rem; text-transform: uppercase; letter-spacing: .05em; padding: .6rem 1rem; text-align: left; border-bottom: 1px solid var(--border); }
.ledger-table td { padding: .6rem 1rem; border-bottom: 1px solid var(--border); }
.ledger-table tr:hover td { background: var(--surface2); }
.ledger-empty { text-align: center; color: var(--text-sub); padding: 2rem !important; }
.ledger-coin { color: var(--accent2); font-weight: 700; }
.ledger-coin-in  { color: var(--accent2); font-weight: 700; }
.ledger-coin-out { color: var(--danger);  font-weight: 700; }
.tx-badge { display: inline-block; padding: .15rem .55rem; border-radius: 20px; font-size: .72rem; font-weight: 700; }
.tx-task  { background: rgba(88,166,255,.15);  color: var(--accent);  border: 1px solid rgba(88,166,255,.25); }
.tx-shop  { background: rgba(210,153,34,.15);  color: var(--warning); border: 1px solid rgba(210,153,34,.25); }
.tx-sell  { background: rgba(63,185,80,.15);   color: var(--accent2); border: 1px solid rgba(63,185,80,.25); }
.tx-buy   { background: rgba(248,81,73,.12);   color: var(--danger);  border: 1px solid rgba(248,81,73,.2); }

/* Inactive parent password */
.parent-pw-inactive .parent-pw-label,
.parent-pw-inactive .parent-pw-dots {
  opacity: 0.4;
  text-decoration: line-through;
}
.parent-pw-inactive { opacity: 0.65; }

/* Chat modal */
.modal-content { color: var(--text); }
.modal-header .btn-close { filter: invert(1); opacity: 0.6; }
.modal-header .btn-close:hover { opacity: 1; }
#chatHistory::-webkit-scrollbar { width: 6px; }
#chatHistory::-webkit-scrollbar-track { background: var(--surface2); }
#chatHistory::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }
#chatHistory::-webkit-scrollbar-thumb:hover { background: var(--text-sub); }
