:root{--bg-primary: #ede0d0;--card-bg: #f5f2e9;--card-bg-light: #fdfaf5;--accent: #9f4022;--accent-hover: #86351d;--text-primary: #53372b;--text-secondary: rgba(83, 55, 43, .6);--text-tertiary: rgba(83, 55, 43, .4);--success-bg: #e7f3e2;--success-text: #2d5a27;--warning-bg: #fcecc9;--warning-text: #856404;--danger-bg: #f8e7e7;--danger-text: #721c24;--border-color: rgba(83, 55, 43, .1);--nav-bg: #f5f2e9;--nav-item-active: #ede0d0;--pill-bg: #f5f2e9;--font-heading: "Playfair Display", serif;--font-body: "Outfit", sans-serif;--sidebar-width: 250px;--max-content-width: 1200px;--nav-height: 70px;--border-radius: 20px;--transition-speed: .3s}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-body);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.5;display:flex;min-height:100vh;overflow-x:hidden}#root{width:100%;min-height:100vh;display:flex;flex-direction:column}.layout-root{display:flex;width:100%;min-height:100vh;flex-direction:column}.main-content{flex:1;padding:100px 24px 40px;max-width:var(--max-content-width);width:100%;margin:0 auto;transition:padding .3s ease}h1,h2,h3{font-family:var(--font-heading);font-weight:800}::-webkit-scrollbar{width:0px;background:transparent}.page-container{width:100%}.section-title{font-size:24px;margin-bottom:4px}.section-subtitle{font-size:14px;color:var(--text-secondary);margin-bottom:24px}.card{background:var(--card-bg-light);border-radius:var(--border-radius);border:1px solid var(--border-color);padding:24px;margin-bottom:16px;transition:transform .2s ease}.status-badge{padding:12px;border-radius:12px;font-weight:600;font-size:16px;display:flex;align-items:center;justify-content:center;gap:8px;width:100%}.bottom-nav{position:fixed;top:0;left:-280px;width:280px;height:100vh;background:var(--nav-bg);display:flex;flex-direction:column;justify-content:flex-start;padding:40px 24px;border-right:1px solid var(--border-color);box-shadow:10px 0 30px #53372b0d;z-index:1500;transition:transform .4s cubic-bezier(.4,0,.2,1),left .4s cubic-bezier(.4,0,.2,1)}.bottom-nav.open{transform:translate(280px)}@media (max-width: 1023px){.bottom-nav{left:-280px}}@media (min-width: 1024px){body{flex-direction:row}#root{flex-direction:row;align-items:stretch}.layout-root{flex-direction:row}.bottom-nav{left:0;transform:none!important}.burger-btn{display:none}.main-content{margin-left:280px;padding-top:40px;max-width:calc(var(--max-content-width) + 280px)}.nav-item{width:100%;flex-direction:row;justify-content:flex-start;padding:16px 20px;gap:16px;border-radius:16px;color:var(--text-secondary);font-size:16px}.nav-item span{font-size:16px;font-weight:500}.sidebar-logo{display:block!important}}.nav-logo-section{padding:24px 0 32px 12px;display:flex;justify-content:space-between;align-items:center}.logo-box{width:60px;height:60px;border-radius:14px;overflow:hidden;background:white;border:1px solid var(--border-color);box-shadow:0 5px 15px #0000000d}.logo-box img{width:100%;height:100%;object-fit:cover}.nav-items-container{display:flex;flex-direction:column;gap:8px;width:100%}.logout-container{margin-top:auto;padding-top:40px}.logout-btn{opacity:.5;border:none;background:transparent;width:100%;text-align:left;display:flex;gap:16px;align-items:center;cursor:pointer;padding:12px 16px;border-radius:12px;transition:.2s}.logout-btn:hover{opacity:1;background:rgba(83,55,43,.05)}.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:8px 12px;border-radius:12px;transition:all .2s ease;min-width:60px}.nav-item.active{color:var(--accent);background:var(--nav-item-active)}.nav-item.active span{font-weight:700}.nav-item i{width:24px;height:24px}.nav-item span{font-size:11px}.day-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:12px;margin-bottom:24px;max-width:800px}.day-card{aspect-ratio:1;border-radius:12px;background:var(--nav-item-active);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:.2s;border:1px solid rgba(83,55,43,.05);font-weight:700;font-size:12px;color:var(--text-primary)}.day-card.completed{background:var(--danger-bg);color:var(--accent)}.day-card.active{background:var(--accent);color:#fff;position:relative}.day-card.active:after{content:"";position:absolute;top:-2px;right:-2px;width:10px;height:10px;background:white;border-radius:50%;border:2px solid var(--accent)}.day-card.locked{background:#EFEFEF;opacity:.6;cursor:not-allowed}.leaderboard-tabs{display:flex;background:#EFE6DD;padding:6px;border-radius:16px;margin-bottom:32px;max-width:500px;margin-left:auto;margin-right:auto}.leaderboard-tab{flex:1;padding:10px;border:none;background:transparent;font-weight:700;border-radius:12px;color:var(--text-secondary);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-size:14px}.leaderboard-tab.active{background:white;color:var(--text-primary);box-shadow:0 4px 12px #0000000d}.ranking-card{display:flex;align-items:center;gap:16px;background:white;padding:20px 24px;border-radius:20px;margin-bottom:12px;border:1px solid var(--border-color);transition:transform .2s}.ranking-card.me{background:#fdf3ef;border:1px solid #f8e1d7;box-shadow:0 10px 20px #b25b320d}.rank-badge{width:44px;font-weight:800;font-size:14px;color:var(--text-secondary);display:flex;justify-content:center}.avatar-circle{width:48px;height:48px;background:#f1f1f1;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--text-primary);font-size:14px}.name-stack h4{margin:0;font-size:16px;color:var(--text-primary)}.name-stack p{margin:0;font-size:13px;color:var(--text-secondary);font-weight:500}.points-display{margin-left:auto;font-weight:900;font-size:18px;color:var(--text-primary)}.team-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:40px}.stat-card{background:#f9f5f1;padding:32px 24px;border-radius:24px;display:flex;flex-direction:column;align-items:center;justify-content:center;border:1px solid var(--border-color)}.stat-value{font-size:32px;font-weight:950;color:#1a1411;font-family:var(--font-heading);margin:8px 0}.stat-label{font-size:12px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em}.member-progress-bar{width:80px;height:6px;background:#e5e5e5;border-radius:3px;overflow:hidden;position:relative}.member-progress-fill{height:100%;background:#964b29;border-radius:3px}.member-percent{font-size:11px;color:var(--text-tertiary);margin-top:4px}.burger-btn{display:none;position:fixed;top:20px;left:20px;z-index:2000;background:white;border:1px solid var(--border-color);width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 12px #0000000d;color:var(--accent)}.overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.2);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1400}@media (max-width: 1023px){.main-content{padding:20px 16px 100px}.sidebar-width{width:0}.nav-logo-section{display:none}.nav-items-container{flex-direction:row;height:100%;gap:0}.logout-container{display:none}.bottom-nav{position:fixed;bottom:0;left:0;top:auto;width:100%;height:70px;background:white;border-top:1px solid var(--border-color);padding:0;flex-direction:row;justify-content:space-around;align-items:center;box-shadow:0 -4px 12px #0000000d;z-index:2000}.bottom-nav .nav-item{flex:1;height:100%;justify-content:center;border-radius:0;padding:10px 0}.day-grid{grid-template-columns:repeat(7,1fr);gap:6px}.day-card{font-size:10px}.team-stats-grid{grid-template-columns:1fr;gap:12px}.stat-card{padding:20px}.stat-value{font-size:24px}.ranking-card{padding:12px 16px;gap:12px}.ranking-info{max-width:150px;overflow:hidden}.ranking-name{font-size:14px}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:.2;transform:scale(.95)}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.login-screen{width:100%;min-height:100vh;display:flex;background:#fbf9f4;overflow:hidden}.login-aside{display:none;flex:1.2;position:relative;overflow:hidden}.login-aside img{width:100%;height:100%;object-fit:cover;filter:sepia(.2) contrast(1.1)}.login-aside-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(0deg,rgba(83,55,43,.4) 0%,rgba(0,0,0,0) 60%);display:flex;flex-direction:column;justify-content:flex-end;padding:60px;color:#fff}.login-aside-text h2{font-size:48px;line-height:1.1;margin-bottom:16px;font-family:var(--font-heading);font-weight:300;font-style:italic}.login-main{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 24px;background:white;box-shadow:-10px 0 50px #00000008;z-index:10}.login-card{max-width:420px;width:100%;text-align:center}.login-logo{width:90px;height:90px;background:white;border-radius:28px;display:flex;align-items:center;justify-content:center;margin:0 auto 40px;border:1px solid rgba(83,55,43,.1);box-shadow:0 15px 35px #53372b14}.login-logo span{font-size:28px;font-weight:900;font-style:italic;color:var(--accent);letter-spacing:-1px}.login-card h1{font-size:36px;font-weight:400;color:var(--text-primary);margin-bottom:12px;letter-spacing:-.5px}.login-card p{color:var(--text-secondary);font-size:15px;margin-bottom:48px;line-height:1.6}.google-login-btn{width:100%;padding:20px;background:var(--text-primary);color:#fff;border-radius:20px;border:none;font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.1em;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;gap:12px;box-shadow:0 15px 30px #53372b33}.google-login-btn:hover{transform:translateY(-3px);box-shadow:0 20px 40px #53372b4d;background:#402a21}.google-icon{width:20px;height:20px}.login-footer{margin-top:60px;font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.25em;font-weight:800}@media (min-width: 1024px){.login-aside{display:block}.login-main{border-radius:40px 0 0 40px}}@media (max-width: 1023px){.login-screen{background:white}.login-main{box-shadow:none}}
