@import url(https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700;800;900&family=DM+Sans:wght@300;400;500;600;700&display=swap);:root{--blush:#e8b4c8;--blush-dark:#c2185b;--blush-light:#fdf0f5;--nude:#e8d5c4;--nude-dark:#c4a882;--nude-light:#faf5f0;--cream:#fdf8f4;--cream-dark:#f2eae1;--brown:#8b6355;--brown-light:#c4a882;--brown-dark:#5c3d2e;--text:#2c1810;--text-mid:#7a5c52;--text-light:#b89990;--border:#edd5c8;--success:#7b9e87;--success-light:#eaf2ec;--danger:#c0392b;--warning:#c9a84c;--shadow-sm:0 2px 8px #8b635514;--shadow-md:0 4px 20px #8b63551f;--shadow-lg:0 8px 40px #8b635529}.sidebar{background:linear-gradient(180deg,#5c3d2e,#6b4226);background:linear-gradient(180deg,var(--brown-dark) 0,var(--brown) 100%)}.sidebar-logo{align-items:center;display:flex;gap:12px}.sidebar-logo .logo-icon{align-items:center;background:linear-gradient(135deg,#c9a84c,#c4a882);background:linear-gradient(135deg,var(--gold),var(--nude-dark));border-radius:12px;display:flex;flex-shrink:0;font-size:22px;height:44px;justify-content:center;width:44px}.sidebar-logo .logo-mark{font-size:18px;line-height:1.1}.sidebar-logo .logo-sub{color:#ffffff73;font-size:10px;letter-spacing:1.2px;margin-top:2px}.sidebar-user{padding:18px 24px}.sidebar-user .user-avatar{align-items:center;background:linear-gradient(135deg,#c9a84c,#e8b4c8);background:linear-gradient(135deg,var(--gold),var(--blush));border-radius:50%;color:#fff;display:flex;font-size:15px;font-weight:800;height:38px;justify-content:center;margin-bottom:8px;width:38px}.sidebar-user .user-name{font-size:14px}.sidebar-user .user-role{font-size:11px}.nav-section-label{color:#ffffff4d}.nav-item{color:#ffffffa6}.nav-item.active{background:linear-gradient(135deg,#c9a84c,#c4a882);background:linear-gradient(135deg,var(--gold),var(--nude-dark));color:#fff;color:var(--white)}.card-title{color:#999;color:var(--text-light);font-size:12px;letter-spacing:1.2px;margin-bottom:14px}.stat-card .stat-value{color:#5c3d2e;color:var(--brown-dark)}.btn-primary{background:linear-gradient(135deg,#5c3d2e,#6b4226);background:linear-gradient(135deg,var(--brown-dark),var(--brown))}.btn-gold{background:linear-gradient(135deg,#c9a84c,#c4a882);background:linear-gradient(135deg,var(--gold),var(--nude-dark))}.btn-gold:hover{box-shadow:0 4px 20px #0000001a;box-shadow:var(--shadow-md)}.btn-blush{background:#fdf0f5;background:var(--blush-light);border:1.5px solid #e8b4c8;border:1.5px solid var(--blush);color:#c2185b;color:var(--blush-dark)}.btn-blush:hover{background:#e8b4c8;background:var(--blush);color:#fff;color:var(--white)}.btn-outline{color:#555;color:var(--text-mid)}.btn-outline:hover{border-color:#c4a882;border-color:var(--nude-dark)}.form-label{font-size:12px;font-weight:700;letter-spacing:.8px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#c9a84c;border-color:var(--gold);box-shadow:0 0 0 3px #c9a84c26}.badge-green{background:#eaf2ec;background:var(--success-light);color:#2d6a4f;color:var(--success)}.badge-pink{background:#fdf0f5;background:var(--blush-light);color:var(--blush-dark)}.badge-staff{background:linear-gradient(135deg,#c9a84c,#c4a882);background:linear-gradient(135deg,var(--gold),var(--nude-dark))}.progress-fill{background:linear-gradient(90deg,#c9a84c,#e8b4c8);background:linear-gradient(90deg,var(--gold),var(--blush))}.mood-btn.selected,.mood-btn:hover{border-color:#c9a84c;border-color:var(--gold)}.mood-btn.selected{background:#f5e6c0;background:var(--gold-light)}.toggle-label{color:#1a1a1a;color:var(--text)}.toggle.on{background:#c9a84c;background:var(--gold)}.affirmation-card{background:linear-gradient(135deg,#5c3d2e,#6b4226 60%,#9a7a2e);background:linear-gradient(135deg,var(--brown-dark) 0,var(--brown) 60%,var(--gold-dark) 100%)}.affirmation-card:before{color:#ffffff0f}.affirmation-text{font-size:20px;line-height:1.6}.affirmation-label{color:#f5e6c0;color:var(--gold-light);font-size:11px}.phase-dot.done{background:var(--success)}.sobriety-ring{background:#f5e6c0;background:var(--gold-light);border:8px solid #c9a84c;border:8px solid var(--gold)}.sobriety-ring .ring-num{color:#5c3d2e;color:var(--brown-dark)}.sobriety-ring .ring-label{color:#9a7a2e;color:var(--gold-dark)}.resident-row:hover{background:#faf5f0;background:var(--nude-light)}.resident-avatar{background:linear-gradient(135deg,#c9a84c,#e8b4c8);background:linear-gradient(135deg,var(--gold),var(--blush))}.resident-name{color:#1a1a1a;color:var(--text)}.login-page{background:linear-gradient(135deg,#5c3d2e,#6b4226 50%,#9a7a2e);background:linear-gradient(135deg,var(--brown-dark) 0,var(--brown) 50%,var(--gold-dark) 100%)}.login-logo{color:#5c3d2e;color:var(--brown-dark)}.login-logo-icon{display:block;font-size:48px;margin-bottom:12px;text-align:center}.login-tagline{font-size:12px}.success-banner{background:#f5e6c0;background:var(--gold-light);border:1.5px solid #c9a84c;border:1.5px solid var(--gold)}.success-banner .success-title{color:#5c3d2e;color:var(--brown-dark)}.success-banner .success-sub{color:#9a7a2e;color:var(--gold-dark)}.spinner{border-top-color:#c9a84c;border-top-color:var(--gold)}.text-brown{color:#5c3d2e;color:var(--brown-dark)}:root{--gold:#c9a84c;--gold-light:#f5e6c0;--gold-dark:#9a7a2e;--green:#2d6a4f;--green-light:#d8f3dc;--green-dark:#1b4332;--pink:#e8b4c8;--pink-dark:#c2185b;--pink-light:#fce4ec;--cream:#faf7f2;--cream-dark:#f0ebe3;--brown:#6b4226;--brown-light:#c8a882;--text:#1a1a1a;--text-mid:#555;--text-light:#999;--white:#fff;--border:#e5ddd4;--success:#2d6a4f;--danger:#c62828;--warning:#f9a825;--shadow-sm:0 2px 8px #0000000f;--shadow-md:0 4px 20px #0000001a;--shadow-lg:0 8px 40px #00000024;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;background:#faf7f2;background:var(--cream);color:#1a1a1a;color:var(--text);font-family:DM Sans,sans-serif;line-height:1.6}h1,h2,h3{font-family:Playfair Display,serif;line-height:1.2}.app-shell,.sidebar{display:flex;min-height:100vh}.sidebar{background:#1b4332;background:var(--green-dark);bottom:0;flex-direction:column;left:0;position:fixed;top:0;transition:transform .3s ease;width:260px;z-index:100}.main-content{background:#faf7f2;background:var(--cream);flex:1 1;margin-left:260px;min-height:100vh}@media (max-width:768px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.main-content{margin-left:0}}.sidebar-logo{border-bottom:1px solid #ffffff1a;padding:28px 24px 20px}.sidebar-logo .logo-mark{color:#c9a84c;color:var(--gold);font-family:Playfair Display,serif;font-size:22px;font-weight:900;line-height:1}.sidebar-logo .logo-sub{color:#ffffff80;font-size:11px;letter-spacing:1.5px;margin-top:4px;text-transform:uppercase}.sidebar-user{border-bottom:1px solid #ffffff14;padding:20px 24px}.sidebar-user .user-name{color:#fff;color:var(--white);font-size:15px;font-weight:600}.sidebar-user .user-role{color:#c9a84c;color:var(--gold);font-size:12px;letter-spacing:1px;margin-top:2px;text-transform:uppercase}.sidebar-nav{flex:1 1;overflow-y:auto;padding:16px 12px}.nav-section-label{color:#ffffff59;font-size:10px;letter-spacing:1.5px;padding:12px 12px 6px;text-transform:uppercase}.nav-item{align-items:center;background:none;border:none;border-radius:8px;border-radius:var(--radius-sm);color:#ffffffb3;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px;padding:10px 12px;text-align:left;text-decoration:none;transition:all .15s ease;width:100%}.nav-item:hover{background:#ffffff14;color:#fff;color:var(--white)}.nav-item.active{background:#c9a84c;background:var(--gold);color:#1b4332;color:var(--green-dark);font-weight:700}.nav-item .nav-icon{font-size:18px;text-align:center;width:24px}.sidebar-footer{border-top:1px solid #ffffff14;padding:16px 12px}.page-header{align-items:center;background:#fff;background:var(--white);border-bottom:1px solid #e5ddd4;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:20px 32px;position:-webkit-sticky;position:sticky;top:0;z-index:50}.page-header h1{color:#1a1a1a;color:var(--text);font-size:26px}.page-header .page-subtitle{color:#999;color:var(--text-light);font-family:DM Sans,sans-serif;font-size:14px;font-weight:400;margin-top:2px}.page-content{max-width:1200px;padding:32px}.card{background:#fff;background:var(--white);border:1px solid #e5ddd4;border:1px solid var(--border);border-radius:20px;border-radius:var(--radius-lg);box-shadow:0 2px 8px #0000000f;box-shadow:var(--shadow-sm);padding:24px}.card-title{color:#555;color:var(--text-mid);font-family:DM Sans,sans-serif;font-size:13px;font-weight:700;letter-spacing:1px;margin-bottom:12px;text-transform:uppercase}.stat-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:28px}.stat-card{background:#fff;background:var(--white);border:1px solid #e5ddd4;border:1px solid var(--border);border-radius:20px;border-radius:var(--radius-lg);box-shadow:0 2px 8px #0000000f;box-shadow:var(--shadow-sm);padding:20px 24px}.stat-card .stat-icon{font-size:28px;margin-bottom:10px}.stat-card .stat-value{color:#1a1a1a;color:var(--text);font-family:Playfair Display,serif;font-size:36px;font-weight:800;line-height:1}.stat-card .stat-label{color:#555;color:var(--text-mid);font-size:13px;font-weight:500;margin-top:4px}.stat-card .stat-sub{color:#999;color:var(--text-light);font-size:12px;margin-top:2px}.btn{align-items:center;border:none;border-radius:14px;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-family:DM Sans,sans-serif;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;text-decoration:none;transition:all .15s ease}.btn-primary{background:#2d6a4f;background:var(--green);color:#fff;color:var(--white)}.btn-primary:hover{background:#1b4332;background:var(--green-dark);box-shadow:0 4px 20px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-gold{background:#c9a84c;background:var(--gold);color:#fff;color:var(--white)}.btn-gold:hover{background:#9a7a2e;background:var(--gold-dark);transform:translateY(-1px)}.btn-outline{background:#0000;border:1.5px solid #e5ddd4;border:1.5px solid var(--border);color:#1a1a1a;color:var(--text)}.btn-outline:hover{background:#f0ebe3;background:var(--cream-dark);border-color:#555;border-color:var(--text-mid)}.btn-danger{background:#c62828;background:var(--danger);color:#fff;color:var(--white)}.btn:disabled{cursor:not-allowed;opacity:.5;transform:none!important}.btn-lg{font-size:16px;padding:14px 28px}.btn-sm{font-size:13px;padding:7px 14px}.btn-full{justify-content:center;width:100%}.form-group{margin-bottom:18px}.form-label{color:#555;color:var(--text-mid);display:block;font-size:13px;font-weight:600;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.form-input,.form-select,.form-textarea{background:#faf7f2;background:var(--cream);border:1.5px solid #e5ddd4;border:1.5px solid var(--border);border-radius:14px;border-radius:var(--radius-md);color:#1a1a1a;color:var(--text);font-family:DM Sans,sans-serif;font-size:15px;outline:none;padding:12px 14px;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{background:#fff;background:var(--white);border-color:#2d6a4f;border-color:var(--green);box-shadow:0 0 0 3px #2d6a4f1f}.form-textarea{min-height:100px;resize:vertical}.badge{align-items:center;border-radius:999px;display:inline-flex;font-size:12px;font-weight:700;gap:4px;padding:3px 10px}.badge-green{background:#d8f3dc;background:var(--green-light);color:#1b4332;color:var(--green-dark)}.badge-gold{background:#f5e6c0;background:var(--gold-light);color:#9a7a2e;color:var(--gold-dark)}.badge-pink{background:#fce4ec;background:var(--pink-light);color:#c2185b;color:var(--pink-dark)}.badge-gray{background:#f0ebe3;background:var(--cream-dark);color:#555;color:var(--text-mid)}.badge-danger{background:#ffebee;color:#c62828;color:var(--danger)}.badge-staff{background:#c9a84c;background:var(--gold);color:#fff;color:var(--white)}.progress-bar{background:#f0ebe3;background:var(--cream-dark);border-radius:999px;height:10px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,#2d6a4f,#c9a84c);background:linear-gradient(90deg,var(--green),var(--gold));border-radius:999px;height:100%;transition:width .6s ease}.mood-scale{display:flex;gap:10px}.mood-btn{align-items:center;aspect-ratio:1;background:#faf7f2;background:var(--cream);border:2px solid #e5ddd4;border:2px solid var(--border);border-radius:14px;border-radius:var(--radius-md);cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-size:22px;gap:4px;justify-content:center;transition:all .15s ease}.mood-btn span.mood-label{color:#999;color:var(--text-light);font-size:10px;font-weight:600}.mood-btn:hover{transform:scale(1.05)}.mood-btn.selected,.mood-btn:hover{border-color:#2d6a4f;border-color:var(--green)}.mood-btn.selected{background:#d8f3dc;background:var(--green-light)}.toggle-row{align-items:center;border-bottom:1px solid #e5ddd4;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:14px 0}.toggle-row:last-child{border-bottom:none}.toggle-label{font-size:15px;font-weight:500}.toggle-sub{color:#999;color:var(--text-light);font-size:13px;margin-top:2px}.toggle{background:#f0ebe3;background:var(--cream-dark);border:none;border-radius:999px;cursor:pointer;flex-shrink:0;height:26px;position:relative;transition:background .2s ease;width:48px}.toggle:after{background:#fff;background:var(--white);border-radius:50%;box-shadow:0 1px 4px #0003;content:"";height:20px;left:3px;position:absolute;top:3px;transition:transform .2s ease;width:20px}.toggle.on{background:#2d6a4f;background:var(--green)}.toggle.on:after{transform:translateX(22px)}.affirmation-card{background:linear-gradient(135deg,#1b4332,#6b4226);background:linear-gradient(135deg,var(--green-dark) 0,var(--brown) 100%);border-radius:28px;border-radius:var(--radius-xl);color:#fff;color:var(--white);overflow:hidden;padding:32px;position:relative}.affirmation-card:before{color:#ffffff12;content:'"';font-family:Playfair Display,serif;font-size:140px;left:20px;line-height:1;position:absolute;top:-20px}.affirmation-text{font-family:Playfair Display,serif;font-size:22px;line-height:1.5;position:relative;z-index:1}.affirmation-label{color:#c9a84c;color:var(--gold);font-size:12px;font-weight:700;letter-spacing:2px;margin-bottom:12px;text-transform:uppercase}.phase-dots{align-items:center;display:flex;gap:6px}.phase-dot{background:#f0ebe3;background:var(--cream-dark);border-radius:50%;height:10px;transition:all .3s ease;width:10px}.phase-dot.done{background:#2d6a4f;background:var(--green)}.phase-dot.current{background:#c9a84c;background:var(--gold);transform:scale(1.4)}.sobriety-ring{align-items:center;background:#d8f3dc;background:var(--green-light);border:8px solid #2d6a4f;border:8px solid var(--green);border-radius:50%;display:flex;flex-direction:column;height:120px;justify-content:center;width:120px}.sobriety-ring .ring-num{color:#1b4332;color:var(--green-dark);font-family:Playfair Display,serif;font-size:36px;font-weight:800;line-height:1}.sobriety-ring .ring-label{color:#2d6a4f;color:var(--green);font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.resident-row{align-items:center;border-bottom:1px solid #e5ddd4;border-bottom:1px solid var(--border);cursor:pointer;display:flex;gap:14px;padding:14px 0;transition:background .1s ease}.resident-row:last-child{border-bottom:none}.resident-row:hover{background:#faf7f2;background:var(--cream);border-radius:8px;border-radius:var(--radius-sm);margin:0 -24px;padding:14px 24px}.resident-avatar{align-items:center;background:linear-gradient(135deg,#c9a84c,#2d6a4f);background:linear-gradient(135deg,var(--gold),var(--green));border-radius:50%;color:#fff;color:var(--white);display:flex;flex-shrink:0;font-size:16px;font-weight:800;height:42px;justify-content:center;width:42px}.resident-name{font-size:15px;font-weight:600}.resident-meta{font-size:13px;margin-top:2px}.empty-state,.resident-meta{color:#999;color:var(--text-light)}.empty-state{padding:60px 20px;text-align:center}.empty-state .empty-icon{font-size:48px;margin-bottom:16px}.empty-state h3{color:#555;color:var(--text-mid);font-family:DM Sans,sans-serif;font-size:20px;margin-bottom:8px}.empty-state p{font-size:14px}.login-page{align-items:center;background:linear-gradient(135deg,#1b4332,#6b4226 60%,#9a7a2e);background:linear-gradient(135deg,var(--green-dark) 0,var(--brown) 60%,var(--gold-dark) 100%);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;background:var(--white);border-radius:28px;border-radius:var(--radius-xl);box-shadow:0 8px 40px #00000024;box-shadow:var(--shadow-lg);max-width:420px;padding:48px 40px;width:100%}.login-logo{color:#1b4332;color:var(--green-dark);font-family:Playfair Display,serif;font-size:32px;font-weight:900;margin-bottom:4px;text-align:center}.login-tagline{color:#999;color:var(--text-light);font-size:13px;letter-spacing:1.5px;margin-bottom:36px;text-align:center;text-transform:uppercase}.login-error{background:#ffebee;border-radius:8px;border-radius:var(--radius-sm);color:#c62828;color:var(--danger);font-size:14px;font-weight:500;margin-bottom:16px;padding:12px 16px}.success-banner{align-items:center;background:#d8f3dc;background:var(--green-light);border:1.5px solid #2d6a4f;border:1.5px solid var(--green);border-radius:20px;border-radius:var(--radius-lg);display:flex;gap:16px;padding:20px 24px}.success-banner .success-icon{font-size:32px}.success-banner .success-title{color:#1b4332;color:var(--green-dark);font-size:16px;font-weight:700}.success-banner .success-sub{color:#2d6a4f;color:var(--green);font-size:13px;margin-top:2px}.grid-2{grid-gap:20px;grid-template-columns:1fr 1fr}.grid-2,.grid-3{display:grid;gap:20px}.grid-3{grid-gap:20px;grid-template-columns:repeat(3,1fr)}@media (max-width:900px){.grid-2,.grid-3{grid-template-columns:1fr}}.loading-screen{align-items:center;background:#faf7f2;background:var(--cream);display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:100vh}.spinner{animation:spin .8s linear infinite;border:4px solid #f0ebe3;border-top-color:#2d6a4f;border:4px solid var(--cream-dark);border-radius:50%;border-top-color:var(--green);height:48px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:fadeUp .4s ease forwards}.fade-up-1{animation-delay:.05s;opacity:0}.fade-up-2{animation-delay:.1s;opacity:0}.fade-up-3{animation-delay:.15s;opacity:0}.fade-up-4{animation-delay:.2s;opacity:0}.fade-up-5{animation-delay:.25s;opacity:0}.text-gold{color:#c9a84c;color:var(--gold)}.text-green{color:#2d6a4f;color:var(--green)}.text-mid{color:#555;color:var(--text-mid)}.text-light{color:#999;color:var(--text-light)}.text-center{text-align:center}.font-serif{font-family:Playfair Display,serif}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}.mb-4{margin-bottom:4px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.mb-32{margin-bottom:32px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.w-full{width:100%}
/*# sourceMappingURL=main.64b1daa8.css.map*/