@import"https://fonts.googleapis.com/css2?family=Nunito:wght@300;400;600;700;800&family=Lora:ital,wght@0,600;0,700;1,600&display=swap";@import"https://fonts.googleapis.com/css2?family=Lora:wght@600;700&family=IBM+Plex+Mono:wght@400;500;600&family=Lato:wght@300;400;500;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,600;0,700;1,600&family=IBM+Plex+Mono:wght@400;500;600&family=Lato:wght@300;400;500;700&display=swap";:root{--bg: #F0EEEC;--bg2: #E8E5E1;--surface: #C3BEB8;--surface2: #D4D0CA;--ink: #1C1A17;--ink2: #3D3A35;--ink3: #6B6560;--cta: #1C1A17;--cta-text: #F0EEEC;--r-xl: 36px;--r-lg: 26px;--r-md: 18px;--r-sm: 12px;--shadow: 8px 8px 22px rgba(28, 26, 23, .16), -5px -5px 16px rgba(255, 255, 255, .7);--shadow-hover: 14px 14px 32px rgba(28, 26, 23, .2), -9px -9px 22px rgba(255, 255, 255, .78);--shadow-inset: inset 5px 5px 14px rgba(28, 26, 23, .16), inset -4px -4px 12px rgba(255, 255, 255, .65);--shadow-sm: 4px 4px 12px rgba(28, 26, 23, .12), -3px -3px 9px rgba(255, 255, 255, .6);--shadow-surf: 8px 8px 20px rgba(28, 26, 23, .18), -5px -5px 15px rgba(255, 255, 255, .35);--shadow-surf-hover: 14px 14px 28px rgba(28, 26, 23, .22), -8px -8px 20px rgba(255, 255, 255, .4);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--ease-expo: cubic-bezier(.16, 1, .3, 1)}html{scroll-behavior:smooth}.clay-page{font-family:Nunito,system-ui,sans-serif;background:var(--bg);color:var(--ink);overflow-x:hidden;min-height:100vh}.clay-enter{opacity:0;transform:translateY(22px);transition:none}.clay-ready .clay-enter{opacity:1;transform:none;transition:opacity .85s var(--ease-expo),transform .85s var(--ease-expo)}.clay-reveal{opacity:1;transform:none;transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);will-change:opacity,transform}.clay-reveal.clay-anim-ready{opacity:0}.clay-reveal.clay-anim-ready.clay-reveal--bottom{transform:translateY(40px)}.clay-reveal.clay-anim-ready.clay-reveal--left{transform:translate(-40px)}.clay-reveal.clay-anim-ready.clay-reveal--right{transform:translate(40px)}.clay-reveal.clay-anim-ready.is-visible{opacity:1;transform:none}.clay-divider{height:1px;background:var(--surface);border:none}.clay-nav{position:fixed;top:0;left:0;right:0;height:66px;display:flex;align-items:center;z-index:200;background:transparent;transition:background .35s,box-shadow .35s}.clay-nav--solid{background:#f0eeecf5;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--surface)}.clay-nav-inner{width:100%;max-width:1240px;margin:0 auto;padding:0 2.5rem;display:flex;align-items:center;gap:2rem}.clay-brand{display:flex;align-items:center;gap:.5rem;flex-shrink:0;cursor:default}.clay-brand-ico{font-size:1.6rem;color:var(--ink)}.clay-brand-name{font-family:Lora,serif;font-size:1.2rem;font-weight:700;color:#f0eeec;letter-spacing:-.02em;text-shadow:0 1px 4px rgba(0,0,0,.35);transition:color .3s,text-shadow .3s}.clay-nav--solid .clay-brand-name{color:var(--ink);text-shadow:none}.clay-nav-links{display:flex;align-items:center;gap:2rem;margin-left:auto}.clay-nav-link{text-decoration:none;color:#f0eeece6;font-size:.875rem;font-weight:700;letter-spacing:.01em;text-shadow:0 1px 3px rgba(0,0,0,.4);transition:color .2s,text-shadow .2s}.clay-nav-link:hover{color:#fff}.clay-nav--solid .clay-nav-link{color:var(--ink2);text-shadow:none}.clay-nav--solid .clay-nav-link:hover{color:var(--ink)}.clay-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.5rem;margin-left:auto}.clay-burger span{display:block;width:22px;height:2px;background:#f0eeec;border-radius:2px;transition:.3s;box-shadow:0 1px 3px #0006}.clay-nav--solid .clay-burger span{background:var(--ink);box-shadow:none}.clay-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.clay-burger.open span:nth-child(2){opacity:0}.clay-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.clay-mobile-nav{position:fixed;top:66px;left:0;right:0;background:#f0eeecfa;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);padding:1rem 2rem 1.5rem;display:flex;flex-direction:column;gap:0;border-bottom:1px solid var(--surface);z-index:199}.clay-mobile-nav a{text-decoration:none;color:var(--ink2);font-size:.95rem;font-weight:700;padding:.8rem .5rem;border-bottom:1px solid var(--bg2);transition:color .2s}.clay-mobile-nav a:hover{color:var(--ink)}.clay-mobile-nav a:last-child{border-bottom:none}.clay-hero{position:relative;min-height:100vh;min-height:100dvh;display:flex;align-items:stretch;overflow:hidden;background:var(--ink)}.clay-hero-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:1}.clay-hero-pane{position:relative;z-index:2;width:100%;display:flex;align-items:center;justify-content:center;padding:110px 2.5rem 80px;background:#f0eeecb8;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.clay-hero-inner{width:100%;max-width:1200px;display:grid;grid-template-columns:1fr 440px;gap:5rem;align-items:center}.clay-section-reveal{opacity:1;transform:none;transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}.clay-section-reveal.clay-animate{opacity:0;transform:translateY(48px) scale(.985)}.clay-section-reveal.clay-animate.is-visible{opacity:1;transform:none}.clay-scroll-indicator{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:.4rem}.clay-scroll-dot{width:6px;height:6px;border-radius:50%;background:var(--ink);animation:scrollBounce 2s ease-in-out infinite}@keyframes scrollBounce{0%,to{transform:translateY(0);opacity:.4}50%{transform:translateY(10px);opacity:1}}.clay-hero-badge{display:inline-block;background:var(--surface);border-radius:999px;padding:.3rem 1rem;font-size:.75rem;font-weight:800;color:var(--ink);letter-spacing:.06em;text-transform:uppercase;margin-bottom:1.25rem;box-shadow:var(--shadow-sm)}.clay-hero-h1{font-family:Lora,Georgia,serif;font-size:clamp(2.6rem,5.5vw,4.2rem);font-weight:700;line-height:1.1;color:var(--ink);margin-bottom:1.25rem;letter-spacing:-.04em}.clay-h1-accent{font-style:italic;color:var(--ink)}.clay-h1-underline{position:relative;color:var(--ink);display:inline-block}.clay-h1-underline:after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:4px;background:var(--surface);border-radius:3px}.clay-h1-sub{font-size:.62em;color:var(--ink2);font-style:italic;font-weight:600}.clay-hero-body{font-size:1.05rem;color:var(--ink2);line-height:1.8;font-weight:400;max-width:480px;margin-bottom:1.5rem}.clay-hero-tags{display:flex;flex-wrap:wrap;gap:.5rem}.clay-hero-tags span{background:var(--bg2);border:1.5px solid var(--surface);border-radius:var(--r-sm);padding:.3rem .875rem;font-size:.78rem;font-weight:700;color:var(--ink2)}.clay-hero-hint{text-align:center;font-size:.78rem;color:var(--ink3);font-weight:700;margin-top:.75rem;letter-spacing:.01em}.clay-login-card{background:#fff;border-radius:var(--r-xl);padding:2.25rem 2rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:1rem;border:1.5px solid var(--surface);transition:transform .3s var(--ease-spring),box-shadow .3s}.clay-login-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}.clay-login-header{display:flex;align-items:center;gap:.875rem;margin-bottom:.25rem}.clay-login-logo{width:46px;height:46px;background:var(--ink);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:var(--bg);flex-shrink:0;box-shadow:var(--shadow-sm)}.clay-login-title{font-family:Lora,serif;font-size:1.1rem;font-weight:700;color:var(--ink);letter-spacing:-.02em}.clay-login-sub{font-size:.78rem;color:var(--ink3);margin-top:.15rem;font-weight:600}.clay-login-error{background:#fdf2f2;border:1.5px solid #e0b0b0;border-radius:var(--r-sm);padding:.65rem .875rem;font-size:.82rem;color:#7a2020;font-weight:700}.clay-roles{display:flex;flex-direction:column;gap:.625rem}.clay-role{display:flex;align-items:center;gap:.875rem;padding:.875rem 1rem;background:var(--bg);border-radius:var(--r-md);border:1.5px solid var(--surface);cursor:pointer;transition:all .25s var(--ease-spring);box-shadow:var(--shadow-sm);text-align:left;width:100%}.clay-role:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--ink2)}.clay-role--on{background:var(--bg2);border-color:var(--ink);border-width:2px;box-shadow:var(--shadow)}.clay-role-ico{font-size:1.3rem;color:var(--ink2);flex-shrink:0}.clay-role-name{font-size:.9rem;font-weight:800;color:var(--ink)}.clay-role-desc{font-size:.75rem;color:var(--ink3);margin-top:.1rem;font-weight:600}.clay-role-tick{margin-left:auto;color:var(--ink);font-size:1.05rem;flex-shrink:0}.clay-google-btn{display:flex;align-items:center;justify-content:center;gap:.625rem;width:100%;padding:1rem;background:var(--ink);color:var(--bg);border:none;border-radius:var(--r-md);font-size:.95rem;font-weight:800;font-family:Nunito,sans-serif;cursor:pointer;letter-spacing:.01em;transition:transform .25s var(--ease-spring),box-shadow .25s,background .2s;box-shadow:var(--shadow)}.clay-google-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:var(--shadow-hover);background:var(--ink2)}.clay-google-btn:active{box-shadow:var(--shadow-inset)}.clay-google-btn--off{background:var(--bg2);color:var(--ink3);cursor:not-allowed;box-shadow:none;border:1.5px solid var(--surface)}.clay-google-ico{font-size:1.15rem;background:#fff;border-radius:50%;padding:2px;flex-shrink:0}.clay-arrow{font-size:.9rem;margin-left:auto}.clay-spin{font-size:1rem;animation:claySpin .8s linear infinite}@keyframes claySpin{to{transform:rotate(360deg)}}.clay-login-hint{font-size:.75rem;color:var(--ink3);text-align:center;line-height:1.55;font-weight:600}.clay-wrap{max-width:1200px;margin:0 auto;padding:0 2.5rem}.clay-section-label{font-size:.7rem;font-weight:900;letter-spacing:.14em;text-transform:uppercase;margin-bottom:1.25rem;color:var(--ink3)}.clay-section-h2{font-family:Lora,serif;font-size:clamp(1.75rem,3.5vw,2.7rem);font-weight:700;line-height:1.15;margin-bottom:.875rem;letter-spacing:-.03em}.clay-section-body{font-size:1rem;line-height:1.8;font-weight:400;max-width:520px;margin-bottom:.5rem}.clay-stats-section{padding:5.5rem 0;background:var(--surface)}.clay-stats-section .clay-section-label{color:var(--ink2)}.clay-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-top:1.5rem}.clay-stat{background:var(--bg);border-radius:var(--r-lg);padding:1.75rem 1.25rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;box-shadow:var(--shadow-surf);transition:transform .3s var(--ease-spring),box-shadow .3s}.clay-stat:hover{transform:translateY(-6px);box-shadow:var(--shadow-surf-hover)}.clay-stat-num{font-family:Lora,serif;font-size:2.6rem;font-weight:700;color:var(--ink);line-height:1}.clay-stat-plus{font-size:1.5rem}.clay-stat-loading{font-size:2rem;color:var(--ink3);animation:statPulse 1.4s ease-in-out infinite;display:inline-block}@keyframes statPulse{0%,to{opacity:.3}50%{opacity:.8}}.clay-stat-lbl{font-size:.82rem;font-weight:700;color:var(--ink2);text-align:center;letter-spacing:.02em}.clay-features-section{padding:6rem 0;background:var(--bg)}.clay-features-section .clay-section-h2{color:var(--ink)}.clay-features-section .clay-section-body{color:var(--ink2)}.clay-features-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:4rem;align-items:start;margin-top:1rem}.clay-features-illustration{margin-top:2rem;max-width:220px;opacity:.65}.clay-features-illustration img{width:100%;object-fit:contain}.clay-feature-cols{display:grid;grid-template-columns:1fr 1fr;gap:1.75rem}.clay-feature-col-title{display:flex;align-items:center;gap:.5rem;font-size:.82rem;font-weight:800;padding:.6rem 1rem;border-radius:var(--r-sm);margin-bottom:.875rem;letter-spacing:.02em;text-transform:uppercase}.clay-student-title{background:var(--surface);color:var(--ink)}.clay-faculty-title{background:var(--ink);color:var(--bg)}.clay-feature-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#fff;border-radius:var(--r-sm);margin-bottom:.5rem;font-size:.875rem;font-weight:600;color:var(--ink);box-shadow:var(--shadow-sm);border:1px solid var(--bg2);transition:transform .2s var(--ease-spring),box-shadow .2s}.clay-feature-item:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.clay-feature-ico{font-size:1rem;flex-shrink:0}.clay-ico--student,.clay-ico--faculty{color:var(--ink2)}.clay-how-section{padding:6rem 0;background:var(--surface)}.clay-how-section .clay-section-label{color:var(--ink2)}.clay-how-section .clay-section-h2{color:var(--ink)}.clay-how-section .clay-section-body{color:var(--ink2)}.clay-how-intro{margin-bottom:2.5rem}.clay-how-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.75rem}.clay-how-block{background:var(--bg);border:1px solid var(--surface2);border-radius:var(--r-xl);padding:2rem;box-shadow:var(--shadow-surf);position:relative;overflow:hidden;transition:transform .3s var(--ease-spring),box-shadow .3s}.clay-how-block:hover{transform:translateY(-4px);box-shadow:var(--shadow-surf-hover)}.clay-how-block-label{font-size:.7rem;font-weight:900;letter-spacing:.12em;text-transform:uppercase;margin-bottom:1.5rem;color:var(--ink2)}.clay-step{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.25rem}.clay-step-num{width:40px;height:40px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-family:Lora,serif;font-weight:700;font-size:.9rem;flex-shrink:0;background:var(--ink);color:var(--bg);box-shadow:var(--shadow-sm)}.clay-step-title{font-weight:800;font-size:.9rem;color:var(--ink);margin-bottom:.3rem}.clay-step-desc{font-size:.8rem;color:var(--ink2);line-height:1.6;font-weight:600}.clay-how-illustration{position:absolute;bottom:-8px;right:-8px;width:100px;opacity:.1;pointer-events:none;-webkit-user-select:none;user-select:none}.clay-how-illustration--right{right:-4px;bottom:-8px}.clay-how-illustration img{width:100%;height:auto;object-fit:contain;display:block}.clay-testimonials-section{padding:6rem 0;background:var(--bg)}.clay-testimonials-section .clay-section-h2{color:var(--ink)}.clay-testimonials-section .clay-section-body{color:var(--ink2)}.clay-testimonials-intro{margin-bottom:2.5rem}.clay-testimonials-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.clay-testimonial{background:#fff;border-radius:var(--r-xl);padding:1.875rem;box-shadow:var(--shadow-sm);border:1.5px solid var(--surface);transition:transform .3s var(--ease-spring),box-shadow .3s}.clay-testimonial:hover{transform:translateY(-4px);box-shadow:var(--shadow)}.clay-testimonial:nth-child(odd){border-left:4px solid var(--ink)}.clay-testimonial:nth-child(2n){border-left:4px solid var(--surface)}.clay-testimonial-msg{font-family:Lora,serif;font-size:.975rem;font-style:italic;color:var(--ink);line-height:1.75;margin-bottom:1.1rem}.clay-testimonial-footer{display:flex;flex-direction:column;gap:.2rem}.clay-testimonial-from{font-weight:800;font-size:.875rem;color:var(--ink)}.clay-testimonial-role{font-size:.75rem;color:var(--ink3);font-weight:600}.clay-footer{background:var(--ink);padding:3.5rem 0 2rem}.clay-footer-inner{display:flex;flex-direction:column;align-items:center;gap:1.25rem;text-align:center}.clay-footer-brand{display:flex;align-items:center;gap:.55rem;font-family:Lora,serif;font-size:1.3rem;font-weight:700;color:var(--bg)}.clay-footer-brand-ico{font-size:1.5rem;color:var(--surface)}.clay-footer-tagline{font-size:.875rem;color:var(--surface);font-weight:400;max-width:360px}.clay-footer-links{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.clay-footer-links a{display:inline-flex;align-items:center;gap:.35rem;text-decoration:none;font-size:.82rem;font-weight:700;color:var(--bg);background:#f0eeec1a;padding:.4rem .875rem;border-radius:var(--r-sm);border:1px solid rgba(240,238,236,.18);transition:background .2s,color .2s,border-color .2s}.clay-footer-links a:hover{background:var(--bg);color:var(--ink);border-color:var(--bg)}.clay-footer-bottom{display:flex;gap:2rem;flex-wrap:wrap;justify-content:center;font-size:.75rem;color:#f0eeec94;padding-top:1rem;border-top:1px solid rgba(240,238,236,.1);width:100%;font-weight:600}.clay-footer-heart{color:var(--surface);margin:0 .2rem;vertical-align:middle}.clay-auth-loading{min-height:100vh;background:var(--bg);display:flex;align-items:center;justify-content:center}.clay-auth-loading-inner{display:flex;flex-direction:column;align-items:center;gap:1rem}.clay-auth-loading-logo{width:60px;height:60px;background:var(--ink);border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;font-size:1.8rem;color:var(--bg);box-shadow:var(--shadow)}.clay-auth-loading-name{font-family:Lora,serif;font-size:1.3rem;font-weight:700;color:var(--ink)}.clay-auth-loading-ring{width:38px;height:38px;border:3.5px solid var(--surface);border-top-color:var(--ink);border-radius:50%;animation:claySpin .85s linear infinite}.clay-nav-signin{text-decoration:none;font-size:.85rem;font-weight:800;color:var(--cta-text);background:var(--cta);padding:.42rem 1.1rem;border-radius:var(--r-sm);box-shadow:var(--shadow-sm);transition:transform .2s var(--ease-spring),box-shadow .2s;white-space:nowrap}.clay-nav-signin:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.clay-mobile-signin{display:block;margin-top:.5rem;padding:.875rem .5rem!important;font-weight:800!important;color:var(--ink)!important;background:var(--surface);border-radius:var(--r-sm);text-align:center}.clay-footer-about{max-width:480px;text-align:center;padding:1.5rem 2rem;background:#f0eeec0f;border:1px solid rgba(240,238,236,.12);border-radius:var(--r-lg)}.clay-footer-about-name{font-family:Lora,serif;font-size:1.1rem;font-weight:700;color:var(--bg);margin-bottom:.25rem}.clay-footer-about-meta{font-size:.72rem;font-weight:900;letter-spacing:.1em;text-transform:uppercase;color:var(--surface);margin-bottom:.875rem}.clay-footer-about-bio{font-size:.85rem;line-height:1.7;color:#f0eeecb3;font-weight:400;margin-bottom:.875rem}.clay-footer-quote{font-family:Lora,serif;font-style:italic;font-size:.85rem;color:var(--surface);border-left:3px solid var(--surface);padding:.5rem .875rem;text-align:left;border-radius:0 var(--r-sm) var(--r-sm) 0}.clay-quick-return{background:#fff;border-radius:var(--r-xl);padding:2rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:.5rem;border:1.5px solid var(--surface);text-align:center}.clay-quick-return-label{font-size:.72rem;font-weight:900;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);margin-bottom:.25rem}.clay-quick-return-name{font-family:Lora,serif;font-size:1.5rem;font-weight:700;color:var(--ink);letter-spacing:-.02em;line-height:1.2}.clay-quick-return-meta{font-size:.78rem;color:var(--ink3);font-weight:600;margin-bottom:.5rem}.clay-quick-return-meta strong{color:var(--ink2);text-transform:capitalize}.clay-quick-return-btn{display:flex;align-items:center;gap:.625rem;width:100%;padding:1rem 1.25rem;background:var(--ink);color:var(--bg);border:none;border-radius:var(--r-md);font-size:.95rem;font-weight:800;font-family:Nunito,sans-serif;cursor:pointer;letter-spacing:.01em;transition:transform .25s var(--ease-spring),box-shadow .25s,background .2s;box-shadow:var(--shadow);margin-top:.5rem}.clay-quick-return-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:var(--shadow-hover);background:var(--ink2)}.clay-quick-return-btn:disabled{opacity:.6;cursor:not-allowed}.clay-quick-return-switch{background:none;border:none;cursor:pointer;font-size:.78rem;font-weight:700;color:var(--ink3);padding:.5rem;border-radius:var(--r-sm);font-family:Nunito,sans-serif;transition:color .2s;text-decoration:underline;text-underline-offset:3px}.clay-quick-return-switch:hover{color:var(--ink)}@media (max-width: 380px){.clay-quick-return{padding:1.5rem 1.25rem}.clay-quick-return-name{font-size:1.25rem}}@media (max-width: 1024px){.clay-hero-pane{padding:90px 1.5rem 60px}.clay-hero-inner{grid-template-columns:1fr;text-align:center;gap:2.5rem}.clay-hero-right{margin:0 auto;max-width:440px}.clay-hero-hint{display:none}.clay-stats-grid{grid-template-columns:repeat(2,1fr)}.clay-features-grid,.clay-feature-cols{grid-template-columns:1fr}.clay-features-illustration{max-width:140px}.clay-how-grid,.clay-testimonials-grid{grid-template-columns:1fr}.clay-nav-links{display:none}.clay-burger{display:flex}}@media (max-width: 600px){.clay-hero-pane{padding:90px 1.25rem 60px}.clay-wrap{padding:0 1.25rem}.clay-hero-h1{font-size:2.1rem}.clay-stats-grid{grid-template-columns:repeat(2,1fr);gap:.875rem}.clay-stat{padding:1.25rem 1rem}.clay-stat-num{font-size:2rem}.clay-login-card{padding:1.5rem 1.25rem}.clay-features-section,.clay-how-section,.clay-testimonials-section,.clay-footer-bottom{gap:1rem;flex-direction:column;align-items:center}}@media (max-width: 480px){.clay-features-section,.clay-how-section,.clay-testimonials-section{padding:3rem 0}.clay-section-h2{font-size:1.6rem}.clay-how-block{padding:1.5rem 1.25rem}.clay-testimonial{padding:1.25rem}}@media (max-width: 380px){.clay-hero-pane{padding:80px 1rem 50px}.clay-login-card{padding:1.25rem 1rem}.clay-role{padding:.7rem .75rem;gap:.6rem}.clay-role-ico{font-size:1.1rem}.clay-stats-grid{grid-template-columns:1fr 1fr;gap:.5rem}.clay-stat{padding:1rem .75rem}.clay-stat-num{font-size:1.75rem}}@media (prefers-reduced-motion: reduce){.clay-enter,.clay-reveal{animation:none!important;transition:none!important;opacity:1!important;transform:none!important}}:root{--sb-bg: #f5f4f0;--sb-border: #dddbd6;--sb-border2: #c8c5be;--sb-ink: #1a1916;--sb-ink2: #4a4843;--sb-ink3: #8c8880;--sb-ink4: #b8b5b0;--sb-accent: #2d5be3;--sb-accent-bg: #eef2ff;--sb-w: 232px;--sb-w-col: 64px;--ease-expo: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1)}body.dark-mode{--sb-bg: #0c4a6e;--sb-border: #075985;--sb-border2: #0369a1;--sb-ink: #e0f2fe;--sb-ink2: #bae6fd;--sb-ink3: #7dd3fc;--sb-ink4: #64748b;--sb-accent: #60a5fa;--sb-accent-bg: #1e3a8a22}.sb{width:var(--sb-w);background:var(--sb-bg);border-right:1px solid var(--sb-border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;overflow:hidden;flex-shrink:0;z-index:200;transition:width .3s var(--ease-expo),background .25s,border-color .25s;font-family:Lato,system-ui,sans-serif}.sb--collapsed{width:var(--sb-w-col)}.sb-header{padding:1.125rem 1rem;border-bottom:1px solid var(--sb-border);display:flex;align-items:center;justify-content:space-between;gap:.5rem;min-height:66px;flex-shrink:0;transition:border-color .25s}.sb--collapsed .sb-header{justify-content:center}.sb-brand{display:flex;align-items:center;gap:.625rem;min-width:0;flex:1;animation:sbBrandIn .55s cubic-bezier(.16,1,.3,1) both}@keyframes sbBrandIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:none}}.sb-brand-icon{width:34px;height:34px;background:var(--sb-ink);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--sb-bg);flex-shrink:0;transition:transform .4s var(--ease-spring),background .25s,color .25s}.sb-brand:hover .sb-brand-icon{transform:rotate(-10deg) scale(1.1)}.sb-brand-text{display:flex;flex-direction:column;min-width:0}.sb-brand-name{font-family:Lora,Georgia,serif;font-size:.975rem;font-weight:700;color:var(--sb-ink);letter-spacing:-.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .25s}.sb-role-pill{display:inline-block;font-family:IBM Plex Mono,monospace;font-size:.6rem;font-weight:600;color:var(--sb-accent);background:var(--sb-accent-bg);border:1px solid rgba(45,91,227,.15);border-radius:999px;padding:.1rem .45rem;letter-spacing:.04em;text-transform:lowercase;width:fit-content;margin-top:2px;transition:color .25s,background .25s}.sb-header-actions{display:flex;align-items:center}.sb-toggle{background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--sb-ink3);display:flex;align-items:center;justify-content:center;width:32px;height:32px;min-width:32px;min-height:32px;border-radius:6px;transition:color .18s,background .18s,transform .25s var(--ease-spring);flex-shrink:0;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.sb-toggle:hover{color:var(--sb-accent);background:var(--sb-accent-bg);transform:scale(1.1)}.desktop-only{display:flex}.mobile-only{display:none}.sb-nav{padding:1rem .75rem;flex:1;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:.2rem;scrollbar-width:thin;scrollbar-color:var(--sb-border2) transparent}.sb-nav::-webkit-scrollbar{width:4px}.sb-nav::-webkit-scrollbar-track{background:transparent}.sb-nav::-webkit-scrollbar-thumb{background:var(--sb-border2);border-radius:2px}.sb-link{display:flex;align-items:center;gap:.75rem;padding:.7rem .875rem;border-radius:8px;color:var(--sb-ink3);background:transparent;border:none;width:100%;text-align:left;cursor:pointer;font-family:Lato,system-ui,sans-serif;font-size:.875rem;font-weight:500;white-space:nowrap;overflow:hidden;position:relative;flex-shrink:0;opacity:0;transform:translate(-14px);transition:opacity .5s var(--ease-expo),transform .5s var(--ease-expo),background .18s,color .18s,box-shadow .2s;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.sb--mounted .sb-link{opacity:1;transform:translate(0)}.sb-link:hover:not(.sb-link--active){background:var(--sb-accent-bg);color:var(--sb-accent);transform:translate(4px)}.sb-link--active{background:var(--sb-ink);color:var(--sb-bg);box-shadow:0 4px 14px #1a191633;opacity:1;transform:none!important}body.dark-mode .sb-link--active{box-shadow:0 4px 14px #00000059}.sb-link--fav:not(.sb-link--active){color:#e11d48}body.dark-mode .sb-link--fav:not(.sb-link--active){color:#fb7185}.sb-link--fav:hover:not(.sb-link--active){background-color:#fff1f2;color:#be123c}body.dark-mode .sb-link--fav:hover:not(.sb-link--active){background-color:#4c002133;color:#fb7185}.sb-link--fav.sb-link--active{background:linear-gradient(135deg,#e11d48,#be123c);box-shadow:0 4px 12px #e11d484d}.sb--collapsed .sb-link{justify-content:center;padding:.7rem}.sb--collapsed .sb-label,.sb--collapsed .sb-active-dot{display:none}.sb-icon{font-size:1.2rem;min-width:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .3s var(--ease-spring)}.sb-link:hover .sb-icon{transform:scale(1.18)}.sb-link--active .sb-icon{transform:none}.sb-label{flex:1;overflow:hidden;text-overflow:ellipsis;letter-spacing:.01em}.sb-active-dot{width:5px;height:5px;border-radius:50%;background:#ffffff8c;flex-shrink:0;margin-left:auto;animation:dotPop .35s var(--ease-spring) both}@keyframes dotPop{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.sb-footer{padding:.75rem .875rem .875rem;border-top:1px solid var(--sb-border);flex-shrink:0;display:flex;flex-direction:column;gap:.35rem;transition:border-color .25s}.sb-about-toggle{display:flex;align-items:center;gap:.5rem;background:none;border:none;cursor:pointer;padding:.45rem .5rem;border-radius:7px;width:100%;font-family:IBM Plex Mono,monospace;font-size:.7rem;font-weight:500;color:var(--sb-ink3);text-align:left;transition:background .18s,color .18s}.sb-about-toggle:hover{background:var(--sb-accent-bg);color:var(--sb-accent)}.sb-about-icon{font-size:1rem;flex-shrink:0}.sb-about-caret{margin-left:auto;font-size:1rem;transition:transform .25s var(--ease-expo);display:inline-block}.sb-about-caret.open{transform:rotate(90deg)}.sb-about-panel{overflow:hidden;max-height:0;opacity:0;transition:max-height .4s var(--ease-expo),opacity .3s var(--ease-expo)}.sb-about-panel--open{max-height:240px;opacity:1}.sb-about-row{display:flex;align-items:center;gap:.625rem;padding:.5rem .25rem .35rem}.sb-about-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;border:1.5px solid var(--sb-border2);flex-shrink:0;filter:grayscale(20%);transition:filter .3s}.sb-about-avatar:hover{filter:grayscale(0%)}.sb-about-name{font-family:Lora,Georgia,serif;font-size:.78rem;font-weight:700;color:var(--sb-ink);display:block;transition:color .25s}.sb-about-role{font-family:IBM Plex Mono,monospace;font-size:.58rem;color:var(--sb-ink3);display:block;margin-top:1px;transition:color .25s}.sb-about-desc{font-size:.75rem;color:var(--sb-ink3);line-height:1.55;padding:0 .25rem .5rem;font-weight:300;margin:0;transition:color .25s}.sb-about-links{display:flex;gap:.375rem;padding:0 .25rem .5rem}.sb-about-link{display:inline-flex;align-items:center;gap:.3rem;font-family:IBM Plex Mono,monospace;font-size:.62rem;color:var(--sb-ink3);text-decoration:none;padding:.25rem .55rem;border:1px solid var(--sb-border);border-radius:999px;transition:color .18s,border-color .18s,transform .2s var(--ease-spring)}.sb-about-link:hover{color:var(--sb-accent);border-color:var(--sb-accent);transform:translateY(-2px)}.sb-watermark{display:flex;align-items:center;justify-content:space-between;padding:.25rem .25rem 0}.sb-footer-text{font-family:IBM Plex Mono,monospace;font-size:.6rem;color:var(--sb-ink4);letter-spacing:.1em;text-transform:lowercase;transition:color .25s}.sb-footer-heart{font-size:.65rem;color:#e05252;animation:heartbeat 1.8s ease infinite}@keyframes heartbeat{0%,to{transform:scale(1)}14%{transform:scale(1.4)}28%{transform:scale(1)}42%{transform:scale(1.2)}56%{transform:scale(1)}}.sb-hamburger{display:none;align-items:center;justify-content:center;position:fixed;top:1rem;left:1rem;width:38px;height:38px;background:var(--sb-bg);border:1px solid var(--sb-border);border-radius:9px;font-size:1.3rem;color:var(--sb-ink2);cursor:pointer;z-index:400;box-shadow:0 2px 8px #00000014;transition:transform .25s var(--ease-spring),box-shadow .2s,background .25s,border-color .25s}.sb-hamburger:hover{transform:scale(1.08);box-shadow:0 4px 14px #0000001f}.sb-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#1a191647;z-index:300;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:backdropIn .25s ease both}@keyframes backdropIn{0%{opacity:0}to{opacity:1}}@media (max-width: 1024px) and (min-width: 769px){.sb{width:var(--sb-w-col)}.sb .sb-brand,.sb .sb-label,.sb .sb-active-dot{display:none}.sb .sb-footer{padding:.5rem;align-items:center}.sb .sb-watermark,.sb .sb-about-toggle,.sb .sb-about-panel{display:none}.sb-link{justify-content:center;padding:.7rem}.sb-header{justify-content:center}.sb-header-actions{width:100%;justify-content:center}}@media (max-width: 768px){.sb-hamburger{display:flex}.sb-backdrop{display:block}.sb{position:fixed;top:0;left:0;height:100dvh;width:250px!important;transform:translate(-100%);transition:transform .3s var(--ease-expo);box-shadow:4px 0 24px #0000001f;z-index:350}.sb--open{transform:translate(0)}.sb .sb-brand{display:flex}.sb .sb-label{display:block}.sb-link{justify-content:flex-start;padding:.7rem .875rem}.desktop-only{display:none}.mobile-only{display:flex}}@media (prefers-reduced-motion: reduce){.sb-link,.sb-brand,.sb-brand-icon,.sb-toggle,.sb-about-panel{animation:none!important;transition:none!important;opacity:1!important;transform:none!important}.sb-about-panel--open{max-height:240px;opacity:1}}.sb-feedback-btn{display:flex;align-items:center;gap:.5rem;background:none;border:1px dashed var(--sb-border2);cursor:pointer;padding:.45rem .5rem;border-radius:7px;width:100%;font-family:IBM Plex Mono,monospace;font-size:.7rem;font-weight:500;color:var(--sb-ink3);text-align:left;transition:background .18s,color .18s,border-color .18s}.sb-feedback-btn:hover{background:#fff8f0;color:#d97706;border-color:#d97706}body.dark-mode .sb-feedback-btn:hover{background:#45260033;color:#fbbf24;border-color:#fbbf24}.sb-share-btn{display:flex;align-items:center;gap:.5rem;background:none;border:1px solid rgba(37,211,102,.35);cursor:pointer;padding:.45rem .5rem;border-radius:7px;width:100%;font-family:IBM Plex Mono,monospace;font-size:.7rem;font-weight:500;color:#16a34a;text-align:left;transition:background .18s,color .18s,border-color .18s}.sb-share-btn:hover{background:#25d3661a;color:#15803d;border-color:#25d366}body.dark-mode .sb-share-btn{color:#4ade80;border-color:#4ade8040}body.dark-mode .sb-share-btn:hover{background:#4ade801a;color:#86efac;border-color:#4ade80}.fb-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a191673;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fbFadeIn .2s ease both}@keyframes fbFadeIn{0%{opacity:0}to{opacity:1}}.fb-modal{background:#faf9f6;border:1px solid #dddbd6;border-radius:16px;width:100%;max-width:420px;padding:1.5rem;box-shadow:0 20px 60px #0000002e;animation:fbSlideUp .28s cubic-bezier(.16,1,.3,1) both}body.dark-mode .fb-modal{background:#0c1a2e;border-color:#1e3a5f}@keyframes fbSlideUp{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:none}}.fb-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.fb-modal-title{font-family:Lora,Georgia,serif;font-size:1.05rem;font-weight:700;color:#1a1916}body.dark-mode .fb-modal-title{color:#e0f2fe}.fb-modal-close{background:none;border:none;cursor:pointer;font-size:1.25rem;color:#8c8880;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;transition:background .18s,color .18s}.fb-modal-close:hover{background:#f0ede8;color:#1a1916}body.dark-mode .fb-modal-close:hover{background:#1e3a5f;color:#e0f2fe}.fb-hint{font-size:.82rem;color:#6b6966;line-height:1.55;margin:0 0 1rem}body.dark-mode .fb-hint{color:#94a3b8}.fb-field{position:relative;margin-bottom:.75rem}.fb-textarea{width:100%;resize:none;border:1.5px solid #dddbd6;border-radius:10px;padding:.75rem .875rem 1.75rem;font-family:Lato,system-ui,sans-serif;font-size:.9rem;color:#1a1916;background:#fff;outline:none;box-sizing:border-box;transition:border-color .18s,box-shadow .18s;line-height:1.55}.fb-textarea:focus{border-color:#2d5be3;box-shadow:0 0 0 3px #2d5be31a}body.dark-mode .fb-textarea{background:#0f2236;border-color:#1e3a5f;color:#e0f2fe}body.dark-mode .fb-textarea:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa26}.fb-counter{position:absolute;bottom:.5rem;right:.75rem;font-family:IBM Plex Mono,monospace;font-size:.65rem;color:#b8b5b0;pointer-events:none;transition:color .18s}.fb-counter--max{color:#e05252;font-weight:700}.fb-error{font-size:.8rem;color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:7px;padding:.5rem .75rem;margin-bottom:.75rem}.fb-actions{display:flex;gap:.625rem;justify-content:flex-end}.fb-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;border-radius:8px;font-family:Lato,system-ui,sans-serif;font-size:.85rem;font-weight:700;cursor:pointer;border:none;transition:background .18s,transform .18s,opacity .18s}.fb-btn:disabled{opacity:.55;cursor:not-allowed}.fb-btn--ghost{background:transparent;color:#6b6966;border:1px solid #dddbd6}.fb-btn--ghost:hover:not(:disabled){background:#f0ede8}body.dark-mode .fb-btn--ghost{color:#94a3b8;border-color:#1e3a5f}body.dark-mode .fb-btn--ghost:hover:not(:disabled){background:#1e3a5f}.fb-btn--primary{background:#1a1916;color:#faf9f6}.fb-btn--primary:hover:not(:disabled){background:#2d5be3;transform:translateY(-1px)}body.dark-mode .fb-btn--primary{background:#2d5be3}body.dark-mode .fb-btn--primary:hover:not(:disabled){background:#60a5fa}.fb-loading{display:flex;justify-content:center;padding:2rem;color:#8c8880;font-size:1.5rem}.fb-success{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1rem 0 .5rem;text-align:center}.fb-success-icon{font-size:2.5rem}.fb-success-msg{font-size:.9rem;color:#4a4843;line-height:1.55;max-width:280px}body.dark-mode .fb-success-msg{color:#94a3b8}.fb-spin{animation:fbSpin .7s linear infinite}@keyframes fbSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sb-storage-wrap{border:1px solid var(--sb-border);border-radius:9px;padding:.5rem .625rem;background:#2d5be30a;margin-bottom:.1rem;transition:background .25s,border-color .25s}body.dark-mode .sb-storage-wrap{background:#60a5fa0f;border-color:var(--sb-border2)}.sw--compact{display:flex;flex-direction:column;gap:.25rem;padding:.35rem .1rem .1rem}.sw-compact-header{display:flex;align-items:center;gap:.4rem}.sw-compact-icon{font-size:.85rem;color:var(--sb-accent, #2d5be3);flex-shrink:0;line-height:1;transition:color .25s}.sw-compact-title{font-family:IBM Plex Mono,monospace;font-size:.6rem;font-weight:600;color:var(--sb-ink2, #4a4843);flex:1;transition:color .25s}.sw-compact-spin{font-size:.7rem;color:var(--sb-ink3, #8c8880);flex-shrink:0}.sw-compact-label{font-family:IBM Plex Mono,monospace;font-size:.62rem;color:var(--sb-ink3, #8c8880);transition:color .25s}.sw-compact-error{font-family:IBM Plex Mono,monospace;font-size:.57rem;color:#dc2626}.sw-track{width:100%;height:6px;background:var(--sb-border, #dddbd6);border-radius:999px;overflow:hidden;transition:background .25s}.sw-fill{height:100%;border-radius:999px;transition:width .7s cubic-bezier(.16,1,.3,1)}.sw-bar--green{background:linear-gradient(90deg,#16a34a,#22c55e)}.sw-spin{animation:swSpin .7s linear infinite;display:inline-block}@keyframes swSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}body.dark-mode .sw-compact-icon{color:var(--sb-accent, #60a5fa)}body.dark-mode .sw-compact-title{color:var(--sb-ink2, #bae6fd)}body.dark-mode .sw-compact-label{color:var(--sb-ink3, #7dd3fc)}.tour-root{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99999;pointer-events:none;opacity:0;transition:opacity .25s ease}.tour-root--visible{opacity:1;pointer-events:all}.tour-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000008c;transition:clip-path .4s cubic-bezier(.4,0,.2,1);cursor:pointer}.tour-highlight{position:fixed;border-radius:10px;border:2.5px solid rgba(255,255,255,.9);pointer-events:none;transition:top .4s cubic-bezier(.4,0,.2,1),left .4s cubic-bezier(.4,0,.2,1),width .4s cubic-bezier(.4,0,.2,1),height .4s cubic-bezier(.4,0,.2,1);animation:tourPulse 2s ease-in-out infinite;box-shadow:0 0 0 4px #ffffff1f}@keyframes tourPulse{0%,to{box-shadow:0 0 0 4px #ffffff1f}50%{box-shadow:0 0 0 7px #ffffff38,0 0 32px #ffffff26}}.tour-tooltip{position:fixed;background:#fff;border-radius:16px;padding:1.125rem 1.25rem 1rem;box-shadow:0 24px 64px #0000004d,0 4px 16px #00000024;z-index:100000;pointer-events:all;transition:top .35s cubic-bezier(.4,0,.2,1),left .35s cubic-bezier(.4,0,.2,1);border:1px solid rgba(0,0,0,.07);max-height:90vh;overflow-y:auto;max-width:calc(100vw - 24px);box-sizing:border-box}body.dark-mode .tour-tooltip{background:#1e293b;border-color:#ffffff1a;color:#f1f5f9}.tour-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.625rem}.tour-step-badge{font-family:IBM Plex Mono,monospace;font-size:.63rem;font-weight:700;letter-spacing:.08em;color:#64748b;background:#f1f5f9;padding:.18rem .5rem;border-radius:999px}body.dark-mode .tour-step-badge{background:#334155;color:#94a3b8}.tour-close{background:none;border:none;cursor:pointer;color:#94a3b8;font-size:1.1rem;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;transition:color .15s,background .15s;flex-shrink:0}.tour-close:hover{color:#475569;background:#f1f5f9}body.dark-mode .tour-close:hover{color:#e2e8f0;background:#334155}.tour-emoji{font-size:1.6rem;margin-bottom:.4rem;line-height:1}.tour-title{font-family:Lora,Georgia,serif;font-size:.975rem;font-weight:700;color:#0f172a;margin-bottom:.35rem;line-height:1.35}body.dark-mode .tour-title{color:#f1f5f9}.tour-desc{font-size:.82rem;color:#475569;line-height:1.6}body.dark-mode .tour-desc{color:#94a3b8}.tour-dots{display:flex;gap:5px;margin:.75rem 0 .625rem;flex-wrap:wrap}.tour-dot{width:6px;height:6px;border-radius:50%;background:#e2e8f0;cursor:pointer;transition:background .2s,transform .2s;flex-shrink:0}.tour-dot:hover,.tour-dot--done{background:#94a3b8}.tour-dot--active{background:#2563eb;transform:scale(1.35)}body.dark-mode .tour-dot{background:#334155}body.dark-mode .tour-dot--done{background:#475569}body.dark-mode .tour-dot--active{background:#3b82f6}.tour-actions{display:flex;gap:.375rem;align-items:center;flex-wrap:nowrap}.tour-btn{padding:.4rem .8rem;border-radius:8px;font-size:.8rem;font-weight:700;cursor:pointer;border:none;display:inline-flex;align-items:center;gap:.25rem;transition:background .15s,transform .12s;font-family:inherit;white-space:nowrap;flex-shrink:0}.tour-btn:active{transform:scale(.96)}.tour-btn--back{background:#f1f5f9;color:#475569}.tour-btn--back:hover{background:#e2e8f0;color:#1e293b}body.dark-mode .tour-btn--back{background:#334155;color:#94a3b8}.tour-btn--skip{background:none;color:#94a3b8;margin-right:auto;padding-left:.2rem}.tour-btn--skip:hover{color:#475569}body.dark-mode .tour-btn--skip:hover{color:#cbd5e1}.tour-btn--next{background:#1e293b;color:#fff;padding:.4rem .95rem}.tour-btn--next:hover{background:#0f172a}body.dark-mode .tour-btn--next{background:#3b82f6}body.dark-mode .tour-btn--next:hover{background:#2563eb}.tour-replay-btn{display:flex;align-items:center;gap:.4rem;background:none;border:none;cursor:pointer;color:var(--sb-ink3, #8c8880);font-size:.72rem;font-family:IBM Plex Mono,monospace;font-weight:600;padding:.4rem .625rem;border-radius:7px;transition:background .18s,color .18s;width:100%;letter-spacing:.02em}.tour-replay-btn svg{font-size:.95rem;flex-shrink:0}.tour-replay-btn:hover{background:var(--sb-bg2, #eeecea);color:var(--sb-ink, #1a1916)}body.dark-mode .tour-replay-btn:hover{background:#ffffff0d;color:#e2e8f0}@media (max-width: 480px){.tour-tooltip{padding:.875rem 1rem;border-radius:14px}.tour-emoji{font-size:1.3rem}.tour-title{font-size:.88rem}.tour-desc{font-size:.77rem}.tour-btn{font-size:.75rem;padding:.35rem .6rem}.tour-btn--next{padding:.35rem .8rem}}.navbar{background:#f5f4f0;border-bottom:1px solid #dddbd6;padding:0 1.5rem;position:sticky;top:0;z-index:100;font-family:Lato,system-ui,sans-serif;transition:background .25s,border-color .25s}body.dark-mode .navbar{background:#0c4a6e;border-bottom-color:#075985}.navbar-content{display:flex;justify-content:space-between;align-items:center;height:64px;max-width:1400px;margin:0 auto}.navbar-title{font-family:Lora,Georgia,serif;font-size:1.05rem;font-weight:700;color:#1a1916;margin:0;letter-spacing:-.2px;transition:color .25s}body.dark-mode .navbar-title{color:#e0f2fe}.navbar-actions{display:flex;align-items:center;gap:.5rem}.profile-dropdown{position:relative}.profile-button{display:flex;align-items:center;gap:.5rem;background:none;border:1px solid #dddbd6;cursor:pointer;padding:.35rem .625rem .35rem .35rem;border-radius:10px;transition:background .18s,border-color .18s;font-family:Lato,system-ui,sans-serif}body.dark-mode .profile-button{border-color:#075985}.profile-button:hover{background:#eeedea;border-color:#c8c5be}body.dark-mode .profile-button:hover{background:#052e3d;border-color:#0369a1}.profile-avatar{width:32px;height:32px;border-radius:8px;background:#1a1916;color:#f5f4f0;display:flex;align-items:center;justify-content:center;font-family:IBM Plex Mono,monospace;font-weight:600;font-size:.8rem;flex-shrink:0;overflow:hidden;transition:background .25s}body.dark-mode .profile-avatar{background:#2d5be3}.profile-avatar-img{width:100%;height:100%;object-fit:cover}.profile-info{display:flex;flex-direction:column;align-items:flex-start;gap:0}.profile-name{font-family:Lato,system-ui,sans-serif;font-weight:700;font-size:.8rem;color:#1a1916;line-height:1.3;white-space:nowrap;max-width:120px;overflow:hidden;text-overflow:ellipsis;transition:color .25s}body.dark-mode .profile-name{color:#e0f2fe}.profile-role{font-family:IBM Plex Mono,monospace;font-size:.62rem;font-weight:500;color:#2d5be3;background:#eef2ff;border:1px solid rgba(45,91,227,.15);border-radius:999px;padding:.05rem .4rem;text-transform:lowercase;letter-spacing:.03em;margin-top:2px;transition:color .25s,background .25s}body.dark-mode .profile-role{color:#60a5fa;background:#1e3a8a22;border-color:#60a5fa33}.dropdown-arrow{font-size:1.1rem;color:#8c8880;transition:transform .2s ease,color .25s;flex-shrink:0}.dropdown-arrow.rotated{transform:rotate(180deg)}body.dark-mode .dropdown-arrow{color:#7dd3fc}.dropdown-menu{position:absolute;top:calc(100% + .5rem);right:0;background:#faf9f6;border:1px solid #dddbd6;border-radius:12px;box-shadow:0 10px 30px #1a19161f,0 2px 8px #1a19160f;min-width:230px;z-index:1000;overflow:hidden;animation:nbSlideDown .18s cubic-bezier(.16,1,.3,1);font-family:Lato,system-ui,sans-serif}body.dark-mode .dropdown-menu{background:#0c4a6e;border-color:#075985;box-shadow:0 10px 30px #0006}@keyframes nbSlideDown{0%{opacity:0;transform:translateY(-8px) scale(.97)}to{opacity:1;transform:none}}.dropdown-header{padding:1rem;display:flex;align-items:center;gap:.75rem}.dropdown-avatar{width:38px;height:38px;border-radius:9px;background:#1a1916;color:#f5f4f0;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0;overflow:hidden;transition:background .25s}body.dark-mode .dropdown-avatar{background:#2d5be3}.dropdown-avatar-img{width:100%;height:100%;object-fit:cover}.dropdown-name{font-family:Lora,Georgia,serif;font-weight:700;font-size:.875rem;color:#1a1916;margin:0 0 .15rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:155px;transition:color .25s}body.dark-mode .dropdown-name{color:#e0f2fe}.dropdown-email{font-family:IBM Plex Mono,monospace;font-size:.7rem;color:#8c8880;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:155px;transition:color .25s}body.dark-mode .dropdown-email{color:#7dd3fc}.dropdown-divider{border:none;border-top:1px solid #dddbd6;margin:0;transition:border-color .25s}body.dark-mode .dropdown-divider{border-top-color:#075985}.dropdown-item{width:100%;padding:.75rem 1rem;background:none;border:none;text-align:left;cursor:pointer;display:flex;align-items:center;gap:.625rem;color:#1a1916;font-family:Lato,system-ui,sans-serif;font-size:.875rem;font-weight:500;transition:background .15s,color .15s}body.dark-mode .dropdown-item{color:#e0f2fe}.dropdown-item:hover{background:#eeedea}body.dark-mode .dropdown-item:hover{background:#052e3d}.dropdown-item--danger{color:#dc2626}body.dark-mode .dropdown-item--danger{color:#f87171}.dropdown-item--danger:hover{background:#fef2f2;color:#b91c1c}body.dark-mode .dropdown-item--danger:hover{background:#7f1d1d22;color:#fca5a5}@media (max-width: 768px){.navbar{padding:0 1rem 0 3.5rem}.navbar-title{font-size:.95rem}.profile-info,.dropdown-arrow{display:none}}@media (max-width: 380px){.navbar{padding-left:3.25rem}.dropdown-menu{min-width:200px;right:-.5rem}.profile-name{max-width:90px}}@media (max-width: 320px){.dropdown-menu{min-width:180px;right:0;left:auto}}:root{--fd-bg: #f5f4f0;--fd-bg2: #eeecea;--fd-card: #ffffff;--fd-ink: #1a1916;--fd-ink2: #4a4843;--fd-ink3: #8c8880;--fd-ink4: #b8b5b0;--fd-accent: #2d5be3;--fd-green: #1a7a4a;--fd-amber: #92400e;--fd-red: #b91c1c;--fd-border: #dddbd6;--fd-border2: #c8c5be;--ease-expo: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1)}body.dark-mode{--fd-bg: #052e3d;--fd-bg2: #0c4a6e;--fd-card: #0c4a6e;--fd-ink: #e0f2fe;--fd-ink2: #bae6fd;--fd-ink3: #7dd3fc;--fd-ink4: #38bdf8;--fd-accent: #22d3ee;--fd-green: #4ade80;--fd-amber: #fbbf24;--fd-red: #f87171;--fd-border: #075985;--fd-border2: #0369a1}.app-container{display:flex;min-height:100vh;background:var(--fd-bg);font-family:Lato,system-ui,sans-serif;transition:background .25s}.main-content{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--fd-bg);transition:background .25s}.fd-page{flex:1;padding:3rem 3rem 5rem;max-width:1140px}.fd-enter{opacity:0;transform:translateY(18px);transition:none}.fd-ready .fd-enter{opacity:1;transform:none;transition:opacity .7s var(--ease-expo),transform .7s var(--ease-expo)}.fd-reveal{opacity:0;transform:translateY(22px);transition:opacity .65s var(--ease-expo),transform .65s var(--ease-expo)}.fd-reveal--left{transform:translate(-22px)}.fd-reveal--right{transform:translate(22px)}.fd-reveal.fd-visible{opacity:1;transform:none}.fd-hero{display:grid;grid-template-columns:1fr 1fr;gap:3rem;margin-bottom:3rem;align-items:start}.fd-hero-label{font-family:IBM Plex Mono,monospace;font-size:.72rem;color:var(--fd-ink3);letter-spacing:.05em;margin-bottom:1rem;transition:color .25s}.fd-title{font-family:Lora,Georgia,serif;font-size:clamp(2rem,4vw,3rem);font-weight:700;color:var(--fd-ink);letter-spacing:-1px;line-height:1.13;margin-bottom:1rem;transition:color .25s}.fd-title-accent{color:var(--fd-accent);font-style:italic;transition:color .25s}.fd-subtitle{font-size:1rem;color:var(--fd-ink2);line-height:1.75;font-weight:300;max-width:420px;transition:color .25s}.fd-profile-card{display:flex;align-items:center;gap:1rem;background:var(--fd-card);border:1px solid var(--fd-border);border-radius:12px;padding:1.25rem 1.5rem;margin-bottom:1rem;box-shadow:0 4px 16px #0000000a;transition:background .25s,border-color .25s}.fd-profile-avatar{width:48px;height:48px;background:var(--fd-ink);color:var(--fd-card);border-radius:12px;display:flex;align-items:center;justify-content:center;font-family:Lora,serif;font-size:1.25rem;font-weight:700;flex-shrink:0;transition:background .25s,color .25s}.fd-profile-name{font-family:Lora,serif;font-size:.95rem;font-weight:700;color:var(--fd-ink);transition:color .25s}.fd-profile-email{font-size:.78rem;color:var(--fd-ink3);margin:2px 0 4px;transition:color .25s}.fd-profile-role{font-family:IBM Plex Mono,monospace;font-size:.62rem;font-weight:600;color:var(--fd-accent);background:color-mix(in srgb,var(--fd-accent) 10%,transparent);border:1px solid color-mix(in srgb,var(--fd-accent) 20%,transparent);border-radius:999px;padding:.1rem .5rem;text-transform:lowercase;transition:all .25s}.fd-stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.fd-stat{background:var(--fd-card);border:1px solid var(--fd-border);border-radius:10px;padding:.875rem 1rem;text-align:center;transition:background .25s,border-color .25s}.fd-stat-val{font-family:Lora,serif;font-size:1.5rem;font-weight:700;color:var(--fd-ink);line-height:1;transition:color .25s}.fd-stat-lbl{font-family:IBM Plex Mono,monospace;font-size:.62rem;color:var(--fd-ink3);margin-top:4px;transition:color .25s}.fd-alert{display:flex;align-items:center;gap:.5rem;font-size:.875rem;padding:.65rem 1rem;border-radius:8px;margin-bottom:1.25rem;font-weight:500}.fd-alert--err{background:#fff5f5;border:1px solid #fecaca;color:var(--fd-red)}.fd-alert--ok{background:#f0fdf4;border:1px solid #bbf7d0;color:var(--fd-green)}body.dark-mode .fd-alert--err{background:#451a1a33;border-color:#7f1d1d}body.dark-mode .fd-alert--ok{background:#052e1633;border-color:#166534}.fd-section-head{display:flex;align-items:center;justify-content:space-between;padding-bottom:1.5rem;margin-bottom:2rem;border-bottom:1px solid var(--fd-border);transition:border-color .25s}.fd-section-title{font-family:Lora,serif;font-size:1.375rem;font-weight:700;color:var(--fd-ink);letter-spacing:-.3px;transition:color .25s}.fd-section-sub{font-family:IBM Plex Mono,monospace;font-size:.68rem;color:var(--fd-ink3);margin-top:3px;transition:color .25s}.fd-create-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1.25rem;background:var(--fd-ink);color:var(--fd-card);border:none;border-radius:9px;font-family:Lato,system-ui,sans-serif;font-size:.875rem;font-weight:700;cursor:pointer;transition:transform .2s var(--ease-spring),box-shadow .2s,background .25s,color .25s}.fd-create-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #1a191633}body.dark-mode .fd-create-btn:hover{box-shadow:0 6px 20px #0006}.fd-create-btn:active{transform:translateY(0)}.fd-loading{display:flex;align-items:center;gap:.75rem;padding:4rem 0;font-family:IBM Plex Mono,monospace;font-size:.8rem;color:var(--fd-ink3)}.fd-spinner{font-size:1.2rem;animation:fdSpin .8s linear infinite;color:var(--fd-accent)}@keyframes fdSpin{to{transform:rotate(360deg)}}.fd-empty{display:flex;flex-direction:column;align-items:center;padding:5rem 2rem;text-align:center}.fd-empty-icon{width:64px;height:64px;background:var(--fd-bg2);border:1px solid var(--fd-border);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--fd-ink4);margin-bottom:1.25rem;transition:background .25s,border-color .25s,color .25s}.fd-empty-title{font-family:Lora,serif;font-size:1.375rem;font-weight:700;color:var(--fd-ink);margin-bottom:.5rem;transition:color .25s}.fd-empty-sub{font-size:.9rem;color:var(--fd-ink3);font-weight:300;margin-bottom:1.5rem;transition:color .25s}.fd-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(320px,100%),1fr));gap:1.25rem}.fd-card{background:var(--fd-card);border:1px solid var(--fd-border);border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;gap:0;overflow:hidden;min-width:0;transition:border-color .2s,box-shadow .3s var(--ease-expo),transform .3s var(--ease-expo),background .25s}.fd-card:hover{border-color:var(--fd-border2);box-shadow:0 8px 32px #00000012;transform:translateY(-3px)}.fd-card-top{display:flex;align-items:flex-start;gap:.875rem;margin-bottom:1.125rem}.fd-card-icon{width:42px;height:42px;background:var(--fd-ink);color:var(--fd-card);border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0;transition:transform .4s var(--ease-spring),background .25s,color .25s}.fd-card:hover .fd-card-icon{transform:rotate(-8deg) scale(1.08)}.fd-card-title-wrap{flex:1;min-width:0;display:flex;align-items:flex-start;gap:.5rem}.fd-card-title{font-family:Lora,serif;font-size:1rem;font-weight:700;color:var(--fd-ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .25s}.fd-msg-dot{display:flex;align-items:center;color:#d97706;font-size:1rem;flex-shrink:0}body.dark-mode .fd-msg-dot{color:var(--fd-amber)}.fd-card-meta{display:flex;flex-direction:column;gap:.3rem;margin-bottom:.875rem;font-size:.8rem;color:var(--fd-ink3);transition:color .25s}.fd-card-meta span{display:flex;gap:.4rem;min-width:0}.fd-card-meta strong{color:var(--fd-ink2);font-weight:600;min-width:46px;flex-shrink:0;transition:color .25s}.fd-card-meta span>span,.fd-card-meta span>*:not(strong){overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.fd-sf-list{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.875rem;min-width:0}.fd-sf-chip{display:inline-flex;align-items:center;gap:.3rem;font-family:IBM Plex Mono,monospace;font-size:.68rem;font-weight:500;color:var(--fd-accent);background:color-mix(in srgb,var(--fd-accent) 8%,transparent);border:1px solid color-mix(in srgb,var(--fd-accent) 18%,transparent);border-radius:999px;padding:.18rem .55rem;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:all .25s}.fd-sf-chip em{font-style:normal;color:var(--fd-ink3)}.fd-msg-preview{display:flex;align-items:flex-start;gap:.4rem;background:#fffbeb;border:1px solid #fde68a;border-radius:7px;padding:.5rem .75rem;margin-bottom:.875rem;font-size:.78rem;color:#92400e;line-height:1.45;overflow-wrap:break-word;word-break:break-word;min-width:0;overflow:hidden}body.dark-mode .fd-msg-preview{background:#451a0033;border-color:#78350f44;color:var(--fd-amber)}.fd-code-box{background:var(--fd-bg2);border:1px solid var(--fd-border);border-radius:9px;padding:.75rem 1rem;margin-bottom:1rem;transition:background .25s,border-color .25s}.fd-code-label{font-family:IBM Plex Mono,monospace;font-size:.6rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--fd-accent);margin-bottom:.4rem;display:block;transition:color .25s}.fd-code-row{display:flex;align-items:center;gap:.6rem;min-width:0}.fd-code{flex:1;font-family:IBM Plex Mono,monospace;font-size:1.2rem;font-weight:700;letter-spacing:.2em;color:var(--fd-ink);background:none;border:none;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:color .25s}.fd-copy-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .7rem;border-radius:6px;border:1px solid var(--fd-border2);background:var(--fd-card);color:var(--fd-ink2);font-family:IBM Plex Mono,monospace;font-size:.68rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .18s}.fd-copy-btn:hover{background:var(--fd-ink);color:var(--fd-card);border-color:var(--fd-ink)}.fd-copy-btn--done{background:var(--fd-green);border-color:var(--fd-green);color:#fff}body.dark-mode .fd-copy-btn--done{background:#166534;border-color:#166534}.fd-card-actions{display:flex;gap:.5rem;margin-top:auto}.fd-btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.55rem 1rem;border-radius:7px;border:none;cursor:pointer;font-family:Lato,system-ui,sans-serif;font-size:.8125rem;font-weight:600;white-space:nowrap;transition:transform .2s var(--ease-spring),box-shadow .2s,background .2s,color .25s}.fd-btn:hover{transform:translateY(-1px)}.fd-btn:active{transform:translateY(0)}.fd-btn--primary{background:var(--fd-ink);color:var(--fd-card);flex:1}.fd-btn--primary:hover{box-shadow:0 4px 14px #1a191638}body.dark-mode .fd-btn--primary:hover{box-shadow:0 4px 14px #0006}.fd-btn--secondary{background:var(--fd-bg2);color:var(--fd-ink2);border:1px solid var(--fd-border);flex:1}.fd-btn--secondary:hover{border-color:var(--fd-border2);color:var(--fd-ink)}.fd-btn--danger{background:#fee2e2;color:var(--fd-red);border:1px solid #fecaca;padding:.55rem .75rem}.fd-btn--danger:hover{background:var(--fd-red);color:#fff;border-color:var(--fd-red)}body.dark-mode .fd-btn--danger{background:#451a1a33;border-color:#7f1d1d;color:var(--fd-red)}body.dark-mode .fd-btn--danger:hover{background:#7f1d1d;color:#fff}.fd-btn--ghost{background:transparent;color:var(--fd-ink2);border:1px solid var(--fd-border)}.fd-btn--ghost:hover{background:var(--fd-bg2);color:var(--fd-ink)}.fd-spin{animation:fdSpin .75s linear infinite;font-size:.9rem}.fd-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#1a19168c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:1rem;animation:fdOverlayIn .2s ease both}@keyframes fdOverlayIn{0%{opacity:0}to{opacity:1}}.fd-modal{background:var(--fd-card);border:1px solid var(--fd-border);border-radius:14px;width:100%;max-width:560px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 32px 80px #00000047;animation:fdModalIn .35s var(--ease-expo) both;transition:background .25s,border-color .25s}@keyframes fdModalIn{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:none}}.fd-modal-header{display:flex;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--fd-border);flex-shrink:0;transition:border-color .25s}.fd-modal-title{flex:1;font-family:Lora,serif;font-size:1.05rem;font-weight:700;color:var(--fd-ink);transition:color .25s}.fd-modal-close{width:28px;height:28px;background:none;border:none;border-radius:6px;font-size:1.1rem;color:var(--fd-ink3);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .18s,color .18s}.fd-modal-close:hover{background:var(--fd-bg2);color:var(--fd-ink)}.fd-modal-body{flex:1;padding:1.5rem;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--fd-border2) transparent}.fd-modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--fd-border);display:flex;gap:.625rem;justify-content:flex-end;flex-shrink:0;transition:border-color .25s}.fd-modal-hint{font-size:.82rem;color:var(--fd-ink3);margin-bottom:1.25rem;line-height:1.6;transition:color .25s}.fd-form{display:flex;flex-direction:column;gap:0}.fd-field{margin-bottom:1.125rem}.fd-field-row{display:grid;grid-template-columns:1fr 1fr;gap:.875rem;margin-bottom:1.125rem}.fd-label{display:block;font-size:.8125rem;font-weight:600;color:var(--fd-ink2);margin-bottom:.4rem;transition:color .25s}.fd-label span{color:var(--fd-accent)}.fd-optional{color:var(--fd-ink4);font-weight:400;font-size:.75rem;transition:color .25s}.fd-input,.fd-textarea{width:100%;padding:.625rem .875rem;border:1.5px solid var(--fd-border);border-radius:8px;background:var(--fd-bg);color:var(--fd-ink);font-size:.875rem;font-family:Lato,system-ui,sans-serif;transition:border-color .2s,box-shadow .2s,background .25s,color .25s;outline:none}.fd-input:focus,.fd-textarea:focus{border-color:var(--fd-accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--fd-accent) 12%,transparent)}.fd-textarea{resize:vertical;line-height:1.6}.fd-char-count{font-family:IBM Plex Mono,monospace;font-size:.68rem;color:var(--fd-ink4);text-align:right;margin-top:.25rem;transition:color .25s}.fd-clear-msg-btn{background:none;border:none;cursor:pointer;font-size:.78rem;color:var(--fd-red);padding:0;margin-top:.375rem;transition:opacity .2s}.fd-clear-msg-btn:hover{opacity:.7}.fd-sf-create{display:flex;align-items:center;gap:.5rem;background:var(--fd-bg2);border:1px solid var(--fd-border);border-radius:8px;padding:.5rem .75rem;margin-bottom:.875rem;transition:background .25s,border-color .25s}.fd-sf-create-icon{font-size:1.1rem;color:var(--fd-accent);flex-shrink:0}.fd-sf-input{flex:1;border:none;background:transparent;font-size:.875rem;color:var(--fd-ink);outline:none;font-family:Lato,system-ui,sans-serif;transition:color .25s}.fd-sf-input::placeholder{color:var(--fd-ink4)}.fd-sf-btn{flex-shrink:0;padding:.35rem .75rem;font-size:.78rem}.fd-dropzone{border:2px dashed var(--fd-border);border-radius:10px;padding:2.25rem 1.5rem;text-align:center;cursor:pointer;transition:border-color .2s,background .2s,transform .2s;background:var(--fd-bg);margin-bottom:.875rem}.fd-dropzone:hover{border-color:var(--fd-accent);background:color-mix(in srgb,var(--fd-accent) 4%,var(--fd-bg))}.fd-dropzone--active{border-color:var(--fd-accent);background:color-mix(in srgb,var(--fd-accent) 8%,var(--fd-bg));transform:scale(1.01)}.fd-dropzone-icon{font-size:2.5rem;margin-bottom:.625rem}.fd-dropzone-text{font-size:.9rem;font-weight:700;color:var(--fd-ink);margin:0 0 .25rem;transition:color .25s}.fd-dropzone-sub{font-size:.8rem;color:var(--fd-ink3);margin:0;transition:color .25s}.fd-file-list{background:var(--fd-card);border:1px solid var(--fd-border);border-radius:9px;padding:.75rem;max-height:260px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--fd-border2) transparent;transition:background .25s,border-color .25s}.fd-file-list-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:.5rem;margin-bottom:.5rem;border-bottom:1px solid var(--fd-border);font-family:IBM Plex Mono,monospace;font-size:.72rem;font-weight:600;color:var(--fd-ink2);transition:border-color .25s,color .25s}.fd-clear-btn{font-size:.72rem;font-weight:600;color:var(--fd-red);background:none;border:1px solid var(--fd-border);border-radius:5px;padding:.15rem .5rem;cursor:pointer;transition:background .18s,color .18s}.fd-clear-btn:hover{background:var(--fd-red);color:#fff;border-color:var(--fd-red)}.fd-file-row{display:flex;align-items:center;gap:.625rem;padding:.5rem .625rem;background:var(--fd-bg);border:1px solid var(--fd-border);border-radius:7px;margin-bottom:.35rem;transition:border-color .18s,background .25s}.fd-file-row:hover{border-color:var(--fd-border2)}.fd-file-emoji{font-size:1.25rem}.fd-file-info{flex:1;min-width:0}.fd-file-name{font-size:.8125rem;font-weight:600;color:var(--fd-ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .25s}.fd-file-size{font-size:.72rem;color:var(--fd-ink3);margin-top:1px;transition:color .25s}.fd-file-remove{padding:.2rem .5rem;border:1px solid var(--fd-border);background:var(--fd-card);border-radius:5px;font-size:.78rem;font-weight:700;color:var(--fd-red);cursor:pointer;flex-shrink:0;transition:background .18s,color .18s}.fd-file-remove:hover{background:var(--fd-red);color:#fff;border-color:var(--fd-red)}.fd-dest-badge{margin-top:.625rem;padding:.45rem .875rem;background:color-mix(in srgb,var(--fd-accent) 8%,transparent);border:1px solid color-mix(in srgb,var(--fd-accent) 18%,transparent);border-radius:7px;font-size:.8rem;color:var(--fd-accent);transition:all .25s}@media (max-width: 1024px){.fd-hero{grid-template-columns:1fr;gap:1.5rem}.fd-hero-right{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.fd-profile-card{margin-bottom:0}}@media (max-width: 768px){.fd-page{padding:2rem 1.5rem 3rem}.fd-grid,.fd-hero-right{grid-template-columns:1fr}.fd-stats-row{grid-template-columns:repeat(3,1fr)}.fd-field-row{grid-template-columns:1fr}}@media (max-width: 480px){.fd-page{padding:1.75rem 1.25rem}.fd-card-actions{flex-wrap:wrap}.fd-share-row{flex-direction:column;align-items:flex-start;gap:.4rem}.fd-share-btns{width:100%}.fd-share-btn{flex:1;justify-content:center;font-size:.7rem}.fd-stats-row{gap:.5rem}.fd-stat{padding:.75rem .5rem}.fd-stat-val{font-size:1.25rem}}@media (max-width: 360px){.fd-page{padding:1.5rem .875rem}.fd-card{padding:1.125rem}.fd-code{font-size:1rem;letter-spacing:.1em}}@media (prefers-reduced-motion: reduce){.fd-enter,.fd-reveal{opacity:1!important;transform:none!important;transition:none!important}.fd-card,.fd-card-icon,.fd-btn,.fd-modal{transition:none!important;animation:none!important}.fd-reveal.fd-visible{opacity:1;transform:none}}.fd-storage-row{margin-bottom:1.75rem;max-width:600px}.fd-share-row{display:flex;align-items:center;justify-content:space-between;margin-top:.6rem;padding-top:.6rem;border-top:1px solid var(--fd-border);gap:.5rem;flex-wrap:wrap}.fd-share-label{font-family:IBM Plex Mono,monospace;font-size:.62rem;font-weight:600;color:var(--fd-ink3);white-space:nowrap;transition:color .25s}.fd-share-btns{display:flex;gap:.4rem}.fd-share-btn{display:inline-flex;align-items:center;gap:.3rem;font-family:Lato,system-ui,sans-serif;font-size:.72rem;font-weight:700;padding:.32rem .7rem;border-radius:7px;border:none;cursor:pointer;transition:background .18s,transform .18s,color .18s;white-space:nowrap}.fd-share-btn:hover{transform:translateY(-1px)}.fd-share-btn--wa{background:#25d366;color:#fff}.fd-share-btn--wa:hover{background:#1ebe5a}body.dark-mode .fd-share-btn--wa{background:#128c3e}body.dark-mode .fd-share-btn--wa:hover{background:#25d366}.fd-share-btn--copy{background:var(--fd-bg2);color:var(--fd-ink2);border:1px solid var(--fd-border)}.fd-share-btn--copy:hover{border-color:var(--fd-border2);color:var(--fd-ink)}.fd-share-btn--done{background:#dcfce7!important;color:#166534!important;border-color:#bbf7d0!important}body.dark-mode .fd-share-btn--copy{background:var(--fd-bg2);border-color:var(--fd-border);color:var(--fd-ink3)}body.dark-mode .fd-share-btn--done{background:#14532d55!important;color:#4ade80!important;border-color:#166534!important}.fd-fab-share{position:fixed;bottom:2rem;right:2rem;z-index:500;animation:fdFabIn .5s cubic-bezier(.34,1.56,.64,1) .8s both}@keyframes fdFabIn{0%{opacity:0;transform:scale(.6) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.fd-fab-btn{display:flex;align-items:center;gap:.5rem;background:#25d366;color:#fff;border:none;border-radius:999px;padding:.7rem 1.25rem .7rem 1rem;font-family:Lato,system-ui,sans-serif;font-size:.875rem;font-weight:700;cursor:pointer;box-shadow:0 4px 20px #25d36673;transition:background .2s,transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .2s}.fd-fab-btn:hover{background:#1ebe5a;transform:scale(1.07) translateY(-2px);box-shadow:0 8px 28px #25d3668c}.fd-fab-btn:active{transform:scale(.97)}.fd-fab-icon{font-size:1.1rem}.fd-fab-label{letter-spacing:.01em}@media (max-width: 480px){.fd-fab-btn{padding:.85rem;border-radius:50%}.fd-fab-label{display:none}.fd-fab-icon{font-size:1.3rem}}.fd-platform-card{background:var(--fd-bg2);border:1px solid var(--fd-border);border-radius:12px;padding:1rem 1.125rem;margin-top:.625rem;transition:background .25s,border-color .25s}.fd-platform-card-heading{display:flex;align-items:center;gap:.45rem;font-family:IBM Plex Mono,monospace;font-size:.65rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--fd-ink3);margin-bottom:.875rem;transition:color .25s}.fd-platform-dot{width:6px;height:6px;border-radius:50%;background:var(--fd-accent);flex-shrink:0;animation:fdDotPulse 2.5s ease-in-out infinite}@keyframes fdDotPulse{0%,to{opacity:1}50%{opacity:.4}}.fd-platform-card-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.fd-platform-item{display:flex;flex-direction:column;gap:2px}.fd-platform-val{font-family:Lora,serif;font-size:1.1rem;font-weight:700;color:var(--fd-ink2);line-height:1;transition:color .25s}.fd-platform-lbl{font-family:IBM Plex Mono,monospace;font-size:.58rem;color:var(--fd-ink3);transition:color .25s}@media (max-width: 480px){.fd-platform-val{font-size:.95rem}.fd-platform-card{padding:.875rem}}.fd-p2-prompt{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;margin-bottom:1.25rem;background:var(--fd-card);border:1.5px solid var(--fd-accent);border-radius:12px;box-shadow:0 4px 16px #2d5be31a;animation:p2SlideIn .4s cubic-bezier(.16,1,.3,1) both;flex-wrap:wrap}@keyframes p2SlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}.fd-p2-prompt-left{display:flex;align-items:center;gap:.875rem;flex:1;min-width:0}.fd-p2-prompt-emoji{font-size:1.75rem;flex-shrink:0;line-height:1}.fd-p2-prompt-title{font-family:Lora,serif;font-size:.9rem;font-weight:700;color:var(--fd-ink);margin-bottom:.2rem;transition:color .25s}.fd-p2-prompt-sub{font-size:.78rem;color:var(--fd-ink3);transition:color .25s}.fd-p2-prompt-actions{display:flex;gap:.5rem;align-items:center;flex-shrink:0}.fd-p2-prompt-btn{padding:.45rem 1rem;border-radius:8px;font-size:.82rem;font-weight:700;cursor:pointer;border:none;font-family:Lato,system-ui,sans-serif;transition:background .15s,transform .15s;white-space:nowrap}.fd-p2-prompt-btn:active{transform:scale(.97)}.fd-p2-prompt-btn--primary{background:var(--fd-ink);color:var(--fd-card)}.fd-p2-prompt-btn--primary:hover{background:var(--fd-ink2)}.fd-p2-prompt-btn--skip{background:var(--fd-bg2);color:var(--fd-ink3);border:1px solid var(--fd-border)}.fd-p2-prompt-btn--skip:hover{color:var(--fd-ink);border-color:var(--fd-border2)}@media (max-width: 480px){.fd-p2-prompt{padding:.875rem 1rem}.fd-p2-prompt-emoji{font-size:1.4rem}.fd-p2-prompt-title{font-size:.82rem}.fd-p2-prompt-sub{font-size:.72rem}.fd-p2-prompt-actions{width:100%;justify-content:flex-end}}.fpv-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000f2;z-index:99999;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:0}.fpv-modal{width:100%;height:100vh;height:100dvh;background:#0c4a6e;display:flex;flex-direction:column;overflow:hidden}.fpv-header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#052e3d;border-bottom:1px solid rgba(255,255,255,.07);flex-shrink:0;min-height:52px}.fpv-filename{flex:1;color:#f1f5f9;font-size:.875rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fpv-close{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#f87171;width:2.25rem;height:2.25rem;border-radius:8px;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;touch-action:manipulation}.fpv-close:hover{background:#ef4444;border-color:#ef4444;color:#fff}.fpv-body{flex:1;overflow:hidden;background:#052e3d;position:relative;display:flex;align-items:center;justify-content:center}.fpv-iframe{width:100%;height:100%;border:none;display:block;background:#fff}.fpv-img-wrap{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#052e3d;overflow:auto;-webkit-overflow-scrolling:touch;padding:1rem}.fpv-img{max-width:100%;max-height:100%;object-fit:contain;border-radius:4px}.fpv-unavail{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;color:#64748b;text-align:center;padding:2rem;background:#052e3d}.fpv-unavail-icon{font-size:3.5rem;color:#475569}.fpv-unavail h3{color:#94a3b8;margin:0}.fpv-unavail p{margin:0;font-size:.875rem;color:#64748b}.fm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d1;z-index:8000;display:flex;align-items:center;justify-content:center;padding:1.5rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.fm-window{width:100%;max-width:1060px;height:88vh;background:#fff;border-radius:12px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 32px 100px #0000008c}.fm-titlebar{display:flex;align-items:center;justify-content:space-between;padding:0 1rem;height:52px;background:linear-gradient(135deg,#0891b2,#0e7490);flex-shrink:0;gap:.75rem}.fm-titlebar-left{display:flex;align-items:center;gap:.5rem;min-width:0;flex:1}.fm-titlebar-right{display:flex;align-items:center;gap:.35rem;flex-shrink:0}.fm-title{color:#f1f5f9;font-size:.95rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fm-count-badge{color:#7dd3fc;font-size:.75rem;background:#ffffff1a;padding:.15rem .5rem;border-radius:999px;white-space:nowrap;flex-shrink:0}.fm-view-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.1);color:#7dd3fc;width:2.25rem;height:2.25rem;border-radius:6px;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:all .15s;touch-action:manipulation}.fm-view-btn:hover{background:#ffffff26;color:#bae6fd}.fm-view-btn.active{background:#0891b2;border-color:#0891b2;color:#fff}.fm-close-btn{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#f87171;width:2.25rem;height:2.25rem;border-radius:6px;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:all .15s;margin-left:.35rem;touch-action:manipulation}.fm-close-btn:hover{background:#ef4444;border-color:#ef4444;color:#fff}.fm-hintbar{padding:.45rem 1rem;background:#f1f5f9;border-bottom:1px solid #bae6fd;font-size:.78rem;color:#0369a1;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fm-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:1rem;background:#f8fafc}.fm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(128px,1fr));gap:.75rem}.fm-tile{background:#fff;border:2px solid #bae6fd;border-radius:10px;padding:1rem .75rem .75rem;display:flex;flex-direction:column;align-items:center;gap:.35rem;cursor:pointer;text-align:center;-webkit-user-select:none;user-select:none;transition:border-color .15s,box-shadow .15s;touch-action:manipulation}.fm-tile:hover{border-color:#7dd3fc;box-shadow:0 4px 16px #00000014}.fm-tile--sel{border-color:#3b82f6;background:#eff6ff;box-shadow:0 0 0 3px #3b82f62e}.fm-tile-icon{font-size:2.5rem;line-height:1}.fm-tile-name{font-size:.72rem;font-weight:500;color:#075985;word-break:break-word;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.3;width:100%}.fm-tile-size{font-size:.68rem;color:#7dd3fc}.fm-tile-actions{display:flex;gap:.25rem;margin-top:.2rem;flex-wrap:wrap;justify-content:center}.fm-icon-btn{background:#f1f5f9;border:1px solid #bae6fd;border-radius:6px;cursor:pointer;font-size:.85rem;padding:.3rem .5rem;transition:background .15s;line-height:1;display:flex;align-items:center;justify-content:center;min-width:34px;min-height:34px;touch-action:manipulation}.fm-icon-btn--preview:hover{background:#dbeafe;border-color:#93c5fd}.fm-icon-btn--dl:hover{background:#dcfce7;border-color:#86efac}.fm-table{width:100%;border-collapse:collapse;background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 1px 6px #0000000f;min-width:400px}.fm-table thead tr{background:#f1f5f9}.fm-table th{padding:.65rem 1rem;font-size:.75rem;font-weight:700;color:#0369a1;text-align:left;border-bottom:1px solid #bae6fd;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.fm-row{cursor:pointer;border-bottom:1px solid #f1f5f9;transition:background .1s;-webkit-user-select:none;user-select:none}.fm-row:hover{background:#f8fafc}.fm-row--sel{background:#eff6ff}.fm-row td{padding:.65rem 1rem;font-size:.85rem;color:#075985}.fm-td-name{display:flex;align-items:center;gap:.4rem}.fm-row-name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}.fm-td-meta{color:#0369a1;font-size:.82rem;white-space:nowrap}.fm-type-badge{padding:.2rem .55rem;border-radius:999px;font-size:.72rem;font-weight:700;white-space:nowrap}.fm-row-actions{display:flex;gap:.4rem}.fm-action-btn{padding:.35rem .65rem;border-radius:6px;border:1px solid #bae6fd;cursor:pointer;font-size:.78rem;font-weight:500;background:#f8fafc;white-space:nowrap;transition:all .15s;display:flex;align-items:center;gap:.25rem;min-height:34px;touch-action:manipulation}.fm-action-btn--preview:hover{background:#dbeafe;border-color:#93c5fd;color:#2563eb}.fm-action-btn--dl:hover{background:#dcfce7;border-color:#86efac;color:#16a34a}.fm-statusbar{padding:.45rem 1rem;background:#f1f5f9;border-top:1px solid #bae6fd;font-size:.78rem;color:#0369a1;display:flex;gap:1rem;flex-shrink:0;flex-wrap:wrap}.fm-status-sel{color:#3b82f6;font-weight:500}.fm-empty{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;color:#7dd3fc;text-align:center;padding:2rem}.fm-empty h3{color:#0369a1;margin:0}.fm-empty p{margin:0;font-size:.875rem}body.dark-mode .fm-window{background:#0c4a6e}body.dark-mode .fm-hintbar{background:#052e3d;border-color:#075985;color:#7dd3fc}body.dark-mode .fm-body{background:#052e3d}body.dark-mode .fm-tile{background:#0c4a6e;border-color:#075985}body.dark-mode .fm-tile--sel{background:#1e3a5f;border-color:#3b82f6}body.dark-mode .fm-tile-name{color:#bae6fd}body.dark-mode .fm-tile-size{color:#0369a1}body.dark-mode .fm-table{background:#0c4a6e}body.dark-mode .fm-table thead tr{background:#052e3d}body.dark-mode .fm-table th{color:#7dd3fc;border-color:#075985}body.dark-mode .fm-row{border-color:#075985}body.dark-mode .fm-row:hover{background:#075985}body.dark-mode .fm-row--sel{background:#1e3a5f}body.dark-mode .fm-row td{color:#bae6fd}body.dark-mode .fm-icon-btn,body.dark-mode .fm-action-btn{background:#075985;border-color:#0369a1;color:#bae6fd}body.dark-mode .fm-statusbar{background:#052e3d;border-color:#075985}body.dark-mode .fm-empty h3{color:#7dd3fc}@media (max-width: 768px){.fm-overlay{padding:.75rem}.fm-window{height:92vh;border-radius:10px}.fm-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.6rem}.fm-tile{padding:.75rem .5rem .6rem}.fm-tile-icon{font-size:2rem}.fm-table th:nth-child(2),.fm-table td:nth-child(2),.fm-table th:nth-child(4),.fm-table td:nth-child(4){display:none}}@media (max-width: 480px){.fm-overlay{padding:0}.fm-window{height:100vh;height:100dvh;border-radius:0;max-width:100%}.fm-titlebar{height:56px;padding:0 .75rem}.fm-title{font-size:.875rem}.fm-view-btn,.fm-close-btn{width:2.5rem;height:2.5rem;font-size:1.2rem}.fm-grid{grid-template-columns:repeat(3,1fr);gap:.5rem}.fm-tile{padding:.6rem .4rem;border-radius:8px}.fm-tile-icon{font-size:1.75rem}.fm-tile-name{font-size:.65rem}.fm-tile-size{font-size:.6rem}.fm-icon-btn{min-width:36px;min-height:36px}.fm-table th:nth-child(2),.fm-table td:nth-child(2),.fm-table th:nth-child(3),.fm-table td:nth-child(3),.fm-table th:nth-child(4),.fm-table td:nth-child(4){display:none}.fm-row-name{max-width:160px}.fm-body{padding:.75rem}.fm-statusbar{padding:.4rem .75rem;font-size:.72rem}.fm-hintbar{display:none}}@media (max-width: 360px){.fm-grid{grid-template-columns:repeat(2,1fr)}.fm-tile-icon{font-size:1.5rem}}.fm-subfolder-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.6rem;margin-bottom:.25rem}.fm-subfolder-tile{background:#fff;border:2px solid #bae6fd;border-radius:10px;padding:1rem .75rem .8rem;display:flex;flex-direction:column;align-items:center;gap:.3rem;cursor:pointer;text-align:center;-webkit-user-select:none;user-select:none;transition:border-color .15s,box-shadow .15s,background .15s;touch-action:manipulation}.fm-subfolder-tile:hover{border-color:#0891b2;background:#e0f2fe;box-shadow:0 4px 16px #0891b21f}.fm-subfolder-icon{font-size:2.6rem;color:#0891b2;flex-shrink:0}.fm-subfolder-name{font-size:.78rem;font-weight:600;color:#075985;word-break:break-word;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.3;width:100%}.fm-subfolder-count{font-size:.68rem;color:#0891b2;font-weight:500}.fm-section{margin-bottom:1rem}.fm-section-label{font-size:.72rem;font-weight:700;color:#0369a1;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.5rem;padding-bottom:.25rem;border-bottom:1px solid #bae6fd}.fm-subfolder-header{display:flex;align-items:center;gap:.6rem;padding:.6rem 0 .75rem;flex-wrap:wrap}.fm-back-btn{display:flex;align-items:center;gap:.3rem;background:#f1f5f9;border:1px solid #bae6fd;border-radius:7px;padding:.35rem .75rem;font-size:.82rem;font-weight:600;color:#0369a1;cursor:pointer;transition:all .15s;flex-shrink:0;touch-action:manipulation}.fm-back-btn:hover{background:#bae6fd;color:#0c4a6e}.fm-subfolder-title{font-size:.95rem;font-weight:700;color:#0c4a6e;display:flex;align-items:center}body.dark-mode .fm-subfolder-tile{background:#0c4a6e;border-color:#075985}body.dark-mode .fm-subfolder-tile:hover{background:#075985;border-color:#0891b2}body.dark-mode .fm-subfolder-icon{color:#22d3ee}body.dark-mode .fm-subfolder-name{color:#bae6fd}body.dark-mode .fm-subfolder-count{color:#22d3ee}body.dark-mode .fm-section-label{color:#0369a1;border-color:#075985}body.dark-mode .fm-back-btn{background:#075985;border-color:#0369a1;color:#bae6fd}body.dark-mode .fm-back-btn:hover{background:#0369a1}body.dark-mode .fm-subfolder-title{color:#f1f5f9}@media (max-width: 480px){.fm-subfolder-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.45rem}.fm-subfolder-tile{padding:.7rem .5rem .6rem}.fm-subfolder-icon{font-size:2rem}.fm-subfolder-name{font-size:.68rem}}:root{--fm-bg: #f5f4f0;--fm-bg2: #eeecea;--fm-card: #ffffff;--fm-ink: #1a1916;--fm-ink2: #4a4843;--fm-ink3: #8c8880;--fm-ink4: #b8b5b0;--fm-accent: #2d5be3;--fm-green: #1a7a4a;--fm-red: #b91c1c;--fm-amber: #92400e;--fm-border: #dddbd6;--fm-border2: #c8c5be;--ease-expo: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1)}body.dark-mode{--fm-bg: #0f172a;--fm-bg2: #1e293b;--fm-card: #1e293b;--fm-ink: #f1f5f9;--fm-ink2: #cbd5e1;--fm-ink3: #94a3b8;--fm-ink4: #64748b;--fm-accent: #60a5fa;--fm-green: #4ade80;--fm-red: #f87171;--fm-amber: #fbbf24;--fm-border: #334155;--fm-border2: #475569}.app-container{display:flex;min-height:100vh;background:var(--fm-bg);font-family:Lato,system-ui,sans-serif;transition:background .25s}.main-content{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--fm-bg);transition:background .25s}.fm-page{flex:1;padding:3rem 3rem 5rem;max-width:960px}.fm-enter{opacity:0;transform:translateY(18px);transition:none}.fm-ready .fm-enter{opacity:1;transform:none;transition:opacity .7s var(--ease-expo),transform .7s var(--ease-expo)}.fm-reveal{opacity:0;transform:translateY(20px);transition:opacity .65s var(--ease-expo),transform .65s var(--ease-expo)}.fm-reveal.fm-visible{opacity:1;transform:none}.fm-hero{margin-bottom:2.5rem}.fm-hero-label{font-family:IBM Plex Mono,monospace;font-size:.72rem;color:var(--fm-ink3);letter-spacing:.05em;margin-bottom:1rem;transition:color .25s}.fm-title{font-family:Lora,Georgia,serif;font-size:clamp(2rem,4vw,2.75rem);font-weight:700;color:var(--fm-ink);letter-spacing:-1px;line-height:1.13;margin-bottom:1rem;transition:color .25s}.fm-title-accent{color:var(--fm-accent);font-style:italic;transition:color .25s}.fm-subtitle{font-size:1rem;color:var(--fm-ink2);line-height:1.75;font-weight:300;max-width:480px;transition:color .25s}.fm-alert{display:flex;align-items:center;gap:.5rem;font-size:.875rem;padding:.65rem 1rem;border-radius:8px;margin-bottom:1.25rem;font-weight:500}.fm-alert--err{background:#fff5f5;border:1px solid #fecaca;color:var(--fm-red)}.fm-alert--ok{background:#f0fdf4;border:1px solid #bbf7d0;color:var(--fm-green)}body.dark-mode .fm-alert--err{background:#451a1a33;border-color:#7f1d1d}body.dark-mode .fm-alert--ok{background:#052e1633;border-color:#166534}.fm-toolbar{display:flex;align-items:center;gap:1rem;margin-bottom:1.75rem}.fm-search-wrap{flex:1;position:relative;display:flex;align-items:center}.fm-search-icon{position:absolute;left:.875rem;font-size:1rem;color:var(--fm-ink3);pointer-events:none;transition:color .25s}.fm-search{width:100%;padding:.65rem 2.25rem .65rem 2.5rem;border:1.5px solid var(--fm-border);border-radius:9px;background:var(--fm-card);color:var(--fm-ink);font-size:.875rem;font-family:Lato,system-ui,sans-serif;outline:none;transition:border-color .2s,box-shadow .2s,background .25s,color .25s}.fm-search:focus{border-color:var(--fm-accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--fm-accent) 10%,transparent)}.fm-search::placeholder{color:var(--fm-ink4)}.fm-search-clear{position:absolute;right:.75rem;background:none;border:none;font-size:1rem;color:var(--fm-ink3);cursor:pointer;transition:color .18s}.fm-search-clear:hover{color:var(--fm-ink)}.fm-count{font-family:IBM Plex Mono,monospace;font-size:.72rem;color:var(--fm-ink3);white-space:nowrap;transition:color .25s}.fm-loading{display:flex;align-items:center;gap:.75rem;padding:4rem 0;font-family:IBM Plex Mono,monospace;font-size:.8rem;color:var(--fm-ink3)}.fm-spinner{font-size:1.2rem;animation:fmSpin .8s linear infinite;color:var(--fm-accent)}@keyframes fmSpin{to{transform:rotate(360deg)}}.fm-empty{display:flex;flex-direction:column;align-items:center;padding:5rem 2rem;text-align:center}.fm-empty-icon{width:64px;height:64px;background:var(--fm-bg2);border:1px solid var(--fm-border);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--fm-ink4);margin-bottom:1.25rem;transition:background .25s,border-color .25s,color .25s}.fm-empty-title{font-family:Lora,serif;font-size:1.375rem;font-weight:700;color:var(--fm-ink);margin-bottom:.5rem;transition:color .25s}.fm-empty-sub{font-size:.9rem;color:var(--fm-ink3);font-weight:300;transition:color .25s}.fm-list{display:flex;flex-direction:column;gap:1rem}.fm-card{display:flex;align-items:flex-start;gap:1.25rem;background:var(--fm-card);border:1px solid var(--fm-border);border-radius:12px;padding:1.5rem;transition:border-color .2s,box-shadow .3s var(--ease-expo),transform .3s var(--ease-expo),background .25s}.fm-card:hover{border-color:var(--fm-border2);box-shadow:0 8px 32px #00000012;transform:translateY(-2px)}.fm-card-icon{width:46px;height:46px;flex-shrink:0;background:var(--fm-ink);color:var(--fm-card);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;transition:transform .4s var(--ease-spring),background .25s,color .25s}.fm-card:hover .fm-card-icon{transform:rotate(-8deg) scale(1.08)}.fm-card-body{flex:1;min-width:0}.fm-card-top{display:flex;align-items:center;gap:.625rem;margin-bottom:.4rem}.fm-card-title{font-family:Lora,serif;font-size:1.05rem;font-weight:700;color:var(--fm-ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .25s}.fm-msg-badge{display:inline-flex;align-items:center;gap:.2rem;font-family:IBM Plex Mono,monospace;font-size:.62rem;font-weight:600;color:var(--fm-amber);background:#fef3c7;border-radius:999px;padding:.15rem .5rem;flex-shrink:0}body.dark-mode .fm-msg-badge{background:#45260033;color:var(--fm-amber)}.fm-card-meta{display:flex;align-items:center;flex-wrap:wrap;gap:.35rem;font-size:.8rem;color:var(--fm-ink3);margin-bottom:.75rem;font-weight:400;transition:color .25s}.fm-dot{color:var(--fm-border2);transition:color .25s}.fm-sf-list{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.75rem}.fm-sf-chip{display:inline-flex;align-items:center;gap:.3rem;font-family:IBM Plex Mono,monospace;font-size:.68rem;font-weight:500;color:var(--fm-accent);background:color-mix(in srgb,var(--fm-accent) 8%,transparent);border:1px solid color-mix(in srgb,var(--fm-accent) 18%,transparent);border-radius:999px;padding:.18rem .55rem;transition:all .25s}.fm-sf-chip em{font-style:normal;color:var(--fm-ink3)}.fm-msg-preview{display:flex;align-items:flex-start;gap:.4rem;background:#fffbeb;border:1px solid #fde68a;border-radius:7px;padding:.45rem .7rem;margin-bottom:.75rem;font-size:.78rem;color:var(--fm-amber);line-height:1.45}body.dark-mode .fm-msg-preview{background:#45260033;border-color:#78350f44}.fm-code-row{display:flex;align-items:center;gap:.625rem}.fm-code{font-family:IBM Plex Mono,monospace;font-size:1rem;font-weight:700;letter-spacing:.18em;color:var(--fm-ink);background:none;transition:color .25s}.fm-copy-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .7rem;border-radius:6px;border:1px solid var(--fm-border2);background:var(--fm-bg2);color:var(--fm-ink2);font-family:IBM Plex Mono,monospace;font-size:.68rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .18s}.fm-copy-btn:hover{background:var(--fm-ink);color:var(--fm-card);border-color:var(--fm-ink)}.fm-copy-btn--done{background:var(--fm-green);border-color:var(--fm-green);color:#fff}body.dark-mode .fm-copy-btn--done{background:#166534;border-color:#166534}.fm-card-actions{display:flex;flex-direction:column;gap:.5rem;flex-shrink:0;margin-left:.5rem}.fm-btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.55rem 1rem;border-radius:7px;border:none;cursor:pointer;font-family:Lato,system-ui,sans-serif;font-size:.8125rem;font-weight:600;white-space:nowrap;transition:transform .2s var(--ease-spring),box-shadow .2s,background .2s,color .25s}.fm-btn:hover{transform:translateY(-1px)}.fm-btn:active{transform:none}.fm-btn--primary{background:var(--fm-ink);color:var(--fm-card)}.fm-btn--primary:hover{box-shadow:0 4px 14px #1a191638}body.dark-mode .fm-btn--primary:hover{box-shadow:0 4px 14px #0006}.fm-btn--danger{background:#fee2e2;color:var(--fm-red);border:1px solid #fecaca}.fm-btn--danger:hover{background:var(--fm-red);color:#fff;border-color:var(--fm-red)}body.dark-mode .fm-btn--danger{background:#451a1a33;border-color:#7f1d1d}body.dark-mode .fm-btn--danger:hover{background:#7f1d1d;color:#fff}@media (max-width: 768px){.fm-page{padding:2rem 1.5rem 3rem}.fm-card{flex-direction:column}.fm-card-actions{flex-direction:row;width:100%;margin-left:0}.fm-btn{flex:1}}@media (max-width: 480px){.fm-page{padding:1.75rem 1.25rem}.fm-toolbar{flex-direction:column;align-items:stretch}.fm-count{text-align:right}}@media (prefers-reduced-motion: reduce){.fm-enter,.fm-reveal{opacity:1!important;transform:none!important;transition:none!important}.fm-card,.fm-card-icon,.fm-btn{transition:none!important}.fm-reveal.fm-visible{opacity:1;transform:none}}:root{--ec-bg: #f5f4f0;--ec-bg2: #eeecea;--ec-card: #ffffff;--ec-ink: #1a1916;--ec-ink2: #4a4843;--ec-ink3: #8c8880;--ec-ink4: #b8b5b0;--ec-accent: #2d5be3;--ec-border: #dddbd6;--ec-border2: #c8c5be;--ease-expo: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1)}body.dark-mode{--ec-bg: #0f172a;--ec-bg2: #1e293b;--ec-card: #1e293b;--ec-ink: #f1f5f9;--ec-ink2: #cbd5e1;--ec-ink3: #94a3b8;--ec-ink4: #64748b;--ec-accent: #60a5fa;--ec-border: #334155;--ec-border2: #475569}.app-container{display:flex;min-height:100vh;background:var(--ec-bg);font-family:Lato,system-ui,sans-serif;transition:background .25s}.main-content{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--ec-bg);transition:background .25s}.ec-page{flex:1;padding:3rem 3rem 4rem;max-width:1100px}.ec-enter{opacity:0;transform:translateY(20px);transition:none}.ec-ready .ec-enter{opacity:1;transform:translateY(0);transition:opacity .7s var(--ease-expo),transform .7s var(--ease-expo)}.ec-hero{margin-bottom:2.5rem}.ec-hero-label{font-family:IBM Plex Mono,monospace;font-size:.72rem;color:var(--ec-ink3);letter-spacing:.05em;margin-bottom:1rem;transition:color .25s}.ec-title{font-family:Lora,Georgia,serif;font-size:clamp(2rem,4vw,3rem);font-weight:700;color:var(--ec-ink);letter-spacing:-1px;line-height:1.13;margin-bottom:1rem;transition:color .25s}.ec-title-accent{color:var(--ec-accent);font-style:italic;transition:color .25s}.ec-subtitle{font-size:1rem;color:var(--ec-ink2);line-height:1.75;font-weight:300;max-width:420px;transition:color .25s}.ec-card{background:var(--ec-card);border:1px solid var(--ec-border);border-radius:12px;padding:2rem;box-shadow:0 4px 24px #0000000d;margin-bottom:1.5rem;transition:box-shadow .3s var(--ease-expo),background .25s,border-color .25s}.ec-card:hover{box-shadow:0 8px 32px #00000014}.ec-card-header{display:flex;align-items:center;gap:.875rem;padding-bottom:1.5rem;margin-bottom:1.5rem;border-bottom:1px solid var(--ec-border);transition:border-color .25s}.ec-card-icon{width:40px;height:40px;background:var(--ec-ink);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:var(--ec-card);flex-shrink:0;transition:transform .4s var(--ease-spring),background .25s,color .25s}.ec-card:hover .ec-card-icon{transform:rotate(-8deg) scale(1.08)}.ec-card-title{font-family:Lora,Georgia,serif;font-size:1.05rem;font-weight:700;color:var(--ec-ink);transition:color .25s}.ec-card-sub{font-family:IBM Plex Mono,monospace;font-size:.7rem;color:var(--ec-ink3);margin-top:2px;transition:color .25s}.ec-error{display:flex;align-items:center;gap:.5rem;background:#fff5f5;border:1px solid #fecaca;color:#b91c1c;font-size:.8375rem;padding:.6rem .875rem;border-radius:8px;margin-bottom:1.25rem;animation:errShake .4s var(--ease-spring)}body.dark-mode .ec-error{background:#451a1a;border-color:#7f1d1d;color:#fca5a5}@keyframes errShake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.ec-form{display:flex;flex-direction:column;gap:1.25rem}.ec-input-wrap{position:relative;cursor:text}.ec-input-chars{display:flex;gap:.5rem;justify-content:center;pointer-events:none}.ec-char-box{width:52px;height:60px;border:1.5px solid var(--ec-border);border-radius:8px;background:var(--ec-bg);display:flex;align-items:center;justify-content:center;font-family:IBM Plex Mono,monospace;font-size:1.4rem;font-weight:600;color:var(--ec-ink);letter-spacing:0;transition:border-color .2s,background .2s,transform .2s var(--ease-spring),box-shadow .2s,color .25s}.ec-input-wrap:focus-within .ec-char-box{border-color:var(--ec-border2)}.ec-char-box--filled{border-color:var(--ec-accent)!important;background:var(--ec-bg2);transform:scale(1.04);box-shadow:0 4px 12px #2d5be326}body.dark-mode .ec-char-box--filled{background:#1e3a8a33;box-shadow:0 4px 12px #60a5fa1f}.ec-char-box--active{border-color:var(--ec-accent)!important;border-width:2px;background:var(--ec-accent-bg, rgba(45,91,227,.04));box-shadow:0 0 0 3px #2d5be31f;animation:ecBoxPulse 1.5s ease-in-out infinite}body.dark-mode .ec-char-box--active{box-shadow:0 0 0 3px #60a5fa26}@keyframes ecBoxPulse{0%,to{box-shadow:0 0 0 3px #2d5be31f}50%{box-shadow:0 0 0 5px #2d5be338}}.ec-caret{display:inline-block;width:2px;height:1.5rem;background:var(--ec-accent);border-radius:2px;animation:ecCaretBlink 1s step-start infinite}@keyframes ecCaretBlink{0%,to{opacity:1}50%{opacity:0}}.ec-real-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:text;font-size:16px;border:none;background:transparent;z-index:2;pointer-events:all}.ec-submit{width:100%;display:flex;align-items:center;justify-content:center;gap:.625rem;padding:.9rem 1.5rem;background:var(--ec-ink);border:none;border-radius:9px;color:var(--ec-card);font-family:Lato,system-ui,sans-serif;font-size:.9375rem;font-weight:700;cursor:pointer;position:relative;overflow:hidden;transition:background .2s,transform .2s var(--ease-spring),box-shadow .2s,color .25s}.ec-submit:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.08) 50%,transparent 70%);transform:translate(-100%);transition:transform .5s var(--ease-expo)}.ec-submit:hover:not(.ec-submit--off):after{transform:translate(100%)}.ec-submit:hover:not(.ec-submit--off){transform:translateY(-2px);box-shadow:0 6px 20px #1a191638}body.dark-mode .ec-submit:hover:not(.ec-submit--off){box-shadow:0 6px 20px #0006}.ec-submit:active:not(.ec-submit--off){transform:translateY(0)}.ec-submit--off{opacity:.35;cursor:not-allowed}.ec-submit--loading{opacity:.7;cursor:wait}.ec-spin{animation:spin .75s linear infinite;font-size:1rem}.ec-quick{display:flex;flex-direction:column;gap:.6rem}.ec-quick-btn{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:var(--ec-card);border:1px solid var(--ec-border);border-radius:10px;cursor:pointer;text-align:left;width:100%;transition:border-color .2s,background .2s,transform .25s var(--ease-spring),box-shadow .2s}.ec-quick-btn:hover{border-color:var(--ec-border2);background:var(--ec-bg2);transform:translate(5px);box-shadow:0 4px 14px #0000000f}.ec-quick-icon{width:34px;height:34px;background:var(--ec-bg);border:1px solid var(--ec-border);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--ec-ink2);flex-shrink:0;transition:transform .3s var(--ease-spring),color .2s,background .2s}.ec-quick-btn:hover .ec-quick-icon{color:var(--ec-accent);transform:scale(1.12)}.ec-quick-text{flex:1;display:flex;flex-direction:column;gap:2px}.ec-quick-label{font-size:.9rem;font-weight:600;color:var(--ec-ink);font-family:Lato,system-ui,sans-serif;transition:color .25s}.ec-quick-sub{font-family:IBM Plex Mono,monospace;font-size:.68rem;color:var(--ec-ink3);transition:color .25s}.ec-quick-arrow{font-size:1rem;color:var(--ec-ink4);transition:transform .25s var(--ease-spring),color .2s}.ec-quick-btn:hover .ec-quick-arrow{transform:translate(4px);color:var(--ec-accent)}@media (max-width: 768px){.ec-page{padding:2rem 1.5rem 3rem}.ec-char-box{width:38px;height:50px;font-size:1.1rem}.ec-input-chars{gap:.35rem}}@media (max-width: 480px){.ec-page{padding:1.75rem 1.25rem}.ec-char-box{width:32px;height:44px;font-size:1rem}.ec-input-chars{gap:.25rem}}@media (max-width: 360px){.ec-page{padding:1.5rem .875rem}.ec-char-box{width:28px;height:40px;font-size:.875rem;border-radius:6px}.ec-input-chars{gap:.18rem}.ec-card{padding:1.25rem 1rem}.ec-quick-btn{padding:.75rem .875rem}}@media (prefers-reduced-motion: reduce){.ec-enter{opacity:1!important;transform:none!important;transition:none!important}.ec-char-box,.ec-submit,.ec-quick-btn{transition:none!important}}.ann-banner-wrap{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem}.ann-banner{display:flex;align-items:flex-start;gap:.75rem;background:#fffbeb;border:1px solid #fcd34d;border-left:4px solid #f59e0b;border-radius:10px;padding:.875rem 1rem;animation:annSlideIn .3s cubic-bezier(.16,1,.3,1) both}body.dark-mode .ann-banner{background:#2d240833;border-color:#92400e55;border-left-color:#d97706}@keyframes annSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}.ann-banner-icon{font-size:1.2rem;color:#d97706;flex-shrink:0;margin-top:1px}body.dark-mode .ann-banner-icon{color:#fbbf24}.ann-banner-body{flex:1;display:flex;flex-direction:column;gap:.2rem;min-width:0}.ann-banner-title{font-weight:700;font-size:.875rem;color:#92400e;line-height:1.3}body.dark-mode .ann-banner-title{color:#fcd34d}.ann-banner-msg{font-size:.82rem;color:#78350f;line-height:1.55;word-break:break-word}body.dark-mode .ann-banner-msg{color:#fef3c7}.ann-banner-close{background:none;border:none;cursor:pointer;font-size:1.1rem;color:#b45309;flex-shrink:0;display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:5px;transition:background .18s,color .18s;margin-top:-2px}.ann-banner-close:hover{background:#fef3c7;color:#78350f}body.dark-mode .ann-banner-close{color:#fbbf24}body.dark-mode .ann-banner-close:hover{background:#45260044}@media (max-width: 480px){.ann-banner{padding:.75rem;gap:.5rem}.ann-banner-title{font-size:.82rem}.ann-banner-msg{font-size:.78rem}}.ec-body-grid{display:grid;grid-template-columns:1fr 280px;gap:2rem;align-items:start}.ec-body-left{display:flex;flex-direction:column;gap:0;min-width:0}.ec-stats-panel{background:var(--ec-card);border:1px solid var(--ec-border);border-radius:14px;padding:1.5rem;position:sticky;top:1.5rem;box-shadow:0 2px 12px #0000000d;transition:background .25s,border-color .25s}.ec-stats-panel-heading{display:flex;align-items:center;gap:.5rem;font-family:IBM Plex Mono,monospace;font-size:.72rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ec-ink2);margin-bottom:.35rem;transition:color .25s}.ec-stats-panel-dot{width:7px;height:7px;border-radius:50%;background:var(--ec-accent);flex-shrink:0;animation:ecDotPulse 2.5s ease-in-out infinite}@keyframes ecDotPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.ec-stats-panel-sub{font-family:Lato,system-ui,sans-serif;font-size:.75rem;color:var(--ec-ink3);margin-bottom:1.25rem;line-height:1.5;transition:color .25s}.ec-stats-panel-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1.25rem}.ec-stats-panel-item{background:var(--ec-bg);border:1px solid var(--ec-border);border-radius:10px;padding:.875rem .75rem;display:flex;flex-direction:column;gap:.25rem;transition:background .25s,border-color .25s}.ec-stats-panel-val{font-family:IBM Plex Mono,monospace;font-size:1.2rem;font-weight:700;color:var(--ec-ink);line-height:1;transition:color .25s}.ec-stats-panel-lbl{font-family:IBM Plex Mono,monospace;font-size:.58rem;font-weight:600;letter-spacing:.04em;color:var(--ec-ink3);line-height:1.3;transition:color .25s}.ec-stats-panel-footer{font-family:IBM Plex Mono,monospace;font-size:.62rem;color:var(--ec-ink4, var(--ec-ink3));text-align:center;letter-spacing:.08em;opacity:.7;padding-top:.875rem;border-top:1px solid var(--ec-border);transition:color .25s,border-color .25s}@media (max-width: 800px){.ec-body-grid{grid-template-columns:1fr;gap:1.25rem}.ec-stats-panel{position:static;padding:1.25rem}.ec-stats-panel-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.ec-stats-panel-val{font-size:1rem}.ec-stats-panel-item{padding:.75rem .625rem}}@media (max-width: 360px){.ec-stats-panel-grid{gap:.5rem}.ec-stats-panel-val{font-size:.9rem}.ec-stats-panel-lbl{font-size:.52rem}}.msg-banner{border:1.5px solid #fbbf24;border-radius:10px;background:#fffbeb;margin-bottom:1.25rem;overflow:hidden;box-shadow:0 2px 8px #fbbf241f}.msg-banner-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:linear-gradient(90deg,#fef3c7,#fffbeb);cursor:pointer;-webkit-user-select:none;user-select:none;gap:.5rem}.msg-banner-title{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:.9rem;color:#92400e}.msg-banner-icon{font-size:1.3rem;color:#d97706;flex-shrink:0}.msg-banner-toggle{background:none;border:none;color:#92400e;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;padding:0;flex-shrink:0}.msg-banner-body{padding:.75rem 1rem 1rem;border-top:1px solid #fde68a}.msg-banner-body p{margin:0;font-size:.9rem;color:#78350f;line-height:1.6;white-space:pre-wrap;word-break:break-word}body.dark-mode .msg-banner{background:#1c1700;border-color:#854d0e}body.dark-mode .msg-banner-header{background:linear-gradient(90deg,#1c1a08,#1c1700)}body.dark-mode .msg-banner-title,body.dark-mode .msg-banner-icon,body.dark-mode .msg-banner-toggle{color:#fbbf24}body.dark-mode .msg-banner-body{border-top-color:#713f12}body.dark-mode .msg-banner-body p{color:#fde68a}@media (max-width: 480px){.msg-banner-header{padding:.65rem .75rem}.msg-banner-body{padding:.65rem .75rem .85rem}.msg-banner-title,.msg-banner-body p{font-size:.82rem}}.material-access-info{display:flex;flex-direction:column;gap:.625rem}.info-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--border-solid);font-size:.875rem}.info-row:last-child{border-bottom:none}.info-label{font-weight:700;color:var(--text-sub)}.info-value{font-weight:600;color:var(--text)}.action-cards-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:1.5rem}.action-card{text-align:center}.action-card-icon{width:64px;height:64px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto 1rem}.action-card--save .action-card-icon{background:#dbeafe;color:#2563eb}.action-card--download .action-card-icon{background:#d1fae5;color:#059669}.action-card-title{font-size:1.125rem;font-weight:800;margin-bottom:.625rem;color:var(--text)}.action-card-description{color:var(--text-sub);margin-bottom:1rem;font-size:.875rem}.action-card-benefits{list-style:none;padding:0;margin:0 0 1.5rem;font-size:.8375rem;display:flex;flex-direction:column;gap:.4rem}.action-card-benefits li{color:var(--success);font-weight:500}@media (max-width: 768px){.action-cards-grid{grid-template-columns:1fr}}.saved-materials-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:1.5rem}.saved-material-card{display:flex;flex-direction:column;overflow:hidden}.saved-material-header{background:linear-gradient(135deg,#2563eb,#1d4ed8);padding:1.25rem;text-align:center;color:#fff}.saved-material-header .material-icon{font-size:2rem;margin-bottom:.4rem;display:flex;justify-content:center}.saved-material-header .material-title{margin:0;color:#fff;font-size:1.0625rem;font-weight:700}.saved-material-body{padding:1.125rem;flex:1}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:.45rem 0;border-bottom:1px solid var(--border-solid);font-size:.8375rem}.detail-row:last-child{border-bottom:none}.detail-label{font-weight:600;color:var(--text-sub)}.detail-value{font-weight:600;color:var(--text)}.saved-material-footer{padding:.875rem 1.125rem;border-top:1px solid var(--border-solid);display:flex;gap:.5rem}@media (max-width: 768px){.saved-materials-grid{grid-template-columns:1fr}}:root{--sh-bg: #f5f4f0;--sh-bg2: #eeecea;--sh-card: #ffffff;--sh-ink: #1a1916;--sh-ink2: #4a4843;--sh-ink3: #8c8880;--sh-ink4: #b8b5b0;--sh-accent: #2d5be3;--sh-border: #dddbd6;--sh-border2: #c8c5be;--ease-expo: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1)}body.dark-mode{--sh-bg: #0f172a;--sh-bg2: #1e293b;--sh-card: #1e293b;--sh-ink: #f1f5f9;--sh-ink2: #cbd5e1;--sh-ink3: #94a3b8;--sh-ink4: #64748b;--sh-accent: #60a5fa;--sh-border: #334155;--sh-border2: #475569}.app-container{display:flex;min-height:100vh;background:var(--sh-bg);font-family:Lato,system-ui,sans-serif;transition:background .25s}.main-content{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--sh-bg);transition:background .25s}.sh-page{flex:1;padding:3rem 3rem 4rem;max-width:900px}.sh-enter{opacity:0;transform:translateY(18px);transition:none}.sh-ready .sh-enter{opacity:1;transform:translateY(0);transition:opacity .7s var(--ease-expo),transform .7s var(--ease-expo)}.sh-reveal{opacity:0;transform:translateY(20px);transition:opacity .6s var(--ease-expo),transform .6s var(--ease-expo)}.sh-reveal.is-visible{opacity:1;transform:none}.sh-hero{margin-bottom:2.5rem}.sh-hero-label{font-family:IBM Plex Mono,monospace;font-size:.72rem;color:var(--sh-ink3);letter-spacing:.05em;margin-bottom:1rem;transition:color .25s}.sh-title{font-family:Lora,Georgia,serif;font-size:clamp(2rem,4vw,2.75rem);font-weight:700;color:var(--sh-ink);letter-spacing:-1px;line-height:1.13;margin-bottom:1rem;transition:color .25s}.sh-title-accent{color:var(--sh-accent);font-style:italic;transition:color .25s}.sh-subtitle{font-size:1rem;color:var(--sh-ink2);line-height:1.75;font-weight:300;max-width:480px;transition:color .25s}.sh-alert{display:flex;align-items:center;gap:.5rem;font-size:.875rem;padding:.65rem 1rem;border-radius:8px;margin-bottom:1.25rem;font-weight:500}.sh-alert--err{background:#fff5f5;border:1px solid #fecaca;color:#b91c1c}.sh-alert--ok{background:#f0fdf4;border:1px solid #bbf7d0;color:#15803d}body.dark-mode .sh-alert--err{background:#451a1a;border-color:#7f1d1d;color:#fca5a5}body.dark-mode .sh-alert--ok{background:#052e16;border-color:#166534;color:#86efac}.sh-loading{display:flex;align-items:center;gap:.75rem;padding:3rem 0;font-family:IBM Plex Mono,monospace;font-size:.8rem;color:var(--sh-ink3);transition:color .25s}.sh-spinner{font-size:1.2rem;animation:spin .8s linear infinite;color:var(--sh-accent)}.sh-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5rem 2rem;text-align:center}.sh-empty-icon{width:64px;height:64px;background:var(--sh-bg2);border:1px solid var(--sh-border);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--sh-ink4);margin-bottom:1.25rem;transition:background .25s,border-color .25s,color .25s}.sh-empty-title{font-family:Lora,Georgia,serif;font-size:1.375rem;font-weight:700;color:var(--sh-ink);margin-bottom:.5rem;transition:color .25s}.sh-empty-sub{font-size:.9rem;color:var(--sh-ink3);font-weight:300;transition:color .25s}.sh-list{display:flex;flex-direction:column;gap:.75rem;margin-top:.5rem}.sh-card{display:flex;align-items:center;gap:1.25rem;background:var(--sh-card);border:1px solid var(--sh-border);border-radius:10px;padding:1.25rem 1.5rem;transition:border-color .2s,box-shadow .3s var(--ease-expo),transform .3s var(--ease-expo),background .25s}.sh-card:hover{border-color:var(--sh-border2);box-shadow:0 6px 24px #00000012;transform:translateY(-2px)}.sh-card-icon{width:44px;height:44px;background:var(--sh-ink);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:var(--sh-card);flex-shrink:0;transition:transform .4s var(--ease-spring),background .25s,color .25s}.sh-card:hover .sh-card-icon{transform:rotate(-8deg) scale(1.08)}.sh-card-info{flex:1;min-width:0}.sh-card-top{display:flex;align-items:center;gap:.625rem;margin-bottom:.35rem}.sh-card-title{font-family:Lora,Georgia,serif;font-size:1rem;font-weight:700;color:var(--sh-ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .25s}.sh-msg-badge{display:inline-flex;align-items:center;gap:.2rem;font-family:IBM Plex Mono,monospace;font-size:.62rem;font-weight:600;color:#d97706;background:#fef3c7;border-radius:999px;padding:.15rem .45rem;flex-shrink:0}body.dark-mode .sh-msg-badge{background:#451a0033;color:#fbbf24}.sh-card-meta{display:flex;align-items:center;flex-wrap:wrap;gap:.35rem;font-size:.8rem;color:var(--sh-ink3);margin-bottom:.6rem;font-weight:400;transition:color .25s}.sh-meta-dot{color:var(--sh-border2)}.sh-card-badges{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.sh-code-badge{font-family:IBM Plex Mono,monospace;font-size:.72rem;font-weight:600;color:var(--sh-accent);background:var(--sh-bg2);border:1px solid var(--sh-border);border-radius:5px;padding:.15rem .55rem;letter-spacing:.08em;transition:color .25s,background .25s,border-color .25s}.sh-date-badge{font-family:IBM Plex Mono,monospace;font-size:.68rem;color:var(--sh-ink4);transition:color .25s}.sh-card-actions{display:flex;flex-direction:column;gap:.45rem;flex-shrink:0}.sh-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .875rem;border-radius:7px;font-family:Lato,system-ui,sans-serif;font-size:.8125rem;font-weight:600;border:none;cursor:pointer;transition:transform .2s var(--ease-spring),box-shadow .2s,background .2s,color .25s;white-space:nowrap}.sh-btn--save{background:var(--sh-ink);color:var(--sh-card)}.sh-btn--save:hover{transform:translateY(-2px);box-shadow:0 4px 12px #1a191633}body.dark-mode .sh-btn--save:hover{box-shadow:0 4px 12px #0006}.sh-btn--saved{background:var(--sh-bg2);color:var(--sh-ink3);cursor:not-allowed;border:1px solid var(--sh-border)}.sh-btn--open{background:var(--sh-bg2);color:var(--sh-ink2);border:1px solid var(--sh-border)}.sh-btn--open:hover{background:var(--sh-bg);border-color:var(--sh-border2);color:var(--sh-ink);transform:translateY(-2px);box-shadow:0 4px 10px #0000000f}@media (max-width: 768px){.sh-page{padding:2rem 1.5rem 3rem}.sh-card{flex-direction:column;align-items:flex-start;gap:1rem}.sh-card-actions{flex-direction:row;width:100%}.sh-btn{flex:1;justify-content:center}}@media (max-width: 480px){.sh-page{padding:2rem 1.25rem}.sh-card{padding:1rem}.sh-toolbar{padding:.6rem .75rem;flex-wrap:wrap}.sh-sort-btns{flex-wrap:wrap}.sh-sort-btn{font-size:.62rem;padding:.25rem .5rem}.sh-count{width:100%;text-align:right}}@media (max-width: 360px){.sh-page{padding:1.5rem .875rem}.sh-card{padding:.875rem;gap:.75rem}.sh-card-icon{width:36px;height:36px;font-size:1rem}}@media (prefers-reduced-motion: reduce){.sh-enter,.sh-reveal{opacity:1!important;transform:none!important;transition:none!important}.sh-card,.sh-card-icon,.sh-btn{transition:none!important}}.sh-toolbar{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;padding:.75rem 1rem;background:var(--sh-card, #fff);border:1px solid var(--sh-border, #dddbd6);border-radius:12px;margin-bottom:1.25rem;transition:background .25s,border-color .25s}.sh-toolbar-label{font-family:IBM Plex Mono,monospace;font-size:.68rem;font-weight:600;color:var(--sh-ink3, #8c8880);white-space:nowrap}.sh-sort-btns{display:flex;gap:.4rem;flex-wrap:wrap;flex:1}.sh-sort-btn{padding:.3rem .75rem;border-radius:8px;border:1px solid var(--sh-border, #dddbd6);background:var(--sh-bg2, #eeecea);font-family:IBM Plex Mono,monospace;font-size:.68rem;font-weight:600;color:var(--sh-ink2, #4a4843);cursor:pointer;transition:background .18s,border-color .18s,color .18s;white-space:nowrap}.sh-sort-btn:hover{background:var(--sh-border, #dddbd6)}.sh-sort-btn--active{background:var(--sh-ink, #1a1916);color:#fff;border-color:var(--sh-ink, #1a1916)}.sh-count{font-family:IBM Plex Mono,monospace;font-size:.62rem;color:var(--sh-ink3, #8c8880);margin-left:auto;white-space:nowrap}:root{--ss-bg: #f5f4f0;--ss-bg2: #eeecea;--ss-card: #ffffff;--ss-ink: #1a1916;--ss-ink2: #4a4843;--ss-ink3: #8c8880;--ss-ink4: #b8b5b0;--ss-accent: #2d5be3;--ss-amber: #f59e0b;--ss-green: #1a7a4a;--ss-red: #b91c1c;--ss-border: #dddbd6;--ss-border2: #c8c5be;--ease-expo: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1)}body.dark-mode{--ss-bg: #052e3d;--ss-bg2: #0c4a6e;--ss-card: #0c4a6e;--ss-ink: #e0f2fe;--ss-ink2: #bae6fd;--ss-ink3: #7dd3fc;--ss-ink4: #38bdf8;--ss-accent: #22d3ee;--ss-amber: #fbbf24;--ss-green: #4ade80;--ss-red: #f87171;--ss-border: #075985;--ss-border2: #0369a1}.app-container{display:flex;min-height:100vh;background:var(--ss-bg);font-family:Lato,system-ui,sans-serif;transition:background .25s}.main-content{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--ss-bg);transition:background .25s}.ss-page{flex:1;padding:3rem 3rem 5rem;max-width:860px}.ss-enter{opacity:0;transform:translateY(18px);transition:none}.ss-ready .ss-enter{opacity:1;transform:none;transition:opacity .7s var(--ease-expo),transform .7s var(--ease-expo)}.ss-reveal{opacity:0;transform:translateY(20px);transition:opacity .65s var(--ease-expo),transform .65s var(--ease-expo)}.ss-reveal.ss-visible{opacity:1;transform:none}.ss-hero{margin-bottom:2.5rem}.ss-hero-label{font-family:IBM Plex Mono,monospace;font-size:.72rem;color:var(--ss-ink3);letter-spacing:.05em;margin-bottom:1rem;transition:color .25s}.ss-title{font-family:Lora,Georgia,serif;font-size:clamp(2rem,4vw,2.75rem);font-weight:700;color:var(--ss-ink);letter-spacing:-1px;line-height:1.13;margin-bottom:1rem;transition:color .25s}.ss-title-accent{color:var(--ss-amber);font-style:italic;transition:color .25s}.ss-subtitle{font-size:1rem;color:var(--ss-ink2);line-height:1.75;font-weight:300;max-width:480px;transition:color .25s}.ss-alert{display:flex;align-items:center;gap:.5rem;font-size:.875rem;padding:.65rem 1rem;border-radius:8px;margin-bottom:1.25rem;font-weight:500}.ss-alert--err{background:#fff5f5;border:1px solid #fecaca;color:var(--ss-red)}.ss-alert--ok{background:#f0fdf4;border:1px solid #bbf7d0;color:var(--ss-green)}body.dark-mode .ss-alert--err{background:#451a1a33;border-color:#7f1d1d}body.dark-mode .ss-alert--ok{background:#052e1633;border-color:#166534}.ss-toolbar{display:flex;align-items:center;gap:1rem;margin-bottom:1.75rem}.ss-search-wrap{flex:1;position:relative;display:flex;align-items:center}.ss-search-icon{position:absolute;left:.875rem;font-size:1rem;color:var(--ss-ink3);pointer-events:none}.ss-search{width:100%;padding:.65rem 2.25rem .65rem 2.5rem;border:1.5px solid var(--ss-border);border-radius:9px;background:var(--ss-card);color:var(--ss-ink);font-size:.875rem;font-family:Lato,system-ui,sans-serif;outline:none;transition:border-color .2s,box-shadow .2s,background .25s,color .25s}.ss-search:focus{border-color:var(--ss-accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--ss-accent) 10%,transparent)}.ss-search::placeholder{color:var(--ss-ink4)}.ss-search-clear{position:absolute;right:.75rem;background:none;border:none;font-size:1rem;color:var(--ss-ink3);cursor:pointer}.ss-search-clear:hover{color:var(--ss-ink)}.ss-count{font-family:IBM Plex Mono,monospace;font-size:.72rem;color:var(--ss-ink3);white-space:nowrap;transition:color .25s}.ss-loading{display:flex;align-items:center;gap:.75rem;padding:4rem 0;font-family:IBM Plex Mono,monospace;font-size:.8rem;color:var(--ss-ink3)}.ss-spinner{font-size:1.2rem;animation:ssSpin .8s linear infinite;color:var(--ss-accent)}@keyframes ssSpin{to{transform:rotate(360deg)}}.ss-empty{display:flex;flex-direction:column;align-items:center;padding:5rem 2rem;text-align:center}.ss-empty-icon{width:64px;height:64px;background:var(--ss-bg2);border:1px solid var(--ss-border);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--ss-amber);margin-bottom:1.25rem;transition:background .25s,border-color .25s}.ss-empty-title{font-family:Lora,serif;font-size:1.375rem;font-weight:700;color:var(--ss-ink);margin-bottom:.5rem;transition:color .25s}.ss-empty-sub{font-size:.9rem;color:var(--ss-ink3);font-weight:300;margin-bottom:1.5rem;line-height:1.7;transition:color .25s}.ss-go-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1.25rem;background:var(--ss-ink);color:var(--ss-card);border:none;border-radius:9px;font-family:Lato,system-ui,sans-serif;font-size:.875rem;font-weight:700;cursor:pointer;transition:transform .2s var(--ease-spring),box-shadow .2s,background .25s}.ss-go-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #1a191633}.ss-groups{display:flex;flex-direction:column;gap:1.5rem}.ss-group{background:var(--ss-card);border:1px solid var(--ss-border);border-radius:12px;overflow:hidden;transition:background .25s,border-color .25s}.ss-group-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--ss-border);background:var(--ss-bg2);transition:background .25s,border-color .25s}.ss-group-title{font-family:Lora,serif;font-size:.95rem;font-weight:700;color:var(--ss-ink);transition:color .25s}.ss-group-open{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .75rem;border-radius:6px;border:1px solid var(--ss-border2);background:var(--ss-card);color:var(--ss-ink2);font-family:IBM Plex Mono,monospace;font-size:.68rem;font-weight:600;cursor:pointer;transition:all .18s}.ss-group-open:hover{background:var(--ss-ink);color:var(--ss-card);border-color:var(--ss-ink)}.ss-group-files{padding:.5rem 0}.ss-file-row{display:flex;align-items:center;gap:1rem;padding:.75rem 1.25rem;transition:background .15s}.ss-file-row:hover{background:var(--ss-bg2)}.ss-file-icon-wrap{width:36px;height:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.ss-file-icon{font-size:1.5rem;color:var(--ss-ink3);transition:color .25s}.ss-icon--pdf{color:#dc2626}.ss-icon--img{color:#7c3aed}.ss-icon--vid{color:#0891b2}.ss-icon--doc{color:#1d4ed8}.ss-file-info{flex:1;min-width:0}.ss-file-name{font-size:.875rem;font-weight:600;color:var(--ss-ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .25s}.ss-file-meta{font-family:IBM Plex Mono,monospace;font-size:.65rem;color:var(--ss-ink3);margin-top:2px;transition:color .25s}.ss-unstar-btn{background:none;border:none;cursor:pointer;font-size:1.2rem;color:var(--ss-amber);padding:.3rem;border-radius:6px;transition:transform .2s var(--ease-spring),opacity .15s;flex-shrink:0}.ss-unstar-btn:hover{transform:scale(1.25);opacity:.7}@media (max-width: 768px){.ss-page{padding:2rem 1.5rem 3rem}.ss-toolbar{flex-direction:column;align-items:stretch}.ss-count{text-align:right}}@media (max-width: 480px){.ss-page{padding:1.75rem 1.25rem}.ss-sort-btns{flex-wrap:wrap}.ss-sort-btn{font-size:.62rem;padding:.25rem .5rem}.ss-file-row{padding:.6rem 1rem}}@media (max-width: 360px){.ss-page{padding:1.5rem .875rem}.ss-group-header{padding:.75rem 1rem}.ss-file-row{padding:.6rem .75rem;gap:.6rem}.ss-file-icon-wrap{width:28px;height:28px;font-size:1rem}}@media (prefers-reduced-motion: reduce){.ss-enter,.ss-reveal{opacity:1!important;transform:none!important;transition:none!important}.ss-reveal.ss-visible{opacity:1;transform:none}}.ss-file-row--clickable{cursor:pointer}.ss-file-row--clickable:hover{background:var(--ss-bg2)}.ss-open-btn{background:none;border:1.5px solid var(--ss-border);color:var(--ss-accent);border-radius:7px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.1rem;flex-shrink:0;transition:background .15s,color .15s,border-color .15s;touch-action:manipulation}.ss-open-btn:hover{background:var(--ss-accent);color:#fff;border-color:var(--ss-accent)}.ss-sort-btns{display:flex;gap:.35rem;flex-wrap:wrap}.ss-sort-btn{padding:.28rem .65rem;border-radius:7px;border:1px solid var(--ss-border, #dddbd6);background:var(--ss-bg2, #eeecea);font-family:IBM Plex Mono,monospace;font-size:.65rem;font-weight:600;color:var(--ss-ink2, #4a4843);cursor:pointer;transition:background .18s,border-color .18s,color .18s;white-space:nowrap}.ss-sort-btn:hover{background:var(--ss-border, #dddbd6)}.ss-sort-btn--active{background:var(--ss-ink, #1a1916);color:#fff;border-color:var(--ss-ink, #1a1916)}.table-toolbar{display:flex;gap:var(--sp-md);align-items:flex-end;margin-bottom:var(--sp-lg);flex-wrap:wrap}.table-toolbar .form-group{flex:1;min-width:200px;margin-bottom:0}.role-filter-select{width:160px;flex-shrink:0;height:38px}.user-cell{display:flex;align-items:center;gap:.6rem;font-weight:500}.user-avatar-sm{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--primary) 0%,#1d4ed8 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;flex-shrink:0}.role-change-cell{display:flex;align-items:center}.role-select{padding:.3rem .6rem;border-radius:var(--radius);font-size:.8125rem;font-weight:600;cursor:pointer;border:2px solid transparent;transition:all .2s ease;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.role-select:focus{outline:none;box-shadow:0 0 0 3px #2563eb26}.role-select:disabled{opacity:.6;cursor:not-allowed}.role-select--admin{background-color:#fee2e2;color:#991b1b;border-color:#fca5a5}body.dark-mode .role-select--admin{background-color:#7f1d1d;color:#fecaca;border-color:#ef4444}.role-select--faculty{background-color:#dbeafe;color:#1e40af;border-color:#93c5fd}body.dark-mode .role-select--faculty{background-color:#1e3a8a;color:#bfdbfe;border-color:#3b82f6}.role-select--student{background-color:#d1fae5;color:#065f46;border-color:#6ee7b7}body.dark-mode .role-select--student{background-color:#064e3b;color:#a7f3d0;border-color:#10b981}.stats-icon{font-size:2.5rem;margin-bottom:var(--sp-sm)}.analytics-list{list-style:none;padding:0;margin:0}.analytics-item{display:flex;justify-content:space-between;align-items:center;padding:var(--sp-md) 0;border-bottom:1px solid var(--border-solid)}body.dark-mode .analytics-item{border-bottom-color:var(--border-solid)}.analytics-item:last-child{border-bottom:none}.analytics-name{font-size:.9375rem;color:var(--text);font-weight:500}body.dark-mode .analytics-name{color:var(--text)}.empty-text{text-align:center;color:var(--text-sub);padding:var(--sp-lg) 0;margin:0}body.dark-mode .empty-text{color:var(--text-sub)}.activity-metric{text-align:center;padding:var(--sp-lg) 0}.activity-icon{font-size:3rem;margin-bottom:var(--sp-md)}.activity-metric h3{font-size:2.5rem;color:var(--primary);margin-bottom:var(--sp-xs)}.activity-metric p{color:var(--text-sub);margin:0}body.dark-mode .activity-metric p{color:var(--text-sub)}.table-actions{margin-bottom:var(--sp-lg);max-width:400px}.action-buttons{display:flex;gap:var(--sp-sm)}@media (max-width: 768px){.action-buttons{flex-direction:column}.action-buttons button{width:100%}}.ad-tabs{display:flex;gap:.25rem;margin-bottom:1.5rem;border-bottom:2px solid var(--border-color,#e5e7eb);flex-wrap:wrap}.ad-tab{display:inline-flex;align-items:center;gap:.4rem;padding:.65rem 1rem;border:none;background:none;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--text-secondary-light);border-bottom:2px solid transparent;margin-bottom:-2px;border-radius:6px 6px 0 0;transition:color .18s,background .18s;white-space:nowrap}.ad-tab:hover{color:var(--primary);background:#3b82f60f}.ad-tab--active{color:var(--primary);border-bottom-color:var(--primary)}.ad-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;margin-bottom:1rem}.ad-stat-card{background:var(--bg-primary,#fff);border:1px solid var(--border-color,#e5e7eb);border-radius:12px;padding:1.25rem 1rem;text-align:center;border-top:3px solid transparent;transition:box-shadow .2s,transform .2s}.ad-stat-card:hover{box-shadow:0 4px 16px #00000014;transform:translateY(-2px)}.ad-stat-card--blue{border-top-color:#3b82f6}.ad-stat-card--green{border-top-color:#22c55e}.ad-stat-card--purple{border-top-color:#a855f7}.ad-stat-card--amber{border-top-color:#f59e0b}.ad-stat-icon{font-size:1.75rem;margin-bottom:.5rem}.ad-stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);line-height:1}.ad-stat-label{font-size:.78rem;color:var(--text-secondary-light);margin-top:.35rem;font-weight:500}.ad-timeline{display:flex;align-items:center;gap:.5rem;margin:.75rem 0 .5rem;font-size:.85rem;color:var(--text-secondary-light);flex-wrap:wrap}.ad-tl-btn{padding:.28rem .75rem;border:1px solid var(--border-color,#e5e7eb);border-radius:999px;background:none;cursor:pointer;font-size:.78rem;font-weight:500;transition:all .18s}.ad-tl-btn:hover{border-color:var(--primary);color:var(--primary)}.ad-tl-btn--on{background:var(--primary);color:#fff;border-color:var(--primary)}.ad-tl-count{font-weight:600;color:var(--text-primary)}.ad-refresh-btn{background:none;border:1px solid var(--border-color,#e5e7eb);border-radius:6px;padding:.28rem .5rem;cursor:pointer;font-size:1rem;color:var(--text-secondary-light);transition:all .18s;margin-left:auto}.ad-refresh-btn:hover{color:var(--primary);border-color:var(--primary)}.ad-date-input{height:30px;border:1px solid var(--border-color,#e5e7eb);border-radius:6px;padding:0 .5rem;font-size:.78rem;background:var(--bg-primary);color:var(--text-primary);outline:none}.ad-small-select{height:30px;border:1px solid var(--border-color,#e5e7eb);border-radius:6px;padding:0 .5rem;font-size:.78rem;background:var(--bg-primary);color:var(--text-primary);outline:none;cursor:pointer}.ad-sub{display:block;font-size:.72rem;color:var(--text-secondary-light);font-weight:400;margin-top:1px}.ad-pill{font-size:.78rem;background:var(--bg-secondary,#f9fafb);border:1px solid var(--border-color,#e5e7eb);border-radius:999px;padding:.22rem .7rem;color:var(--text-secondary-light);white-space:nowrap;flex-shrink:0}.ad-code{font-family:IBM Plex Mono,monospace;font-size:.78rem;background:var(--bg-secondary,#f9fafb);border:1px solid var(--border-color,#e5e7eb);border-radius:4px;padding:.15rem .45rem;letter-spacing:.08em;font-weight:600}.ad-name-link{background:none;border:none;cursor:pointer;font-size:.9rem;font-weight:500;color:var(--primary);text-decoration:underline;padding:0}.ad-icon-btn{background:none;border:1px solid var(--border-color,#e5e7eb);border-radius:6px;width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.1rem;color:var(--text-secondary-light);transition:all .18s;flex-shrink:0}.ad-icon-btn:hover{color:var(--primary);border-color:var(--primary);background:var(--bg-secondary)}.ad-report-btn{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;border:1px solid var(--border-color,#e5e7eb);border-radius:8px;background:var(--bg-secondary);cursor:pointer;font-size:.85rem;font-weight:500;color:var(--text-primary);transition:all .18s}.ad-report-btn:hover{border-color:var(--primary);color:var(--primary);background:#eff6ff}.ad-feedback-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.ad-feedback-card{background:var(--bg-primary,#fff);border:1px solid var(--border-color,#e5e7eb);border-radius:10px;padding:1rem 1.1rem;border-left:4px solid var(--border-color,#e5e7eb);transition:box-shadow .2s}.ad-feedback-card:hover{box-shadow:0 2px 12px #00000012}.ad-feedback-card--approved{border-left-color:#22c55e}.ad-feedback-card--hidden{border-left-color:#ef4444;opacity:.72}.ad-feedback-msg{font-size:.9rem;font-style:italic;line-height:1.6;margin:0 0 .6rem;color:var(--text-primary)}.ad-feedback-meta{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.ad-feedback-name{font-weight:700;font-size:.82rem;color:var(--text-primary)}.ad-feedback-date{font-size:.72rem;color:var(--text-secondary-light);margin-top:.3rem}.ad-ann-layout{display:grid;grid-template-columns:360px 1fr;gap:1.5rem;align-items:start}@media (max-width:900px){.ad-ann-layout{grid-template-columns:1fr}}.ad-ann-card{background:var(--bg-primary,#fff);border:1px solid var(--border-color,#e5e7eb);border-radius:10px;padding:1rem 1.25rem;margin-bottom:.75rem;transition:box-shadow .2s}.ad-ann-card:hover{box-shadow:0 2px 10px #00000012}.ad-ann-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;flex-wrap:wrap}.ad-ann-title{font-weight:700;font-size:.95rem;flex:1;color:var(--text-primary)}.ad-ann-msg{font-size:.875rem;color:var(--text-secondary-light);line-height:1.6;margin:0 0 .75rem;white-space:pre-wrap}.ad-ann-footer{display:flex;align-items:center;justify-content:space-between;font-size:.75rem;color:var(--text-secondary-light);flex-wrap:wrap;gap:.5rem}.ad-settings-layout{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start}@media (max-width:900px){.ad-settings-layout{grid-template-columns:1fr}}.ad-filetypes-grid{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}.ad-filetype-chip{padding:.3rem .65rem;border:1px solid var(--border-color,#e5e7eb);border-radius:6px;font-size:.75rem;font-family:monospace;cursor:pointer;transition:all .18s;background:var(--bg-secondary);color:var(--text-secondary-light);-webkit-user-select:none;user-select:none}.ad-filetype-chip--on{background:var(--primary);color:#fff;border-color:var(--primary)}.ad-features-list{display:flex;flex-direction:column;gap:.5rem}.ad-feature-row{display:flex;align-items:center;justify-content:space-between;padding:.6rem .75rem;background:var(--bg-secondary);border-radius:8px}.ad-feature-name{font-size:.875rem;font-weight:500;color:var(--text-primary)}.ad-toggle{position:relative;display:inline-block;cursor:pointer}.ad-toggle input{position:absolute;opacity:0;width:100%;height:100%;cursor:pointer;margin:0}.ad-toggle-track{display:block;width:36px;height:20px;background:var(--border-color,#e5e7eb);border-radius:999px;transition:background .2s;position:relative}.ad-toggle input:checked+.ad-toggle-track{background:var(--primary,#3b82f6)}.ad-toggle-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform .2s}.ad-toggle input:checked~.ad-toggle-track .ad-toggle-thumb{transform:translate(16px)}.ad-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a191673;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;animation:adFadeIn .2s ease both}@keyframes adFadeIn{0%{opacity:0}to{opacity:1}}.ad-modal{background:var(--bg-primary,#fff);border:1px solid var(--border-color,#e5e7eb);border-radius:16px;width:100%;max-width:520px;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #0000002e;animation:adSlideUp .28s cubic-bezier(.16,1,.3,1) both}@keyframes adSlideUp{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:none}}.ad-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem 0}.ad-modal-title{font-size:1.05rem;font-weight:700;color:var(--text-primary)}.ad-modal-close{background:none;border:none;cursor:pointer;font-size:1.25rem;color:var(--text-secondary-light);display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;transition:background .18s}.ad-modal-close:hover{background:var(--bg-secondary)}.ad-profile-body{padding:1rem 1.5rem 1.5rem}.ad-profile-row{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.ad-profile-avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--primary,#3b82f6),#1d4ed8);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.3rem;font-weight:700;flex-shrink:0}.ad-profile-name{font-size:1.05rem;font-weight:700;color:var(--text-primary)}.ad-profile-email{font-size:.82rem;color:var(--text-secondary-light);margin:.15rem 0 .4rem}.ad-profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:1rem}.ad-profile-item{background:var(--bg-secondary);border-radius:8px;padding:.6rem .75rem}.ad-profile-item span{display:block;font-size:.72rem;color:var(--text-secondary-light);margin-bottom:.15rem}.ad-profile-item strong{font-size:.875rem;color:var(--text-primary);font-weight:600}.ad-profile-section-title{font-size:.82rem;font-weight:700;color:var(--text-secondary-light);text-transform:uppercase;letter-spacing:.06em;margin:.75rem 0 .5rem}.ad-spin{animation:adSpin .7s linear infinite;display:inline-block;vertical-align:middle}@keyframes adSpin{to{transform:rotate(360deg)}}@media (max-width:640px){.ad-stats-grid{grid-template-columns:repeat(2,1fr)}.ad-feedback-grid,.ad-settings-layout{grid-template-columns:1fr}}.page-container>div>.alert{margin-bottom:0}.ad-upload-trigger{display:flex;align-items:center;gap:.4rem;width:100%;margin-top:.625rem;padding:.45rem .875rem;background:transparent;border:1.5px dashed var(--border-solid);border-radius:8px;font-size:.82rem;font-weight:600;color:var(--primary);cursor:pointer;transition:background .18s,border-color .18s;font-family:inherit}.ad-upload-trigger:hover{background:var(--primary-light);border-color:var(--primary);border-style:solid}.ad-upload-panel{margin-top:.75rem;padding:1rem;background:var(--bg);border:1.5px solid var(--border-solid);border-radius:10px}.ad-upload-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;font-size:.85rem;font-weight:600;color:var(--text)}.ad-upload-drop{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.25rem 1rem;border:2px dashed var(--border-solid);border-radius:8px;cursor:pointer;text-align:center;background:var(--surface);transition:border-color .18s,background .18s;color:var(--text)}.ad-upload-drop:hover{border-color:var(--primary);background:var(--primary-light)}.ad-upload-filelist{margin-top:.5rem;display:flex;flex-direction:column;gap:.3rem;max-height:160px;overflow-y:auto}.ad-upload-filerow{display:flex;align-items:center;gap:.5rem;padding:.3rem .625rem;background:var(--surface);border:1px solid var(--border-solid);border-radius:6px;font-size:.78rem}.ad-upload-fname{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text);font-weight:500}.ad-upload-fsize{color:var(--text-sub);white-space:nowrap;font-size:.72rem}body.dark-mode .ad-upload-panel{background:var(--surface);border-color:var(--border-solid)}body.dark-mode .ad-upload-drop,body.dark-mode .ad-upload-filerow{background:var(--bg)}body.dark-mode .ad-upload-trigger{border-color:var(--border-solid)}@media (max-width: 480px){.ad-upload-drop{padding:1rem .75rem}.ad-upload-panel{padding:.75rem}}.bm-light{--bm-bg: #f0f9ff;--bm-surface: #ffffff;--bm-border: #bae6fd;--bm-text: #0c4a6e;--bm-text-sec: #0369a1;--bm-accent: #0891b2;--bm-accent-bg: #e0f2fe;--bm-hover: #e0f2fe;--bm-selected: #bae6fd;--bm-topbar: #ffffff;--bm-toolbar: #f0f9ff;--bm-panel: #ffffff;--bm-folder: #f59e0b;--bm-danger: #dc2626;--bm-success: #059669;--bm-shadow: 0 1px 4px rgba(8,145,178,.1);--bm-radius: 10px}.bm-dark{--bm-bg: #0f0f0f;--bm-surface: #1a1a1a;--bm-border: #2e2e2e;--bm-text: #f0f0f0;--bm-text-sec: #a0a0a0;--bm-accent: #e2e8f0;--bm-accent-bg: rgba(255,255,255,.06);--bm-hover: rgba(255,255,255,.05);--bm-selected: rgba(255,255,255,.1);--bm-topbar: #111111;--bm-toolbar: #141414;--bm-panel: #161616;--bm-folder: #fbbf24;--bm-danger: #f87171;--bm-success: #4ade80;--bm-shadow: 0 1px 6px rgba(0,0,0,.6);--bm-radius: 10px}.bm-root{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;flex-direction:column;background:var(--bm-bg);color:var(--bm-text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:.875rem;overflow:hidden}.bm-topbar{display:flex;align-items:center;justify-content:space-between;padding:0 .875rem;height:52px;background:var(--bm-topbar);border-bottom:2px solid var(--bm-border);box-shadow:var(--bm-shadow);flex-shrink:0;gap:.5rem}.bm-topbar-left{display:flex;align-items:center;gap:.5rem;min-width:0;flex:1;overflow:hidden}.bm-topbar-right{display:flex;align-items:center;gap:.35rem;flex-shrink:0}.bm-topbar-title{display:flex;align-items:center;gap:.4rem;font-weight:700;font-size:1rem;color:var(--bm-accent);white-space:nowrap;flex-shrink:0}.bm-back-btn,.bm-close-btn,.bm-theme-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1.5px solid var(--bm-border);border-radius:8px;background:var(--bm-surface);color:var(--bm-text-sec);cursor:pointer;font-size:1.2rem;transition:background .15s,color .15s,border-color .15s;touch-action:manipulation;flex-shrink:0}.bm-back-btn:hover,.bm-theme-btn:hover{background:var(--bm-hover);color:var(--bm-accent);border-color:var(--bm-accent)}.bm-close-btn{color:var(--bm-danger);border-color:#fca5a5}.bm-close-btn:hover{background:#f8717126}.bm-search-wrap{position:relative;display:flex;align-items:center}.bm-search-icon{position:absolute;left:.6rem;color:var(--bm-text-sec);font-size:1rem;pointer-events:none}.bm-search{width:180px;padding:.42rem 2rem .42rem 2.1rem;border:1.5px solid var(--bm-border);border-radius:8px;background:var(--bm-bg);color:var(--bm-text);font-size:.85rem;outline:none;transition:border-color .2s}.bm-search:focus{border-color:var(--bm-accent);box-shadow:0 0 0 3px var(--bm-accent-bg)}.bm-search-clear{position:absolute;right:.5rem;background:none;border:none;color:var(--bm-text-sec);cursor:pointer;font-size:1rem}.bm-view-toggle{display:flex;border:1.5px solid var(--bm-border);border-radius:8px;overflow:hidden}.bm-view-toggle button{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:none;background:transparent;color:var(--bm-text-sec);cursor:pointer;font-size:1.1rem;transition:background .15s,color .15s;touch-action:manipulation}.bm-view-toggle button.active,.bm-view-toggle button:hover{background:var(--bm-accent);color:#fff}.bm-toolbar{display:flex;align-items:center;justify-content:space-between;padding:.5rem .875rem;background:var(--bm-toolbar);border-bottom:1px solid var(--bm-border);flex-shrink:0;gap:.5rem;flex-wrap:wrap}.bm-toolbar-left,.bm-toolbar-right{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.bm-toolbar-icon{color:var(--bm-text-sec);font-size:1rem;flex-shrink:0}.bm-select{padding:.3rem .6rem;border:1.5px solid var(--bm-border);border-radius:6px;background:var(--bm-surface);color:var(--bm-text);font-size:.8rem;cursor:pointer;outline:none}.bm-select:focus{border-color:var(--bm-accent)}.bm-count{font-size:.8rem;color:var(--bm-text-sec);white-space:nowrap;font-weight:600}.bm-alert{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1rem;font-size:.85rem;flex-shrink:0}.bm-alert--error{background:#fee2e2;color:#991b1b;border-bottom:1px solid #fca5a5}.bm-alert--success{background:#d1fae5;color:#065f46;border-bottom:1px solid #6ee7b7}.bm-alert button{background:none;border:none;cursor:pointer;color:inherit;font-size:1rem;display:flex}.bm-dark .bm-alert--error{background:#dc26262e;color:#fca5a5;border-bottom-color:#dc262640}.bm-dark .bm-alert--success{background:#4ade801f;color:#4ade80;border-bottom-color:#4ade8033}.bm-breadcrumb{display:flex;align-items:center;gap:.2rem;font-size:.8rem;color:var(--bm-text-sec);min-width:0;flex:1;overflow:hidden}.bm-breadcrumb button{display:flex;align-items:center;gap:.2rem;background:none;border:none;color:var(--bm-accent);cursor:pointer;font-size:.8rem;padding:.1rem .3rem;border-radius:4px;white-space:nowrap;touch-action:manipulation}.bm-breadcrumb button:hover{background:var(--bm-hover)}.bm-breadcrumb span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bm-breadcrumb-sep{flex-shrink:0}.bm-body{display:flex;flex:1;overflow:hidden}.bm-main{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:1rem}.bm-main--with-panel{border-right:1px solid var(--bm-border)}.bm-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60%;gap:.75rem;color:var(--bm-text-sec);text-align:center}.bm-empty-icon{font-size:3.5rem;color:var(--bm-folder);opacity:.5}.bm-spinner{width:36px;height:36px;border:3px solid var(--bm-border);border-top-color:var(--bm-accent);border-radius:50%;animation:bm-spin .7s linear infinite}@keyframes bm-spin{to{transform:rotate(360deg)}}.bm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem}.bm-folder-card,.bm-file-card{position:relative;display:flex;flex-direction:column;align-items:center;padding:.875rem .75rem .75rem;border:1.5px solid var(--bm-border);border-radius:var(--bm-radius);background:var(--bm-surface);cursor:pointer;transition:border-color .15s,box-shadow .15s;box-shadow:var(--bm-shadow);gap:.35rem;text-align:center}.bm-folder-card:hover,.bm-file-card:hover{border-color:var(--bm-accent);box-shadow:0 4px 14px #00000040}.bm-folder-card.selected,.bm-file-card.selected{background:var(--bm-selected);border-color:var(--bm-accent)}.bm-folder-card-icon,.bm-file-card-icon{display:flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:12px;background:var(--bm-accent-bg);margin-bottom:.2rem}.bm-folder-icon{color:var(--bm-folder);font-size:2rem}.bm-folder-icon-sm{color:var(--bm-folder);font-size:1.1rem;vertical-align:middle;margin-right:.4rem}.bm-folder-icon-xl{color:var(--bm-folder);font-size:4rem}.bm-folder-name,.bm-file-name{font-size:.78rem;font-weight:600;color:var(--bm-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.bm-folder-meta,.bm-file-size{font-size:.7rem;color:var(--bm-text-sec)}.bm-folder-card-actions,.bm-file-card-actions{display:flex;gap:.25rem;justify-content:center;flex-wrap:wrap;width:100%;margin-top:.4rem;padding-top:.4rem;border-top:1px solid var(--bm-border)}.bm-folder-card-actions button,.bm-file-card-actions button{display:flex;align-items:center;justify-content:center;min-width:36px;height:32px;padding:0 .45rem;border:1.5px solid var(--bm-border);border-radius:7px;background:var(--bm-bg);color:var(--bm-text-sec);cursor:pointer;font-size:1rem;transition:background .15s,color .15s,border-color .15s;touch-action:manipulation}.bm-folder-card-actions button:hover,.bm-file-card-actions button:hover{background:var(--bm-accent-bg);color:var(--bm-accent);border-color:var(--bm-accent)}.bm-action--danger{color:var(--bm-danger)!important;border-color:#fca5a5!important}.bm-action--danger:hover{background:#fee2e2!important}.bm-action--copied{color:var(--bm-success)!important}.bm-open-btn{width:100%;margin-top:.3rem;padding:.3rem .75rem;border:1.5px solid var(--bm-accent);border-radius:7px;background:var(--bm-accent-bg);color:var(--bm-accent);font-size:.75rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s;touch-action:manipulation}.bm-open-btn:hover{background:var(--bm-accent);color:#fff}.bm-folder-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.875rem;padding-bottom:.75rem;border-bottom:1px solid var(--bm-border);flex-wrap:wrap;gap:.5rem}.bm-breadcrumb-back{display:flex;align-items:center;gap:.4rem;background:var(--bm-accent-bg);border:1.5px solid var(--bm-border);color:var(--bm-accent);cursor:pointer;font-size:.875rem;font-weight:600;padding:.4rem .875rem;border-radius:8px;transition:background .15s;touch-action:manipulation}.bm-breadcrumb-back:hover{background:var(--bm-hover)}.bm-upload-btn{display:flex;align-items:center;gap:.4rem;padding:.4rem .875rem;background:var(--bm-accent);color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .15s;touch-action:manipulation}.bm-upload-btn:hover{opacity:.88}.bm-file-icon{font-size:1rem}.bm-file-icon--sm{font-size:1.1rem}.bm-file-icon--md{font-size:1.5rem}.bm-file-icon--lg{font-size:2rem}.bm-file-icon--xl{font-size:3.5rem}.bm-icon--pdf{color:#dc2626}.bm-icon--img{color:#059669}.bm-icon--vid{color:#7c3aed}.bm-icon--doc{color:#0891b2}.bm-icon--ppt{color:#d97706}.bm-table{width:100%;border-collapse:collapse;font-size:.85rem}.bm-table thead th{text-align:left;padding:.6rem .75rem;color:var(--bm-text-sec);font-weight:700;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--bm-border);background:var(--bm-toolbar);position:sticky;top:0;z-index:1}.bm-table tbody tr{border-bottom:1px solid var(--bm-border);cursor:pointer;transition:background .1s}.bm-table tbody tr:hover{background:var(--bm-hover)}.bm-table tbody tr.selected{background:var(--bm-selected)}.bm-table td{padding:.6rem .75rem;color:var(--bm-text);vertical-align:middle}.bm-table-name{display:flex;align-items:center;gap:.4rem;font-weight:500;max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bm-table-actions{display:flex;gap:.3rem;align-items:center}.bm-table-actions button{display:flex;align-items:center;justify-content:center;min-width:34px;height:32px;padding:0 .4rem;border:1.5px solid var(--bm-border);border-radius:7px;background:var(--bm-bg);color:var(--bm-text-sec);cursor:pointer;font-size:1rem;transition:background .15s,color .15s;touch-action:manipulation}.bm-table-actions button:hover{background:var(--bm-hover);color:var(--bm-accent)}.bm-panel{width:260px;flex-shrink:0;background:var(--bm-panel);border-left:1.5px solid var(--bm-border);display:flex;flex-direction:column;overflow-y:auto}.bm-panel-header{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1rem;border-bottom:1px solid var(--bm-border);font-weight:700;font-size:.875rem;color:var(--bm-text)}.bm-panel-header button{background:none;border:none;cursor:pointer;color:var(--bm-text-sec);font-size:1.1rem;display:flex;border-radius:6px;padding:2px}.bm-panel-preview{padding:1rem;display:flex;align-items:center;justify-content:center;background:var(--bm-bg);border-bottom:1px solid var(--bm-border);min-height:120px}.bm-panel-img{max-width:100%;max-height:140px;border-radius:8px;object-fit:contain}.bm-panel-file-icon{display:flex;align-items:center;justify-content:center;padding:1.25rem}.bm-panel-info{padding:.875rem 1rem;display:flex;flex-direction:column;gap:.5rem;flex:1}.bm-panel-filename{font-weight:700;font-size:.875rem;color:var(--bm-text);word-break:break-word;margin-bottom:.25rem}.bm-panel-row{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;gap:.5rem}.bm-panel-row span:first-child{color:var(--bm-text-sec);font-weight:600;flex-shrink:0}.bm-panel-row span:last-child{color:var(--bm-text);text-align:right;word-break:break-all}.bm-panel-code .bm-code-tag{display:flex;align-items:center;gap:.4rem;font-family:monospace;background:var(--bm-accent-bg);color:var(--bm-accent);padding:.2rem .5rem;border-radius:5px;font-size:.8rem}.bm-panel-code .bm-code-tag button{background:none;border:none;cursor:pointer;color:var(--bm-accent);font-size:.85rem;display:flex;align-items:center}.bm-panel-actions{padding:.875rem 1rem;display:flex;flex-direction:column;gap:.4rem;border-top:1px solid var(--bm-border)}.bm-panel-btn{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.5rem;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .15s;touch-action:manipulation}.bm-panel-btn:hover{opacity:.85}.bm-panel-btn--primary{background:var(--bm-accent);color:#fff}.bm-panel-btn--secondary{background:var(--bm-accent-bg);color:var(--bm-accent)}.bm-panel-btn--danger{background:#fee2e2;color:var(--bm-danger)}.bm-dark .bm-panel-btn--danger{background:#dc26262e;color:#f87171;border:1px solid rgba(220,38,38,.25)}.bm-panel-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;color:var(--bm-text-sec);padding:2rem 1rem;text-align:center}.bm-panel-empty-icon{font-size:3rem;color:var(--bm-folder);opacity:.4}.bm-panel-row--downloads{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--bm-border)}.bm-dl-count{display:inline-flex;align-items:baseline;gap:.3rem}.bm-dl-count-num{font-size:1.1rem;font-weight:700;color:var(--bm-accent)}.bm-dl-count-label{font-size:.72rem;color:var(--bm-text-sec)}.bm-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:10000;display:flex;align-items:center;justify-content:center;padding:1rem}.bm-modal{background:var(--bm-surface);border-radius:14px;width:100%;max-width:440px;box-shadow:0 20px 60px #00000059;overflow:hidden;border:1.5px solid var(--bm-border)}.bm-modal--upload{max-width:560px}.bm-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--bm-border);font-weight:700;font-size:1rem;color:var(--bm-text);background:var(--bm-toolbar)}.bm-modal-header button{background:none;border:none;cursor:pointer;color:var(--bm-text-sec);font-size:1.2rem;display:flex;border-radius:6px;padding:4px}.bm-modal-body{padding:1.25rem;display:flex;flex-direction:column;gap:.75rem;max-height:65vh;overflow-y:auto}.bm-modal-body label{font-size:.8rem;font-weight:700;color:var(--bm-text-sec);text-transform:uppercase;letter-spacing:.4px}.bm-input{padding:.55rem .75rem;border:1.5px solid var(--bm-border);border-radius:8px;background:var(--bm-bg);color:var(--bm-text);font-size:.875rem;outline:none;width:100%;box-sizing:border-box;transition:border-color .2s}.bm-input:focus{border-color:var(--bm-accent);box-shadow:0 0 0 3px var(--bm-accent-bg)}.bm-modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:.875rem 1.25rem;border-top:1px solid var(--bm-border);align-items:center;flex-wrap:wrap}.bm-btn{padding:.5rem 1.25rem;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .15s;touch-action:manipulation}.bm-btn:disabled{opacity:.5;cursor:not-allowed}.bm-btn:hover{opacity:.88}.bm-btn--primary{background:var(--bm-accent);color:#fff}.bm-btn--secondary{background:var(--bm-bg);color:var(--bm-text);border:1.5px solid var(--bm-border)}.bm-upload-hint{font-size:.8rem;color:var(--bm-text-sec);line-height:1.5}.bm-upload-label{display:block;font-size:.78rem;font-weight:700;color:var(--bm-text-sec);margin-bottom:.35rem;text-transform:uppercase}.bm-sf-create-row{display:flex;align-items:center;gap:.5rem;background:var(--bm-bg);border:1.5px solid var(--bm-border);border-radius:8px;padding:.45rem .75rem}.bm-sf-create-input{flex:1;border:none;background:transparent;font-size:.875rem;color:var(--bm-text);outline:none;font-family:inherit}.bm-sf-create-input::placeholder{color:var(--bm-text-sec);opacity:.7}.bm-dropzone{border:2px dashed var(--bm-border);border-radius:10px;padding:2rem 1rem;text-align:center;cursor:pointer;background:var(--bm-surface);transition:border-color .18s,background .18s}.bm-dropzone:hover,.bm-dropzone--active{border-color:var(--bm-accent);background:var(--bm-hover)}.bm-dropzone-icon{font-size:2.25rem;margin-bottom:.5rem}.bm-dropzone-text{font-size:.9rem;font-weight:700;color:var(--bm-text);margin:0 0 .2rem}.bm-dropzone-sub{font-size:.78rem;color:var(--bm-text-sec);margin:0}.bm-upload-filelist{background:var(--bm-bg);border:1.5px solid var(--bm-border);border-radius:8px;padding:.625rem;max-height:180px;overflow-y:auto}.bm-upload-filelist-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:.4rem;margin-bottom:.4rem;border-bottom:1px solid var(--bm-border);font-size:.72rem;font-weight:700;color:var(--bm-text-sec)}.bm-clear-btn{font-size:.7rem;font-weight:600;color:var(--bm-danger);background:none;border:1px solid var(--bm-border);border-radius:4px;padding:.1rem .4rem;cursor:pointer}.bm-upload-file-row{display:flex;align-items:center;gap:.5rem;padding:.35rem .5rem;background:var(--bm-surface);border:1px solid var(--bm-border);border-radius:6px;margin-bottom:.25rem}.bm-upload-file-info{flex:1;min-width:0}.bm-upload-file-name{font-size:.78rem;font-weight:600;color:var(--bm-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bm-upload-file-size{font-size:.68rem;color:var(--bm-text-sec)}.bm-remove-file-btn{background:none;border:1px solid var(--bm-border);border-radius:4px;padding:.1rem .4rem;font-size:.72rem;font-weight:700;color:var(--bm-danger);cursor:pointer;flex-shrink:0}.bm-dest-badge{padding:.35rem .75rem;background:var(--bm-accent-bg);border:1.5px solid var(--bm-border);border-radius:6px;font-size:.78rem;color:var(--bm-accent)}.bm-batch-bar{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;padding:.5rem .75rem;background:var(--bm-surface);border:1.5px solid var(--bm-border);border-radius:8px;margin-bottom:.875rem}.bm-batch-select{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .7rem;border-radius:6px;border:1.5px solid var(--bm-border);background:var(--bm-bg);color:var(--bm-text-sec);font-size:.78rem;font-weight:600;cursor:pointer;touch-action:manipulation}.bm-batch-select:hover{border-color:var(--bm-accent);color:var(--bm-accent)}.bm-batch-count{font-size:.75rem;font-weight:700;color:var(--bm-accent);background:var(--bm-accent-bg);border-radius:999px;padding:.15rem .6rem}.bm-batch-zip{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .875rem;border-radius:6px;border:none;background:var(--bm-accent);color:#fff;font-size:.78rem;font-weight:700;cursor:pointer;touch-action:manipulation}.bm-batch-zip:disabled{opacity:.5;cursor:not-allowed}.bm-batch-delete{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .875rem;border-radius:6px;border:none;background:#fee2e2;color:var(--bm-danger);font-size:.78rem;font-weight:700;cursor:pointer;touch-action:manipulation}.bm-file-checkbox{width:16px;height:16px;cursor:pointer;accent-color:var(--bm-accent);flex-shrink:0}.bm-file-card--checked{border-color:var(--bm-accent)!important;background:var(--bm-selected)!important}.bm-row--checked{background:var(--bm-selected)!important}.bm-star-btn{background:none;border:none;cursor:pointer;font-size:1.1rem;color:var(--bm-text-sec);transition:color .15s,transform .2s;display:flex;align-items:center;touch-action:manipulation;padding:2px}.bm-star-btn:hover{color:#f59e0b;transform:scale(1.15)}.bm-star-btn--on{color:#f59e0b}.bm-highlight{background:#fef08a;color:#1a1916;border-radius:2px;padding:0 1px;font-weight:700}.bm-code-preview{width:100%;height:100%;overflow:auto;background:#f8fafc}.bm-dark .bm-code-preview{background:#0d0d0d}.bm-dark .bm-code-lang{background:#1a1a1a;border-bottom-color:#2e2e2e;color:#a0a0a0}.bm-dark .bm-code-pre{background:#0d0d0d;color:#e2e8f0}.bm-code-lang{padding:.4rem 1rem;background:#e0f2fe;border-bottom:1px solid #bae6fd;font-family:monospace;font-size:.72rem;color:#0369a1}.bm-code-pre{margin:0;padding:1.25rem 1.5rem;font-family:monospace;font-size:.82rem;line-height:1.7;color:#0c4a6e;white-space:pre;overflow-x:auto}.bm-code-pre code{background:none;padding:0}.hl-keyword{color:#0891b2;font-weight:700}.hl-string{color:#059669}.hl-comment{color:#94a3b8;font-style:italic}.hl-number{color:#d97706}.bm-md-preview{width:100%;height:100%;overflow:auto;padding:2rem;background:#fff;color:#0c4a6e;font-family:system-ui,sans-serif;font-size:.95rem;line-height:1.8}.bm-dark .bm-md-preview{background:#111;color:#f0f0f0}.bm-recent-strip{margin-bottom:1.25rem;background:var(--bm-surface);border:1.5px solid var(--bm-border);border-radius:10px;padding:.875rem 1rem}.bm-recent-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.625rem}.bm-recent-label{font-size:.68rem;font-weight:700;color:var(--bm-text-sec);letter-spacing:.05em;text-transform:uppercase}.bm-recent-clear{font-size:.68rem;font-weight:600;color:var(--bm-text-sec);background:none;border:1px solid var(--bm-border);border-radius:4px;padding:.1rem .45rem;cursor:pointer}.bm-recent-row{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.25rem;scrollbar-width:thin}.bm-recent-chip{display:flex;flex-direction:column;align-items:center;gap:.2rem;flex-shrink:0;width:88px;padding:.6rem .5rem;background:var(--bm-bg);border:1.5px solid var(--bm-border);border-radius:8px;cursor:pointer;text-align:center;transition:border-color .15s;touch-action:manipulation}.bm-recent-chip:hover{border-color:var(--bm-accent)}.bm-recent-chip-name{font-size:.68rem;font-weight:600;color:var(--bm-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.bm-recent-chip-sub{font-size:.6rem;color:var(--bm-text-sec);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}@keyframes bmSlide{0%{transform:translate(-100%)}50%{transform:translate(100%)}to{transform:translate(200%)}}@media (max-width: 900px){.bm-panel{display:none}}@media (max-width: 768px){.bm-search{width:130px}.bm-topbar-title{display:none}.bm-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.bm-table th:nth-child(3),.bm-table td:nth-child(3),.bm-table th:nth-child(4),.bm-table td:nth-child(4){display:none}}@media (max-width: 540px){.bm-topbar{padding:0 .5rem;height:48px}.bm-search{width:100px;font-size:.78rem}.bm-toolbar{flex-direction:column;align-items:flex-start;gap:.35rem;padding:.4rem .5rem}.bm-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.6rem}.bm-main{padding:.6rem}.bm-breadcrumb{display:none}.bm-folder-card-actions button,.bm-file-card-actions button{flex:1;min-width:0;height:38px;font-size:1.1rem}.bm-back-btn,.bm-close-btn,.bm-theme-btn{width:40px;height:40px}.bm-view-toggle{display:none}}@media (max-width: 400px){.bm-grid{grid-template-columns:repeat(2,1fr)}.bm-search{width:80px}}@media (max-width: 360px){.bm-topbar{height:auto;min-height:44px;padding:.3rem .35rem;flex-wrap:nowrap}.bm-topbar-left{gap:.25rem}.bm-search{width:70px;font-size:.72rem}.bm-back-btn,.bm-close-btn,.bm-theme-btn{width:36px;height:36px;font-size:1rem}.bm-main{padding:.4rem}.bm-grid{gap:.4rem}}@supports (padding: max(0px)){.bm-root{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);padding-bottom:env(safe-area-inset-bottom)}}.ac-page{padding:2rem 2.5rem;opacity:0;transition:opacity .3s ease}.ac-ready{opacity:1}.ac-enter{opacity:0;transform:translateY(12px);animation:acIn .5s cubic-bezier(.16,1,.3,1) forwards}@keyframes acIn{to{opacity:1;transform:none}}.ac-hero{margin-bottom:1.75rem}.ac-hero-label{font-size:.75rem;font-weight:600;letter-spacing:.08em;color:var(--text-secondary-light);text-transform:uppercase;margin-bottom:.5rem}.ac-title{font-size:2rem;font-weight:800;color:var(--text-primary);margin:0 0 .5rem;line-height:1.2}.ac-title-accent{color:var(--primary)}.ac-subtitle{font-size:.9rem;color:var(--text-secondary-light);max-width:520px;line-height:1.65;margin:0}.ac-filters{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:1.5rem}.ac-search-wrap{display:flex;align-items:center;gap:.5rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:.45rem .75rem;flex:1;min-width:200px;max-width:300px}.ac-search-icon{color:var(--text-secondary-light);font-size:1.1rem;flex-shrink:0}.ac-search{border:none;background:none;outline:none;font-size:.875rem;color:var(--text-primary);width:100%}.ac-cat-pills{display:flex;gap:.375rem;flex-wrap:wrap}.ac-cat-pill{padding:.3rem .75rem;border:1px solid var(--border-color);border-radius:999px;background:none;cursor:pointer;font-size:.78rem;font-weight:500;color:var(--text-secondary-light);transition:all .18s;white-space:nowrap}.ac-cat-pill:hover{border-color:var(--primary);color:var(--primary)}.ac-cat-pill--on{background:var(--primary);color:#fff;border-color:var(--primary)}.ac-dept-select{height:34px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:.82rem;padding:0 .75rem;outline:none;cursor:pointer}.ac-count{font-size:.82rem;color:var(--text-secondary-light);margin-bottom:1rem}.ac-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem}.ac-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;padding:1.25rem;display:flex;flex-direction:column;gap:.5rem;transition:box-shadow .2s,transform .2s,border-color .2s}.ac-card:hover{box-shadow:0 4px 20px #00000014;transform:translateY(-2px);border-color:var(--primary)}.ac-card-top{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.ac-card-icon{font-size:1.5rem;color:var(--primary)}.ac-cat-badge{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:999px;padding:.15rem .55rem;color:var(--text-secondary-light)}.ac-card-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0;line-height:1.35;word-break:break-word}.ac-card-meta{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap;font-size:.78rem;color:var(--text-secondary-light)}.ac-card-views{font-size:.72rem;color:var(--text-secondary-light)}.ac-open-btn{display:inline-flex;align-items:center;gap:.4rem;margin-top:auto;padding-top:.75rem;background:var(--primary);color:#fff;border:none;border-radius:8px;padding:.6rem 1rem;font-size:.875rem;font-weight:600;cursor:pointer;width:100%;justify-content:center;transition:background .18s,transform .18s}.ac-open-btn:hover{background:#2563eb;transform:translateY(-1px)}.ac-loading{display:flex;align-items:center;gap:.75rem;padding:3rem;justify-content:center;color:var(--text-secondary-light);font-size:.9rem}.ac-spin{animation:acSpin .7s linear infinite;font-size:1.3rem}@keyframes acSpin{to{transform:rotate(360deg)}}.ac-empty{text-align:center;padding:4rem 2rem;color:var(--text-secondary-light)}.ac-empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.4}.ac-empty h3{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem}.ac-empty p{font-size:.875rem;margin:0}@media (max-width: 640px){.ac-page{padding:1.25rem}.ac-title{font-size:1.5rem}.ac-grid{grid-template-columns:1fr}}:root{--primary: #2563eb;--primary-dark: #1d4ed8;--primary-light: #dbeafe;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--bg: #f0f4f8;--surface: #ffffff;--card: #ffffff;--border: rgba(0,0,0,.07);--border-solid: #e5e7eb;--text: #0f172a;--text-sub: #64748b;--text-muted: #94a3b8;--shadow-xs: 0 1px 2px rgba(0,0,0,.04);--shadow-sm: 0 2px 8px rgba(0,0,0,.06);--shadow: 0 4px 16px rgba(0,0,0,.08);--shadow-md: 0 8px 24px rgba(0,0,0,.1);--shadow-lg: 0 16px 48px rgba(0,0,0,.14);--radius-sm: .375rem;--radius: .625rem;--radius-lg: .875rem;--radius-xl: 1.25rem;--sp-xs: .25rem;--sp-sm: .5rem;--sp-md: 1rem;--sp-lg: 1.5rem;--sp-xl: 2rem;--sp-2xl: 3rem;--transition: all .2s ease;--primary-color: var(--primary);--primary-hover: var(--primary-dark);--success-color: var(--success);--danger-color: var(--danger);--warning-color: var(--warning);--background-light: var(--bg);--surface-light: var(--surface);--card-light: var(--card);--text-light: var(--text);--text-secondary-light: var(--text-sub);--border-light: var(--border-solid);--spacing-xs: var(--sp-xs);--spacing-sm: var(--sp-sm);--spacing-md: var(--sp-md);--spacing-lg: var(--sp-lg);--spacing-xl: var(--sp-xl);--spacing-2xl: var(--sp-2xl);--border-radius-sm: var(--radius-sm);--border-radius: var(--radius);--border-radius-lg: var(--radius-lg);--border-radius-xl: var(--radius-xl)}body.dark-mode{--bg: #052e3d;--surface: #0c4a6e;--card: #0c4a6e;--border: rgba(255,255,255,.08);--border-solid: #075985;--text: #e0f2fe;--text-sub: #7dd3fc;--text-muted: #38bdf8;--background-dark: var(--bg);--surface-dark: var(--surface);--card-dark: var(--card);--text-dark: var(--text);--text-secondary-dark: var(--text-sub);--border-dark: var(--border-solid)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.6;transition:background .25s ease,color .25s ease;overflow-x:hidden}img,video{max-width:100%;display:block}h1{font-size:clamp(1.375rem,4vw,2rem);font-weight:800;margin-bottom:var(--sp-md);letter-spacing:-.5px;line-height:1.2}h2{font-size:clamp(1.125rem,3vw,1.5rem);font-weight:700;margin-bottom:var(--sp-md);letter-spacing:-.3px}h3{font-size:clamp(1rem,2.5vw,1.25rem);font-weight:700;margin-bottom:var(--sp-sm)}h4{font-size:clamp(.9rem,2vw,1.125rem);font-weight:600;margin-bottom:var(--sp-sm)}p{line-height:1.7;margin-bottom:var(--sp-md)}.app-container{display:flex;height:100vh;height:100dvh;min-height:100vh;min-height:100dvh;background:var(--bg);overflow:hidden}.main-content{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--bg);overflow-y:auto;overflow-x:hidden}.page-container{flex:1;padding:var(--sp-xl);max-width:1400px;margin:0 auto;width:100%}.card{background:var(--card);border-radius:var(--radius-lg);padding:var(--sp-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:var(--transition);overflow:hidden;word-break:break-word}.card:hover{box-shadow:var(--shadow)}.card-header{margin-bottom:var(--sp-md);padding-bottom:var(--sp-md);border-bottom:1px solid var(--border-solid)}.card-title{font-size:1.125rem;font-weight:700;color:var(--text)}.btn{padding:.6rem 1.25rem;border-radius:var(--radius);font-size:.875rem;font-weight:600;cursor:pointer;border:none;transition:var(--transition);display:inline-flex;align-items:center;justify-content:center;gap:.5rem;text-decoration:none;white-space:nowrap;min-height:42px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-secondary{background:var(--text-sub);color:#fff}.btn-secondary:hover:not(:disabled){background:#475569}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#059669}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-outline{background:transparent;border:2px solid var(--primary);color:var(--primary)}.btn-outline:hover:not(:disabled){background:var(--primary);color:#fff}.btn-sm{padding:.4rem .875rem;font-size:.8125rem;min-height:36px}.btn-lg{padding:.875rem 1.75rem;font-size:1rem;min-height:50px}.form-group{margin-bottom:var(--sp-lg)}.form-label{display:block;margin-bottom:var(--sp-sm);font-weight:600;font-size:.875rem;color:var(--text)}.form-input,.form-select,.form-textarea{width:100%;padding:.625rem .875rem;border:1.5px solid var(--border-solid);border-radius:var(--radius);font-size:max(16px,.875rem);transition:var(--transition);background:var(--surface);color:var(--text)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1f}.form-textarea{resize:vertical;min-height:100px}.form-error{color:var(--danger);font-size:.8125rem;margin-top:var(--sp-xs)}.alert{padding:var(--sp-md);border-radius:var(--radius);margin-bottom:var(--sp-md);display:flex;align-items:flex-start;gap:var(--sp-sm);font-size:.875rem;font-weight:500;word-break:break-word}.alert-success{background:#d1fae5;color:#065f46;border-left:4px solid var(--success)}.alert-error{background:#fee2e2;color:#991b1b;border-left:4px solid var(--danger)}.alert-info{background:#dbeafe;color:#1e40af;border-left:4px solid var(--primary)}.alert-warning{background:#fef3c7;color:#92400e;border-left:4px solid var(--warning)}body.dark-mode .alert-success{background:#064e3b33;color:#6ee7b7}body.dark-mode .alert-error{background:#7f1d1d33;color:#fca5a5}body.dark-mode .alert-info{background:#1e3a8a33;color:#93c5fd}body.dark-mode .alert-warning{background:#78350f33;color:#fcd34d}.badge{display:inline-block;padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600}.badge-primary{background:#dbeafe;color:#1e40af}.badge-success{background:#d1fae5;color:#065f46}.badge-warning{background:#fef3c7;color:#92400e}.badge-danger{background:#fee2e2;color:#991b1b}body.dark-mode .badge-primary{background:#1e3a8a44;color:#93c5fd}body.dark-mode .badge-success{background:#064e3b44;color:#6ee7b7}body.dark-mode .badge-warning{background:#78350f44;color:#fcd34d}body.dark-mode .badge-danger{background:#7f1d1d44;color:#fca5a5}.grid{display:grid;gap:var(--sp-lg)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-sm{gap:var(--sp-sm)}.gap-md{gap:var(--sp-md)}.gap-lg{gap:var(--sp-lg)}.w-full{width:100%}.spinner{border:3px solid rgba(37,99,235,.12);border-top:3px solid var(--primary);border-radius:50%;width:40px;height:40px;animation:spin .9s linear infinite;flex-shrink:0}.spinner-sm{width:20px;height:20px;border-width:2px}@keyframes spin{to{transform:rotate(360deg)}}.loading-container{display:flex;justify-content:center;align-items:center;flex-direction:column;gap:1rem;min-height:200px}.empty-state{text-align:center;padding:var(--sp-2xl) var(--sp-md);color:var(--text-sub)}.empty-state-icon{font-size:3.5rem;margin-bottom:var(--sp-md);opacity:.5}.empty-state h3{color:var(--text);margin-bottom:var(--sp-sm)}.stats-card{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;padding:var(--sp-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.stats-card h3{font-size:clamp(1.5rem,4vw,2rem);margin-bottom:var(--sp-xs)}.stats-card p{opacity:.9;font-size:.875rem;margin:0}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch;background:var(--card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border)}.table{width:100%;border-collapse:collapse}.table thead{background:var(--bg);border-bottom:2px solid var(--border-solid)}.table th{padding:var(--sp-md);text-align:left;font-size:.8125rem;font-weight:700;color:var(--text-sub);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.table td{padding:var(--sp-md);border-bottom:1px solid var(--border);font-size:.875rem}.table tbody tr:hover{background:var(--bg)}.pagination{display:flex;gap:var(--sp-sm);justify-content:center;margin-top:var(--sp-xl);flex-wrap:wrap}.pagination button{padding:.5rem .875rem;border:1.5px solid var(--border-solid);background:var(--surface);color:var(--text);border-radius:var(--radius);cursor:pointer;transition:var(--transition);font-size:.875rem;font-weight:500;min-height:40px;min-width:40px}.pagination button:hover:not(:disabled){background:var(--primary);color:#fff;border-color:var(--primary)}.pagination button.active{background:var(--primary);color:#fff;border-color:var(--primary)}.pagination button:disabled{opacity:.4;cursor:not-allowed}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--sp-xl);gap:var(--sp-md);flex-wrap:wrap}.page-header h1{margin-bottom:.25rem}.page-description{color:var(--text-sub);margin:0;font-size:.9375rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--sp-lg);flex-wrap:wrap;gap:var(--sp-sm)}.section-header h2{margin:0}.count-badge{background:var(--bg);color:var(--text-sub);padding:.35rem .875rem;border-radius:999px;font-size:.8125rem;font-weight:600;border:1px solid var(--border-solid);white-space:nowrap}.text-center{text-align:center}.text-right{text-align:right}.mt-sm{margin-top:var(--sp-sm)}.mt-md{margin-top:var(--sp-md)}.mt-lg{margin-top:var(--sp-lg)}.mb-sm{margin-bottom:var(--sp-sm)}.mb-md{margin-bottom:var(--sp-md)}.mb-lg{margin-bottom:var(--sp-lg)}@media (max-width: 1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}.page-container{padding:var(--sp-lg)}}@media (max-width: 768px){.page-container{padding:var(--sp-md);padding-top:calc(var(--sp-md) + 58px)}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.page-header{flex-direction:column;margin-bottom:var(--sp-lg)}.card{padding:var(--sp-md)}.page-header .btn{width:100%;justify-content:center}.table-container{border-radius:var(--radius)}}@media (max-width: 480px){.page-container{padding:.75rem;padding-top:calc(.75rem + 58px)}.card{padding:.875rem;border-radius:var(--radius)}.empty-state{padding:var(--sp-xl) var(--sp-sm)}.empty-state-icon{font-size:2.5rem}.section-header{flex-direction:column;align-items:flex-start}.count-badge{font-size:.75rem;padding:.25rem .625rem}.alert{padding:.75rem;font-size:.8125rem}}@media (max-width: 360px){.page-container{padding:.5rem;padding-top:calc(.5rem + 58px)}.btn{padding:.5rem .875rem;font-size:.8125rem}.card{padding:.75rem}h1{font-size:1.25rem}h2{font-size:1.05rem}}@supports (padding: max(0px)){.app-container{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.page-container{padding-left:max(var(--sp-xl),env(safe-area-inset-left));padding-right:max(var(--sp-xl),env(safe-area-inset-right))}@media (max-width: 768px){.page-container{padding-left:max(var(--sp-md),env(safe-area-inset-left));padding-right:max(var(--sp-md),env(safe-area-inset-right))}}@media (max-width: 480px){.page-container{padding-left:max(.75rem,env(safe-area-inset-left));padding-right:max(.75rem,env(safe-area-inset-right))}}}
