@font-face{font-family:Inter;font-style:normal;font-weight:300;font-display:swap;src:url(../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:300;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:300;font-display:swap;src:url(../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:300;font-display:swap;src:url(../media/5476f68d60460930-s.0wxq9webf.ew4.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:300;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:300;font-display:swap;src:url(../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:300;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/5476f68d60460930-s.0wxq9webf.ew4.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(../media/5476f68d60460930-s.0wxq9webf.ew4.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/5476f68d60460930-s.0wxq9webf.ew4.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/5476f68d60460930-s.0wxq9webf.ew4.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_5ba3adcc-module__M5nlAW__className{font-family:Inter,Inter Fallback;font-style:normal}.inter_5ba3adcc-module__M5nlAW__variable{--font-inter:"Inter", "Inter Fallback"}
@font-face{font-family:Outfit;font-style:normal;font-weight:400;font-display:swap;src:url(../media/b2ea385cb5ae8625-s.0kjod.kaq1k69.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Outfit;font-style:normal;font-weight:400;font-display:swap;src:url(../media/1b99372b3eaef0c8-s.p.0gx2haw2tmll8.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Outfit;font-style:normal;font-weight:500;font-display:swap;src:url(../media/b2ea385cb5ae8625-s.0kjod.kaq1k69.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Outfit;font-style:normal;font-weight:500;font-display:swap;src:url(../media/1b99372b3eaef0c8-s.p.0gx2haw2tmll8.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Outfit;font-style:normal;font-weight:600;font-display:swap;src:url(../media/b2ea385cb5ae8625-s.0kjod.kaq1k69.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Outfit;font-style:normal;font-weight:600;font-display:swap;src:url(../media/1b99372b3eaef0c8-s.p.0gx2haw2tmll8.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Outfit;font-style:normal;font-weight:700;font-display:swap;src:url(../media/b2ea385cb5ae8625-s.0kjod.kaq1k69.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Outfit;font-style:normal;font-weight:700;font-display:swap;src:url(../media/1b99372b3eaef0c8-s.p.0gx2haw2tmll8.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Outfit;font-style:normal;font-weight:800;font-display:swap;src:url(../media/b2ea385cb5ae8625-s.0kjod.kaq1k69.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Outfit;font-style:normal;font-weight:800;font-display:swap;src:url(../media/1b99372b3eaef0c8-s.p.0gx2haw2tmll8.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Outfit Fallback;src:local(Arial);ascent-override:100.18%;descent-override:26.05%;line-gap-override:0.0%;size-adjust:99.82%}.outfit_cbfa4884-module__hWmOPq__className{font-family:Outfit,Outfit Fallback;font-style:normal}.outfit_cbfa4884-module__hWmOPq__variable{--font-outfit:"Outfit", "Outfit Fallback"}
:root{--font-primary:var(--font-inter), -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-heading:var(--font-outfit), sans-serif;--bg-app:#090d16;--bg-sidebar:#0f1626;--bg-card:#15203680;--bg-card-hover:#1d2c4a99;--bg-input:#0f162699;--border-color:#ffffff14;--border-hover:#ffffff26;--text-primary:#f3f4f6;--text-secondary:#9ca3af;--text-muted:#6b7280;--accent-color:#6366f1;--accent-glow:#6366f126;--success:#10b981;--danger:#ef4444;--warning:#f59e0b;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--shadow-sm:0 2px 8px #00000026;--shadow-md:0 8px 30px #0000004d;--shadow-lg:0 15px 40px #0006;--glass-blur:16px;--grid-cell-bg:#162035;--grid-cell-border:#ffffff08}body.light-theme{--bg-app:#f4f6fa;--bg-sidebar:#fff;--bg-card:#ffffffb3;--bg-card-hover:#fffffff2;--bg-input:#f3f4f6cc;--border-color:#0000000f;--border-hover:#0000001f;--text-primary:#1f2937;--text-secondary:#4b5563;--text-muted:#9ca3af;--accent-glow:#6366f11a;--shadow-md:0 8px 30px #6366f10f;--shadow-lg:0 15px 40px #6366f114;--grid-cell-bg:#e5e7eb;--grid-cell-border:#00000005}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}body{font-family:var(--font-primary);background-color:var(--bg-app);color:var(--text-primary);min-height:100vh;transition:background-color .4s,color .4s;overflow-x:hidden}.bg-glow{filter:blur(120px);z-index:-1;pointer-events:none;opacity:.15;border-radius:50%;transition:opacity .5s;position:fixed}.bg-glow-1{background:radial-gradient(circle, var(--accent-color) 0%, transparent 70%);width:500px;height:500px;top:-10%;right:10%}.bg-glow-2{background:radial-gradient(circle,#ec4899 0%,#0000 70%);width:600px;height:600px;bottom:-10%;left:5%}body.light-theme .bg-glow{opacity:.08}.glass{background:var(--bg-card);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--border-color);box-shadow:var(--shadow-sm);transition:border .3s,background-color .3s,box-shadow .3s}.glass:hover{border-color:var(--border-hover)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.btn{border-radius:var(--radius-md);font-family:var(--font-heading);cursor:pointer;border:none;outline:none;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:.95rem;font-weight:600;transition:all .25s cubic-bezier(.4,0,.2,1);display:inline-flex}.btn-primary{background-color:var(--accent-color);color:#fff;box-shadow:0 4px 14px #6366f14d}.btn-primary:hover{background-color:#6a63e9;transform:translateY(-2px);box-shadow:0 6px 20px #6366f173}.btn-secondary{background-color:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background-color:var(--border-hover);border-color:var(--border-hover)}.btn-danger{background-color:var(--danger);color:#fff;box-shadow:0 4px 14px #ef444433}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ef444459}.btn-danger.btn-outline{color:var(--danger);border:1px solid var(--danger);box-shadow:none;background:0 0}.btn-danger.btn-outline:hover{background:#ef44441a;transform:translateY(-2px)}.btn-sm{border-radius:var(--radius-sm);padding:6px 12px;font-size:.85rem}.app-container{grid-template-columns:280px 1fr;min-height:100vh;display:grid}.sidebar{background-color:var(--bg-sidebar);border-right:1px solid var(--border-color);flex-direction:column;height:100vh;padding:24px;transition:background-color .4s,border-color .4s;display:flex;position:sticky;top:0}.sidebar-header{margin-bottom:36px}.logo{align-items:center;gap:12px;display:flex}.logo-icon{background:var(--accent-glow);width:40px;height:40px;color:var(--accent-color);border-radius:var(--radius-md);border:1px solid #6366f140;justify-content:center;align-items:center;display:flex}.logo span{font-family:var(--font-heading);letter-spacing:-.5px;background:linear-gradient(135deg, var(--text-primary) 30%, var(--accent-color) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:1.4rem;font-weight:800}.sidebar-nav{flex-direction:column;gap:8px;margin-bottom:32px;display:flex}.nav-btn{border-radius:var(--radius-md);color:var(--text-secondary);font-family:var(--font-primary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;padding:12px 16px;font-size:.95rem;font-weight:500;transition:all .2s;display:flex}.nav-btn:hover{color:var(--text-primary);background-color:var(--bg-input)}.nav-btn.active{color:#fff;background-color:var(--accent-color);box-shadow:0 4px 15px var(--accent-glow)}.sidebar-categories{flex-grow:1;margin-bottom:24px;overflow-y:auto}.sidebar-categories h3{font-family:var(--font-heading);text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:16px;font-size:.75rem}.category-filters{flex-direction:column;gap:6px;display:flex}.cat-filter-btn{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:8px 12px;font-size:.9rem;transition:all .2s;display:flex}.cat-filter-btn:hover{background-color:var(--bg-input);color:var(--text-primary)}.cat-filter-btn.active{background-color:var(--bg-input);color:var(--text-primary);font-weight:600}.cat-dot{border-radius:50%;width:8px;height:8px}.cat-count{color:var(--text-muted);background-color:#ffffff0d;border-radius:10px;margin-left:auto;padding:2px 6px;font-size:.75rem}.sidebar-footer{border-top:1px solid var(--border-color);padding-top:16px}.theme-toggle{border-radius:var(--radius-md);border:1px solid var(--border-color);background-color:var(--bg-input);width:100%;color:var(--text-primary);cursor:pointer;font-family:var(--font-heading);justify-content:center;align-items:center;gap:10px;padding:12px;font-weight:500;transition:all .25s;display:flex}.theme-toggle:hover{border-color:var(--border-hover);background-color:var(--bg-card-hover)}.theme-toggle .sun-icon{display:none}.theme-toggle .moon-icon,body.light-theme .theme-toggle .sun-icon{display:inline}body.light-theme .theme-toggle .moon-icon{display:none}.main-content{padding:40px 24px;padding-top:calc(24px + env(safe-area-inset-top,0px));padding-bottom:calc(100px + env(safe-area-inset-bottom,0px));height:100vh;overflow-y:auto}.top-bar{justify-content:space-between;align-items:center;margin-bottom:40px;display:flex}.welcome-section h1{font-family:var(--font-heading);letter-spacing:-.5px;margin-bottom:6px;font-size:2.2rem;font-weight:800}.welcome-section p{color:var(--text-secondary);font-size:1rem}.content-view{display:none}.content-view.active{animation:.4s cubic-bezier(.4,0,.2,1) viewFadeIn;display:block}@keyframes viewFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.overview-cards{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:40px;display:grid}.stat-card{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);align-items:center;gap:20px;padding:24px;display:flex}.stat-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:56px;height:56px;display:flex}.stat-icon i{width:26px;height:26px}.stat-info{flex-direction:column;display:flex}.stat-label{color:var(--text-secondary);margin-bottom:4px;font-size:.85rem}.stat-value{font-family:var(--font-heading);font-size:1.6rem;font-weight:700}.section-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.section-header h2{font-family:var(--font-heading);font-size:1.4rem;font-weight:700}.habits-sorting{align-items:center;gap:10px;display:flex}.habits-sorting label{color:var(--text-secondary);font-size:.85rem}.glass-select{border-radius:var(--radius-sm);border:1px solid var(--border-color);background-color:var(--bg-card);color:var(--text-primary);font-family:var(--font-primary);cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);outline:none;padding:8px 16px;font-size:.85rem}.glass-select:focus{border-color:var(--accent-color)}.empty-state{border-radius:var(--radius-lg);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;max-width:500px;margin:40px auto;padding:60px 40px;display:flex}.empty-icon{background:var(--accent-glow);width:64px;height:64px;color:var(--accent-color);border:1px solid #6366f126;border-radius:50%;justify-content:center;align-items:center;margin-bottom:8px;display:flex}.empty-icon i{width:30px;height:30px}.empty-state h3{font-family:var(--font-heading);font-size:1.25rem;font-weight:700}.empty-state p{color:var(--text-secondary);margin-bottom:8px;font-size:.95rem;line-height:1.5}.habits-list{grid-template-columns:1fr;gap:20px;display:grid}.habit-card{border-radius:var(--radius-lg);cursor:pointer;grid-template-columns:auto 1fr;align-items:center;gap:16px;padding:16px 20px;transition:transform .25s,box-shadow .25s,border-color .25s;display:grid;position:relative;overflow:hidden}.habit-card:hover{box-shadow:var(--shadow-md);background-color:var(--bg-card-hover);transform:translateY(-2px)}.habit-color-stripe{background-color:hsl(var(--habit-hue,145), 75%, 50%);width:6px;position:absolute;top:0;bottom:0;left:0;box-shadow:2px 0 10px #0000001a}.habit-check-wrapper{z-index:2;position:relative}.check-circle-btn{border:2px dashed hsl(var(--habit-hue,145), 70%, 55%);cursor:pointer;color:#0000;background:0 0;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex}.check-circle-btn:hover{color:hsl(var(--habit-hue,145), 70%, 55%);border-style:solid;transform:scale(1.1)}.check-circle-btn.completed{background-color:hsl(var(--habit-hue,145), 70%, 50%);border-style:solid;border-color:hsl(var(--habit-hue,145), 70%, 50%);color:#fff;box-shadow:0 0 15px rgba(var(--habit-color-rgb,16, 185, 129), .4)}.check-circle-btn.numeric{border-radius:12px}.habit-info-wrapper{flex-direction:column;gap:4px;display:flex}.habit-title-row{align-items:center;gap:12px;display:flex}.habit-card-title{font-family:var(--font-heading);font-size:1.2rem;font-weight:700}.habit-category-tag{color:var(--text-secondary);background-color:#ffffff0d;border-radius:20px;padding:3px 10px;font-size:.75rem;font-weight:600}.habit-card-desc{color:var(--text-secondary);font-size:.9rem}.habit-meta-row{color:var(--text-muted);align-items:center;gap:16px;margin-top:8px;font-size:.8rem;display:flex}.habit-meta-item{align-items:center;gap:6px;display:flex}.habit-meta-item.streak{color:var(--warning);background:#f59e0b1a;border-radius:10px;padding:2px 8px;font-weight:600}.mini-grid{grid-template-rows:repeat(7,10px);grid-template-columns:repeat(14,10px);gap:3px;margin-left:20px;display:grid}.mini-cell{background-color:var(--grid-cell-bg);border-radius:2px;width:10px;height:10px}.mini-cell.filled{background-color:hsl(var(--habit-hue,145), 70%, 50%)}.mini-cell.filled-1{background-color:hsl(var(--habit-hue,145), 70%, 30%)}.mini-cell.filled-2{background-color:hsl(var(--habit-hue,145), 70%, 45%)}.mini-cell.filled-3{background-color:hsl(var(--habit-hue,145), 70%, 60%)}.mini-cell.filled-4{background-color:hsl(var(--habit-hue,145), 70%, 75%)}.stats-grid{flex-direction:column;gap:20px;width:100%;display:flex}.chart-card{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex-direction:column;gap:16px;width:100%;padding:24px;display:flex}.chart-card.large{grid-column:span 1}.chart-card h3{font-family:var(--font-heading);font-size:1.1rem;font-weight:700}.chart-container{width:100%;height:280px;position:relative}.consistency-ring-wrapper{justify-content:center;align-items:center;padding:20px 0;display:flex}.consistency-ring{width:160px;height:160px;position:relative}.consistency-ring svg{transform:rotate(-90deg)}.ring-bg{fill:none;stroke:var(--grid-cell-bg);stroke-width:12px}.ring-fg{fill:none;stroke:var(--accent-color);stroke-width:12px;stroke-linecap:round;transition:stroke-dashoffset .6s}.ring-text{text-align:center;flex-direction:column;align-items:center;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.ring-text .percentage{font-family:var(--font-heading);font-size:1.8rem;font-weight:800}.ring-text .label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem}.ring-stats-detail{border-top:1px solid var(--border-color);grid-template-columns:1fr 1fr;gap:12px;margin-top:10px;padding-top:16px;display:grid}.ring-detail-item{flex-direction:column;align-items:center;display:flex}.ring-detail-item .num{font-family:var(--font-heading);font-size:1.25rem;font-weight:700}.ring-detail-item .txt{color:var(--text-muted);font-size:.75rem}.settings-container{border-radius:var(--radius-lg);max-width:800px;margin:0 auto;padding:32px}.settings-container h2{font-family:var(--font-heading);font-size:1.8rem;font-weight:800}.settings-divider{background-color:var(--border-color);border:0;height:1px;margin:24px 0}.settings-section{margin-bottom:32px}.settings-section h3{font-family:var(--font-heading);align-items:center;gap:10px;margin-bottom:20px;font-size:1.1rem;font-weight:700;display:flex}.settings-section h3 i{width:20px;height:20px;color:var(--accent-color)}.setting-row{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;gap:20px;padding:16px 0;display:flex}.setting-row:last-of-type{border-bottom:none}.setting-info{flex-direction:column;gap:4px;display:flex}.setting-label{font-size:.95rem;font-weight:600}.setting-desc{color:var(--text-secondary);font-size:.85rem;line-height:1.4}.theme-accent-picker{gap:10px;display:flex}.accent-color-btn{cursor:pointer;border:2px solid #0000;border-radius:50%;width:32px;height:32px;transition:transform .2s,border-color .2s}.accent-color-btn:hover{transform:scale(1.1)}.accent-color-btn.active{border-color:#fff;box-shadow:0 0 10px #fff6}body.light-theme .accent-color-btn.active{border-color:#1f2937;box-shadow:0 0 10px #00000026}.danger-zone{border-radius:var(--radius-md);background:#ef44440d;border:1px dashed #ef444433;margin-top:10px;padding:16px}.about-card{background:var(--bg-input);border-radius:var(--radius-md);color:var(--text-secondary);border:1px solid var(--border-color);padding:20px;font-size:.9rem;line-height:1.6}.friends-layout{flex-direction:column;gap:0;height:100%;display:flex;overflow:hidden}.friends-sub-nav{border-bottom:1px solid var(--border-color);gap:4px;padding:16px 16px 0;display:flex}.friends-sub-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #0000;border-bottom:none;border-radius:10px 10px 0 0;align-items:center;gap:6px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:all .18s;display:flex}.friends-sub-btn.active{background:var(--bg-card);color:var(--text-primary);border-color:var(--border-color);border-bottom-color:var(--bg-card);margin-bottom:-1px}.friends-content{flex-direction:column;flex:1;gap:16px;padding:20px 16px;display:flex;overflow-y:auto}.add-friend-bar{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);gap:10px;padding:14px 16px;display:flex}.add-friend-bar input{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);outline:none;flex:1;padding:8px 12px;font-size:.9rem;transition:border-color .2s}.add-friend-bar input:focus{border-color:var(--accent-color)}.friend-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);align-items:center;gap:14px;padding:14px 16px;transition:border-color .2s;display:flex}.friend-card:hover{border-color:#ffffff1f}.friend-avatar{background:linear-gradient(135deg, var(--accent-color), #a855f7);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.2rem;font-weight:800;display:flex}.friend-info{flex:1;min-width:0}.friend-name{white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:700;overflow:hidden}.friend-username{color:var(--text-muted);font-size:.78rem}.friend-stats{flex-shrink:0;align-items:center;gap:10px;display:flex}.friend-stat-pill{background:var(--bg-elevated);color:var(--text-secondary);border-radius:20px;align-items:center;gap:4px;padding:3px 8px;font-size:.75rem;font-weight:600;display:flex}.friend-request-card{border-radius:var(--radius-md);background:#6366f10f;border:1px solid #6366f133;align-items:center;gap:12px;padding:12px 14px;display:flex}.friend-request-actions{flex-shrink:0;gap:8px;margin-left:auto;display:flex}.feed-item{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);align-items:flex-start;gap:12px;padding:12px 14px;transition:border-color .2s;display:flex}.feed-item:hover{border-color:#ffffff1a}.feed-habit-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.feed-text{flex:1;font-size:.88rem;line-height:1.5}.feed-date{color:var(--text-muted);flex-shrink:0;font-size:.72rem}.explore-layout{flex-direction:column;gap:0;height:100%;display:flex;overflow:hidden}.explore-sub-nav{border-bottom:1px solid var(--border-color);gap:4px;padding:16px 16px 0;display:flex;overflow-x:auto}.explore-sub-btn{color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #0000;border-bottom:none;border-radius:10px 10px 0 0;align-items:center;gap:6px;padding:8px 18px;font-size:.85rem;font-weight:600;transition:all .18s;display:flex}.explore-sub-btn.active{background:var(--bg-card);color:var(--text-primary);border-color:var(--border-color);border-bottom-color:var(--bg-card);margin-bottom:-1px}.explore-content{flex-direction:column;flex:1;gap:12px;padding:20px 16px;display:flex;overflow-y:auto}.ranking-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);align-items:center;gap:14px;padding:12px 16px;transition:all .18s;display:flex}.ranking-card.me{background:#6366f112;border-color:#6366f140;box-shadow:0 0 16px #6366f114}.ranking-pos{text-align:center;width:32px;color:var(--text-muted);flex-shrink:0;font-size:.9rem;font-weight:800}.ranking-pos.top-1{color:#f59e0b;font-size:1.1rem}.ranking-pos.top-2{color:#94a3b8}.ranking-pos.top-3{color:#cd7c3a}.ranking-avatar{background:linear-gradient(135deg, var(--accent-color), #a855f7);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:.9rem;font-weight:800;display:flex}.ranking-info{flex:1;min-width:0}.ranking-name{white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:700;overflow:hidden}.ranking-username{color:var(--text-muted);font-size:.74rem}.ranking-xp{color:var(--accent-color);flex-shrink:0;font-size:.82rem;font-weight:700}.trending-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);align-items:center;gap:14px;padding:16px;transition:all .2s;display:flex}.trending-card:hover{border-color:#ffffff1a;transform:translateY(-1px)}.trending-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.trending-info{flex:1;min-width:0}.trending-name{font-size:.92rem;font-weight:700}.trending-meta{color:var(--text-muted);margin-top:2px;font-size:.75rem}.challenge-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);flex-direction:column;gap:12px;padding:20px;transition:all .2s;display:flex}.challenge-card:hover{border-color:#ffffff1a}.challenge-header{align-items:center;gap:12px;display:flex}.challenge-emoji{flex-shrink:0;font-size:2rem}.challenge-title{font-size:1rem;font-weight:700}.challenge-desc{color:var(--text-secondary);font-size:.85rem}.challenge-footer{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.challenge-pills{flex-wrap:wrap;gap:6px;display:flex}.challenge-pill{background:var(--bg-elevated);color:var(--text-secondary);border-radius:20px;padding:3px 10px;font-size:.72rem;font-weight:600}.challenge-enrolled{color:var(--success);align-items:center;gap:4px;font-size:.78rem;font-weight:700;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;opacity:0;pointer-events:none;background-color:#04070eb3;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:fixed;inset:0}.modal-overlay.active{opacity:1;pointer-events:auto}.modal-container{border-radius:var(--radius-lg);width:90%;max-width:500px;max-height:90vh;box-shadow:var(--shadow-lg);flex-direction:column;display:flex;overflow-y:auto}.modal-container.large-modal{max-width:850px}.modal-container.detail-modal{width:96%;max-width:680px}.detail-modal-body{flex-direction:column;gap:0;display:flex;overflow-y:auto}.detail-heatmap-section{border-bottom:1px solid var(--border-color);padding:20px 20px 16px}.heatmap-legend{color:var(--text-muted);align-items:center;gap:4px;font-size:.72rem;display:flex}.heatmap-legend-cell{border-radius:2px;flex-shrink:0;width:12px;height:12px}.heatmap-scroll-area{cursor:default;padding-bottom:6px;overflow:auto hidden}.heatmap-month-row{align-items:flex-end;margin-bottom:4px;display:flex}.heatmap-day-col-spacer{flex-shrink:0;width:22px}.heatmap-months-track{color:var(--text-muted);grid-template-columns:repeat(53,13px);gap:2px;font-size:.68rem;display:grid}.heatmap-month-label{white-space:nowrap;overflow:visible}.heatmap-body-row{align-items:flex-start;gap:4px;display:flex}.heatmap-day-col{flex-direction:column;flex-shrink:0;gap:2px;width:18px;padding-top:1px;display:flex}.heatmap-day-label{color:var(--text-muted);text-align:right;height:13px;font-size:.65rem;line-height:13px;display:block}.heatmap-cells-grid{grid-template-rows:repeat(7,13px);grid-template-columns:repeat(53,13px);grid-auto-flow:column;gap:2px;display:grid}.heatmap-cell{background:var(--grid-cell-bg);border:1px solid var(--grid-cell-border);cursor:pointer;border-radius:2px;width:13px;height:13px;transition:transform .1s,box-shadow .1s;position:relative}.heatmap-cell:hover{z-index:10;box-shadow:0 0 6px hsl(var(--habit-hue,145), 70%, 55%);transform:scale(1.4)}.heatmap-cell.hm-empty{opacity:.25;cursor:default}.heatmap-cell.hm-empty:hover{box-shadow:none;transform:none}.heatmap-cell.hm-full{background:hsl(var(--habit-hue,145), 70%, 50%);border-color:#0000}.heatmap-cell.hm-partial-1{background:hsl(var(--habit-hue,145), 65%, 22%);border-color:#0000}.heatmap-cell.hm-partial-2{background:hsl(var(--habit-hue,145), 68%, 35%);border-color:#0000}.heatmap-cell.hm-partial-3{background:hsl(var(--habit-hue,145), 70%, 44%);border-color:#0000}.heatmap-cell.hm-selected{outline-offset:1px;z-index:5;outline:2px solid #fff}.heatmap-cell.hm-noted:after{content:"";background:#f59e0b;border-radius:50%;width:3px;height:3px;position:absolute;top:1px;right:1px}.detail-date-panel{flex-direction:column;gap:14px;padding:16px 20px 20px;display:flex}.detail-date-badge{color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;align-items:center;gap:6px;width:fit-content;padding:6px 12px;font-size:.82rem;display:inline-flex}.detail-date-cards{flex-direction:column;gap:12px;display:flex}.detail-card{border-radius:var(--radius-md);border:1px solid var(--border-color);padding:14px 16px}.detail-card h4{color:var(--text-primary);margin:0 0 2px;font-size:.88rem;font-weight:700}.detail-actions-row{flex-wrap:wrap;gap:8px;display:flex}.detail-actions-row .btn{flex:auto;justify-content:center;align-items:center;min-width:80px;display:flex}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:24px;display:flex}.modal-header h2{font-family:var(--font-heading);font-size:1.4rem;font-weight:700}.modal-close-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:background-color .2s,color .2s;display:flex}.modal-close-btn:hover{background-color:var(--bg-input);color:var(--text-primary)}.modal-form{flex-direction:column;gap:20px;padding:24px;display:flex}.icon-picker-grid{grid-template-columns:repeat(6,1fr);gap:8px;display:grid}.icon-picker-btn{cursor:pointer;background:var(--bg-card);border:1.5px solid #0000;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:5px;padding:10px 6px;transition:all .18s;display:flex}.icon-picker-btn:hover{border-color:#ffffff26;transform:translateY(-1px)}.icon-picker-btn.active{transform:translateY(-1px)}.icon-picker-label{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:.62rem;overflow:hidden}.icon-picker-btn.active .icon-picker-label{color:var(--text-secondary)}.weekday-btn-row{grid-template-columns:repeat(7,1fr);gap:8px;display:grid}.weekday-btn{border:1.5px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;text-align:center;border-radius:12px;padding:10px 4px;font-size:.82rem;font-weight:600;transition:all .18s}.weekday-btn:hover{filter:brightness(1.15);transform:translateY(-1px)}.weekday-btn.active{color:#fff;font-weight:700}.community-toggle-card{border-radius:var(--radius-md);border:1.5px solid var(--border-color);background:var(--bg-card);cursor:pointer;text-align:left;justify-content:space-between;align-items:center;gap:12px;width:100%;padding:14px 16px;transition:all .2s;display:flex}.community-toggle-card:hover{border-color:#ffffff26}.community-toggle-left{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.community-toggle-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;transition:all .2s;display:flex}.community-toggle-title{font-size:.88rem;font-weight:600;transition:color .2s}.community-toggle-desc{color:var(--text-muted);margin-top:2px;font-size:.75rem}.community-toggle-switch{background:var(--border-color);border-radius:12px;flex-shrink:0;width:42px;height:24px;transition:background .25s;position:relative}.community-toggle-switch:after{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .25s;position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #0000004d}.community-toggle-switch.on{background:var(--success)}.community-toggle-switch.on:after{transform:translate(18px)}.form-group{flex-direction:column;gap:8px;display:flex}.form-grid-2{grid-template-columns:1fr 1fr;gap:20px;display:grid}.form-group label{color:var(--text-secondary);font-size:.85rem;font-weight:600}.form-group input[type=text],.form-group input[type=number]{border-radius:var(--radius-md);border:1px solid var(--border-color);background-color:var(--bg-input);color:var(--text-primary);font-family:var(--font-primary);outline:none;padding:12px 16px;font-size:.95rem;transition:border-color .25s}.form-group input:focus{border-color:var(--accent-color)}.meta-type-toggle{background:var(--bg-input);border-radius:var(--radius-md);border:1px solid var(--border-color);grid-template-columns:1fr 1fr;padding:4px;display:grid}.meta-opt{text-align:center;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);justify-content:center;align-items:center;padding:8px 12px;font-size:.85rem;font-weight:500;transition:all .2s;display:flex}.meta-opt.active{background-color:var(--bg-card);color:var(--text-primary);box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.freq-selector{gap:10px;display:flex}.freq-btn{border-radius:var(--radius-sm);border:1px solid var(--border-color);background-color:var(--bg-input);color:var(--text-secondary);font-family:var(--font-primary);cursor:pointer;flex:1;padding:10px;font-size:.85rem;font-weight:500;transition:all .2s}.freq-btn.active{background-color:var(--accent-color);color:#fff;border-color:var(--accent-color)}.weekdays-selector{justify-content:space-between;margin-top:10px;display:flex}.weekday-checkbox{cursor:pointer;display:block}.weekday-checkbox input{display:none}.weekday-checkbox span{border:1px solid var(--border-color);background-color:var(--bg-input);width:36px;height:36px;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;font-size:.8rem;font-weight:600;transition:all .2s;display:flex}.weekday-checkbox input:checked+span{background-color:var(--accent-color);color:#fff;border-color:var(--accent-color);box-shadow:0 0 10px var(--accent-glow)}.color-picker-grid{grid-template-columns:repeat(8,1fr);gap:8px;margin-bottom:12px;display:grid}.color-circle{aspect-ratio:1;cursor:pointer;border:2px solid #0000;border-radius:50%;transition:transform .2s,border-color .2s}.color-circle:hover{transform:scale(1.15)}.color-circle.active{border-color:#fff;box-shadow:0 0 10px #fff6}body.light-theme .color-circle.active{border-color:#1f2937;box-shadow:0 0 10px #00000026}.hue-slider-container{flex-direction:column;gap:8px;margin-top:8px;display:flex}.hue-slider-container label{color:var(--text-muted);font-size:.8rem}.slider-wrapper{align-items:center;gap:16px;display:flex}.hue-slider{-webkit-appearance:none;background:linear-gradient(to right, gradient-colors);cursor:pointer;border-radius:5px;outline:none;flex-grow:1;height:10px}.hue-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;border:2px solid var(--accent-color);background:#fff;border-radius:50%;width:20px;height:20px;box-shadow:0 0 5px #0000004d}.hue-preview{background-color:#20df70;border:2px solid #fff;border-radius:50%;width:24px;height:24px;box-shadow:0 0 5px #0003}.modal-actions{border-top:1px solid var(--border-color);justify-content:flex-end;gap:12px;padding:16px 24px 24px;display:flex}.mr-auto{margin-right:auto}.detail-modal-body{flex-direction:column;gap:24px;max-height:calc(90vh - 180px);padding:24px;display:flex;overflow-y:auto}.detail-header-info{flex-direction:column;gap:6px;display:flex}.detail-category-badge{background-color:#ffffff14;border-radius:20px;align-self:flex-start;padding:4px 12px;font-size:.75rem;font-weight:600}.detail-subtitle{color:var(--text-secondary);font-size:.95rem}.detail-stats-row{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;display:grid}.detail-stat-box{border-radius:var(--radius-md);text-align:center;flex-direction:column;align-items:center;gap:4px;padding:16px;display:flex}.detail-stat-box .lbl{color:var(--text-muted);text-transform:uppercase;font-size:.75rem}.detail-stat-box .val{font-family:var(--font-heading);font-size:1.15rem;font-weight:700}.grid-section{border-radius:var(--radius-lg);flex-direction:column;gap:16px;padding:24px;display:flex}.grid-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.grid-header h3{font-family:var(--font-heading);font-size:1.1rem;font-weight:700}.grid-legend{color:var(--text-muted);align-items:center;gap:8px;font-size:.75rem;display:flex}.legend-cells{gap:3px;display:flex}.legend-cell{border-radius:2px;width:11px;height:11px}.interactive-grid-container{padding-bottom:8px;overflow-x:auto}.grid-months-labels{color:var(--text-muted);grid-template-columns:repeat(53,1fr);min-width:770px;margin-bottom:6px;padding-left:28px;font-size:.7rem;display:grid}.grid-months-labels span{text-align:left;grid-column:span 4}.grid-body-wrapper{gap:10px;min-width:770px;display:flex}.grid-days-labels{color:var(--text-muted);text-align:right;flex-direction:column;justify-content:space-between;width:18px;padding:2px 0;font-size:.7rem;line-height:13px;display:flex}.grid-cells-wrapper{grid-flow:column;grid-template-rows:repeat(7,11px);grid-template-columns:repeat(53,11px);gap:3px;display:grid}.grid-cell{background-color:var(--grid-cell-bg);cursor:pointer;border:1px solid var(--grid-cell-border);border-radius:2px;width:11px;height:11px;transition:transform .15s,box-shadow .15s;position:relative}.grid-cell:hover{z-index:5;box-shadow:0 0 6px hsl(var(--habit-hue,145), 70%, 55%);border-color:#fff;transform:scale(1.3)}.grid-cell.filled{background-color:hsl(var(--habit-hue,145), 70%, 50%)}.grid-cell.filled-1{background-color:hsl(var(--habit-hue,145), 70%, 25%)}.grid-cell.filled-2{background-color:hsl(var(--habit-hue,145), 70%, 40%)}.grid-cell.filled-3{background-color:hsl(var(--habit-hue,145), 70%, 55%)}.grid-cell.filled-4{background-color:hsl(var(--habit-hue,145), 70%, 70%)}.grid-help-text{color:var(--text-secondary);align-items:center;gap:6px;font-size:.8rem;display:flex}.inline-icon{width:16px;height:16px;color:var(--accent-color)}.numeric-log-section{border-radius:var(--radius-md);flex-direction:column;gap:16px;padding:20px;display:flex}.numeric-log-section h3{font-family:var(--font-heading);font-size:1rem;font-weight:700}.numeric-log-form{align-items:center;gap:12px;display:flex}.input-with-addon{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);flex-grow:1;display:flex;overflow:hidden}.input-with-addon input{width:100%;color:var(--text-primary);background:0 0;border:none;outline:none;padding:12px 16px;font-size:.95rem}.addon-text{border-left:1px solid var(--border-color);color:var(--text-secondary);white-space:nowrap;background:#ffffff0a;align-items:center;padding:12px 16px;font-size:.9rem;display:flex}.progress-bar-wrapper{flex-direction:column;gap:8px;display:flex}.progress-bar-label{color:var(--text-secondary);justify-content:space-between;font-size:.85rem;display:flex}.progress-bar-outer{background-color:var(--bg-input);border-radius:5px;height:10px;overflow:hidden}.progress-bar-inner{background-color:hsl(var(--habit-hue,145), 70%, 50%);border-radius:5px;height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}.toast{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:2000;background:#0f1626d9;border:1px solid #10b9814d;align-items:center;gap:12px;padding:16px 24px;transition:all .3s cubic-bezier(.175,.885,.32,1.275);display:flex;position:fixed;bottom:24px;right:24px}.toast.hidden{opacity:0;pointer-events:none;transform:translateY(20px)scale(.9)}.toast-icon{color:var(--success);width:20px;height:20px}.toast-message{color:var(--text-primary);font-size:.9rem;font-weight:500}.animate-slide-up{animation:.35s cubic-bezier(.34,1.56,.64,1) forwards slideUp}.animate-fade-in{animation:.25s ease-out forwards fadeIn}.hidden{display:none!important}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.grid-cell:after{content:attr(data-tooltip);color:#fff;white-space:nowrap;opacity:0;pointer-events:none;z-index:10;background:#090d16;border:1px solid #ffffff1a;border-radius:4px;padding:6px 10px;font-size:.75rem;transition:opacity .15s,transform .15s;position:absolute;bottom:100%;left:50%;transform:translate(-50%)translateY(-6px);box-shadow:0 4px 10px #00000080}.grid-cell:hover:after{opacity:1;transform:translate(-50%)translateY(-3px)}@media (max-width:1024px){.app-container{grid-template-columns:1fr}.sidebar{border-right:none;border-bottom:1px solid var(--border-color);height:auto;padding:20px;position:relative}.sidebar-header{margin-bottom:20px}.sidebar-nav{flex-flow:wrap;margin-bottom:16px}.nav-btn{flex:1;justify-content:center;min-width:120px}.sidebar-categories{display:none}.main-content{height:auto;padding:24px;overflow-y:visible}.stats-grid{grid-template-columns:1fr}.chart-card.large{grid-column:span 1}}@media (max-width:600px){.top-bar{flex-direction:column;align-items:flex-start;gap:16px}.actions-section,.actions-section .btn{width:100%}.habit-card{grid-template-columns:auto 1fr;gap:16px}.mini-grid{display:none}.modal-container{width:95%;max-height:95vh}.form-grid-2{grid-template-columns:1fr;gap:12px}.modal-actions{flex-direction:column;gap:10px}.modal-actions .btn{width:100%}.mr-auto{margin-right:0}}.motivation-banner{border-radius:var(--radius-lg);background:linear-gradient(135deg, #6366f114 0%, #ec489914 100%), var(--bg-card);box-shadow:var(--shadow-sm);border:1px solid #ffffff14;align-items:center;gap:20px;margin-bottom:30px;padding:20px 24px;display:flex;position:relative;overflow:hidden}.motivation-banner:before{content:"";background:linear-gradient(to right, var(--accent-color), #ec4899, #f59e0b);height:2px;position:absolute;top:0;left:0;right:0}.motivation-emoji{font-size:2rem;animation:3s ease-in-out infinite bounceSlow}@keyframes bounceSlow{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.motivation-text-wrapper{flex-grow:1}.motivation-text-wrapper h3{font-family:var(--font-heading);background:linear-gradient(90deg,#fff,#d1d5db);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:4px;font-size:1.2rem;font-weight:700}body.light-theme .motivation-text-wrapper h3{-webkit-text-fill-color:var(--text-primary);background:0 0}.motivation-text-wrapper p{color:var(--text-secondary);font-size:.85rem;line-height:1.4}.motivation-progress-circle{flex-shrink:0;justify-content:center;align-items:center;width:60px;height:60px;display:flex;position:relative}.motivation-progress-circle svg{position:absolute;transform:rotate(-90deg)}.mot-circle-bg{fill:none;stroke:#ffffff0d;stroke-width:4px}body.light-theme .mot-circle-bg{stroke:#0000000d}.mot-circle-fg{fill:none;stroke:var(--accent-color);stroke-width:4px;stroke-linecap:round;transition:stroke-dashoffset .5s}.motivation-progress-circle span{font-family:var(--font-heading);font-size:.85rem;font-weight:700}.weekly-quick-log{border-top:1px solid var(--border-color);grid-column:span 3;justify-content:space-between;gap:8px;margin-top:16px;padding-top:16px;display:flex}.quick-log-day{cursor:pointer;flex-direction:column;flex:1;align-items:center;gap:6px;display:flex}.quick-log-label{color:var(--text-muted);font-size:.7rem;font-weight:600}.quick-log-circle{border:1px solid var(--border-color);background-color:var(--bg-input);color:#0000;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:.7rem;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex}.quick-log-day:hover .quick-log-circle{border-color:hsl(var(--habit-hue,145), 70%, 55%);color:hsl(var(--habit-hue,145), 70%, 55%)}.quick-log-day.not-scheduled{cursor:not-allowed}.quick-log-day.not-scheduled .quick-log-circle{opacity:.15;border-style:dotted}.quick-log-day.completed .quick-log-circle{background-color:hsl(var(--habit-hue,145), 70%, 50%);border-color:hsl(var(--habit-hue,145), 70%, 50%);color:#fff;box-shadow:0 0 10px #10b98140}.quick-log-day.completed.partial .quick-log-circle{background-color:hsl(var(--habit-hue,145), 70%, 25%);border-color:hsl(var(--habit-hue,145), 70%, 30%);color:#ffffff80}.detail-notes-section{border-radius:var(--radius-md);flex-direction:column;gap:12px;padding:20px;display:flex}.detail-notes-section h3{font-family:var(--font-heading);font-size:1rem;font-weight:700}.notes-input-wrapper{flex-direction:column;gap:12px;display:flex}.notes-input-wrapper textarea{border-radius:var(--radius-md);border:1px solid var(--border-color);background-color:var(--bg-input);width:100%;color:var(--text-primary);font-family:var(--font-primary);resize:none;outline:none;padding:12px 16px;font-size:.9rem;line-height:1.5;transition:border-color .25s}.notes-input-wrapper textarea:focus{border-color:var(--accent-color)}.grid-cell.has-note:before{content:"";z-index:2;background-color:#fff;border-radius:50%;width:4px;height:4px;position:absolute;top:2px;right:2px;box-shadow:0 0 2px #000c}body.light-theme .grid-cell.has-note:before{background-color:#000;box-shadow:0 0 2px #fffc}.archived-list{flex-direction:column;gap:10px;width:100%;margin-top:8px;display:flex}.archived-item{border-radius:var(--radius-md);background:var(--bg-input);border:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.archived-item-info{flex-direction:column;gap:2px;display:flex}.archived-item-name{font-family:var(--font-heading);font-size:.95rem;font-weight:600}.archived-item-cat{color:var(--text-muted);font-size:.75rem}.auth-container{background-color:var(--bg-app);justify-content:center;align-items:flex-start;min-height:100vh;padding:48px 20px;display:flex;position:relative;overflow-y:auto}@media (min-height:700px){.auth-container{align-items:center;padding:24px 20px}}.auth-card{border-radius:var(--radius-lg);border:1px solid var(--border-color);width:100%;max-width:440px;box-shadow:var(--shadow-lg);z-index:10;background:#0f162673;padding:40px;position:relative}.auth-header{text-align:center;margin-bottom:32px}.logo-icon-large{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--accent-color) 0%, #a855f7 100%);color:#fff;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 16px;display:flex;box-shadow:0 8px 24px #6366f14d}.auth-header h1{font-family:var(--font-heading);letter-spacing:-.5px;background:linear-gradient(90deg,#fff,#9ca3af);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:6px;font-size:2.2rem;font-weight:800}.auth-header p{color:var(--text-secondary);font-size:.95rem}.auth-form{flex-direction:column;gap:20px;display:flex}.input-with-icon{width:100%;position:relative}.input-with-icon .input-icon{width:18px;height:18px;color:var(--text-muted);pointer-events:none;transition:color .25s;position:absolute;top:50%;left:16px;transform:translateY(-50%)}.input-with-icon input{border-radius:var(--radius-md);border:1px solid var(--border-color);background-color:var(--bg-input);width:100%;color:var(--text-primary);font-family:var(--font-primary);outline:none;padding:14px 16px 14px 46px;font-size:.95rem;transition:border-color .25s,box-shadow .25s}.input-with-icon input:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px var(--accent-glow)}.input-with-icon input:focus+.input-icon{color:var(--accent-color)}.auth-submit-btn{border-radius:var(--radius-md);justify-content:center;align-items:center;gap:8px;width:100%;margin-top:10px;padding:14px;font-size:1rem;font-weight:600;display:flex}.auth-error-alert{color:#fca5a5;border-radius:var(--radius-md);background-color:#ef44441a;border:1px solid #ef444433;align-items:center;gap:10px;margin-bottom:20px;padding:12px 16px;font-size:.88rem;display:flex}.auth-footer{text-align:center;color:var(--text-secondary);margin-top:24px;font-size:.9rem}.auth-link{color:var(--accent-color);font-weight:600;text-decoration:none;transition:opacity .25s}.auth-link:hover{opacity:.8}.bottom-nav{bottom:calc(24px + env(safe-area-inset-bottom,0px));width:calc(100% - 48px);max-width:440px;-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--border-color);z-index:1000;background:#0f1626d9;border-radius:30px;justify-content:space-around;align-items:center;padding:8px 12px;transition:bottom .3s cubic-bezier(.25,1,.5,1);display:flex;position:fixed;left:50%;transform:translate(-50%);box-shadow:0 10px 40px #00000080}.bottom-nav.nav-hidden{bottom:-100px}.bottom-nav-btn{color:var(--text-muted);font-family:var(--font-primary);cursor:pointer;background:0 0;border:none;border-radius:20px;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:68px;padding:8px;font-size:.72rem;font-weight:500;transition:color .3s,background-color .3s,transform .2s;display:flex}.bottom-nav-btn:hover{color:var(--text-secondary)}.bottom-nav-btn:active{transform:scale(.95)}.bottom-nav-btn.active{color:var(--accent-color);background-color:var(--accent-glow)}.main-content{margin-left:0!important;padding-bottom:120px!important}.sidebar{display:none!important}@media (min-width:481px){.app-container{background-color:#070a10;justify-content:center;min-height:100vh;display:flex}.main-content{border-left:1px solid var(--border-color);border-right:1px solid var(--border-color);background-color:var(--bg-app);width:100%;max-width:480px;box-shadow:0 0 50px #0006}.top-bar{border-bottom:1px solid var(--border-color)}}.header-gamification{border:1px solid var(--accent-glow);border-radius:var(--radius-md);background:#6366f10d;align-items:center;gap:16px;width:100%;margin-bottom:20px;padding:8px 16px;display:flex}.user-level-badge{background:linear-gradient(135deg, var(--accent-color) 0%, #a855f7 100%);color:#fff;font-family:var(--font-heading);box-shadow:0 4px 12px var(--accent-glow);border-radius:20px;flex-shrink:0;align-items:center;gap:4px;padding:6px 12px;font-size:.95rem;font-weight:800;display:flex}.xp-progress-container{flex-direction:column;flex-grow:1;gap:4px;display:flex}.xp-text-row{color:var(--text-secondary);justify-content:space-between;font-size:.78rem;font-weight:600;display:flex}.xp-bar-bg{background:#ffffff14;border-radius:4px;width:100%;height:8px;position:relative;overflow:hidden}.xp-bar-fg{background:linear-gradient(to right, var(--accent-color), #a855f7);border-radius:4px;height:100%;transition:width .6s cubic-bezier(.25,1,.5,1)}@keyframes floatUp{0%{opacity:0;transform:translateY(0)scale(.8)}20%{opacity:1;transform:translateY(-20px)scale(1.1)}to{opacity:0;transform:translateY(-80px)scale(.9)}}.xp-floater{color:#a855f7;font-size:1.1rem;font-weight:800;font-family:var(--font-heading);pointer-events:none;z-index:2000;text-shadow:0 0 8px #a855f780;animation:1.2s cubic-bezier(.25,1,.5,1) forwards floatUp;position:absolute}.level-up-modal{text-align:center;padding:32px 16px}.level-up-badge-large{background:linear-gradient(135deg, var(--accent-color) 0%, #a855f7 100%);color:#fff;width:100px;height:100px;font-family:var(--font-heading);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 24px;font-size:3rem;font-weight:800;animation:2s infinite pulse;display:flex;box-shadow:0 12px 30px #a855f766}@keyframes pulse{0%{transform:scale(1);box-shadow:0 12px 30px #a855f766}50%{transform:scale(1.05);box-shadow:0 12px 40px #a855f799}to{transform:scale(1);box-shadow:0 12px 30px #a855f766}}.level-up-modal h2{font-family:var(--font-heading);background:linear-gradient(to right, #fff, var(--text-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:8px;font-size:2rem}.level-up-modal p{color:var(--text-secondary);margin-bottom:24px}.mood-selector{justify-content:space-between;gap:8px;width:100%;margin-bottom:16px;display:flex}.mood-btn{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;flex-direction:column;flex:1;align-items:center;gap:6px;padding:10px 6px;transition:transform .2s,border-color .25s,background-color .25s;display:flex}.mood-btn:hover{border-color:var(--border-hover);transform:translateY(-2px)}.mood-btn.active{border-color:var(--accent-color);background-color:var(--accent-glow);transform:translateY(-2px)scale(1.05)}.mood-emoji-large{font-size:1.4rem}.mood-label-small{color:var(--text-secondary);font-size:.68rem;font-weight:600}.mood-btn.active .mood-label-small{color:var(--accent-color)}.grid-cell.mood-incrivel{box-shadow:inset 0 0 0 2px #f59e0b99!important}.grid-cell.mood-bem{box-shadow:inset 0 0 0 2px #10b98199!important}.grid-cell.mood-neutro{box-shadow:inset 0 0 0 2px #6366f199!important}.grid-cell.mood-cansado{box-shadow:inset 0 0 0 2px #f59e0b66!important}.grid-cell.mood-triste{box-shadow:inset 0 0 0 2px #ef444480!important}.time-period-section{margin-bottom:24px}.time-period-header{font-family:var(--font-heading);color:var(--text-secondary);letter-spacing:.5px;text-transform:uppercase;align-items:center;gap:8px;margin-bottom:12px;font-size:.95rem;font-weight:700;display:flex}.time-period-header span{opacity:.8}.focus-tabs{gap:8px;margin-bottom:16px;display:flex}.focus-tab-btn{background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;border-radius:20px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:all .25s}.focus-tab-btn.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color);box-shadow:0 4px 12px var(--accent-glow)}.achievements-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px;margin-top:16px;display:grid}.badge-card{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);text-align:center;flex-direction:column;align-items:center;gap:10px;padding:16px 12px;transition:all .3s cubic-bezier(.25,1,.5,1);display:flex;position:relative;overflow:hidden}.badge-card:hover{border-color:#ffffff26;transform:translateY(-4px)scale(1.02)}.badge-card.unlocked{background:linear-gradient(135deg, #6366f114 0%, #a855f714 100%), var(--bg-card);border-color:#a855f759;box-shadow:0 8px 24px #a855f71f,inset 0 0 12px #6366f10d}.badge-card.unlocked:hover{border-color:#a855f799;box-shadow:0 12px 30px #a855f738,inset 0 0 12px #6366f11a}.badge-icon-wrapper{width:50px;height:50px;color:var(--text-muted);background:#ffffff0d;border-radius:50%;justify-content:center;align-items:center;transition:all .3s;display:flex}.badge-card.unlocked .badge-icon-wrapper{background:linear-gradient(135deg, var(--accent-color) 0%, #a855f7 100%);color:#fff;box-shadow:0 4px 12px #a855f740}.badge-card h4{font-family:var(--font-heading);margin:0;font-size:.85rem;font-weight:800}.badge-card.unlocked h4{color:#fff;text-shadow:0 0 10px #a855f766}body.light-theme .badge-card.unlocked h4{color:var(--text-primary);text-shadow:none}.badge-card.locked{opacity:.55;border:1px dashed var(--border-color);background:#ffffff03}.badge-card.locked .badge-icon-wrapper{color:var(--text-muted);background:#ffffff08}.badge-card.locked h4{color:var(--text-secondary)}.badge-card p{color:var(--text-muted);margin:0;font-size:.68rem;line-height:1.3}.single-check-wrapper{flex-shrink:0;justify-content:center;align-items:center;padding-right:16px;display:flex}.check-today-btn{color:#0000;cursor:pointer;background:#ffffff05;border:2px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:all .3s cubic-bezier(.25,.8,.25,1);display:flex}.check-today-btn:hover{border-color:var(--accent-color);background:var(--accent-glow);transform:scale(1.05)}.check-today-btn.completed{background:linear-gradient(135deg, var(--accent-color) 0%, #a855f7 100%);color:#fff;box-shadow:0 4px 12px var(--accent-glow);border-color:#0000}.settings-section-profile{border-radius:var(--radius-md);border:1px solid var(--border-color);background:#ffffff05;flex-direction:column;gap:16px;margin-bottom:20px;padding:20px;display:flex}.profile-avatar-row{align-items:center;gap:16px;display:flex}.profile-avatar-large{background:linear-gradient(135deg, var(--accent-color) 0%, #a855f7 100%);color:#fff;width:60px;height:60px;font-size:1.5rem;font-family:var(--font-heading);border-radius:50%;justify-content:center;align-items:center;font-weight:800;display:flex}.profile-user-info{flex-direction:column;gap:4px;display:flex}.profile-user-name{font-family:var(--font-heading);font-size:1.15rem;font-weight:700}.profile-user-email{color:var(--text-secondary);font-size:.85rem}.logout-row{width:100%;margin-top:10px}.categories-scroll-container{scrollbar-width:none;gap:8px;margin-bottom:16px;padding-bottom:8px;display:flex;overflow-x:auto}.categories-scroll-container::-webkit-scrollbar{display:none}.category-chip{background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-radius:20px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:all .25s}.category-chip:hover{border-color:var(--border-hover);color:var(--text-primary)}.category-chip.active{color:#fff;box-shadow:0 4px 12px var(--accent-glow)}.template-selector-btn{border-radius:var(--radius-md);border:1px dashed var(--accent-color);width:100%;color:var(--accent-color);cursor:pointer;background:#6366f114;justify-content:center;align-items:center;gap:8px;margin-bottom:16px;padding:12px;font-weight:600;transition:all .2s;display:flex}.template-selector-btn:hover{background:#6366f11f;transform:translateY(-1px)}.templates-category-tabs{scrollbar-width:none;gap:6px;margin-bottom:12px;padding-bottom:6px;display:flex;overflow-x:auto}.templates-category-tabs::-webkit-scrollbar{display:none}.template-category-tab{background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-radius:12px;padding:6px 12px;font-size:.75rem;transition:all .2s}.template-category-tab:hover{border-color:var(--border-hover);color:var(--text-primary)}.template-category-tab.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.templates-grid{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:#00000026;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px;max-height:220px;margin-bottom:16px;padding:8px;display:grid;overflow-y:auto}.template-item-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;text-align:left;flex-direction:column;gap:4px;padding:10px;transition:all .2s;display:flex}.template-item-card:hover{border-color:var(--accent-color);background:var(--bg-card-hover)}.template-item-name{color:var(--text-primary);font-size:.8rem;font-weight:700}.template-item-desc{color:var(--text-secondary);font-size:.7rem;line-height:1.25}.template-xp-badge-preview{color:var(--success);margin-top:4px;font-size:.75rem;font-weight:700}.profile-edit-form{flex-direction:column;gap:16px;margin-top:16px;display:flex}.avatar-grid{grid-template-columns:repeat(6,1fr);gap:8px;margin-top:8px;display:grid}.avatar-option-btn{background:var(--bg-input);cursor:pointer;border:2px solid #0000;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.4rem;transition:all .2s;display:flex}.avatar-option-btn:hover{transform:scale(1.1)}.avatar-option-btn.active{border-color:var(--accent-color);background:var(--accent-glow);box-shadow:0 0 10px var(--accent-glow)}.settings-list{background:var(--bg-card);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--border-color);border-radius:var(--radius-lg);flex-direction:column;display:flex;overflow:hidden}.settings-item{border:none;border-bottom:1px solid var(--border-color);width:100%;color:var(--text-primary);font-family:var(--font-primary);cursor:pointer;text-align:left;background:0 0;justify-content:space-between;align-items:center;padding:16px 20px;font-size:.92rem;font-weight:600;transition:background-color .2s;display:flex}.settings-item:last-child{border-bottom:none}.settings-item:hover{background-color:#ffffff08}body.light-theme .settings-item:hover{background-color:#00000005}.settings-item-label{align-items:center;gap:12px;display:flex}.settings-item-arrow{color:var(--text-muted);justify-content:center;align-items:center;transition:transform .25s cubic-bezier(.4,0,.2,1);display:flex}.settings-item-arrow.expanded{transform:rotate(90deg)}.settings-expanded-content{border-bottom:1px solid var(--border-color);background:#00000026;padding:20px;animation:.25s cubic-bezier(.25,1,.5,1) slideDownFade}.settings-expanded-content:last-child{border-bottom:none}@keyframes slideDownFade{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.badge-icon-wrapper-large{border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;transition:all .3s;display:flex}.badge-icon-wrapper-large.unlocked{background:linear-gradient(135deg, var(--accent-color) 0%, #a855f7 100%);color:#fff;animation:2s ease-in-out infinite badgePulse;box-shadow:0 8px 30px #a855f766}.badge-icon-wrapper-large.locked{color:var(--text-muted);border:2px dashed var(--border-color);background:#ffffff0d}@keyframes badgePulse{0%,to{transform:scale(1);box-shadow:0 8px 30px #a855f766}50%{transform:scale(1.05);box-shadow:0 12px 35px #a855f799}}.badge-modal-status{border-radius:20px;align-items:center;gap:6px;padding:6px 14px;font-size:.8rem;font-weight:700;display:inline-flex}.badge-modal-status.unlocked{color:var(--success);background:#10b9811f;border:1px solid #10b98140}.badge-modal-status.locked{color:var(--text-secondary);border:1px solid var(--border-color);background:#ffffff0d}.badge-modal-progress-bar-bg{background:#ffffff14;border-radius:4px;width:100%;height:8px;margin-bottom:16px;overflow:hidden}body.light-theme .badge-modal-progress-bar-bg{background:#00000014}.badge-modal-progress-bar-fg{background:linear-gradient(to right, var(--accent-color), #a855f7);border-radius:4px;height:100%;transition:width .5s cubic-bezier(.25,1,.5,1)}.badge-modal-tips-box{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:#ffffff05;align-items:flex-start;gap:12px;padding:12px 14px;display:flex}body.light-theme .badge-modal-tips-box{background:#00000005}.badge-modal-reward-card{border-radius:var(--radius-md);text-align:center;background:linear-gradient(135deg,#f59e0b14 0%,#ef44440a 100%);border:1px solid #f59e0b33;padding:14px;box-shadow:0 4px 12px #f59e0b0d}.premium-header-card{border-radius:var(--radius-lg);background:linear-gradient(135deg, #6366f11f 0%, #a855f714 100%), var(--bg-card);border:1px solid var(--border-color);box-shadow:var(--shadow-md), inset 0 0 15px #ffffff05;padding:16px 20px}.fab-btn{bottom:calc(96px + env(safe-area-inset-bottom,0px));background:linear-gradient(135deg, var(--accent-color) 0%, #a855f7 100%);color:#fff;cursor:pointer;z-index:999;border:none;border-radius:50%;justify-content:center;align-items:center;width:54px;height:54px;transition:transform .25s cubic-bezier(.175,.885,.32,1.275),box-shadow .25s;display:flex;position:fixed;right:20px;box-shadow:0 6px 20px #6366f173}.fab-btn:hover{transform:scale(1.1);box-shadow:0 8px 25px #6366f199}.fab-btn:active{transform:scale(.95)}@media (min-width:481px){.fab-btn{right:calc(50% - 220px)}}.motivation-banner.compact{padding:12px 16px}.motivation-progress-circle-compact{flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex;position:relative}.motivation-dismiss-btn{color:var(--text-muted);cursor:pointer;opacity:.6;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;transition:opacity .2s;display:flex}.motivation-dismiss-btn:hover{opacity:1;color:var(--text-primary)}.habit-card{border-style:solid;border-width:1px;border-left:none!important}.check-today-btn{border:2px dashed hsla(var(--btn-hue,145), 70%, 55%, .5);color:#0000;cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex}body.light-theme .check-today-btn{border-color:hsla(var(--btn-hue,145), 60%, 45%, .4)}.check-today-btn:hover{border-style:solid;border-color:hsl(var(--btn-hue,145), 75%, 55%);color:hsl(var(--btn-hue,145), 75%, 55%);transform:scale(1.1)}.check-today-btn.completed{background:linear-gradient(135deg, hsl(var(--btn-hue,145), 75%, 50%) 0%, #a855f7 100%);color:#fff;box-shadow:0 4px 12px hsla(var(--btn-hue,145), 75%, 50%, .35);border-style:solid;border-color:#0000}.dashboard-controls-row{margin-top:4px}.focus-tab-btn{padding:6px 14px;font-size:.8rem}.categories-scroll-container{margin-bottom:20px;padding-bottom:4px}.habit-numeric-progress-container{flex-direction:column;width:100%;display:flex}:root{--bg-app:#070c16;--bg-card:#0b111ebf;--bg-card-hover:#10182ae0;--bg-sidebar:#0c1420;--bg-input:#0a101c99}.bg-glow{opacity:.28}@media (min-width:481px){.app-container{background:radial-gradient(70% 60% at 15% 15%,#6366f11a 0%,#0000 55%),radial-gradient(60% 55% at 85% 85%,#a855f714 0%,#0000 55%),radial-gradient(50% 50% at 50% 40%,#10b9810a 0%,#0000 65%),#060b14}.main-content{box-shadow:0 0 0 1px #ffffff0a,0 0 60px #6366f11a,0 30px 80px #00000080}}.btn-primary{background:linear-gradient(135deg,#6366f1,#7c3aed);box-shadow:0 4px 14px #6366f14d}.btn-primary:hover{filter:brightness(1.1);background:linear-gradient(135deg,#6366f1,#7c3aed);box-shadow:0 6px 22px #6366f180}.welcome-section h1{background:linear-gradient(135deg,#fff 0%,#e2e8f0 50%,#a5b4fc 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.premium-header-card{background:linear-gradient(135deg,#6366f124 0%,#a855f717 100%),#0b111ed9;border-color:#6366f12e;position:relative;overflow:hidden;box-shadow:0 8px 32px #6366f114,0 0 0 1px #6366f11f}.premium-header-card:before{content:"";border-radius:var(--radius-lg) var(--radius-lg) 0 0;background:linear-gradient(90deg,#6366f1,#a855f7,#ec4899);height:2px;position:absolute;top:0;left:0;right:0}.bottom-nav{background:#080d18e0;border-color:#ffffff12;box-shadow:0 12px 48px #0000008c,0 0 0 1px #6366f114}.bottom-nav-btn.active{color:#a5b4fc;background:linear-gradient(135deg,#6366f12e,#a855f71f)}.focus-tab-btn.active{background:linear-gradient(135deg,#6366f1,#7c3aed);border-color:#0000;box-shadow:0 4px 14px #6366f14d}.time-period-header{color:var(--text-muted);letter-spacing:1px;font-size:.78rem}.habit-card{transition:transform .25s,box-shadow .25s,border-color .25s,background .25s;background:#0b111eb3!important}.habit-card:hover{box-shadow:0 8px 28px #0000004d;background:#10182ae0!important}.glass{background:#0b111eb3}.category-chip{background:#0b111e99;border-color:#ffffff12;padding:6px 14px;font-size:.78rem}.top-bar .welcome-section h1{font-size:1.6rem}.modal-overlay{background:#04070ebf}.toast{background:#080d18eb;border-color:#6366f140;box-shadow:0 8px 32px #00000080,0 0 0 1px #6366f11a}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton{background:linear-gradient(90deg,#ffffff0a 25%,#ffffff14 50%,#ffffff0a 75%) 0 0/200% 100%;border-radius:8px;animation:1.6s infinite shimmer}.skeleton-card{border-radius:var(--radius-lg);border:1px solid #ffffff0d;flex-direction:column;gap:12px;padding:16px 20px;display:flex}.skeleton-line{border-radius:6px;height:14px}.skeleton-grid-row{grid-template-columns:repeat(7,1fr);gap:3px;margin-top:4px;display:grid}.skeleton-cell{aspect-ratio:1;border-radius:3px}.habit-month-grid{margin-top:8px;padding-top:10px}.habit-month-grid-days{grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:3px;display:grid}.habit-month-grid-week{grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:2px;display:grid}.habit-month-cell{aspect-ratio:1;background:#ffffff0f;border-radius:3px;transition:transform .15s}.habit-month-cell.empty{background:0 0}.habit-month-cell.skip{opacity:.4;background:#ffffff08}.habit-month-cell.today{outline-offset:1px;outline:1.5px solid #ffffff80}.habit-month-cell:hover{transform:scale(1.15)}.onboarding-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;background:#04070ed9;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.onboarding-card{background:#080e1af2;border:1px solid #6366f140;border-radius:24px;width:100%;max-width:420px;padding:32px 28px;box-shadow:0 32px 80px #000000b3,0 0 0 1px #6366f11a}.onboarding-step-dots{justify-content:center;gap:6px;margin-bottom:28px;display:flex}.onboarding-dot{background:#ffffff26;border-radius:50%;width:6px;height:6px;transition:all .25s}.onboarding-dot.active{background:var(--accent-color);border-radius:3px;width:20px}.drag-handle{cursor:grab;color:var(--text-muted);opacity:0;touch-action:none;padding:4px;transition:opacity .2s}.habit-card:hover .drag-handle{opacity:1}.habit-card[data-dragging=true]{opacity:.5;cursor:grabbing;box-shadow:0 16px 48px #00000080}@media (max-width:479px){.bottom-nav{gap:0;padding:6px 4px 10px}.bottom-nav-btn{flex:1;min-width:0;padding:4px 6px;font-size:.6rem}.bottom-nav-btn svg{width:18px;height:18px}.top-bar{padding:10px 14px!important}.top-bar .welcome-section h1{font-size:1.2rem!important}.content-view{padding:0 10px!important}.habit-card{padding:10px 12px}.stats-grid{grid-template-columns:repeat(2,1fr)!important}.mini-calendar-day-label{font-size:.6rem}.modal-content{margin:0 2vw;width:96vw!important;max-width:96vw!important;padding:18px 14px!important}.add-friend-bar{flex-direction:column}.add-friend-bar input{width:100%}.profile-avatar-large{width:48px!important;height:48px!important;font-size:1.4rem!important}.ranking-card{gap:8px;padding:10px 12px}.ranking-xp{font-size:.78rem}.focus-tab-btn,.friends-sub-btn,.explore-sub-btn{padding:6px 8px;font-size:.7rem}}
