@import url(https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,600;0,700;0,900;1,700&family=DM+Sans:wght@300;400;500;600&display=swap);*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--orange:#ff6b2b;--orange-light:#ff8c55;--yellow:#ffd166;--cream:#fff8f2;--ink:#1a0a00;--ink-soft:#5c3d2e;--white:#fff;--gray-50:#f9f5f2;--gray-100:#f0eae4;--gray-200:#ddd3ca;--gray-400:#a0877a;--gray-600:#6b5347;--success:#16a34a;--danger:#dc2626;--info:#2563eb;--shadow-sm:0 1px 3px #1a0a0014;--shadow-md:0 4px 16px #1a0a001a;--shadow-lg:0 12px 40px #1a0a001f;--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--radius-xl:28px;--sidebar-width:220px}html{scroll-behavior:smooth}body{background:#f9f5f2;background:var(--gray-50);color:#1a0a00;color:var(--ink);font-family:DM Sans,sans-serif;font-size:15px;line-height:1.6}.app-layout{display:flex;min-height:100vh}.main-content{flex:1 1;margin-left:220px;margin-left:var(--sidebar-width);min-width:0}@media (max-width:768px){.main-content{margin-left:0}}h1,h2,h3,h4{color:#1a0a00;color:var(--ink);font-family:Playfair Display,serif;font-weight:700;line-height:1.2}h1{font-size:clamp(1.8rem,3vw,2.6rem)}h2{font-size:clamp(1.4rem,2.5vw,2rem)}h3{font-size:1.25rem}p{color:#5c3d2e;color:var(--ink-soft)}.btn{align-items:center;border:1.5px solid #0000;border-radius:100px;cursor:pointer;display:inline-flex;font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;gap:6px;justify-content:center;padding:10px 20px;text-decoration:none;transition:all .2s}.btn-primary{background:#ff6b2b;background:var(--orange);border-color:#ff6b2b;border-color:var(--orange);box-shadow:0 4px 14px #ff6b2b4d;color:#fff}.btn-primary:hover{background:#e55b1f;box-shadow:0 6px 20px #ff6b2b66;transform:translateY(-1px)}.btn-secondary{background:#fff;border-color:#ddd3ca;border-color:var(--gray-200);color:#1a0a00;color:var(--ink)}.btn-ghost,.btn-secondary:hover{border-color:#ff6b2b;border-color:var(--orange);color:#ff6b2b;color:var(--orange)}.btn-ghost{background:#0000}.btn-ghost:hover{background:#ff6b2b0f}.btn-danger{background:#dc2626;background:var(--danger);border-color:#dc2626;border-color:var(--danger);color:#fff}.btn-sm{font-size:12px;padding:6px 14px}.btn-lg{font-size:16px;padding:14px 32px}.btn:disabled{cursor:not-allowed;opacity:.5;transform:none!important}.card{background:#fff;border:1px solid #f0eae4;border:1px solid var(--gray-100);border-radius:20px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #1a0a0014;box-shadow:var(--shadow-sm)}.card-body{padding:20px}.card-header{border-bottom:1px solid #f0eae4;border-bottom:1px solid var(--gray-100);padding:16px 20px}.form-group{margin-bottom:18px}.form-label{color:#5c3d2e;color:var(--ink-soft);display:block;font-size:13px;font-weight:500;margin-bottom:6px}.form-control{background:#fff;border:1.5px solid #ddd3ca;border:1.5px solid var(--gray-200);border-radius:8px;border-radius:var(--radius-sm);color:#1a0a00;color:var(--ink);font-family:DM Sans,sans-serif;font-size:14px;outline:none;padding:10px 14px;transition:border-color .2s;width:100%}.form-control:focus{border-color:#ff6b2b;border-color:var(--orange);box-shadow:0 0 0 3px #ff6b2b1a}.form-control::placeholder{color:#a0877a;color:var(--gray-400)}textarea.form-control{line-height:1.6;min-height:120px;resize:vertical}select.form-control{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%23A0877A' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;background-size:16px}.avatar{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-weight:600;justify-content:center;overflow:hidden}.avatar img{height:100%;object-fit:cover;width:100%}.avatar-sm{font-size:12px;height:32px;width:32px}.avatar-md{font-size:14px;height:40px;width:40px}.avatar-lg{font-size:18px;height:56px;width:56px}.avatar-xl{font-size:24px;height:80px;width:80px}.badge{align-items:center;border-radius:100px;display:inline-flex;font-size:11px;font-weight:600;gap:4px;padding:3px 10px}.badge-orange{background:#ff6b2b1f;color:#ff6b2b;color:var(--orange)}.badge-green{background:#16a34a1a;color:#16a34a;color:var(--success)}.badge-blue{background:#2563eb1a;color:#2563eb;color:var(--info)}.badge-gray{background:#f0eae4;background:var(--gray-100);color:#6b5347;color:var(--gray-600)}.badge-gold{background:#ffd16633;color:#8b6914}.tag{background:#f0eae4;background:var(--gray-100);border:1px solid #ddd3ca;border:1px solid var(--gray-200);border-radius:100px;color:#6b5347;color:var(--gray-600);cursor:pointer;display:inline-flex;font-size:11px;font-weight:500;padding:2px 8px;transition:all .15s}.tag.active,.tag:hover{background:#ff6b2b1a;border-color:#ff6b2b4d;color:#ff6b2b;color:var(--orange)}.page-header{margin-bottom:24px;padding:24px 32px 0}.page-header h2{font-size:1.5rem}.page-header p{color:#a0877a;color:var(--gray-400);font-size:14px;margin-top:4px}.section{margin-bottom:32px;padding:0 32px}.section-title{align-items:center;display:flex;font-size:16px;font-weight:600;justify-content:space-between;margin-bottom:14px}.section-title a{color:#ff6b2b;color:var(--orange);font-family:DM Sans;font-size:13px;font-weight:400;text-decoration:none}.stats-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));margin-bottom:24px}.stat-card{background:#fff;border:1px solid #f0eae4;border:1px solid var(--gray-100);border-radius:12px;border-radius:var(--radius-md);padding:16px}.stat-val{color:#1a0a00;color:var(--ink);font-family:Playfair Display,serif;font-size:22px;font-weight:600}.stat-label{color:#a0877a;color:var(--gray-400);font-size:12px;margin-top:2px}.stat-delta{color:#16a34a;color:var(--success);font-size:11px;margin-top:6px}.story-card{background:#fff;border:1px solid #f0eae4;border:1px solid var(--gray-100);border-radius:20px;border-radius:var(--radius-lg);cursor:pointer;padding:20px;transition:all .2s}.story-card:hover{border-color:#ff6b2b;border-color:var(--orange);box-shadow:0 4px 16px #1a0a001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.story-card-head{align-items:center;display:flex;gap:10px;margin-bottom:12px}.story-card-meta{flex:1 1}.story-card-author{font-size:13px;font-weight:600}.story-card-time{color:#a0877a;color:var(--gray-400);font-size:11px;margin-top:1px}.story-card-cat{background:#ff6b2b1a;border-radius:100px;color:#ff6b2b;color:var(--orange);font-size:10px;font-weight:600;padding:3px 10px;white-space:nowrap}.story-card-title{color:#1a0a00;color:var(--ink);font-family:Playfair Display,serif;font-size:15px;font-weight:700;line-height:1.3;margin-bottom:6px}.story-card-text{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#5c3d2e;color:var(--ink-soft);display:-webkit-box;font-size:13px;line-height:1.6;margin-bottom:14px;overflow:hidden}.story-card-footer{align-items:center;display:flex;gap:14px}.story-action{align-items:center;background:none;border:none;color:#a0877a;color:var(--gray-400);cursor:pointer;display:flex;font-family:DM Sans,sans-serif;font-size:12px;gap:5px;transition:color .15s}.story-action.liked,.story-action:hover{color:#ff6b2b;color:var(--orange)}.story-action svg{height:15px;width:15px}.story-tags{display:flex;gap:4px;margin-left:auto}.habit-card{background:#fff;border:1px solid #f0eae4;border:1px solid var(--gray-100);border-radius:20px;border-radius:var(--radius-lg);padding:18px;transition:all .2s}.habit-card:hover{border-color:#ff6b2b;border-color:var(--orange);box-shadow:0 4px 16px #1a0a001a;box-shadow:var(--shadow-md)}.habit-icon-wrap{align-items:center;border-radius:8px;border-radius:var(--radius-sm);display:flex;font-size:20px;height:44px;justify-content:center;margin-bottom:10px;width:44px}.habit-name{font-size:14px;font-weight:600;margin-bottom:4px}.habit-meta{color:#a0877a;color:var(--gray-400);font-size:11px;margin-bottom:10px}.progress-bar{background:#f0eae4;background:var(--gray-100);border-radius:2px;height:4px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#ff6b2b,#ffd166);background:linear-gradient(90deg,var(--orange),var(--yellow));border-radius:2px;height:100%;transition:width .6s ease}.adopt-btn{border-radius:100px;cursor:pointer;font-family:DM Sans,sans-serif;font-size:12px;font-weight:600;margin-top:12px;padding:8px;transition:all .2s;width:100%}.adopt-btn.not-adopted{background:#0000;border:1.5px solid #ff6b2b;border:1.5px solid var(--orange);color:#ff6b2b;color:var(--orange)}.adopt-btn.not-adopted:hover{background:#ff6b2b;background:var(--orange);color:#fff}.adopt-btn.adopted{background:#16a34a1a;border:1.5px solid #16a34a4d;color:#16a34a;color:var(--success)}.lb-row{align-items:center;border-bottom:1px solid #f0eae4;border-bottom:1px solid var(--gray-100);display:flex;gap:12px;padding:12px 0}.lb-row:last-child{border:none}.lb-rank{flex-shrink:0;font-size:14px;font-weight:700;text-align:center;width:28px}.lb-info{flex:1 1;min-width:0}.lb-name{font-size:13px;font-weight:600}.lb-sub{color:#a0877a;color:var(--gray-400);font-size:11px}.lb-score{color:#ff6b2b;color:var(--orange);font-size:13px;font-weight:600}.modal-overlay{align-items:center;background:#1a0a0080;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.modal{background:#fff;border-radius:28px;border-radius:var(--radius-xl);box-shadow:0 12px 40px #1a0a001f;box-shadow:var(--shadow-lg);max-height:90vh;max-width:560px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #f0eae4;border-bottom:1px solid var(--gray-100);display:flex;justify-content:space-between;padding:20px 24px 16px}.modal-header h3{font-size:1.1rem}.modal-body{padding:20px 24px}.modal-footer{border-top:1px solid #f0eae4;border-top:1px solid var(--gray-100);display:flex;gap:10px;justify-content:flex-end;padding:16px 24px}.close-btn{background:none;border:none;color:#a0877a;color:var(--gray-400);cursor:pointer;font-size:20px;line-height:1;padding:0}.close-btn:hover{color:#1a0a00;color:var(--ink)}.text-orange{color:#ff6b2b;color:var(--orange)}.text-muted{color:#a0877a;color:var(--gray-400)}.text-sm{font-size:13px}.text-xs{font-size:11px}.font-serif{font-family:Playfair Display,serif}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.w-full{width:100%}.grid-2{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.grid-3{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(3,1fr)}.grid-4{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,1fr)}@media (max-width:900px){.grid-3,.grid-4{grid-template-columns:1fr 1fr}}@media (max-width:600px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.section{padding:0 16px}.page-header{padding:16px 16px 0}}.toast-container{bottom:24px;display:flex;flex-direction:column;gap:8px;position:fixed;right:24px;z-index:9999}.toast{align-items:center;animation:slideIn .3s ease;background:#1a0a00;background:var(--ink);border-radius:12px;border-radius:var(--radius-md);box-shadow:0 12px 40px #1a0a001f;box-shadow:var(--shadow-lg);color:#fff;display:flex;font-size:13px;font-weight:500;gap:8px;padding:12px 18px}.toast.success{background:#16a34a;background:var(--success)}.toast.error{background:#dc2626;background:var(--danger)}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.spinner{animation:spin .7s linear infinite;border:3px solid #f0eae4;border-top-color:#ff6b2b;border:3px solid var(--gray-100);border-radius:50%;border-top-color:var(--orange);height:28px;width:28px}.spinner-sm{border-width:2px;height:18px;width:18px}@keyframes spin{to{transform:rotate(1turn)}}.loading-center{align-items:center;display:flex;justify-content:center;padding:60px}.empty-state{padding:60px 20px;text-align:center}.empty-state-icon{font-size:3rem;margin-bottom:12px}.empty-state h3{font-size:1.1rem;margin-bottom:8px}.empty-state p{color:#a0877a;color:var(--gray-400);font-size:14px;margin:0 auto 20px;max-width:320px}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#ddd3ca;background:var(--gray-200);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#a0877a;background:var(--gray-400)}
/*# sourceMappingURL=main.ed5c3bb9.css.map*/