*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;scrollbar-gutter:stable}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;overflow-x:clip;letter-spacing:-.011em;position:relative}body:before{content:"";position:fixed;inset:0;pointer-events:none;opacity:.35;background-image:linear-gradient(to right,var(--border) 1px,transparent 1px),linear-gradient(to bottom,var(--border) 1px,transparent 1px);background-size:56px 56px;mask-image:radial-gradient(ellipse at center top,black 0%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse at center top,black 0%,transparent 70%);z-index:-1}:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:4px}input:focus-visible,textarea:focus-visible,select:focus-visible{outline:none}.screen{width:100%;min-height:100vh}#loading-screen{display:flex;align-items:stretch}@keyframes subtle-pulse{0%,to{opacity:.55}50%{opacity:.85}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.skeleton-layout{display:flex;width:100%;min-height:100vh}.skeleton-sidebar{width:var(--sidebar-w);min-height:100vh;border-right:1px solid var(--border);padding-top:24px;background:var(--card-bg);flex-shrink:0}.skeleton-main{flex:1;padding:32px 40px}.skeleton-avatar{width:56px;height:56px;border-radius:50%;margin:0 auto 8px;background:var(--bg-alt);animation:subtle-pulse 1.8s ease-in-out infinite}.skeleton-line{background:var(--bg-alt);animation:subtle-pulse 1.8s ease-in-out infinite;border-radius:var(--radius-sm);height:12px;margin-bottom:8px}.skeleton-greeting{text-align:center;padding:12px 20px 6px;font-size:15px;font-weight:600;color:var(--text-primary, #2D2622)}.skeleton-line-short{width:50%;height:10px;margin:0 auto 24px}.skeleton-line-nav{width:80%;height:36px;margin:0 20px 8px;border-radius:6px}.skeleton-welcome{font-size:18px;font-weight:600;color:var(--text-primary, #2D2622);margin-bottom:8px}.skeleton-loading-copy{font-size:13px;color:var(--text-secondary, #8A817C);margin-bottom:24px}.skeleton-main>.skeleton-card{background:var(--bg-alt);animation:subtle-pulse 1.8s ease-in-out infinite;border-radius:var(--radius);height:140px;margin-bottom:16px}@media(max-width:768px){.skeleton-sidebar{display:none}.skeleton-main{padding:16px}}.loader{width:48px;height:48px;border:3px solid rgba(255,86,48,.15);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}.animate-on-scroll{opacity:0;transform:translateY(16px)}.animate-on-scroll.visible{animation:fadeInUp .5s cubic-bezier(.22,1,.36,1) forwards}.animate-on-scroll.visible.delay-1{animation-delay:.1s}.animate-on-scroll.visible.delay-2{animation-delay:.2s}.animate-on-scroll.visible.delay-3{animation-delay:.3s}.error-content,.expired-content{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:32px;text-align:center;min-height:100vh}.error-icon,.expired-icon{margin-bottom:24px}.error-content h1,.expired-content h1{font-family:inherit;font-size:28px;margin-bottom:12px;color:var(--secondary)}.error-content p,.expired-content p{color:var(--text-muted);margin-bottom:32px;line-height:1.6}.error-link{color:var(--primary);font-weight:600}
