@font-face{font-family:IBM Plex Sans;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(../media/7fea77d1d19108bf-s.2y65deuc30pmy.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:IBM Plex Sans;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(../media/1bcd0e671759a44c-s.2qt3tdwt-y9x_.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:IBM Plex Sans;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(../media/e15f58668ad64cb8-s.3cvcemwuzoywn.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:IBM Plex Sans;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(../media/90c51ce8fb754fe8-s.02z5rrbg5nt92.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:IBM Plex Sans;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(../media/57215795b8570f5c-s.2rixgazldzomk.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:IBM Plex Sans;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(../media/03fc1b4a8d284b5e-s.p.0wiir8udbzjvx.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:IBM Plex Sans;font-style:normal;font-weight:500;font-stretch:100%;font-display:swap;src:url(../media/7fea77d1d19108bf-s.2y65deuc30pmy.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:IBM Plex Sans;font-style:normal;font-weight:500;font-stretch:100%;font-display:swap;src:url(../media/1bcd0e671759a44c-s.2qt3tdwt-y9x_.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:IBM Plex Sans;font-style:normal;font-weight:500;font-stretch:100%;font-display:swap;src:url(../media/e15f58668ad64cb8-s.3cvcemwuzoywn.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:IBM Plex Sans;font-style:normal;font-weight:500;font-stretch:100%;font-display:swap;src:url(../media/90c51ce8fb754fe8-s.02z5rrbg5nt92.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:IBM Plex Sans;font-style:normal;font-weight:500;font-stretch:100%;font-display:swap;src:url(../media/57215795b8570f5c-s.2rixgazldzomk.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:IBM Plex Sans;font-style:normal;font-weight:500;font-stretch:100%;font-display:swap;src:url(../media/03fc1b4a8d284b5e-s.p.0wiir8udbzjvx.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:IBM Plex Sans;font-style:normal;font-weight:600;font-stretch:100%;font-display:swap;src:url(../media/7fea77d1d19108bf-s.2y65deuc30pmy.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:IBM Plex Sans;font-style:normal;font-weight:600;font-stretch:100%;font-display:swap;src:url(../media/1bcd0e671759a44c-s.2qt3tdwt-y9x_.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:IBM Plex Sans;font-style:normal;font-weight:600;font-stretch:100%;font-display:swap;src:url(../media/e15f58668ad64cb8-s.3cvcemwuzoywn.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:IBM Plex Sans;font-style:normal;font-weight:600;font-stretch:100%;font-display:swap;src:url(../media/90c51ce8fb754fe8-s.02z5rrbg5nt92.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:IBM Plex Sans;font-style:normal;font-weight:600;font-stretch:100%;font-display:swap;src:url(../media/57215795b8570f5c-s.2rixgazldzomk.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:IBM Plex Sans;font-style:normal;font-weight:600;font-stretch:100%;font-display:swap;src:url(../media/03fc1b4a8d284b5e-s.p.0wiir8udbzjvx.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:IBM Plex Sans;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(../media/7fea77d1d19108bf-s.2y65deuc30pmy.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:IBM Plex Sans;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(../media/1bcd0e671759a44c-s.2qt3tdwt-y9x_.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:IBM Plex Sans;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(../media/e15f58668ad64cb8-s.3cvcemwuzoywn.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:IBM Plex Sans;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(../media/90c51ce8fb754fe8-s.02z5rrbg5nt92.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:IBM Plex Sans;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(../media/57215795b8570f5c-s.2rixgazldzomk.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:IBM Plex Sans;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(../media/03fc1b4a8d284b5e-s.p.0wiir8udbzjvx.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:IBM Plex Sans Fallback;src:local(Arial);ascent-override:101.32%;descent-override:27.18%;line-gap-override:0.0%;size-adjust:101.17%}.ibm_plex_sans_4815361e-module__l71bla__className{font-family:IBM Plex Sans,IBM Plex Sans Fallback;font-style:normal}.ibm_plex_sans_4815361e-module__l71bla__variable{--font-plex-sans:"IBM Plex Sans", "IBM Plex Sans Fallback"}
@font-face{font-family:IBM Plex Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/e390973e931a41c5-s.0rgnxg2b64rzs.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:IBM Plex Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/59b15b4bcd7b1eb5-s.2vemzm0itqzfy.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:IBM Plex Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/e532fa1b9921e1cd-s.3cb5lpr2l6xud.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:IBM Plex Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/2fe89d53234c61d4-s.1u30mmyq6lnsd.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:IBM Plex Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/99e609270109b47d-s.p.40sczeszzbjw1.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:IBM Plex Mono;font-style:normal;font-weight:500;font-display:swap;src:url(../media/5e05ae5b48faa55e-s.1yd4_i3e35931.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:IBM Plex Mono;font-style:normal;font-weight:500;font-display:swap;src:url(../media/a7afbb44bec2bb18-s.1qc6dx89jd2qv.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:IBM Plex Mono;font-style:normal;font-weight:500;font-display:swap;src:url(../media/02263ebadd758ea4-s.29yke99gs9qpn.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:IBM Plex Mono;font-style:normal;font-weight:500;font-display:swap;src:url(../media/68757d6cddeff913-s.1i-sca43-qwng.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:IBM Plex Mono;font-style:normal;font-weight:500;font-display:swap;src:url(../media/effe91970fc4db64-s.p.0oace-s_gkfks.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:IBM Plex Mono;font-style:normal;font-weight:600;font-display:swap;src:url(../media/6ff74e33ebd7bca3-s.352ti9pm7m6qh.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:IBM Plex Mono;font-style:normal;font-weight:600;font-display:swap;src:url(../media/1a69062cfe6f77f8-s.0o-3_g79811ob.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:IBM Plex Mono;font-style:normal;font-weight:600;font-display:swap;src:url(../media/9a4838fcda0d1bca-s.0ngr-xkgqz1kf.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:IBM Plex Mono;font-style:normal;font-weight:600;font-display:swap;src:url(../media/2e95a7d252b9825a-s.15orukf5wyxb5.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:IBM Plex Mono;font-style:normal;font-weight:600;font-display:swap;src:url(../media/23b7a97ae3b5c134-s.p.226pwps5o-gq_.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:IBM Plex Mono Fallback;src:local(Arial);ascent-override:76.16%;descent-override:20.43%;line-gap-override:0.0%;size-adjust:134.59%}.ibm_plex_mono_a253c4ed-module__m5iU3G__className{font-family:IBM Plex Mono,IBM Plex Mono Fallback;font-style:normal}.ibm_plex_mono_a253c4ed-module__m5iU3G__variable{--font-plex-mono:"IBM Plex Mono", "IBM Plex Mono Fallback"}
@font-face{font-family:Outfit;font-style:normal;font-weight:500;font-display:swap;src:url(../media/b2ea385cb5ae8625-s.1spbknb88wd48.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.1gsd1jahc5dg_.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.1spbknb88wd48.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.1gsd1jahc5dg_.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.1spbknb88wd48.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.1gsd1jahc5dg_.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.1spbknb88wd48.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.1gsd1jahc5dg_.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_860f8024-module__wg8ura__className{font-family:Outfit,Outfit Fallback;font-style:normal}.outfit_860f8024-module__wg8ura__variable{--font-outfit:"Outfit", "Outfit Fallback"}
:root{--color-bg:#f3efe5;--color-surface-100:#faf7efb8;--color-surface-200:#f5f1e7d1;--color-surface-300:#ece7d8e6;--color-surface-solid:#faf7ef;--color-surface-elevated:#fff;--color-surface-border:#1b2a3a24;--color-surface-hover:#1b2a3a0f;--navy:#06121e;--navy-2:#16314a;--color-text-on-navy:#f3efe5;--color-on-navy-muted:#f3efe5a3;--color-on-navy-dim:#f3efe56b;--color-on-navy-hover:#f3efe514;--color-accent-on-navy:#6bb3c0;--color-text-primary:#1b2a3a;--color-text-secondary:#435363;--color-text-tertiary:#5f6b78;--color-text-inverse:#f3efe5;--color-accent:#0d6e7e;--color-accent-hover:#0a5560;--color-accent-soft:#0d6e7e1a;--color-accent-glow:#0d6e7e29;--color-warning:#9a6c12;--color-warning-bg:#9a6c1224;--color-success:#2c6e49;--color-success-bg:#2c6e491f;--color-error:#bc4327;--color-error-bg:#bc43271f;--font-body:var(--font-plex-sans,"IBM Plex Sans"), system-ui, -apple-system, sans-serif;--font-heading:var(--font-outfit,"Outfit"), system-ui, -apple-system, sans-serif;--font-mono:var(--font-plex-mono,"IBM Plex Mono"), ui-monospace, "SFMono-Regular", monospace;--space-0:0;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.5rem;--space-6:2rem;--space-8:3rem;--space-10:4rem;--space-12:6rem;--radius-sm:.25rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--radius-full:9999px;--shadow-sm:0 1px 2px #1b2a3a0f;--shadow-md:0 14px 34px -26px #1b2a3a38;--shadow-lg:0 24px 70px -42px #1b2a3a42;--shadow-xl:0 34px 90px -44px #1b2a3a4d;--shadow-glow:0 18px 48px -34px #0d6e7e85;--ease-custom:cubic-bezier(.16, 1, .3, 1);--transition-fast:.15s var(--ease-custom);--transition-base:.25s var(--ease-custom);--transition-slow:.4s var(--ease-custom);--z-negative:-1;--z-base:0;--z-dropdown:100;--z-sticky:200;--z-fixed:300;--z-modal:400;--z-tooltip:500}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-bg);color:var(--color-text-primary);scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-body);background:var(--color-bg);min-height:100vh;color:var(--color-text-primary);font-variant-numeric:tabular-nums;line-height:1.5;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--color-text-primary);font-weight:600;line-height:1.2}a{color:inherit;text-decoration:none}ul,ol{list-style:none}img,picture,video,canvas,svg{max-width:100%;display:block}button,input,select,textarea{font:inherit;color:inherit;background:0 0;border:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-surface-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-surface-border)}.text-xs{font-size:.75rem;line-height:1rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-mono,.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.text-accent{color:var(--color-accent)}.text-error{color:var(--color-error)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.flex-col{flex-direction:column}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.w-full{width:100%}.h-full{height:100%}.min-w-0{min-width:0}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.p-2{padding:var(--space-2)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.py-2{padding-top:var(--space-2);padding-bottom:var(--space-2)}.py-4{padding-top:var(--space-4);padding-bottom:var(--space-4)}.m-0{margin:0}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.ml-auto{margin-left:auto}.mr-auto{margin-right:auto}.mx-auto{margin-left:auto;margin-right:auto}.glass-panel{background:var(--color-surface-100);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-surface-border)}.surface-panel{background:var(--color-surface-solid);border:1px solid var(--color-surface-border)}@media (max-width:640px){:root{--space-10:3rem;--space-12:4rem}}@media (min-width:768px){.md\:flex-row{flex-direction:row}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}
.card{border:1px solid var(--color-surface-border);border-radius:var(--radius-xl);padding:var(--space-5);transition:transform var(--transition-base), border-color var(--transition-base), box-shadow var(--transition-base);box-shadow:var(--shadow-sm);background:var(--color-surface-solid)}.card--hoverable:hover{box-shadow:var(--shadow-md);border-color:#1b2a3a38;transform:translateY(-3px)}.card--interactive{cursor:pointer}.card--interactive:hover{box-shadow:var(--shadow-glow);border-color:#0d6e7e6b;transform:translateY(-4px)}.card--interactive:active{transform:translateY(0)}.card--highlight{background:linear-gradient(180deg, var(--color-accent-soft) 0%, var(--color-surface-solid) 100%);border-color:#0d6e7e3d}.card--metric{gap:var(--space-2);flex-direction:column;min-height:132px;display:flex;position:relative;overflow:hidden}.card--metric:after{content:"";bottom:0;left:var(--space-5);right:var(--space-5);opacity:.55;background:linear-gradient(90deg,#0000,#0d6e7e80,#0000);height:1px;position:absolute}.card--metric .metric-value{font-family:var(--font-mono);font-variant-numeric:tabular-nums;letter-spacing:-.01em;font-size:2rem;font-weight:600;line-height:1}.card--metric .metric-label{font-family:var(--font-mono);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.08em;font-size:.7rem;font-weight:600}.btn{justify-content:center;align-items:center;gap:var(--space-2);font-family:var(--font-body);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-base), border-color var(--transition-base), color var(--transition-base), transform var(--transition-base), box-shadow var(--transition-base);white-space:nowrap;-webkit-user-select:none;user-select:none;font-weight:500;display:inline-flex}.btn:active{transform:translateY(1px)scale(.99)}.btn--sm{padding:.375rem .75rem;font-size:.875rem}.btn--md{padding:.5rem 1rem;font-size:1rem}.btn--lg{border-radius:var(--radius-lg);padding:.75rem 1.5rem;font-size:1.125rem}.btn--primary{background-color:var(--color-accent);color:var(--color-text-inverse);border:1px solid #0000;box-shadow:0 14px 28px -22px #0d6e7ef2}.btn--primary:hover{background-color:var(--color-accent-hover);box-shadow:0 20px 38px -24px var(--color-accent)}.btn--secondary{background-color:var(--color-surface-200);color:var(--color-text-primary);border:1px solid var(--color-surface-border)}.btn--secondary:hover{background-color:var(--color-surface-300);border-color:var(--color-accent);color:var(--color-accent-hover)}.btn--outline{color:var(--color-text-primary);border:1px solid var(--color-surface-border);background-color:#0000}.btn--outline:hover{background:var(--color-accent-soft);color:var(--color-accent);border-color:#0d6e7e6b}.btn--ghost{color:var(--color-text-secondary);background-color:#0000;border:1px solid #0000}.btn--ghost:hover{background-color:var(--color-surface-hover);color:var(--color-text-primary)}.btn--danger{background-color:var(--color-error);color:#fff;border:1px solid #0000}.btn--danger:hover{background-color:#bc4327;box-shadow:0 0 15px #bc43274d}.btn--success{background-color:var(--color-success);color:var(--color-text-inverse);border:1px solid #0000}.btn--success:hover{background-color:#2c6e49}.btn--loading{pointer-events:none;opacity:.8}.btn--loading:after{content:"";border:2px solid;border-right-color:#0000;border-radius:50%;width:1em;height:1em;animation:.75s linear infinite spin}.btn:disabled,.btn--disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.badge{font-family:var(--font-mono);border-radius:var(--radius-sm);letter-spacing:.055em;text-transform:uppercase;white-space:nowrap;align-items:center;padding:.28rem .64rem;font-size:.7rem;font-weight:600;display:inline-flex}.badge--default{background-color:var(--color-surface-200);color:var(--color-text-secondary);border:1px solid var(--color-surface-border)}.badge--primary{background-color:var(--color-accent-soft);color:var(--color-accent);border:1px solid #0d6e7e52}.badge--success{background-color:var(--color-success-bg);color:var(--color-success);border:1px solid #2c6e494d}.badge--warning{background-color:var(--color-warning-bg);color:var(--color-warning);border:1px solid #9a6c124d}.badge--danger{background-color:var(--color-error-bg);color:var(--color-error);border:1px solid #bc43274d}.badge--outline{color:var(--color-text-primary);border:1px solid var(--color-text-tertiary);background-color:#0000}.badge--solid{background-color:var(--color-text-primary);color:var(--color-bg)}.badge--dot:before{content:"";background-color:currentColor;border-radius:50%;width:6px;height:6px;margin-right:6px;display:inline-block}.badge--directory{color:var(--color-accent-hover);background-color:#0d6e7e1f;border:1px solid #0d6e7e4d}.badge--verified{background-color:var(--color-success-bg);color:var(--color-success);border:1px solid #2c6e494d}.badge--excellent{color:#2c6e49;background-color:#2c6e4926;border:1px solid #2c6e4959}.badge--good{background-color:var(--color-accent-soft);color:var(--color-accent);border:1px solid #0d6e7e52}.badge--possible{background-color:var(--color-warning-bg);color:var(--color-warning);border:1px solid #9a6c124d}.badge--poor{background-color:var(--color-error-bg);color:var(--color-error);border:1px solid #bc43274d}.form-group{gap:var(--space-2);margin-bottom:var(--space-4);flex-direction:column;display:flex}.form-label{color:var(--color-text-secondary);font-size:.875rem;font-weight:500}.form-input{border:1px solid var(--color-surface-border);border-radius:var(--radius-md);width:100%;color:var(--color-text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);background-color:var(--color-surface-elevated);padding:.625rem 1rem;font-size:.875rem}.form-input::placeholder{color:var(--color-text-tertiary)}.form-input:focus{border-color:#0d6e7e8c;outline:none;box-shadow:0 0 0 3px #0d6e7e21}.form-input:disabled{color:var(--color-text-tertiary);cursor:not-allowed;background-color:var(--color-surface-300)}.form-input--error{border-color:var(--color-error)}.form-hint{color:var(--color-text-tertiary);font-size:.75rem}.form-hint.error{color:var(--color-error)}.table-container{border:1px solid var(--color-surface-border);border-radius:var(--radius-xl);width:100%;box-shadow:var(--shadow-sm);background-color:var(--color-surface-solid);overflow-x:auto}.table{border-collapse:collapse;text-align:left;width:100%}.table th,.table td{padding:.92rem var(--space-4);border-bottom:1px solid var(--color-surface-border)}.table th{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);background-color:var(--color-surface-300);font-size:.7rem;font-weight:600}.table tr:last-child td{border-bottom:none}.table tbody tr{transition:background-color var(--transition-fast)}.table tbody tr:hover{background-color:#0d6e7e0b}.table td{font-family:var(--font-mono);color:var(--color-text-primary);font-size:.84rem}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:var(--z-modal);padding:var(--space-4);opacity:0;pointer-events:none;transition:opacity var(--transition-base);background-color:#06121ecc;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-overlay.is-open{opacity:1;pointer-events:auto}.modal-content{background:linear-gradient(180deg, var(--color-surface-elevated), var(--color-surface-solid));border:1px solid var(--color-surface-border);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);width:100%;max-width:32rem;transition:transform var(--transition-base);flex-direction:column;display:flex;transform:scale(.95)translateY(10px)}.modal-overlay.is-open .modal-content{transform:scale(1)translateY(0)}.modal-header{padding:var(--space-5);border-bottom:1px solid var(--color-surface-border);justify-content:space-between;align-items:center;display:flex}.modal-title{font-family:var(--font-heading);font-size:1.25rem;font-weight:600}.modal-close{color:var(--color-text-secondary);cursor:pointer;padding:var(--space-1);border-radius:var(--radius-sm);transition:background-color var(--transition-fast), color var(--transition-fast);background:0 0;border:none}.modal-close:hover{background-color:var(--color-surface-hover);color:var(--color-text-primary)}.modal-body{padding:var(--space-5);max-height:60vh;overflow-y:auto}.modal-footer{padding:var(--space-5);border-top:1px solid var(--color-surface-border);justify-content:flex-end;gap:var(--space-3);display:flex}.status-dot{border-radius:50%;width:8px;height:8px}.status-dot--online{background-color:var(--color-success);box-shadow:0 0 8px #2c6e4980}.status-dot--offline{background-color:var(--color-text-tertiary)}.status-dot--warning{background-color:var(--color-warning)}.status-dot--error{background-color:var(--color-error)}.vessel-card{flex-direction:column;gap:0;display:flex}.vessel-card-header{align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-4);display:flex}.vessel-card-icon{border-radius:var(--radius-md);background:var(--color-accent-soft);width:38px;height:38px;color:var(--color-accent);border:1px solid #0d6e7e38;flex-shrink:0;justify-content:center;align-items:center;display:flex}.vessel-card-name{font-family:var(--font-heading);color:var(--color-text-primary);transition:color var(--transition-fast);font-size:.95rem;font-weight:700;line-height:1.2;display:block}.vessel-card-name:hover{color:var(--color-accent)}.vessel-card-meta{color:var(--color-text-tertiary);margin-top:2px;font-size:.73rem}.vessel-specs-row{align-items:center;gap:var(--space-3);padding:var(--space-3) 0;border-top:1px solid var(--color-surface-border);border-bottom:1px solid var(--color-surface-border);margin-bottom:var(--space-3);flex-wrap:wrap;display:flex}.vessel-spec{flex-direction:column;gap:2px;min-width:52px;display:flex}.vessel-spec-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-tertiary);font-size:.62rem;font-weight:600}.vessel-spec-value{font-family:var(--font-mono);color:var(--color-text-primary);font-size:.85rem;font-weight:600}.vessel-spec-divider{background:var(--color-surface-border);flex-shrink:0;width:1px;height:28px}.vessel-location{align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);font-size:.8rem;display:flex}.vessel-location-label{color:var(--color-text-tertiary);flex-shrink:0}.vessel-location-value{color:var(--color-text-secondary);font-weight:500}.vessel-gear{color:var(--color-text-tertiary);margin-bottom:var(--space-4);font-size:.78rem}.vessel-card-footer{justify-content:space-between;align-items:center;gap:var(--space-2);padding-top:var(--space-4);border-top:1px solid var(--color-surface-border);margin-top:auto;display:flex}@media (max-width:760px){.btn,.form-input,.modal-close{min-height:44px}.modal-overlay{padding:max(var(--space-3), env(safe-area-inset-top)) var(--space-2) calc(88px + env(safe-area-inset-bottom));align-items:flex-start;overflow-y:auto}.modal-content{max-height:calc(100dvh - 104px - env(safe-area-inset-bottom));border-radius:var(--radius-xl);margin:0 auto}.modal-header,.modal-body,.modal-footer{padding:var(--space-4)}.modal-body{flex:auto;min-height:0;max-height:none}.modal-footer{flex-wrap:wrap}.modal-footer .btn{flex:10rem}.table{min-width:640px}.card--metric{min-height:112px}.card--metric .metric-value{font-size:1.55rem}}@media (max-width:520px){.modal-overlay{padding:var(--space-2) 0 calc(88px + env(safe-area-inset-bottom))}.modal-content{border-radius:var(--radius-xl)}}
@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes pulse{0%{opacity:.7;transform:scale(.95)}50%{opacity:1;transform:scale(1.05)}to{opacity:.7;transform:scale(.95)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}@keyframes breathe{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}@keyframes dataFlow{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes countUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn var(--transition-base) forwards}.animate-fade-in-up{animation:fadeInUp var(--transition-slow) forwards}.animate-spin{animation:1s linear infinite spin}.animate-pulse{animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}.animate-breathe{animation:4s ease-in-out infinite breathe}.skeleton{background:linear-gradient(90deg, var(--color-surface-200) 25%, var(--color-surface-300) 50%, var(--color-surface-200) 75%);background-size:400% 100%;animation:1.5s infinite shimmer}.stagger-1{animation-delay:.1s}.stagger-2{animation-delay:.2s}.stagger-3{animation-delay:.3s}.stagger-4{animation-delay:.4s}.stagger-5{animation-delay:.5s}.stagger-6{animation-delay:.6s}.stagger-container>*{opacity:0;will-change:transform, opacity}.reveal-on-scroll{opacity:0;transition:opacity .6s var(--ease-custom), transform .6s var(--ease-custom);transform:translateY(30px)}.reveal-on-scroll.is-visible{opacity:1;transform:translateY(0)}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
.app-shell{background:linear-gradient(135deg, #0d6e7e0e, transparent 42%), linear-gradient(315deg, #0d6e7e0a, transparent 38%), var(--color-bg);height:100vh;display:flex;overflow:hidden}.main-area{flex-direction:column;flex:1;min-width:0;display:flex}.content-area{padding:var(--space-6);background-color:#0000;background-image:linear-gradient(#1b2a3a06 1px,#0000 1px),linear-gradient(90deg,#1b2a3a05 1px,#0000 1px);background-size:48px 48px;flex:1;overflow-y:auto}@media (max-width:640px){.content-area{padding:var(--space-4)}}.sidebar{border-right:1px solid var(--navy-2);width:256px;transition:width var(--transition-base);background:var(--navy);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.sidebar .brand-name,.sidebar .uc-name{color:var(--color-text-on-navy)}.sidebar .brand-tag,.sidebar .sidebar-section-label,.sidebar .uc-meta{color:var(--color-on-navy-dim)}.sidebar .nav-item{color:var(--color-on-navy-muted)}.sidebar .nav-item:hover{background:var(--color-on-navy-hover);color:var(--color-text-on-navy)}.sidebar .nav-item--active{color:var(--color-accent-on-navy);background:#6bb3c029;border-color:#6bb3c047}.sidebar .collapse-btn,.sidebar .logout-btn{color:var(--color-on-navy-dim)}.sidebar .collapse-btn:hover{background:var(--color-on-navy-hover);color:var(--color-text-on-navy)}.sidebar--collapsed{width:76px}.sidebar-brand{align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-5) var(--space-4);white-space:nowrap;display:flex}.sidebar-logo{border-radius:var(--radius-lg);background:linear-gradient(135deg, #0a5560, var(--color-accent));width:36px;height:36px;font-family:var(--font-heading);color:#fff;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;font-weight:800;display:flex;box-shadow:0 16px 34px -24px #0d6e7ecc}.sidebar-brand-text{flex-direction:column;line-height:1.1;display:flex}.sidebar-brand-text .brand-name{font-family:var(--font-heading);font-size:1.05rem;font-weight:700}.sidebar-brand-text .brand-tag{color:var(--color-text-tertiary);letter-spacing:.04em;font-size:.7rem}.sidebar-nav{padding:var(--space-3);flex-direction:column;flex:1;gap:2px;display:flex;overflow-y:auto}.sidebar-section-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary);padding:var(--space-3) var(--space-3) var(--space-2);font-size:.65rem;font-weight:600}.nav-item{align-items:center;gap:var(--space-3);border-radius:var(--radius-md);color:var(--color-text-secondary);white-space:nowrap;transition:background-color var(--transition-fast), color var(--transition-fast), transform var(--transition-fast), border-color var(--transition-fast);cursor:pointer;border:1px solid #0000;padding:.625rem .75rem;font-size:.9rem;font-weight:500;display:flex}.nav-item:hover{background:var(--color-surface-hover);color:var(--color-text-primary);transform:translate(2px)}.nav-item svg{flex-shrink:0}.nav-item--active{background:var(--color-accent-soft);color:var(--color-accent);border-color:#0d6e7e38}.sidebar--collapsed .nav-label,.sidebar--collapsed .sidebar-brand-text,.sidebar--collapsed .sidebar-section-label{display:none}.sidebar--collapsed .sidebar-brand{justify-content:center;padding-left:0;padding-right:0}.sidebar-footer{border-top:1px solid var(--color-surface-border);padding:var(--space-3);gap:var(--space-2);flex-direction:column;display:flex}.user-card{align-items:center;gap:var(--space-2);border-radius:var(--radius-md);border:1px solid var(--navy-2);background:#ffffff0d;padding:.5rem .625rem;display:flex}.user-card-text{flex-direction:column;flex:1;min-width:0;line-height:1.2;display:flex}.user-card-text .uc-name{white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:6px;font-size:.82rem;font-weight:600;display:flex;overflow:hidden}.user-card-text .uc-meta{color:var(--color-text-tertiary);white-space:nowrap;text-overflow:ellipsis;font-size:.68rem;overflow:hidden}.uc-role-tag{text-transform:uppercase;letter-spacing:.04em;border-radius:var(--radius-full);font-size:.58rem;font-weight:700;font-family:var(--font-mono);align-items:center;gap:2px;padding:1px 5px;display:inline-flex}.uc-role-tag--charterer{color:var(--color-accent);background:var(--color-accent-soft)}.uc-role-tag--shipowner{color:#0d6e7e;background:#0d6e7e1f}.uc-role-tag--broker{color:var(--color-warning);background:var(--color-warning-bg)}.uc-role-tag--admin{color:var(--color-success);background:var(--color-success-bg)}.sidebar .uc-role-tag--charterer,.sidebar .uc-role-tag--shipowner{color:var(--color-accent-on-navy);background:#6bb3c029}.sidebar .uc-role-tag--broker{color:#d6a23a;background:#d6a23a29}.sidebar .uc-role-tag--admin{color:#4caa78;background:#4caa7829}.logout-btn{border-radius:var(--radius-md);width:30px;height:30px;color:var(--color-text-tertiary);cursor:pointer;transition:color var(--transition-fast), border-color var(--transition-fast);background:0 0;border:1px solid #0000;flex-shrink:0;justify-content:center;align-items:center;display:flex}.logout-btn:hover{color:var(--color-error);border-color:var(--color-surface-border)}.sidebar--collapsed .user-card-text{display:none}.sidebar--collapsed .user-card{justify-content:center;padding-left:0;padding-right:0}.sidebar--collapsed .logout-btn{display:none}.collapse-btn{width:100%;padding:var(--space-2);border-radius:var(--radius-md);color:var(--color-text-tertiary);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);justify-content:center;align-items:center;display:flex}.collapse-btn:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.app-header{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-surface-border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);z-index:var(--z-sticky);background:#faf7efd1;display:flex}.breadcrumb{align-items:center;gap:var(--space-2);color:var(--color-text-tertiary);font-size:.85rem;display:flex}.breadcrumb .crumb-current{color:var(--color-text-primary);font-weight:600}.header-search{align-items:center;width:320px;max-width:38vw;margin-left:auto;display:flex;position:relative}.header-search .search-icon{color:var(--color-text-tertiary);pointer-events:none;position:absolute;left:.75rem}.header-search input{border:1px solid var(--color-surface-border);border-radius:var(--radius-full);width:100%;color:var(--color-text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);background:var(--color-surface-elevated);padding:.5rem .75rem .5rem 2.25rem;font-size:.85rem}.header-search input:focus{border-color:#0d6e7e8c;outline:none;box-shadow:0 0 0 3px #0d6e7e1f}.icon-btn{border-radius:var(--radius-md);width:40px;height:40px;color:var(--color-text-secondary);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);justify-content:center;align-items:center;display:flex;position:relative}.icon-btn:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.avatar{border-radius:var(--radius-full);background:linear-gradient(135deg, #0a5560, var(--color-accent));color:#fff;width:38px;height:38px;font-family:var(--font-mono);flex-shrink:0;justify-content:center;align-items:center;font-size:.82rem;font-weight:600;display:flex}.page-header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid #1b2a3a14;flex-wrap:wrap;display:flex}.page-title{font-family:var(--font-heading);font-size:clamp(1.8rem,3vw,2.65rem);font-weight:800}.page-subtitle{color:var(--color-text-secondary);margin-top:var(--space-1);max-width:72ch;font-size:.94rem}.kpi-grid{gap:var(--space-4);margin-bottom:var(--space-6);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));display:grid}.section-title{font-family:var(--font-heading);letter-spacing:.01em;margin-bottom:var(--space-4);font-size:1.02rem;font-weight:700}.empty-state{text-align:center;padding:var(--space-10) var(--space-6);color:var(--color-text-tertiary);justify-content:center;align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.empty-state .empty-icon{border-radius:var(--radius-full);background:var(--color-surface-200);width:56px;height:56px;color:var(--color-text-secondary);justify-content:center;align-items:center;display:flex}.dashboard-grid{gap:var(--space-5);grid-template-columns:2fr 1fr;align-items:start;display:grid}@media (max-width:1024px){.dashboard-grid{grid-template-columns:1fr}}.meta-stack{flex-direction:column;line-height:1.2;display:flex}.meta-stack .meta-main{color:var(--color-text-primary);font-size:.9rem;font-weight:700}.meta-stack .meta-sub{color:var(--color-text-tertiary);font-size:.73rem}.listing-row{align-items:center;gap:var(--space-3);padding:.85rem var(--space-3);border-radius:var(--radius-lg);transition:background-color var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);cursor:pointer;border:1px solid #0000;display:flex}.listing-row:hover{background:var(--color-surface-hover);border-color:var(--color-surface-border);transform:translateY(-1px)}.badge-row{gap:var(--space-2);flex-wrap:wrap;display:flex}.toolbar{align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);padding:var(--space-3);border:1px solid var(--color-surface-border);border-radius:var(--radius-xl);background:var(--color-surface-solid);box-shadow:var(--shadow-sm);flex-wrap:wrap;display:flex}.toolbar .toolbar-search{flex:1;min-width:200px}.view-toggle{border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);background:var(--color-surface-300);gap:2px;padding:2px;display:inline-flex;overflow:hidden}.view-toggle button{color:var(--color-text-secondary);cursor:pointer;border-radius:calc(var(--radius-lg) - 3px);transition:background-color var(--transition-fast), color var(--transition-fast);padding:.48rem .82rem;font-size:.8rem}.view-toggle button:hover{color:var(--color-text-primary)}.view-toggle button.active{background:var(--color-accent);color:var(--color-text-inverse)}.result-count{font-family:var(--font-mono);color:var(--color-text-tertiary);font-size:.78rem}.vessel-grid{gap:var(--space-5);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));display:grid}.filter-panel{gap:var(--space-4);top:var(--space-4);background:0 0;flex-direction:column;display:flex;position:sticky}.filter-group{gap:var(--space-2);flex-direction:column;display:flex}.filter-group .fg-title{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-tertiary);font-size:.7rem;font-weight:600}.filter-option{align-items:center;gap:var(--space-2);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:background-color var(--transition-fast);padding:.4rem .6rem;font-size:.85rem;display:flex}.filter-option:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.filter-option.active{background:var(--color-accent-soft);color:var(--color-accent)}.board-layout{gap:var(--space-5);grid-template-columns:240px 1fr;align-items:start;display:grid}@media (max-width:900px){.board-layout{grid-template-columns:1fr}}.detail-layout{gap:var(--space-5);grid-template-columns:1fr 340px;align-items:start;display:grid}@media (max-width:1024px){.detail-layout{grid-template-columns:1fr}}.spec-table{width:100%}.spec-table .spec-row{justify-content:space-between;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--color-surface-border);font-size:.85rem;display:flex}.spec-table .spec-row:last-child{border-bottom:none}.spec-table .spec-row .k{color:var(--color-text-secondary)}.spec-table .spec-row .v{font-family:var(--font-mono);color:var(--color-text-primary);text-align:right;font-weight:600}.match-level-bar{border-radius:var(--radius-full);background:var(--color-surface-300);height:4px;overflow:hidden}.match-level-bar span{border-radius:var(--radius-full);height:100%;transition:width var(--transition-slow);display:block}.match-level-bar--excellent span{background:linear-gradient(90deg,#2c6e49,#2c6e49);width:100%}.match-level-bar--good span{background:linear-gradient(90deg, var(--color-accent), #0d6e7e);width:75%}.match-level-bar--possible span{background:linear-gradient(90deg, var(--color-warning), #9a6c12);width:50%}.match-level-bar--poor span{background:linear-gradient(90deg, var(--color-error), #bc4327);width:25%}.directory-notice{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--color-accent-hover);background:#0d6e7e14;border:1px solid #0d6e7e38;font-size:.78rem;display:flex}.msg-thread{gap:var(--space-2);max-height:320px;padding:var(--space-2) 0;flex-direction:column;display:flex;overflow-y:auto}.msg-bubble{border-radius:var(--radius-lg);max-width:78%;padding:.55rem .85rem;font-size:.85rem;line-height:1.35}.msg-bubble--in{background:var(--color-surface-200);border:1px solid var(--color-surface-border);border-bottom-left-radius:var(--radius-sm);align-self:flex-start}.msg-bubble--out{background:var(--color-accent);color:#fff;border-bottom-right-radius:var(--radius-sm);align-self:flex-end}.msg-time{opacity:.7;margin-top:2px;font-size:.65rem;display:block}.msg-input{gap:var(--space-2);margin-top:var(--space-3);display:flex}.msg-input input{flex:1}.stepper{align-items:center;gap:var(--space-2);margin-bottom:var(--space-5);display:flex}.step-dot{background:var(--color-surface-200);width:26px;height:26px;color:var(--color-text-tertiary);border:1px solid var(--color-surface-border);border-radius:50%;justify-content:center;align-items:center;font-size:.78rem;font-weight:700;display:flex}.step-dot.active{background:var(--color-accent);color:#fff;border-color:#0000}.step-dot.done{background:var(--color-success);color:#fff;border-color:#0000}.step-bar{background:var(--color-surface-border);flex:1;height:2px}.step-bar.done{background:var(--color-success)}.login-screen{min-height:100vh;padding:var(--space-6);background:radial-gradient(1200px 600px at 100% -10%, #0d6e7e17, transparent 60%), radial-gradient(900px 500px at -10% 110%, #0d6e7e12, transparent 55%), var(--color-bg);justify-content:center;align-items:center;display:flex}.login-card{background:var(--color-surface-solid);border:1px solid var(--color-surface-border);border-radius:var(--radius-xl);width:100%;max-width:440px;padding:var(--space-8);box-shadow:var(--shadow-lg)}.login-brand{align-items:center;gap:var(--space-3);margin-bottom:var(--space-6);display:flex}.login-title{font-family:var(--font-heading);font-size:1.4rem;font-weight:700;line-height:1.1}.login-subtitle{color:var(--color-text-tertiary);font-size:.8rem}.login-divider{align-items:center;gap:var(--space-3);margin:var(--space-5) 0;color:var(--color-text-tertiary);font-size:.72rem;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--color-surface-border);flex:1;height:1px}.login-accounts{gap:var(--space-4);flex-direction:column;display:flex}.login-account-group{gap:var(--space-2);flex-direction:column;display:flex}.login-account-head{align-items:baseline;gap:var(--space-2);display:flex}.login-account-role{color:var(--color-text-primary);font-size:.8rem;font-weight:700}.login-account-blurb{color:var(--color-text-tertiary);font-size:.7rem}.login-account-btn{align-items:center;gap:var(--space-3);text-align:left;border:1px solid var(--color-surface-border);border-radius:var(--radius-md);background:var(--color-surface-100);cursor:pointer;width:100%;transition:border-color var(--transition-fast), background-color var(--transition-fast);padding:.6rem .7rem;display:flex}.login-account-btn:hover{border-color:var(--color-accent);background:var(--color-accent-glow)}.login-account-icon{border-radius:var(--radius-md);background:var(--color-surface-200);width:36px;height:36px;color:var(--color-text-secondary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.login-account-icon--charterer{color:var(--color-accent);background:var(--color-accent-soft)}.login-account-icon--shipowner{color:#0d6e7e;background:#0d6e7e1f}.login-account-icon--broker{color:var(--color-warning);background:var(--color-warning-bg)}.login-account-icon--admin{color:var(--color-success);background:var(--color-success-bg)}.login-account-info{flex-direction:column;flex:1;min-width:0;display:flex}.login-account-name{align-items:center;gap:var(--space-2);font-size:.85rem;font-weight:600;display:flex}.login-account-meta{color:var(--color-text-tertiary);white-space:nowrap;text-overflow:ellipsis;font-size:.7rem;overflow:hidden}.login-account-go{color:var(--color-text-tertiary);flex-shrink:0}.login-foot{color:var(--color-text-tertiary);margin-top:var(--space-5);font-size:.7rem;line-height:1.45}@media (max-width:1100px){.sidebar:not(.sidebar--collapsed){width:88px}.sidebar:not(.sidebar--collapsed) .nav-label,.sidebar:not(.sidebar--collapsed) .sidebar-brand-text,.sidebar:not(.sidebar--collapsed) .sidebar-section-label,.sidebar:not(.sidebar--collapsed) .user-card-text{display:none}.sidebar:not(.sidebar--collapsed) .sidebar-brand,.sidebar:not(.sidebar--collapsed) .user-card{justify-content:center;padding-left:0;padding-right:0}.sidebar:not(.sidebar--collapsed) .logout-btn{display:none}}@media (max-width:900px){.app-header{padding:var(--space-3) var(--space-4);align-items:stretch;gap:var(--space-3);flex-wrap:wrap}.header-search{order:3;width:100%;max-width:none;margin-left:0}.page-header{align-items:stretch;gap:var(--space-3)}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(min(100%,165px),1fr))}.vessel-grid{grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr))}}@media (max-width:760px){.app-shell{height:100dvh;min-height:100dvh}.main-area{width:100%}.content-area{padding:var(--space-4) var(--space-4) calc(86px + env(safe-area-inset-bottom));min-width:0}.sidebar,.sidebar.sidebar--collapsed,.sidebar:not(.sidebar--collapsed){width:100%;height:calc(72px + env(safe-area-inset-bottom));z-index:var(--z-fixed);border-right:0;border-top:1px solid var(--color-surface-border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#06121ef5;position:fixed;bottom:0;left:0;right:0}.sidebar-brand,.sidebar-footer{display:none}.sidebar-nav{align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-2) calc(var(--space-2) + env(safe-area-inset-bottom));scrollbar-width:none;flex-direction:row;overflow:auto hidden}.sidebar-nav::-webkit-scrollbar{display:none}.nav-item,.sidebar--collapsed .nav-item{text-align:center;flex-direction:column;justify-content:center;gap:.2rem;min-width:64px;min-height:54px;padding:.4rem .45rem;font-size:.65rem}.nav-item:hover{transform:none}.nav-label,.sidebar--collapsed .nav-label{text-overflow:ellipsis;max-width:60px;display:block;overflow:hidden}.app-header{position:sticky;top:0}.page-title{font-size:clamp(1.45rem,8vw,2rem)}.card{padding:var(--space-4);border-radius:var(--radius-lg)}.detail-layout{grid-template-columns:1fr}}@media (max-width:520px){.content-area,.app-header{padding-left:var(--space-3);padding-right:var(--space-3)}.kpi-grid{gap:var(--space-3);grid-template-columns:1fr 1fr}.empty-state{padding:var(--space-6) var(--space-3)}}@media (max-width:380px){.kpi-grid{grid-template-columns:1fr}}
