@font-face{font-family:DM Sans;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/dm-sans-latin-ext-400-normal-BtiwyxMk.woff2)format("woff2"),url(/assets/dm-sans-latin-ext-400-normal-BjWJ59Pq.woff)format("woff");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:DM Sans;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/dm-sans-latin-400-normal-CW0RaeGs.woff2)format("woff2"),url(/assets/dm-sans-latin-400-normal-BwCSEQnW.woff)format("woff");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:Fira Code;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/fira-code-cyrillic-ext-400-normal-txZ9Fk_1.woff2)format("woff2"),url(/assets/fira-code-cyrillic-ext-400-normal-Buh61xzB.woff)format("woff");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Fira Code;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/fira-code-cyrillic-400-normal-UC0NFL4U.woff2)format("woff2"),url(/assets/fira-code-cyrillic-400-normal-dc1q3VD7.woff)format("woff");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Fira Code;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/fira-code-greek-ext-400-normal-DR7mBgIM.woff2)format("woff2"),url(/assets/fira-code-greek-ext-400-normal-DSPUheWg.woff)format("woff");unicode-range:U+1F??}@font-face{font-family:Fira Code;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/fira-code-greek-400-normal-B2Gh_Y8s.woff2)format("woff2"),url(/assets/fira-code-greek-400-normal-DobhaxvF.woff)format("woff");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Fira Code;font-style:normal;font-display:swap;font-weight:400;src:url(data:font/woff2;base64,d09GMgABAAAAAA24ABAAAAAANbgAAA1aAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAGhYbHhxiBmA/U1RBVC4Agx4RCArJMLMkC4JaAAE2AiQDgloEIAWESAePIQwHGzEoFeOYJbBxACDpsyMqRr+Q/f8puSFDmAtQ6yeRLLJIipDmNLfH2EYHFtbBoCmBQ5He0ES1eaAvfdBNIUWXPpOtkmldXNLF6Tn8HmzM6X/0FrrJN+YYD09r6fuzs3BXJBI2sgSWHKMw0QXUKGQ122pSSbo/vVv2BglhEuRSM9ZEWXGowxqw62G3WzoVUU5sas5RtZx9VeVyIjYwz9c0yJcQqkmwvK8LAAPrusmAZlPYHCFUYhS/GFyM/d7/uvacs+TgP2vN7wfnhTziICLAV/dNEcJ3KENej0t2WycVR2uVdnuO/wNMQhLJCPMyEqirq7rrejs9sztzNAsBxKm9wNyFQEeiY4nsgHWEJjbulQuovI2L9QlkdYJknxpA6lwsb0dS7OZP30rumS66XEKW8ROyY1wiiBnljc+O/YULDAYkIRRCoGuyydDu0qomYGVogUDXZpUY5ozQ8Yg95XpH7Ohe79qH+tZ/rj7nah6Ph+OS0HiJ4V5gsablWjWhAuO+fs6v4yE1+W/eDjzG7UN6JjHnf5kHNZ2SJF8ENeMBYFcXF8J1GDKnt3cDC0FzWvlrP+j9+Zg8pbQDmE4thEZgNITJFOccziEESYEUKR6C9A4gocBoyojlVRW3gfGMlBpDTFeAuoHS9CbkIitIg9xtHSLkc+K7aPvbXOdQAP0c4PuyzhzyGgj+j+gSDVilXbJBa3VZp9sqDqs5RZqpWZtooGGNWkV5OmuJcXfUkODvJGCPmPf0JPo58OwW8Y6uOAObhDTYaswu3tBmV3trE71ijWzxtRNEzezQt1HcWzamREslLJNUKpOhVqF0IJSuSoFcOAyJUiIFAA5EJbNi5SoUqVenzAEHHXLYEostssJ6ayzXoYeLzUobdOonmGiC8cYZa4zRJgkTLsIoSLQMA88B0QMQ10DzFgy5BSwH1gNk6VFuxP0vtE/w6JezCWbPDoWEBHQKBWpQmUJufG+idFsEk9/GIhJHLOJF3M374QjmvDsF8KxSpTqJYRlmtyJRvb+tqcozMMGzGi7AsyqMGYde6mPBsxoUGKYmWFWbx+8vNHo0y2DGBytMhDehzj63hC4gYpzVw8tpXo+DQ7j1MjyLGcxUnn3hDfoDqYxklEcgxOjpXnoIrz+C0OPHaNkjvP508M7zV1h2+zG34eFDWPqgybrs2nE5uQJLL+P1V4neignnwaJujkchKEepBDVhBA1hBS3xCMSgC7wGhSOvRvTBiHQ6A5MRVh/GKjewkd6g0GmyvMVUG6TVaoLWcCJgNN8onZpR76jrXXYcBnIJ/x4LKNm/lPinLn1FbnnWIPcWOHNQGG2PeDBwFjWjbq/r8+w4CL8nV/anLGcR0HvwRjkWNlFbj95MIEMwkHiy2rh1gc4I54UItgNyAc7lkU6rowKGCpuNQIlZfYjjScVB5ngjMhTeWJUcyx0o2kqYBoP443XAx2u3NBKdjnrZwUMHgk2PUEqHhBUFQLZa4OIKAQWKEIwizuUCeXCiII5zNTjuZB0YCetEa10Rz5rHYfMng0V+AZp8Sqo0YOkoCEakuJSngyJ6RkkqLIKOwl4RbcF0ySux2ZAwvMYkbio0uFiRhQ/UOkKjkeihPpFTYIdRoiLLtulUvNaEaVgbKw3bOHQMT1D8yTqFoJx3rDIsatpIOBKAb6h27iUIy4EOsGFwWespCSursoLxRCm6SIcSe3TgJLY8HnjI0xnN81sIUF0M/BpOidkM9IgozNycSTjAbaD6FFm2n1NhLYa1AGuL27g5BhOchZSbN5YVuRJTA4W9IMublMdLYjFncHAZ4rl1o6PRW5gRUIZ5sxHvcq7ASaHsFQqhTjln2qOnMl540EdxFm3tXBaulBYdPiMBvP7BA2Cxdtnj9+txZMNDtK746BHGaA7iNhAXQFqOXfoA18Nk/SNE7XFRjgPSbGtpnthi+eBhSDupmX81tfojIzCxxsx8J6jnpJrP+6By7P8QfT/2ULe6org2K7bGPO2Ht77mxr41atLNZkNYiy0/1Jntsrrb9SPaqSNTn7emLaiefQGkJswN6J1zdLLa/gpf8az9l48//wzMKDraFw0+qzanC6z0rQSz4ky/vxKYlStB/cJndghmlQ80bBvM5+Ns8vpsMphLrc0H5gj+Zmc6yrWOOxNvLnx8TKKXTA5Lbi4JWZNYl8R+m/yyJL0sWbmk4KCaaHsYsbqUZ1ssPqtPpC5MV5Vd9HXePWH1tywxa6qxVYK6mDOrfJ7xBDPkuxIjetu96eXJlY827baoT+pPe0BYGHSLSxbkOxn/HaJurWyTIgcP6a/YkP9pfbxLm5UOeNN+uBBobfya9/b5x7veqRuLbDnc1fKz6y1I+Hu/U16Nu8L3Bea9vCYIwDRRYP6CyDV3JIH6Qd0OkSt4x1MyF6gG91Q/FaR2DEYamnS5e2PLRSXPnDtfwk7EgI8jROu4+jR+OD4YTOHniVSU5KAs+dqceTqRQuSKY6DZeWkXNN0t4+rT/ZSQ9rjrUUmgYjAkf05npiE59nLMX376Wt5l6NdlVA03pRIJZ7q5nihRqYBINvqv2JzHYPE9UJ9Oq5teQnsbnJkGU1Z9w6U9OVi8Jd1j1D+wMzQ7UwLyw/HyJUwTshcKCGmnEq3oOo437+nhM3rFZVVB/mvZMoPVw6/2kkpB83fBPdhgGlRDKoKjrsC+iVIOsAMlUP4pKc4xDVrMFF0GWKjbgfNlBh5UstzNM1mYN0H8Sw/umKdEzoFYU9xVkEu7lvCMVm9Gy7sIkqf7AnF4VyoV7D17TP58C+RFGeWVlFEGgH0hgKaYIz0NE03nP16qLM/L1DwLJC+3XpevT1XTwg0CEBMq0cugI+3KtmdMQxMxSAIL2b+jKXgWGca5j3llb9RnbxJLK73AHLrsBccoebL8BKMhtDVaCf3f5IvqDI5xsqlYlZHtl4yX0Y7HS+NwWwuP2FqZSPbyDazdrkomojo03sx8Llh6WOkFU7pQiG8IdpzQpJuK84gDR4bOGKDJOaMlllJhptMonVW5VFqdd6V04l7dEbOl1Ky1by2DUiVPz1Nqtg8HBzXQPlbTg7sPBjTHHvz0NuPkgF6N91L//qfE0krPN4dOvaAZhcn0CaC5DEDv+r/RpeZCoBkHE8VKGSJBUbH+0782kRx1nS5ZejCPNACFWX/BNaXlJ7PPmXHzXpcYasptUKe3k59sKipKR5TvGFb1hji5tvghSIzQrQ5qptLRbE6m7QM++/BmSmnD+zkxJl4RtEz5nFlCzhqvOX5S5HNmwdvM7Tv1Oo91dh5zPqFPBtybO3febGwBe4tv1fqkbT9w16ST0exjdHopaLs9D7awsOc9xo2MNm858k709E4EIfuzdjGLdmn2uccrLRVlpbMrKg/a+kVNXcuziGIuhMrTUi959n9osb9QNfZ9y3oNPsF28d5nFV5yAcg36tH1C1b/WgOrcl8d01Z/JhBKV84fOrd5rmHzv0ZZf4av2iXnAPje/PJq+Hj/+KJjSzmUesFX8lr5NaMLDcaR7yeDPFmdiNf7GpyUelQTK4d8Gjo82ahV2hMI507hpPM4rhwheK1MIZyKReTdsuJyaoygBDvow5y2Ykad0Jx6IHtwoBQg5FXSuhQQ+dudQssgPI+LbCZRZv2qSULXebLInaA49bR1mBqwdTLU760L2/m3zpZauXVpoq6tKwvlbzXUavzOgsFQuucK6uDi4DRkQG8+IFPcs7m1EbkMGFLrxXLzPfWn7SdyiFOrVJVSLiK7Iv3adahKVMZosF/PYVgPO1GLDmKCt+vXxyRFrHjxEnVmgrqp2BNTNeanKkuRJsUKZUmQ1o3oF90HD/AQhfhEPDtBspiDMaVJE6065k1U1hFPqiu0xXYLDOc59GfieJPwnEd30XVwseWwVvRtQb6XCEM50/xq3TyDx3pyBIX3h7edRCD8Z/IcmO1TlKKIrIgyqqijeRDSIow4xCMd0iMDMgKIMKGMC6m0sc4HYRQnaZYXZVU3bdcP4zQv67Yf53U/7/fTDMvxgijJiqrphmnZjuv5A8FQOBKNxRPJVDqTzeULxVK5Uq3VG81Wu9Pt9QfD0Xgync0XyxXjQiptrPNZXpRV3bRdiP0wTvOybnvCcV73834/3xNmR0bsmNeh6TdciUDUSepdv+Mf6mK/f6eCdZi+JakRzuXzfST4/UTWiQYj3otXRtVbASuXjtw4ePLR1Aqh1o4LR/qB9e70uE7Z9xucThbtfUO/Wcf8WpuFgoPf88MeazUPDCweCd2CvnZvd+IL93yqbJs/CSpE0eVtjPJj2L0w8CpudOLBbRLO0NR6bmdRdKirriZXLSifU9ggmhQoK1wZroSMDS+AYjsNrDnUKARqAIfNYri01F54wQE20QRUZisSlthXOxcAJjqUbhXK9iGVcQZQtBqzsfpEpjauyJEdSmUsGiNaqVkJjeSMTbK6IHUoTKdiH4HVV1FyAk5O2BpHVGG4B2m03NA6VYPkuC6ZwWNDLUiNFpyyHLvUyNQhW4xISAth2SpDUqcvLqZzvWZG/QNPOjs81BH73wS8jwvv8Xu+Vb58DwA=)format("woff2"),url(/assets/fira-code-symbols2-400-normal-_QEZCEwe.woff)format("woff");unicode-range:U+2000-2001,U+2004-2008,U+200A,U+23B8-23BD,U+2500-259F}@font-face{font-family:Fira Code;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/fira-code-latin-ext-400-normal-KSMg0QLl.woff2)format("woff2"),url(/assets/fira-code-latin-ext-400-normal-DG73JjOf.woff)format("woff");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:Fira Code;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/fira-code-latin-400-normal-DGosTW8U.woff2)format("woff2"),url(/assets/fira-code-latin-400-normal-C-QZfXAs.woff)format("woff");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:Syne;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/syne-greek-400-normal-B4XGRaFa.woff2)format("woff2"),url(/assets/syne-greek-400-normal-C1nzy5ms.woff)format("woff");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Syne;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/syne-latin-ext-400-normal-B5s6XpS5.woff2)format("woff2"),url(/assets/syne-latin-ext-400-normal-DCnt6qEA.woff)format("woff");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:Syne;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/syne-latin-400-normal-CcHADMBd.woff2)format("woff2"),url(/assets/syne-latin-400-normal-CULFKXub.woff)format("woff");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}:root{--bg:#08090c;--surface:#0f1116;--surface-2:#13151c;--surface-3:#1a1d26;--border:#ffffff12;--border-hover:#ffffff26;--text:#e8eaf0;--text-body:#b8bccb;--muted:#e8eaf06b;--muted2:#e8eaf040;--accent:#4af0c4;--accent-dim:#4af0c41f;--accent-glow:#4af0c452;--glow-accent:drop-shadow(0 0 18px var(--accent-glow));--glow-logo:0 0 14px var(--accent-glow);--glow-logo-h:0 0 22px var(--accent-glow);--glow-btn:0 0 16px var(--accent-glow);--glow-btn-h:0 0 28px var(--accent-glow);--glow-input:0 0 0 3px var(--accent-dim), 0 0 20px var(--accent-glow);--glow-card:0 0 30px var(--accent-dim);--btn-login-col:#e8eaf0a6;--btn-signup-bg:var(--accent);--btn-signup-col:#08090c;--surface-hover:#ffffff0d;--input-bg:#ffffff0a;--input-border:#ffffff1a;--footer-col:#e8eaf047;--modal-bg:#0f1116;--modal-border:#ffffff17;--error:#ff6b6b;--error-dim:#ff6b6b1f;--warn:#f0a84a;--warn-dim:#f0a84a1f;--success:var(--accent);--font-display:"Syne", sans-serif;--font-body:"DM Sans", sans-serif;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--transition-fast:.18s cubic-bezier(.4, 0, .2, 1);--transition-normal:.28s cubic-bezier(.4, 0, .2, 1);--transition-theme:.35s cubic-bezier(.4, 0, .2, 1);--fd:var(--font-display);--fb:var(--font-body);--fm:"Fira Code", "Consolas", monospace;--tf:var(--transition-fast);--tn:var(--transition-normal);--r-sm:6px;--r-md:10px;--border-h:var(--border-hover)}[data-theme=light]{--bg:#f2f3f7;--surface:#fff;--surface-2:#f7f8fa;--surface-3:#eff0f5;--border:#00000014;--border-hover:#00000029;--text:#111318;--text-body:#111318a6;--muted:#11131873;--muted2:#11131847;--accent:#00b386;--accent-dim:#00b3861a;--accent-glow:#00b38647;--btn-login-col:#11131899;--btn-signup-col:#fff;--surface-hover:#0000000a;--input-bg:#00000008;--input-border:#0000001f;--footer-col:#1113184d;--modal-bg:#fff;--modal-border:#0000001a;--error:#c94040;--warn:#d4820a;--warn-dim:#d4820a1a;--glow-accent:none;--glow-logo:0 2px 8px #0000001f;--glow-logo-h:0 4px 14px #00000029;--glow-btn:0 2px 10px #00000024;--glow-btn-h:0 4px 16px #0003;--glow-input:0 0 0 3px var(--accent-dim);--glow-card:0 4px 24px #00000014}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;font-family:var(--font-body);background:var(--bg);color:var(--text);transition:background var(--transition-theme), color var(--transition-theme);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}@keyframes page-fadein{0%{opacity:0;transform:translateY(6px)}to{opacity:1}}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}.form__input:focus-visible,.btn:focus-visible{outline:none}#bg-canvas{z-index:0;pointer-events:none;position:fixed;inset:0}.page{z-index:1;flex-direction:column;height:100dvh;padding:clamp(14px,2.5vw,26px) clamp(16px,4vw,56px);animation:.4s cubic-bezier(.4,0,.2,1) both page-fadein;display:flex;position:relative;overflow:hidden}header{flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;display:flex}.logo{color:var(--text);transition:opacity var(--transition-fast);align-items:center;gap:10px;text-decoration:none;display:flex}.logo:hover{opacity:.8}.logo__mark{border-radius:var(--radius-sm);background:var(--accent);width:32px;height:32px;box-shadow:var(--glow-logo);transition:box-shadow var(--transition-normal);flex-shrink:0;place-items:center;display:grid}.logo__mark svg{fill:#08090c;width:16px;height:16px}.logo:hover .logo__mark{box-shadow:var(--glow-logo-h)}.logo__name{font-family:var(--font-display);letter-spacing:.02em;font-size:1.15rem;font-weight:700}nav{flex-wrap:nowrap;align-items:center;gap:8px;display:flex}.btn{font-family:var(--font-body);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast), filter var(--transition-fast);letter-spacing:.01em;white-space:nowrap;background:0 0;border:1.5px solid #0000;padding:8px 18px;font-size:.85rem;font-weight:500;line-height:1}.btn--login{color:var(--btn-login-col);border-color:var(--border)}.btn--login:hover{color:var(--text);border-color:var(--border-hover);background:var(--surface-hover)}.btn--signup{background:var(--btn-signup-bg);color:var(--btn-signup-col);border-color:var(--btn-signup-bg);box-shadow:var(--glow-btn)}.btn--signup:hover{filter:brightness(1.1);box-shadow:var(--glow-btn-h);transform:translateY(-1px)}.btn--signup:active{filter:brightness(.98);transform:translateY(0)}.btn--primary{background:var(--btn-signup-bg);width:100%;color:var(--btn-signup-col);border-color:var(--btn-signup-bg);box-shadow:var(--glow-btn);border-radius:var(--radius-md);justify-content:center;align-items:center;gap:8px;padding:11px 24px;font-size:.9rem;display:flex}.btn--primary:hover{filter:brightness(1.08);box-shadow:var(--glow-btn-h)}.btn--primary:disabled{opacity:.55;cursor:not-allowed;filter:none;transform:none}.btn--primary .btn-spinner{border:2px solid #00000040;border-top-color:#08090c;border-radius:50%;width:14px;height:14px;animation:.7s linear infinite spin;display:none}.btn--primary.is-loading .btn-spinner{display:block}.btn--primary.is-loading .btn-label{opacity:.6}@keyframes spin{to{transform:rotate(360deg)}}.toggle-wrap{align-items:center;gap:6px;margin-left:4px;display:flex}.toggle-icon{opacity:.6;-webkit-user-select:none;user-select:none;font-size:.85rem;line-height:1}.toggle{cursor:pointer;flex-shrink:0;width:40px;height:22px;position:relative}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle__slider{background:var(--input-border);transition:background var(--transition-fast);border-radius:999px;position:absolute;inset:0}.toggle__slider:before{content:"";background:var(--text);width:16px;height:16px;transition:transform var(--transition-fast), background var(--transition-fast);border-radius:50%;position:absolute;top:3px;left:3px}.toggle input:checked+.toggle__slider{background:var(--accent)}.toggle input:checked+.toggle__slider:before{transform:translate(18px)}footer{flex-shrink:0;justify-content:center;align-items:center;gap:clamp(12px,3vw,28px);padding-bottom:2px;display:flex}footer a{color:var(--footer-col);letter-spacing:.03em;transition:color var(--transition-fast);font-size:.78rem;text-decoration:none}footer a:hover{color:var(--muted)}.footer__dot{background:var(--footer-col);opacity:.5;border-radius:50%;width:3px;height:3px}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(8px);opacity:0;visibility:hidden;pointer-events:none;transition:opacity var(--transition-normal), visibility var(--transition-normal);background:#000000a6;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-overlay.is-open{opacity:1;visibility:visible;pointer-events:all}.modal{background:var(--modal-bg);border:1px solid var(--modal-border);border-radius:var(--radius-lg);width:100%;max-width:420px;transition:transform var(--transition-normal), background var(--transition-theme), border-color var(--transition-theme);box-shadow:0 0 0 1px var(--modal-border), 0 24px 60px #00000073, var(--glow-card);padding:32px;position:relative;transform:scale(.94)translateY(10px)}.modal-overlay.is-open .modal{transform:scale(1)translateY(0)}@media (width<=640px){.modal-overlay{align-items:flex-start;padding:0}.modal{width:100%;max-width:100%;padding:max(20px, env(safe-area-inset-top,16px)) 20px 24px;scrollbar-width:thin;scrollbar-color:var(--border) transparent;max-height:92dvh;box-shadow:0 8px 40px #00000073, 0 0 0 1px var(--modal-border);border-top:none;border-radius:0 0 20px 20px;overflow-y:auto;transform:translateY(-100%)}.modal-overlay.is-open .modal{transform:translateY(0)}.modal:after{content:"";background:var(--border-hover);border-radius:999px;width:36px;height:4px;margin:16px auto 0;display:block}.modal__close{top:14px;right:16px}.modal__panel .btn--primary{padding:14px 24px;font-size:.95rem}}.modal__close{border:1px solid var(--border);width:28px;height:28px;color:var(--muted);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border-radius:6px;place-items:center;font-size:1rem;line-height:1;display:grid;position:absolute;top:16px;right:16px}.modal__close:hover{background:var(--surface-hover);color:var(--text)}.modal__header{margin-bottom:24px}.modal__title{font-family:var(--font-display);color:var(--text);margin-bottom:4px;font-size:1.35rem;font-weight:700}.modal__subtitle{color:var(--muted);font-size:.82rem}.modal__panel{display:none}.modal__panel.is-active{display:block}.form__group{margin-bottom:14px}.form__label{color:var(--muted);letter-spacing:.04em;text-transform:uppercase;margin-bottom:6px;font-size:.78rem;font-weight:500;display:block}.form__input{background:var(--input-bg);border:1.5px solid var(--input-border);border-radius:var(--radius-sm);width:100%;font-family:var(--font-body);color:var(--text);transition:border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-theme);outline:none;padding:10px 14px;font-size:.9rem}.form__input::placeholder{color:var(--muted2)}.form__input:focus{border-color:var(--accent);box-shadow:var(--glow-input);background:var(--surface)}.form__input.is-error{border-color:var(--error);box-shadow:0 0 0 3px var(--error-dim)}.form__error{color:var(--error);min-height:1em;margin-top:4px;font-size:.75rem;display:none}.form__error.is-visible{display:block}.form__divider{text-align:center;color:var(--muted);margin:18px 0;font-size:.8rem}.form__switch{text-align:center;color:var(--muted);margin-top:18px;font-size:.82rem}.form__switch a{color:var(--accent);cursor:pointer;transition:opacity var(--transition-fast);font-weight:500;text-decoration:none}.form__switch a:hover{opacity:.75}.form__success{text-align:center;border-radius:var(--radius-sm);background:var(--accent-dim);color:var(--accent);margin-top:12px;padding:12px;font-size:.85rem;font-weight:500;display:none}.form__success.is-visible{display:block}.page--inner main{flex:1;justify-content:center;align-items:center;min-height:0;padding:12px 0;display:flex}.content-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);scrollbar-width:thin;scrollbar-color:var(--border) transparent;width:min(700px,100%);max-height:90%;transition:background var(--transition-theme), border-color var(--transition-theme);box-shadow:0 0 0 1px var(--border), 0 20px 50px #00000040, var(--glow-card);padding:clamp(20px,3.5vw,38px) clamp(20px,4vw,40px);overflow-y:auto}.content-card *{word-wrap:break-word;overflow-wrap:break-word;max-width:100%}.content-card__tag{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);background:var(--accent-dim);white-space:nowrap;border-radius:999px;margin-bottom:14px;padding:4px 10px;font-size:.7rem;font-weight:600;display:inline-block}.content-card h1{font-family:var(--font-display);color:var(--text);-webkit-hyphens:auto;hyphens:auto;margin-bottom:8px;font-size:clamp(1.4rem,3.5vw,2rem);font-weight:800;line-height:1.15}.content-card .lead{color:var(--muted);border-bottom:1px solid var(--border);margin-bottom:20px;padding-bottom:18px;font-size:clamp(.85rem,1.8vw,.95rem);line-height:1.75}.content-card h2{font-family:var(--font-display);color:var(--text);letter-spacing:.01em;margin:20px 0 8px;font-size:clamp(.85rem,1.6vw,.98rem);font-weight:700}.content-card p{color:var(--muted);margin-bottom:10px;font-size:clamp(.82rem,1.5vw,.9rem);line-height:1.8}.content-card ul{margin:0 0 12px;list-style:none}.content-card ul li{color:var(--muted);margin-bottom:4px;padding-left:16px;font-size:clamp(.82rem,1.5vw,.9rem);line-height:1.75;position:relative}.content-card ul li:before{content:"";background:var(--accent);opacity:.75;border-radius:50%;flex-shrink:0;width:5px;height:5px;position:absolute;top:10px;left:0}@media (width<=640px){.logo__name{font-size:1rem}.btn{padding:7px 12px;font-size:.78rem}.toggle-icon{display:none}.modal__title{font-size:1.15rem}.content-card{border-radius:var(--radius-md);padding:18px 16px}}@media (width<=380px){.logo__name{display:none}.btn{padding:6px 10px}}.contact-textarea{resize:vertical;min-height:100px;max-height:130px}:root{--header-h:64px}header{z-index:100;height:var(--header-h);background:var(--bg);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);transition:background var(--transition-theme), border-color var(--transition-theme);padding:0 clamp(16px,4vw,56px);position:sticky;top:0}.page header{padding-left:0;padding-right:0}header .btn--login,header .btn--logout{padding:9px 22px;font-size:.9rem}:root{--user-nav-h:64px}.user-nav{z-index:50;pointer-events:none;justify-content:center;width:100%;padding:.85rem 1.5rem .35rem;animation:.28s cubic-bezier(.4,0,.2,1) both navSlideIn;display:flex;position:sticky;top:0}@keyframes navSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.user-nav__inner{pointer-events:auto;background:color-mix(in srgb, var(--surface-2) 82%, transparent);border:1px solid var(--border);-webkit-backdrop-filter:blur(16px)saturate(1.4);scrollbar-width:none;-ms-overflow-style:none;max-width:100%;transition:background var(--transition-theme), border-color var(--transition-theme);border-radius:100px;align-items:center;gap:.2rem;padding:.3rem;display:inline-flex;overflow-x:auto;box-shadow:0 1px 2px #0000002e,0 8px 28px #00000038}.user-nav__inner::-webkit-scrollbar{display:none}[data-theme=light] .user-nav__inner{box-shadow:0 1px 2px #0000000f,0 8px 24px #0000001a}.user-nav__link{font-family:var(--font-body);color:var(--muted);white-space:nowrap;transition:color var(--transition-fast), background var(--transition-fast), border-color var(--transition-fast);border:1px solid #0000;border-radius:100px;flex-shrink:0;align-items:center;gap:.45rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;text-decoration:none;display:inline-flex}.user-nav__link:hover{color:var(--text);background:var(--surface-hover)}.user-nav__link.is-active{color:var(--accent);background:var(--accent-dim);border-color:color-mix(in srgb, var(--accent) 22%, transparent)}.user-nav__link--soon{opacity:.5;cursor:default;pointer-events:none}.user-nav__icon{font-size:1.02rem;line-height:1}.user-nav__badge{font-size:.56rem;font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;background:var(--surface-3);color:var(--muted);border:1px solid var(--border);border-radius:100px;margin-left:.1rem;padding:.1rem .4rem;font-weight:600}.hamburger{border-radius:var(--radius-sm);border:1.5px solid var(--border);cursor:pointer;width:40px;height:40px;transition:background var(--transition-fast), border-color var(--transition-fast);background:0 0;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:5px;padding:4px;display:none}.hamburger:hover{background:var(--surface-hover);border-color:var(--border-hover)}.hamburger__bar{background:var(--text);transform-origin:50%;border-radius:2px;width:18px;height:2px;transition:transform .25s cubic-bezier(.4,0,.2,1),opacity .2s,width .2s;display:block}.hamburger.is-open .hamburger__bar:first-child{transform:translateY(7px)rotate(45deg)}.hamburger.is-open .hamburger__bar:nth-child(2){opacity:0;width:0}.hamburger.is-open .hamburger__bar:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.mobile-drawer-overlay{-webkit-backdrop-filter:blur(4px);z-index:998;opacity:0;pointer-events:none;background:#0000008c;transition:opacity .28s;display:none;position:fixed;inset:0}.mobile-drawer-overlay.is-open{opacity:1;pointer-events:all}.mobile-drawer{z-index:999;background:var(--surface);border-top:1px solid var(--border);padding:8px 0 max(20px, env(safe-area-inset-bottom,16px));overscroll-behavior:contain;scrollbar-width:none;visibility:hidden;max-height:min(85vh,640px);transition:transform .34s cubic-bezier(.32, .72, 0, 1), visibility 0s .34s, background var(--transition-theme), border-color var(--transition-theme);border-radius:22px 22px 0 0;display:none;position:fixed;bottom:0;left:0;right:0;overflow-y:auto;transform:translateY(110%);box-shadow:0 -10px 44px #00000080}.mobile-drawer::-webkit-scrollbar{display:none}.mobile-drawer.is-open{visibility:visible;transition:transform .34s cubic-bezier(.32, .72, 0, 1), visibility 0s 0s, background var(--transition-theme), border-color var(--transition-theme);transform:translateY(0)}.mobile-drawer__handle{background:var(--border-hover);border-radius:999px;width:40px;height:4px;margin:4px auto 14px}.mobile-drawer__profile{background:var(--surface-2);border:1px solid var(--border);transition:border-color var(--transition-fast), background var(--transition-fast);border-radius:16px;align-items:center;gap:12px;margin:0 16px 14px;padding:12px 14px;text-decoration:none;display:flex}.mobile-drawer__profile:hover{border-color:var(--border-hover)}.mobile-drawer__avatar{width:42px;height:42px;font-family:var(--font-display);color:var(--accent);background:var(--accent-dim);border:1.5px solid color-mix(in srgb, var(--accent) 30%, transparent);border-radius:50%;flex-shrink:0;place-items:center;font-size:1rem;font-weight:700;display:grid}.mobile-drawer__profile-info{flex-direction:column;flex:1;min-width:0;display:flex}.mobile-drawer__profile-name{font-family:var(--font-display);color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:700;overflow:hidden}.mobile-drawer__profile-sub{color:var(--muted);font-size:.75rem}.mobile-drawer__profile-arrow{color:var(--muted2);flex-shrink:0;font-size:1.1rem}.mobile-drawer__nav{flex-direction:column;gap:4px;padding:0 12px;display:flex}.mobile-drawer__item{color:var(--text-body);font-family:var(--font-body);transition:background var(--transition-fast), color var(--transition-fast);border-radius:14px;align-items:center;gap:14px;padding:14px 16px;font-size:1rem;font-weight:500;text-decoration:none;display:flex;position:relative}.mobile-drawer__item:hover{background:var(--surface-hover);color:var(--text)}.mobile-drawer__item.is-active{background:var(--accent-dim);color:var(--accent);font-weight:600}.mobile-drawer__item-icon{text-align:center;flex-shrink:0;width:26px;font-size:1.2rem;line-height:1}.mobile-drawer__item-label{flex:1}.mobile-drawer__active-dot{background:var(--accent);width:7px;height:7px;box-shadow:0 0 8px var(--accent-glow);border-radius:50%;flex-shrink:0}.mobile-drawer__soon{border-top:1px solid var(--border);margin:14px 12px 0;padding-top:14px}.mobile-drawer__soon-heading{letter-spacing:.12em;text-transform:uppercase;color:var(--muted2);margin-bottom:6px;padding:0 16px;font-size:.62rem;font-weight:700;display:block}.mobile-drawer__soon-items{flex-direction:column;gap:2px;display:flex}.mobile-drawer__soon-item{color:var(--muted2);font-family:var(--font-body);opacity:.6;border-radius:14px;align-items:center;gap:14px;padding:11px 16px;font-size:.95rem;display:flex}.mobile-drawer__soon-badge{letter-spacing:.06em;text-transform:uppercase;color:var(--muted2);background:var(--surface-2);border:1px solid var(--border);border-radius:100px;margin-left:auto;padding:2px 7px;font-size:.58rem;font-weight:700}.mobile-drawer__actions{border-top:1px solid var(--border);gap:8px;margin:16px 16px 0;padding-top:14px;display:flex}.mobile-drawer__action{font-family:var(--font-body);cursor:pointer;border:1.5px solid var(--border);background:var(--surface-2);color:var(--text);transition:background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);border-radius:12px;flex:1;justify-content:center;align-items:center;gap:8px;padding:12px;font-size:.9rem;font-weight:600;text-decoration:none;display:inline-flex}.mobile-drawer__action:hover{background:var(--surface-hover);border-color:var(--border-hover)}.mobile-drawer__action--logout{color:var(--error);border-color:var(--error-dim)}.mobile-drawer__action--logout:hover{background:var(--error-dim);border-color:var(--error)}.header-btn--profile,.header-btn--logout{display:inline-flex}@media (width<=768px){.toggle-wrap{order:1}.hamburger{order:2;display:flex}.user-nav{display:none}.mobile-drawer-overlay,.mobile-drawer{display:block}header .header-btn--profile,header .header-btn--logout{display:none!important}}@media (width<=480px){.mobile-drawer{border-radius:18px 18px 0 0}.mobile-drawer__item{padding:13px 14px;font-size:.95rem}}html:has(.dash-page){height:auto;min-height:100%;overflow:hidden auto}html:has(.dash-page) body{height:auto;min-height:100%;overflow:hidden auto}.dash-page.page{height:auto;min-height:100vh;padding:0;overflow:visible}.dash-page.page--inner main,.dash-page main{justify-content:flex-start;align-items:stretch;height:auto;overflow:visible}.dash-page{flex-direction:column;min-height:100vh;display:flex}.dash-main{flex-direction:column;flex:1;padding:0 0 4rem;display:flex}.dash-main--gate{justify-content:center;align-items:center;padding:0}.dash-content{box-sizing:border-box;grid-template-columns:3fr 1fr;align-items:stretch;gap:1.5rem;width:100%;max-width:1200px;margin:0 auto;padding:2rem 1.5rem;display:grid}#col-left,#col-right{flex-direction:column;display:flex}#col-right .panel{flex-direction:column;flex:1;display:flex}#col-right .panel .panel__body{flex:1}.dash-gate{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;width:100%;max-width:420px;padding:2rem 1.5rem;display:flex}.dash-gate__icon{opacity:.4;font-size:2.5rem}.dash-gate__title{font-family:var(--font-display);color:var(--text);font-size:1.25rem;font-weight:700}.dash-gate__sub{color:var(--text-body);font-size:.9rem}.dash-content-v2{box-sizing:border-box;grid-template-columns:65fr 35fr;align-items:start;gap:1.5rem;width:100%;max-width:1280px;margin:0 auto;padding:2rem 1.5rem;display:grid}.dash-col-left,.dash-col-right{flex-direction:column;gap:1.5rem;display:flex}.user-hero{background:var(--surface);border-bottom:1px solid var(--border);width:100%;padding:2.5rem 1.5rem 2rem;position:relative;overflow:hidden}.user-hero:before{content:"";background:linear-gradient(135deg, var(--accent-dim) 0%, transparent 55%);pointer-events:none;position:absolute;inset:0}.user-hero__inner{box-sizing:border-box;flex-wrap:wrap;align-items:center;gap:1.5rem;width:100%;max-width:1200px;margin:0 auto;display:flex;position:relative}.user-avatar{background:var(--accent-dim);border:2px solid var(--accent);width:64px;height:64px;font-family:var(--font-display);color:var(--accent);text-transform:uppercase;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.4rem;font-weight:700;display:flex}.user-hero__text{flex:1;min-width:0}.user-hero__greeting{color:var(--muted);font-size:.78rem;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.2rem}.user-hero__name-row{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.user-hero__name{font-family:var(--font-display);color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:clamp(1.6rem,4vw,2.4rem);font-weight:800;line-height:1.1;overflow:hidden}.user-hero__controls{flex-wrap:wrap;align-items:center;gap:.6rem;margin-top:.65rem;display:flex}.meta-select{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-body);font-family:var(--font-body);cursor:pointer;transition:border-color var(--tf), color var(--tf);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right .4rem center;background-repeat:no-repeat;padding:.3rem 1.5rem .3rem .6rem;font-size:.8rem}.meta-select:focus{border-color:var(--accent);color:var(--text);outline:none}.meta-select.is-changed{border-color:var(--accent);color:var(--accent)}.meta-sep{color:var(--muted);font-size:.8rem}.btn-save{background:var(--accent);color:var(--bg);border-radius:var(--r-sm);font-family:var(--font-body);cursor:pointer;transition:opacity var(--tf), transform var(--tf);opacity:0;pointer-events:none;border:none;padding:.32rem .9rem;font-size:.8rem;font-weight:500;transform:translateY(-4px)}.btn-save.is-visible{opacity:1;pointer-events:all;transform:translateY(0)}.btn-save.is-loading{opacity:.6;pointer-events:none}.save-feedback{color:var(--success);opacity:0;transition:opacity var(--tf);font-size:.78rem;font-family:var(--font-mono)}.save-feedback.is-visible{opacity:1}.save-error{color:var(--error);font-size:.78rem;font-family:var(--font-mono)}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}.panel__header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1rem 1.25rem .75rem;display:flex}.panel__title{font-family:var(--font-display);color:var(--text);font-size:.95rem;font-weight:700}.panel__tag{font-size:.7rem;font-family:var(--font-mono);color:var(--accent);background:var(--accent-dim);border-radius:4px;padding:.15rem .5rem}.panel__body{padding:1.25rem}.parcours-name{color:var(--muted);text-transform:uppercase;letter-spacing:.09em;font-size:.73rem;font-family:var(--font-mono);margin-bottom:1rem}.rooms-list{flex-direction:column;gap:.5rem;display:flex}.room-item{border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface-2);color:var(--text);transition:border-color var(--tf), background var(--tf), transform var(--tf);align-items:center;gap:.875rem;padding:.875rem 1rem;text-decoration:none;display:flex;position:relative;overflow:hidden}.room-item:hover:not(.is-locked){border-color:var(--border-h);background:var(--surface-3);transform:translate(3px)}.room-item.is-locked{opacity:.4;cursor:not-allowed}.room-item.is-done{border-color:#4af0c433}.room-item:before{content:"";background:var(--border);width:3px;position:absolute;top:0;bottom:0;left:0}.room-item.is-done:before{background:var(--accent)}.room-item.is-available:before{background:var(--accent);opacity:.4}.room-icon{border-radius:var(--r-sm);background:var(--surface-3);flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:1rem;display:flex}.room-item.is-done .room-icon{background:var(--accent-dim)}.room-item.is-available .room-icon{background:var(--accent-dim);opacity:.7}.room-text{flex:1;min-width:0}.room-title{white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:500;overflow:hidden}.room-date{color:var(--muted);font-size:.72rem;font-family:var(--font-mono);margin-top:.15rem}.room-badge{font-size:.68rem;font-family:var(--font-mono);border-radius:4px;flex-shrink:0;padding:.15rem .5rem}.room-badge--done{background:var(--accent-dim);color:var(--accent)}.room-badge--available{color:var(--accent);opacity:.7;background:#4af0c414}.room-badge--locked{background:var(--surface-3);color:var(--muted)}.stats-list{flex-direction:column;gap:1rem;display:flex}.stat-item{flex-direction:column;gap:.2rem;display:flex}.stat-label{color:var(--muted);text-transform:uppercase;letter-spacing:.07em;font-size:.72rem;font-family:var(--font-mono)}.stat-value{font-family:var(--font-display);color:var(--text);font-size:1.6rem;font-weight:700;line-height:1}.stat-value span{color:var(--muted);font-size:.85rem;font-weight:400;font-family:var(--font-body);margin-left:.25rem}.stat-bar{background:var(--surface-3);border-radius:2px;height:4px;margin-top:.35rem;overflow:hidden}.stat-bar__fill{background:var(--accent);transform-origin:0;border-radius:2px;height:100%;animation:.8s cubic-bezier(.4,0,.2,1) forwards barGrow}@keyframes barGrow{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.streak-wrap{align-items:center;gap:.4rem;margin-top:.25rem;display:flex}.streak-dot{background:var(--surface-3);border-radius:50%;width:8px;height:8px}.streak-dot.is-active{background:var(--accent)}.divider{background:var(--border);height:1px;margin:.25rem 0}.chart-placeholder{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);margin-top:1rem;padding:.875rem}.chart-placeholder__label{color:var(--muted);font-size:.7rem;font-family:var(--font-mono);margin-bottom:.5rem}.chart-bars{align-items:flex-end;gap:3px;height:48px;display:flex}.chart-bar{background:var(--accent);opacity:.25;transition:opacity var(--tf);border-radius:2px 2px 0 0;flex:1}.chart-bar:hover{opacity:.65}.chart-bar.is-today{opacity:.9}.badge{font-size:.7rem;font-family:var(--font-mono);white-space:nowrap;border-radius:999px;flex-shrink:0;align-items:center;padding:.18rem .55rem;font-weight:500;display:inline-flex}.badge--free{background:var(--surface-3);color:var(--muted);border:1px solid var(--border)}.badge--premium{color:#fff;background:linear-gradient(135deg,#f5a623,#e8591a);border:none}.badge--vip{color:#fff;background:linear-gradient(135deg,#7c3aed,#4f46e5);border:none}.badge--role{background:var(--accent-dim);color:var(--accent);border:1px solid #4af0c440}.badge--admin{color:var(--error);background:#ef44441f;border:1px solid #ef444440}.badge--warn{color:var(--warn);background:#f0a84a1f;border:1px solid #f0a84a4d}.badge--status{background:var(--accent-dim);color:var(--muted);border:1px solid var(--border);white-space:nowrap;border-radius:20px;padding:.15rem .5rem;font-size:.7rem}.badge-status--draft{color:#6b7280;background:#f3f4f6;border-color:#d1d5db}.badge-status--inreview{color:#92400e;background:#fef3c7;border-color:#fcd34d}.badge-status--published{color:#166534;background:#dcfce7;border-color:#86efac}.badge-status--inpreview{color:#0c4a6e;background:#dbeafe;border-color:#7dd3fc}.badge-status--archived{color:#4b5563;background:#e5e7eb;border-color:#9ca3af}.role-badge{font-size:.7rem;font-family:var(--font-mono);background:var(--surface-3);color:var(--muted);border-radius:4px;padding:.15rem .5rem}.role-badge--admin,.role-badge--superadmin{color:var(--error);background:#ef44441a}.badge--conf-struggling{color:#ef4444;background:#ef44441f;border:1px solid #ef44444d}.badge--conf-confident{color:#22c55e;background:#22c55e1f;border:1px solid #22c55e4d}.badge--conf-neutral,.badge--eng-passive{background:var(--surface-3);color:var(--muted);border:1px solid var(--border)}.badge--eng-active{color:#3b82f6;background:#3b82f61f;border:1px solid #3b82f64d}.badge--eng-engaged{color:var(--accent);background:#4af0c41f;border:1px solid #4af0c440}.badge--info{color:var(--muted);background:#94a3b81f;border:1px solid #94a3b833}.badge--goal{color:#818cf8;background:#6366f11f;border:1px solid #6366f140}.priv-section,.admin-section{box-sizing:border-box;width:100%;max-width:1200px;margin:0 auto 1.5rem;padding:0 1.5rem}.priv-section__header{align-items:center;gap:.75rem;margin-bottom:1rem;padding-top:.5rem;display:flex}.priv-section__title{font-family:var(--font-display);color:var(--text);font-size:1rem;font-weight:700}.priv-section__desc{color:var(--text-body);margin-bottom:1rem;font-size:.85rem}.priv-section__body{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:1.25rem}.priv-section__body>.btn{background:var(--accent);color:var(--bg);border-radius:var(--r-sm);font-family:var(--font-body);cursor:pointer;transition:opacity var(--tf), transform var(--tf);border:none;padding:.6rem 1.2rem;font-size:.85rem;font-weight:500}.priv-section__body>.btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.priv-section__body>.btn:active:not(:disabled){transform:translateY(0)}.priv-links{flex-direction:column;gap:.5rem;display:flex}.priv-link{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface-2);color:var(--text);transition:border-color var(--tf), background var(--tf), transform var(--tf);align-items:center;gap:1rem;padding:.875rem 1rem;text-decoration:none;display:flex}.priv-link:hover{border-color:var(--accent);background:var(--surface-3);transform:translate(3px)}.priv-link__icon{flex-shrink:0;font-size:1.25rem}.priv-link__title{font-size:.9rem;font-weight:500}.priv-link__sub{color:var(--muted);margin-top:.1rem;font-size:.75rem}.priv-link__arrow{color:var(--muted);transition:transform var(--tf);margin-left:auto;font-size:1rem}.priv-link:hover .priv-link__arrow{color:var(--accent);transform:translate(3px)}.sys-btn{background:var(--surface-3);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-body);font-size:.75rem;font-family:var(--fb);cursor:pointer;transition:border-color var(--tf), color var(--tf), background var(--tf);flex:1;justify-content:center;align-items:center;gap:.3rem;padding:.3rem .6rem;text-decoration:none;display:inline-flex}.sys-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.sys-btn--stop:hover:not(:disabled){border-color:var(--error);color:var(--error);background:#ff6b6b1a}.sys-btn:disabled{opacity:.45;cursor:not-allowed}.sys-metric-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);padding:1rem}.sys-metric-card__label{color:var(--muted);text-transform:uppercase;letter-spacing:.09em;font-size:.62rem;font-family:var(--fm);margin-bottom:.5rem}.sys-counter-val{font-family:var(--fd);color:var(--text);font-size:1.5rem;font-weight:700}.sys-counter-sub{color:var(--muted);font-size:.7rem;font-family:var(--fm)}.btn-apply{border-radius:var(--r-sm);color:var(--accent);font-size:.73rem;font-family:var(--fb);cursor:pointer;transition:background var(--tf), border-color var(--tf);background:0 0;border:1px solid #4af0c44d;padding:.25rem .6rem}.btn-apply:hover:not(:disabled){border-color:var(--accent);background:#4af0c414}.role-select{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-body);font-family:var(--fm);cursor:pointer;appearance:none;transition:border-color var(--tf);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right .4rem center;background-repeat:no-repeat;padding:.2rem 1.4rem .2rem .5rem;font-size:.74rem}.role-select:focus{border-color:var(--accent);outline:none}.adm-sv2{flex-direction:column;gap:.5rem;display:flex}.adm-sv2__groups{grid-template-columns:repeat(3,1fr);gap:.5rem;display:grid}.adm-sv2__group{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:.35rem;padding:.9rem;display:flex;position:relative;overflow:hidden}.adm-sv2__group:before{content:"";background:linear-gradient(90deg, transparent 0%, var(--gc) 40%, var(--gc) 60%, transparent 100%);opacity:.6;height:2px;position:absolute;top:0;left:0;right:0}.adm-sv2__group-label{font-size:.58rem;font-family:var(--fm);text-transform:uppercase;letter-spacing:.14em;color:var(--muted);align-items:center;gap:.4rem;margin-bottom:.15rem;display:flex}.adm-sv2__group-dot{background:var(--gc);width:5px;height:5px;box-shadow:0 0 6px var(--gc);border-radius:50%;flex-shrink:0}.adm-sv2__grid{grid-template-columns:1fr 1fr;gap:.35rem;display:grid}.adm-sv2-card{background:#ffffff05;border:1px solid #ffffff0b;border-radius:8px;flex-direction:column;gap:.1rem;padding:.65rem .7rem .55rem;transition:border-color .2s,background .2s;display:flex}.adm-sv2-card:hover{background:#ffffff09;border-color:#ffffff1a}.adm-sv2-card--hero{background:#4af0c40a;border-color:#4af0c41f;flex-direction:row;grid-column:1/-1;align-items:center;gap:.75rem}.adm-sv2-card--accent .adm-sv2-card__value{color:var(--accent)}.adm-sv2-card--warn .adm-sv2-card__value{color:var(--error)}.adm-sv2-card__label{font-size:.57rem;font-family:var(--fm);text-transform:uppercase;letter-spacing:.1em;color:var(--muted);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.adm-sv2-card--hero .adm-sv2-card__label{order:0;font-size:.6rem}.adm-sv2-card__value{font-family:var(--fd);color:var(--text);letter-spacing:-.02em;font-size:1.55rem;font-weight:800;line-height:1}.adm-sv2-card--hero .adm-sv2-card__value{order:-1;font-size:2rem}.adm-sv2-card__trend{font-size:.57rem;font-family:var(--fm);color:var(--accent);margin-top:.1rem}.adm-sv2__chart{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:.85rem 1rem .35rem}.adm-sv2__chart-label{font-size:.57rem;font-family:var(--fm);text-transform:uppercase;letter-spacing:.12em;color:var(--muted);opacity:.7;margin-bottom:.5rem}.adm-stats-wrap{flex-direction:column;gap:.6rem;display:flex}.adm-stats-group{flex-direction:column;gap:.35rem;display:flex}.adm-stats-group-label{font-size:.57rem;font-family:var(--fm);text-transform:uppercase;letter-spacing:.13em;color:var(--muted);opacity:.65;padding-left:2px}.adm-stat-row{grid-template-columns:repeat(4,1fr);gap:.5rem;display:grid}.adm-stat-card{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:1rem .9rem .85rem;transition:border-color .22s,transform .18s;position:relative;overflow:hidden}.adm-stat-card__label{font-size:.59rem;font-family:var(--fm);text-transform:uppercase;letter-spacing:.1em;color:var(--muted);white-space:nowrap;text-overflow:ellipsis;margin-bottom:.45rem;overflow:hidden}.adm-stat-card__value{font-family:var(--fd);color:var(--text);letter-spacing:-.025em;font-size:1.7rem;font-weight:800;line-height:1}.adm-chart-section{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:.85rem 1rem .2rem}.adm-chart-section-label{font-size:.59rem;font-family:var(--fm);text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:.55rem}.adm-mod-v2{grid-template-columns:repeat(3,1fr);gap:.65rem;display:grid}.adm-mod-v2__card{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:.3rem;padding:1.1rem 1.15rem 1rem;transition:border-color .22s;display:flex;position:relative;overflow:hidden}.adm-mod-v2__card:before{content:"";background:linear-gradient(90deg,#0000,#ffffff12,#0000);height:1px;position:absolute;top:0;left:0;right:0}.adm-mod-v2__card--urgent{background:#ef44440a;border-color:#ef44444d}.adm-mod-v2__card--urgent:before{background:linear-gradient(90deg,#0000,#ef444480,#0000)}.adm-mod-v2__pulse{background:var(--error);border-radius:50%;width:7px;height:7px;animation:2s ease-in-out infinite adm-pulse;position:absolute;top:.85rem;right:.85rem;box-shadow:0 0 #ef444480}@keyframes adm-pulse{0%,to{box-shadow:0 0 #ef444480}50%{box-shadow:0 0 0 5px #ef444400}}.adm-mod-v2__card-label{font-size:.57rem;font-family:var(--fm);text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.adm-mod-v2__card-count{font-family:var(--fd);color:var(--text);letter-spacing:-.03em;font-size:2rem;font-weight:800;line-height:1}.adm-mod-v2__card-count--urgent{color:var(--error)}.adm-mod-v2__card-desc{color:var(--muted);font-size:.72rem;font-family:var(--fb)}.adm-mod-v2__action{font-size:.73rem;font-family:var(--fb);color:var(--accent);background:#4af0c412;border:1px solid #4af0c433;border-radius:6px;align-items:center;gap:.3rem;width:fit-content;margin-top:.35rem;padding:.3rem .6rem;font-weight:600;text-decoration:none;transition:opacity .15s;display:inline-flex}.adm-mod-v2__action:hover{opacity:.78}.adm-mod-v2__note{color:var(--muted);font-size:.67rem;font-family:var(--fm);margin-top:.25rem;font-style:italic}.adm-rt{flex-direction:column;gap:0;display:flex}.adm-rt__nav{border-bottom:1px solid var(--border);flex-wrap:wrap;gap:.3rem;padding-bottom:.75rem;display:flex}.adm-rt__pill{color:var(--muted);font-size:.73rem;font-family:var(--fb);cursor:pointer;white-space:nowrap;background:#ffffff09;border:1px solid #ffffff0f;border-radius:999px;align-items:center;gap:.35rem;padding:.3rem .7rem;transition:background .18s,border-color .18s,color .18s;display:inline-flex}.adm-rt__pill:hover:not(.adm-rt__pill--active){color:var(--text-body);background:#ffffff0f}.adm-rt__pill--active{color:var(--accent);background:#4af0c41a;border-color:#4af0c459}.adm-rt__pill-name{font-weight:500}.adm-rt__pill-count{font-size:.62rem;font-family:var(--fm);color:var(--muted);background:#ffffff14;border-radius:999px;padding:.05rem .38rem;transition:background .18s,color .18s}.adm-rt__pill--active .adm-rt__pill-count{color:var(--accent);background:#4af0c426}.adm-rt__toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;padding:.65rem 0;display:flex}.adm-rt__toolbar-left,.adm-rt__toolbar-right{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.adm-rt__count{color:var(--muted);font-size:.73rem;font-family:var(--fm)}.adm-rt__count strong{color:var(--text);font-family:var(--fd)}.adm-rt__sort-group{border:1px solid var(--border);background:#ffffff08;border-radius:8px;align-items:center;gap:.2rem;padding:.2rem;display:flex}.adm-rt__sort-btn{color:var(--muted);font-size:.68rem;font-family:var(--fm);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:6px;align-items:center;gap:.25rem;padding:.22rem .55rem;transition:background .15s,color .15s;display:inline-flex}.adm-rt__sort-btn:hover{color:var(--text-body);background:#ffffff0d}.adm-rt__sort-btn.is-active{color:var(--accent);background:#4af0c414}.adm-rt-sort-icon{font-size:.65rem;font-family:var(--fm)}.adm-rt-sort-icon--idle{opacity:.3}.adm-rt-sort-icon--active{color:var(--accent)}.adm-rt__search-wrap{align-items:center;display:flex;position:relative}.adm-rt__search-icon{color:var(--muted);pointer-events:none;position:absolute;left:.6rem}.adm-rt__search{background:var(--surface-2);border:1px solid var(--border);color:var(--text);font-family:var(--fm);width:220px;transition:border-color var(--tf), box-shadow var(--tf);box-sizing:border-box;border-radius:8px;padding:.32rem 2.1rem .32rem 2rem;font-size:.78rem}.adm-rt__search:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 2px #4af0c412}.adm-rt__search::placeholder{color:var(--muted)}.adm-rt__search-clear{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:.15rem .25rem;font-size:.7rem;line-height:1;transition:color .15s;position:absolute;right:.5rem}.adm-rt__search-clear:hover{color:var(--text)}.adm-rt__panel{min-height:80px}.adm-rt__empty{color:var(--muted);font-family:var(--fm);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;padding:2.5rem 1rem;font-size:.82rem;display:flex}.adm-rt__empty-icon{opacity:.3;font-size:1.6rem}.adm-table-wrap{border:1px solid var(--border);-webkit-overflow-scrolling:touch;border-radius:10px;overflow:auto hidden}.adm-table{border-collapse:collapse;background:var(--surface);width:100%;min-width:680px;font-size:.82rem}.adm-table thead th{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1;text-align:left;font-size:.57rem;font-family:var(--fm);text-transform:uppercase;letter-spacing:.12em;color:var(--muted);border-bottom:1px solid var(--border);white-space:nowrap;background:#0f1116f5;padding:.65rem .9rem;position:sticky;top:0}.adm-table__row{transition:background .15s}.adm-table__row:not(:last-child) td{border-bottom:1px solid #ffffff0a}.adm-table__row:hover td{background:#4af0c406}.adm-table td{vertical-align:middle;color:var(--text-body);padding:.6rem .9rem}.adm-table__user-cell{align-items:center;gap:.65rem;display:flex}.adm-table__avatar{width:32px;height:32px;font-family:var(--fd);text-transform:uppercase;letter-spacing:0;background:oklch(30% .08 var(--hue));color:oklch(85% .15 var(--hue));border:1px solid oklch(45% .1 var(--hue) / .35);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:flex}@supports not (background:oklch(30% 0.08 0)){.adm-table__avatar{background:hsl(var(--hue), 35%, 22%);color:hsl(var(--hue), 55%, 72%);border-color:hsl(var(--hue), 40%, 40%)}}.adm-table__user-info{flex-direction:column;min-width:0;display:flex}.adm-table__pseudo{color:var(--text);font-weight:600;font-family:var(--fb);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.adm-table__email{font-family:var(--fm);color:var(--muted);white-space:nowrap;text-overflow:ellipsis;max-width:200px;font-size:.68rem;overflow:hidden}.adm-table__meta{flex-direction:column;gap:.05rem;font-size:.78rem;display:flex}.adm-table__meta-sub{font-family:var(--fm);color:var(--muted);font-size:.65rem}.adm-table__date{font-family:var(--fm);color:var(--muted);white-space:nowrap;font-size:.73rem}.adm-table__role-select{background:var(--surface-3);border:1px solid var(--border);color:var(--text-body);font-family:var(--fm);cursor:pointer;appearance:none;transition:border-color var(--tf);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right .45rem center;background-repeat:no-repeat;border-radius:6px;padding:.22rem 1.5rem .22rem .55rem;font-size:.72rem}.adm-table__role-select:focus{border-color:var(--accent);outline:none}.adm-table__actions{align-items:center;gap:.35rem;display:flex}.adm-table__btn{font-size:.71rem;font-family:var(--fb);cursor:pointer;white-space:nowrap;border-radius:6px;padding:.25rem .6rem;transition:all .15s}.adm-table__btn--detail{background:var(--surface-3);border:1px solid var(--border);color:var(--text-body)}.adm-table__btn--detail:hover{border-color:var(--border-hover);color:var(--text)}.adm-table__btn--apply{color:var(--accent);background:0 0;border:1px solid #4af0c447}.adm-table__btn--apply:hover:not(:disabled){border-color:var(--accent);background:#4af0c412}.adm-table__btn--apply:disabled{opacity:.35;cursor:not-allowed}.adm-table-pagination{border-top:1px solid var(--border);justify-content:center;align-items:center;gap:1rem;margin-top:.75rem;padding-top:.65rem;display:flex}.adm-table-pagination__btn{background:var(--surface-2);border:1px solid var(--border);color:var(--text-body);font-size:.77rem;font-family:var(--fb);cursor:pointer;transition:border-color var(--tf), color var(--tf);border-radius:7px;padding:.3rem .8rem}.adm-table-pagination__btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.adm-table-pagination__btn:disabled{opacity:.3;cursor:not-allowed}.adm-table-pagination__info{font-family:var(--fm);color:var(--text);font-size:.73rem}.adm-table-pagination__info span{color:var(--muted)}.adm-search-wrap{width:100%;max-width:540px;position:relative}.adm-search-input{background:var(--surface-2);border:1px solid var(--border);width:100%;color:var(--text);font-family:var(--fm);box-sizing:border-box;transition:border-color var(--tf), box-shadow var(--tf);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23777' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E");background-position:.75rem;background-repeat:no-repeat;border-radius:8px;padding:.55rem .9rem .55rem 2.4rem;font-size:.85rem}.adm-search-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #4af0c414}.adm-search-input::placeholder{color:var(--muted)}.adm-search-results{background:var(--surface);border:1px solid var(--border);z-index:200;border-radius:8px;max-height:320px;margin:0;padding:.3rem;list-style:none;position:absolute;top:calc(100% + 5px);left:0;right:0;overflow-y:auto;box-shadow:0 10px 28px #00000059,0 0 0 1px #ffffff08}.adm-search-item{cursor:pointer;transition:background var(--tf);border-radius:6px;align-items:center;gap:.6rem;padding:.5rem .7rem;display:flex}.adm-search-item:hover{background:var(--surface-2)}.adm-search-item__pseudo{color:var(--text);flex-shrink:0;font-size:.84rem;font-weight:600}.adm-search-item__email{font-family:var(--fm);color:var(--muted);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.71rem;overflow:hidden}.adm-collapsible__toggle{border:none;border-bottom:1px solid var(--border);cursor:pointer;width:100%;color:var(--text-body);font-size:.83rem;font-family:var(--fb);text-align:left;transition:color var(--tf);background:0 0;align-items:center;gap:.5rem;margin-bottom:.75rem;padding:.65rem 0;display:flex}.adm-collapsible__toggle:hover{color:var(--accent)}.adm-collapsible__toggle>span:last-child{margin-left:auto}.adm-feed{flex-direction:column;gap:.15rem;margin:0;padding:0;list-style:none;display:flex}.adm-feed-item{transition:background var(--tf);border-radius:6px;align-items:center;gap:.7rem;padding:.4rem .45rem;display:flex}.adm-feed-item:hover{background:var(--surface-2)}.adm-feed-icon{width:26px;height:26px;color:var(--accent);font-size:.68rem;font-weight:700;font-family:var(--fd);background:#4af0c412;border:1px solid #4af0c424;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.adm-feed-body{color:var(--text-body);flex:1;font-size:.82rem}.adm-feed-time{white-space:nowrap;color:var(--muted);font-size:.68rem;font-family:var(--fm)}.adm-tab-count{background:var(--surface-3);color:var(--muted);font-size:.61rem;font-family:var(--fm);border-radius:999px;padding:.07rem .38rem}.adm-tab-count--warn{color:var(--error);background:#ef44441f}.adm-modal-overlay{z-index:9999;-webkit-backdrop-filter:blur(10px);background:#000000b8;justify-content:center;align-items:center;animation:.22s forwards adm-overlay-in;display:flex;position:fixed;inset:0}@keyframes adm-overlay-in{0%{opacity:0}to{opacity:1}}.adm-modal-panel{background:linear-gradient(170deg,#13151c 0%,#0d0f14 100%);border:1px solid #ffffff14;border-radius:18px;flex-direction:column;width:min(780px,96vw);max-height:88vh;animation:.3s cubic-bezier(.16,1,.3,1) forwards adm-panel-in;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #ffffff0a,0 40px 80px #000000a6,0 0 100px #4af0c40a}@keyframes adm-panel-in{0%{opacity:0;transform:translateY(24px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.adm-modal-glow{background:linear-gradient(90deg, transparent, hsl(var(--hue), 70%, 70%), transparent);opacity:.55;pointer-events:none;z-index:1;width:60%;height:1px;position:absolute;top:0;left:50%;transform:translate(-50%)}.adm-modal-close{z-index:20;width:30px;height:30px;color:var(--muted);cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:8px;justify-content:center;align-items:center;transition:background .15s,color .15s,border-color .15s;display:flex;position:absolute;top:1rem;right:1rem}.adm-modal-close:hover{color:var(--text);background:#ffffff1f;border-color:#ffffff2e}.adm-modal-hero{flex-shrink:0;align-items:center;gap:1.1rem;padding:1.75rem 1.75rem 1.25rem;display:flex;position:relative;overflow:hidden}.adm-modal-hero__gradient{background:radial-gradient(ellipse 80% 120% at 15% 50%, hsl(var(--hue), 60%, 25%, .25) 0%, transparent 70%);pointer-events:none;position:absolute;inset:0}.adm-modal-hero__avatar{width:56px;height:56px;font-family:var(--fd);text-transform:uppercase;background:oklch(28% .1 var(--hue));color:oklch(88% .18 var(--hue));border:2px solid oklch(50% .14 var(--hue) / .45);box-shadow:0 0 20px oklch(50% .14 var(--hue) / .25);z-index:1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.4rem;font-weight:800;display:flex;position:relative}@supports not (background:oklch(28% 0.1 0)){.adm-modal-hero__avatar{background:hsl(var(--hue), 35%, 22%);color:hsl(var(--hue), 60%, 78%);border-color:hsl(var(--hue), 45%, 42%)}}.adm-modal-hero__info{z-index:1;flex:1;min-width:0;padding-right:2.5rem;position:relative}.adm-modal-hero__name{font-family:var(--fd);color:var(--text);margin:0 0 .12rem;font-size:1.2rem;font-weight:700;line-height:1.2}.adm-modal-hero__email{font-family:var(--fm);color:var(--muted);text-overflow:ellipsis;white-space:nowrap;margin:0 0 .45rem;font-size:.73rem;overflow:hidden}.adm-modal-hero__badges{flex-wrap:wrap;gap:.35rem;display:flex}.adm-modal-tabs{border-bottom:1px solid #ffffff12;flex-shrink:0;align-items:center;gap:0;padding:0 1.75rem;display:flex;position:relative}.adm-modal-tab{color:#ffffff52;font-family:var(--fm);letter-spacing:.06em;text-transform:uppercase;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:.7rem 1.1rem;font-size:.71rem;font-weight:500;transition:color .15s,border-color .15s}.adm-modal-tab:hover:not(.adm-modal-tab--active){color:#fff9}.adm-modal-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.adm-modal-body{scrollbar-width:thin;scrollbar-color:#ffffff1a transparent;flex:1;min-height:0;padding:1.4rem 1.75rem 1.75rem;overflow-y:auto}.adm-modal-loading{justify-content:center;align-items:center;gap:.5rem;padding:3rem 0;display:flex}.adm-modal-loading span{background:var(--accent);opacity:.4;border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite adm-dot-pulse}.adm-modal-loading span:nth-child(2){animation-delay:.2s}.adm-modal-loading span:nth-child(3){animation-delay:.4s}@keyframes adm-dot-pulse{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:.9;transform:scale(1.1)}}.adm-modal-info-grid{grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:1.25rem;display:grid}.adm-modal-ia-grid{grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:1rem;display:grid}.adm-modal-info-cell{background:#ffffff06;border:1px solid #ffffff0e;border-radius:8px;flex-direction:column;gap:.15rem;padding:.6rem .7rem;display:flex}.adm-modal-info-cell--full{grid-column:1/-1}.adm-modal-info-cell__label{font-size:.57rem;font-family:var(--fm);text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}.adm-modal-info-cell__val{color:var(--text);font-size:.88rem;font-family:var(--fb)}.adm-modal-controls{border:1px solid #ffffff0e;border-radius:10px;flex-direction:column;gap:0;display:flex;overflow:hidden}.adm-modal-ctrl{flex-direction:column;gap:.4rem;padding:.8rem 1rem;display:flex}.adm-modal-ctrl:not(:last-child){border-bottom:1px solid #ffffff0e}.adm-modal-ctrl__head{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.adm-modal-ctrl__label{font-size:.58rem;font-family:var(--fm);text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}.adm-modal-ctrl__current{color:var(--text-body);font-size:.73rem;font-family:var(--fm)}.adm-modal-ctrl__locked{color:var(--muted);margin:0;font-size:.73rem;font-style:italic}.adm-modal-ctrl__row{align-items:center;gap:.5rem;display:flex}.adm-modal-select{background:var(--surface-3);border:1px solid var(--border);min-width:0;color:var(--text-body);font-family:var(--fm);cursor:pointer;appearance:none;transition:border-color var(--tf);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;border-radius:7px;flex:1;padding:.3rem 1.6rem .3rem .65rem;font-size:.78rem}.adm-modal-select:focus{border-color:var(--accent);outline:none}.adm-modal-apply{color:var(--accent);font-size:.76rem;font-family:var(--fb);cursor:pointer;white-space:nowrap;background:#4af0c414;border:1px solid #4af0c447;border-radius:7px;flex-shrink:0;padding:.3rem .85rem;font-weight:600;transition:background .15s,border-color .15s}.adm-modal-apply:hover:not(:disabled){border-color:var(--accent);background:#4af0c424}.adm-modal-apply:disabled{opacity:.4;cursor:not-allowed}.adm-modal-feedback{font-size:.76rem;font-family:var(--fm);color:var(--accent);background:#4af0c40f;border:1px solid #4af0c426;border-radius:7px;margin-top:.85rem;padding:.5rem .75rem}.adm-modal-feedback--error{color:var(--error);background:#ff6b6b0f;border-color:#ff6b6b33}.adm-modal-activite{flex-direction:column;gap:1.25rem;display:flex}.adm-modal-act-stats{grid-template-columns:repeat(5,1fr);gap:.5rem;display:grid}.adm-modal-act-stat{text-align:center;background:#ffffff06;border:1px solid #ffffff0e;border-radius:9px;flex-direction:column;align-items:center;gap:.15rem;padding:.75rem .6rem .65rem;display:flex}.adm-modal-act-stat__icon{color:var(--muted);opacity:.7;font-size:.8rem}.adm-modal-act-stat__val{font-family:var(--fd);color:var(--text);letter-spacing:-.02em;font-size:1.35rem;font-weight:800;line-height:1}.adm-modal-act-stat__label{font-size:.57rem;font-family:var(--fm);text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.adm-modal-ia{flex-direction:column;gap:1.25rem;display:flex}.adm-modal-ia-tags{flex-wrap:wrap;gap:.3rem;margin-top:.25rem;display:flex}.adm-modal-empty{color:var(--muted);font-family:var(--fm);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.6rem;padding:2.5rem 1rem;font-size:.82rem;display:flex}.adm-modal-empty__icon{opacity:.25;font-size:2rem}.adm-modal-danger{background:#ef444408;border:1px solid #ef44442e;border-radius:10px;flex-direction:column;gap:.65rem;padding:1rem 1.1rem;display:flex}.adm-modal-danger__header{align-items:center;gap:.45rem;display:flex}.adm-modal-danger__icon{color:var(--error);opacity:.8;font-size:.85rem}.adm-modal-danger__title{font-size:.65rem;font-family:var(--fm);text-transform:uppercase;letter-spacing:.12em;color:var(--error);opacity:.85}.adm-modal-danger__btn{color:var(--error);font-size:.76rem;font-family:var(--fb);cursor:pointer;background:#ef444412;border:1px solid #ef444440;border-radius:7px;width:fit-content;padding:.5rem 1rem;transition:background .15s,border-color .15s}.adm-modal-danger__btn:hover:not(:disabled){background:#ef444421;border-color:#ef444473}.adm-modal-danger__btn:disabled{opacity:.4;cursor:not-allowed}@media (width<=1100px){.adm-sv2__groups{grid-template-columns:1fr}.adm-sv2__grid{grid-template-columns:repeat(4,1fr)}.adm-sv2-card--hero{grid-column:auto}.adm-mod-v2{grid-template-columns:1fr 1fr}}@media (width<=860px){.adm-sv2__grid{grid-template-columns:repeat(2,1fr)}.adm-mod-v2{grid-template-columns:1fr}.adm-rt__toolbar{flex-direction:column;align-items:flex-start}.adm-modal-info-grid,.adm-modal-ia-grid{grid-template-columns:repeat(2,1fr)}.adm-modal-act-stats{grid-template-columns:repeat(3,1fr)}}@media (width<=600px){.adm-modal-panel{border-radius:14px}.adm-modal-hero{padding:1.25rem 1.25rem 1rem}.adm-modal-body{padding:1rem 1.25rem 1.25rem}.adm-modal-tabs{padding:0 1.25rem}.adm-modal-info-grid,.adm-modal-ia-grid{grid-template-columns:1fr 1fr}.adm-modal-act-stats{grid-template-columns:repeat(2,1fr)}.adm-rt__sort-group{display:none}.adm-rt__search{width:160px}}@media (width<=440px){.adm-sv2__grid{grid-template-columns:1fr 1fr}.adm-modal-tab{padding:.6rem .7rem;font-size:.65rem}.adm-modal-hero__avatar{width:44px;height:44px;font-size:1.1rem}}.adm-modal-ia-feed{flex-direction:column;gap:.35rem;margin-top:.25rem;display:flex}.adm-modal-ia-feed__item{background:var(--surface-2);border:1px solid var(--border);border-radius:6px;align-items:baseline;gap:.5rem;padding:.3rem .5rem;font-size:.78rem;display:flex}.adm-modal-ia-feed__icon{flex-shrink:0;font-size:.65rem}.adm-modal-ia-feed__topic{color:var(--text);white-space:nowrap;font-weight:500}.adm-modal-ia-feed__note{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.72rem;overflow:hidden}.adm-modal-ia-feed__ts{color:var(--muted);white-space:nowrap;margin-left:auto;font-size:.68rem}.adm-modal-ia-fingerprint{flex-wrap:wrap;gap:.4rem;margin-top:.25rem;display:flex}.dash-modal-overlay{z-index:1000;background:#0000008c;justify-content:center;align-items:center;width:100vw;height:100dvh;display:flex;position:fixed;inset:0}.dash-modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex-direction:column;width:min(460px,94vw);max-height:85vh;margin:auto;padding:1.5rem;display:flex;overflow-y:auto}.dash-modal form{border-top:1px solid var(--border);flex-direction:column;flex:1 0;padding-top:.75rem;display:flex}.dash-modal__title{color:var(--text);border-bottom:2px solid var(--accent-dim);margin:0 0 1.5rem;padding-bottom:1rem;font-size:1.25rem;font-weight:600}.dash-modal__footer{flex-wrap:nowrap;justify-content:flex-end;gap:.75rem;width:100%;margin-top:1rem;display:flex}.dash-modal__footer .btn{flex:none;width:auto;min-width:5rem;min-height:2rem}.dash-modal__footer .btn--primary{width:auto;padding:.65rem 1rem}.variants-list{flex-direction:column;gap:.5rem;margin-bottom:1rem;display:flex}.variants-list__item{background:var(--background);border:1px solid var(--border);border-radius:6px;justify-content:space-between;align-items:center;gap:.75rem;padding:.75rem 1rem;transition:all .15s;display:flex}.variants-list__item:hover{background:var(--surface);border-color:var(--accent)}.variants-list__label{color:var(--text);flex:1;align-items:center;gap:.5rem;min-width:0;font-size:.9rem;font-weight:500;display:flex}.variants-list__label .variant-emoji{flex-shrink:0;font-size:1rem}.variants-list__edit-btn{cursor:pointer;opacity:.6;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:.3rem;font-size:1rem;transition:opacity .15s;display:flex}.variants-list__edit-btn:hover{opacity:1}.creator-comments{flex-direction:column;gap:.75rem;margin:0;padding:0;list-style:none;display:flex}.creator-comment{border:1px solid var(--border);border-radius:8px;padding:.75rem}.creator-comment__author{color:var(--text);margin-bottom:.25rem;font-size:.8rem;font-weight:700}.creator-comment__body{color:var(--text);white-space:pre-wrap;font-size:.85rem}.creator-comment__date{color:var(--muted);margin-top:.25rem;font-size:.7rem}.dm-overlay{z-index:1000;-webkit-backdrop-filter:blur(8px);background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.dm{background:linear-gradient(160deg,#13151c 0%,#0f1116 100%);border:1px solid #ffffff14;border-radius:16px;flex-direction:column;width:min(620px,96vw);max-height:88vh;animation:.28s cubic-bezier(.16,1,.3,1) forwards dm-enter;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #ffffff0a,0 32px 64px #0000008c,0 0 80px #4af0c40d}@keyframes dm-enter{0%{opacity:0;transform:translateY(28px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.dm__glow-line{pointer-events:none;z-index:1;background:linear-gradient(90deg,#0000,#4af0c480,#0000);width:70%;height:1px;position:absolute;top:0;left:50%;transform:translate(-50%)}.dm__close{width:28px;height:28px;color:var(--muted);cursor:pointer;z-index:10;background:#ffffff0f;border:1px solid #ffffff17;border-radius:7px;justify-content:center;align-items:center;transition:background .15s,color .15s,border-color .15s;display:flex;position:absolute;top:1.1rem;right:1.1rem}.dm__close:hover{color:var(--text);background:#ffffff1f;border-color:#ffffff29}.dm__steps{flex-shrink:0;align-items:center;padding:1.35rem 1.75rem 0;display:flex}.dm__step{align-items:center;gap:.5rem;display:flex}.dm__step-dot{width:26px;height:26px;color:var(--muted);font-size:.72rem;font-weight:700;font-family:var(--font-display);background:#1a1d26;border:1.5px solid #ffffff21;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.dm__step.is-current .dm__step-dot{border-color:var(--accent);color:var(--accent);background:#4af0c41a;box-shadow:0 0 14px #4af0c440}.dm__step.is-done .dm__step-dot{border-color:var(--accent);background:var(--accent);color:#08090c}.dm__step-label{color:var(--muted);font-size:.72rem;font-weight:600;font-family:var(--font-display);letter-spacing:.06em;text-transform:uppercase;transition:color .2s}.dm__step.is-current .dm__step-label,.dm__step.is-done .dm__step-label{color:var(--text)}.dm__step-track{background:#ffffff14;border-radius:1px;flex:1;height:2px;margin:0 .8rem;overflow:hidden}.dm__step-fill{background:var(--accent);border-radius:1px;width:0;height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}.dm__step-track.is-done .dm__step-fill{width:100%}.dm__body{flex-direction:column;flex:1;gap:1.2rem;min-height:0;padding:1.4rem 1.75rem .5rem;display:flex;overflow-y:auto}.dm__body::-webkit-scrollbar{width:3px}.dm__body::-webkit-scrollbar-track{background:0 0}.dm__body::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.dm__step1,.dm__step2{animation:.24s cubic-bezier(.16,1,.3,1) forwards dm-step-in}@keyframes dm-step-in{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.dm__section{flex-direction:column;gap:.65rem;display:flex}.dm__section-label{text-transform:uppercase;letter-spacing:.09em;color:var(--muted);font-size:.69rem;font-weight:700;font-family:var(--font-display);margin:0}.dm__choices{grid-template-columns:1fr 1fr;gap:.65rem;display:grid}.dm__choice-card{cursor:pointer;text-align:left;background:#ffffff08;border:1.5px solid #ffffff12;border-radius:11px;flex-direction:column;gap:.55rem;padding:1rem 1.05rem;transition:border-color .18s,background .18s,box-shadow .18s;display:flex;position:relative}.dm__choice-card:hover{background:#4af0c408;border-color:#4af0c44d}.dm__choice-card.is-active{border-color:var(--accent);background:#4af0c40f;box-shadow:0 0 22px #4af0c41a}.dm__choice-icon{color:var(--muted);align-items:center;transition:color .18s;display:flex}.dm__choice-card.is-active .dm__choice-icon{color:var(--accent)}.dm__choice-radio{border:1.5px solid #ffffff2e;border-radius:50%;width:15px;height:15px;transition:border-color .18s;position:absolute;top:.85rem;right:.85rem}.dm__choice-radio:after{content:"";background:var(--accent);opacity:0;border-radius:50%;transition:opacity .18s;position:absolute;inset:3px}.dm__choice-card.is-active .dm__choice-radio{border-color:var(--accent)}.dm__choice-card.is-active .dm__choice-radio:after{opacity:1}.dm__choice-text{flex-direction:column;gap:.2rem;display:flex}.dm__choice-title{color:var(--text);font-size:.87rem;font-weight:600;font-family:var(--font-display)}.dm__choice-desc{color:var(--muted);font-size:.76rem;line-height:1.45}.dm__targets-section{animation:.2s forwards dm-step-in}.dm__targets{flex-wrap:wrap;gap:.45rem;display:flex}.dm__target{color:var(--text);cursor:pointer;font-size:.84rem;font-weight:500;font-family:var(--font-body);background:#ffffff08;border:1.5px solid #ffffff1a;border-radius:8px;align-items:center;gap:.45rem;padding:.48rem .95rem;transition:border-color .15s,background .15s,color .15s,box-shadow .15s;display:flex}.dm__target:hover:not(:disabled){background:#4af0c40d;border-color:#4af0c466}.dm__target.is-active{border-color:var(--accent);background:var(--accent);color:#08090c;font-weight:700;box-shadow:0 0 14px #4af0c440}.dm__target.is-existing,.dm__target:disabled{opacity:.38;cursor:not-allowed}.dm__target.is-existing .dm__target-label{-webkit-text-decoration:line-through #ffffff4d;text-decoration:line-through #ffffff4d}.dm__target-badge{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);background:#ffffff14;border-radius:4px;padding:.1rem .3rem;font-size:.62rem;font-weight:700}.dm__review-header{border-bottom:1px solid #ffffff0f;flex-wrap:wrap;flex-shrink:0;align-items:center;gap:.75rem;padding-bottom:.85rem;display:flex}.dm__review-tag{color:var(--accent);font-size:.77rem;font-weight:700;font-family:var(--font-display);letter-spacing:.04em;background:#4af0c41a;border:1px solid #4af0c440;border-radius:999px;align-items:center;padding:.28rem .75rem;display:inline-flex}.dm__review-sep{opacity:.4}.dm__streaming-badge{color:var(--accent);font-size:.78rem;font-weight:600;font-family:var(--font-display);align-items:center;gap:.45rem;display:inline-flex}.dm__streaming-dot{background:var(--accent);border-radius:50%;width:7px;height:7px;animation:1.1s ease-in-out infinite dm-pulse}@keyframes dm-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.65)}}.dm__blocks{flex-direction:column;flex:1;gap:.45rem;display:flex}.dm__review-stats{color:var(--muted);align-items:center;gap:.45rem;font-size:.78rem;display:inline-flex}.dm__stat--modified{color:var(--accent);font-weight:600}.dm-block{background:#ffffff06;border:1px solid #ffffff12;border-radius:9px;transition:border-color .2s;animation:.26s cubic-bezier(.16,1,.3,1) both dm-block-in;overflow:hidden}@keyframes dm-block-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.dm-block--modified{border-color:#4af0c42e;border-left:2px solid var(--accent);background:#4af0c408}.dm-block--unchanged{opacity:.42;filter:saturate(.6)}.dm-block--loading{background:#ffffff05;border:1px solid #ffffff0d;flex-direction:column;gap:.55rem;padding:.9rem 1rem;display:flex}.dm-block__shimmer{background:linear-gradient(90deg,#ffffff0a 0%,#ffffff17 50%,#ffffff0a 100%) 0 0/200% 100%;border-radius:4px;height:10px;animation:1.5s infinite dm-shimmer}.dm-block__shimmer--sm{width:55%}@keyframes dm-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.dm-block__header{justify-content:space-between;align-items:center;gap:.5rem;min-height:34px;padding:.45rem .6rem .45rem .7rem;display:flex}.dm-block__header-left{flex:1;align-items:center;gap:.5rem;min-width:0;display:flex}.dm-block__type-chip{letter-spacing:.04em;text-transform:uppercase;color:var(--chip-color,#888);background:color-mix(in srgb, var(--chip-color,#888) 12%, transparent);border:1px solid color-mix(in srgb, var(--chip-color,#888) 25%, transparent);font-size:.67rem;font-weight:700;font-family:var(--font-display);border-radius:999px;flex-shrink:0;align-items:center;gap:.3rem;padding:.14rem .5rem .14rem .35rem;display:inline-flex}.dm-block__type-dot{background:var(--chip-color,#888);border-radius:50%;flex-shrink:0;width:5px;height:5px}.dm-block__sub-count{opacity:.7;text-transform:none;letter-spacing:0;border-left:1px solid;margin-left:.1rem;padding-left:.35rem;font-size:.6rem;font-weight:500}.dm-block__status--modified{text-transform:uppercase;letter-spacing:.06em;color:var(--accent);font-size:.63rem;font-weight:700;font-family:var(--font-display);align-items:center;gap:.25rem;display:inline-flex}.dm-block__remove{cursor:pointer;color:#fff3;background:0 0;border:none;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;transition:color .14s,background .14s;display:flex}.dm-block__remove:hover{color:#ff6b6b;background:#ff6b6b1a}.dm-block__preview{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;margin:0;padding:0 .7rem .5rem;font-size:.76rem;line-height:1.5;overflow:hidden}.dm-block--modified .dm-block__preview{color:#ffffff8c;border-bottom:1px solid #ffffff0d;margin-bottom:0;padding-bottom:.45rem}.dm-block__editor{width:100%;min-height:3.5rem;font-family:var(--font-mono,"JetBrains Mono", monospace);color:var(--text);resize:vertical;box-sizing:border-box;background:0 0;border:none;padding:.55rem .75rem;font-size:.77rem;line-height:1.65;transition:background .15s;display:block}.dm-block__editor:focus{background:#ffffff05;outline:none}.dm__generating{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:1.3rem;min-height:220px;padding:2.5rem 1rem;display:flex}.dm__gen-rings{justify-content:center;align-items:center;width:72px;height:72px;display:flex;position:relative}.dm__gen-ring{border:2px solid #0000;border-radius:50%;position:absolute;inset:0}.dm__gen-ring--outer{border-top-color:var(--accent);border-right-color:#4af0c459;animation:1.4s linear infinite dm-spin}.dm__gen-ring--inner{border-top-color:#4af0c480;border-left-color:#4af0c433;animation:.9s linear infinite reverse dm-spin;inset:12px}.dm__gen-core{z-index:1;color:var(--accent);opacity:.7;animation:2s ease-in-out infinite dm-core-pulse;position:relative}@keyframes dm-spin{to{transform:rotate(360deg)}}@keyframes dm-core-pulse{0%,to{opacity:.5;transform:scale(.9)}50%{opacity:.9;transform:scale(1.05)}}.dm__gen-status{color:var(--text);font-size:.88rem;font-weight:600;font-family:var(--font-display);text-align:center;margin:0;animation:.35s cubic-bezier(.16,1,.3,1) both dm-msg-in}@keyframes dm-msg-in{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.dm__gen-hint{color:var(--muted);text-align:center;opacity:.65;max-width:280px;margin:0;font-size:.76rem;line-height:1.5}.dm__empty{text-align:center;color:var(--muted);padding:2.5rem 1rem;font-size:.87rem}.dm__error{color:var(--error,#ff6b6b);background:#ff6b6b12;border:1px solid #ff6b6b33;border-radius:8px;flex-shrink:0;margin:0;padding:.6rem .85rem;font-size:.82rem}.dm__footer{background:linear-gradient(#0000,#0f111699);border-top:1px solid #ffffff0f;flex-shrink:0;justify-content:flex-end;align-items:center;gap:.65rem;padding:1rem 1.75rem 1.35rem;display:flex}.dm__footer .btn{flex-shrink:0;width:auto;min-height:2rem}.dm__generate-btn{align-items:center;gap:.3rem;display:inline-flex}.creator-toast{background:var(--surface);border:1px solid var(--border);z-index:2000;border-radius:8px;padding:.75rem 1rem;font-size:.85rem;position:fixed;bottom:1.5rem;right:1.5rem;box-shadow:0 4px 16px #0003}.creator-toast--error{border-color:var(--color-error,#c0392b);color:var(--color-error,#c0392b)}.creator-toast--success{border-color:var(--color-success,#27ae60);color:var(--color-success,#27ae60)}.creator-rooms-frame{box-sizing:border-box;flex:1;padding:1rem 1.5rem 2rem;overflow-y:auto}.creator-rooms{grid-template-columns:repeat(3,minmax(280px,1fr));gap:1.25rem;max-width:1200px;margin:0 auto;display:grid}.creator-rooms::-webkit-scrollbar-thumb:hover{background:var(--border-h)}.creator-room-card{background:var(--surface);border:1px solid var(--border);cursor:default;border-radius:12px;flex-direction:column;padding:0;transition:box-shadow .2s,transform .2s;display:flex;overflow:hidden}.creator-room-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001f}.creator-room-card__accent{background:var(--accent);flex-shrink:0;height:4px}.creator-room-card__body{flex-direction:column;flex:1;gap:.75rem;padding:1.25rem;display:flex}.creator-room-card__header{align-items:flex-start;gap:1rem;display:flex}.creator-room-card__icon{flex-shrink:0;font-size:2.5rem;line-height:1}.creator-room-card__header-text{flex-direction:column;flex:1;gap:.5rem;min-width:0;display:flex}.creator-room-card__title{font-family:var(--fd);color:var(--text);cursor:pointer;word-break:break-word;border-bottom:1px dashed #0000;margin:0;padding:0;font-size:1rem;font-weight:700;transition:border-color .15s,color .15s}.creator-room-card__title:hover{border-bottom-color:var(--accent);color:var(--accent)}.creator-room-card__title-input{font-family:var(--fd);color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:4px;width:100%;padding:.4rem;font-size:1rem;font-weight:700}.creator-room-card__title-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px rgba(var(--accent-rgb,0, 0, 0), .1);outline:none}.creator-room-card__variants-section{flex-direction:column;gap:.5rem;display:flex}.creator-room-card__variants-toggle{cursor:pointer;color:var(--muted);background:0 0;border:none;align-items:center;gap:.5rem;padding:.5rem 0;font-size:.9rem;transition:color .15s;display:flex}.creator-room-card__variants-toggle:hover{color:var(--text)}.variant-toggle.is-expanded{color:var(--accent)}.creator-room-card .pill{background:var(--border);color:var(--text);border-radius:1rem;padding:.3rem .6rem;font-size:.8rem;font-weight:600}.icon-arrow{font-size:.75rem;transition:transform .15s;display:inline-block}.creator-room-card__variants-row{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.creator-room-card__like-stats{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.creator-room-card__like-stat{border:1px solid var(--border);background:var(--surface-2);color:var(--muted);white-space:nowrap;border-radius:999px;align-items:center;gap:.2rem;padding:.2rem .5rem;font-size:.8rem;font-weight:600;line-height:1;display:inline-flex}.creator-room-card__like-stat--like{color:#27ae60;background:#27ae6010;border-color:#27ae6040}.creator-room-card__like-stat--dislike{color:#c0392b;background:#c0392b10;border-color:#c0392b40}.creator-room-card__variants-list{border-top:1px solid var(--border);border-bottom:1px solid var(--border);flex-direction:column;gap:.5rem;padding:.5rem 0;display:flex}.creator-room-card__variant-chip{background:var(--background);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:6px;align-items:center;gap:.5rem;padding:.6rem .8rem;font-size:.85rem;transition:background .15s,border-color .15s;display:flex}.creator-room-card__variant-chip:hover{background:var(--surface);border-color:var(--accent)}.variant-emoji{font-size:1rem}.variant-label{word-break:break-word;flex:1;min-width:0}.variant-status-dot{background:var(--muted);border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.variant-status--draft{background:#999}.variant-status--inreview{background:#f39c12}.variant-status--published{background:#27ae60}.variant-status--inpreview{background:#3498db}.variant-status--archived{background:#95a5a6}.variant-dropdown{background:var(--surface);border:1px solid var(--border);z-index:10;border-radius:8px;flex-wrap:wrap;gap:.5rem;min-width:200px;max-width:100%;padding:.5rem;display:flex;position:absolute;left:0;box-shadow:0 4px 12px #00000026}.variant-dropdown--down{margin-top:.25rem;top:100%}.variant-dropdown--up{margin-bottom:.25rem;bottom:100%}.variant-chip{background:var(--accent-dim);color:var(--text);cursor:pointer;white-space:nowrap;border:none;border-radius:20px;align-items:center;gap:.3rem;padding:.2rem .6rem;font-size:.75rem;text-decoration:none;transition:background .15s;display:inline-flex}.variant-chip:hover{background:var(--accent);color:#fff}.creator-room-card__actions{grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch;gap:.5rem;width:100%;display:grid}.creator-room-card .btn,.validator-room-card .btn{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);color:var(--text);cursor:pointer;white-space:nowrap;align-items:center;padding:.5rem .75rem;font-size:.8rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.creator-room-card .btn:hover:not(:disabled),.validator-room-card .btn:hover:not(:disabled){background:var(--accent);color:#fff;border-color:var(--accent)}.creator-room-card .btn:disabled,.validator-room-card .btn:disabled{opacity:.5;cursor:not-allowed}.creator-room-card .btn-sm,.validator-room-card .btn-sm{padding:.35rem .5rem;font-size:.75rem}.creator-room-card__actions .btn{white-space:nowrap;text-overflow:ellipsis;justify-content:center;width:100%;min-width:0;overflow:hidden}.creator-room-card__actions .btn.btn--danger{background:var(--color-error,#c0392b);color:#fff;border-color:var(--color-error,#c0392b)}.creator-room-card__actions .btn.btn--danger:hover{background:#a93226;border-color:#a93226}.validator-room-card{background:var(--surface);border:1px solid var(--border);cursor:default;border-radius:12px;flex-direction:column;padding:0;transition:box-shadow .2s,transform .2s;display:flex;overflow:hidden}.validator-room-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001f}.validator-room-card__accent{background:#f39c12;flex-shrink:0;height:4px}.validator-room-card__body{flex-direction:column;flex:1;gap:.75rem;padding:1.25rem;display:flex}.validator-room-card__header{align-items:flex-start;gap:1rem;display:flex}.validator-room-card__icon{flex-shrink:0;font-size:2.5rem;line-height:1}.validator-room-card__header-text{flex-direction:column;flex:1;gap:.5rem;min-width:0;display:flex}.validator-room-card__title{font-family:var(--fd);color:var(--text);word-break:break-word;margin:0;padding:0;font-size:1rem;font-weight:700}.validator-room-card__meta{color:var(--muted);font-size:.85rem;line-height:1.4}.validator-room-card__subject{color:var(--text);margin-top:.25rem;font-size:.9rem;font-weight:500;display:block}.validator-room-card__actions{grid-template-columns:repeat(3,minmax(0,1fr));align-items:stretch;gap:.5rem;width:100%;display:grid}.validator-room-card__actions .btn,.validator-room-card__view-btn{white-space:nowrap;text-overflow:ellipsis;justify-content:center;width:100%;min-width:0;padding:.35rem .25rem;font-size:.7rem;overflow:hidden}.validator-room-card__view-btn{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);cursor:pointer;justify-content:center;align-items:center;text-decoration:none;transition:background .2s,border-color .2s,color .2s;display:flex}.validator-room-card__view-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}.validator-tab{color:var(--muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:.5rem;padding:.6rem 1rem;font-size:.9rem;font-weight:600;transition:all .2s;display:flex}.validator-tab:hover{color:var(--text)}.validator-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.validator-tab__count{background:var(--border);min-width:24px;height:24px;color:var(--text);border-radius:12px;justify-content:center;align-items:center;padding:0 .4rem;font-size:.75rem;font-weight:700;display:inline-flex}.creator-parcours-topbar{align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.creator-parcours-count{color:var(--muted);font-size:.85rem}.creator-parcours-loading,.creator-parcours-error,.creator-parcours-empty{color:var(--muted);padding:1rem 0;font-size:.9rem}.creator-parcours-error{color:var(--danger,#ef4444)}.creator-parcours-group{margin-bottom:1.75rem}.creator-parcours-group__title{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:0 0 .6rem;font-size:.78rem;font-weight:600}.creator-parcours-card{border:1px solid var(--border);border-radius:var(--radius,8px);background:var(--surface,#fff);align-items:center;gap:.85rem;margin-bottom:.5rem;padding:.75rem 1rem;transition:border-color .15s;display:flex}.creator-parcours-card:hover{border-color:var(--border-h,#9ca3af)}.creator-parcours-card__icon{flex-shrink:0;font-size:1.75rem;line-height:1}.creator-parcours-card__body{flex:1;min-width:0}.creator-parcours-card__header{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.creator-parcours-card__name{white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:600;overflow:hidden}.creator-parcours-card__subject{color:var(--muted);margin-top:.1rem;font-size:.78rem}.creator-parcours-card__meta{color:var(--muted);gap:.75rem;margin-top:.3rem;font-size:.75rem;display:flex}.creator-parcours-card__actions{flex-shrink:0}.validator-parcours-card{background:var(--surface);border:1px solid var(--border);cursor:default;border-radius:12px;flex-direction:column;padding:0;transition:box-shadow .2s,transform .2s;display:flex;overflow:hidden}.validator-parcours-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001f}.validator-parcours-card__accent{background:#8b5cf6;flex-shrink:0;height:4px}.validator-parcours-card__body{flex-direction:column;flex:1;gap:.75rem;padding:1.25rem;display:flex}.validator-parcours-card__header{align-items:flex-start;gap:1rem;display:flex}.validator-parcours-card__icon{flex-shrink:0;font-size:2.5rem;line-height:1}.validator-parcours-card__header-text{flex-direction:column;flex:1;gap:.5rem;min-width:0;display:flex}.validator-parcours-card__title{font-family:var(--fd);color:var(--text);word-break:break-word;margin:0;padding:0;font-size:1rem;font-weight:700}.validator-parcours-card__meta{color:var(--muted);flex-wrap:wrap;gap:.5rem;font-size:.8rem;display:flex}.validator-parcours-card__meta span{align-items:center;display:inline-flex}.validator-parcours-card__meta span+span:before{content:"·";opacity:.5;margin-right:.5rem}.validator-parcours-card__actions{gap:.5rem;width:100%;display:flex}.validator-parcours-card__actions .btn{flex:1;justify-content:center;font-size:.8rem}.btn--danger{background:var(--color-error,#c0392b);color:#fff;border-color:var(--color-error,#c0392b)}.btn--danger:hover{background:#a93226;border-color:#a93226}.btn--info{background:var(--surface-2);border-color:var(--accent);color:var(--text)}.btn--info:hover{background:var(--accent);border-color:var(--accent);color:#fff}.btn--warning{color:#fff;background:#f39c12;border-color:#f39c12}.btn--warning:hover{background:#e67e22;border-color:#e67e22}.btn-apply{border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-body);font-size:.75rem;font-family:var(--font-body);cursor:pointer;transition:border-color var(--tf), color var(--tf), background var(--tf);white-space:nowrap;background:0 0;padding:.22rem .65rem}.btn-apply:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.btn-apply:disabled{opacity:.4;cursor:not-allowed}.btn-completed{background:var(--accent-dim);border:1.5px solid color-mix(in srgb, var(--accent) 30%, transparent);border-radius:var(--radius-md);color:var(--accent);font-family:var(--font-display);cursor:pointer;width:100%;transition:background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast), box-shadow var(--transition-fast);align-items:center;gap:8px;padding:10px 18px;font-size:.9rem;font-weight:700;display:inline-flex}.btn-completed:hover{background:var(--accent);border-color:var(--accent);color:#08090c;box-shadow:var(--glow-btn)}.btn-completed:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.completed-modal__overlay{z-index:200;background:#0000008c;justify-content:center;align-items:center;padding:16px;animation:.18s both overlay-in;display:flex;position:fixed;inset:0}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.completed-modal__panel{background:var(--surface-2,#13151c);border:1px solid var(--border);border-radius:var(--radius-lg,16px);flex-direction:column;width:100%;max-width:480px;max-height:80vh;animation:.22s cubic-bezier(.4,0,.2,1) both panel-in;display:flex;overflow:hidden}@keyframes panel-in{0%{opacity:0;transform:translateY(12px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.completed-modal__header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex}.completed-modal__title{font-family:var(--font-display);color:var(--text);font-size:1rem;font-weight:700}.completed-modal__close{width:32px;height:32px;color:var(--muted);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;place-items:center;font-size:1.2rem;display:grid}.completed-modal__close:hover{background:var(--surface-hover);color:var(--text)}.completed-modal__body{flex:1;padding:8px 0;overflow-y:auto}.completed-modal__empty{text-align:center;color:var(--muted);padding:32px 20px;font-size:.9rem}.completed-room-item{transition:background var(--transition-fast);align-items:center;gap:12px;padding:12px 20px;text-decoration:none;display:flex}.completed-room-item:hover{background:var(--surface-hover)}.completed-room-item__icon{text-align:center;flex-shrink:0;width:36px;font-size:1.4rem}.completed-room-item__info{flex:1;min-width:0}.completed-room-item__name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.completed-room-item__meta{color:var(--muted);margin-top:2px;font-size:.75rem}.completed-room-item__arrow{color:var(--muted);transition:color var(--transition-fast);flex-shrink:0;font-size:.9rem}.completed-room-item:hover .completed-room-item__arrow{color:var(--accent)}.dash-stat-card{background:var(--surface-2);border:1px solid var(--border);border-radius:16px;flex-direction:column;gap:1rem;padding:1.25rem;display:flex}.dash-stat-card__header{align-items:center;gap:.875rem;display:flex}.dash-stat-card__avatar{background:var(--accent-dim);border:1.5px solid var(--accent-glow);width:44px;height:44px;font-family:var(--font-display);color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.95rem;font-weight:700;display:flex}.dash-stat-card__info{flex-direction:column;gap:.2rem;min-width:0;display:flex}.dash-stat-card__name{font-family:var(--font-display);color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:700;overflow:hidden}.dash-stat-card__badges{flex-wrap:wrap;gap:.35rem;display:flex}.dash-stat-card__pills{grid-template-columns:1fr 1fr;gap:.625rem;display:grid}.dash-stat-pill{background:var(--surface-3);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:.15rem;padding:.6rem .75rem;display:flex}.dash-stat-pill__value{font-family:var(--font-display);color:var(--accent);font-size:1.25rem;font-weight:700;line-height:1}.dash-stat-pill__label{color:var(--muted);font-size:.7rem;line-height:1.2}.dash-priv-card{background:var(--surface-2);border:1px solid var(--border);border-radius:16px;flex-direction:column;gap:.625rem;padding:1rem 1.125rem .875rem;display:flex;position:relative;overflow:hidden}.dash-priv-card:before{content:"";background:linear-gradient(90deg, transparent, var(--accent-glow), transparent);pointer-events:none;height:1px;position:absolute;top:0;left:20%;right:20%}.dash-priv-card__header{align-items:center;gap:.5rem;margin-bottom:.125rem;display:flex}.dash-priv-card__dot{background:var(--accent);width:5px;height:5px;box-shadow:0 0 6px var(--accent-glow);border-radius:50%;flex-shrink:0}.dash-priv-card__title{font-family:var(--font-display);color:var(--muted);text-transform:uppercase;letter-spacing:.09em;font-size:.7rem;font-weight:700}.dash-priv-card__list{flex-direction:column;gap:.125rem;display:flex}.dash-priv-item{color:var(--text-body);transition:background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);background:0 0;border:1px solid #0000;border-radius:8px;align-items:center;gap:.5rem;padding:.45rem .5rem;font-size:.8rem;font-weight:500;text-decoration:none;display:flex}.dash-priv-item:hover{background:var(--accent-dim);color:var(--text);border-color:#4af0c42e}.dash-priv-item__icon{text-align:center;flex-shrink:0;width:20px;font-size:.9rem;line-height:1}.dash-priv-item__label{white-space:nowrap;text-overflow:ellipsis;min-width:0;font-family:var(--font-body);flex:1;overflow:hidden}.dash-priv-item__arrow{color:var(--muted2);transition:transform var(--transition-fast), color var(--transition-fast);flex-shrink:0;font-size:.75rem}.dash-priv-item:hover .dash-priv-item__arrow{color:var(--accent);transform:translate(3px)}.dash-pinned{background:var(--surface-2);border:1px solid var(--border);border-radius:16px;flex-direction:column;gap:1rem;padding:1.25rem;display:flex}.dash-pinned__header{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.dash-pinned__title{font-family:var(--font-display);color:var(--text);white-space:nowrap;text-overflow:ellipsis;min-width:0;font-size:1rem;font-weight:700;overflow:hidden}.dash-pinned__meta{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.dash-pinned__progress-pct{color:var(--accent);font-size:.78rem;font-weight:600}.dash-unpin-btn{cursor:pointer;color:var(--muted);background:0 0;border:none;border-radius:4px;padding:.2rem;font-size:.9rem;line-height:1;transition:color .15s}.dash-unpin-btn:hover{color:var(--error)}.dash-empty{background:var(--surface-2);border:1px solid var(--border);text-align:center;border-radius:16px;flex-direction:column;align-items:center;gap:.875rem;padding:2rem 1.5rem;display:flex}.dash-empty__icon{opacity:.35;font-size:2rem}.dash-empty__title{font-family:var(--font-display);color:var(--text);font-size:1rem;font-weight:700}.dash-empty__sub{color:var(--muted);font-size:.85rem}.dash-empty__cta{background:var(--accent);color:var(--bg);border-radius:10px;align-items:center;gap:.4rem;margin-top:.25rem;padding:.55rem 1.1rem;font-size:.85rem;font-weight:600;text-decoration:none;transition:opacity .15s;display:inline-flex}.dash-empty__cta:hover{opacity:.88}.dash-reco{background:var(--surface-3);border:1px solid var(--border-hover);border-radius:14px;flex-direction:column;gap:.625rem;padding:1rem 1.25rem;display:flex}.dash-reco__label{letter-spacing:.06em;text-transform:uppercase;color:var(--accent);align-items:center;gap:.3rem;font-size:.7rem;font-weight:700;display:inline-flex}.dash-reco__name{font-family:var(--font-display);color:var(--text);font-size:.95rem;font-weight:700}.dash-reco__desc{color:var(--muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.8rem;display:-webkit-box;overflow:hidden}.dash-reco__pin-btn{border:1px solid var(--accent);background:var(--accent-dim);color:var(--accent);cursor:pointer;border-radius:8px;align-self:flex-start;padding:.4rem .9rem;font-size:.8rem;font-weight:600;transition:background .15s}.dash-reco__pin-btn:hover:not(:disabled){background:#4af0c433}.dash-reco__pin-btn:disabled{opacity:.5;cursor:not-allowed}.dash-reco--completion{border-color:var(--p-accent,#8b5cf6);background:var(--p-accent-dim,#8b5cf61a)}.dash-reco--completion .dash-reco__label{color:var(--p-accent,#8b5cf6)}.dash-reco--completion .dash-reco__pin-btn{border-color:var(--p-accent,#8b5cf6);background:var(--p-accent-dim,#8b5cf61a);color:var(--p-accent-alt,#a78bfa)}.dash-new-rooms{flex-direction:column;gap:.875rem;display:flex}.dash-new-rooms__header{justify-content:space-between;align-items:center;display:flex}.dash-new-rooms__title{font-family:var(--font-display);color:var(--text);font-size:1rem;font-weight:700}.dash-new-rooms__see-all{color:var(--accent);opacity:.8;font-size:.78rem;text-decoration:none;transition:opacity .15s}.dash-new-rooms__see-all:hover{opacity:1}.dash-new-rooms__grid{grid-template-columns:1fr 1fr;gap:.875rem;display:grid}.dash-skel{background:var(--surface-2);border:1px solid var(--border);border-radius:16px;padding:1.25rem}.dash-skel-block{background:var(--surface-3);border-radius:8px;animation:1.5s ease-in-out infinite dash-skel-pulse}@keyframes dash-skel-pulse{0%,to{opacity:.5}50%{opacity:1}}.dash-tabs{border-bottom:1px solid var(--border);gap:.25rem;margin-bottom:1.25rem;padding-bottom:.5rem;display:flex}.dash-tab{font-size:.82rem;font-family:var(--font-display);opacity:.45;cursor:pointer;color:var(--text);background:0 0;border:none;border-radius:999px;padding:.3rem .875rem;transition:opacity .15s}.dash-tab:hover{opacity:.75}.dash-tab--active{opacity:1;color:var(--accent,#4af0c4);background:#4af0c414;font-weight:700}.dash-pinned__cta{background:var(--accent,#4af0c4);color:#000;border-radius:6px;margin-top:.875rem;padding:.4rem 1.1rem;font-size:.82rem;font-weight:700;text-decoration:none;transition:opacity .15s;display:inline-block}.dash-pinned__cta:hover{opacity:.82}.dash-nudge{background:var(--surface-2);border:1px solid var(--border);border-radius:16px;align-items:center;gap:.75rem;padding:.75rem 1.125rem;animation:.4s cubic-bezier(.22,1,.36,1) both nudge-arrive;display:flex;position:relative;overflow:hidden}.dash-nudge:before{content:"";background:linear-gradient(90deg, transparent, var(--accent-glow), transparent);pointer-events:none;height:1px;position:absolute;top:0;left:20%;right:20%}.dash-nudge__sigil{background:var(--accent-dim);border:1px solid var(--accent-glow);width:22px;height:22px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.6rem;animation:3s ease-in-out infinite nudge-pulse;display:inline-flex}.dash-nudge__text{font-family:var(--font-body);color:var(--text-body);flex:1;min-width:0;margin:0;font-size:.84rem;line-height:1.5}@keyframes nudge-arrive{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes nudge-pulse{0%,to{box-shadow:0 0 #0000}50%{box-shadow:0 0 7px 0 var(--accent-glow)}}@keyframes sa-fade-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes sa-dot-pulse{0%,to{box-shadow:0 0 0 0 var(--accent-glow)}50%{box-shadow:0 0 0 5px #0000}}.sa-page{box-sizing:border-box;width:100%;max-width:1280px;margin:0 auto;padding:1.5rem 1.5rem 4rem}.sa-header{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1.75rem;padding-bottom:1.25rem;display:flex}.sa-header__left{align-items:center;gap:.75rem;display:flex}.sa-header__title{font-family:var(--fd);color:var(--text);margin:0;font-size:1.35rem;font-weight:700}.sa-header__right{align-items:center;gap:.75rem;display:flex}.sa-header__ts{font-family:var(--fm);color:var(--muted);font-size:.7rem}.sa-layout{grid-template-columns:60fr 40fr;align-items:start;gap:1.25rem;display:grid}.sa-col-main,.sa-col-side{flex-direction:column;gap:1.25rem;display:flex}.sa-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);padding:1.25rem;animation:.35s ease-out both sa-fade-up}.sa-card--flush{padding:0;overflow:hidden}.sa-card__header{align-items:center;gap:.5rem;margin-bottom:1.1rem;display:flex}.sa-card__title{font-family:var(--fm);text-transform:uppercase;letter-spacing:.1em;color:var(--muted);flex:1;font-size:.62rem}.sa-card__meta{font-family:var(--fm);color:var(--muted);font-size:.68rem}.sa-card__sub{font-family:var(--fm);text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:.6rem;font-size:.6rem}.sa-card-divider{background:var(--border);height:1px;margin:1rem 0}.sa-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.sa-dot[data-status=active]{background:var(--accent);animation:2.5s ease-in-out infinite sa-dot-pulse}.sa-dot[data-status=failed]{background:var(--error)}.sa-dot[data-status=inactive]{background:var(--warn)}.sa-dot[data-status=unknown]{background:var(--muted)}.sa-service-list{flex-direction:column;display:flex}.sa-service-row{border-bottom:1px solid var(--border);transition:background var(--tf);grid-template-columns:12px 1fr auto auto auto;align-items:center;gap:.75rem;padding:.6rem 0;display:grid}.sa-service-row:last-child{border-bottom:none}.sa-service-row__name{font-family:var(--fm);color:var(--text);font-size:.78rem}.sa-service-row__type{font-family:var(--fm);color:var(--muted);background:var(--surface-3);border-radius:4px;padding:.1rem .4rem;font-size:.58rem}.sa-service-row__status{font-family:var(--fm);color:var(--muted);text-align:right;min-width:4rem;font-size:.68rem}.sa-service-row[data-status=active] .sa-service-row__status{color:var(--accent)}.sa-service-row[data-status=failed] .sa-service-row__status{color:var(--error)}.sa-service-row[data-status=inactive] .sa-service-row__status{color:var(--warn)}.sa-service-row__actions{gap:.35rem;display:flex}.sa-btn{background:var(--surface-3);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-body);font-family:var(--fb);cursor:pointer;transition:border-color var(--tf), color var(--tf), background var(--tf);white-space:nowrap;justify-content:center;align-items:center;gap:.3rem;display:inline-flex}.sa-btn:disabled{opacity:.4;cursor:not-allowed}.sa-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.sa-btn--danger:hover:not(:disabled){border-color:var(--error);color:var(--error);background:#ff6b6b14}.sa-btn--xs{padding:.22rem .55rem;font-size:.7rem}.sa-btn--refresh{padding:.28rem .7rem;font-size:.75rem}.sa-sudo__label{font-family:var(--fm);text-transform:uppercase;letter-spacing:.08em;color:var(--muted);align-items:center;margin-bottom:.5rem;font-size:.62rem;display:flex}.sa-sudo__form{align-items:center;gap:.5rem;display:flex}.sys-gauge{text-align:center;position:relative}.sys-gauge__label{margin-top:-.15rem}.sys-gauge__pct{font-family:var(--fd);color:var(--text);font-size:.95rem;font-weight:700;line-height:1;display:block}.sys-gauge__sub{color:var(--muted);margin-top:.1rem;font-size:.58rem;display:block}.sa-vitals{grid-template-columns:repeat(3,1fr);gap:.5rem;display:grid}.sa-vital{text-align:center;flex-direction:column;align-items:center;display:flex}.sa-vital__label{font-family:var(--fm);text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:.15rem;font-size:.6rem}.sa-vital__sub{font-family:var(--fm);color:var(--text-body);margin-top:.1rem;font-size:.62rem}.sa-load-vals{grid-template-columns:repeat(3,1fr);gap:.5rem;display:grid}.sa-load-val{background:var(--surface-3);border-radius:var(--r-sm);flex-direction:column;align-items:center;padding:.45rem .25rem;display:flex}.sa-load-val__num{font-family:var(--fd);color:var(--text);font-size:1rem;font-weight:700;line-height:1.1}.sa-load-val__lbl{font-family:var(--fm);color:var(--muted);margin-top:.12rem;font-size:.58rem}.sa-ops-label{font-family:var(--fm);text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:.55rem;font-size:.6rem}.sa-uptime{grid-template-columns:1fr 1fr;gap:.5rem;display:grid}.sa-uptime-item{background:var(--surface-3);border-radius:var(--r-sm);flex-direction:column;gap:.12rem;padding:.5rem .6rem;display:flex}.sa-uptime-item__val{font-family:var(--fd);color:var(--text);font-size:1rem;font-weight:700;line-height:1.1}.sa-uptime-item__lbl{font-family:var(--fm);color:var(--muted);font-size:.58rem}.sa-backup__status{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.35rem;display:flex}.sa-backup__file{font-family:var(--fm);color:var(--muted);text-overflow:ellipsis;white-space:nowrap;margin-bottom:.35rem;font-size:.62rem;overflow:hidden}.sa-backup__actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.sa-counters{flex-direction:column;gap:.75rem;display:flex}.sa-counter-row{grid-template-columns:auto 1fr;align-items:center;gap:.75rem;display:grid}.sa-counter-row__meta{flex-direction:column;gap:.05rem;min-width:3.5rem;display:flex}.sa-counter-val{font-family:var(--fd);color:var(--text);font-size:1.05rem;font-weight:700;line-height:1.1}.sa-umami{flex-direction:column;gap:.65rem;display:flex}.sa-umami__open{font-size:.78rem;font-family:var(--fb);color:var(--accent);border-radius:var(--r-sm);transition:border-color var(--tf), background var(--tf);border:1px solid #4af0c44d;align-items:center;width:fit-content;padding:.3rem .75rem;text-decoration:none;display:inline-flex}.sa-umami__open:hover{border-color:var(--accent);background:var(--accent-dim)}[data-theme=light] .sa-umami__open{border-color:#00b3864d}[data-theme=light] .sa-umami__open:hover{border-color:var(--accent)}.sa-umami__form{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.sa-log__toggle{cursor:pointer;width:100%;color:var(--text-body);font-size:.78rem;font-family:var(--fb);text-align:left;transition:color var(--tf);background:0 0;border:none;justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.sa-log__toggle:hover{color:var(--accent)}.sa-log__toggle-icon{color:var(--muted);font-size:.62rem}.sa-log__toolbar{justify-content:space-between;align-items:center;padding:0 1.25rem .5rem;display:flex}.sys-input{background:var(--surface-3);border:1px solid var(--border);border-radius:var(--r-sm);min-width:0;color:var(--text);font-size:.78rem;font-family:var(--fm);transition:border-color var(--tf);flex:1;padding:.28rem .6rem}.sys-input:focus{border-color:var(--accent);outline:none}.sys-input::placeholder{color:var(--muted)}.sys-log-service-select{background:var(--surface-3);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text);font-size:.72rem;font-family:var(--fm);padding:.22rem .5rem}.sys-log-pre{background:var(--surface-3);border-top:1px solid var(--border);font-family:var(--fm);color:var(--text-body);white-space:pre-wrap;word-break:break-all;border-radius:0 0 var(--r-md) var(--r-md);max-height:300px;margin:0;padding:.75rem 1.25rem;font-size:.68rem;line-height:1.6;overflow-y:auto}.sa-status-ok{color:var(--accent);font-size:.78rem}.sa-status-err{color:var(--error);font-size:.78rem}.sa-muted{color:var(--muted);font-size:.7rem;font-family:var(--fm)}.sa-loading{color:var(--muted);font-size:.85rem;font-family:var(--fb);padding:1.5rem}.sa-error{color:var(--error);padding:1.5rem;font-size:.85rem}.sys-restart-banner{border-radius:var(--r-sm);font-size:.75rem;font-family:var(--fm);color:var(--warn);background:#f0a84a14;border:1px solid #f0a84a40;align-items:center;gap:.6rem;margin-bottom:1rem;padding:.6rem .9rem;display:flex}.sys-restart-banner__icon{flex-shrink:0;font-size:1rem}.sys-traffic-grid{grid-template-columns:3fr 2fr;align-items:start;gap:1rem;display:grid}.sys-traffic-card{background:var(--surface-3);border:1px solid var(--border);border-radius:var(--r-sm);padding:1rem}.sys-traffic-card--ai{background:linear-gradient(160deg, #4af0c40a 0%, var(--surface-3) 60%);border-color:#4af0c424}.sys-traffic-card__head{align-items:center;gap:.5rem;margin-bottom:.875rem;display:flex}.sys-traffic-card__title{font-size:.6rem;font-family:var(--fm);color:var(--muted);text-transform:uppercase;letter-spacing:.08em;flex:1}.sys-route-bars{flex-direction:column;gap:.8rem;display:flex}.sys-route-row{grid-template-columns:5.5rem 1fr 3.5rem 2.5rem;align-items:center;gap:.6rem;display:grid}.sys-route-name{font-family:var(--fm);color:var(--text-body);white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;overflow:hidden}.sys-route-bar-track{background:var(--surface-2);border-radius:4px;height:8px;overflow:hidden}.sys-route-bar-fill{border-radius:4px;height:100%;transition:width .55s cubic-bezier(.25,.46,.45,.94)}.sys-route-count{font-family:var(--fm);color:var(--text-body);text-align:right;font-size:.68rem}.sys-route-pct{font-family:var(--fm);color:var(--muted);text-align:right;font-size:.62rem}.sys-ai-badge{font-size:.58rem;font-family:var(--fm);color:var(--accent);letter-spacing:.05em;text-transform:uppercase;background:#4af0c41f;border:1px solid #4af0c44d;border-radius:4px;padding:.1rem .4rem}.sys-ai-total-row{align-items:baseline;gap:.5rem;margin-bottom:.4rem;display:flex}.sys-ai-total-val{font-family:var(--fd);color:var(--text);font-size:1.6rem;font-weight:700;line-height:1}.sys-ai-paths{flex-direction:column;gap:.4rem;margin-top:.75rem;display:flex}.sys-ai-path-row{grid-template-columns:8px 1fr auto;align-items:center;gap:.5rem;display:grid}.sys-ai-path-dot{background:var(--accent);opacity:.6;border-radius:50%;width:5px;height:5px}.sys-ai-path-name{font-family:var(--fm);color:var(--text-body);text-overflow:ellipsis;white-space:nowrap;font-size:.68rem;overflow:hidden}.sys-ai-path-count{font-family:var(--fm);color:var(--muted);font-size:.65rem}.sys-traffic-empty{color:var(--muted);font-size:.72rem;font-family:var(--fm);padding:1.25rem 0}.sys-traffic-empty--sm{padding:.6rem 0 0;font-size:.68rem}@media (width<=960px){.sa-layout,.sys-traffic-grid{grid-template-columns:1fr}}@media (width<=640px){.sa-page{padding:1rem 1rem 3rem}.sa-header{flex-direction:column;align-items:flex-start}.sa-service-row{grid-template-columns:12px 1fr auto}.sa-service-row__type,.sa-service-row__status{display:none}}@media (width<=768px){.dash-content{grid-template-columns:1fr;padding:1.25rem 1rem}.user-hero{padding:1.5rem 1rem 1.25rem}.user-hero__inner{gap:1rem}.user-avatar{width:50px;height:50px;font-size:1.1rem}.user-hero__name{font-size:clamp(1.3rem,5.5vw,2rem)}.dash-content-v2{grid-template-columns:1fr;gap:1rem;padding:1.25rem 1rem}.dash-col-left{order:1}.dash-col-right{order:2;gap:1rem}.dash-tabs{gap:.2rem;margin-bottom:1rem}.dash-tab{padding:.28rem .75rem;font-size:.8rem}.dash-pinned{gap:.75rem;padding:1rem}.dash-pinned__title{font-size:.92rem}.dash-empty{gap:.75rem;padding:1.5rem 1rem}.dash-empty__icon{font-size:1.6rem}.dash-reco{padding:.875rem 1rem}.dash-stat-card{padding:1rem}.dash-priv-card{padding:.875rem 1rem .75rem}.dash-new-rooms__grid{grid-template-columns:1fr}.priv-section,.admin-section{padding:0 1rem}}@media (width<=480px){.user-hero{padding:1.25rem .875rem 1rem}.user-avatar{width:44px;height:44px;font-size:1rem}.user-hero__inner{gap:.75rem}.user-hero__name{font-size:clamp(1.2rem,6vw,1.7rem)}.dash-nudge{gap:.6rem;padding:.6rem .875rem}.dash-nudge__sigil{width:18px;height:18px;font-size:.55rem}.dash-nudge__text{font-size:.8rem}.dash-content-v2{gap:.875rem;padding:1rem .875rem}.dash-tabs{scrollbar-width:none;flex-wrap:nowrap;padding-bottom:.375rem;overflow-x:auto}.dash-tabs::-webkit-scrollbar{display:none}.dash-tab{flex-shrink:0;padding:.25rem .65rem;font-size:.78rem}.dash-stat-card{gap:.75rem;padding:.875rem}.dash-stat-card__pills{grid-template-columns:1fr 1fr;gap:.5rem}.dash-stat-pill{min-width:0;padding:.5rem .6rem;overflow:hidden}.dash-stat-pill__value{text-overflow:ellipsis;white-space:nowrap;font-size:clamp(.85rem,5vw,1.1rem);overflow:hidden}.dash-stat-pill__label{white-space:nowrap;text-overflow:ellipsis;font-size:.62rem;overflow:hidden}.dash-pinned{gap:.625rem;padding:.875rem}.dash-empty{padding:1.25rem .875rem}.dash-reco{gap:.5rem;padding:.75rem .875rem}.dash-priv-card{padding:.75rem .875rem .625rem}.dash-new-rooms__grid{grid-template-columns:1fr;gap:.75rem}.dash-main{padding-bottom:2.5rem}}@media (width<=360px){.dash-content-v2{gap:.75rem;padding:.75rem}.dash-stat-card__pills{grid-template-columns:1fr 1fr;gap:.4rem}.dash-stat-pill{padding:.4rem .5rem}.dash-stat-pill__value{font-size:.9rem}.dash-stat-card__avatar{width:36px;height:36px;font-size:.8rem}}@media (width<=900px){.admin-table th,.admin-table td{padding:.5rem .65rem;font-size:.76rem}.admin-email{text-overflow:ellipsis;white-space:nowrap;max-width:120px;overflow:hidden}.role-select{padding:.18rem 1.2rem .18rem .4rem;font-size:.72rem}}@media (width<=1023px){.creator-rooms{grid-template-columns:repeat(2,1fr)}}@media (width<=639px){.creator-rooms{grid-template-columns:1fr}}#btn-login[title="Gérer mon compte"]{color:var(--accent);border-color:var(--accent);background:var(--accent-dim);text-overflow:ellipsis;white-space:nowrap;max-width:140px;font-weight:600;overflow:hidden}#btn-login[title="Gérer mon compte"]:hover{background:var(--accent);color:var(--bg)}.btn--logout{color:var(--error);border:1px solid var(--error);border-radius:var(--r-md);font-size:.875rem;font-family:var(--font-body);cursor:pointer;transition:background var(--tf), color var(--tf);background:0 0;padding:.4rem 1rem;font-weight:500}.btn--logout:hover{background:var(--error);color:#fff}:root{--text-body:#b8bccb;--warn-color:#f59e0b;--warn-bg-dark:#f59e0b14;--warn-bg-lite:#f59e0b12;--warn-border:#f59e0b59;--q-bg-dark:#4af0c40d;--q-bg-lite:#00b3860a}[data-theme=light]{--text-body:#444859}.page--cours{height:100dvh;padding:0;overflow:hidden}.page--cours header{flex-shrink:0}.page--cours main{flex-direction:column;flex:1;justify-content:flex-start;align-items:stretch;min-height:0;padding:0;display:flex;overflow:hidden}.page--cours footer{border-top:1px solid var(--border);transition:max-height .36s cubic-bezier(.4, 0, .2, 1), opacity .28s ease, padding .32s ease, border-color var(--transition-theme);max-height:160px;margin-top:auto;padding:clamp(14px,2vh,20px) 0;overflow:hidden}.page--cours .user-nav{z-index:55;pointer-events:none;visibility:visible;justify-content:center;width:auto;margin:0;padding:0 12px;transition:transform .34s cubic-bezier(.32,.72,0,1),opacity .26s,visibility;animation:none;display:flex;position:fixed;top:clamp(64px,8vh,74px);left:0;right:0}.page--cours .user-nav__inner{pointer-events:auto}.page--cours.nav-hidden .user-nav{opacity:0;visibility:hidden;pointer-events:none;transition:transform .34s cubic-bezier(.32,.72,0,1),opacity .26s,visibility 0s .34s;transform:translateY(-14px)}.page--cours.nav-hidden .user-nav__inner{pointer-events:none}@media (width<=768px){.page--cours .user-nav{display:none}}@media (prefers-reduced-motion:reduce){.page--cours .user-nav{transition:opacity .2s,visibility}.page--cours.nav-hidden .user-nav{transform:none}}.room-scrolltop{z-index:60;width:46px;height:46px;color:var(--course-color,var(--accent));border:1px solid color-mix(in srgb, var(--course-color,var(--accent)) 45%, var(--border));background:color-mix(in srgb, var(--course-color,var(--accent)) 14%, var(--surface));-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;opacity:0;pointer-events:none;border-radius:50%;place-items:center;transition:opacity .24s,transform .32s cubic-bezier(.34,1.56,.64,1),background .2s,box-shadow .24s,border-color .2s;display:grid;position:fixed;bottom:clamp(18px,3.5vh,32px);right:clamp(18px,3.5vw,32px);transform:translateY(14px)scale(.8);box-shadow:0 8px 24px #00000061}.room-scrolltop.is-visible{opacity:1;pointer-events:auto;transform:translateY(0)scale(1)}.room-scrolltop:hover{background:color-mix(in srgb, var(--course-color,var(--accent)) 24%, var(--surface));border-color:var(--course-color,var(--accent));box-shadow:0 12px 30px #00000073, 0 0 0 4px color-mix(in srgb, var(--course-color,var(--accent)) 16%, transparent);transform:translateY(-3px)scale(1.06)}.room-scrolltop:active{transform:translateY(0)scale(.95)}.room-scrolltop:focus-visible{outline:2px solid var(--course-color,var(--accent));outline-offset:3px}.room-scrolltop svg{display:block}@media (prefers-reduced-motion:reduce){.room-scrolltop{transition:opacity .2s;transform:none}.room-scrolltop.is-visible,.room-scrolltop:hover{transform:none}}.cours-header-zone{border-bottom:1px solid var(--border);background:radial-gradient(120% 135% at 0% -12%, color-mix(in srgb, var(--course-color,var(--accent)) 11%, transparent), transparent 58%);flex-shrink:0;grid-template-columns:1fr;gap:clamp(12px,2vw,20px);max-height:600px;margin-bottom:0;padding:clamp(26px,4.5vh,48px) clamp(16px,4vw,44px) clamp(20px,3vh,32px);transition:max-height .38s cubic-bezier(.4,0,.2,1),padding .38s cubic-bezier(.4,0,.2,1),border-color .22s ease-in,border-width .22s ease-in;display:grid;position:relative;overflow:hidden}.cours-header-zone.is-collapsed{border-bottom-width:0;border-bottom-color:#0000;max-height:0;padding:0}.cours-hero__eyebrow,.cours-hero__subtitle{opacity:1;transition:opacity .22s ease-out .28s,transform .22s ease-out .28s;transform:translateY(0)}.cours-header-zone.is-collapsed .cours-hero__eyebrow,.cours-header-zone.is-collapsed .cours-hero__subtitle{opacity:0;pointer-events:none;transition:opacity .12s ease-in,transform .12s ease-in;transform:translateY(-8px)}.cours-header-zone:before{content:"";background:linear-gradient(90deg, var(--course-color,var(--accent)), color-mix(in srgb, var(--course-color,var(--accent)) 30%, transparent) 70%, transparent);height:3px;box-shadow:0 0 16px color-mix(in srgb, var(--course-color,var(--accent)) 45%, transparent);position:absolute;top:0;left:0;right:0}@media (width>=768px){.cours-header-zone{grid-template-columns:1fr}}.cours-hero{--course-color:var(--accent);flex-direction:column;gap:10px;display:flex}@media (width>=640px){.cours-hero:has(.cours-hero__audio){grid-template-columns:1fr minmax(220px,300px);grid-template-areas:"eyebrow eyebrow""title audio""sub audio";align-items:start;gap:10px 40px;display:grid}.cours-hero:has(.cours-hero__audio) .cours-hero__eyebrow{grid-area:eyebrow}.cours-hero:has(.cours-hero__audio) .cours-hero__title{grid-area:title;align-self:end}.cours-hero:has(.cours-hero__audio) .cours-hero__subtitle{grid-area:sub}.cours-hero:has(.cours-hero__audio) .cours-hero__audio{grid-area:audio;align-self:center}}.cours-hero__eyebrow{align-items:center;gap:12px;display:flex}.cours-hero__rule{background:linear-gradient(90deg, var(--border), transparent);flex:1;height:1px}.cours-hero__spark{background:var(--course-color,var(--accent));width:9px;height:9px;box-shadow:0 0 0 3px color-mix(in srgb, var(--course-color,var(--accent)) 14%, transparent), 0 0 14px color-mix(in srgb, var(--course-color,var(--accent)) 60%, transparent);border-radius:2px;flex-shrink:0;transform:rotate(45deg)}.cours-hero__pct{font-family:var(--font-mono,ui-monospace, monospace);letter-spacing:.04em;white-space:nowrap;color:var(--course-color,var(--accent));flex-shrink:0;font-size:.72rem;font-weight:700}.cours-hero__pct.is-complete{background:color-mix(in srgb, var(--course-color,var(--accent)) 16%, transparent);border:1px solid color-mix(in srgb, var(--course-color,var(--accent)) 38%, transparent);border-radius:999px;padding:2px 9px}.cours-hero__audience{letter-spacing:.12em;text-transform:uppercase;color:var(--course-color,var(--accent));border:1px solid color-mix(in srgb, var(--course-color,var(--accent)) 35%, transparent);white-space:nowrap;border-radius:999px;flex-shrink:0;align-items:center;gap:6px;padding:3px 10px;font-size:.68rem;font-weight:700;display:inline-flex}.cours-hero__title{font-family:var(--font-display);letter-spacing:-.032em;color:var(--text);text-wrap:balance;margin:0;font-size:clamp(1.6rem,4.2vw,2.8rem);font-weight:800;line-height:1.06}.cours-hero__subtitle{color:var(--text-body);max-width:54ch;font-size:clamp(1.05rem,2.2vw,1.25rem);font-weight:400;line-height:1.65}.cours-hero__audio{margin-top:4px}.cours-hero__audio .audio-player{width:100%;max-width:300px}.selector-group{flex-direction:column;gap:8px;display:flex}.selector-label{letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-size:.68rem;font-weight:600}.selector-tabs{flex-wrap:wrap;gap:5px;display:flex}.sel-tab{font-family:var(--font-body);border-radius:var(--radius-sm);border:1.5px solid var(--border);color:var(--text-body);cursor:pointer;white-space:nowrap;transition:background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast), box-shadow var(--transition-fast);background:0 0;padding:6px 14px;font-size:.8rem;font-weight:500}.sel-tab:hover{border-color:var(--border-hover);color:var(--text);background:var(--surface-hover)}.sel-tab:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.sel-tab.is-active{background:var(--accent);border-color:var(--accent);color:#08090c;box-shadow:var(--glow-btn);font-weight:600}.cours-hero__progress{background:color-mix(in srgb, var(--course-color,var(--accent)) 16%, var(--border));border-radius:999px;height:5px;margin-top:6px;position:relative;overflow:hidden}.cours-hero__progress-bar{inset-block:0;background:linear-gradient(90deg, var(--course-color,var(--accent)), color-mix(in srgb, var(--course-color,var(--accent)) 55%, #fff 45%));max-width:100%;height:100%;box-shadow:0 0 12px color-mix(in srgb, var(--course-color,var(--accent)) 55%, transparent);border-radius:999px;transition:width .5s cubic-bezier(.25,.46,.45,.94);position:absolute;left:0}@media (prefers-reduced-motion:no-preference){.cours-hero__eyebrow{animation:.55s cubic-bezier(.2,.7,.2,1) backwards heroReveal}.cours-hero__title{animation:.55s cubic-bezier(.2,.7,.2,1) 70ms backwards heroReveal}.cours-hero__subtitle{animation:.55s cubic-bezier(.2,.7,.2,1) .14s backwards heroReveal}.cours-hero__progress{animation:.55s cubic-bezier(.2,.7,.2,1) .2s backwards heroReveal}}@keyframes heroReveal{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.cours-body{flex-direction:column;gap:8px;animation:.35s cubic-bezier(.4,0,.2,1) both content-in;display:flex}@keyframes content-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.cours-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);transition:background var(--transition-theme), border-color var(--transition-theme), box-shadow var(--transition-fast);overflow:hidden}.cours-section.is-open{border-color:color-mix(in srgb, var(--course-color,var(--accent)) 35%, var(--border));box-shadow:0 0 0 1px color-mix(in srgb, var(--course-color,var(--accent)) 12%, transparent), 0 4px 20px #00000014}.cours-section__heading{cursor:pointer;text-align:left;width:100%;font-family:var(--font-display);color:var(--text);letter-spacing:-.01em;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;align-items:center;gap:10px;padding:14px 18px;font-size:clamp(.95rem,2vw,1.1rem);font-weight:700;display:flex}.cours-section__heading:hover{background:var(--surface-hover)}.cours-section__heading:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.cours-section__heading:before{content:"";background:var(--accent);width:3px;height:1.1em;transition:background var(--transition-fast);border-radius:2px;flex-shrink:0;display:inline-block}.cours-section.is-open .cours-section__heading:before{background:var(--course-color,var(--accent))}.cours-section__heading-text{flex:1}.cours-section__status{transition:color var(--transition-fast);flex-shrink:0;font-size:.8rem;font-weight:700;line-height:1}.cours-section__status--pending{color:var(--muted);opacity:.5}.cours-section__status--started{color:#f59e0b}.cours-section__status--complete{color:var(--course-color,var(--accent))}.cours-section__arrow{width:20px;height:20px;color:var(--muted);transition:transform var(--transition-normal), color var(--transition-fast);flex-shrink:0;place-items:center;display:grid}.cours-section__arrow svg{width:14px;height:14px}.cours-section.is-open .cours-section__arrow{color:var(--course-color,var(--accent));transform:rotate(180deg)}.cours-section__body{grid-template-rows:0fr;transition:grid-template-rows .38s cubic-bezier(.25,.46,.45,.94);display:grid}.cours-section.is-open .cours-section__body{grid-template-rows:1fr}.cours-section__inner{opacity:0;flex-direction:column;gap:14px;padding:0 18px;transition:opacity .24s .16s;display:flex;overflow:hidden}.cours-section.is-open .cours-section__inner{opacity:1;padding-bottom:18px}.cours-preview{-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--border) transparent;gap:10px;padding-bottom:6px;display:flex;overflow-x:auto}.cours-preview::-webkit-scrollbar{height:3px}.cours-preview::-webkit-scrollbar-track{background:0 0}.cours-preview::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}.cours-preview__chip{border:1.5px solid var(--border);border-radius:var(--radius-md);min-width:180px;max-width:240px;color:var(--text-body);font-family:var(--font-body);cursor:pointer;white-space:normal;text-align:left;transition:border-color var(--transition-fast), background var(--transition-fast), color var(--transition-fast), box-shadow var(--transition-fast);background:0 0;flex-direction:column;flex-shrink:0;gap:6px;padding:10px 14px 10px 10px;display:inline-flex}.cours-preview__chip:hover{border-color:var(--accent);background:var(--accent-dim);color:var(--text);box-shadow:var(--glow-card)}.cours-preview__chip:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.cours-preview__top{align-items:center;gap:8px;display:flex}.cours-preview__num{background:var(--accent);color:#08090c;border-radius:6px;flex-shrink:0;place-items:center;width:26px;height:26px;font-size:.72rem;font-weight:800;display:grid}.cours-preview__title{color:var(--text);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.8rem;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.cours-preview__desc{color:var(--muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.72rem;line-height:1.45;display:-webkit-box;overflow:hidden}.cours-preview-bar{z-index:45;background:var(--surface);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);-webkit-overflow-scrolling:touch;scrollbar-width:none;opacity:0;pointer-events:none;box-shadow:none;transition:opacity .18s ease, box-shadow .18s ease, background var(--transition-theme), border-color var(--transition-theme);align-items:center;gap:8px;padding:8px clamp(16px,4vw,56px);display:flex;position:fixed;top:0;left:0;right:0;overflow-x:auto}.cours-preview-bar.is-visible{opacity:1;pointer-events:all;box-shadow:0 4px 16px #0000001f}.cours-preview-bar .cours-preview__chip{white-space:nowrap;border-radius:999px;flex-direction:row;align-items:center;gap:8px;min-width:auto;max-width:none;padding:6px 16px 6px 8px;font-size:.82rem}.cours-preview-bar .cours-preview__desc{display:none}.cours-preview-bar .cours-preview__top{align-items:center;gap:8px;display:flex}.cours-preview-bar .cours-preview__num{border-radius:50%;width:40px;height:40px;font-size:.7rem}.cours-preview-bar .cours-preview__title{-webkit-line-clamp:1;-webkit-box-orient:vertical;max-width:200px;font-size:.9rem;font-weight:600;display:-webkit-box;overflow:hidden}@media (width<=640px){.cours-preview-bar{gap:5px;padding:5px clamp(10px,3vw,16px)}.cours-preview-bar .cours-preview__chip{gap:5px;padding:4px 10px 4px 5px;font-size:.72rem}.cours-preview-bar .cours-preview__num{width:22px;height:22px;font-size:.6rem}.cours-preview-bar .cours-preview__title{max-width:120px;font-size:.82rem}}.cours-steps-list{flex-direction:column;gap:8px;display:flex}.cours-step{background:var(--surface-2,#13151c);border:1px solid var(--border);border-radius:var(--radius-md);transition:border-color var(--transition-fast), background var(--transition-theme);overflow:hidden}.cours-step[open]{border-color:var(--border-hover)}.cours-step__summary{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast);grid-template-columns:34px 1fr 22px;align-items:center;gap:12px;padding:12px 16px;list-style:none;display:grid}.cours-step__summary::-webkit-details-marker{display:none}.cours-step__summary::marker{display:none}.cours-step__summary:hover{background:var(--surface-hover)}.cours-step__num{background:var(--accent);color:#08090c;width:34px;height:34px;font-family:var(--font-display);box-shadow:var(--glow-btn);border-radius:8px;flex-shrink:0;place-items:center;font-size:.85rem;font-weight:800;display:grid}.cours-step__meta{flex-wrap:wrap;align-items:baseline;gap:7px;min-width:0;display:flex}.cours-step__keyword{letter-spacing:.1em;text-transform:uppercase;color:var(--accent);background:var(--accent-dim);border-radius:999px;flex-shrink:0;padding:2px 7px;font-size:.6rem;font-weight:700}.cours-step__title{font-family:var(--font-display);color:var(--text);min-width:0;font-size:.93rem;font-weight:700;line-height:1.3}.cours-step__arrow{width:22px;height:22px;color:var(--muted);transition:transform var(--transition-normal), color var(--transition-fast);flex-shrink:0;place-items:center;display:grid}.cours-step__arrow svg{width:14px;height:14px}.cours-step[open] .cours-step__arrow{color:var(--accent);transform:rotate(180deg)}.cours-step__body{grid-template-rows:0fr;transition:grid-template-rows .32s cubic-bezier(.25,.46,.45,.94);display:grid}.cours-step[open] .cours-step__body{grid-template-rows:1fr}.cours-step__inner{opacity:0;flex-direction:column;gap:10px;padding:0 16px;transition:opacity .2s .14s;display:flex;overflow:hidden}.cours-step[open] .cours-step__inner{opacity:1;padding-bottom:14px}.cours-step__desc{color:var(--text-body);font-size:.84rem;line-height:1.75}.cours-step__action{background:var(--accent-dim);border:1px solid color-mix(in srgb, var(--accent) 20%, transparent);border-radius:var(--radius-sm);color:var(--text);padding:9px 12px 9px 20px;font-size:.82rem;line-height:1.6;position:relative}.cours-step__action:before{content:"▶";color:var(--accent);opacity:.85;font-size:.5rem;position:absolute;top:11px;left:7px}.cours-block--paragraph{color:var(--text-body);font-size:clamp(.88rem,1.6vw,.97rem);line-height:1.8}.cours-block--tagline{font-family:var(--font-display);color:var(--accent);border-left:3px solid var(--accent);filter:var(--glow-accent);padding:10px 0 10px 14px;font-size:clamp(1rem,2.2vw,1.2rem);font-weight:700;line-height:1.45}.cours-block--warning{background:var(--warn-bg-dark);border:1px solid var(--warn-border);border-left:3px solid var(--warn-color);border-radius:var(--radius-sm);color:var(--text-body);align-items:flex-start;gap:12px;padding:12px 14px;font-size:clamp(.84rem,1.5vw,.92rem);line-height:1.7;display:flex}[data-theme=light] .cours-block--warning{background:var(--warn-bg-lite)}.cours-block--warning__icon{flex-shrink:0;font-size:1rem;line-height:1.65}.cours-block--spoiler{border:1px solid var(--border);border-radius:var(--radius-sm);font-size:clamp(.84rem,1.5vw,.92rem);overflow:hidden}.cours-block--spoiler summary{cursor:pointer;color:var(--muted);-webkit-user-select:none;user-select:none;transition:background var(--transition-fast), color var(--transition-fast);align-items:center;gap:8px;padding:10px 14px;font-size:.8rem;font-weight:600;list-style:none;display:flex}.cours-block--spoiler summary::-webkit-details-marker{display:none}.cours-block--spoiler summary::marker{display:none}.cours-block--spoiler summary:hover{background:var(--surface-hover);color:var(--text)}.cours-block--spoiler summary:before{content:"👁";opacity:.7;font-size:.85rem}.cours-block--spoiler__body{grid-template-rows:0fr;transition:grid-template-rows .28s cubic-bezier(.4,0,.2,1);display:grid}.cours-block--spoiler[open] .cours-block--spoiler__body{grid-template-rows:1fr}.cours-block--spoiler__inner{color:var(--text-body);padding:0 14px;line-height:1.75;overflow:hidden}.cours-block--spoiler[open] .cours-block--spoiler__inner{padding-bottom:14px}.cours-block--link{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);transition:background var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);cursor:pointer;align-items:center;gap:12px;padding:12px 16px;font-size:.88rem;font-weight:500;text-decoration:none;display:flex}.cours-block--link:hover{border-color:var(--border-hover);background:var(--surface-hover);box-shadow:var(--glow-card);transform:translate(3px)}.cours-block--link:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.cours-block--link__icon{flex-shrink:0;font-size:1rem}.cours-block--link__text{flex:1;line-height:1.4}.cours-block--link__label{letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:1px;font-size:.7rem;font-weight:600;display:block}.cours-block--link__arrow{color:var(--muted);transition:color var(--transition-fast);flex-shrink:0}.cours-block--link:hover .cours-block--link__arrow{color:var(--accent)}.cours-block--image{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);transition:border-color var(--transition-fast);flex-direction:column;display:flex;overflow:hidden}.cours-block--image:hover{border-color:var(--border-hover)}.cours-block--image img{object-fit:cover;width:100%;height:auto;max-height:380px;display:block}.cours-block--image figcaption{color:var(--muted);border-top:1px solid var(--border);background:var(--surface);padding:8px 14px;font-size:.78rem;font-style:italic;line-height:1.5}.cours-block--question{background:var(--q-bg-dark);border:1px solid var(--accent-dim);border-left:3px solid var(--accent);border-radius:var(--radius-md);flex-direction:column;gap:12px;padding:16px;display:flex}[data-theme=light] .cours-block--question{background:var(--q-bg-lite)}.cours-block--question__text{font-family:var(--font-display);color:var(--text);font-size:.95rem;font-weight:700;line-height:1.4}.cours-block--question__input{background:var(--input-bg);border:1.5px solid var(--input-border);border-radius:var(--radius-sm);width:100%;font-family:var(--font-body);color:var(--text);resize:vertical;min-height:72px;max-height:200px;transition:border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-theme);outline:none;padding:10px 14px;font-size:.9rem;line-height:1.6}.cours-block--question__input::placeholder{color:var(--muted2)}.cours-block--question__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);background:var(--surface)}.cours-block--question__footer{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.cours-block--question__submit{font-family:var(--font-body);border-radius:var(--radius-sm);background:var(--accent);color:#08090c;cursor:pointer;box-shadow:var(--glow-btn);transition:filter var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast), opacity var(--transition-fast);border:none;padding:8px 20px;font-size:.85rem;font-weight:600}.cours-block--question__submit:hover:not(:disabled){filter:brightness(1.08);box-shadow:var(--glow-btn-h);transform:translateY(-1px)}.cours-block--question__submit:disabled{opacity:.55;cursor:not-allowed;filter:none;transform:none}.cours-block--question__feedback{color:var(--accent);font-size:.82rem;font-weight:500;display:none}.cours-block--question__feedback.is-visible{display:block}.q-options{flex-direction:column;gap:8px;display:flex}.q-option-label{border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-body);transition:border-color var(--transition-fast), background var(--transition-fast);align-items:center;gap:10px;padding:10px 12px;font-size:.88rem;display:flex}.q-option-label:hover{border-color:var(--accent);background:var(--accent-dim);color:var(--text)}.q-option-label input[type=checkbox],.q-option-label input[type=radio]{appearance:none;border:2px solid var(--input-border);background:var(--input-bg);width:18px;height:18px;transition:border-color var(--transition-fast), background var(--transition-fast);cursor:pointer;border-radius:4px;flex-shrink:0;position:relative}.q-option-label input[type=radio]{border-radius:50%}.q-option-label input:checked{border-color:var(--accent);background:var(--accent)}.q-option-label input[type=checkbox]:checked:after{content:"";background:url("data:image/svg+xml,%3Csvg viewBox='0 0 10 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 4l3 3 5-6' stroke='%2308090c' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") 50%/contain no-repeat;position:absolute;inset:2px}.q-option-label input[type=radio]:checked:after{content:"";background:#08090c;border-radius:50%;position:absolute;inset:3px}.q-option-label input:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.q-option-label:has(input:checked){border-color:var(--accent);background:var(--accent-dim);color:var(--text)}.q-image-grid{grid-template-columns:repeat(auto-fill,minmax(min(100%,140px),1fr));gap:10px;display:grid}.q-image-option{border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);background:var(--surface);overflow:hidden}.q-image-option:hover{border-color:var(--border-hover)}.q-image-option.is-selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-dim)}.q-image-option:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.q-image-option img{object-fit:cover;background:var(--surface);width:100%;height:110px;display:block}.q-image-option__label{color:var(--text-body);text-align:center;background:var(--surface);border-top:1px solid var(--border);padding:6px 8px;font-size:.72rem;line-height:1.3}.q-image-option.is-selected .q-image-option__label{color:var(--accent);font-weight:600}.md-content p{font-size:inherit;color:inherit;line-height:inherit;margin:0 0 .6em}.md-content p:last-child{margin-bottom:0}.md-content h1,.md-content h2,.md-content h3,.md-content h4,.md-content h5,.md-content h6{font-family:var(--font-display);color:var(--text);letter-spacing:-.01em;margin:.9em 0 .4em;font-weight:700;line-height:1.3}.md-content h1{font-size:clamp(1.2rem,2.5vw,1.5rem)}.md-content h2{font-size:clamp(1rem,2vw,1.2rem)}.md-content h3{font-size:clamp(.9rem,1.8vw,1.05rem)}.md-content h1:first-child,.md-content h2:first-child,.md-content h3:first-child{margin-top:0}.md-content strong{color:var(--text);font-weight:700}.md-content em{font-style:italic}.md-content u{text-underline-offset:2px;text-decoration:underline}.md-content del{opacity:.65;text-decoration:line-through}.md-content a{color:var(--accent);transition:border-color var(--transition-fast), opacity var(--transition-fast);border-bottom:1px solid #0000;font-weight:500;text-decoration:none}.md-content a:hover{border-bottom-color:var(--accent)}.md-content a:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}.md-content ul,.md-content ol{flex-direction:column;gap:3px;margin:.4em 0 .6em;padding-left:1.4em;display:flex}.md-content ul{list-style:none}.md-content ul li{padding-left:.2em;position:relative}.md-content ul li:before{content:"";background:var(--accent);opacity:.8;border-radius:50%;width:5px;height:5px;position:absolute;top:.55em;left:-1em}.md-content ol{list-style:decimal}.md-content li{font-size:inherit;color:inherit;line-height:1.7}.md-content li:last-child{margin-bottom:0}.md-content code:not(pre>code){background:color-mix(in srgb, var(--accent) 8%, var(--surface));border:1px solid var(--border);color:var(--accent);word-break:break-word;border-radius:4px;padding:1px 5px;font-family:Fira Code,Cascadia Code,Consolas,monospace;font-size:.82em}.md-content pre{background:var(--surface-2,#13151c);border:1px solid var(--border);border-radius:var(--radius-md);scrollbar-width:thin;scrollbar-color:var(--border) transparent;margin:.6em 0;padding:14px 16px;overflow-x:auto}[data-theme=light] .md-content pre{background:#f0f1f5}.md-content pre code{color:var(--text);background:0 0;border:none;padding:0;font-family:Fira Code,Cascadia Code,Consolas,monospace;font-size:.83rem;line-height:1.6}.md-content blockquote{border-left:3px solid var(--accent);background:var(--accent-dim);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--text-body);margin:.6em 0;padding:8px 14px;font-style:italic}.md-content blockquote p{color:inherit;margin:0}.md-content hr{border:none;border-top:1px solid var(--border);margin:1em 0}.md-content table{border-collapse:collapse;width:100%;margin:.6em 0;font-size:.84rem;display:block;overflow-x:auto}.md-content thead th{background:var(--surface);font-family:var(--font-display);color:var(--text);border:1px solid var(--border);text-align:left;padding:8px 12px;font-weight:700}.md-content td{border:1px solid var(--border);color:var(--text-body);padding:7px 12px}.md-content tr:nth-child(2n) td{background:var(--surface)}.hljs-comment,.hljs-quote{color:#6c7a9c;font-style:italic}[data-theme=light] .hljs-comment,[data-theme=light] .hljs-quote{color:#8a95b0}.hljs-keyword,.hljs-selector-tag,.hljs-literal,.hljs-section,.hljs-link{color:var(--accent);font-weight:600}.hljs-string,.hljs-title.hljs-class_ .hljs-string,.hljs-attr,.hljs-attribute{color:#f9c859}[data-theme=light] .hljs-string,[data-theme=light] .hljs-attr{color:#b07e00}.hljs-number,.hljs-bullet{color:#ff9d5c}[data-theme=light] .hljs-number,[data-theme=light] .hljs-bullet{color:#c76b00}.hljs-title,.hljs-title.function_,.hljs-function .hljs-title{color:#60c5f5}[data-theme=light] .hljs-title,[data-theme=light] .hljs-title.function_{color:#07a}.hljs-class .hljs-title,.hljs-title.class_,.hljs-type{color:#f0a04a}[data-theme=light] .hljs-type{color:#c06000}.hljs-built_in,.hljs-builtin-name{color:#a78bfa}[data-theme=light] .hljs-built_in{color:#6d28d9}.hljs-variable,.hljs-params{color:var(--text)}.hljs-operator,.hljs-punctuation{color:var(--muted)}.hljs-meta,.hljs-meta .hljs-string{color:#a0aec0;font-style:italic}.hljs-regexp{color:#f9c859}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}.hljs-deletion{background:#ff6b6b26}.hljs-addition{background:#4af0c41f}.code-test-block{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-2,#13151c);flex-direction:column;font-family:Fira Code,Cascadia Code,Consolas,monospace;display:flex;overflow:hidden}[data-theme=light] .code-test-block{background:#f0f1f5}.code-test-block__bar{background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:10px;padding:8px 14px;display:flex}.code-test-block__label{font-family:var(--font-display);color:var(--text);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:.8rem;font-weight:700;overflow:hidden}.code-test-block__lang{font-family:var(--font-body);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2,#13151c);color:var(--muted);cursor:pointer;transition:border-color var(--transition-fast), color var(--transition-fast);outline:none;padding:4px 10px;font-size:.75rem;font-weight:500}[data-theme=light] .code-test-block__lang{background:#e8e9ef}.code-test-block__lang:focus{border-color:var(--accent);color:var(--text)}.code-test-block__run{font-family:var(--font-body);border-radius:var(--radius-sm);background:var(--accent);color:#08090c;cursor:pointer;box-shadow:var(--glow-btn);white-space:nowrap;transition:filter var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);border:none;flex-shrink:0;align-items:center;gap:6px;padding:5px 14px;font-size:.78rem;font-weight:600;display:flex}.code-test-block__run:hover:not(:disabled){filter:brightness(1.1);box-shadow:var(--glow-btn-h);transform:translateY(-1px)}.code-test-block__run:active:not(:disabled){transform:translateY(0)}.code-test-block__run[data-state=pending]{background:var(--surface);color:var(--muted);border:1px solid var(--border);box-shadow:none;cursor:default}.code-test-block__main{flex-direction:column;flex:1;min-height:0;display:flex}@media (width>=768px){.code-test-block__main{flex-direction:row;align-items:stretch}}.code-test-block__editor{scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex:1;min-width:0;max-height:450px;display:flex;overflow:hidden auto}.code-test-block__lines{background:var(--surface);border-right:1px solid var(--border);color:var(--muted);text-align:right;-webkit-user-select:none;user-select:none;z-index:1;white-space:pre;flex-shrink:0;align-self:flex-start;min-width:36px;padding:14px 10px;font-size:.82rem;line-height:1.6;position:sticky;left:0;overflow-y:hidden}.code-test-block__code-wrapper{flex:1;position:relative;overflow:hidden}.code-test-block__highlight{width:100%;height:100%;color:var(--text);tab-size:4;white-space:pre;pointer-events:none;background:0 0;margin:0;padding:14px;font-family:inherit;font-size:.82rem;line-height:1.6;position:absolute;top:0;left:0;overflow:hidden}.code-test-block__highlight code{font-family:inherit}.code-test-block__code{z-index:1;resize:none;color:var(--text);caret-color:var(--accent);tab-size:4;white-space:pre;background:0 0;border:none;outline:none;flex:1;min-width:max-content;min-height:80px;padding:14px;font-family:inherit;font-size:.82rem;line-height:1.6;position:relative;overflow:auto hidden}.code-test-block__code::selection{color:var(--text);background:#4af0c433}[data-theme=light] .code-test-block__code::selection{color:var(--text);background:#00b38626}.code-test-block__output{min-height:52px;max-height:200px;color:var(--muted);scrollbar-width:thin;scrollbar-color:var(--border) transparent;border-top:1px solid var(--border);padding:12px 16px;font-size:.8rem;line-height:1.55;overflow-y:auto}@media (width>=768px){.code-test-block__output{border-top:none;border-left:1px solid var(--border);flex-shrink:0;width:clamp(300px,38%,460px);max-height:none;overflow-y:auto}}.code-test-block__output:empty:before{content:"La sortie du programme s'affichera ici…";opacity:.5;font-style:italic}.code-test-block__output .out-success{color:var(--accent)}.code-test-block__output .out-error{color:var(--error)}.code-test-block__output .out-info{color:var(--muted)}.chat-ai-block{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);transition:background var(--transition-theme), border-color var(--transition-fast);flex-direction:column;display:flex;overflow:hidden}.chat-ai-block__header{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:10px;padding:10px 16px;display:flex}.chat-ai-block__avatar{background:var(--accent-dim);border:1.5px solid var(--accent);border-radius:50%;flex-shrink:0;place-items:center;width:32px;height:32px;font-size:1rem;display:grid}.chat-ai-block__title{font-family:var(--font-display);color:var(--text);font-size:.88rem;font-weight:700}.chat-ai-block__status{color:var(--muted);align-items:center;gap:5px;font-size:.72rem;display:flex}.chat-ai-block__status:before{content:"";background:#94a3b8;border-radius:50%;width:7px;height:7px;display:inline-block}.chat-ai-block__status.is-typing:before{background:var(--accent);animation:1s ease-in-out infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.3}}.chat-ai-block__messages{scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex-direction:column;flex:1;gap:12px;min-height:180px;max-height:380px;padding:14px 16px;display:flex;overflow-y:auto}.chat-msg{gap:10px;max-width:88%;display:flex}.chat-msg--ai{align-self:flex-start}.chat-msg--user{flex-direction:row-reverse;align-self:flex-end}.chat-msg--ai .chat-msg__bubble{background:var(--surface-2,#13151c);border:1px solid var(--border);color:var(--text-body);border-radius:4px 12px 12px}[data-theme=light] .chat-msg--ai .chat-msg__bubble{background:#eef0f6}.chat-msg--user .chat-msg__bubble{background:var(--accent-dim);border:1px solid color-mix(in srgb, var(--accent) 30%, transparent);color:var(--text);border-radius:12px 4px 12px 12px}.chat-msg__bubble{padding:9px 13px;font-size:.85rem;line-height:1.6}.chat-msg__bubble .md-content p{font-size:inherit;color:inherit;margin-bottom:.3em}.chat-msg__bubble .md-content p:last-child{margin-bottom:0}.chat-msg__icon{border-radius:50%;flex-shrink:0;place-items:center;width:28px;height:28px;margin-top:2px;font-size:.85rem;display:grid}.chat-msg--ai .chat-msg__icon{background:var(--accent-dim);border:1px solid var(--accent)}.chat-msg--user .chat-msg__icon{background:var(--surface);border:1px solid var(--border)}.chat-typing{background:var(--surface-2,#13151c);border:1px solid var(--border);border-radius:4px 12px 12px;align-self:flex-start;align-items:center;gap:4px;padding:10px 14px;display:flex}[data-theme=light] .chat-typing{background:#eef0f6}.chat-typing span{background:var(--muted);border-radius:50%;width:7px;height:7px;animation:1.2s ease-in-out infinite typing-bounce}.chat-typing span:nth-child(2){animation-delay:.2s}.chat-typing span:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,80%,to{opacity:.4;transform:translateY(0)}40%{opacity:1;transform:translateY(-5px)}}.chat-ai-block__input-area{background:var(--surface);border-top:1px solid var(--border);flex-shrink:0;gap:8px;padding:10px 14px;display:flex}.chat-ai-block__input{background:var(--input-bg);border:1.5px solid var(--input-border);border-radius:var(--radius-sm);font-family:var(--font-body);color:var(--text);resize:none;min-height:40px;max-height:120px;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;flex:1;padding:9px 13px;font-size:.88rem;line-height:1.5;overflow-y:auto}.chat-ai-block__input::placeholder{color:var(--muted2)}.chat-ai-block__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.chat-ai-block__send{border-radius:var(--radius-sm);background:var(--accent);cursor:pointer;width:38px;height:38px;box-shadow:var(--glow-btn);transition:filter var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);border:none;flex-shrink:0;align-self:flex-end;place-items:center;display:grid}.chat-ai-block__send:hover:not(:disabled){filter:brightness(1.1);box-shadow:var(--glow-btn-h);transform:translateY(-1px)}.chat-ai-block__send:disabled{opacity:.5;cursor:not-allowed;transform:none}.chat-ai-block__send svg{width:16px;height:16px}.chat-empty{color:var(--muted);text-align:center;flex-direction:column;align-items:center;gap:8px;padding:24px 16px;font-size:.82rem;display:flex}.chat-empty__icon{opacity:.4;font-size:2rem}.cours-skeleton{flex-direction:column;gap:12px;padding:8px 0;display:flex}.skel-line{background:var(--border);border-radius:6px;animation:1.4s ease-in-out infinite skel-pulse}@keyframes skel-pulse{0%,to{opacity:.45}50%{opacity:.85}}.chat-ai-block__cta{background:var(--surface,#1a1b1e);border-top:1px solid var(--border,#ffffff14);flex-direction:column;gap:10px;padding:12px 16px;display:flex}.chat-ai-block__cta-text{color:var(--muted2,#888);margin:0;font-size:.875rem;line-height:1.4}.chat-ai-block__cta-btn{background:var(--accent,#a78bfa);color:#fff;border-radius:6px;align-self:flex-start;padding:8px 16px;font-size:.875rem;font-weight:600;text-decoration:none;transition:opacity .15s}.chat-ai-block__cta-btn:hover{opacity:.85}.cours-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:clamp(40px,8vh,80px) 20px;display:flex}.cours-empty__icon{opacity:.5;font-size:2.5rem}.cours-empty__title{font-family:var(--font-display);color:var(--text);font-size:1rem;font-weight:700}.cours-empty__desc{color:var(--text-body);max-width:38ch;font-size:.85rem;line-height:1.65}.cours-empty__code{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--accent);padding:3px 10px;font-family:monospace;font-size:.76rem}html{scroll-padding-top:114px}html:has(.page--cours .user-nav){scroll-padding-top:calc(56px + var(--user-nav-h,57px) + 46px + 12px)}.cours-step[id]{scroll-margin-top:114px}.page--cours:has(.user-nav) .cours-step[id]{scroll-margin-top:calc(56px + var(--user-nav-h,57px) + 46px + 12px)}@media (width<=640px){.sel-tab{padding:5px 11px;font-size:.76rem}.cours-section__heading{padding:10px}.cours-section__inner{gap:10px;padding:0 8px 10px}.cours-step__summary{gap:8px;padding:10px}.cours-step__inner{gap:8px;padding:0 8px}.cours-step[open] .cours-step__inner{padding-bottom:10px}.cours-preview__chip{min-width:140px;max-width:185px}.code-test-block__output{max-height:140px}}@media (width<=400px){.cours-section__inner,.cours-step__inner{padding:0 6px}.cours-section__heading{padding:9px 8px;font-size:.9rem}}.room-comments{max-width:760px;margin:3rem auto 4rem;padding:0 1.5rem}.room-comments__title{color:var(--text);margin-bottom:1.25rem;font-size:1.25rem;font-weight:600}.room-comments__hint{color:var(--text-muted,#888);margin-bottom:.75rem;font-size:.875rem;font-style:italic}.room-comments__tabs{border-bottom:1px solid var(--border);gap:.5rem;margin-bottom:1.25rem;padding-bottom:.5rem;display:flex}.comment-tab{cursor:pointer;color:var(--text-muted,#888);background:0 0;border:none;border-radius:6px;padding:.4rem .9rem;font-size:.875rem;transition:background .15s,color .15s}.comment-tab:hover{background:var(--surface-2,#80808014)}.comment-tab.is-active{background:var(--surface-2,#8080801f);color:var(--text);font-weight:600}.comment-list{flex-direction:column;gap:1rem;margin:0 0 1.25rem;padding:0;list-style:none;display:flex}.comment-item{background:var(--surface,#8080800d);border:1px solid var(--border);border-radius:8px;padding:.85rem 1rem}.comment-item__header{align-items:center;gap:.6rem;margin-bottom:.4rem;display:flex}.comment-item__author{color:var(--text);font-size:.875rem;font-weight:600}.comment-item__date{color:var(--text-muted,#888);font-size:.75rem}.comment-item__delete{cursor:pointer;color:var(--text-muted,#888);background:0 0;border:none;border-radius:4px;margin-left:auto;padding:2px 4px;font-size:.75rem;transition:color .15s,background .15s}.comment-item__delete:hover{color:#ef4444;background:#ef444414}.comment-item__body{color:var(--text-body);white-space:pre-wrap;margin:0;font-size:.9rem;line-height:1.55}.comment-empty{color:var(--text-muted,#888);margin:.5rem 0 1rem;font-size:.875rem;font-style:italic}.comment-loading,.comment-error{font-size:.875rem}.comment-error{color:#ef4444}.comment-login-hint{color:var(--text-muted,#888);margin-top:.5rem;font-size:.875rem}.comment-form{flex-direction:column;gap:.6rem;margin-top:.75rem;display:flex}.comment-form__textarea{background:var(--surface,#8080800d);border:1px solid var(--border);width:100%;color:var(--text);resize:vertical;box-sizing:border-box;border-radius:8px;padding:.7rem .9rem;font-family:inherit;font-size:.9rem;transition:border-color .15s}.comment-form__textarea:focus{border-color:var(--accent,#4af0c4);outline:none}.comment-form__btn{align-self:flex-end;padding:.45rem 1.1rem;font-size:.875rem}.selector-row{flex-wrap:wrap;align-items:flex-end;gap:8px;display:flex}@media (width>=768px){.selector-row{justify-content:flex-end}}.selector-inline{flex-direction:column;gap:4px;display:flex}.selector-select{font-family:var(--font-body);border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;appearance:none;transition:border-color var(--transition-fast), background-color var(--transition-fast);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 7px center;background-repeat:no-repeat;padding:5px 26px 5px 9px;font-size:.8rem;font-weight:500}.selector-select:hover{border-color:var(--border-hover);background-color:var(--surface-hover)}.selector-select:focus{outline:2px solid var(--accent);outline-offset:2px;border-color:var(--accent)}.selector-select option{background:var(--bg);color:var(--text)}.selector-comments-btn{font-family:var(--font-body);border-radius:var(--radius-sm);border:1.5px solid var(--border);color:var(--text-body);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;align-items:center;gap:5px;padding:5px 11px;font-size:.8rem;font-weight:500;display:inline-flex}.selector-comments-btn svg{flex-shrink:0;width:13px;height:13px}.selector-comments-btn:hover{border-color:var(--accent);color:var(--text);background:var(--accent-dim)}.selector-comments-btn.is-active{background:var(--accent);border-color:var(--accent);color:#08090c}.selector-comments-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.cours-content-wrap{transition:opacity .18s}.cours-content-wrap--loading{opacity:.45;pointer-events:none}.room-cp__tabs{border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;gap:0;padding:0 1.25rem;display:flex}.room-cp__tab{font-family:var(--font-body);cursor:pointer;color:var(--muted);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:.7rem 1rem;font-size:.82rem;font-weight:500;transition:color .18s,border-color .18s}.room-cp__tab:hover{color:var(--text)}.room-cp__tab.is-active{color:var(--text);border-bottom-color:var(--accent);font-weight:600}.room-cp__tab:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.audio-player{background:color-mix(in srgb, var(--course-color,#e05c00) 7%, var(--surface,#13151c));border:1px solid color-mix(in srgb, var(--course-color,#e05c00) 22%, transparent);border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:8px;width:100%;max-width:520px;padding:12px 16px;transition:opacity .2s,background .3s;display:flex}.audio-player--loading{opacity:.55;pointer-events:none}.audio-player__controls{align-items:center;gap:10px;width:100%;display:flex}.audio-player__play{background:var(--course-color,#e05c00);color:#fff;cursor:pointer;width:38px;height:38px;box-shadow:0 2px 8px color-mix(in srgb, var(--course-color,#e05c00) 40%, transparent);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:transform .12s,box-shadow .12s,opacity .2s;display:flex}.audio-player__play svg{width:16px;height:16px}.audio-player__play:hover{box-shadow:0 4px 14px color-mix(in srgb, var(--course-color,#e05c00) 50%, transparent);transform:scale(1.08)}.audio-player__play:active{transform:scale(.93)}.audio-player__play:disabled{opacity:.4;cursor:default;box-shadow:none}.audio-player__spinner{width:18px;height:18px;animation:.8s linear infinite audio-spin}@keyframes audio-spin{to{transform:rotate(360deg)}}.audio-player__track{flex:1;position:relative}.audio-player__progress{appearance:none;background:linear-gradient(to right, var(--course-color,#e05c00) 0%, var(--course-color,#e05c00) var(--fill,0%), color-mix(in srgb, var(--course-color,#e05c00) 20%, transparent) var(--fill,0%), color-mix(in srgb, var(--course-color,#e05c00) 20%, transparent) 100%);cursor:pointer;border-radius:2px;width:100%;height:4px;display:block}.audio-player__progress::-webkit-slider-thumb{-webkit-appearance:none;background:var(--course-color,#e05c00);width:13px;height:13px;box-shadow:0 0 0 2px color-mix(in srgb, var(--course-color,#e05c00) 25%, transparent);cursor:pointer;border-radius:50%;transition:transform .1s}.audio-player__progress::-webkit-slider-thumb:hover{transform:scale(1.25)}.audio-player__progress::-moz-range-thumb{background:var(--course-color,#e05c00);cursor:pointer;border:none;border-radius:50%;width:13px;height:13px}.audio-player__time{font-variant-numeric:tabular-nums;color:var(--muted);white-space:nowrap;text-align:right;letter-spacing:.02em;min-width:72px;font-size:.72rem}.audio-player__time-sep{opacity:.4;margin:0 2px}.audio-player__volume{appearance:none;background:color-mix(in srgb, var(--course-color,#e05c00) 20%, transparent);width:60px;height:3px;accent-color:var(--course-color,#e05c00);cursor:pointer;border-radius:2px}.audio-player__volume::-webkit-slider-thumb{-webkit-appearance:none;background:var(--course-color,#e05c00);cursor:pointer;border-radius:50%;width:10px;height:10px}.audio-player__error{color:var(--muted);opacity:.7;margin:0;font-size:.78rem}#cours-main{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.room-layout{flex-direction:row;flex:1;gap:0 20px;min-height:0;padding:0 clamp(12px,2.5vw,32px);display:flex;overflow:hidden}@media (width>=1024px){.room-layout{gap:0 28px}}.room-content-col{overscroll-behavior-y:contain;overflow-anchor:auto;flex:1;min-width:0;min-height:0;padding-top:clamp(20px,3vh,32px);padding-bottom:clamp(40px,6vh,80px);overflow-y:auto}@media (width>=768px){.room-layout--sidebar-hidden .room-sidebar{display:none}}.room-toolbar{background:color-mix(in srgb, var(--bg) 88%, transparent);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border);transition:background var(--transition-theme), border-color var(--transition-theme);flex-shrink:0;margin-left:calc(-1*clamp(16px,4vw,56px));margin-right:calc(-1*clamp(16px,4vw,56px))}.room-toolbar__inner{align-items:center;gap:10px;max-width:1200px;height:46px;margin:0 auto;padding:0 clamp(16px,4vw,56px);display:flex}.room-toolbar__selectors{flex:1;align-items:center;gap:8px;display:flex}.room-toolbar .selector-inline{flex-direction:row;align-items:center;gap:6px}.room-toolbar .selector-label{white-space:nowrap;font-size:.65rem}.room-toolbar .selector-select{height:30px;padding:3px 22px 3px 7px;font-size:.78rem}.room-toolbar__toc-btn{font-family:var(--font-body);border-radius:var(--radius-sm);border:1.5px solid var(--border);color:var(--text-body);cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);background:0 0;flex-shrink:0;align-items:center;gap:5px;padding:4px 10px;font-size:.78rem;font-weight:500;display:inline-flex}.room-toolbar__toc-btn svg{flex-shrink:0;width:14px;height:14px}.room-toolbar__toc-btn:hover{border-color:var(--accent);color:var(--text);background:var(--accent-dim)}.room-toolbar__toc-btn.is-active{background:var(--accent);border-color:var(--accent);color:#08090c}.room-toolbar__toc-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media (width>=768px){.room-toolbar__toc-btn{display:none}}.room-toolbar__show-sidebar-btn{font-family:var(--font-body);border-radius:var(--radius-sm);border:1.5px solid var(--border);color:var(--text-body);cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);background:0 0;flex-shrink:0;align-items:center;gap:5px;padding:4px 10px;font-size:.78rem;font-weight:500;animation:.2s cubic-bezier(.25,.46,.45,.94) both miniTitleIn;display:none}.room-toolbar__show-sidebar-btn svg{flex-shrink:0;width:14px;height:14px}.room-toolbar__show-sidebar-btn:hover{border-color:var(--accent);color:var(--text);background:var(--accent-dim)}.room-toolbar__show-sidebar-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media (width>=768px){.room-toolbar__show-sidebar-btn{display:inline-flex}}.room-toolbar__sticky-hero{align-items:center;gap:9px;min-width:0;animation:.28s cubic-bezier(.25,.46,.45,.94) both miniTitleIn;display:flex;overflow:hidden}.room-toolbar__sticky-dot{background:var(--course-color,var(--accent));width:8px;height:8px;box-shadow:0 0 0 3px color-mix(in srgb, var(--course-color,var(--accent)) 18%, transparent), 0 0 9px color-mix(in srgb, var(--course-color,var(--accent)) 50%, transparent);border-radius:50%;flex-shrink:0;animation:.34s cubic-bezier(.34,1.56,.64,1) both dotPop}@keyframes dotPop{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}@keyframes miniTitleIn{0%{opacity:0;transform:translate(-7px)}to{opacity:1;transform:translate(0)}}@keyframes miniToolsIn{0%{opacity:0;transform:translateY(-3px)}to{opacity:1;transform:translateY(0)}}.room-toolbar__sticky-title{font-family:var(--font-display);letter-spacing:-.03em;color:var(--text);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:.96rem;font-weight:700;line-height:1.2;overflow:hidden}.room-toolbar__selectors--compact{flex:none;margin-left:auto}.room-toolbar__audio-slot{flex-shrink:0;align-items:center;display:flex}.room-toolbar--scrolled .room-toolbar__audio-slot{display:none}.room-toolbar__audio-slot .audio-player{background:0 0;border:none;border-radius:0;flex-shrink:0;width:auto;max-width:260px;padding:0}.room-toolbar__audio-slot .audio-player__controls{gap:8px}.room-toolbar__audio-slot .audio-player__play{width:32px;height:32px}.room-toolbar__audio-slot .audio-player__play svg{width:13px;height:13px}.room-toolbar__audio-slot .audio-player__volume{display:none}.room-toolbar__audio-slot .audio-player__time{min-width:58px;font-size:.68rem}.room-toolbar__audio-slot .audio-player__track{min-width:90px}.room-toolbar__audio-slot--compact .audio-player{max-width:220px}.room-toolbar__audio-slot--compact .audio-player__play{width:28px;height:28px;box-shadow:0 1px 6px color-mix(in srgb, var(--course-color,#e05c00) 30%, transparent)}.room-toolbar__audio-slot--compact .audio-player__play svg{width:12px;height:12px}.room-toolbar__audio-slot--compact .audio-player__time{min-width:54px;font-size:.63rem}.room-toolbar__audio-slot--compact .audio-player__track{min-width:70px}@media (width<=560px){.room-toolbar__audio-slot{display:flex}.room-toolbar__audio-slot .audio-player__time,.room-toolbar__audio-slot .audio-player__volume{display:none}.room-toolbar__audio-slot .audio-player__track{min-width:36px}.room-toolbar__audio-slot .audio-player__play{width:26px;height:26px}.room-toolbar__audio-slot .audio-player__play svg{width:10px;height:10px}.room-toolbar__toc-btn span,.room-toolbar__comments-btn span,.room-toolbar__edit-btn span,.room-toolbar__pin-btn span{display:none}.room-toolbar__toc-btn,.room-toolbar__comments-btn,.room-toolbar__edit-btn,.room-toolbar__pin-btn{padding:4px 7px}.room-toolbar .selector-label{display:none}.room-toolbar .selector-select{height:28px;padding:2px 18px 2px 5px;font-size:.72rem}}.room-toolbar__progress{background:color-mix(in srgb, var(--course-color,var(--accent)) 8%, var(--border) 92%);height:4px;overflow:hidden}.room-toolbar__progress-bar{background:linear-gradient(90deg, var(--course-color,var(--accent)), color-mix(in srgb, var(--course-color,var(--accent)) 68%, #fff 32%));border-radius:0 3px 3px 0;height:100%;transition:width .5s cubic-bezier(.25,.46,.45,.94)}.room-toolbar__comments-btn{font-family:var(--font-body);border-radius:var(--radius-sm);border:1.5px solid var(--border);color:var(--text-body);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;flex-shrink:0;align-items:center;gap:5px;padding:4px 10px;font-size:.78rem;font-weight:500;display:inline-flex}.room-toolbar__comments-btn svg{flex-shrink:0;width:14px;height:14px}.room-toolbar__comments-btn:hover{border-color:var(--accent);color:var(--text);background:var(--accent-dim)}.room-toolbar__comments-btn.is-active{background:var(--accent);border-color:var(--accent);color:#08090c}.room-toolbar__comments-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.room-toolbar__pin-btn{font-family:var(--font-body);border-radius:var(--radius-sm);border:1.5px solid var(--border);color:var(--text-body);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;flex-shrink:0;align-items:center;gap:5px;padding:4px 10px;font-size:.78rem;font-weight:500;display:inline-flex}.room-toolbar__pin-btn svg{flex-shrink:0;width:14px;height:14px}.room-toolbar__pin-btn:hover{border-color:var(--accent);color:var(--text);background:var(--accent-dim)}.room-toolbar__pin-btn.is-active{background:var(--accent);border-color:var(--accent);color:#08090c}.room-toolbar__pin-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.room-toolbar__edit-btn{font-family:var(--font-body);border-radius:var(--radius-sm);border:1.5px solid var(--border);color:var(--text-body);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;flex-shrink:0;align-items:center;gap:5px;padding:4px 10px;font-size:.78rem;font-weight:500;display:inline-flex}.room-toolbar__edit-btn svg{flex-shrink:0;width:14px;height:14px}.room-toolbar__edit-btn:hover{border-color:var(--accent);color:var(--text);background:var(--accent-dim)}.room-toolbar__edit-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.room-toolbar--scrolled{background:linear-gradient(110deg, color-mix(in srgb, var(--course-color,var(--accent)) 6%, color-mix(in srgb, var(--bg) 88%, transparent) 94%), color-mix(in srgb, var(--bg) 88%, transparent) 58%);border-bottom-color:color-mix(in srgb, var(--course-color,var(--accent)) 20%, var(--border))}.room-toolbar--scrolled .room-toolbar__inner{flex-wrap:wrap;align-items:center;gap:3px 7px;height:auto;padding-top:6px;padding-bottom:7px}.room-toolbar--scrolled .room-toolbar__sticky-hero{flex:0 0 100%;order:-1;min-width:0;overflow:hidden}.room-toolbar--scrolled .room-toolbar__toc-btn,.room-toolbar--scrolled .room-toolbar__show-sidebar-btn{order:1}.room-toolbar--scrolled .room-toolbar__selectors--compact{flex:none;order:2;margin-left:0}.room-toolbar--scrolled .room-toolbar__comments-btn{order:3}.room-toolbar--scrolled .selector-label{display:none}.room-toolbar--scrolled .room-toolbar__toc-btn,.room-toolbar--scrolled .room-toolbar__show-sidebar-btn,.room-toolbar--scrolled .room-toolbar__selectors--compact,.room-toolbar--scrolled .room-toolbar__comments-btn{animation:.22s cubic-bezier(.25,.46,.45,.94) 80ms both miniToolsIn}.room-sidebar-overlay{z-index:64;-webkit-backdrop-filter:blur(4px);opacity:0;background:#0000004d;transition:opacity .28s;display:none;position:fixed;inset:0}.room-sidebar-overlay.is-open{opacity:1;display:block}.room-sidebar{z-index:65;background:color-mix(in srgb, var(--surface) 90%, transparent);-webkit-backdrop-filter:blur(28px)saturate(1.8);border-top:1px solid color-mix(in srgb, var(--border) 50%, transparent);width:100%;height:88dvh;transition:transform .32s cubic-bezier(.32, .72, 0, 1), background var(--transition-theme), border-color var(--transition-theme);scrollbar-width:thin;scrollbar-color:var(--border) transparent;border-radius:18px 18px 0 0;flex-direction:column;display:flex;position:fixed;inset:auto 0 0;overflow-y:auto;transform:translateY(100%);box-shadow:0 -12px 48px #00000042}.room-sidebar.is-open{transform:translateY(28dvh)}.room-sidebar.is-open.snap-full{transform:translateY(0)}.room-sidebar__handle{background:color-mix(in srgb, var(--border) 90%, transparent);touch-action:none;cursor:grab;border-radius:3px;flex-shrink:0;width:44px;height:4px;margin:12px auto 0}.room-sidebar__progress{background:color-mix(in srgb, var(--border) 50%, transparent);flex-shrink:0;height:4px;margin-top:10px;overflow:hidden}.room-sidebar__progress-bar{background:linear-gradient(90deg, var(--course-color,var(--accent)), color-mix(in srgb, var(--course-color,var(--accent)) 55%, #fff 45%));height:100%;transition:width .5s cubic-bezier(.25,.46,.45,.94)}.room-sidebar__header{z-index:1;background:var(--surface);transition:background var(--transition-theme);flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;padding:8px 12px 8px 14px;display:flex;position:sticky;top:0}@media (width<=767px){.room-sidebar__header{background:color-mix(in srgb, var(--surface) 85%, transparent);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid color-mix(in srgb, var(--border) 60%, transparent)}}.room-sidebar__variant-label{color:var(--muted);letter-spacing:.01em;white-space:nowrap;text-overflow:ellipsis;min-width:0;font-size:.72rem;font-weight:500;overflow:hidden}.room-sidebar__header-actions{flex-shrink:0;align-items:center;gap:2px;display:flex}.room-sidebar__close,.room-sidebar__collapse-btn{width:28px;height:28px;color:var(--muted);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;border-radius:7px;flex-shrink:0;place-items:center;display:grid}.room-sidebar__close:hover,.room-sidebar__collapse-btn:hover{background:var(--surface-hover);color:var(--text)}.room-sidebar__close svg,.room-sidebar__collapse-btn svg{width:13px;height:13px}.room-sidebar__close{display:grid}.room-sidebar__collapse-btn{display:none}@media (width>=768px){.room-sidebar__close{display:none}.room-sidebar__collapse-btn{display:grid}.room-sidebar-overlay{display:none!important}.room-sidebar{background:var(--surface);-webkit-backdrop-filter:none;border:1px solid var(--border);border-radius:var(--radius-md);width:220px;height:auto;max-height:none;box-shadow:none;transition:background var(--transition-theme), border-color var(--transition-theme);border-top:none;flex-shrink:0;align-self:stretch;margin-top:clamp(20px,3vh,32px);margin-bottom:clamp(16px,2vh,24px);position:relative;inset:auto;overflow:hidden;transform:none!important}.room-sidebar__handle{display:none}.room-sidebar__progress{margin-top:0}.room-sidebar__header{border-bottom:1px solid var(--border)}}@media (width>=1024px){.room-sidebar{width:256px}}.room-sidebar__empty{color:var(--muted);padding:16px 14px;font-size:.78rem;font-style:italic}.room-sidebar__toc{margin:0;padding:6px 0 20px;list-style:none}.room-sidebar__section{position:relative}.room-sidebar__section.is-active:before{content:"";background:var(--course-color,var(--accent));width:2px;transition:background var(--transition-fast);border-radius:0 2px 2px 0;position:absolute;top:6px;bottom:6px;left:0}.room-sidebar__section-btn{cursor:pointer;text-align:left;width:100%;color:var(--text-body);transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;align-items:flex-start;gap:9px;padding:7px 14px 7px 16px;display:flex}.room-sidebar__section-btn:hover{background:var(--surface-hover);color:var(--text)}.room-sidebar__section-btn:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.room-sidebar__section.is-active .room-sidebar__section-btn{color:var(--text)}.room-sidebar__section-num{width:18px;height:18px;font-size:.62rem;font-weight:800;font-family:var(--font-display);background:var(--border);color:var(--text-body);transition:background var(--transition-fast), color var(--transition-fast);border-radius:5px;flex-shrink:0;place-items:center;margin-top:2px;display:grid}.room-sidebar__section.is-active .room-sidebar__section-num{background:var(--course-color,var(--accent));color:#08090c}.room-sidebar__section-title{color:inherit;font-size:.92rem;font-weight:600;line-height:1.35}.room-sidebar__steps{flex-direction:column;gap:1px;margin:0;padding:2px 0 6px 43px;list-style:none;display:flex}.room-sidebar__step-btn{cursor:pointer;text-align:left;border-radius:var(--radius-sm);width:100%;color:var(--muted);transition:color var(--transition-fast);background:0 0;border:none;align-items:center;gap:8px;padding:4px 10px 4px 0;display:flex}.room-sidebar__step-btn:hover{color:var(--text-body)}.room-sidebar__step-btn:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.room-sidebar__step-dot{opacity:.5;background:currentColor;border-radius:50%;flex-shrink:0;width:5px;height:5px}.room-sidebar__step-title{color:inherit;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.82rem;line-height:1.4;display:-webkit-box;overflow:hidden}:root{--card-preview-bg:#08090ceb;--card-preview-text:#e8eaf0e0;--progress-color:#f59e0b;--progress-track:#ffffff14}[data-theme=light]{--card-preview-bg:#f2f3f7f0;--card-preview-text:#111318cc;--progress-track:#00000014}.catalogue-header-nav{flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;display:flex}.catalogue-header-nav .header-actions{flex-wrap:nowrap;align-items:center;gap:8px;display:flex}.catalogue-header-nav .header-btn{align-items:center;gap:6px;display:flex}.catalogue-header-nav .header-btn__icon{display:none}.catalogue-main{box-sizing:border-box;flex-direction:column;flex:1;width:100%;padding:0 0 4rem;display:flex}.catalogue-header{text-align:left;box-sizing:border-box;border-bottom:1px solid var(--border);flex-direction:column;align-items:flex-start;gap:.5rem;width:100%;max-width:1280px;margin:0 auto clamp(1.25rem,3vw,1.75rem);padding:2.5rem 1.5rem clamp(1.25rem,3vw,1.75rem);display:flex}.catalogue-kicker{text-transform:uppercase;letter-spacing:.16em;color:var(--accent);align-items:center;gap:.55rem;font-size:.72rem;font-weight:600;display:inline-flex}.catalogue-kicker:before{content:"";background:var(--accent);opacity:.7;width:1.6rem;height:1px}.catalogue-title{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text);text-wrap:balance;margin:0;font-size:clamp(1.9rem,5vw,2.9rem);font-weight:700;line-height:1.08}.catalogue-subtitle{max-width:52ch;color:var(--muted);margin:0;font-size:clamp(.95rem,1.4vw,1.05rem);line-height:1.55}.catalogue-toolbar{box-sizing:border-box;align-items:center;gap:.75rem;width:100%;max-width:1280px;margin:0 auto;padding:0 1.5rem 1rem;display:flex}.catalogue-new-btn{border-radius:var(--radius-md,10px);color:#fff;font-family:var(--font-body,inherit);white-space:nowrap;background:linear-gradient(135deg,#6366f1,#818cf8);border:1px solid #818cf873;flex:none;justify-content:center;align-items:center;gap:.45rem;padding:.65rem 1.1rem;font-size:.9rem;font-weight:600;text-decoration:none;transition:transform .16s,box-shadow .16s,filter .16s;display:inline-flex;box-shadow:0 4px 14px #4f46e547}.catalogue-new-btn__icon{font-size:1.05rem;line-height:1}.catalogue-new-btn:hover{filter:brightness(1.06);transform:translateY(-1px);box-shadow:0 8px 20px #4f46e566}.catalogue-new-btn:active{transform:translateY(0)}.catalogue-search{flex:1;min-width:0;position:relative}.catalogue-search__icon{pointer-events:none;font-size:.9rem;position:absolute;top:50%;left:.85rem;transform:translateY(-50%)}.catalogue-search__input{box-sizing:border-box;background:var(--input-bg);border:1px solid var(--input-border);width:100%;color:var(--text);font-size:.9rem;font-family:var(--font-body);border-radius:8px;outline:none;padding:.6rem .9rem .6rem 2.4rem;transition:border-color .15s,box-shadow .15s}.catalogue-search__input:focus{border-color:var(--accent);box-shadow:var(--glow-input)}.catalogue-search__input::placeholder{color:var(--muted2)}.catalogue-filter__select{background:var(--input-bg);border:1px solid var(--input-border);color:var(--text);font-size:.9rem;font-family:var(--font-body);cursor:pointer;white-space:nowrap;border-radius:8px;outline:none;padding:.6rem 1rem;transition:border-color .15s}.catalogue-filter__select:focus{border-color:var(--accent)}.catalogue-tabs{box-sizing:border-box;border-bottom:1px solid var(--border);width:100%;max-width:1280px;margin:0 auto 1.5rem;padding:0 1.5rem;display:flex}.catalogue-tab{color:var(--muted);font-size:.95rem;font-family:var(--font-body);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2.5px solid #0000;margin-bottom:-1px;padding:.75rem 1.25rem;font-weight:500;transition:color .15s,border-color .15s}.catalogue-tab:hover{color:var(--text)}.catalogue-tab.is-active{color:var(--accent);border-bottom-color:var(--accent)}.room-list{box-sizing:border-box;grid-template-columns:repeat(3,1fr);gap:1.25rem;width:100%;max-width:1280px;margin:0 auto;padding:0 1.5rem;display:grid}.room-list--loading,.room-list--error,.room-list--empty{justify-content:center;align-items:center;width:100%;max-width:1280px;margin:0 auto;padding:3rem 1.5rem;display:flex}.room-list__empty-msg{color:var(--muted);font-size:.95rem}.room-list__skeleton{grid-template-columns:repeat(3,1fr);gap:1.25rem;width:100%;display:grid}.room-card-link{border-radius:16px;outline:none;text-decoration:none;display:block}.room-card-link:focus-visible .room-card{outline:2px solid var(--accent);outline-offset:2px}.room-card-link--no-slug{cursor:default}.room-card-link--selection{cursor:pointer}.room-card{background:var(--surface);border:1px solid var(--border);box-sizing:border-box;border-radius:16px;flex-direction:column;height:100%;min-height:290px;transition:border-color .22s,box-shadow .22s,transform .22s;display:flex;position:relative;overflow:hidden}.room-card-link:not(.room-card-link--no-slug):hover .room-card,.room-card-link--selection:hover .room-card{border-color:#4af0c4a6;transform:translateY(-8px);box-shadow:0 0 0 1px #4af0c447,0 10px 24px #00000038,0 28px 64px #0000004d,0 0 90px #4af0c417}[data-theme=light] .room-card-link:not(.room-card-link--no-slug):hover .room-card,[data-theme=light] .room-card-link--selection:hover .room-card{border-color:#00b3868c;box-shadow:0 0 0 1px #00b3863d,0 10px 24px #0000001a,0 28px 64px #00000024,0 0 90px #00b38612}.room-card--skeleton{background:var(--surface-2);border:1px solid var(--border);border-radius:16px;min-height:290px;animation:1.5s ease-in-out infinite skeletonPulse}@keyframes skeletonPulse{0%,to{opacity:1}50%{opacity:.45}}.room-card__header{background:var(--surface-2);width:100%;min-height:178px;transition:background-color var(--transition-theme);background-image:radial-gradient(145% 90% at 50% -18%,#4af0c47a 0%,#0000 52%),radial-gradient(75% 55% at -8% 110%,#6366f138 0%,#0000 55%),radial-gradient(60% 45% at 110% 100%,#f59e0b24 0%,#0000 50%);flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.room-card__header:before{content:"";pointer-events:none;z-index:0;background-image:radial-gradient(circle,#ffffff17 1px,#0000 1px);background-size:18px 18px;animation:22s linear infinite dotDrift;position:absolute;inset:-18px;-webkit-mask-image:linear-gradient(#0000008c 0%,#0000 100%);mask-image:linear-gradient(#0000008c 0%,#0000 100%)}@keyframes dotDrift{0%{background-position:0 0}to{background-position:18px 18px}}.room-card__header:after{content:"";pointer-events:none;z-index:2;background:linear-gradient(112deg,#0000 0% 28%,#ffffff1f 50%,#0000 72% 100%);transition:transform .6s cubic-bezier(.25,.46,.45,.94);position:absolute;inset:0;transform:translate(-170%)}.room-card-link:not(.room-card-link--no-slug):hover .room-card__header:after,.room-card-link--selection:hover .room-card__header:after{transform:translate(170%)}.room-card--inprogress .room-card__header{background-image:radial-gradient(145% 90% at 50% -18%,#f59e0b70 0%,#0000 52%),radial-gradient(75% 55% at -8% 110%,#ef444426 0%,#0000 55%),radial-gradient(60% 45% at 110% 100%,#eab30821 0%,#0000 50%)}.room-card--completed .room-card__header{background-image:radial-gradient(145% 90% at 50% -18%,#4af0c480 0%,#0000 52%),radial-gradient(75% 55% at -8% 110%,#10b98138 0%,#0000 55%),radial-gradient(60% 45% at 110% 100%,#3b82f621 0%,#0000 50%)}[data-theme=light] .room-card--completed .room-card__header{background-image:radial-gradient(145% 90% at 50% -18%,#00b38657 0%,#0000 52%),radial-gradient(75% 55% at -8% 110%,#05966933 0%,#0000 55%),radial-gradient(60% 45% at 110% 100%,#2563eb1c 0%,#0000 50%)}.room-card__icon-wrap{z-index:1;justify-content:center;align-items:center;width:82px;height:82px;transition:transform .22s;display:flex;position:relative}.room-card-link:not(.room-card-link--no-slug):hover .room-card__icon-wrap,.room-card-link--selection:hover .room-card__icon-wrap{transform:scale(1.16)translateY(-5px)}.room-card-link:not(.room-card-link--no-slug):hover .room-card__icon,.room-card-link--selection:hover .room-card__icon{filter:drop-shadow(0 10px 28px #4af0c480)drop-shadow(0 2px 8px #00000073)}.room-card__icon{z-index:1;filter:drop-shadow(0 4px 14px #00000059);font-size:3.2rem;line-height:1;position:relative}.room-card__ring{pointer-events:none;width:82px;height:82px;position:absolute;inset:0;transform:rotate(-90deg)}.room-card__ring-track{fill:none;stroke:var(--progress-track);stroke-width:3.5px}.room-card__ring-fill{fill:none;stroke:var(--progress-color);stroke-width:3.5px;stroke-linecap:round;transition:stroke-dashoffset .5s}.room-card__check{background:var(--accent);width:26px;height:26px;color:var(--btn-signup-col);z-index:3;box-shadow:0 0 16px var(--accent-glow), 0 2px 6px #00000038;border-radius:50%;justify-content:center;align-items:center;font-size:.75rem;font-weight:900;line-height:1;display:flex;position:absolute;top:12px;right:12px}.room-card__badge{font-size:.62rem;font-family:var(--font-body);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;z-index:3;border-radius:5px;padding:.2rem .55rem;font-weight:700;position:absolute;top:12px;right:12px}.room-card__badge.badge--premium{color:#ffc33c;background:#ffc33c26;border:1px solid #ffc33c4d}.room-card__preview{background:var(--card-preview-bg);-webkit-backdrop-filter:blur(8px)saturate(1.3);opacity:0;pointer-events:none;z-index:4;align-items:flex-start;padding:1.1rem 1rem .9rem;transition:opacity .2s,transform .2s;display:flex;position:absolute;inset:0;overflow:hidden;transform:translateY(8px)}.room-card__preview.is-visible{opacity:1;transform:translateY(0)}.room-card__preview-text{color:var(--card-preview-text);-webkit-line-clamp:6;font-size:.8rem;line-height:1.65;font-family:var(--font-body);-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.room-card__body{border-top:1px solid var(--border);background:var(--surface);transition:background var(--transition-theme);flex-shrink:0;padding:1rem 1.1rem 1.1rem}.room-card__name{color:var(--text);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:.35rem;font-size:.95rem;font-weight:600;line-height:1.35;display:-webkit-box;overflow:hidden}.room-card__subject{color:var(--muted);background:var(--surface-2);border:1px solid var(--border);white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:.72rem;font-family:var(--font-body);border-radius:4px;padding:.12rem .48rem;display:inline-block;overflow:hidden}.room-card__progress-bar{background:var(--progress-track);border-radius:2px;height:4px;margin-top:.75rem;overflow:hidden}.room-card__progress-fill{background:var(--progress-color);border-radius:2px;height:100%;transition:width .4s}.room-card__checkbox{z-index:5;width:18px;height:18px;accent-color:var(--accent);position:absolute;top:12px;left:12px}@media (width>=1400px){.room-list,.room-list__skeleton{grid-template-columns:repeat(4,1fr)}}@media (width<=1100px){.room-list,.room-list__skeleton{grid-template-columns:repeat(3,1fr)}}@media (width<=820px){.room-list,.room-list__skeleton{grid-template-columns:repeat(2,1fr);gap:1rem}.catalogue-header{padding:2rem 1.25rem 1.25rem}.catalogue-title{font-size:1.75rem}}@media (width<=640px){.catalogue-toolbar{flex-direction:column;align-items:stretch;gap:.5rem;padding:0 1rem 1rem}.catalogue-toolbar>.catalogue-search{flex:1}.catalogue-toolbar>.catalogue-filter{flex-shrink:0}.catalogue-header{padding:1.5rem 1rem 1rem}.catalogue-title{font-size:1.5rem}.catalogue-subtitle{font-size:.88rem}.catalogue-tabs{-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;padding:0 1rem;overflow-x:auto}.catalogue-tabs::-webkit-scrollbar{display:none}.catalogue-tab{flex-shrink:0;padding:.625rem 1rem;font-size:.88rem}.room-list,.room-list__skeleton{grid-template-columns:repeat(2,1fr);gap:.75rem;padding:0 1rem}.room-card{min-height:240px}.room-card__header{min-height:130px}.room-card__icon{font-size:2.4rem}.room-card__icon-wrap,.room-card__ring{width:68px;height:68px}.room-card__name{font-size:.88rem}.room-card__subject{font-size:.7rem}.room-card__body{padding:.75rem .875rem .875rem}.catalogue-search__input{min-height:44px;padding:.7rem .875rem .7rem 2.4rem;font-size:16px}.catalogue-search__icon{font-size:.9rem;left:.875rem}.catalogue-filter__select{min-height:44px;padding:.7rem 1rem;font-size:16px}.room-list--loading,.room-list--error,.room-list--empty{padding:2rem 1rem}}@media (width<=380px){.catalogue-header{padding:1.25rem .875rem .875rem}.catalogue-title{font-size:1.35rem}.catalogue-subtitle{font-size:.85rem}.catalogue-toolbar,.catalogue-tabs,.room-list,.room-list__skeleton{padding-left:.875rem;padding-right:.875rem}.room-list,.room-list__skeleton{grid-template-columns:1fr;gap:.875rem}.room-card{min-height:230px}.room-card__header{min-height:150px}.room-card__icon{font-size:2.8rem}.room-card__icon-wrap,.room-card__ring{width:76px;height:76px}.catalogue-header-nav .header-btn__text{display:none}.catalogue-header-nav .header-btn__icon{display:inline}.catalogue-header-nav .header-btn{padding:7px 10px}.catalogue-header-nav .btn--login .header-btn__icon:before{content:"👤"}.catalogue-header-nav .btn--logout .header-btn__icon:before{content:"→"}.catalogue-tab{padding:.5rem .875rem;font-size:.85rem}}.parcours-card__niveau{color:#9370db;white-space:nowrap;background:#9370db1f;border:1px solid #9370db40;border-radius:4px;padding:.1rem .45rem;font-size:.72rem;font-weight:600}:root{--cat-feature:#6366f1;--cat-room:#10b981;--cat-news:#f59e0b;--cat-tutorial:#3b82f6;--cat-update:#ec4899}.blog-progress{background:var(--accent);z-index:2000;pointer-events:none;height:3px;transition:width .1s linear;position:fixed;top:0;left:0}html:has(.page--blog) body{overflow:visible}.page--blog .user-nav{transition:transform .34s cubic-bezier(.32,.72,0,1),opacity .26s,visibility}.page--blog.nav-hidden .user-nav{opacity:0;visibility:hidden;pointer-events:none;transition:transform .34s cubic-bezier(.32,.72,0,1),opacity .26s,visibility 0s .34s;transform:translateY(-14px)}.page--blog.nav-hidden .user-nav__inner{pointer-events:none}@media (prefers-reduced-motion:reduce){.page--blog .user-nav{transition:opacity .2s,visibility}.page--blog.nav-hidden .user-nav{transform:none}}.blog-landing{box-sizing:border-box;width:100%;max-width:1280px;margin:0 auto;padding:clamp(1.5rem,4vw,2.5rem) clamp(1rem,4vw,1.5rem) 4rem}.blog-hero{text-align:left;border-bottom:1px solid var(--border);flex-direction:column;justify-content:flex-start;align-items:flex-start;gap:.5rem;margin-bottom:clamp(1.25rem,3vw,1.75rem);padding-bottom:clamp(1.25rem,3vw,1.75rem);display:flex}.blog-hero__kicker{text-transform:uppercase;letter-spacing:.16em;color:var(--accent);align-items:center;gap:.55rem;font-size:.72rem;font-weight:600;display:inline-flex}.blog-hero__kicker:before{content:"";background:var(--accent);opacity:.7;width:1.6rem;height:1px}.blog-hero__title{font-family:var(--font-display,inherit);letter-spacing:-.02em;text-wrap:balance;margin:0;font-size:clamp(1.9rem,5vw,2.9rem);line-height:1.08}.blog-hero__sub{max-width:52ch;color:var(--text-body,var(--text-secondary,#888));margin:0;font-size:clamp(.95rem,1.4vw,1.05rem);line-height:1.55}.blog-toolbar__top{align-items:center;gap:.75rem;width:100%;display:flex}.blog-new-btn{border-radius:var(--radius-md,10px);color:#fff;font-family:var(--font-body,inherit);white-space:nowrap;background:linear-gradient(135deg,#6366f1,#818cf8);border:1px solid #818cf873;flex:none;justify-content:center;align-items:center;gap:.45rem;padding:.65rem 1.1rem;font-size:.9rem;font-weight:600;text-decoration:none;transition:transform .16s,box-shadow .16s,filter .16s;display:inline-flex;box-shadow:0 4px 14px #4f46e547}.blog-new-btn__icon{font-size:1.05rem;line-height:1}.blog-new-btn:hover{filter:brightness(1.06);transform:translateY(-1px);box-shadow:0 8px 20px #4f46e566}.blog-new-btn:active{transform:translateY(0)}@media (width<=560px){.blog-toolbar__top{flex-wrap:wrap}.blog-search{flex:100%}.blog-new-btn{flex:100%;padding:.75rem 1.1rem}}.blog-toolbar{flex-direction:column;gap:.85rem;margin-bottom:clamp(1.25rem,3vw,1.75rem);display:flex}.blog-search{border:1px solid var(--border);border-radius:var(--radius-md,10px);background:var(--surface);min-width:0;color:var(--text);flex:auto;padding:.65rem .9rem;font-size:.95rem}.blog-search:focus{outline:2px solid var(--accent);outline-offset:2px}.blog-cats{flex-wrap:wrap;gap:.4rem;max-width:100%;display:flex}@media (width<=560px){.blog-cats{scrollbar-width:none;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;margin:0 calc(-1*clamp(1rem,4vw,1.5rem));padding:.2rem clamp(1rem,4vw,1.5rem);overflow-x:auto}.blog-cats::-webkit-scrollbar{display:none}}.blog-cat-tab{border:1px solid var(--border);color:var(--text);cursor:pointer;white-space:nowrap;background:0 0;border-radius:999px;padding:.4rem .8rem;font-size:.85rem;transition:all .15s}.blog-cat-tab.is-active,.blog-cat-tab:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.blog-grid{grid-template-columns:repeat(auto-fill,minmax(min(100%,290px),1fr));gap:clamp(1rem,2.5vw,1.25rem);display:grid}.blog-state{text-align:center;border:1px dashed var(--border);border-radius:var(--radius-lg,16px);background:radial-gradient(120% 100% at 50% 0%, var(--accent-dim,#4af0c40f), transparent 60%), var(--surface);flex-direction:column;align-items:center;gap:.65rem;padding:clamp(2.5rem,9vw,4.5rem) 1.25rem;display:flex}.blog-state__icon{width:3.25rem;height:3.25rem;color:var(--accent);background:var(--accent-dim,#4af0c41f);border-radius:50%;place-items:center;font-size:1.4rem;display:grid}.blog-state__title{color:var(--text);margin:0;font-size:1.05rem;font-weight:600}.blog-state__hint{color:var(--text-body,var(--text-secondary,#888));margin:0;font-size:.9rem}.blog-card{border:1px solid var(--border);border-radius:var(--radius-lg,14px);background:var(--surface);color:inherit;flex-direction:column;text-decoration:none;transition:transform .15s,box-shadow .15s;display:flex;overflow:hidden}.blog-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #0000002e}.blog-card__cover{aspect-ratio:16/9;object-fit:cover;background:var(--bg);width:100%;display:block}.blog-card__cover--ph{--ph-color:var(--cat-feature);background:radial-gradient(90% 120% at 18% 12%, color-mix(in srgb, var(--ph-color) 55%, transparent), transparent 60%), linear-gradient(135deg, color-mix(in srgb, var(--ph-color) 24%, var(--surface)), var(--surface));place-items:center;display:grid;position:relative;overflow:hidden}.blog-card__cover--ph:after{content:"";pointer-events:none;background-image:repeating-linear-gradient(135deg,#ffffff09 0 2px,#0000 2px 11px);position:absolute;inset:0}.blog-card__ph-glyph{z-index:1;color:var(--ph-color);filter:drop-shadow(0 2px 10px color-mix(in srgb, var(--ph-color) 40%, transparent));font-size:2.4rem;line-height:1;position:relative}.blog-card__ph-word{z-index:1;font-family:var(--font-display,inherit);letter-spacing:-.02em;color:color-mix(in srgb, var(--ph-color) 26%, transparent);text-transform:uppercase;font-size:2.6rem;font-weight:700;line-height:1;position:absolute;bottom:.55rem;right:.7rem}.blog-card__cover--Feature{--ph-color:var(--cat-feature)}.blog-card__cover--Room{--ph-color:var(--cat-room)}.blog-card__cover--News{--ph-color:var(--cat-news)}.blog-card__cover--Tutorial{--ph-color:var(--cat-tutorial)}.blog-card__cover--Update{--ph-color:var(--cat-update)}.blog-card__body{flex-direction:column;flex:1;gap:.5rem;padding:1rem;display:flex}.blog-card__title{margin:0;font-size:1.05rem;line-height:1.3}.blog-card__excerpt{color:var(--text-secondary,#888);flex:1;margin:0;font-size:.9rem}.blog-card__meta{color:var(--text-secondary,#888);align-items:center;gap:.5rem;font-size:.8rem;display:flex}.blog-badge{color:#fff;white-space:nowrap;border-radius:999px;align-self:flex-start;padding:.2rem .6rem;font-size:.72rem;font-weight:600;display:inline-block}.blog-badge--Feature{background:var(--cat-feature)}.blog-badge--Room{background:var(--cat-room)}.blog-badge--News{background:var(--cat-news)}.blog-badge--Tutorial{background:var(--cat-tutorial)}.blog-badge--Update{background:var(--cat-update)}.blog-badge--ai{background:#7c3aed}.blog-tags{flex-wrap:wrap;gap:.35rem;display:flex}.blog-tags--article{margin-top:.75rem}.blog-tag{color:var(--accent);background:var(--accent-dim,#4af0c41f);border:1px solid var(--border);white-space:nowrap;border-radius:999px;align-items:center;gap:.25rem;padding:.15rem .55rem;font-size:.72rem;font-weight:500;display:inline-flex}.blog-tag--removable{padding-right:.3rem}.blog-tag__remove{width:1rem;height:1rem;color:inherit;cursor:pointer;background:0 0;border:0;border-radius:999px;justify-content:center;align-items:center;padding:0;font-size:.85rem;line-height:1;display:inline-flex}.blog-tag__remove:hover{background:color-mix(in srgb, var(--accent,#4af0c4) 24%, transparent)}.blog-pager{justify-content:center;align-items:center;gap:1rem;margin-top:2rem;display:flex}.blog-pager button{border:1px solid var(--border);border-radius:var(--radius-md,10px);background:var(--surface);color:var(--text);cursor:pointer;padding:.5rem 1rem}.blog-pager button:disabled{opacity:.4;cursor:default}.blog-article-hero{isolation:isolate;text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:clamp(2.75rem,6vw,4.75rem) 1.25rem clamp(1.75rem,4vw,2.75rem);display:flex;position:relative}.blog-article-hero--has-cover{min-height:clamp(360px,52vw,560px);padding:clamp(3.5rem,7vw,5.5rem) 1.25rem;overflow:hidden}.blog-article-hero--default{--ph-color:var(--cat-news);background:radial-gradient(85% 120% at 22% 0%, color-mix(in srgb, var(--ph-color) 50%, transparent), transparent 62%), linear-gradient(135deg, color-mix(in srgb, var(--ph-color) 26%, var(--bg)), var(--bg));min-height:clamp(300px,42vw,460px);padding:clamp(3rem,6vw,5rem) 1.25rem;overflow:hidden}.blog-article-hero--default.blog-article-hero--Feature{--ph-color:var(--cat-feature)}.blog-article-hero--default.blog-article-hero--Room{--ph-color:var(--cat-room)}.blog-article-hero--default.blog-article-hero--News{--ph-color:var(--cat-news)}.blog-article-hero--default.blog-article-hero--Tutorial{--ph-color:var(--cat-tutorial)}.blog-article-hero--default.blog-article-hero--Update{--ph-color:var(--cat-update)}.blog-article-hero__glyph{z-index:-1;color:color-mix(in srgb, var(--ph-color) 32%, transparent);filter:drop-shadow(0 4px 30px color-mix(in srgb, var(--ph-color) 35%, transparent));pointer-events:none;-webkit-user-select:none;user-select:none;font-size:clamp(11rem,30vw,22rem);line-height:.8;position:absolute;bottom:clamp(-2rem,-1vw,.5rem);right:clamp(-1rem,2vw,2rem)}.blog-article-hero__img{z-index:-2;object-fit:cover;object-position:center;width:100%;height:100%;display:block;position:absolute;inset:0}.blog-article-hero__scrim{z-index:-1;background:linear-gradient(#06080b9e 0%,#06080b6b 38%,#06080bc7 100%),radial-gradient(125% 90% at 50% 60%,#06080b26 0%,#06080b8c 100%);position:absolute;inset:0}.blog-article-hero__body{z-index:1;flex-direction:column;align-items:center;gap:1rem;width:100%;max-width:820px;display:flex;position:relative}.blog-article-hero--default .blog-article-hero__scrim{background:linear-gradient(#06080b4d 0%,#06080b2e 42%,#06080b94 100%)}.blog-article-hero--has-cover .blog-article__title,.blog-article-hero--default .blog-article__title{color:#fff;text-shadow:0 2px 28px #0000008c}.blog-article-hero--has-cover .blog-article__meta,.blog-article-hero--has-cover .blog-article__excerpt,.blog-article-hero--default .blog-article__meta,.blog-article-hero--default .blog-article__excerpt{color:#ffffffe6}.blog-article__badges{flex-wrap:wrap;justify-content:center;gap:.4rem;display:flex}.blog-article__title{font-family:var(--font-display,inherit);letter-spacing:-.01em;text-wrap:balance;margin:0;font-size:clamp(2rem,5.2vw,3.25rem);line-height:1.12}.blog-article__excerpt{max-width:660px;color:var(--text-secondary,#888);margin:0;font-size:clamp(1rem,1.6vw,1.18rem);line-height:1.6}.blog-article__meta{color:var(--text-secondary,#888);flex-wrap:wrap;justify-content:center;align-items:center;gap:.6rem;font-size:.9rem;display:flex}.blog-edit-btn{z-index:3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;white-space:nowrap;background:#0a0c1080;border:1px solid #ffffff47;border-radius:999px;align-items:center;gap:.4rem;padding:.45rem .85rem;font-size:.82rem;font-weight:600;text-decoration:none;transition:background .15s,border-color .15s,transform .15s;display:inline-flex;position:absolute;top:clamp(.9rem,2vw,1.4rem);right:clamp(.9rem,2vw,1.4rem)}.blog-edit-btn:hover{background:#0a0c10b8;border-color:#ffffff8c;transform:translateY(-1px)}.blog-article-layout{grid-template-columns:240px minmax(0,760px) 240px;align-items:start;gap:2rem;max-width:1380px;margin:0 auto;padding:2rem 1.25rem 4rem;display:grid}@media (width<=1200px){.blog-article-layout{grid-template-columns:minmax(0,760px) 220px}.blog-toc{display:none}}@media (width<=860px){.blog-article-layout{grid-template-columns:1fr;padding:1.5rem 1rem 3rem}.blog-sidebar-right{display:none}}.blog-article{min-width:0;padding-bottom:2rem}.blog-toc{top:calc(var(--user-nav-h,64px) + 1rem);max-height:calc(100vh - var(--user-nav-h,64px) - 2rem);border:1px solid var(--border);border-radius:var(--radius-md,10px);background:var(--surface);scrollbar-width:none;align-self:start;padding:1rem;position:sticky;overflow-y:auto}.blog-toc::-webkit-scrollbar{display:none}.blog-toc__label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary,#888);margin:0 0 .75rem;font-size:.72rem}.blog-toc__list{flex-direction:column;gap:.15rem;margin:0;padding:0;list-style:none;display:flex}.blog-toc__item{padding:0}.blog-toc__item--h3{padding-left:.85rem}.blog-toc__link{color:var(--text-secondary,#888);border-radius:6px;padding:.25rem .35rem;font-size:.82rem;line-height:1.35;text-decoration:none;transition:all .12s;display:block}.blog-toc__link:hover{color:var(--text);background:#0000000d}.blog-toc__link.is-active{color:var(--accent);background:#6366f114;font-weight:600}.blog-sidebar-right{top:calc(var(--user-nav-h,64px) + 1rem);max-height:calc(100vh - var(--user-nav-h,64px) - 2rem);border:1px solid var(--border);border-radius:var(--radius-md,10px);background:var(--surface);scrollbar-width:none;align-self:start;padding:1rem;position:sticky;overflow-y:auto}.blog-sidebar-right::-webkit-scrollbar{display:none}.blog-sidebar-right__list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.blog-sidebar-right__item{color:inherit;border-radius:8px;flex-direction:column;gap:.25rem;padding:.6rem .5rem;text-decoration:none;transition:all .12s;display:flex}.blog-sidebar-right__item:hover{background:#0000000a}.blog-sidebar-right__title{font-size:.87rem;font-weight:500;line-height:1.3}.blog-sidebar-right__meta{color:var(--text-secondary,#888);font-size:.75rem}.blog-blocks{overflow-wrap:anywhere;flex-direction:column;gap:clamp(1rem,2.5vw,1.25rem);min-width:0;font-size:clamp(1rem,.5vw + .94rem,1.05rem);line-height:1.7;display:flex}.blog-heading{scroll-margin-top:calc(var(--user-nav-h,64px) + 1.5rem);text-wrap:balance;margin:1rem 0 0}h2.blog-heading{font-size:clamp(1.4rem,3.4vw,1.85rem);line-height:1.2}h3.blog-heading{font-size:clamp(1.15rem,2.6vw,1.4rem);line-height:1.25}.blog-paragraph p,.blog-image{margin:0}.blog-image img{border-radius:var(--radius-md,10px);width:100%}.blog-image figcaption,.blog-video figcaption{text-align:center;color:var(--text-secondary,#888);margin-top:.4rem;font-size:.85rem}.blog-quote{border-left:4px solid var(--accent);margin:0;padding:.5rem 0 .5rem 1.25rem;font-style:italic}.blog-quote cite{color:var(--text-secondary,#888);margin-top:.5rem;font-style:normal;display:block}.blog-callout{border-radius:var(--radius-md,10px);border:1px solid var(--border);gap:.75rem;padding:1rem 1.1rem;display:flex}.blog-callout__body p{margin:0}.blog-callout--info{background:#3b82f614;border-color:#3b82f666}.blog-callout--tip{background:#10b98114;border-color:#10b98166}.blog-callout--warning{background:#f59e0b1a;border-color:#f59e0b73}.blog-callout--danger{background:#ef44441a;border-color:#ef444473}.blog-code-wrap{border:1px solid var(--border);border-radius:var(--radius-md,10px);background:#0d1117;overflow:hidden}.blog-code-bar{background:#161b22;border-bottom:1px solid #ffffff12;justify-content:space-between;align-items:center;padding:.4rem .55rem .4rem .85rem;display:flex}.blog-code-lang{font-family:var(--font-mono,monospace);text-transform:uppercase;letter-spacing:.06em;color:#8b949e;font-size:.72rem}.blog-code-copy{color:#c9d1d9;cursor:pointer;background:0 0;border:1px solid #ffffff24;border-radius:6px;padding:.22rem .6rem;font-size:.72rem;font-weight:600;transition:background .15s,border-color .15s}.blog-code-copy:hover{background:#ffffff14;border-color:#ffffff47}.blog-code{-webkit-overflow-scrolling:touch;font-family:var(--font-mono,monospace);background:#0d1117;margin:0;padding:1rem;font-size:clamp(.78rem,2.4vw,.88rem);line-height:1.55;overflow-x:auto}.blog-code code.hljs{background:0 0;padding:0}.blog-divider{border:none;border-top:1px solid var(--border);margin:1rem 0}.blog-video__frame{padding-top:56.25%;position:relative}.blog-video__frame iframe{border-radius:var(--radius-md,10px);border:0;width:100%;height:100%;position:absolute;inset:0}.blog-video video{border-radius:var(--radius-md,10px);width:100%}.blog-link-card{border:1px solid var(--border);border-radius:var(--radius-md,10px);color:inherit;flex-direction:column;gap:.25rem;padding:1rem;text-decoration:none;transition:all .15s;display:flex}.blog-link-card:hover{border-color:var(--accent)}.blog-link-card__title{overflow-wrap:anywhere;font-weight:600}.blog-link-card__desc{color:var(--text-secondary,#888);font-size:.9rem}.blog-link-card__url{color:var(--accent);overflow-wrap:anywhere;font-size:.8rem}.blog-list{flex-direction:column;gap:.35rem;margin:0;padding-left:1.4rem;display:flex}.blog-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.blog-table{border-collapse:collapse;width:100%}.blog-table th,.blog-table td{border:1px solid var(--border);text-align:left;padding:.55rem .8rem}.blog-table th{background:var(--surface)}.blog-tweet{border:1px solid var(--border);border-radius:var(--radius-md,10px);max-width:100%;color:var(--accent);overflow-wrap:anywhere;word-break:break-word;padding:.6rem 1rem;text-decoration:none;display:inline-block}.blog-room-card{border:1px solid var(--border);border-radius:var(--radius-md,10px);color:inherit;background:var(--surface);align-items:center;gap:.9rem;padding:1rem 1.1rem;text-decoration:none;transition:all .15s;display:flex}.blog-room-card:hover{border-color:var(--accent);transform:translateY(-2px)}.blog-room-card__icon{font-size:1.6rem}.blog-room-card__body{flex-direction:column;display:flex}.blog-room-card__name{font-weight:600}.blog-room-card__cta{color:var(--accent);font-size:.85rem}.blog-reactions{flex-wrap:wrap;gap:.5rem;margin:2.5rem 0 1.5rem;display:flex}.blog-reaction{border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;border-radius:999px;align-items:center;gap:.4rem;padding:.45rem .85rem;font-size:.95rem;transition:all .15s;display:flex}.blog-reaction.is-active{border-color:var(--accent);background:#6366f11f}.blog-reaction:disabled{opacity:.5;cursor:default}.blog-comments{flex-direction:column;gap:1rem;margin-top:2rem;display:flex}.blog-comments__title{margin:0 0 .5rem}.blog-comment{border:1px solid var(--border);border-radius:var(--radius-md,10px);background:var(--surface);padding:.85rem 1rem}.blog-comment__head{color:var(--text-secondary,#888);justify-content:space-between;margin-bottom:.35rem;font-size:.85rem;display:flex}.blog-comment__delete{color:var(--text-secondary,#888);cursor:pointer;background:0 0;border:none}.blog-comment-form{flex-direction:column;gap:.5rem;display:flex}.blog-comment-form textarea{border:1px solid var(--border);border-radius:var(--radius-md,10px);background:var(--surface);color:var(--text);resize:vertical;min-height:80px;padding:.7rem;font-family:inherit}.blog-comment-form button{border-radius:var(--radius-md,10px);background:var(--accent);color:#fff;cursor:pointer;border:none;align-self:flex-end;padding:.5rem 1.2rem;font-weight:600}.blog-login-prompt{color:var(--text-secondary,#888);font-style:italic}.blog-btn{border-radius:var(--radius-md,10px);cursor:pointer;border:none;padding:.5rem 1rem;font-size:.9rem;font-weight:600;text-decoration:none;display:inline-block}.blog-btn--primary{background:var(--accent);color:#fff}.blog-btn--ghost{border:1px solid var(--border);color:var(--text);background:0 0}.blog-btn:disabled{opacity:.5;cursor:default}.blog-scrolltop{z-index:60;background:var(--accent);color:#08090c;cursor:pointer;opacity:0;pointer-events:none;border:none;border-radius:50%;place-items:center;width:46px;height:46px;font-size:1.1rem;font-weight:700;line-height:1;transition:opacity .24s,transform .24s cubic-bezier(.34,1.56,.64,1);display:grid;position:fixed;bottom:clamp(18px,3.5vh,32px);right:clamp(18px,3.5vw,32px);transform:translateY(12px)scale(.85);box-shadow:0 4px 20px #4af0c459}.blog-scrolltop.is-visible{opacity:1;pointer-events:auto;transform:translateY(0)scale(1)}.blog-scrolltop:hover{transform:translateY(-3px)scale(1.05);box-shadow:0 6px 26px #4af0c480}[data-theme=light] .blog-toc__link:hover,[data-theme=light] .blog-sidebar-right__item:hover{background:#0000000a}[data-theme=light] .blog-scrolltop{box-shadow:0 4px 16px #0000002e}@media (width<=640px){.blog-article-hero{padding:2.25rem 1rem 1.5rem}.blog-article-hero--has-cover,.blog-article-hero--default{min-height:clamp(240px,60vw,360px);padding:2.75rem 1rem}.blog-article-hero__glyph{font-size:clamp(8rem,42vw,14rem)}.blog-article__title{font-size:clamp(1.55rem,6.5vw,2.2rem)}.blog-article__excerpt{font-size:1rem}.blog-article-layout{padding:1.25rem .9rem 2.5rem}.blog-blocks{line-height:1.65}.blog-quote{padding-left:1rem}.blog-callout{gap:.55rem;padding:.85rem .9rem}.blog-code{padding:.85rem}.blog-code-bar{padding:.35rem .5rem .35rem .75rem}.blog-link-card{padding:.85rem}.blog-table th,.blog-table td{padding:.45rem .6rem;font-size:.9rem}.blog-room-card{gap:.7rem;padding:.85rem .9rem}.blog-room-card__icon{font-size:1.35rem}.blog-reactions{gap:.4rem;margin:2rem 0 1.25rem}.blog-reaction{padding:.4rem .7rem;font-size:.9rem}.blog-comments__title{font-size:1.15rem}}@media (width<=480px){.blog-edit-btn span{display:none}.blog-edit-btn{padding:.42rem .55rem}}.blog-article__inner{max-width:860px;margin:0 auto;padding:4rem 1.25rem 2rem}html:has(.page--blog-creator) body{overflow:visible}.blog-creator{grid-template-columns:1fr;gap:1rem;max-width:1480px;margin:0 auto;padding:1.25rem 1.25rem 4rem;display:grid}@media (width>=1024px){.blog-creator{grid-template-columns:var(--outline-w,264px) minmax(0, 1fr) var(--preview-w,440px);align-items:start}.blog-creator--outline-collapsed{--outline-w:46px}.blog-creator--preview-collapsed{--preview-w:46px}.blog-creator__toolbar,.blog-tagbar,.blog-creator__error{grid-column:1/-1}.blog-outline{grid-column:1}.blog-editor{grid-column:2}.blog-preview{grid-column:3}}.blog-creator__toolbar{z-index:30;background:color-mix(in srgb, var(--surface-2) 86%, transparent);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius-lg,16px);flex-wrap:wrap;align-items:center;gap:.65rem .9rem;padding:.6rem .75rem;display:flex;position:sticky;top:.75rem;box-shadow:0 10px 34px #00000057}.blog-creator__title-input{min-width:180px;font-family:var(--fd);letter-spacing:-.01em;color:var(--text);border-radius:var(--r-md,10px);transition:var(--tf);background:0 0;border:1px solid #0000;flex:240px;padding:.45rem .7rem;font-size:1.35rem;font-weight:700}.blog-creator__title-input::placeholder{color:var(--muted2)}.blog-creator__title-input:focus{background:var(--bg);border-color:var(--border-hover);box-shadow:var(--glow-input);outline:none}.blog-creator__controls{flex-wrap:wrap;align-items:center;gap:.55rem .7rem;margin-left:auto;display:flex}.blog-creator__meta,.blog-creator__actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.blog-creator__meta select,.blog-creator__meta input[type=text]{height:36px;font-family:var(--fb);color:var(--text);background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--r-md,10px);transition:var(--tf);padding:0 .65rem;font-size:.85rem}.blog-creator__meta input[type=text]{width:150px}.blog-creator__meta select:focus,.blog-creator__meta input[type=text]:focus{border-color:var(--accent);box-shadow:var(--glow-input);outline:none}.blog-creator__sep{background:var(--border);align-self:stretch;width:1px;min-height:22px;margin:0 .1rem}.blog-tagbar{background:color-mix(in srgb, var(--surface-2) 86%, transparent);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius-lg,16px);align-items:flex-start;gap:.7rem;padding:.5rem .7rem;display:flex}.blog-tagbar__label{height:34px;font-family:var(--fb);text-transform:uppercase;letter-spacing:.12em;color:var(--muted);white-space:nowrap;-webkit-user-select:none;user-select:none;flex-shrink:0;align-items:center;gap:.4rem;font-size:.68rem;font-weight:700;display:inline-flex}.blog-tagbar__hash{width:20px;height:20px;color:var(--accent);background:var(--accent-dim);border:1px solid color-mix(in srgb, var(--accent) 24%, transparent);border-radius:6px;place-items:center;font-size:.82rem;display:grid}.blog-tagbar__count{font-family:var(--fm);letter-spacing:.04em;color:var(--muted2);font-size:.66rem}.blog-tagfield{background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--r-md,10px);min-width:0;max-height:5.6rem;transition:var(--tf);scrollbar-width:thin;scrollbar-color:var(--border-hover) transparent;flex-wrap:wrap;flex:1;align-items:center;gap:.4rem;padding:.4rem .5rem;display:flex;overflow-y:auto}.blog-tagfield:focus-within{border-color:var(--accent);box-shadow:var(--glow-input)}.blog-tagfield__input{min-width:8rem;height:26px;color:var(--text);font-family:var(--fb);background:0 0;border:none;flex:8rem;padding:0 .3rem;font-size:.82rem}.blog-tagfield__input:focus{outline:none}.blog-tagfield__input::placeholder{color:var(--muted2)}.blog-tagfield__input:disabled{cursor:not-allowed}.blog-tagfield .blog-tag{font-family:var(--fb);border-color:color-mix(in srgb, var(--accent) 22%, var(--border));transition:var(--tf);padding:.18rem .25rem .18rem .55rem;font-size:.75rem}.blog-tagfield .blog-tag:hover{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 16%, transparent)}.blog-switch{color:var(--text-body);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.5rem;font-size:.82rem;display:inline-flex}.blog-switch input{opacity:0;width:0;height:0;position:absolute}.blog-switch__track{background:var(--surface-3);border:1px solid var(--border);width:38px;height:22px;transition:var(--tf);border-radius:999px;flex-shrink:0;position:relative}.blog-switch__track:after{content:"";background:var(--muted);width:16px;height:16px;transition:var(--tf);border-radius:50%;position:absolute;top:2px;left:2px}.blog-switch input:checked+.blog-switch__track{background:var(--accent-dim);border-color:var(--accent)}.blog-switch input:checked+.blog-switch__track:after{background:var(--accent);box-shadow:0 0 10px var(--accent-glow);transform:translate(16px)}.blog-switch input:focus-visible+.blog-switch__track{box-shadow:var(--glow-input)}.blog-tool-btn{height:36px;font-family:var(--fb);color:var(--text-body);background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--r-md,10px);cursor:pointer;white-space:nowrap;transition:var(--tf);align-items:center;gap:.4rem;padding:0 .8rem;font-size:.85rem;font-weight:600;display:inline-flex}.blog-tool-btn:hover{color:var(--text);border-color:var(--border-hover)}.blog-tool-btn.is-active{color:var(--accent);border-color:var(--accent);background:var(--accent-dim)}@keyframes blog-pop{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}.blog-ai-error{color:var(--error);font-size:.85rem}.blog-creator__error{color:var(--error);background:var(--error-dim);border:1px solid color-mix(in srgb, var(--error) 40%, transparent);border-radius:var(--r-md,10px);margin:0;padding:.65rem .9rem;font-size:.88rem}.blog-panel-label{font-family:var(--fb);text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-size:.68rem;font-weight:700}.blog-icon-btn{border:1px solid var(--border);width:26px;height:26px;color:var(--muted);cursor:pointer;transition:var(--tf);background:0 0;border-radius:8px;justify-content:center;align-items:center;font-size:1.05rem;line-height:1;display:inline-flex}.blog-icon-btn:hover{color:var(--accent);border-color:var(--accent)}.blog-outline{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg,16px);flex-direction:column;gap:.5rem;max-height:calc(100vh - 6rem);padding:.75rem;display:flex;position:sticky;top:5rem;overflow-y:auto}.blog-outline__head{justify-content:space-between;align-items:center;padding:0 .15rem;display:flex}.blog-outline__list{flex-direction:column;gap:.25rem;margin:0;padding:0;list-style:none;display:flex}.blog-outline__item{border-radius:var(--r-md,10px);color:var(--text-body);cursor:grab;transition:var(--tf);border:1px solid #0000;align-items:center;gap:.55rem;padding:.45rem .55rem;font-size:.82rem;display:flex}.blog-outline__item:hover{background:var(--surface-hover);border-color:var(--border);color:var(--text)}.blog-outline__item:active{cursor:grabbing}.blog-outline__num{text-align:right;width:1.4em;font-family:var(--fm);color:var(--muted2);flex-shrink:0;font-size:.7rem}.blog-outline__glyph{text-align:center;width:1.5em;font-family:var(--fm);color:var(--accent);flex-shrink:0;font-size:.85rem}.blog-outline__text{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.blog-outline__empty{color:var(--muted);padding:.35rem .15rem;font-size:.8rem}.blog-outline--collapsed,.blog-preview--collapsed{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg,16px);padding:0;position:sticky;top:5rem;overflow:hidden}.blog-rail-toggle{width:100%;min-height:160px;color:var(--muted);cursor:pointer;transition:var(--tf);background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:.8rem;padding:1rem .2rem;display:flex}.blog-rail-toggle:hover{color:var(--accent);background:var(--accent-dim)}.blog-rail-toggle__chevron{font-size:1.15rem;line-height:1}.blog-rail-toggle__label{writing-mode:vertical-rl;text-orientation:mixed;font-family:var(--fb);text-transform:uppercase;letter-spacing:.15em;font-size:.7rem;font-weight:700}.blog-editor{flex-direction:column;gap:.75rem;min-width:0;display:flex}.blog-editor__excerpt{font-style:italic}.blog-editor__block{border:1px solid var(--border);border-radius:var(--radius-md,12px);background:var(--surface);transition:border-color var(--tf), box-shadow var(--tf);padding:.8rem;scroll-margin-top:6rem}.blog-editor__block:hover{border-color:var(--border-hover)}.blog-editor__block:focus-within{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-dim)}.blog-editor__block-head{align-items:center;gap:.5rem;margin-bottom:.55rem;display:flex}.blog-editor__drag{cursor:grab;color:var(--muted2);-webkit-user-select:none;user-select:none;font-size:1rem}.blog-editor__drag:active{cursor:grabbing}.blog-editor__glyph{font-family:var(--fm);color:var(--accent);font-size:.8rem}.blog-editor__type{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);flex:1;font-size:.72rem}.blog-editor__block-actions{gap:.25rem;display:flex}.blog-editor__block-actions button{border:1px solid var(--border);cursor:pointer;color:var(--text);transition:var(--tf);background:0 0;border-radius:7px;padding:.15rem .45rem;font-size:.8rem}.blog-editor__block-actions button:hover{border-color:var(--accent);color:var(--accent)}.blog-editor__block-actions button:disabled{opacity:.45;cursor:default}.blog-editor__field{border:1px solid var(--input-border);border-radius:var(--r-sm,6px);background:var(--input-bg);width:100%;color:var(--text);box-sizing:border-box;transition:var(--tf);padding:.5rem .55rem;font-family:inherit}.blog-editor__field:focus{border-color:var(--accent);box-shadow:var(--glow-input);outline:none}textarea.blog-editor__field{resize:vertical;min-height:70px}.blog-editor__row{gap:.5rem;display:flex}.blog-editor__row select{border:1px solid var(--input-border);border-radius:var(--r-sm,6px);background:var(--input-bg);color:var(--text);padding:.45rem .5rem}.blog-editor__empty{text-align:center;color:var(--muted);border:1px dashed var(--border);border-radius:var(--radius-md,12px);padding:1.5rem;font-size:.9rem}.blog-toggle{cursor:pointer;align-items:center;gap:.5rem;font-size:.9rem;display:flex}.blog-addblock{border:1px dashed var(--border);border-radius:var(--radius-md,12px);flex-wrap:wrap;gap:.35rem;margin-top:.25rem;padding:.75rem;display:flex}.blog-addblock button{border:1px solid var(--border);color:var(--text-body);cursor:pointer;transition:var(--tf);background:0 0;border-radius:999px;align-items:center;gap:.35rem;padding:.32rem .7rem;font-size:.8rem;display:inline-flex}.blog-addblock button:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.blog-addblock__glyph{font-family:var(--fm);color:var(--accent);font-size:.8rem}.blog-preview{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg,16px);flex-direction:column;gap:.85rem;max-height:calc(100vh - 6rem);padding:1rem 1.25rem 1.25rem;display:flex;position:sticky;top:5rem;overflow:hidden}.blog-preview__head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding-bottom:.75rem;display:flex}.blog-preview__body{padding-right:.25rem;overflow-y:auto}@media (width<=1023px){.blog-outline,.blog-outline--collapsed,.blog-preview,.blog-preview--collapsed{max-height:none;position:static}.blog-rail-toggle{flex-direction:row;min-height:0}.blog-rail-toggle__label{writing-mode:horizontal-tb}.blog-creator__toolbar{position:static}.blog-creator__controls{justify-content:space-between;width:100%;margin-left:0}}@media (width<=600px){.blog-creator{gap:.85rem;padding:.85rem .85rem 3rem}.blog-creator__toolbar{gap:.6rem;padding:.65rem}.blog-creator__title-input{flex:100%;min-width:0;font-size:1.2rem}.blog-creator__controls{flex-direction:column;align-items:stretch;gap:.55rem}.blog-creator__sep{display:none}.blog-creator__meta{width:100%}.blog-creator__meta select{flex:auto}.blog-creator__meta input[type=text]{flex:100%;width:auto;min-width:0}.blog-switch{margin-left:auto}.blog-creator__actions{width:100%}.blog-creator__actions>.blog-tool-btn,.blog-creator__actions>.blog-btn{text-align:center;flex:calc(50% - .25rem);justify-content:center}.blog-tagbar{flex-direction:column;gap:.45rem}.blog-tagbar__label{height:auto}.blog-tagfield{width:100%}}@keyframes blog-dot-pulse{0%,to{opacity:1;box-shadow:0 0 5px var(--accent-glow)}50%{opacity:.55;box-shadow:0 0 12px var(--accent-glow)}}@keyframes blog-msg-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes blog-typing{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}.blog-studio__backdrop{z-index:1000;-webkit-backdrop-filter:blur(4px);background:#0405089e;justify-content:center;align-items:center;padding:1.5rem;animation:.2s cubic-bezier(.4,0,.2,1) blog-pop;display:flex;position:fixed;inset:0}.blog-studio{background:var(--surface);border:1px solid var(--border-hover);border-radius:var(--radius-lg,16px);flex-direction:column;width:min(1080px,96vw);height:min(760px,92vh);display:flex;overflow:hidden;box-shadow:0 30px 80px #0009}.blog-studio__head{border-bottom:1px solid var(--border);background:color-mix(in srgb, var(--surface-2) 86%, transparent);-webkit-backdrop-filter:blur(12px);flex-shrink:0;align-items:center;gap:.7rem;padding:.7rem .85rem;display:flex}.blog-studio__mark{width:34px;height:34px;color:var(--accent);background:var(--accent-dim);border:1px solid color-mix(in srgb, var(--accent) 24%, transparent);border-radius:10px;flex-shrink:0;place-items:center;display:grid}.blog-studio__identity{flex-direction:column;gap:1px;min-width:0;display:flex}.blog-studio__name{font-family:var(--fd);letter-spacing:-.01em;color:var(--text);font-size:.95rem;font-weight:700;line-height:1.2}.blog-studio__status{color:var(--muted);align-items:center;gap:6px;font-size:.7rem;line-height:1.2;display:flex}.blog-studio__dot{background:var(--accent);width:6px;height:6px;box-shadow:0 0 7px var(--accent-glow);border-radius:50%;animation:2.4s ease-in-out infinite blog-dot-pulse}.blog-studio__dot.is-busy{animation-duration:.9s}.blog-studio__source{flex-wrap:wrap;justify-content:flex-end;gap:.4rem;margin-left:auto;display:flex}.blog-studio__source button{border-radius:var(--r-md,10px);border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-body);font-size:.8rem;font-weight:600;font-family:var(--fb);cursor:pointer;transition:var(--tf);align-items:center;gap:.35rem;padding:.4rem .65rem;display:inline-flex}.blog-studio__source button:hover:not(:disabled){color:var(--text);border-color:var(--border-hover)}.blog-studio__source button.is-active{color:var(--accent);border-color:var(--accent);background:var(--accent-dim)}.blog-studio__source button:disabled{opacity:.5;cursor:not-allowed}.blog-studio__close{width:32px;height:32px;color:var(--muted);cursor:pointer;transition:var(--tf);background:0 0;border:1px solid #0000;border-radius:9px;flex-shrink:0;place-items:center;display:grid}.blog-studio__close:hover{background:var(--surface-hover);border-color:var(--border);color:var(--text)}.blog-studio__docs{border-bottom:1px solid var(--border);background:var(--surface-2);flex-direction:column;flex-shrink:0;gap:.5rem;padding:.7rem .85rem;display:flex}.blog-studio__docsearch{border-radius:var(--r-md,10px);border:1px solid var(--input-border);background:var(--input-bg);color:var(--text);font-family:var(--fb);padding:.5rem .65rem;font-size:.85rem}.blog-studio__docsearch:focus{border-color:var(--accent);box-shadow:var(--glow-input);outline:none}.blog-studio__doclist{scrollbar-width:thin;scrollbar-color:var(--border-hover) transparent;flex-direction:column;gap:.5rem;max-height:220px;display:flex;overflow-y:auto}.blog-studio__docgroup{flex-direction:column;gap:2px;display:flex}.blog-studio__docdir{font-family:var(--fm);text-transform:uppercase;letter-spacing:.08em;color:var(--muted2);background:var(--surface-2);z-index:1;padding:.25rem .3rem;font-size:.68rem;position:sticky;top:0}.blog-studio__docitem{text-align:left;border-radius:var(--r-md,10px);width:100%;color:var(--text-body);font-family:var(--fb);cursor:pointer;transition:var(--tf);background:0 0;border:1px solid #0000;align-items:center;gap:.55rem;padding:.45rem .55rem;font-size:.85rem;display:flex}.blog-studio__docitem:hover{background:var(--surface-hover);border-color:var(--border);color:var(--text)}.blog-studio__docicon{font-family:var(--fm);color:var(--accent);flex-shrink:0;font-size:.8rem}.blog-studio__docname{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.blog-studio__paste{border-bottom:1px solid var(--border);background:var(--surface-2);flex-direction:column;flex-shrink:0;gap:.5rem;padding:.7rem .85rem;display:flex}.blog-studio__paste textarea{resize:vertical;border-radius:var(--r-md,10px);border:1px solid var(--input-border);background:var(--input-bg);min-height:90px;color:var(--text);font-family:var(--fb);padding:.5rem .65rem;font-size:.88rem}.blog-studio__paste textarea:focus{border-color:var(--accent);box-shadow:var(--glow-input);outline:none}.blog-studio__paste .blog-btn{align-self:flex-start}.blog-studio__error{border:1px solid color-mix(in srgb, var(--error) 45%, transparent);border-radius:var(--r-md,10px);background:color-mix(in srgb, var(--error) 12%, transparent);color:var(--text);flex-shrink:0;align-items:flex-start;gap:.5rem;padding:.55rem .7rem;font-size:.82rem;line-height:1.4;display:flex}.blog-studio__error-icon{color:var(--error);flex-shrink:0}.blog-studio__error-text{flex:1;min-width:0}.blog-studio__error-close{color:var(--text-body);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0 .15rem;font-size:1.1rem;line-height:1}.blog-studio__error-close:hover{color:var(--text)}.blog-studio__body{flex:1;min-height:0;display:flex}.blog-studio__chat{border-right:1px solid var(--border);flex-direction:column;flex:55%;gap:.75rem;min-width:0;padding:1rem;display:flex}.blog-studio__draft{background:var(--bg);flex-direction:column;flex:45%;gap:.6rem;min-width:0;padding:1rem;display:flex;overflow-y:auto}.blog-studio__transcript{scrollbar-width:thin;scrollbar-color:var(--border-hover) transparent;flex-direction:column;flex:1;gap:1rem;padding-right:.25rem;display:flex;overflow-y:auto}.blog-studio__empty{text-align:center;max-width:320px;color:var(--muted);flex-direction:column;align-items:center;gap:.75rem;margin:auto;font-size:.85rem;line-height:1.5;display:flex}.blog-studio__empty-mark{width:44px;height:44px;color:var(--accent);background:var(--accent-dim);border:1px solid color-mix(in srgb, var(--accent) 22%, transparent);border-radius:13px;place-items:center;display:grid}.blog-studio__msg{align-items:flex-start;gap:10px;animation:.28s cubic-bezier(.22,1,.36,1) both blog-msg-in;display:flex}.blog-studio__msg--user{justify-content:flex-end}.blog-studio__avatar{width:28px;height:28px;color:var(--accent);background:var(--accent-dim);border:1px solid color-mix(in srgb, var(--accent) 22%, transparent);border-radius:8px;flex-shrink:0;place-items:center;margin-top:1px;display:grid}.blog-studio__bubble{font-family:var(--fb);color:var(--text);white-space:pre-wrap;word-break:break-word;overflow-wrap:anywhere;font-size:.9rem;line-height:1.6}.blog-studio__msg--assistant .blog-studio__bubble{background:color-mix(in srgb, var(--accent) 7%, var(--surface-2));border:1px solid color-mix(in srgb, var(--accent) 14%, var(--border));border-radius:5px 14px 14px;max-width:88%;padding:11px 14px}.blog-studio__msg--user .blog-studio__bubble{background:var(--surface-3);border:1px solid var(--border);border-radius:14px 14px 6px;max-width:88%;padding:10px 14px}.blog-studio__bubble--md{white-space:normal}.blog-studio__bubble--md>:first-child{margin-top:0}.blog-studio__bubble--md>:last-child{margin-bottom:0}.blog-studio__bubble--md p{margin:0 0 .5rem}.blog-studio__bubble--md ul,.blog-studio__bubble--md ol{margin:.25rem 0 .5rem;padding-left:1.25rem}.blog-studio__bubble--md li{margin:.15rem 0}.blog-studio__bubble--md a{color:var(--accent);text-decoration:underline}.blog-studio__bubble--md code{font-family:var(--fm);background:color-mix(in srgb, var(--text) 10%, transparent);border-radius:4px;padding:.1em .35em;font-size:.85em}.blog-studio__bubble--md pre{background:color-mix(in srgb, var(--text) 8%, transparent);border-radius:8px;margin:.35rem 0;padding:.6rem .7rem;overflow-x:auto}.blog-studio__bubble--md pre code{background:0 0;padding:0}.blog-studio__bubble--md h1,.blog-studio__bubble--md h2,.blog-studio__bubble--md h3{margin:.5rem 0 .25rem;font-size:1rem}.blog-studio__bubble--typing{align-items:center;gap:4px;display:inline-flex}.blog-studio__bubble--typing span{background:var(--muted);border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite blog-typing}.blog-studio__bubble--typing span:nth-child(2){animation-delay:.15s}.blog-studio__bubble--typing span:nth-child(3){animation-delay:.3s}.blog-studio__composer{background:var(--input-bg);border:1.5px solid var(--input-border);transition:var(--tf);border-radius:20px;flex-shrink:0;align-items:flex-end;gap:8px;padding:6px 6px 6px 14px;display:flex}.blog-studio__composer:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);background:var(--surface)}.blog-studio__composer textarea{resize:none;min-width:0;color:var(--text);font-family:var(--fb);background:0 0;border:none;outline:none;flex:1;min-height:22px;max-height:180px;padding:8px 0;font-size:.92rem;line-height:1.5;overflow-y:auto}.blog-studio__composer textarea::placeholder{color:var(--muted2)}.blog-studio__send{background:var(--accent);color:#08090c;cursor:pointer;width:36px;height:36px;transition:var(--tf);border:none;border-radius:50%;flex-shrink:0;place-items:center;display:grid}.blog-studio__send:hover:not(:disabled){filter:brightness(1.06);box-shadow:0 0 18px var(--accent-glow);transform:translateY(-1px)}.blog-studio__send:active:not(:disabled){transform:scale(.94)}.blog-studio__send:disabled{background:var(--surface-3);color:var(--muted2);cursor:not-allowed}.blog-studio__spinner{border:2px solid #08090c40;border-top-color:#08090c;border-radius:50%;width:16px;height:16px;animation:.7s linear infinite spin}.blog-studio__draft-body{font-size:.9rem}.blog-studio__draft-title{font-family:var(--fd);margin:.25rem 0}.blog-studio__draft-summary{color:var(--muted);margin-bottom:.75rem;font-style:italic}.blog-studio__hint{color:var(--muted);font-size:.8rem}.blog-studio__foot{border-top:1px solid var(--border);background:var(--surface-2);flex-shrink:0;justify-content:space-between;align-items:center;gap:.75rem;padding:.7rem .85rem;display:flex}.blog-studio__foot-hint{color:var(--muted2);font-size:.7rem}.blog-studio__foot-hint kbd{font-family:var(--fm);background:var(--surface);border:1px solid var(--border);color:var(--muted);border-radius:4px;padding:1px 5px;font-size:.66rem}.blog-studio__foot-actions{gap:.5rem;display:flex}.blog-editor__ai-prompt{gap:.5rem;margin:.4rem 0;display:flex}.blog-editor__ai-prompt input{border-radius:var(--r-md,10px);border:1px solid var(--input-border);background:var(--input-bg);color:var(--text);font-family:var(--fb);flex:1;padding:.45rem .6rem;font-size:.88rem}.blog-editor__ai-prompt input:focus{border-color:var(--accent);box-shadow:var(--glow-input);outline:none}@media (width<=760px){.blog-studio__backdrop{padding:0}.blog-studio{border:none;border-radius:0;width:100vw;height:100dvh}.blog-studio__body{flex-direction:column}.blog-studio__chat{border-right:none;border-bottom:1px solid var(--border);flex:auto}.blog-studio__draft{flex:none;max-height:38vh}.blog-studio__foot{flex-direction:column;align-items:stretch}.blog-studio__foot-hint{display:none}.blog-studio__foot-actions{justify-content:stretch}.blog-studio__foot-actions .blog-btn{text-align:center;flex:1}}.usage-counter{background:var(--surface-2);border:1px solid var(--border);font-family:var(--font-body);color:var(--muted);white-space:nowrap;transition:background var(--transition-theme), border-color var(--transition-theme), color var(--transition-theme);border-radius:100px;align-items:center;gap:8px;padding:4px 10px;font-size:.72rem;display:inline-flex}.usage-counter__label{color:var(--muted);font-weight:500}.usage-counter__label strong{color:var(--text);font-weight:700}.usage-bar{background:var(--surface-3);border-radius:100px;flex-shrink:0;width:46px;height:4px;display:block;overflow:hidden}.usage-fill{background:var(--accent);border-radius:100px;height:100%;transition:width .3s,background-color .3s;display:block}.usage-counter.is-warning{border-color:var(--warn-dim)}.usage-counter.is-warning .usage-fill{background:var(--warn)}.usage-counter.is-full{border-color:var(--error-dim);color:var(--error)}.usage-counter.is-full .usage-fill{background:var(--error)}.usage-counter--unlimited{color:var(--accent);border-color:color-mix(in srgb, var(--accent) 26%, transparent);background:var(--accent-dim)}.usage-counter__icon{color:var(--accent);font-size:.95rem;line-height:1}.usage-counter--unlimited .usage-counter__label{color:var(--accent);font-weight:600}.conv{text-align:left;background:var(--surface);border:1px solid var(--border);width:min(1080px,96vw);max-width:100%;min-height:0;max-height:1100px;transition:background var(--transition-theme), border-color var(--transition-theme);border-radius:24px;outline:none;flex-direction:column;flex:auto;animation:.4s cubic-bezier(.22,1,.36,1) conv-enter;display:flex;overflow:hidden;box-shadow:inset 0 1px #ffffff08,0 24px 70px #0000008c}[data-theme=light] .conv{box-shadow:inset 0 1px #fff9,0 18px 50px #00000024}@keyframes conv-enter{0%{opacity:0;transform:translateY(14px)scale(.99)}to{opacity:1;transform:translateY(0)scale(1)}}.conv__topbar{border-bottom:1px solid var(--border);background:color-mix(in srgb, var(--surface) 86%, transparent);-webkit-backdrop-filter:blur(12px);transition:border-color var(--transition-theme), background var(--transition-theme);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px 12px 16px;display:flex}.conv__identity{align-items:center;gap:10px;min-width:0;display:flex}.conv__identity-mark{width:32px;height:32px;color:var(--accent);background:var(--accent-dim);border:1px solid color-mix(in srgb, var(--accent) 24%, transparent);border-radius:10px;flex-shrink:0;place-items:center;display:grid}.conv__identity-text{flex-direction:column;gap:1px;min-width:0;display:flex}.conv__identity-name{font-family:var(--font-display);letter-spacing:-.01em;color:var(--text);font-size:.92rem;font-weight:700;line-height:1.2}.conv__identity-status{color:var(--muted);align-items:center;gap:6px;font-size:.7rem;line-height:1.2;display:flex}.conv__status-dot{background:var(--accent);width:6px;height:6px;box-shadow:0 0 7px var(--accent-glow);border-radius:50%;animation:2.4s ease-in-out infinite dot-pulse}.conv__status-dot.is-busy{animation-duration:.9s}@keyframes dot-pulse{0%,to{opacity:1;box-shadow:0 0 5px var(--accent-glow)}50%{opacity:.55;box-shadow:0 0 12px var(--accent-glow)}}.conv__close{width:32px;height:32px;color:var(--muted);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);background:0 0;border:1px solid #0000;border-radius:9px;flex-shrink:0;place-items:center;display:grid}.conv__close:hover:not(:disabled){background:var(--surface-hover);border-color:var(--border);color:var(--text)}.conv__close:disabled{opacity:.35;cursor:not-allowed}.conv__scroll{overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:var(--border-hover) transparent;flex:1;min-height:0;padding:26px 0 10px;overflow-y:auto}.conv__scroll::-webkit-scrollbar{width:8px}.conv__scroll::-webkit-scrollbar-track{background:0 0}.conv__scroll::-webkit-scrollbar-thumb{background:var(--border-hover);background-clip:padding-box;border:2px solid #0000;border-radius:8px}.conv__thread{flex-direction:column;gap:26px;width:100%;max-width:800px;margin:0 auto;padding:0 24px;display:flex}.conv__anchor{height:1px}.conv__msg{align-items:flex-start;gap:13px;animation:.28s cubic-bezier(.22,1,.36,1) both msg-in;display:flex}@keyframes msg-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.conv__msg--assistant .conv__msg-content{max-width:100%}.conv__msg--user{justify-content:flex-end}.conv__msg--user .conv__msg-content{justify-content:flex-end;max-width:80%;display:flex}.conv__msg-avatar{width:30px;height:30px;color:var(--accent);background:var(--accent-dim);border:1px solid color-mix(in srgb, var(--accent) 22%, transparent);border-radius:9px;flex-shrink:0;place-items:center;margin-top:1px;display:grid}.conv__msg-content{min-width:0}.conv__msg-bubble{font-family:var(--font-body);color:var(--text);word-break:break-word;overflow-wrap:anywhere;font-size:.95rem;line-height:1.7}.conv__msg--assistant .conv__msg-bubble{background:color-mix(in srgb, var(--accent) 7%, var(--surface-2));border:1px solid color-mix(in srgb, var(--accent) 14%, var(--border));border-radius:5px 16px 16px;padding:13px 16px;box-shadow:0 1px 2px #0000002e}[data-theme=light] .conv__msg--assistant .conv__msg-bubble{box-shadow:0 1px 3px #0000000f}.conv__msg--user .conv__msg-bubble{background:var(--surface-3);border:1px solid var(--border);white-space:pre-wrap;border-radius:16px 16px 6px;padding:11px 16px}.conv__msg.is-streaming .conv__msg-avatar{animation:1.6s ease-in-out infinite avatar-glow}@keyframes avatar-glow{0%,to{box-shadow:0 0 #0000}50%{box-shadow:0 0 0 4px var(--accent-dim)}}.conv__msg-bubble>:first-child{margin-top:0}.conv__msg-bubble>:last-child{margin-bottom:0}.conv__msg-bubble p{margin:0 0 .7em}.conv__msg-bubble ul,.conv__msg-bubble ol{margin:.5em 0 .7em 1.25em;padding:0}.conv__msg-bubble li{margin:.25em 0}.conv__msg-bubble h1{letter-spacing:-.01em;margin:.9em 0 .4em;font-size:1.2em;font-weight:700}.conv__msg-bubble h2{margin:.8em 0 .35em;font-size:1.1em;font-weight:700}.conv__msg-bubble h3{margin:.7em 0 .3em;font-size:1em;font-weight:700}.conv__msg-bubble h4,.conv__msg-bubble h5,.conv__msg-bubble h6{color:var(--muted);margin:.6em 0 .25em;font-size:.95em;font-weight:600}.conv__msg-bubble strong{color:var(--text);font-weight:700}.conv__msg-bubble em{font-style:italic}.conv__msg-bubble del{opacity:.55;text-decoration:line-through}.conv__cursor{background:var(--accent);vertical-align:text-bottom;border-radius:1px;width:2px;height:1.05em;margin-left:2px;animation:.9s step-end infinite blink;display:inline-block}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.conv__action{flex-direction:column;gap:8px;padding-top:3px;display:flex}.conv__action-signup{display:flex}.conv__msg-bubble>.conv__action-signup:not(:first-child){margin-top:10px}.conv__inline-link{background:var(--accent-dim);border:1px solid color-mix(in srgb, var(--accent) 28%, transparent);color:var(--accent);transition:background var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);border-radius:9px;align-items:center;gap:6px;margin:3px 0;padding:6px 12px;font-size:.85rem;font-weight:600;line-height:1.3;text-decoration:none;display:inline-flex}.conv__inline-link:hover{background:color-mix(in srgb, var(--accent) 20%, transparent);border-color:var(--accent);transform:translateY(-1px)}.conv__inline-link svg{flex-shrink:0}.conv__link-card{background:var(--surface-2);border:1px solid var(--border);width:100%;max-width:380px;transition:background var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);border-radius:14px;align-items:center;gap:13px;padding:12px 14px;text-decoration:none;display:flex}.conv__link-card:hover{background:var(--surface-3);border-color:color-mix(in srgb, var(--accent) 50%, var(--border));transform:translateY(-2px);box-shadow:0 8px 24px #00000047}.conv__link-card__icon{width:40px;height:40px;color:var(--accent);background:var(--accent-dim);border:1px solid color-mix(in srgb, var(--accent) 22%, transparent);transition:transform var(--transition-fast);border-radius:11px;flex-shrink:0;place-items:center;display:grid}.conv__link-card:hover .conv__link-card__icon{transform:scale(1.06)}.conv__link-card__text{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.conv__link-card__title{font-family:var(--font-display);color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:700;line-height:1.25;overflow:hidden}.conv__link-card__sub{color:var(--muted);font-size:.76rem;line-height:1.3}.conv__link-card__arrow{color:var(--muted2);transition:transform var(--transition-fast), color var(--transition-fast);flex-shrink:0;place-items:center;display:grid}.conv__link-card:hover .conv__link-card__arrow{color:var(--accent);transform:translate(3px)}.conv__link-card--premium{background:#ffc10714;border-color:#ffc10742}.conv__link-card--premium:hover{background:#ffc10721;border-color:#ffc1078c}.conv__link-card--premium .conv__link-card__icon{color:#ffc107;background:#ffc10724;border-color:#ffc1074d}.conv__link-card--premium:hover .conv__link-card__arrow{color:#ffc107}.conv__footer{border-top:1px solid var(--border);background:color-mix(in srgb, var(--surface) 92%, transparent);transition:border-color var(--transition-theme), background var(--transition-theme);flex-shrink:0}.conv__inner{width:100%;max-width:800px;margin:0 auto;padding:14px 24px 16px}.conv__usage{margin-bottom:10px}.conv__composer{background:var(--input-bg);border:1.5px solid var(--input-border);transition:border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-theme);border-radius:22px;align-items:flex-end;gap:8px;padding:7px 7px 7px 16px;display:flex}.conv__composer:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);background:var(--surface)}.conv__composer.is-streaming{opacity:.85}.conv__composer-input{resize:none;min-width:0;color:var(--text);font-family:var(--font-body);scrollbar-width:thin;scrollbar-color:var(--border) transparent;background:0 0;border:none;outline:none;flex:1;min-height:24px;max-height:200px;padding:9px 0;font-size:.95rem;line-height:1.55;overflow-y:auto}.conv__composer-input::placeholder{color:var(--muted2)}.conv__composer-input:disabled{cursor:not-allowed}.conv__composer-send{background:var(--accent);color:#08090c;cursor:pointer;width:38px;height:38px;transition:transform var(--transition-fast), box-shadow var(--transition-fast), filter var(--transition-fast), opacity var(--transition-fast);border:none;border-radius:50%;flex-shrink:0;place-items:center;display:grid}.conv__composer-send svg{width:17px;height:17px}.conv__composer-send:hover:not(:disabled){filter:brightness(1.06);box-shadow:0 0 18px var(--accent-glow);transform:translateY(-1px)}.conv__composer-send:active:not(:disabled){transform:scale(.94)}.conv__composer-send:disabled{background:var(--surface-3);color:var(--muted2);cursor:not-allowed}.conv__composer-send.is-busy{cursor:progress}.conv__composer-hint{text-align:center;color:var(--muted2);margin:9px 0 0;font-size:.7rem;line-height:1.4}.conv__composer-hint kbd{font-family:var(--font-mono);background:var(--surface-2);border:1px solid var(--border);color:var(--muted);border-radius:4px;padding:1px 5px;font-size:.66rem}.conv__spinner{border:2px solid #08090c40;border-top-color:#08090c;border-radius:50%;width:16px;height:16px;animation:.7s linear infinite spin;display:block}.conv__limit-card{text-align:center;background:linear-gradient(135deg, var(--accent-dim) 0%, transparent 70%);border:1px solid color-mix(in srgb, var(--accent) 22%, transparent);border-radius:16px;flex-direction:column;align-items:center;gap:12px;padding:22px 24px 24px;animation:.3s ease-out msg-in;display:flex}.conv__limit-icon{background:var(--accent-dim);border:1px solid color-mix(in srgb, var(--accent) 30%, transparent);width:34px;height:34px;color:var(--accent);border-radius:50%;place-items:center;font-size:.9rem;display:grid}.conv__limit-text{max-width:420px;color:var(--text-body);margin:0;font-size:.9rem;line-height:1.6}.conv__cta-btn{background:var(--accent);color:#08090c;font-family:var(--font-display);letter-spacing:.01em;cursor:pointer;white-space:nowrap;transition:transform var(--transition-fast), box-shadow var(--transition-fast), filter var(--transition-fast);border:none;border-radius:11px;padding:11px 22px;font-size:.875rem;font-weight:700}.conv__cta-btn:hover{box-shadow:0 8px 26px var(--accent-glow);filter:brightness(1.06);transform:translateY(-2px)}.conv__cta-btn:active{transform:scale(.97)}@media (width>=1280px){.conv{width:min(1180px,92vw);max-height:1160px}}@media (width<=768px){.conv{border-radius:20px}.conv__thread{max-width:680px;padding:0 20px}.conv__inner{max-width:680px;padding-left:20px;padding-right:20px}}@media (width<=640px){.conv{left:0;right:0;top:var(--vv-top,0px);width:100%;height:var(--vvh,100dvh);z-index:110;border-left:none;border-right:none;border-radius:0;min-height:0;max-height:none;position:fixed}.conv__topbar{gap:8px;padding:10px 12px}.conv__identity{flex:1;justify-content:center}.conv__sidebar-toggle{opacity:.85;background:color-mix(in srgb, var(--text) 5%, transparent);border-radius:10px;flex-shrink:0;width:38px;height:38px}.conv__sidebar-toggle:active{background:color-mix(in srgb, var(--text) 12%, transparent)}.conv__close{flex-shrink:0;width:38px;height:38px}.conv__scroll{padding:18px 0 6px}.conv__thread{gap:20px;padding:0 14px}.conv__inner{padding:12px 14px max(14px, env(safe-area-inset-bottom,12px))}.conv__msg--user .conv__msg-content{max-width:86%}.conv__composer{border-radius:20px;padding-left:14px}.conv__composer-input{font-size:16px}.conv__composer-send{width:36px;height:36px}.conv__composer-hint{font-size:.66rem}}@media (width<=420px){.conv__msg{gap:10px}.conv__msg-avatar{border-radius:8px;width:26px;height:26px}.conv__identity-status{display:none}}@media (height<=520px) and (width<=1024px){.conv{border-radius:12px;min-height:0}.conv__scroll{padding:12px 0 4px}.conv__thread{gap:14px}.conv__composer-hint{display:none}}.md-pre-wrap{border:1px solid var(--border);background:var(--surface-2);border-radius:10px;margin:.7em 0;position:relative;overflow:hidden}.md-pre-lang{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:var(--accent-dim);border-bottom:1px solid var(--border);-webkit-user-select:none;user-select:none;padding:5px 13px;font-size:.66rem;font-weight:700;display:block}.md-pre{scrollbar-width:thin;scrollbar-color:var(--border-hover) transparent;background:0 0;border:none;margin:0;padding:13px 14px;overflow-x:auto}.md-pre::-webkit-scrollbar{height:6px}.md-pre::-webkit-scrollbar-track{background:0 0}.md-pre::-webkit-scrollbar-thumb{background:var(--border-hover);border-radius:3px}.md-pre code{font-family:var(--font-mono);color:var(--text);background:0 0;border:none;padding:0;font-size:.82em;line-height:1.7}.md-code--inline{font-family:var(--font-mono);background:var(--accent-dim);border:1px solid color-mix(in srgb, var(--accent) 16%, transparent);color:var(--accent);border-radius:5px;padding:.12em .42em;font-size:.84em}.md-table-wrap{border:1px solid var(--border);-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--border-hover) transparent;border-radius:10px;margin:.7em 0;overflow-x:auto}.md-table{border-collapse:collapse;width:100%;min-width:240px}.md-table th{text-align:left;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);background:var(--surface-2);border-bottom:1px solid var(--border);white-space:nowrap;padding:9px 14px;font-size:.73em;font-weight:700}.md-table td{border-bottom:1px solid var(--border);color:var(--text);padding:9px 14px;font-size:.9em;line-height:1.5}.md-table tr:last-child td{border-bottom:none}.md-table tr:hover td{background:var(--surface-hover)}.md-blockquote{border-left:3px solid var(--accent);background:var(--accent-dim);color:var(--text-body);border-radius:0 8px 8px 0;margin:.6em 0;padding:10px 15px}.md-blockquote p{margin:0;font-style:italic}.md-blockquote p+p{margin-top:.4em}.md-link{color:var(--accent);border-bottom:1px solid color-mix(in srgb, var(--accent) 35%, transparent);transition:border-color var(--transition-fast), opacity var(--transition-fast);text-decoration:none}.md-link:hover{border-bottom-color:var(--accent);opacity:.85}.md-link:active{opacity:.65}.md-hr{border:none;border-top:1px solid var(--border);margin:.9em 0}.chat-room-card{background:var(--surface-2);border:1px solid var(--border);transition:transform var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);border-radius:14px;text-decoration:none;display:block;position:relative;overflow:hidden}.chat-room-card:hover{border-color:var(--level-color,var(--accent));box-shadow:0 8px 28px #00000059, 0 0 24px var(--level-glow,var(--accent-glow));transform:translateY(-2px)}.chat-room-card:hover .chat-room-card__arrow{opacity:1;transform:translate(3px)}.chat-room-card:hover .chat-room-card__shine{opacity:1}.chat-room-card__inner{z-index:1;padding:12px 14px;position:relative}.chat-room-card__top{justify-content:space-between;align-items:center;gap:8px;margin-bottom:7px;display:flex}.chat-room-card__name{font-family:var(--font-display);color:var(--text);font-size:.9rem;font-weight:700;line-height:1.3}.chat-room-card__badge{letter-spacing:.04em;text-transform:uppercase;color:var(--level-color,var(--muted));background:var(--surface-3);border:1px solid var(--border);white-space:nowrap;border-radius:6px;flex-shrink:0;align-items:center;gap:4px;padding:3px 7px;font-size:.68rem;font-weight:700;display:flex}.chat-room-card__badge-icon{font-size:.75rem}.chat-room-card__footer{justify-content:space-between;align-items:center;display:flex}.chat-room-card__age{color:var(--muted);align-items:center;gap:5px;font-size:.75rem;display:flex}.chat-room-card__arrow{color:var(--level-color,var(--accent));opacity:0;transition:opacity var(--transition-fast), transform var(--transition-fast);font-size:.85rem}.chat-room-card__summary{color:var(--text-body);margin:7px 0 0;font-size:.79rem;line-height:1.55}.chat-room-card__shine{opacity:0;transition:opacity var(--transition-fast);pointer-events:none;z-index:0;background:linear-gradient(135deg,#0000 30%,#ffffff0a 50%,#0000 70%);position:absolute;inset:0}.conv__sidebar-toggle{width:30px;height:30px;color:var(--text);opacity:.65;cursor:pointer;background:0 0;border:none;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;transition:opacity .15s,background .15s;display:flex}.conv__sidebar-toggle:hover{opacity:1;background:color-mix(in srgb, var(--text) 8%, transparent)}.conv-shell .conv{box-shadow:none;border:none;border-radius:0;flex:1;width:100%;min-width:0;max-width:100%;animation:none}.conv-shell{background:var(--surface);border:1px solid var(--border);width:min(1080px,96vw);max-width:100%;min-height:0;max-height:1100px;transition:background var(--transition-theme), border-color var(--transition-theme);border-radius:24px;flex:auto;animation:.4s cubic-bezier(.22,1,.36,1) conv-enter;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffff08,0 24px 70px #0000008c}[data-theme=light] .conv-shell{box-shadow:inset 0 1px #fff9,0 18px 50px #00000024}.conv-shell__sidebar{border-right:1px solid var(--border);background:color-mix(in srgb, var(--surface) 82%, transparent);flex-direction:column;flex-shrink:0;width:240px;transition:width .22s,opacity .22s,border-right-width .22s;display:flex;overflow:hidden}[data-sidebar-open=false] .conv-shell__sidebar{opacity:0;pointer-events:none;border-right-width:0;width:0}.conv-shell__new-chat{border:1px solid var(--border);color:var(--text);cursor:pointer;white-space:nowrap;background:0 0;border-radius:8px;flex-shrink:0;align-items:center;gap:8px;margin:12px 10px 6px;padding:7px 12px;font-size:13px;font-weight:500;transition:background .15s,border-color .15s;display:flex}.conv-shell__new-chat:hover{background:color-mix(in srgb, var(--accent,#7c6af7) 9%, transparent);border-color:var(--accent,#7c6af7)}.conv-shell__conv-list{scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex-direction:column;flex:1;gap:1px;padding:4px 6px 16px;display:flex;overflow-y:auto}.conv-shell__conv-item{border-radius:8px;align-items:center;min-height:36px;padding:0 2px 0 6px;transition:background .14s;display:flex;position:relative}.conv-shell__conv-item:hover,.conv-shell__conv-item:focus-within{background:color-mix(in srgb, var(--text) 6%, transparent)}.conv-shell__conv-item.is-active{background:color-mix(in srgb, var(--accent,#7c6af7) 11%, transparent);border-left:2px solid var(--accent,#7c6af7);padding-left:4px}.conv-shell__conv-title{cursor:pointer;min-width:0;color:var(--text);text-align:left;white-space:nowrap;text-overflow:ellipsis;background:0 0;border:none;flex:1;padding:8px 4px 8px 0;font-size:13px;line-height:1.3;overflow:hidden}.conv-shell__conv-actions{flex-shrink:0;gap:1px;display:none}.conv-shell__conv-item:hover .conv-shell__conv-actions,.conv-shell__conv-item:focus-within .conv-shell__conv-actions{display:flex}.conv-shell__action-btn{width:26px;height:26px;color:var(--text);opacity:.55;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:opacity .15s,background .15s,color .15s;display:flex}.conv-shell__action-btn:hover{opacity:1;background:color-mix(in srgb, var(--text) 10%, transparent)}.conv-shell__action-btn--delete:hover{color:#e05555;opacity:1;background:#e055551f}.conv-shell__rename-input{background:color-mix(in srgb, var(--surface) 95%, transparent);border:1px solid var(--accent,#7c6af7);min-width:0;color:var(--text);border-radius:6px;outline:none;flex:1;padding:4px 7px;font-size:13px;transition:border-color .15s}.conv-shell__confirm{color:var(--text);white-space:nowrap;flex:1;align-items:center;gap:6px;padding:4px 2px;font-size:12px;display:flex}.conv-shell__confirm-yes,.conv-shell__confirm-no{border:1px solid var(--border);cursor:pointer;color:var(--text);background:0 0;border-radius:5px;padding:3px 9px;font-size:11px;font-weight:500;transition:background .15s,border-color .15s,color .15s}.conv-shell__confirm-yes:hover{color:#fff;background:#e05555;border-color:#e05555}.conv-shell__confirm-no:hover{background:color-mix(in srgb, var(--text) 8%, transparent)}.conv-shell__sidebar-header,.conv-shell__backdrop{display:none}@media (width<=639px){.conv-shell__sidebar{z-index:112;opacity:1;pointer-events:auto;border-right-width:1px;border-radius:0;width:min(72vw,256px);height:100%;transition:transform .28s cubic-bezier(.22,1,.36,1),opacity .22s;position:fixed;top:0;left:0;transform:translate(0);box-shadow:6px 0 32px #00000080}[data-sidebar-open=false] .conv-shell__sidebar{opacity:0;pointer-events:none;width:min(72vw,256px);transform:translate(-100%)}.conv-shell__sidebar-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 14px 12px;display:flex}.conv-shell__sidebar-title{letter-spacing:.07em;text-transform:uppercase;color:var(--muted);font-size:11px;font-weight:700}.conv-shell__sidebar-close{width:30px;height:30px;color:var(--text);opacity:.55;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:opacity .15s,background .15s;display:flex}.conv-shell__sidebar-close:hover{opacity:1;background:color-mix(in srgb, var(--text) 8%, transparent)}.conv-shell__conv-item{min-height:48px;padding:0 4px 0 10px}.conv-shell__conv-title{padding:12px 6px 12px 0;font-size:14px}.conv-shell__conv-actions{display:flex}.conv-shell__action-btn{opacity:.45;width:32px;height:32px}.conv-shell__new-chat{margin:12px 10px 8px;padding:10px 14px;font-size:14px}.conv-shell__backdrop{z-index:111;-webkit-backdrop-filter:blur(3px);background:#00000080;display:block;position:fixed;inset:0}.conv-shell .conv{border-radius:0}}.landing-main{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:clamp(16px,2.8vh,28px);min-height:0;padding:clamp(8px,1.5vh,16px) 0;display:flex}.dash-main:has(>.landing-main){padding-bottom:.75rem}html:has(.dash-main>.landing-main){overflow:hidden}.dash-page:has(.dash-main>.landing-main){height:100dvh;min-height:0;overflow:hidden}.dash-page:has(.dash-main>.landing-main) .dash-main{min-height:0;overflow:hidden}.tagline{flex-direction:column;align-items:center;gap:4px;display:flex}.tagline__static{font-family:var(--font-display);letter-spacing:-.025em;color:var(--text);font-size:clamp(2rem,5.5vw,3.8rem);font-weight:800;line-height:1.08}.tagline__dynamic-wrap{align-items:center;height:clamp(2.4rem,6vw,4.5rem);display:inline-flex;overflow:hidden}.tagline__dynamic{font-family:var(--font-display);letter-spacing:-.025em;color:var(--accent);filter:var(--glow-accent);opacity:0;white-space:nowrap;font-size:clamp(2rem,5.5vw,3.8rem);font-weight:800;line-height:1.08;transition:opacity .45s cubic-bezier(.4,0,.2,1),transform .45s cubic-bezier(.4,0,.2,1);transform:translateY(22px)}.tagline__dynamic.is-visible{opacity:1;transform:translateY(0)}.landing-subtitle{color:var(--muted);max-width:420px;transition:color var(--transition-theme);font-size:clamp(.85rem,1.8vw,1rem);font-weight:300;line-height:1.7}.input-shell{width:min(680px,90vw);position:relative}.input-shell__textarea{background:var(--input-bg);border:1.5px solid var(--input-border);width:100%;font-family:var(--font-body);color:var(--text);resize:none;scrollbar-width:thin;scrollbar-color:var(--border) transparent;min-height:56px;max-height:180px;transition:border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-theme);-webkit-backdrop-filter:blur(10px);border-radius:14px;outline:none;padding:16px 60px 16px 20px;font-size:.95rem;font-weight:400;line-height:1.6;overflow-y:auto}.input-shell__textarea::placeholder{color:var(--muted2)}.input-shell__textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim), 0 0 24px var(--accent-glow);background:var(--surface)}.input-shell__send{background:var(--accent);cursor:pointer;width:36px;height:36px;box-shadow:0 0 12px var(--accent-glow);transition:transform var(--transition-fast), box-shadow var(--transition-fast), filter var(--transition-fast);border:none;border-radius:9px;flex-shrink:0;place-items:center;display:grid;position:absolute;bottom:10px;right:10px}.input-shell__send:hover{box-shadow:0 0 22px var(--accent-glow);filter:brightness(1.1);transform:scale(1.08)translateY(-1px)}.input-shell__send:active{transform:scale(.96)}.input-shell__send svg{pointer-events:none;width:16px;height:16px}@keyframes send-flash{0%{box-shadow:0 0 0 0 var(--accent-glow)}50%{box-shadow:0 0 0 12px #0000}to{box-shadow:0 0 12px var(--accent-glow)}}.input-shell__send.did-send{animation:.45s ease-out send-flash}@media (width<=520px){.tagline__static,.tagline__dynamic{font-size:1.75rem}.tagline__dynamic-wrap{height:2.2rem}}.parcours-journey{box-sizing:border-box;grid-template-columns:292px 1fr;align-items:start;gap:2.5rem;width:100%;max-width:1080px;margin:0 auto;padding:2rem 2rem 5rem;display:grid}.pj-sidebar{flex-direction:column;gap:1.2rem;display:flex;position:sticky;top:1.5rem}.pj-back{font-size:.8rem;font-family:var(--font-body);color:var(--muted);letter-spacing:.01em;align-items:center;gap:.4rem;width:fit-content;text-decoration:none;transition:color .18s;display:inline-flex}.pj-back:hover{color:var(--text)}.pj-back__arrow{transition:transform .18s}.pj-back:hover .pj-back__arrow{transform:translate(-2px)}.pj-icon-wrap{background-color:var(--surface-2);background-image:radial-gradient(150% 95% at 50% -20%,#8b5cf68c 0%,#0000 55%),radial-gradient(80% 60% at -8% 110%,#6366f138 0%,#0000 55%);border:1px solid #8b5cf640;border-radius:18px;flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;font-size:2.2rem;line-height:1;display:flex;position:relative;overflow:hidden;box-shadow:0 6px 22px #8b5cf62e,0 2px 6px #00000029}.pj-icon-wrap:before{content:"";pointer-events:none;background-image:radial-gradient(circle,#ffffff14 1px,#0000 1px);background-size:12px 12px;animation:20s linear infinite pjDotDrift;position:absolute;inset:-10px;-webkit-mask-image:linear-gradient(#0000008c 0%,#0000 100%);mask-image:linear-gradient(#0000008c 0%,#0000 100%)}@keyframes pjDotDrift{0%{background-position:0 0}to{background-position:12px 12px}}.pj-title{font-family:var(--font-display,"Syne", sans-serif);color:var(--text);letter-spacing:-.015em;margin:0;font-size:1.35rem;font-weight:700;line-height:1.2}.pj-description{font-family:var(--font-body,"DM Sans", sans-serif);color:var(--text-body,#b8bccb);border:1px solid #8b5cf621;border-left:3px solid var(--p-accent,#8b5cf6);background:#8b5cf60d;border-radius:0 8px 8px 0;margin:0;padding:.85rem .95rem;font-size:.855rem;line-height:1.68}[data-theme=light] .pj-description{border-color:#7c3aed1a;border-left-color:var(--p-accent,#7c3aed);color:#111318ad;background:#7c3aed0a}.pj-divider{background:var(--border);flex-shrink:0;height:1px}.pj-meta{flex-wrap:wrap;gap:.4rem;display:flex}.pj-badge{font-size:.7rem;font-weight:600;font-family:var(--font-body);white-space:nowrap;letter-spacing:.01em;border-radius:100px;align-items:center;padding:.2rem .55rem;display:inline-flex}.pj-badge--niveau{background:var(--p-badge-bg,#8b5cf621);color:var(--p-accent,#8b5cf6);border:1px solid var(--p-badge-border,#8b5cf647)}.pj-badge--subject{color:var(--muted);border:1px solid var(--border);background:#b8bccb12}.pj-badge--rooms{color:var(--accent,#4af0c4);background:#4af0c412;border:1px solid #4af0c42e}[data-theme=light] .pj-badge--rooms{color:var(--accent,#00b386);background:#00b38612;border-color:#00b3862e}.pj-progress{flex-direction:column;gap:.42rem;display:flex}.pj-progress__header{font-size:.76rem;font-family:var(--font-body);color:var(--muted);justify-content:space-between;align-items:center;display:flex}.pj-progress__pct{color:var(--p-accent,#8b5cf6);font-weight:700}.pj-progress__track{background:var(--surface-3,#1a1d26);border-radius:100px;height:5px;overflow:hidden}.pj-progress__fill{background:linear-gradient(90deg, var(--p-accent,#8b5cf6) 0%, var(--p-accent-alt,#a78bfa) 100%);border-radius:100px;height:100%;transition:width .85s cubic-bezier(.4,0,.2,1);position:relative}.pj-progress__fill:after{content:"";background:linear-gradient(90deg,#0000,#ffffff38);border-radius:100px;width:18px;position:absolute;top:0;bottom:0;right:0}.pj-stats{flex-direction:column;gap:.28rem;display:flex}.pj-stat{font-size:.76rem;font-family:var(--font-body);color:var(--muted);justify-content:space-between;align-items:center;display:flex}.pj-stat__value{color:var(--text-body);font-weight:600}.pj-stat__value--done{color:var(--accent,#4af0c4)}.pj-stat__value--locked{color:var(--muted2)}.pj-path{flex-direction:column;min-width:0;display:flex}.pj-path__title{font-family:var(--font-display);letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:0 0 1.75rem;font-size:.68rem;font-weight:700}.pj-track{flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.pj-track__item{display:flex}.pj-track__rail{flex-direction:column;flex-shrink:0;align-items:center;width:40px;display:flex}.pj-node{width:32px;height:32px;font-size:.75rem;font-weight:700;font-family:var(--font-body);z-index:1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.pj-node--done{border:2px solid var(--accent,#4af0c4);color:var(--accent,#4af0c4);background:#4af0c417}.pj-node--available{background:var(--p-accent-dim,#8b5cf624);border:2px solid var(--p-accent,#8b5cf6);color:var(--p-accent,#8b5cf6);animation:2.6s ease-in-out infinite pjNodePulse}@keyframes pjNodePulse{0%,to{box-shadow:0 0 0 4px #8b5cf621}50%{box-shadow:0 0 0 9px #8b5cf608}}.pj-node--locked{background:var(--surface-2,#13151c);border:2px solid var(--border);color:var(--muted2)}.pj-node__check{font-size:.85rem;font-style:normal}.pj-node__lock{font-size:.65rem;font-style:normal}.pj-connector{flex-direction:column;flex:1;align-items:center;padding-top:3px;display:flex}.pj-connector__line{border-radius:1px;flex:1;width:2px;min-height:12px}.pj-connector__line--done{background:var(--accent,#4af0c4);opacity:.4}.pj-connector__line--transition{background:linear-gradient(to bottom, var(--accent,#4af0c4), var(--p-accent,#8b5cf6));opacity:.4}.pj-connector__line--available{background:var(--p-accent,#8b5cf6);opacity:.28}.pj-connector__line--locked{background:repeating-linear-gradient(to bottom, var(--border) 0px, var(--border) 4px, transparent 4px, transparent 9px)}.pj-connector__arrow{border-left:4px solid #0000;border-right:4px solid #0000;flex-shrink:0;width:0;height:0;margin-bottom:3px}.pj-connector__arrow--done{border-top:6px solid var(--accent,#4af0c4);opacity:.55}.pj-connector__arrow--transition{border-top:6px solid var(--p-accent,#8b5cf6);opacity:.55}.pj-connector__arrow--available{border-top:6px solid var(--p-accent,#8b5cf6);opacity:.38}.pj-connector__arrow--locked{border-top:6px solid var(--border);opacity:.7}.pj-track__card-col{flex:1;align-items:flex-start;min-width:0;padding-bottom:1.5rem;padding-left:.875rem;display:flex}.pj-track__item:last-child .pj-track__card-col{padding-bottom:0}.pj-card-link{border-radius:11px;outline:none;flex:1;min-width:0;text-decoration:none;transition:transform .2s;display:block}.pj-card-link--locked{pointer-events:none}.pj-card-link:focus-visible .pj-card{outline:2px solid var(--p-accent,#8b5cf6);outline-offset:2px}.pj-card{border:1px solid var(--border);background:var(--surface,#0f1116);border-radius:11px;align-items:stretch;height:72px;transition:border-color .22s,box-shadow .22s,transform .22s,opacity .22s;display:flex;position:relative;overflow:hidden}.pj-card--done{opacity:.78;border-color:#4af0c429}.pj-card-link:hover .pj-card--done{opacity:1;border-color:#4af0c461;transform:translateY(-1px);box-shadow:0 4px 16px #4af0c412}.pj-card--available{background:var(--surface-2,#13151c);border-color:#8b5cf652;box-shadow:0 0 0 1px #8b5cf612,0 4px 14px #8b5cf614}.pj-card-link:hover .pj-card--available{border-color:#8b5cf69e;transform:translateY(-2px);box-shadow:0 0 0 1px #8b5cf62e,0 8px 26px #8b5cf626}.pj-card--locked{opacity:.35;filter:saturate(.4)}.pj-card--available:before{content:"";pointer-events:none;z-index:0;background:linear-gradient(105deg,#0000 35%,#8b5cf60e 50%,#0000 65%) 0 0/250% 100%;animation:3.8s ease-in-out infinite pjCardShimmer;position:absolute;inset:0}@keyframes pjCardShimmer{0%{background-position:250% 0}to{background-position:-250% 0}}.pj-card__thumb{z-index:1;flex-shrink:0;justify-content:center;align-items:center;width:52px;font-size:1.5rem;line-height:1;display:flex;position:relative;overflow:hidden}.pj-card__thumb--done{background-color:var(--surface-2);background-image:radial-gradient(150% 100% at 50% -20%,#4af0c461 0%,#0000 55%),radial-gradient(80% 60% at -8% 110%,#10b9812e 0%,#0000 55%)}.pj-card__thumb--available{background-color:var(--surface-2);background-image:radial-gradient(150% 100% at 50% -20%,#8b5cf670 0%,#0000 55%),radial-gradient(80% 60% at -8% 110%,#6366f133 0%,#0000 55%)}.pj-card__thumb--locked{background-color:var(--surface-2)}.pj-card__thumb:before{content:"";pointer-events:none;background-image:radial-gradient(circle,#ffffff12 1px,#0000 1px);background-size:9px 9px;position:absolute;inset:-6px;-webkit-mask-image:linear-gradient(90deg,#0006 0%,#0000 100%);mask-image:linear-gradient(90deg,#0006 0%,#0000 100%)}.pj-card__sep{background:var(--border);z-index:1;flex-shrink:0;align-self:stretch;width:1px}.pj-card__body{z-index:1;flex-direction:column;flex:1;justify-content:center;gap:.18rem;min-width:0;padding:0 .9rem;display:flex}.pj-card__name{font-family:var(--font-display,"Syne", sans-serif);color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.87rem;font-weight:600;line-height:1.3;overflow:hidden}.pj-card__subject{color:var(--muted);font-size:.7rem;font-family:var(--font-body);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.pj-card__right{z-index:1;flex-shrink:0;align-items:center;gap:.35rem;padding:0 .875rem 0 .5rem;display:flex}.pj-chip{font-size:.66rem;font-weight:700;font-family:var(--font-body);white-space:nowrap;letter-spacing:.01em;border-radius:100px;padding:.16rem .5rem}.pj-chip--done{color:var(--accent,#4af0c4);background:#4af0c417;border:1px solid #4af0c433}.pj-chip--available{background:var(--p-badge-bg,#8b5cf621);color:var(--p-accent,#8b5cf6);border:1px solid var(--p-badge-border,#8b5cf647)}.pj-chip--locked{color:var(--muted2);border:1px solid var(--border);background:0 0}.pj-card__chevron{color:var(--p-accent,#8b5cf6);opacity:.65;font-size:1rem;font-weight:300;line-height:1;transition:transform .2s,opacity .2s}.pj-card-link:hover .pj-card__chevron{opacity:1;transform:translate(3px)}.pj-skeleton{animation:1.6s ease-in-out infinite pjSkeletonPulse}@keyframes pjSkeletonPulse{0%,to{opacity:1}50%{opacity:.42}}.pj-skel-block{background:var(--surface-2,#13151c);border-radius:8px}@media (width<=860px){.parcours-journey{grid-template-columns:1fr;gap:1.75rem;padding:1.5rem 1.25rem 3.5rem}.pj-sidebar{position:static}}@media (width<=640px){.parcours-journey{gap:1.5rem;padding:1rem 1rem 3rem}.pj-title{font-size:1.2rem}.pj-icon-wrap{border-radius:14px;width:60px;height:60px;font-size:1.9rem}.pj-track__rail{width:34px}.pj-node{width:28px;height:28px;font-size:.7rem}.pj-card{height:64px}.pj-card__thumb{width:44px;font-size:1.25rem}.pj-card__name{font-size:.82rem}.pj-card__right{padding-right:.625rem}.pj-chip{display:none}}.pj-pin-btn{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:8px;align-items:center;gap:.4rem;margin-bottom:.5rem;padding:.45rem .9rem;font-size:.8rem;transition:border-color .15s,color .15s,background .15s;display:inline-flex}.pj-pin-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.pj-pin-btn--active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.pj-pin-btn:disabled{opacity:.5;cursor:not-allowed}.pj-edit-btn{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:8px;align-items:center;gap:.4rem;margin-bottom:.5rem;padding:.45rem .9rem;font-size:.8rem;transition:border-color .15s,color .15s,background .15s;display:inline-flex}.pj-edit-btn:hover{border-color:var(--accent);color:var(--accent)}.comments-panel__backdrop{z-index:999;background:#00000080;animation:.2s comments-panel-fade-in;position:fixed;inset:0}@keyframes comments-panel-fade-in{0%{opacity:0}to{opacity:1}}.comments-panel{background:var(--surface);border-left:1px solid var(--border);z-index:1000;flex-direction:column;width:400px;height:100dvh;animation:.3s comments-panel-slide-in;display:flex;position:fixed;top:0;right:0;box-shadow:-2px 0 8px #0000001a}@keyframes comments-panel-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.comments-panel__header{border-bottom:1px solid var(--border);background:var(--surface-2);flex-shrink:0;justify-content:space-between;align-items:center;padding:1.25rem;display:flex}.comments-panel__room-info{flex:1;align-items:center;gap:.75rem;min-width:0;display:flex}.comments-panel__room-icon{flex-shrink:0;font-size:1.5rem}.comments-panel__room-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:1rem;font-weight:600;overflow:hidden}.comments-panel__close{cursor:pointer;color:var(--text);background:0 0;border:none;flex-shrink:0;padding:.5rem;font-size:1.5rem;line-height:1;transition:color .2s}.comments-panel__close:hover{color:var(--accent)}.comments-panel__tabs{border-bottom:1px solid var(--border);background:var(--surface-2);flex-shrink:0;gap:.5rem;padding:.75rem 1.25rem;display:flex;overflow-x:auto}.comments-panel__tab{color:var(--muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;padding:.5rem 1rem;font-size:.85rem;font-weight:500;transition:all .2s}.comments-panel__tab:hover{color:var(--text)}.comments-panel__tab--active{color:var(--accent);border-bottom-color:var(--accent)}.comments-panel__content{flex-direction:column;flex:1;display:flex;overflow-y:auto}.comments-panel__content::-webkit-scrollbar{width:6px}.comments-panel__content::-webkit-scrollbar-track{background:0 0}.comments-panel__content::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.comments-panel__content::-webkit-scrollbar-thumb:hover{background:var(--muted)}.comments-panel__empty{text-align:center;color:var(--muted);flex:1;justify-content:center;align-items:center;padding:2rem 1.25rem;font-size:.9rem;display:flex}.comments-panel__empty--error{color:var(--color-error,#c0392b)}.comments-panel__thread{flex-direction:column;gap:1rem;padding:1.25rem;display:flex}.comments-panel__comment{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);flex-direction:column;gap:.5rem;padding:1rem;display:flex}.comments-panel__comment-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;display:flex}.comments-panel__comment-author{color:var(--text);font-size:.9rem;font-weight:600}.comments-panel__comment-time{color:var(--muted);white-space:nowrap;font-size:.75rem}.comments-panel__comment-body{color:var(--text);white-space:pre-wrap;word-break:break-word;margin:0;font-size:.9rem;line-height:1.5}.comments-panel__comment-delete{color:var(--muted);cursor:pointer;background:0 0;border:none;align-self:flex-start;padding:.25rem 0;font-size:.75rem;transition:color .2s}.comments-panel__comment-delete:hover{color:#c0392b;text-decoration:underline}.comments-panel__footer{border-top:1px solid var(--border);background:var(--surface-2);flex-direction:column;flex-shrink:0;gap:.75rem;padding:1.25rem;display:flex}.comments-panel__textarea{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);width:100%;color:var(--text);resize:vertical;box-sizing:border-box;min-height:80px;max-height:200px;padding:.75rem;font-family:inherit;font-size:.85rem;line-height:1.5;transition:border-color .2s}.comments-panel__textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px rgba(var(--accent-rgb,0, 150, 255), .1);outline:none}.comments-panel__textarea:disabled{opacity:.6;cursor:not-allowed}.comments-panel__submit{background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;padding:.75rem 1.25rem;font-weight:600;transition:all .2s}.comments-panel__submit:hover:not(:disabled){filter:brightness(1.1);box-shadow:0 2px 4px #00000026}.comments-panel__submit:disabled{opacity:.5;cursor:not-allowed}@media (width<=768px){.comments-panel{width:100vw}.comments-panel__header,.comments-panel__footer{padding:1rem}.comments-panel__thread{gap:.75rem;padding:1rem}.comments-panel__comment{padding:.75rem}.comments-panel__textarea{font-size:16px}}:root{--error-dim:#ef444414}[data-theme=light]{--surface-3:#edeef2;--error-dim:#c9404014}body{background:var(--bg);color:var(--text);font-family:var(--fb);min-height:100vh;font-size:.9rem;line-height:1.6;overflow:hidden auto}.mono{font-family:var(--fm)!important;font-size:.8rem!important}.mt6{margin-top:6px}.mt10{margin-top:10px}.flex-gap{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.drag-handle.section-drag-handle{cursor:grab}.page--builder{padding:0}.builder-toolbar{top:calc(var(--header-h) + var(--user-nav-h));z-index:99;background:var(--surface-2);border-bottom:1px solid var(--border);height:52px;transition:background var(--transition-theme), border-color var(--transition-theme);grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;padding:0 clamp(12px,3vw,40px);display:grid;position:sticky}.builder-toolbar__left{align-items:center;gap:8px;min-width:0;display:flex}.builder-toolbar__center{justify-content:center;align-items:center;display:flex}.builder-toolbar__actions{justify-content:flex-end;align-items:center;gap:6px;display:flex}.builder-toolbar__title{font-family:var(--font-display);color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:200px;font-size:.83rem;font-weight:600;overflow:hidden}.builder-toolbar__dirty{color:var(--accent);flex-shrink:0;font-size:.45rem;line-height:1}.builder-toolbar__status{letter-spacing:.03em;transition:background var(--transition-theme), color var(--transition-theme);border-radius:99px;flex-shrink:0;padding:2px 8px;font-size:.68rem;font-weight:600}:root{--status-draft-bg:#fbbf2426;--status-draft-text:#fbbf24;--status-review-bg:#60a5fa26;--status-review-text:#60a5fa;--status-preview-bg:#a78bfa26;--status-preview-text:#a78bfa;--status-published-bg:#34d39926;--status-published-text:#34d399;--status-archived-bg:#9ca3af26;--status-archived-text:#9ca3af}[data-theme=light]{--status-draft-bg:#f59e0b1f;--status-draft-text:#d97706;--status-review-bg:#3b82f61f;--status-review-text:#2563eb;--status-preview-bg:#7c3aed1f;--status-preview-text:#7c3aed;--status-published-bg:#10b9811f;--status-published-text:#059669;--status-archived-bg:#6b72801f;--status-archived-text:#4b5563}.builder-toolbar__status--draft{background:var(--status-draft-bg);color:var(--status-draft-text)}.builder-toolbar__status--inreview{background:var(--status-review-bg);color:var(--status-review-text)}.builder-toolbar__status--inpreview{background:var(--status-preview-bg);color:var(--status-preview-text)}.builder-toolbar__status--published{background:var(--status-published-bg);color:var(--status-published-text)}.builder-toolbar__status--archived{background:var(--status-archived-bg);color:var(--status-archived-text)}@media (width<=640px){.builder-toolbar{grid-template-columns:1fr auto;padding:0 12px}.builder-toolbar__center,.builder-toolbar__title,.builder-toolbar__status,.btn-label{display:none}}.app-body{min-height:calc(100vh - var(--header-h) - var(--user-nav-h) - 48px);grid-template-columns:1fr 360px;transition:grid-template-columns .25s;display:grid}@media (width<=900px){.app-body{grid-template-columns:1fr}}@media (width>=901px){.app-body.preview-collapsed{grid-template-columns:1fr 0}.app-body.preview-collapsed .preview-panel{border-left:none;width:0;padding:0;overflow:hidden}#btn-toggle-preview.active{color:var(--accent);border-color:var(--accent)}}.editor-panel{border-right:1px solid var(--border);padding:clamp(14px,2.5vw,28px)}.preview-panel{top:calc(var(--header-h) + var(--user-nav-h) + 48px + 41px);height:calc(100vh - var(--header-h) - var(--user-nav-h) - 48px - 41px);background:var(--surface-2);flex-direction:column;display:flex;position:sticky;overflow:hidden}@media (width<=900px){.editor-panel{border-right:none}.preview-panel{border-top:1px solid var(--border);height:auto;max-height:380px;position:static}.preview-panel:not(.visible){display:none}.preview-panel.visible{display:flex}}.preview-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:9px 14px;display:flex}.preview-header__title{font-family:var(--fd);color:var(--muted);letter-spacing:.1em;text-transform:uppercase;font-size:.7rem;font-weight:700}.preview-content{scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex:1;padding:12px 14px;overflow:auto}.preview-json{font-family:var(--fm);color:var(--text-body);white-space:pre;font-size:.72rem;line-height:1.55}.jk{color:#60c5f5}.js{color:#f9c859}.jn{color:#ff9d5c}.jb{color:var(--accent)}.jl{color:var(--muted)}.builder-gate{z-index:9999;background:var(--bg);justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.builder-gate .dash-gate{text-align:center;max-width:380px}.builder-gate .dash-gate__icon{margin-bottom:16px;font-size:2.5rem}.builder-gate .dash-gate__title{font-family:var(--fd);color:var(--text);margin-bottom:8px;font-size:1.2rem;font-weight:700}.builder-gate .dash-gate__sub{color:var(--muted);margin-bottom:20px;font-size:.85rem}.builder-panels{flex:1;min-height:0;overflow-y:auto}.builder-tabs{background:var(--surface-2);border-bottom:1px solid var(--border);scrollbar-width:none;top:calc(var(--header-h) + var(--user-nav-h) + 48px);z-index:98;align-items:center;gap:2px;padding:0 clamp(16px,4vw,56px);display:flex;position:sticky;overflow-x:auto}.builder-tabs::-webkit-scrollbar{display:none}.builder-tab{color:var(--muted);font-family:var(--fb);cursor:pointer;white-space:nowrap;transition:color var(--tf);background:0 0;border:none;padding:10px 16px;font-size:.8rem;font-weight:600;position:relative}.builder-tab:after{content:"";background:var(--accent);height:2px;transition:transform var(--tf);border-radius:2px 2px 0 0;position:absolute;bottom:0;left:0;right:0;transform:scaleX(0)}.builder-tab:hover{color:var(--text)}.builder-tab.is-active{color:var(--accent)}.builder-tab.is-active:after{transform:scaleX(1)}.tab-panel{display:none}.tab-panel.is-active{display:block}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);margin-bottom:14px;padding:16px 18px}.card__title{font-family:var(--fd);color:var(--text);align-items:center;gap:7px;margin-bottom:14px;font-size:.84rem;font-weight:700;display:flex}.card__title:before{content:"";background:var(--accent);border-radius:2px;width:3px;height:1em;display:inline-block}.fg{margin-bottom:12px}.fg:last-child{margin-bottom:0}.flabel{color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin-bottom:5px;font-size:.68rem;font-weight:600;display:block}.flabel .req{color:var(--error);margin-left:2px}.fhint{color:var(--muted);margin-top:4px;font-size:.66rem;font-style:italic}.fi,.fs,.fta{background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--r-sm);width:100%;color:var(--text);font-family:var(--fb);transition:border-color var(--tf), box-shadow var(--tf);appearance:none;outline:none;padding:7px 11px;font-size:.86rem}.fi:focus,.fs:focus,.fta:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.fi::placeholder,.fta::placeholder{color:var(--muted)}.fta{resize:vertical;min-height:72px;line-height:1.5}.fs{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23b8bccb' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 9px center;background-repeat:no-repeat;background-size:9px;padding-right:28px}.frow{grid-template-columns:1fr 1fr;gap:10px;display:grid}@media (width<=600px){.frow{grid-template-columns:1fr}}.color-row{align-items:center;gap:8px;display:flex}.color-input{border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--surface-2);cursor:pointer;width:40px;height:36px;padding:3px}.color-dot{border:2px solid var(--border);border-radius:50%;flex-shrink:0;width:26px;height:26px}.audience-badge{letter-spacing:.08em;text-transform:uppercase;background:var(--accent-dim);color:var(--accent);border:1px solid #4af0c440;border-radius:999px;align-items:center;gap:6px;margin-top:8px;padding:4px 12px;font-size:.7rem;font-weight:600;display:inline-flex}.btn{font-family:var(--fb);border-radius:var(--r-sm);cursor:pointer;white-space:nowrap;transition:filter var(--tf), transform var(--tf), box-shadow var(--tf), background var(--tf);border:none;align-items:center;gap:5px;padding:7px 15px;font-size:.8rem;font-weight:600;text-decoration:none;display:inline-flex}.btn:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px)}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.4;cursor:not-allowed;filter:none;transform:none}.btn-primary{background:var(--accent);color:#08090c;box-shadow:0 0 14px #4af0c438}.btn-secondary{background:var(--surface-2);color:var(--text);border:1px solid var(--border);transition:background var(--tf), border-color var(--tf)}.btn-secondary:hover:not(:disabled){background:var(--surface-3);border-color:var(--border-h)}.btn-secondary:disabled{opacity:.45;cursor:not-allowed}.btn-ghost{color:var(--muted);border:1px solid var(--border);background:0 0}.btn-ghost:hover:not(:disabled){color:var(--text);border-color:var(--border-h);background:var(--surface-hover)}.btn-danger{color:var(--error);background:0 0;border:1px solid #ef444433}.btn-danger:hover:not(:disabled){background:var(--error-dim)}.btn-sm{padding:5px 10px;font-size:.74rem}.btn-ico{justify-content:center;width:28px;height:28px;padding:5px}.btn--primary{background:var(--accent);color:#08090c;border-radius:var(--r-sm);cursor:pointer;font-weight:600;font-family:var(--fb);border:none;padding:8px 20px}.variant-select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 6px center;background-repeat:no-repeat;background-size:10px 6px;padding-right:22px}.variant-select option{background:var(--surface-2);color:var(--text)}[data-theme=light] .variant-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23555' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E")}[data-theme=light] .variant-select option{background:var(--surface-2);color:var(--text)}.errors-panel{background:var(--error-dim);border-radius:var(--r-md);border:1px solid #ef44444d;margin-bottom:14px;padding:12px 15px;display:none}.errors-panel.visible{display:block}.errors-title{color:var(--error);margin-bottom:7px;font-size:.82rem;font-weight:700}.errors-list{flex-direction:column;gap:4px;list-style:none;display:flex}.errors-list li{color:#fca5a5;align-items:flex-start;gap:6px;font-size:.78rem;display:flex}.errors-list li:before{content:"•";color:var(--error);flex-shrink:0;margin-top:1px}.toast-box{z-index:1000;pointer-events:none;flex-direction:column;gap:7px;display:flex;position:fixed;bottom:22px;right:22px}.toast{border-radius:var(--r-md);pointer-events:all;max-width:360px;padding:11px 16px;font-size:.82rem;font-weight:500;transition:opacity .25s,transform .25s;animation:.2s both toast-in;box-shadow:0 4px 20px #0006}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.toast-success{border:1px solid var(--accent);color:var(--accent);background:#0d2820}.toast-error{border:1px solid var(--error);color:var(--error);background:#2d1010}.toast-info{background:var(--surface);border:1px solid var(--border);color:var(--text-body)}.sections-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.sections-title{font-family:var(--fd);font-size:.95rem;font-weight:700}.section-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);transition:border-color var(--tf);margin-bottom:12px;overflow:visible}.section-card.is-dragover-sec{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-dim)}.section-card__hdr{background:var(--surface-2);border-bottom:1px solid var(--border);border-radius:var(--r-md) var(--r-md) 0 0;align-items:center;gap:7px;padding:9px 12px;display:flex;overflow:hidden}.section-num{font-family:var(--fd);color:var(--accent);background:var(--accent-dim);border-radius:999px;flex-shrink:0;padding:2px 8px;font-size:.66rem;font-weight:700}.section-heading-input{color:var(--text);font-family:var(--fd);background:0 0;border:none;outline:none;flex:1;font-size:.88rem;font-weight:700}.section-heading-input::placeholder{color:var(--muted);font-weight:400}.section-actions{flex-shrink:0;gap:3px;display:flex}.section-card__body{padding:12px;position:relative}.empty-state{text-align:center;color:var(--muted);border:1px dashed var(--border);border-radius:var(--r-sm);padding:20px;font-size:.8rem}.block-list{flex-direction:column;gap:7px;min-height:20px;display:flex}.block-item{border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--surface-2);transition:border-color var(--tf), opacity var(--tf);-webkit-user-select:none;user-select:none;overflow:visible}.block-item.is-dragging{opacity:.35}.block-item.is-dragover{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.block-item.is-sub{background:var(--surface-3)}.block-hdr{border-radius:var(--r-sm) var(--r-sm) 0 0;cursor:pointer;transition:background var(--tf);align-items:center;gap:7px;padding:7px 9px;display:flex;overflow:hidden}.block-hdr:hover{background:#ffffff08}.block-hdr button,.block-hdr .drag-handle{cursor:default}.block-hdr button{pointer-events:all}.drag-handle{cursor:grab;color:var(--muted);flex-shrink:0;padding:2px 3px;font-size:1rem;line-height:1}.drag-handle:active{cursor:grabbing}.type-badge{letter-spacing:.05em;text-transform:uppercase;border-radius:999px;flex-shrink:0;align-items:center;gap:4px;padding:2px 8px;font-size:.62rem;font-weight:700;display:inline-flex}.block-preview{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.75rem;overflow:hidden}.block-controls{flex-shrink:0;gap:2px;display:flex}.ic-btn{cursor:pointer;color:var(--muted);transition:color var(--tf), background var(--tf);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:3px;font-size:.8rem;line-height:1;display:flex}.ic-btn:hover{color:var(--text);background:#ffffff0f}.ic-btn.danger:hover{color:var(--error)}.ic-btn:disabled{opacity:.2;pointer-events:none}.block-body{border-top:1px solid var(--border);padding:9px 11px 11px;overflow:hidden}.block-body.collapsed{display:none}.palette-wrap{margin-top:8px;display:inline-block;position:relative}.palette{z-index:500;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);scrollbar-width:thin;flex-direction:column;gap:1px;min-width:190px;max-height:320px;padding:5px;display:none;position:absolute;top:calc(100% + 5px);left:0;overflow-y:auto;box-shadow:0 10px 36px #00000073}.palette.open{display:flex}.palette.right{left:auto;right:0}.palette.drop-up{top:auto;bottom:calc(100% + 5px);box-shadow:0 -10px 36px #00000073}.pal-item{border-radius:var(--r-sm);cursor:pointer;color:var(--text-body);text-align:left;width:100%;transition:background var(--tf), color var(--tf);background:0 0;border:none;align-items:center;gap:8px;padding:7px 9px;font-size:.82rem;display:flex}.pal-item:hover{background:var(--surface-2);color:var(--text)}.pal-icon{border-radius:50%;flex-shrink:0;place-items:center;width:22px;height:22px;font-size:.75rem;display:grid}.pal-sep{background:var(--border);height:1px;margin:4px 0}.pal-group-label{color:var(--muted);letter-spacing:.1em;text-transform:uppercase;padding:5px 9px 3px;font-size:.6rem;font-weight:700}.sub-blocks-area{border-top:1px solid var(--border);margin-top:10px;padding-top:10px;position:relative}.sub-blocks-title{color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:7px;font-size:.65rem;font-weight:700}.sub-block-list{flex-direction:column;gap:5px;display:flex}.options-editor{margin-top:6px}.options-editor__title{color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin-bottom:7px;font-size:.68rem;font-weight:600}.option-rows{flex-direction:column;gap:5px;margin-bottom:8px;display:flex}.option-row{align-items:center;gap:6px;display:flex}.option-row .fi{flex:1}.option-row-img{align-items:center;gap:6px;display:flex}.option-row-img .fi-url{flex:1.5}.option-row-img .fi-lbl{flex:1}.opt-del{cursor:pointer;color:var(--error);transition:background var(--tf);background:0 0;border:none;border-radius:4px;flex-shrink:0;padding:4px;font-size:.9rem;line-height:1}.opt-del:hover{background:var(--error-dim)}.btn-add-opt{border:1px dashed var(--border);border-radius:var(--r-sm);width:100%;color:var(--muted);cursor:pointer;text-align:center;transition:border-color var(--tf), color var(--tf), background var(--tf);background:0 0;padding:6px;font-size:.78rem}.btn-add-opt:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.correct-answers-sep{background:var(--border);height:1px;margin:12px 0 10px}.correct-answers-title{color:var(--success)!important}.correct-answer-rows{flex-direction:column;gap:5px;margin-top:6px;display:flex}.correct-answer-row{border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface-2);cursor:pointer;color:var(--text-body);transition:border-color var(--tf), background var(--tf);align-items:center;gap:8px;padding:5px 9px;font-size:.83rem;display:flex}.correct-answer-row:has(input:checked){border-color:var(--success);color:var(--text);background:#4af0c412}.correct-answer-row input[type=checkbox],.correct-answer-row input[type=radio]{accent-color:var(--success);cursor:pointer;flex-shrink:0;width:14px;height:14px}.corr-opt-label{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.preview-edit-mode{gap:8px;flex-direction:column!important}.json-edit-area{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-sm);width:100%;min-height:200px;color:var(--text);font-family:var(--fm);resize:none;transition:border-color var(--tf);outline:none;flex:1;padding:10px 12px;font-size:.72rem;line-height:1.55}.json-edit-area:focus{border-color:var(--accent)}.json-edit-actions{flex-shrink:0;gap:6px;padding:0 2px 4px;display:flex}#panel-simulation.is-active{flex-direction:column;display:flex}.sim-wrapper{flex-direction:column;flex:1;min-height:0;padding:0 clamp(16px,4vw,56px);display:flex;overflow:hidden}.sim-placeholder{text-align:center;color:var(--muted);padding:60px 20px;font-size:.9rem}.status-modal-overlay{z-index:900;background:#000000a6;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.status-modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);width:100%;max-width:460px;max-height:85vh;padding:24px;overflow-y:auto;box-shadow:0 20px 60px #00000080}.status-modal__title{font-family:var(--fd);color:var(--text);margin-bottom:6px;font-size:1rem;font-weight:700}.status-modal__name{color:var(--muted);margin-bottom:16px;font-size:.8rem}.status-modal__section-label{color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;font-size:.66rem;font-weight:700}.status-modal__grid{grid-template-columns:1fr 1fr;gap:7px;margin-bottom:16px;display:grid}.status-modal__grid--2{grid-template-columns:1fr 1fr}.status-modal__grid--3{grid-template-columns:1fr 1fr 1fr}.status-option{border:1.5px solid var(--border);border-radius:var(--r-sm);cursor:pointer;text-align:left;transition:border-color var(--tf), background var(--tf);background:0 0;padding:10px 12px}.status-option:hover{border-color:var(--border-hover);background:var(--surface-2)}.status-option.is-current{border-color:var(--accent);background:var(--accent-dim)}.status-option__label{color:var(--text);font-size:.75rem;font-weight:600;display:block}.status-option__desc{color:var(--muted);margin-top:2px;font-size:.66rem}.status-modal__footer{justify-content:flex-end;gap:8px;display:flex}.preview-modal-overlay{z-index:950;background:#000000bf;justify-content:center;align-items:stretch;padding:0;display:flex;position:fixed;inset:0}.preview-modal{background:var(--bg);flex-direction:column;width:100%;max-width:900px;display:flex;overflow:hidden}.preview-modal__header{border-bottom:1px solid var(--border);background:var(--surface-2);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.preview-modal__title{font-family:var(--fd);color:var(--text);font-size:.85rem;font-weight:700}.preview-modal__body{scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex:1;overflow-y:auto}.preview-modal__loading{text-align:center;color:var(--muted);padding:40px}.preview-modal__hero-zone{background:var(--bg);padding:clamp(24px,4vw,40px) clamp(16px,4vw,40px) 0}.preview-modal__content{width:100%;max-width:800px;margin:0 auto;padding:clamp(20px,3vw,36px) clamp(16px,4vw,40px)}.audio-field{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.audio-field__url{color:var(--muted);word-break:break-all;flex:1;font-size:.78rem}.btn-remove-audio{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:4px;padding:4px 10px;font-size:.8rem}.btn-remove-audio:hover{background:var(--surface)}.room-studio__section{margin-bottom:1.25rem}.room-studio__section-head{color:var(--text,inherit);margin:0 0 .5rem;font-size:.95rem;font-weight:700}.room-studio__step{border-left:2px solid var(--accent,#4af0c4);margin:.5rem 0;padding-left:.65rem}.room-studio__step-head{align-items:center;gap:.4rem;display:flex}.room-studio__step-kw{text-transform:uppercase;letter-spacing:.04em;color:#4af0c4;background:#4af0c424;border-radius:4px;padding:.1rem .4rem;font-size:.65rem}.room-studio__step-desc{color:var(--muted,#8a8a8a);margin:.25rem 0;font-size:.8rem}.room-studio__qcard{border:1px solid var(--border,#ffffff1f);border-radius:8px;margin:.5rem 0;padding:.6rem .75rem}.room-studio__qtext{margin:0 0 .35rem;font-size:.85rem;font-weight:600}.room-studio__qopts{color:var(--muted,#8a8a8a);margin:0;padding-left:1.1rem;font-size:.8rem}.room-studio__placeholder{border:1px dashed var(--border,#ffffff2e);color:var(--muted,#8a8a8a);border-radius:8px;margin:.5rem 0;padding:.6rem .75rem;font-size:.8rem}html:has(.page--builder-creator) body{overflow:visible}.builder-creator{grid-template-columns:1fr;gap:1rem;max-width:1480px;margin:0 auto;padding:1.25rem 1.25rem 4rem;display:grid}@media (width>=1024px){.builder-creator{grid-template-columns:var(--outline-w,264px) minmax(0, 1fr) var(--preview-w,440px);align-items:start}.builder-creator--outline-collapsed{--outline-w:46px}.builder-creator--preview-collapsed{--preview-w:46px}.builder-creator>.builder-toolbar,.builder-creator__error{grid-column:1/-1}.builder-outline{grid-column:1}.builder-editor{grid-column:2}.builder-side{grid-column:3}.builder-creator--two-pane{grid-template-columns:minmax(0, 1fr) var(--preview-w,440px)}.builder-creator--two-pane .builder-editor{grid-column:1}.builder-creator--two-pane .builder-side{grid-column:2}}.builder-creator .builder-toolbar{z-index:30;border:1px solid var(--border);border-radius:var(--radius-lg,16px);background:color-mix(in srgb, var(--surface-2) 86%, transparent);-webkit-backdrop-filter:blur(16px);height:auto;min-height:52px;padding:.5rem clamp(12px,2vw,20px);position:sticky;top:.75rem;box-shadow:0 10px 34px #00000057}.builder-creator__error{color:var(--error);background:var(--error-dim);border:1px solid color-mix(in srgb, var(--error) 40%, transparent);border-radius:var(--r-md,10px);margin:0;padding:.65rem .9rem;font-size:.88rem}.builder-panel-label{font-family:var(--fb);text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-size:.68rem;font-weight:700}.builder-icon-btn{border:1px solid var(--border);width:26px;height:26px;color:var(--muted);cursor:pointer;transition:var(--tf);background:0 0;border-radius:8px;justify-content:center;align-items:center;font-size:1.05rem;line-height:1;display:inline-flex}.builder-icon-btn:hover{color:var(--accent);border-color:var(--accent)}.builder-outline{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg,16px);flex-direction:column;gap:.5rem;max-height:calc(100vh - 6rem);padding:.75rem;display:flex;position:sticky;top:5rem;overflow-y:auto}.builder-outline__head{justify-content:space-between;align-items:center;padding:0 .15rem;display:flex}.builder-outline__list{flex-direction:column;gap:.25rem;margin:0;padding:0;list-style:none;display:flex}.builder-outline__item{border-radius:var(--r-md,10px);color:var(--text-body);cursor:grab;transition:var(--tf);border:1px solid #0000;align-items:center;gap:.55rem;padding:.45rem .55rem;font-size:.82rem;display:flex}.builder-outline__item:hover{background:var(--surface-hover);border-color:var(--border);color:var(--text)}.builder-outline__item:active{cursor:grabbing}.builder-outline__num{text-align:right;width:1.4em;font-family:var(--fm);color:var(--muted2);flex-shrink:0;font-size:.7rem}.builder-outline__glyph{text-align:center;width:1.5em;font-family:var(--fm);color:var(--accent);flex-shrink:0;font-size:.85rem}.builder-outline__text{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.builder-outline__count{font-family:var(--fm);color:var(--muted2);flex-shrink:0;font-size:.68rem}.builder-outline__empty{color:var(--muted);padding:.35rem .15rem;font-size:.8rem}.builder-outline__node{list-style:none}.builder-outline__list--block{border-left:1px solid var(--border);margin:.25rem 0 .15rem .9rem;padding-left:.4rem}.builder-outline__list--sub{border-left:1px dashed var(--border);margin:.2rem 0 .15rem .75rem;padding-left:.4rem}.builder-outline__item--section{font-weight:600}.builder-outline__item--block{padding-block:.38rem;font-size:.78rem}.builder-outline__item--sub{color:var(--muted);padding-block:.32rem;font-size:.74rem}.builder-outline__item--sub .builder-outline__glyph,.builder-outline__item--block .builder-outline__glyph{font-size:.78rem}.builder-outline--collapsed,.builder-side--collapsed{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg,16px);padding:0;position:sticky;top:5rem;overflow:hidden}.builder-rail-toggle{width:100%;min-height:160px;color:var(--muted);cursor:pointer;transition:var(--tf);background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:.8rem;padding:1rem .2rem;display:flex}.builder-rail-toggle:hover{color:var(--accent);background:var(--accent-dim)}.builder-rail-toggle__chevron{font-size:1.15rem;line-height:1}.builder-rail-toggle__label{writing-mode:vertical-rl;text-orientation:mixed;font-family:var(--fb);text-transform:uppercase;letter-spacing:.15em;font-size:.7rem;font-weight:700}.builder-editor{flex-direction:column;gap:.75rem;min-width:0;display:flex}.builder-editor>.card{margin-bottom:0}.builder-side{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg,16px);flex-direction:column;max-height:calc(100vh - 6rem);display:flex;position:sticky;top:5rem;overflow:hidden}.builder-side__head{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:.5rem;padding:.5rem .6rem;display:flex}.builder-side__tabs{gap:.25rem;display:flex}.builder-side__tab{font-family:var(--fb);color:var(--muted);border-radius:var(--r-md,10px);cursor:pointer;transition:var(--tf);background:0 0;border:1px solid #0000;align-items:center;gap:.35rem;padding:.35rem .7rem;font-size:.8rem;font-weight:600;display:inline-flex}.builder-side__tab:hover{color:var(--text)}.builder-side__tab.is-active{color:var(--accent);border-color:var(--accent);background:var(--accent-dim)}.builder-side__body{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.builder-side__live{background:var(--bg);flex:1;padding:1rem 1.1rem;overflow-y:auto}.builder-side .preview-panel{background:0 0;flex:1;height:auto;min-height:0;position:static}@media (width<=1023px){.builder-outline,.builder-outline--collapsed,.builder-side,.builder-side--collapsed{max-height:none;position:static}.builder-rail-toggle{flex-direction:row;min-height:0}.builder-rail-toggle__label{writing-mode:horizontal-tb}.builder-creator .builder-toolbar{position:static}}@media (width<=600px){.builder-creator{gap:.85rem;padding:.85rem .85rem 3rem}}:root{--cal-medium:#4af0c46b}[data-theme=light]{--cal-medium:#00b3866b}.room-stats-section{box-sizing:border-box;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md,12px);width:100%;max-width:1200px;margin:0 auto 1.5rem;padding:1.25rem 1.5rem}.room-stats-section__header{margin-bottom:1.25rem}.room-stats-section__title{font-family:var(--font-display);color:var(--text);margin:0;font-size:1rem;font-weight:700}.room-stats-section__body{grid-template-columns:auto 1fr 2fr;grid-template-areas:"metrics status calendar";align-items:stretch;gap:1.25rem;display:grid}.room-stats__metrics{grid-area:metrics}.room-stats__status{grid-area:status}.room-stats__activity{grid-area:calendar}.room-stats__status,.room-stats__activity{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm,8px);min-width:0;padding:1rem 1.25rem}.room-stats__panel-title{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);margin-bottom:.875rem;padding-bottom:.625rem;font-size:.82rem;font-weight:700}.room-stats__metrics{flex-direction:column;gap:.75rem;display:flex}.room-stats__metric{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm,8px);min-width:90px;padding:1rem 1.25rem}.room-stats__metric-value{color:var(--accent);font-size:2.25rem;font-weight:800;line-height:1;font-family:var(--font-display);margin-bottom:.2rem}.room-stats__metric-label{color:var(--muted);text-transform:capitalize;font-size:.75rem;font-weight:500}.room-stats__status-list{flex-direction:column;gap:.5rem;display:flex}.room-stats__status-item{align-items:center;gap:.625rem;padding:.35rem 0;font-size:.875rem;display:flex}.room-stats__status-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.room-stats__status-name{color:var(--text);flex:1;font-weight:500}.room-stats__status-count{color:var(--accent);text-align:right;min-width:1.5rem;font-size:1rem;font-weight:700}.activity-cal{flex-direction:column;gap:.75rem;display:flex}.activity-cal__scroll{scrollbar-width:thin;scrollbar-color:var(--border) transparent;overflow:auto hidden}.activity-cal__scroll::-webkit-scrollbar{height:4px}.activity-cal__scroll::-webkit-scrollbar-track{background:0 0}.activity-cal__scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.activity-cal__inner{flex-direction:column;gap:4px;display:inline-flex}.activity-cal__months-row{align-items:flex-end;display:flex}.activity-cal__axis-gap{flex-shrink:0;width:18px}.activity-cal__months-labels{gap:3px;display:flex}.activity-cal__month-cell{width:13px;color:var(--muted);white-space:nowrap;font-size:.62rem;line-height:1;overflow:visible}.activity-cal__body{align-items:flex-start;gap:4px;display:flex}.activity-cal__axis{flex-direction:column;flex-shrink:0;gap:3px;width:14px;display:flex}.activity-cal__axis-label{height:13px;color:var(--muted);text-align:right;-webkit-user-select:none;user-select:none;font-size:.6rem;line-height:13px}.activity-cal__weeks{gap:3px;display:flex}.activity-cal__week{flex-direction:column;gap:3px;display:flex}.activity-cal__day{border-radius:3px;flex-shrink:0;width:13px;height:13px;transition:transform .15s,opacity .15s}.activity-cal__day:not(.activity-cal__day--future):hover{cursor:pointer;transform:scale(1.3)}.activity-cal__day--empty{background-color:var(--surface-3,#ffffff0f)}.activity-cal__day--light{background-color:var(--accent-dim)}.activity-cal__day--medium{background-color:var(--cal-medium)}.activity-cal__day--heavy{background-color:var(--accent)}.activity-cal__day--future{background-color:#0000}.activity-cal__legend{color:var(--muted);align-items:center;gap:.4rem;font-size:.72rem;display:flex}.activity-cal__legend-label{-webkit-user-select:none;user-select:none}@media (width<=900px){.room-stats-section__body{grid-template-columns:auto 1fr;grid-template-areas:"metrics status""calendar calendar"}}@media (width<=600px){.room-stats-section{padding:1rem}.room-stats-section__body{grid-template-columns:1fr;grid-template-areas:"metrics""status""calendar"}.room-stats__metrics{flex-direction:row}.room-stats__metric{flex:1}}@media (width<=400px){.room-stats-section{padding:.875rem .75rem}}.tester-room-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);flex-direction:column;transition:all .2s;display:flex;overflow:hidden}.tester-room-card:hover{border-color:var(--accent);box-shadow:0 2px 8px #0000001a}.tester-room-card__accent{background:linear-gradient(90deg, var(--accent), var(--accent-light,var(--accent)));height:3px}.tester-room-card__body{flex-direction:column;gap:.75rem;padding:1.25rem;display:flex}.tester-room-card__header{align-items:flex-start;gap:1rem;display:flex}.tester-room-card__icon{flex-shrink:0;font-size:2rem;line-height:1}.tester-room-card__header-text{flex-direction:column;flex:1;gap:.5rem;display:flex}.tester-room-card__title{color:var(--text);margin:0;font-size:1rem;font-weight:600;line-height:1.3}.badge-status{text-transform:uppercase;letter-spacing:.5px;border-radius:999px;width:fit-content;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-block}.tester-room-card__subtitle{color:var(--muted);margin:.25rem 0;font-size:.85rem;line-height:1.4}.tester-room-card__variants{gap:.5rem;display:flex}.tester-room-card .pill{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:.375rem .75rem;font-size:.85rem;font-weight:500;display:inline-block}.tester-room-card__actions{flex-wrap:wrap;gap:.5rem;margin-top:.5rem;display:flex}.tester-room-card .btn{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);color:var(--text);cursor:pointer;white-space:nowrap;padding:.5rem .75rem;font-size:.85rem;font-weight:500;transition:all .2s}.tester-room-card .btn:hover:not(:disabled){background:var(--accent);color:#fff;border-color:var(--accent)}.tester-room-card .btn:disabled{opacity:.5;cursor:not-allowed}.tester-room-card .btn--info{background:var(--surface-2);border-color:var(--accent)}.tester-room-card__open-btn{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);white-space:nowrap;cursor:pointer;align-items:center;padding:.5rem .75rem;font-size:.85rem;font-weight:500;text-decoration:none;transition:background .2s,border-color .2s,color .2s;display:inline-flex}.tester-room-card__open-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}.tester-room-card .btn--primary{background:var(--surface-2);border-color:var(--accent)}.tester-room-card .btn-sm{padding:.5rem .75rem;font-size:.85rem}.tester-room-card__feedback-buttons{gap:.25rem;display:flex}.tester-room-card .btn--feedback{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;flex:1;padding:.5rem;font-size:1.25rem;line-height:1;transition:all .2s}.tester-room-card .btn--feedback:hover:not(:disabled){background:var(--accent);border-color:var(--accent);transform:scale(1.05)}.tester-room-card .btn--feedback--active{background:var(--accent);border-color:var(--accent);box-shadow:0 0 0 2px rgba(var(--accent-rgb,0, 150, 255), .2)}.tester-room-card__feedback-hint{color:var(--muted);text-align:center;margin-top:.25rem;font-size:.75rem;font-style:italic}.tester-room-card__badge{background:var(--accent);color:#fff;border-radius:var(--radius-sm);text-align:center;margin-top:.5rem;padding:.5rem .75rem;font-size:.8rem;font-weight:600;animation:.3s slideIn;display:inline-block}@media (width<=639px){.tester-room-card__body{gap:.5rem;padding:1rem}.tester-room-card__icon{font-size:1.5rem}.tester-room-card__title{font-size:.95rem}.tester-room-card__actions{gap:.25rem}.tester-room-card .btn{padding:.4rem .6rem;font-size:.8rem}.tester-room-card .btn--feedback{padding:.4rem;font-size:1rem}}.tester-section{margin-top:2rem}.tester-tabs{flex-wrap:wrap;align-items:flex-end;gap:0;margin-bottom:0;display:flex}.tester-tabs-row{border-bottom:2px solid var(--border);align-items:flex-end;gap:0;margin-bottom:1.5rem;display:flex}.tester-tab{background:var(--surface-2);border:1px solid var(--border);color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none;border-bottom:none;border-radius:6px 6px 0 0;margin-bottom:-2px;margin-right:3px;padding:.6rem 1.25rem .7rem;font-size:.875rem;font-weight:500;transition:background .15s,color .15s;position:relative}.tester-tab:hover:not(.tester-tab--active){background:var(--surface);color:var(--text)}.tester-tab--active{background:var(--surface);color:var(--accent);border-color:var(--border);border-bottom:2px solid var(--surface);box-shadow:0 -2px 0 0 var(--accent);z-index:1;font-weight:600}.tester-tab__count{background:var(--surface-2);border:1px solid var(--border);min-width:1.3rem;height:1.3rem;color:var(--muted);border-radius:999px;justify-content:center;align-items:center;margin-left:.4rem;padding:0 .3rem;font-size:.72rem;font-weight:700;line-height:1;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.tester-tab--active .tester-tab__count{background:var(--accent);border-color:var(--accent);color:#fff}.tester-tab-toggle{color:var(--accent);border:1px solid var(--accent);border-radius:var(--radius-sm);cursor:pointer;background:0 0;align-self:center;margin-bottom:.2rem;margin-left:auto;padding:.5rem 1rem;font-size:.85rem;font-weight:500;transition:background .15s,color .15s}.tester-tab-toggle:hover{background:var(--accent);color:#fff}.tester-rooms-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.tester-no-rooms{text-align:center;color:var(--muted);grid-column:1/-1;padding:3rem 1rem;font-size:.95rem;line-height:1.6}.alert{border-radius:var(--radius-md);margin-bottom:1.5rem;padding:1rem 1.25rem;font-size:.9rem;line-height:1.5}.alert--error{color:#721c24;background-color:#f8d7da;border:1px solid #f5c6cb}.alert--info{color:#0c5460;background-color:#d1ecf1;border:1px solid #bee5eb}.alert p{margin:0}.loading{color:var(--muted);justify-content:center;align-items:center;padding:3rem 1rem;font-size:.95rem;display:flex}@media (width<=900px){.tester-rooms-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.tester-tab{padding:.55rem 1rem;font-size:.84rem}.tester-tab-toggle{padding:.5rem .875rem;font-size:.84rem}}@media (width<=639px){.tester-rooms-grid{grid-template-columns:1fr;gap:1rem}.tester-tabs-row{border-bottom:none;flex-wrap:wrap;gap:.25rem;margin-bottom:1rem;padding-bottom:0}.tester-tab{border-radius:var(--radius-sm);border:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:0}.tester-tab--active{border-bottom:1px solid var(--border);box-shadow:0 -2px 0 0 var(--accent), 0 2px 0 0 var(--accent)}.tester-tab-toggle{margin-left:0}.alert{margin-bottom:1rem;padding:.75rem 1rem;font-size:.85rem}.loading{padding:2rem 1rem}.tester-no-rooms{padding:2rem 1rem;font-size:.9rem}}@keyframes ai-modal-in{0%{opacity:0;transform:translateY(8px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.ai-card{margin-top:1.25rem;position:relative;overflow:hidden}.ai-card:before{content:"";background:linear-gradient(90deg, var(--accent), #4af0c400 60%);opacity:.7;height:2px;position:absolute;top:0;left:0;right:0}.ai-grid{grid-template-columns:1.25fr 1fr;align-items:start;gap:1rem;display:grid}.ai-panel{background:var(--surface-3);border:1px solid var(--border);border-radius:var(--r-sm);flex-direction:column;gap:.7rem;padding:.9rem;display:flex}.ai-panel__head{justify-content:space-between;align-items:center;gap:.5rem;min-height:1.4rem;display:flex}.ai-panel__title{font-size:.6rem;font-family:var(--fm);color:var(--muted);text-transform:uppercase;letter-spacing:.09em}.ai-panel__body{flex-direction:column;gap:.5rem;display:flex}.ai-panel__empty{font-size:.74rem;font-family:var(--fm);color:var(--muted);text-align:center;padding:.75rem .25rem;font-style:italic}.ai-prov{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);transition:border-color var(--tf), opacity var(--tf);flex-direction:column;gap:.5rem;padding:.65rem .7rem;display:flex}.ai-prov:hover{border-color:#4af0c440}.ai-prov--off{opacity:.55}.ai-prov--off:hover{opacity:.8}.ai-prov__top{align-items:center;gap:.5rem;min-width:0;display:flex}.ai-prov__name{font-size:.82rem;font-family:var(--fm);color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:500;overflow:hidden}.ai-prov__bottom{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.ai-prov__meta{font-size:.64rem;font-family:var(--fm);color:var(--muted);align-items:center;gap:.4rem;min-width:0;display:flex;overflow:hidden}.ai-prov__meta-sep{opacity:.4}.ai-prov__env{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.ai-prov__actions{flex-shrink:0;align-items:center;gap:.3rem;display:flex}.ai-kind-badge{letter-spacing:.04em;background:var(--surface-3);color:var(--muted);text-transform:uppercase;font-size:.56rem;font-weight:600;font-family:var(--fm);white-space:nowrap;border-radius:4px;flex-shrink:0;padding:.12rem .4rem}.ai-kind-badge--anthropic{color:#e8834a;background:#ff8c461a}.ai-key-dot{background:var(--surface-3);border-radius:50%;flex-shrink:0;width:7px;height:7px}.ai-key-dot--present{background:var(--accent);box-shadow:0 0 6px #4af0c459}.ai-key-dot--missing{background:#f87171}.sa-btn.ai-btn--ok{color:var(--accent);border-color:#4af0c459}.sa-btn.ai-btn--ok:hover:not(:disabled){border-color:var(--accent);background:var(--accent-dim)}.ai-assign{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);transition:border-color var(--tf);flex-direction:column;gap:.4rem;padding:.55rem .65rem;display:flex}.ai-assign--global{border-color:#4af0c44d}.ai-assign__label{font-size:.74rem;font-family:var(--fm);color:var(--text);white-space:nowrap;text-overflow:ellipsis;cursor:default;overflow:hidden}.ai-assign--global .ai-assign__label{color:var(--accent);font-weight:600}.ai-assign__selects{grid-template-columns:1fr 1fr;gap:.4rem;display:grid}.ai-assign__selects .sys-input{min-width:0;padding:.22rem .4rem;font-size:.72rem}.ai-modal-overlay{-webkit-backdrop-filter:blur(4px);z-index:1000;background:#0000008c;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.ai-modal{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md);flex-direction:column;width:min(520px,100%);max-height:90dvh;animation:.2s cubic-bezier(.2,0,0,1) both ai-modal-in;display:flex;overflow:hidden}.ai-modal__head{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:.5rem;padding:1rem 1.25rem .875rem;display:flex}.ai-modal__title{font-size:.88rem;font-weight:600;font-family:var(--fb);color:var(--text);align-items:center;gap:.5rem;margin:0;display:flex}.ai-modal__title-badge{font-size:.56rem;font-family:var(--fm);text-transform:uppercase;letter-spacing:.06em;color:var(--accent);background:var(--accent-dim);border:1px solid #4af0c44d;border-radius:4px;padding:.08rem .4rem}.ai-modal__close{border-radius:var(--r-sm);cursor:pointer;color:var(--muted);transition:color var(--tf), border-color var(--tf), background var(--tf);background:0 0;border:1px solid #0000;flex-shrink:0;padding:.18rem .42rem;font-size:.78rem;line-height:1}.ai-modal__close:hover{color:var(--text);border-color:var(--border);background:var(--surface-3)}.ai-modal__body{flex-direction:column;flex:1;gap:.85rem;padding:1rem 1.25rem;display:flex;overflow-y:auto}.ai-modal__grid-2{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.ai-modal__row{flex-direction:column;gap:.3rem;min-width:0;display:flex}.ai-modal__label{font-size:.62rem;font-family:var(--fm);color:var(--muted);text-transform:uppercase;letter-spacing:.07em}.ai-modal__hint{font-size:.64rem;font-family:var(--fm);color:var(--muted)}.ai-preset-chips{flex-wrap:wrap;gap:.4rem;display:flex}.ai-preset-chip{font-size:.72rem;font-family:var(--fm);color:var(--text-body);background:var(--surface-3);border:1px solid var(--border);border-radius:var(--r-sm);cursor:pointer;transition:border-color var(--tf), color var(--tf), background var(--tf);padding:.3rem .6rem}.ai-preset-chip:hover{border-color:var(--accent);color:var(--accent)}.ai-preset-chip--active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.ai-modal__divider{background:var(--border);height:1px;margin:.1rem 0}.ai-modal__actions{border-top:1px solid var(--border);flex-shrink:0;justify-content:flex-end;align-items:center;gap:.5rem;padding:.875rem 1.25rem 1rem;display:flex}.ai-modal__actions .ai-modal__err{color:var(--error);font-size:.72rem;font-family:var(--fm);margin-right:auto}.sa-btn--primary{background:var(--accent-dim);color:var(--accent);border-color:#4af0c466}.sa-btn--primary:hover:not(:disabled){border-color:var(--accent);background:#4af0c426}.ai-model-list{flex-wrap:wrap;gap:.3rem;min-height:1.8rem;padding:.1rem 0;display:flex}.ai-model-tag{background:var(--surface-3);border:1px solid var(--border);font-size:.7rem;font-family:var(--fm);color:var(--text-body);border-radius:4px;align-items:center;gap:.2rem;padding:.12rem .28rem .12rem .45rem;display:inline-flex}.ai-model-tag__remove{cursor:pointer;color:var(--muted);transition:color var(--tf);background:0 0;border:none;align-items:center;padding:0 .08rem;font-size:.95rem;line-height:1;display:flex}.ai-model-tag__remove:hover{color:#f87171}.ai-model-empty{font-size:.68rem;font-family:var(--fm);color:var(--muted);align-self:center;font-style:italic}.ai-model-input-row{align-items:center;gap:.45rem;margin-top:.3rem;display:flex}@media (width<=860px){.ai-grid{grid-template-columns:1fr}}.editable-field{border-bottom:1px solid var(--border);transition:background-color var(--transition-fast);align-items:center;gap:1.5rem;padding:1rem 0;display:flex}.editable-field:last-child{border-bottom:none}.editable-field:hover{background-color:var(--surface-hover)}.editable-field--loading{opacity:.7}.editable-field__label{min-width:8rem;color:var(--text);font-weight:500;font-family:var(--font-body);flex-shrink:0;align-items:center;font-size:.95rem;display:flex}.editable-field__content{flex:1;align-items:center;gap:.75rem;min-width:0;display:flex}.editable-field__value{color:var(--text-body);font-family:var(--font-body);-webkit-user-select:text;user-select:text;word-break:break-word;flex:1;padding:.5rem 0;font-size:.95rem}.editable-field__edit-btn{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;width:30px;height:30px;color:var(--muted);transition:all var(--transition-fast);background:0 0;flex-shrink:0;justify-content:center;align-items:center;display:flex}.editable-field__edit-btn:hover{border-color:var(--accent);color:var(--accent);background-color:var(--accent-dim)}.editable-field__edit-btn:disabled{opacity:.4;cursor:not-allowed}.editable-field--editing{flex-direction:column;align-items:stretch;gap:.45rem}.editable-field--editing .editable-field__label{letter-spacing:.1em;text-transform:uppercase;min-width:auto;color:var(--muted);font-size:.68rem;font-weight:700}.editable-field__edit-area{flex-direction:column;gap:.45rem;display:flex}.editable-field__input{box-sizing:border-box;background:var(--input-bg);border:1.5px solid var(--input-border);border-radius:var(--radius-sm);width:100%;color:var(--text);font-family:var(--font-body);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:.6rem .8rem;font-size:.9rem}.editable-field__input:focus{border-color:var(--accent);box-shadow:var(--glow-input);outline:none}.editable-field__input.is-error{border-color:var(--error)}.editable-field__input.is-success{border-color:var(--accent)}.editable-field__input:disabled{opacity:.5;cursor:not-allowed}.editable-field__custom-select{width:100%;position:relative}.editable-field__select-trigger{box-sizing:border-box;background:var(--input-bg);border:1.5px solid var(--input-border);border-radius:var(--radius-sm);width:100%;color:var(--text);font-family:var(--font-body);cursor:pointer;text-align:left;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);justify-content:space-between;align-items:center;gap:.5rem;padding:.6rem .8rem;font-size:.9rem;display:flex}.editable-field__select-trigger:focus,.editable-field__select-trigger[aria-expanded=true]{border-color:var(--accent);box-shadow:var(--glow-input);outline:none}.editable-field__select-trigger:disabled{opacity:.5;cursor:not-allowed}.editable-field__chevron{color:var(--muted);flex-shrink:0;transition:transform .18s}.editable-field__chevron.is-open{transform:rotate(180deg)}.editable-field__dropdown{background:var(--surface-2);border:1px solid var(--border-hover);border-radius:var(--radius-sm);z-index:200;margin:0;padding:.25rem;list-style:none;animation:.14s both ef-dropdown-in;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:hidden;box-shadow:0 8px 24px #00000059}@keyframes ef-dropdown-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.editable-field__option{width:100%;color:var(--text-body);font-family:var(--font-body);text-align:left;cursor:pointer;border-radius:calc(var(--radius-sm) - 2px);transition:background-color var(--transition-fast), color var(--transition-fast);background:0 0;border:none;padding:.55rem .75rem;font-size:.875rem;list-style:none;display:block}.editable-field__option:hover{background:var(--surface-hover);color:var(--text)}.editable-field__option.is-selected{background:var(--accent-dim);color:var(--accent);font-weight:600}.editable-field__error{color:var(--error);font-size:.78rem;font-family:var(--font-body);animation:slideIn var(--transition-fast)}.editable-field__success{color:var(--accent);font-size:.9rem;animation:.4s cubic-bezier(.34,1.56,.64,1) scaleIn}.editable-field__actions{justify-content:flex-end;align-items:center;gap:.35rem;display:flex}.editable-field__save-btn,.editable-field__cancel-btn{border-radius:var(--radius-sm);cursor:pointer;width:28px;height:28px;transition:all var(--transition-fast);background:0 0;flex-shrink:0;justify-content:center;align-items:center;display:flex}.editable-field__save-btn{border:1.5px solid var(--accent);color:var(--accent)}.editable-field__save-btn:hover:not(:disabled){background:var(--accent-dim)}.editable-field__save-btn:disabled{opacity:.4;cursor:not-allowed}.editable-field__cancel-btn{border:1.5px solid var(--border);color:var(--muted)}.editable-field__cancel-btn:hover{border-color:var(--muted);color:var(--text);background:var(--surface-hover)}.editable-field__spinner{border:2px solid var(--accent-dim);border-top-color:var(--accent);border-radius:50%;width:14px;height:14px;animation:.8s linear infinite spin}.password-field{border-bottom:1px solid var(--border);transition:background-color var(--transition-fast);align-items:stretch;gap:1.5rem;padding:1rem 0;display:flex}.password-field:hover{background-color:var(--surface-hover)}.password-field--loading{opacity:.7}.password-field__label{min-width:8rem;color:var(--text);font-weight:500;font-family:var(--font-body);flex-shrink:0;align-items:center;font-size:.95rem;display:flex}.password-field__content{flex:1;align-items:center;gap:.75rem;min-width:0;display:flex}.password-field__view{flex:1;align-items:center;gap:1rem;display:flex}.password-field__masked{color:var(--text-body);font-family:var(--font-body);font-size:.95rem}.password-field__edit-btn{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;width:30px;height:30px;color:var(--muted);transition:all var(--transition-fast);background:0 0;flex-shrink:0;justify-content:center;align-items:center;display:flex}.password-field__edit-btn:hover{border-color:var(--accent);color:var(--accent);background-color:var(--accent-dim)}.password-field--editing{flex-direction:column;align-items:stretch;gap:.45rem}.password-field--editing .password-field__label{letter-spacing:.1em;text-transform:uppercase;min-width:auto;color:var(--muted);font-size:.68rem;font-weight:700}.password-field__edit-section{animation:expandDown var(--transition-normal);flex-direction:column;gap:.5rem;display:flex}.password-field__inputs-row{gap:.5rem;display:flex}.password-field__inputs-row .password-field__input-group{flex:1;min-width:0}.password-field__input-group{flex-direction:column;gap:.5rem;display:flex;position:relative}.password-field__input-group label{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:.68rem;font-weight:700}.password-field__input{background:var(--input-bg);border:1.5px solid var(--input-border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-body);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);box-sizing:border-box;width:100%;padding:.6rem .8rem;font-size:.9rem}.password-field__input:focus{border-color:var(--accent);box-shadow:var(--glow-input);outline:none}.password-field__input.is-error{border-color:var(--error);animation:.3s cubic-bezier(.36,0,.66,-.56) shake}.password-field__input:disabled{opacity:.5;cursor:not-allowed}.password-field__hint{color:var(--muted);font-size:.75rem;font-style:italic}.password-field__hint.is-error{color:var(--error)}.password-field__error{color:var(--error);animation:slideIn var(--transition-fast);font-size:.78rem}.password-field__buttons{align-items:center;gap:.5rem;display:flex}.password-field__save-btn,.password-field__cancel-btn{border-radius:var(--radius-sm);cursor:pointer;width:28px;height:28px;transition:all var(--transition-fast);background:0 0;flex-shrink:0;justify-content:center;align-items:center;display:flex}.password-field__save-btn{border:1.5px solid var(--accent);color:var(--accent)}.password-field__save-btn:hover:not(:disabled){background:var(--accent-dim)}.password-field__save-btn:disabled{opacity:.4;cursor:not-allowed}.password-field__cancel-btn{border:1.5px solid var(--border);color:var(--muted)}.password-field__cancel-btn:hover{border-color:var(--muted);color:var(--text);background:var(--surface-hover)}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes slideIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes expandDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:400px}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}@media (width<=640px){.password-field{flex-direction:column;align-items:flex-start;gap:.75rem}.password-field__label{width:100%;min-width:auto}.password-field__content{width:100%}.password-field__input,.editable-field__input,.editable-field__select-trigger{font-size:16px}.password-field__inputs-row{flex-direction:column;gap:.5rem}.password-field__edit-section{width:100%}.password-field__save-btn,.password-field__cancel-btn{border-radius:var(--radius-md);width:44px;height:44px}.password-field__buttons{justify-content:flex-end;gap:.75rem;width:100%;margin-top:.25rem}}.ma-page{flex-direction:column;max-width:760px;margin:0 auto;padding:0 1.25rem 4rem;animation:.35s both ma-fadein;display:flex}@keyframes ma-fadein{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.ma-hero{z-index:0;flex-direction:column;align-items:center;margin-bottom:1.5rem;padding:2rem 0 1.75rem;display:flex;position:relative}.ma-hero:before{content:"";background:radial-gradient(ellipse at center, var(--accent-dim) 0%, transparent 70%);opacity:.7;pointer-events:none;z-index:-1;width:min(420px,90%);height:220px;position:absolute;top:-10%;left:50%;transform:translate(-50%)}.ma-avatar-wrap{width:88px;height:88px;margin-bottom:1rem;animation:.4s cubic-bezier(.34,1.56,.64,1) both ma-pop;position:relative}@keyframes ma-pop{0%{opacity:0;transform:scale(.75)}to{opacity:1;transform:scale(1)}}.ma-avatar-wrap:before{content:"";background:conic-gradient(from 0deg, var(--accent) 0deg, transparent 110deg, transparent 250deg, var(--accent) 360deg);opacity:.55;border-radius:50%;animation:5s linear infinite ma-ring;position:absolute;inset:-3px}@keyframes ma-ring{to{transform:rotate(360deg)}}.ma-avatar{z-index:1;background:linear-gradient(150deg, var(--surface-3) 0%, var(--surface-2) 100%);border:3px solid var(--bg);width:88px;height:88px;font-family:var(--font-display);color:var(--accent);letter-spacing:-.03em;-webkit-user-select:none;user-select:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.8rem;font-weight:700;display:flex;position:relative}.ma-pseudo{font-family:var(--font-display);color:var(--text);letter-spacing:-.025em;margin:0 0 .5rem;font-size:1.4rem;font-weight:700}.ma-hero-tags{flex-wrap:wrap;justify-content:center;gap:.4rem;display:flex}.ma-tag{letter-spacing:.07em;text-transform:uppercase;background:var(--surface-2);color:var(--muted);border:1px solid var(--border);border-radius:100px;padding:.22rem .65rem;font-size:.68rem;font-weight:600}.ma-tag--premium,.ma-niveau-badge--debutant{color:#f59e0b;background:#f59e0b1a;border-color:#f59e0b47}.ma-niveau-badge--intermediaire{color:#60a5fa;background:#60a5fa1a;border-color:#60a5fa47}.ma-niveau-badge--expert{color:var(--accent);background:var(--accent-dim);border-color:#4af0c433}.ma-grid{isolation:isolate;grid-template-columns:1fr 1fr;gap:.875rem;display:grid}.ma-card--full{grid-column:1/-1}.ma-card:first-child{z-index:2;animation:.35s 50ms both ma-fadein;position:relative}.ma-card:nth-child(2){z-index:2;animation:.35s .12s both ma-fadein;position:relative}.ma-card:nth-child(3){z-index:1;animation:.35s .19s both ma-fadein;position:relative}.ma-card:nth-child(4){z-index:1;animation:.35s .26s both ma-fadein;position:relative}.ma-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition-fast);overflow:hidden}.ma-card:hover{border-color:var(--border-hover)}.ma-card__head{border-bottom:1px solid var(--border);align-items:center;gap:.55rem;padding:.875rem 1.25rem;display:flex}.ma-card__dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.ma-card__dot--amber{background:#f59e0b;box-shadow:0 0 7px #f59e0b80}.ma-card__dot--gold{background:#fbbf24;box-shadow:0 0 7px #fbbf2466}.ma-card__dot--blue{background:#60a5fa;box-shadow:0 0 7px #60a5fa80}.ma-card__dot--green{background:var(--accent);box-shadow:0 0 7px var(--accent-glow)}.ma-card__title{font-family:var(--font-display);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin:0;font-size:.7rem;font-weight:700}.ma-card__fields{padding:0 1.25rem}.ma-card__fields .editable-field:last-child{border-bottom:none}.ma-card__body{padding:1.25rem}.ma-sub-row{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.ma-sub-label{letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-size:.75rem;font-weight:600}.ma-sub-pill{letter-spacing:.06em;text-transform:uppercase;border-radius:100px;padding:.25rem .7rem;font-size:.72rem;font-weight:700}.ma-sub-pill--free{background:var(--surface-3);color:var(--muted);border:1px solid var(--border)}.ma-sub-pill--premium{color:#f59e0b;background:#f59e0b1f;border:1px solid #f59e0b4d}.ma-roles-section{margin-bottom:1.1rem}.ma-roles-section .ma-sub-label{margin-bottom:.5rem;display:block}.ma-roles-list{flex-wrap:wrap;gap:.35rem;display:flex}.ma-role-chip{letter-spacing:.05em;text-transform:uppercase;background:var(--accent-dim);color:var(--accent);border:1px solid #4af0c42e;border-radius:6px;padding:.22rem .55rem;font-size:.67rem;font-weight:600}.ma-role-chip--default{background:var(--surface-2);color:var(--muted);border-color:var(--border)}.ma-upgrade-btn{border-radius:var(--radius-md);background:var(--accent);width:100%;color:var(--btn-signup-col);font-family:var(--font-body);letter-spacing:.03em;cursor:pointer;transition:opacity var(--transition-fast), box-shadow var(--transition-fast);border:none;justify-content:center;align-items:center;gap:.45rem;padding:.6rem 1rem;font-size:.82rem;font-weight:700;text-decoration:none;display:flex}.ma-upgrade-btn:hover{opacity:.88;box-shadow:var(--glow-btn)}.ma-security-grid{grid-template-columns:1fr 1fr;display:grid}.ma-security-col{padding:0 1.25rem}.ma-security-col+.ma-security-col{border-left:1px solid var(--border)}.ma-security-col .editable-field:last-of-type,.ma-security-col .password-field{border-bottom:none}.ma-field-readonly{border-bottom:1px solid var(--border);align-items:center;gap:1.5rem;padding:1rem 0;display:flex}.ma-field-readonly__label{min-width:7rem;color:var(--text);font-size:.95rem;font-weight:500;font-family:var(--font-body);flex-shrink:0}.ma-field-readonly__value{color:var(--text-body);word-break:break-all;font-size:.95rem}.ma-privacy-row{cursor:pointer;align-items:center;gap:.75rem;display:flex}.ma-privacy-row input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:var(--accent);flex-shrink:0}.ma-privacy-text{color:var(--text-body);font-size:.875rem;line-height:1.4}.ma-privacy-note{opacity:.6;color:var(--muted);margin:.5rem 0 0;font-size:.75rem;line-height:1.45}@media (width<=640px){.ma-page{padding:0 .875rem 3rem}.ma-hero{margin-bottom:1.25rem;padding:1.75rem 0 1.5rem}.ma-avatar-wrap,.ma-avatar{width:72px;height:72px}.ma-avatar{font-size:1.5rem}.ma-pseudo{font-size:1.2rem}}@media (width<=560px){.ma-grid{grid-template-columns:1fr}.ma-card--full{grid-column:auto}.ma-security-grid{grid-template-columns:1fr}.ma-security-col+.ma-security-col{border-left:none;border-top:1px solid var(--border);padding-top:.25rem}.ma-security-col .password-field{border-bottom:none}.ma-security-col,.ma-card__fields{padding:0 1rem}.ma-card__body{padding:1rem}.ma-card__head{padding:.75rem 1rem}}@media (width<=380px){.ma-page{padding:0 .75rem 2.5rem}.ma-hero{padding:1.25rem 0}.ma-hero-tags{gap:.3rem}}.parcours-rooms-list{flex-direction:column;gap:.5rem;padding:.5rem 0;display:flex}.parcours-room-item{border-radius:var(--radius,6px);border:1px solid var(--border,#e5e7eb);background:var(--card-bg,#fff);align-items:center;gap:.6rem;padding:.6rem .75rem;transition:opacity .15s;display:flex}.parcours-room-item.is-dragging{opacity:.4}.parcours-room-item__order{color:var(--muted,#9ca3af);min-width:1.5rem;font-size:.78rem}.parcours-room-item__icon{font-size:1.25rem}.parcours-room-item__body{flex:1;min-width:0}.parcours-room-item__name{white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.parcours-room-item__subject{color:var(--muted,#9ca3af);font-size:.78rem}.parcours-room-item__warn{color:var(--warning,#f59e0b);flex-shrink:0;font-size:.9rem}.parcours-room-item__actions{gap:.25rem;display:flex}.modal--wide{flex-direction:column;width:min(920px,96vw);max-width:min(920px,96vw);max-height:88vh;padding:0;display:flex}.picker-body{flex:1;min-height:0;display:flex}.picker-catalogue{border-right:1px solid var(--border,#e5e7eb);flex-direction:column;flex:1;gap:.5rem;min-width:0;padding:.75rem;display:flex}.picker-list-scroll{flex:1;min-height:0;overflow-y:auto}.picker-selection{flex-direction:column;flex-shrink:0;width:260px;padding:.75rem;display:flex}.picker-selection__header{border-bottom:1px solid var(--border,#e5e7eb);margin-bottom:.5rem;padding-bottom:.5rem}.picker-selection__title{color:var(--muted,#6b7280);text-transform:uppercase;letter-spacing:.04em;font-size:.82rem;font-weight:600}.picker-selection__empty{color:var(--muted,#9ca3af);padding:.75rem 0;font-size:.82rem}.picker-selection__list{flex-direction:column;flex:1;gap:.35rem;margin:0;padding:0;list-style:none;display:flex;overflow-y:auto}.picker-selection__item{border-radius:var(--radius,6px);border:1px solid var(--border,#e5e7eb);align-items:center;gap:.35rem;padding:.35rem .4rem;font-size:.82rem;display:flex}.picker-selection__order{color:var(--muted,#9ca3af);min-width:1.2rem;font-size:.75rem}.picker-selection__icon{font-size:1rem}.picker-selection__name{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-weight:500;overflow:hidden}.picker-selection__actions{flex-shrink:0;gap:.15rem;display:flex}.modal-header{border-bottom:1px solid var(--border,#e5e7eb);flex-shrink:0;justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.modal-title{margin:0;font-size:1rem;font-weight:600}.modal-close{cursor:pointer;color:var(--muted,#9ca3af);background:0 0;border:none;border-radius:4px;padding:.25rem;font-size:1.25rem;line-height:1}.modal-close:hover{color:var(--fg,#111)}.modal-body{flex:1;padding:1rem;overflow-y:auto}.modal-footer{border-top:1px solid var(--border,#e5e7eb);flex-shrink:0;align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.modal-selection-count{color:var(--muted,#9ca3af);flex:1;font-size:.85rem}.room-card--selectable{cursor:pointer}.room-card-link--selection{cursor:pointer;color:inherit;text-decoration:none}.room-card__checkbox{cursor:pointer;flex-shrink:0;width:1rem;height:1rem}.parcours-draft-preview--empty{color:var(--muted,#9ca3af);text-align:center;padding:1.5rem .5rem;font-size:.85rem}:root{--p-accent:#8b5cf6;--p-accent-alt:#a78bfa;--p-accent-glow:#8b5cf661;--p-accent-dim:#8b5cf624;--p-badge-bg:#8b5cf621;--p-badge-border:#8b5cf647}[data-theme=light]{--p-accent:#7c3aed;--p-accent-alt:#8b5cf6;--p-accent-glow:#7c3aed42;--p-accent-dim:#7c3aed1a;--p-badge-bg:#7c3aed1a;--p-badge-border:#7c3aed38}.room-card-link:not(.room-card-link--no-slug):hover .parcours-card{border-color:#8b5cf6a6;transform:translateY(-8px);box-shadow:0 0 0 1px #8b5cf647,0 10px 24px #00000038,0 28px 64px #0000004d,0 0 90px #8b5cf61a}[data-theme=light] .room-card-link:not(.room-card-link--no-slug):hover .parcours-card{border-color:#7c3aed8c;box-shadow:0 0 0 1px #7c3aed38,0 10px 24px #0000001a,0 28px 64px #00000024,0 0 90px #7c3aed12}.room-card-link:focus-visible .parcours-card{outline:2px solid var(--p-accent);outline-offset:2px}.parcours-card .room-card__icon{border-bottom:1px solid var(--border);background-color:var(--surface-2);width:100%;min-height:160px;transition:font-size .22s ease, filter .22s ease, background-color var(--transition-theme,.2s);background-image:radial-gradient(145% 90% at 50% -18%,#8b5cf685 0%,#0000 52%),radial-gradient(78% 58% at -8% 110%,#6366f13d 0%,#0000 55%),radial-gradient(62% 48% at 110% 100%,#ec489924 0%,#0000 50%);flex-shrink:0;justify-content:center;align-items:center;font-size:3rem;line-height:1;display:flex;position:relative;overflow:hidden}.room-card-link:not(.room-card-link--no-slug):hover .parcours-card .room-card__icon{filter:drop-shadow(0 8px 22px #8b5cf680);font-size:3.5rem}.parcours-card .room-card__icon:before{content:"";pointer-events:none;background-image:radial-gradient(circle,#ffffff17 1px,#0000 1px);background-size:18px 18px;animation:22s linear infinite parcoursDotDrift;position:absolute;inset:-18px;-webkit-mask-image:linear-gradient(#0000008c 0%,#0000 100%);mask-image:linear-gradient(#0000008c 0%,#0000 100%)}@keyframes parcoursDotDrift{0%{background-position:0 0}to{background-position:18px 18px}}.parcours-card .room-card__icon:after{content:"";pointer-events:none;background:linear-gradient(112deg,#0000 0% 28%,#ffffff1a 50%,#0000 72% 100%);transition:transform .65s cubic-bezier(.25,.46,.45,.94);position:absolute;inset:0;transform:translate(-170%)}.room-card-link:not(.room-card-link--no-slug):hover .parcours-card .room-card__icon:after{transform:translate(170%)}.parcours-card .room-card__body{border-top:none;padding:1rem 1.1rem 1.15rem 1.25rem;position:relative}.parcours-card .room-card__body:before{content:"";background:var(--p-accent);opacity:.5;border-radius:0 2px 2px 0;width:3px;position:absolute;top:.7rem;bottom:.7rem;left:0}.parcours-card__niveau{background:var(--p-badge-bg);color:var(--p-accent);border:1px solid var(--p-badge-border);white-space:nowrap;letter-spacing:.01em;border-radius:4px;padding:.1rem .48rem;font-size:.72rem;font-weight:600}.parcours-card__meta{flex-wrap:wrap;align-items:center;gap:.45rem;margin-top:.35rem;display:flex}.parcours-card__rooms{color:var(--muted);font-size:.76rem}.parcours-card__progress{background:var(--border);border-radius:2px;height:4px;margin-top:.65rem;overflow:hidden}.parcours-card__progress-fill{background:linear-gradient(90deg, var(--p-accent) 0%, var(--p-accent-alt) 100%);border-radius:2px;height:100%;transition:width .4s}.parcours-card .badge--free{background:var(--p-badge-bg);color:var(--p-accent);border:1px solid var(--p-badge-border)}.parcours-card .badge--open{color:#16a34a;background:#22c55e1f;border:1px solid #22c55e42}.catalogue-main .catalogue-filter__select:focus,.catalogue-main .catalogue-search__input:focus{border-color:var(--p-accent);box-shadow:0 0 0 3px var(--p-accent-dim)}@media (width<=820px){.catalogue-main .catalogue-toolbar{flex-wrap:wrap;gap:.5rem}.catalogue-main .catalogue-toolbar>.catalogue-search{flex:200px;min-width:0}.catalogue-main .catalogue-toolbar>.catalogue-filter{flex:0 auto;min-width:120px}}@media (width<=640px){.parcours-card .room-card__icon{min-height:120px;font-size:2.4rem}.room-card-link:not(.room-card-link--no-slug):hover .parcours-card .room-card__icon{font-size:2.8rem}.catalogue-main .catalogue-toolbar{flex-direction:column;gap:.5rem}.catalogue-main .catalogue-toolbar>.catalogue-search,.catalogue-main .catalogue-toolbar>.catalogue-filter{flex:none;width:100%}.catalogue-main .catalogue-filter__select{width:100%;min-height:44px;font-size:16px}.catalogue-main .catalogue-search__input{min-height:44px;font-size:16px}}@media (width<=380px){.parcours-card .room-card__icon{min-height:100px;font-size:2rem}}pre code.hljs{padding:1em;display:block;overflow-x:auto}code.hljs{padding:3px 5px}.hljs{color:#c9d1d9;background:#0d1117}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#ff7b72}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#d2a8ff}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#79c0ff}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#a5d6ff}.hljs-built_in,.hljs-symbol{color:#ffa657}.hljs-comment,.hljs-code,.hljs-formula{color:#8b949e}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#7ee787}.hljs-subst{color:#c9d1d9}.hljs-section{color:#1f6feb;font-weight:700}.hljs-bullet{color:#f2cc60}.hljs-emphasis{color:#c9d1d9;font-style:italic}.hljs-strong{color:#c9d1d9;font-weight:700}.hljs-addition{color:#aff5b4;background-color:#033a16}.hljs-deletion{color:#ffdcd7;background-color:#67060c}
