@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";.toast-container{position:fixed;top:80px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:.5rem;pointer-events:none}.toast{display:flex;align-items:center;gap:.6rem;padding:.8rem 1.2rem;border-radius:10px;background:#121216f2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);color:#fff;font-size:.9rem;min-width:280px;max-width:400px;box-shadow:0 8px 24px #0006;animation:toastSlideIn .3s ease,toastFadeOut .3s ease 2.7s forwards;pointer-events:all}.toast-success{border-left:3px solid #22c55e}.toast-error{border-left:3px solid #ef4444}.toast-warning{border-left:3px solid #f59e0b}.toast-info{border-left:3px solid #fcd34d}.toast-success .toast-icon{color:#22c55e}.toast-error .toast-icon{color:#ef4444}.toast-warning .toast-icon{color:#f59e0b}.toast-info .toast-icon{color:#fcd34d}.toast-icon{display:flex;align-items:center;flex-shrink:0}.toast-message{flex:1}.toast-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;display:flex;align-items:center;flex-shrink:0;transition:color .2s}.toast-close:hover{color:#fff}@keyframes toastSlideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes toastFadeOut{0%{opacity:1}to{opacity:0;transform:translate(50px)}}.navbar{position:sticky;top:0;z-index:100;background:var(--navbar-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-light);padding:0}.navbar-container{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:0 2rem;height:60px}.navbar-brand{display:flex;align-items:center;gap:.75rem;font-weight:700;font-size:1.25rem;letter-spacing:-.5px;color:var(--text-primary);transition:all .3s ease;flex-shrink:0}.navbar-brand:hover{color:var(--accent-light)}.brand-icon{color:var(--accent-light);transition:transform .3s ease}.navbar-brand:hover .brand-icon{transform:rotate(12deg) scale(1.1)}.navbar-links{display:flex;align-items:center;gap:.5rem;flex:1;margin:0 2rem}.navbar-actions-right{display:flex;align-items:center;gap:1rem;flex-shrink:0}.nav-btn{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.85rem;font-weight:500;padding:.45rem .75rem;border-radius:8px;transition:all .25s cubic-bezier(.4,0,.2,1);text-decoration:none;position:relative;white-space:nowrap}.nav-btn:hover{color:var(--text-primary);background-color:#fde68a0f}.nav-btn.active{color:var(--accent-light);background-color:#fde68a14}.nav-btn.active:after{content:"";position:absolute;bottom:-1px;left:50%;transform:translate(-50%);width:20px;height:2px;background:var(--gradient-primary);border-radius:1px}.nav-create-btn{background:var(--gradient-primary);background-size:200% 200%;color:var(--btn-text);padding:.4rem .8rem;border:none;font-weight:600;animation:gradient-shift 3s ease infinite}.nav-create-btn:hover{box-shadow:0 4px 16px #fde68a33;transform:translateY(-1px);color:var(--btn-text)}.navbar-user-profile{display:flex;align-items:center;gap:.75rem;padding:.25rem .5rem .25rem .25rem;border-radius:100px;position:relative;cursor:pointer;transition:all .25s ease}.navbar-user-profile:hover{background:#fde68a0f}.profile-dropdown{position:absolute;top:110%;right:0;width:160px;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:10px;padding:.5rem;box-shadow:0 8px 32px #0009;animation:dropdownFade .2s ease-out forwards}@keyframes dropdownFade{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.55rem .75rem;background:transparent;border:none;color:var(--text-secondary);font-size:.85rem;font-weight:500;text-align:left;border-radius:6px;cursor:pointer;transition:all .2s;font-family:inherit}.dropdown-item:hover{background:#fde68a0f;color:var(--text-primary)}.text-danger:hover{background:#ef44441a;color:#ef4444}.user-avatar-small{width:30px;height:30px;border-radius:50%;background:var(--gradient-subtle);border:1px solid var(--border-light);color:var(--accent-light);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.8rem;transition:all .3s ease;flex-shrink:0}.navbar-user-profile:hover .user-avatar-small{border-color:var(--border-glow);box-shadow:0 0 12px var(--accent-glow)}.navbar-welcome{display:flex;flex-direction:column;gap:0}.user-name{color:var(--text-primary);font-size:.8rem;font-weight:500}.role-badge{font-size:.65rem;color:var(--accent-light);text-transform:uppercase;letter-spacing:.5px}.hamburger-btn{display:none;align-items:center;justify-content:center;width:38px;height:38px;border-radius:8px;border:1px solid var(--border-light);background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.hamburger-btn:hover{color:var(--accent-light);border-color:var(--border-glow)}.mobile-menu{display:none;border-top:1px solid var(--border-light);padding:.75rem 1.5rem 1rem;animation:menuSlideDown .25s ease-out}@keyframes menuSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.mobile-nav-links{display:flex;flex-direction:column;gap:.25rem}.mobile-nav-links .nav-btn{width:100%;padding:.65rem .75rem;font-size:.9rem;border-radius:8px}.mobile-nav-links .nav-btn.active:after{display:none}.mobile-nav-links .nav-btn.active{background:var(--gradient-subtle);border-left:3px solid var(--accent-sun)}.mobile-menu-footer{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-light)}.mobile-user-section{display:flex;flex-direction:column;gap:.5rem}.mobile-user-info{display:flex;align-items:center;gap:.75rem;padding:.5rem 0}.mobile-user-info .user-name,.mobile-user-info .role-badge{display:block}.mobile-only{display:none}@media (max-width: 1100px){.navbar-container{padding:0 1.5rem}.navbar-links{margin:0 1rem;gap:.25rem}.nav-btn{font-size:.8rem;padding:.4rem .6rem}.navbar-welcome{display:none}}@media (max-width: 900px){.desktop-only{display:none!important}.mobile-only{display:flex!important}.hamburger-btn{display:flex}.mobile-menu{display:flex;flex-direction:column}.navbar-container{padding:0 1rem;height:56px}.navbar-brand{font-size:1.1rem}}@media (max-width: 480px){.navbar-container{padding:0 .75rem;height:50px}.navbar-brand{font-size:1rem;gap:.5rem}.navbar-brand .brand-icon{width:20px;height:20px}.theme-toggle-btn{width:32px;height:32px}.hamburger-btn{width:34px;height:34px}.mobile-menu{padding:.5rem 1rem}}.theme-selector{position:relative}.theme-toggle-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid var(--border-light);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:all .25s ease}.theme-toggle-btn:hover{color:var(--accent-light);border-color:var(--border-glow);background:var(--bg-tertiary)}.theme-dropdown{position:absolute;top:110%;right:0;width:220px;padding:.5rem;box-shadow:0 8px 32px #00000080;animation:dropdownFade .2s ease-out forwards;z-index:200;max-height:70vh;overflow-y:auto}.theme-dropdown-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:.4rem .6rem .3rem;font-weight:600}.theme-option{display:flex;align-items:center;gap:.6rem;width:100%;padding:.5rem .6rem;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .2s;text-align:left;color:var(--text-secondary);font-family:inherit}.theme-option:hover{background:var(--bg-tertiary);color:var(--text-primary)}.theme-option.active{background:var(--gradient-subtle);color:var(--text-primary)}.theme-option-icon{font-size:1.1rem;flex-shrink:0}.theme-option-info{display:flex;flex-direction:column;gap:0;flex:1;min-width:0}.theme-option-label{font-size:.85rem;font-weight:500;color:inherit}.theme-option-desc{font-size:.7rem;color:var(--text-muted)}.theme-check{color:var(--accent-light);font-weight:700;font-size:.9rem;flex-shrink:0}.project-card-link{text-decoration:none;color:inherit;display:block}.project-card{padding:1.5rem;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;gap:1rem;height:100%;position:relative;overflow:hidden;animation:fadeInUp .5s ease backwards}.project-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:2px;background:linear-gradient(90deg,#fcd34d,#fde68a,#fdba74);background-size:200% 100%;opacity:0;transition:opacity .4s ease;animation:shimmer 2s linear infinite}.project-card:after{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(253,230,138,.04) 0%,transparent 70%);opacity:0;transition:opacity .4s ease;pointer-events:none}.project-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px -12px #fde68a1a,0 0 0 1px #fde68a14;border-color:#fde68a26}.project-card:hover:before{opacity:1}.project-card:hover:after{opacity:1}.project-header{display:flex;justify-content:space-between;align-items:center;font-size:.85rem}.project-category{color:var(--accent-light);font-weight:600;letter-spacing:.5px;text-transform:uppercase;font-size:.75rem}.project-date{color:var(--text-muted)}.project-title{font-size:1.4rem;font-weight:600;line-height:1.3;margin:.25rem 0;transition:color .3s ease}.project-card:hover .project-title{color:var(--accent-cream)}.project-excerpt{color:var(--text-secondary);font-size:.95rem;line-height:1.6;flex-grow:1}.project-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:1rem;border-top:1px solid var(--border-light)}.project-author{display:flex;align-items:center;gap:.75rem}.author-avatar{width:30px;height:30px;border-radius:50%;background:var(--gradient-subtle);color:var(--accent-light);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;border:1px solid rgba(253,230,138,.15)}.author-name{font-size:.9rem;color:var(--text-secondary);font-weight:500}.project-keywords{display:flex;gap:.5rem}.keyword-tag{background:#fde68a12;color:var(--accent-light);font-size:.75rem;padding:.2rem .6rem;border-radius:100px;border:1px solid rgba(253,230,138,.1);transition:all .2s ease}.keyword-tag:hover{background:#fde68a1f;border-color:#fde68a33}.projects-grid .project-card-link:nth-child(1) .project-card{animation-delay:0s}.projects-grid .project-card-link:nth-child(2) .project-card{animation-delay:.1s}.projects-grid .project-card-link:nth-child(3) .project-card{animation-delay:.2s}.projects-grid .project-card-link:nth-child(4) .project-card{animation-delay:.3s}.projects-grid .project-card-link:nth-child(5) .project-card{animation-delay:.4s}.projects-grid .project-card-link:nth-child(6) .project-card{animation-delay:.5s}.home-container{max-width:1200px;margin:0 auto;padding:2rem;overflow-x:hidden}.hero-section{padding:6rem 0 4rem;text-align:center;position:relative;animation:fadeIn .8s ease;overflow:hidden}.hero-section:before{content:"";position:absolute;top:-50%;left:50%;transform:translate(-50%);width:600px;height:600px;background:radial-gradient(circle,rgba(253,230,138,.06) 0%,rgba(253,186,116,.03) 40%,transparent 70%);pointer-events:none;z-index:0}.hero-title{font-size:4.5rem;font-weight:800;letter-spacing:-2px;line-height:1.1;margin-bottom:1rem;position:relative;z-index:1;background:linear-gradient(135deg,#f5f3ef,#fde68a,#fcd34d,#f5f3ef);background-size:300% 300%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:gradient-shift 6s ease infinite}.hero-subtitle{font-size:1.25rem;color:var(--text-secondary);max-width:600px;margin:0 auto;position:relative;z-index:1;animation:fadeInUp .8s ease .2s backwards}.section-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:2.5rem;animation:slideInLeft .5s ease}.section-title{font-size:2rem;font-weight:600;color:var(--text-primary);white-space:nowrap}.section-line{height:1px;flex-grow:1;background:linear-gradient(90deg,rgba(253,230,138,.2),transparent)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem}.loading-state,.error-state,.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-secondary);animation:fadeIn .5s ease}.error-state{border-color:#ef44444d;color:#fca5a5}.stats-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1rem;margin-bottom:3rem;max-width:800px;margin-left:auto;margin-right:auto}.stat-card{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:1.4rem .8rem;text-align:center;transition:all .35s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--gradient-subtle);opacity:0;transition:opacity .35s ease;border-radius:inherit}.stat-card:hover{transform:translateY(-4px);border-color:#fde68a2e;box-shadow:0 8px 24px #fde68a14}.stat-card:hover:before{opacity:1}.stat-value{font-size:1.6rem;font-weight:700;color:var(--text-primary);position:relative;z-index:1}.stat-label{font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;position:relative;z-index:1}.stat-highlight{border-color:#fde68a26;text-decoration:none}.stat-highlight:hover{border-color:#fde68a4d;box-shadow:0 8px 24px #fde68a14}.stats-grid .stat-card:nth-child(1){animation:fadeInUp .5s ease 0s backwards}.stats-grid .stat-card:nth-child(2){animation:fadeInUp .5s ease .05s backwards}.stats-grid .stat-card:nth-child(3){animation:fadeInUp .5s ease .1s backwards}.stats-grid .stat-card:nth-child(4){animation:fadeInUp .5s ease .15s backwards}.stats-grid .stat-card:nth-child(5){animation:fadeInUp .5s ease .2s backwards}.stats-grid .stat-card:nth-child(6){animation:fadeInUp .5s ease .25s backwards}@media (max-width: 1024px){.home-container{padding:1.5rem}.hero-title{font-size:3.5rem}.hero-section{padding:4rem 0 3rem}}@media (max-width: 768px){.home-container{padding:1rem}.hero-title{font-size:2.5rem;letter-spacing:-1px}.hero-subtitle{font-size:1rem}.hero-section{padding:3rem 0 2rem}.stats-grid{grid-template-columns:repeat(3,1fr);gap:.75rem}.stat-card{padding:1rem .5rem}.stat-value{font-size:1.3rem}.stat-label{font-size:.7rem}.projects-grid{grid-template-columns:1fr;gap:1.5rem}.section-title{font-size:1.5rem}}@media (max-width: 480px){.home-container{padding:.5rem}.hero-title{font-size:2rem}.hero-subtitle{font-size:.9rem}.hero-section{padding:2rem 0 1.5rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}.stat-card{padding:.75rem .5rem}.stat-value{font-size:1.2rem}.section-header{gap:.75rem;margin-bottom:1.5rem}.section-title{font-size:1.25rem}}.component-tooltip-wrapper{position:relative;display:inline-block}.component-highlight{position:relative;cursor:help;color:var(--accent-primary);font-weight:600;text-shadow:0 0 8px rgba(253,230,138,.2);border-bottom:1px dashed var(--accent-primary);transition:all .2s}.component-highlight:hover{color:var(--accent-secondary);border-bottom-color:var(--accent-secondary)}.component-tooltip{visibility:hidden;opacity:0;position:absolute;bottom:120%;left:50%;transform:translate(-50%) translateY(10px);width:max-content;max-width:280px;background:var(--bg-primary);border:1px solid var(--border-light);border-radius:8px;padding:1rem;z-index:100;text-align:left;box-shadow:0 10px 25px #00000080;transition:all .2s cubic-bezier(.175,.885,.32,1.275)}.component-tooltip-wrapper:hover .component-tooltip{visibility:visible;opacity:1;transform:translate(-50%) translateY(0)}.tooltip-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.5rem;border-bottom:1px solid var(--border-light);padding-bottom:.5rem}.tooltip-header strong{color:var(--text-primary);font-size:1.05rem}.tooltip-tier{background:var(--accent-primary);color:#fff;padding:.2rem .6rem;border-radius:12px;font-size:.75rem;font-weight:600;white-space:nowrap}.tooltip-body p{margin:.25rem 0!important;font-size:.85rem;line-height:1.4;color:var(--text-secondary)}.tooltip-source{margin-top:.5rem!important;font-size:.75rem!important;color:var(--text-muted)!important;font-style:italic}.project-details-container{max-width:750px;margin:4rem auto;padding:3rem 2rem}.center-state{display:flex;flex-direction:column;justify-content:center;align-items:center;height:60vh;color:var(--text-secondary)}.error-case{color:#fca5a5}.back-link{color:var(--text-secondary);text-decoration:none;font-weight:500;display:inline-block;margin-bottom:2rem;transition:color .2s}.details-header{border-bottom:1px solid var(--border-light);padding-bottom:2rem;margin-bottom:2.5rem}.details-meta{display:flex;justify-content:space-between;margin-bottom:1rem}.details-category{color:var(--accent-light, #fde68a);text-transform:uppercase;letter-spacing:1px;font-weight:600;font-size:.8rem}.details-date{color:var(--text-muted);font-size:.9rem}.details-title{font-size:2.5rem;font-weight:700;line-height:1.1;letter-spacing:-1px;margin-bottom:2rem;color:var(--text-primary)}.details-author-strip{display:flex;align-items:center;gap:1rem}.author-avatar-large{width:40px;height:40px;border-radius:50%;background:var(--gradient-subtle);border:1px solid rgba(253,230,138,.15);color:var(--accent-light, #fde68a);display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:600}.author-name-large{font-size:1.1rem;color:var(--text-primary);font-weight:600}.author-role{font-size:.85rem;color:var(--text-muted)}.details-content{font-size:1.05rem;line-height:1.7;color:var(--text-secondary)}.details-content p{margin-bottom:1.5rem}.details-footer{margin-top:4rem;padding-top:2rem;border-top:1px solid var(--border-light);display:flex;align-items:center;gap:1.5rem}.tags-label{color:var(--text-secondary);font-weight:500}.details-keywords{display:flex;flex-wrap:wrap;gap:.5rem}@media (max-width: 768px){.project-details-container{margin:2rem 1rem;padding:1.5rem}.details-title{font-size:2rem}}@media (max-width: 480px){.project-details-container{margin:1rem .5rem;padding:1rem;overflow-x:hidden}.details-title{font-size:1.5rem}.details-meta{flex-direction:column;gap:.25rem}.details-footer{flex-direction:column;align-items:flex-start;gap:.75rem}.component-title{font-size:1.8rem}}.rendered-html-content{line-height:1.8;color:var(--text-primary)}.rendered-html-content h1,.rendered-html-content h2,.rendered-html-content h3{color:#fff;margin-top:2rem;margin-bottom:1rem;font-weight:700}.rendered-html-content h1{font-size:2rem}.rendered-html-content h2{font-size:1.6rem}.rendered-html-content h3{font-size:1.3rem}.rendered-html-content p{margin-bottom:1rem}.rendered-html-content a{color:var(--accent-primary);text-decoration:underline}.rendered-html-content strong{color:#fff;font-weight:700}.rendered-html-content em{font-style:italic}.rendered-html-content ul,.rendered-html-content ol{padding-left:2rem;margin-bottom:1rem}.rendered-html-content li{margin-bottom:.4rem}.rendered-html-content blockquote{border-left:3px solid var(--accent-primary);padding-left:1.2rem;margin:1.5rem 0;color:var(--text-secondary);font-style:italic}.rendered-html-content pre{background:var(--bg-primary);color:var(--text-secondary);border-radius:8px;padding:1.2rem;font-family:Fira Code,Consolas,monospace;font-size:.9rem;overflow-x:auto;margin:1.5rem 0;border:1px solid var(--border-light)}.rendered-html-content code{background:#ffffff0f;padding:.15rem .4rem;border-radius:4px;font-family:Fira Code,Consolas,monospace;font-size:.9em}.rendered-html-content pre code{background:none;padding:0}.rendered-html-content img{max-width:100%;border-radius:8px;margin:1.5rem 0}.rendered-html-content hr{border:none;border-top:1px solid var(--border-light);margin:2rem 0}.auth-container{min-height:calc(100vh - 120px);display:flex;align-items:center;justify-content:center;padding:2rem}.auth-card{width:100%;max-width:420px;padding:3rem 2.5rem;text-align:center}.auth-card h2{font-size:2.5rem;margin-bottom:.5rem}.auth-subtitle{color:var(--text-secondary);margin-bottom:2rem}.auth-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:.75rem;border-radius:8px;margin-bottom:1.5rem;font-size:.9rem}.auth-form{display:flex;flex-direction:column;gap:1.5rem;text-align:left}.form-input{width:100%;padding:.8rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:6px;color:var(--text-primary);font-family:inherit;font-size:1rem;transition:all .2s}.form-input:focus{outline:none;border-color:var(--border-focus)}.auth-submit-btn{background:var(--gradient-primary);background-size:200% 200%;animation:gradient-shift 3s ease infinite;color:var(--btn-text);border:none;padding:1rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);margin-top:.5rem;font-family:inherit}.auth-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #fde68a33}.auth-submit-btn:disabled{opacity:.7;cursor:not-allowed}.auth-footer{margin-top:2rem;color:var(--text-muted);font-size:.9rem}.auth-footer a{color:var(--accent-light, #fde68a);text-decoration:none;font-weight:500;transition:color .2s}.auth-footer a:hover{text-decoration:underline}.dashboard-container{max-width:1200px;margin:0 auto;padding:2rem;overflow-x:hidden}.dashboard-welcome{margin-bottom:1.5rem}.create-btn{display:flex;align-items:center;gap:.5rem;background:var(--accent-primary);color:#fff;text-decoration:none;padding:.75rem 1.5rem;border-radius:100px;font-weight:600;transition:all .2s}.create-btn:hover{background:var(--accent-secondary);box-shadow:0 4px 12px var(--accent-glow);transform:translateY(-2px)}.dashboard-grid{display:grid;grid-template-columns:240px 1fr;gap:2rem;align-items:flex-start}.guest-view{grid-template-columns:1fr}.dashboard-sidebar{padding:2rem;height:fit-content}.sidebar-title{font-size:1.1rem;color:var(--text-secondary);margin-bottom:1.5rem;text-transform:uppercase;letter-spacing:1px}.sidebar-nav{list-style:none;display:flex;flex-direction:column;gap:.5rem}.sidebar-nav li{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s;font-size:.9rem;font-weight:500}.sidebar-nav li:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sidebar-nav li.active{background:var(--text-primary);color:var(--bg-primary)}.dashboard-content{padding:2rem}.content-title{font-size:1.25rem;font-weight:600}.dashboard-header-flex{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border-light)}.search-create-row{display:flex;gap:1rem;align-items:center}.search-box{display:flex;align-items:center;background:var(--bg-primary);border:1px solid var(--border-light);border-radius:6px;padding:.4rem .8rem;flex:1;min-width:150px;max-width:300px;transition:border-color .2s ease}.search-box:focus-within{border-color:var(--border-focus)}.search-icon{color:var(--text-muted);margin-right:.5rem}.search-box input{background:transparent;border:none;color:var(--text-primary);font-family:inherit;font-size:.85rem;width:100%;outline:none}.search-box input::placeholder{color:var(--text-muted)}.project-list{display:flex;flex-direction:column;gap:0;border:1px solid var(--border-light);border-radius:6px;overflow:hidden}.project-list-item{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;background:transparent;border-bottom:1px solid var(--border-light);transition:background .2s}.project-list-item:last-child{border-bottom:none}.project-list-item:hover{background:var(--bg-tertiary)}.item-info{display:flex;flex-direction:column;gap:.25rem}.item-category{font-size:.7rem;color:var(--text-secondary);text-transform:uppercase;font-weight:500;letter-spacing:.5px}.item-title{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.item-meta{font-size:.8rem;color:var(--text-muted)}.item-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.view-link{padding:.5rem 1rem;background:#ffffff0d;color:var(--text-primary);text-decoration:none;border-radius:6px;font-size:.9rem;transition:background .2s;white-space:nowrap}.view-link:hover{background:#ffffff1a}.empty-text{color:var(--text-muted);font-style:italic}@media (max-width: 900px){.dashboard-grid{grid-template-columns:1fr}}@media (max-width: 768px){.dashboard-container{padding:1rem}.dashboard-welcome{padding:1.5rem 1rem}}@media (max-width: 600px){.dashboard-header-flex{flex-direction:column;align-items:flex-start;gap:1rem}.search-box{width:100%}.create-btn{padding:.6rem 1rem;font-size:.85rem;white-space:nowrap}}@media (max-width: 480px){.dashboard-container{padding:.5rem}.search-create-row{flex-direction:column;width:100%}.search-box{max-width:100%;width:100%}.create-btn{width:100%;justify-content:center}.project-list-item{flex-direction:column;align-items:flex-start;gap:.75rem;padding:1rem}.item-actions{display:flex;align-items:center;gap:.5rem;align-self:flex-end;flex-direction:row}.view-link{padding:.4rem .75rem;font-size:.8rem;white-space:nowrap}.item-title{font-size:1rem}.item-meta{font-size:.75rem}.welcome-title{font-size:1.2rem}.welcome-subtitle{font-size:.85rem}}.settings-panel{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.settings-info-card{padding:2rem;display:flex;flex-direction:column;gap:1.5rem;max-width:600px}.settings-field{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:1px solid var(--border-light)}.settings-field:last-child{border-bottom:none;padding-bottom:0}.settings-label{color:var(--text-secondary);font-weight:500}.settings-value{color:var(--text-primary);font-weight:600;font-size:1.1rem}.settings-profile-header{display:flex;align-items:center;gap:1.5rem;padding-bottom:2rem;border-bottom:1px solid var(--border-light);margin-bottom:.5rem}.user-avatar-large{width:72px;height:72px;border-radius:50%;background:var(--gradient-subtle);border:1px solid rgba(253,230,138,.15);color:var(--accent-light, #fde68a);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:2rem}.settings-actions{margin-top:1rem;padding-top:1.5rem;border-top:1px solid var(--border-light);display:flex;justify-content:flex-end}/*!
 * Quill Editor v1.3.7
 * https://quilljs.com/
 * Copyright (c) 2014, Jason Chen
 * Copyright (c) 2013, salesforce.com
 */.ql-container{box-sizing:border-box;font-family:Helvetica,Arial,sans-serif;font-size:13px;height:100%;margin:0;position:relative}.ql-container.ql-disabled .ql-tooltip{visibility:hidden}.ql-container.ql-disabled .ql-editor ul[data-checked]>li:before{pointer-events:none}.ql-clipboard{left:-100000px;height:1px;overflow-y:hidden;position:absolute;top:50%}.ql-clipboard p{margin:0;padding:0}.ql-editor{box-sizing:border-box;line-height:1.42;height:100%;outline:none;overflow-y:auto;padding:12px 15px;tab-size:4;-moz-tab-size:4;text-align:left;white-space:pre-wrap;word-wrap:break-word}.ql-editor>*{cursor:text}.ql-editor p,.ql-editor ol,.ql-editor ul,.ql-editor pre,.ql-editor blockquote,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{margin:0;padding:0;counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol,.ql-editor ul{padding-left:1.5em}.ql-editor ol>li,.ql-editor ul>li{list-style-type:none}.ql-editor ul>li:before{content:"•"}.ql-editor ul[data-checked=true],.ql-editor ul[data-checked=false]{pointer-events:none}.ql-editor ul[data-checked=true]>li *,.ql-editor ul[data-checked=false]>li *{pointer-events:all}.ql-editor ul[data-checked=true]>li:before,.ql-editor ul[data-checked=false]>li:before{color:#777;cursor:pointer;pointer-events:all}.ql-editor ul[data-checked=true]>li:before{content:"☑"}.ql-editor ul[data-checked=false]>li:before{content:"☐"}.ql-editor li:before{display:inline-block;white-space:nowrap;width:1.2em}.ql-editor li:not(.ql-direction-rtl):before{margin-left:-1.5em;margin-right:.3em;text-align:right}.ql-editor li.ql-direction-rtl:before{margin-left:.3em;margin-right:-1.5em}.ql-editor ol li:not(.ql-direction-rtl),.ql-editor ul li:not(.ql-direction-rtl){padding-left:1.5em}.ql-editor ol li.ql-direction-rtl,.ql-editor ul li.ql-direction-rtl{padding-right:1.5em}.ql-editor ol li{counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9;counter-increment:list-0}.ql-editor ol li:before{content:counter(list-0,decimal) ". "}.ql-editor ol li.ql-indent-1{counter-increment:list-1}.ql-editor ol li.ql-indent-1:before{content:counter(list-1,lower-alpha) ". "}.ql-editor ol li.ql-indent-1{counter-reset:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-2{counter-increment:list-2}.ql-editor ol li.ql-indent-2:before{content:counter(list-2,lower-roman) ". "}.ql-editor ol li.ql-indent-2{counter-reset:list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-3{counter-increment:list-3}.ql-editor ol li.ql-indent-3:before{content:counter(list-3,decimal) ". "}.ql-editor ol li.ql-indent-3{counter-reset:list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-4{counter-increment:list-4}.ql-editor ol li.ql-indent-4:before{content:counter(list-4,lower-alpha) ". "}.ql-editor ol li.ql-indent-4{counter-reset:list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-5{counter-increment:list-5}.ql-editor ol li.ql-indent-5:before{content:counter(list-5,lower-roman) ". "}.ql-editor ol li.ql-indent-5{counter-reset:list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-6{counter-increment:list-6}.ql-editor ol li.ql-indent-6:before{content:counter(list-6,decimal) ". "}.ql-editor ol li.ql-indent-6{counter-reset:list-7 list-8 list-9}.ql-editor ol li.ql-indent-7{counter-increment:list-7}.ql-editor ol li.ql-indent-7:before{content:counter(list-7,lower-alpha) ". "}.ql-editor ol li.ql-indent-7{counter-reset:list-8 list-9}.ql-editor ol li.ql-indent-8{counter-increment:list-8}.ql-editor ol li.ql-indent-8:before{content:counter(list-8,lower-roman) ". "}.ql-editor ol li.ql-indent-8{counter-reset:list-9}.ql-editor ol li.ql-indent-9{counter-increment:list-9}.ql-editor ol li.ql-indent-9:before{content:counter(list-9,decimal) ". "}.ql-editor .ql-indent-1:not(.ql-direction-rtl){padding-left:3em}.ql-editor li.ql-indent-1:not(.ql-direction-rtl){padding-left:4.5em}.ql-editor .ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:3em}.ql-editor li.ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:4.5em}.ql-editor .ql-indent-2:not(.ql-direction-rtl){padding-left:6em}.ql-editor li.ql-indent-2:not(.ql-direction-rtl){padding-left:7.5em}.ql-editor .ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:6em}.ql-editor li.ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:7.5em}.ql-editor .ql-indent-3:not(.ql-direction-rtl){padding-left:9em}.ql-editor li.ql-indent-3:not(.ql-direction-rtl){padding-left:10.5em}.ql-editor .ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:9em}.ql-editor li.ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:10.5em}.ql-editor .ql-indent-4:not(.ql-direction-rtl){padding-left:12em}.ql-editor li.ql-indent-4:not(.ql-direction-rtl){padding-left:13.5em}.ql-editor .ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:12em}.ql-editor li.ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:13.5em}.ql-editor .ql-indent-5:not(.ql-direction-rtl){padding-left:15em}.ql-editor li.ql-indent-5:not(.ql-direction-rtl){padding-left:16.5em}.ql-editor .ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:15em}.ql-editor li.ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:16.5em}.ql-editor .ql-indent-6:not(.ql-direction-rtl){padding-left:18em}.ql-editor li.ql-indent-6:not(.ql-direction-rtl){padding-left:19.5em}.ql-editor .ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:18em}.ql-editor li.ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:19.5em}.ql-editor .ql-indent-7:not(.ql-direction-rtl){padding-left:21em}.ql-editor li.ql-indent-7:not(.ql-direction-rtl){padding-left:22.5em}.ql-editor .ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:21em}.ql-editor li.ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:22.5em}.ql-editor .ql-indent-8:not(.ql-direction-rtl){padding-left:24em}.ql-editor li.ql-indent-8:not(.ql-direction-rtl){padding-left:25.5em}.ql-editor .ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:24em}.ql-editor li.ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:25.5em}.ql-editor .ql-indent-9:not(.ql-direction-rtl){padding-left:27em}.ql-editor li.ql-indent-9:not(.ql-direction-rtl){padding-left:28.5em}.ql-editor .ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:27em}.ql-editor li.ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:28.5em}.ql-editor .ql-video{display:block;max-width:100%}.ql-editor .ql-video.ql-align-center{margin:0 auto}.ql-editor .ql-video.ql-align-right{margin:0 0 0 auto}.ql-editor .ql-bg-black{background-color:#000}.ql-editor .ql-bg-red{background-color:#e60000}.ql-editor .ql-bg-orange{background-color:#f90}.ql-editor .ql-bg-yellow{background-color:#ff0}.ql-editor .ql-bg-green{background-color:#008a00}.ql-editor .ql-bg-blue{background-color:#06c}.ql-editor .ql-bg-purple{background-color:#93f}.ql-editor .ql-color-white{color:#fff}.ql-editor .ql-color-red{color:#e60000}.ql-editor .ql-color-orange{color:#f90}.ql-editor .ql-color-yellow{color:#ff0}.ql-editor .ql-color-green{color:#008a00}.ql-editor .ql-color-blue{color:#06c}.ql-editor .ql-color-purple{color:#93f}.ql-editor .ql-font-serif{font-family:Georgia,Times New Roman,serif}.ql-editor .ql-font-monospace{font-family:Monaco,Courier New,monospace}.ql-editor .ql-size-small{font-size:.75em}.ql-editor .ql-size-large{font-size:1.5em}.ql-editor .ql-size-huge{font-size:2.5em}.ql-editor .ql-direction-rtl{direction:rtl;text-align:inherit}.ql-editor .ql-align-center{text-align:center}.ql-editor .ql-align-justify{text-align:justify}.ql-editor .ql-align-right{text-align:right}.ql-editor.ql-blank:before{color:#0009;content:attr(data-placeholder);font-style:italic;left:15px;pointer-events:none;position:absolute;right:15px}.ql-snow.ql-toolbar:after,.ql-snow .ql-toolbar:after{clear:both;content:"";display:table}.ql-snow.ql-toolbar button,.ql-snow .ql-toolbar button{background:none;border:none;cursor:pointer;display:inline-block;float:left;height:24px;padding:3px 5px;width:28px}.ql-snow.ql-toolbar button svg,.ql-snow .ql-toolbar button svg{float:left;height:100%}.ql-snow.ql-toolbar button:active:hover,.ql-snow .ql-toolbar button:active:hover{outline:none}.ql-snow.ql-toolbar input.ql-image[type=file],.ql-snow .ql-toolbar input.ql-image[type=file]{display:none}.ql-snow.ql-toolbar button:hover,.ql-snow .ql-toolbar button:hover,.ql-snow.ql-toolbar button:focus,.ql-snow .ql-toolbar button:focus,.ql-snow.ql-toolbar button.ql-active,.ql-snow .ql-toolbar button.ql-active,.ql-snow.ql-toolbar .ql-picker-label:hover,.ql-snow .ql-toolbar .ql-picker-label:hover,.ql-snow.ql-toolbar .ql-picker-label.ql-active,.ql-snow .ql-toolbar .ql-picker-label.ql-active,.ql-snow.ql-toolbar .ql-picker-item:hover,.ql-snow .ql-toolbar .ql-picker-item:hover,.ql-snow.ql-toolbar .ql-picker-item.ql-selected,.ql-snow .ql-toolbar .ql-picker-item.ql-selected{color:#06c}.ql-snow.ql-toolbar button:hover .ql-fill,.ql-snow .ql-toolbar button:hover .ql-fill,.ql-snow.ql-toolbar button:focus .ql-fill,.ql-snow .ql-toolbar button:focus .ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow.ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill{fill:#06c}.ql-snow.ql-toolbar button:hover .ql-stroke,.ql-snow .ql-toolbar button:hover .ql-stroke,.ql-snow.ql-toolbar button:focus .ql-stroke,.ql-snow .ql-toolbar button:focus .ql-stroke,.ql-snow.ql-toolbar button.ql-active .ql-stroke,.ql-snow .ql-toolbar button.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow.ql-toolbar button:hover .ql-stroke-miter,.ql-snow .ql-toolbar button:hover .ql-stroke-miter,.ql-snow.ql-toolbar button:focus .ql-stroke-miter,.ql-snow .ql-toolbar button:focus .ql-stroke-miter,.ql-snow.ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter{stroke:#06c}@media (pointer: coarse){.ql-snow.ql-toolbar button:hover:not(.ql-active),.ql-snow .ql-toolbar button:hover:not(.ql-active){color:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill{fill:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter{stroke:#444}}.ql-snow,.ql-snow *{box-sizing:border-box}.ql-snow .ql-hidden{display:none}.ql-snow .ql-out-bottom,.ql-snow .ql-out-top{visibility:hidden}.ql-snow .ql-tooltip{position:absolute;transform:translateY(10px)}.ql-snow .ql-tooltip a{cursor:pointer;text-decoration:none}.ql-snow .ql-tooltip.ql-flip{transform:translateY(-10px)}.ql-snow .ql-formats{display:inline-block;vertical-align:middle}.ql-snow .ql-formats:after{clear:both;content:"";display:table}.ql-snow .ql-stroke{fill:none;stroke:#444;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.ql-snow .ql-stroke-miter{fill:none;stroke:#444;stroke-miterlimit:10;stroke-width:2}.ql-snow .ql-fill,.ql-snow .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-empty{fill:none}.ql-snow .ql-even{fill-rule:evenodd}.ql-snow .ql-thin,.ql-snow .ql-stroke.ql-thin{stroke-width:1}.ql-snow .ql-transparent{opacity:.4}.ql-snow .ql-direction svg:last-child{display:none}.ql-snow .ql-direction.ql-active svg:last-child{display:inline}.ql-snow .ql-direction.ql-active svg:first-child{display:none}.ql-snow .ql-editor h1{font-size:2em}.ql-snow .ql-editor h2{font-size:1.5em}.ql-snow .ql-editor h3{font-size:1.17em}.ql-snow .ql-editor h4{font-size:1em}.ql-snow .ql-editor h5{font-size:.83em}.ql-snow .ql-editor h6{font-size:.67em}.ql-snow .ql-editor a{text-decoration:underline}.ql-snow .ql-editor blockquote{border-left:4px solid #ccc;margin-bottom:5px;margin-top:5px;padding-left:16px}.ql-snow .ql-editor code,.ql-snow .ql-editor pre{background-color:#f0f0f0;border-radius:3px}.ql-snow .ql-editor pre{white-space:pre-wrap;margin-bottom:5px;margin-top:5px;padding:5px 10px}.ql-snow .ql-editor code{font-size:85%;padding:2px 4px}.ql-snow .ql-editor pre.ql-syntax{background-color:#23241f;color:#f8f8f2;overflow:visible}.ql-snow .ql-editor img{max-width:100%}.ql-snow .ql-picker{color:#444;display:inline-block;float:left;font-size:14px;font-weight:500;height:24px;position:relative;vertical-align:middle}.ql-snow .ql-picker-label{cursor:pointer;display:inline-block;height:100%;padding-left:8px;padding-right:2px;position:relative;width:100%}.ql-snow .ql-picker-label:before{display:inline-block;line-height:22px}.ql-snow .ql-picker-options{background-color:#fff;display:none;min-width:100%;padding:4px 8px;position:absolute;white-space:nowrap}.ql-snow .ql-picker-options .ql-picker-item{cursor:pointer;display:block;padding-bottom:5px;padding-top:5px}.ql-snow .ql-picker.ql-expanded .ql-picker-label{color:#ccc;z-index:2}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-fill{fill:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-stroke{stroke:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-options{display:block;margin-top:-1px;top:100%;z-index:1}.ql-snow .ql-color-picker,.ql-snow .ql-icon-picker{width:28px}.ql-snow .ql-color-picker .ql-picker-label,.ql-snow .ql-icon-picker .ql-picker-label{padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-label svg,.ql-snow .ql-icon-picker .ql-picker-label svg{right:4px}.ql-snow .ql-icon-picker .ql-picker-options{padding:4px 0}.ql-snow .ql-icon-picker .ql-picker-item{height:24px;width:24px;padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-options{padding:3px 5px;width:152px}.ql-snow .ql-color-picker .ql-picker-item{border:1px solid transparent;float:left;height:16px;margin:2px;padding:0;width:16px}.ql-snow .ql-picker:not(.ql-color-picker):not(.ql-icon-picker) svg{position:absolute;margin-top:-9px;right:0;top:50%;width:18px}.ql-snow .ql-picker.ql-header .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-label]:not([data-label=""]):before{content:attr(data-label)}.ql-snow .ql-picker.ql-header{width:98px}.ql-snow .ql-picker.ql-header .ql-picker-label:before,.ql-snow .ql-picker.ql-header .ql-picker-item:before{content:"Normal"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{content:"Heading 1"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{content:"Heading 2"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{content:"Heading 3"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{content:"Heading 4"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{content:"Heading 5"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{content:"Heading 6"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{font-size:2em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{font-size:1.5em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{font-size:1.17em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{font-size:1em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{font-size:.83em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{font-size:.67em}.ql-snow .ql-picker.ql-font{width:108px}.ql-snow .ql-picker.ql-font .ql-picker-label:before,.ql-snow .ql-picker.ql-font .ql-picker-item:before{content:"Sans Serif"}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=serif]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{content:"Serif"}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=monospace]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{content:"Monospace"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{font-family:Georgia,Times New Roman,serif}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{font-family:Monaco,Courier New,monospace}.ql-snow .ql-picker.ql-size{width:98px}.ql-snow .ql-picker.ql-size .ql-picker-label:before,.ql-snow .ql-picker.ql-size .ql-picker-item:before{content:"Normal"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=small]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{content:"Small"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=large]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{content:"Large"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=huge]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{content:"Huge"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{font-size:10px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{font-size:18px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{font-size:32px}.ql-snow .ql-color-picker.ql-background .ql-picker-item{background-color:#fff}.ql-snow .ql-color-picker.ql-color .ql-picker-item{background-color:#000}.ql-toolbar.ql-snow{border:1px solid #ccc;box-sizing:border-box;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;padding:8px}.ql-toolbar.ql-snow .ql-formats{margin-right:15px}.ql-toolbar.ql-snow .ql-picker-label{border:1px solid transparent}.ql-toolbar.ql-snow .ql-picker-options{border:1px solid transparent;box-shadow:#0003 0 2px 8px}.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label,.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options{border-color:#ccc}.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item.ql-selected,.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item:hover{border-color:#000}.ql-toolbar.ql-snow+.ql-container.ql-snow{border-top:0px}.ql-snow .ql-tooltip{background-color:#fff;border:1px solid #ccc;box-shadow:0 0 5px #ddd;color:#444;padding:5px 12px;white-space:nowrap}.ql-snow .ql-tooltip:before{content:"Visit URL:";line-height:26px;margin-right:8px}.ql-snow .ql-tooltip input[type=text]{display:none;border:1px solid #ccc;font-size:13px;height:26px;margin:0;padding:3px 5px;width:170px}.ql-snow .ql-tooltip a.ql-preview{display:inline-block;max-width:200px;overflow-x:hidden;text-overflow:ellipsis;vertical-align:top}.ql-snow .ql-tooltip a.ql-action:after{border-right:1px solid #ccc;content:"Edit";margin-left:16px;padding-right:8px}.ql-snow .ql-tooltip a.ql-remove:before{content:"Remove";margin-left:8px}.ql-snow .ql-tooltip a{line-height:26px}.ql-snow .ql-tooltip.ql-editing a.ql-preview,.ql-snow .ql-tooltip.ql-editing a.ql-remove{display:none}.ql-snow .ql-tooltip.ql-editing input[type=text]{display:inline-block}.ql-snow .ql-tooltip.ql-editing a.ql-action:after{border-right:0px;content:"Save";padding-right:0}.ql-snow .ql-tooltip[data-mode=link]:before{content:"Enter link:"}.ql-snow .ql-tooltip[data-mode=formula]:before{content:"Enter formula:"}.ql-snow .ql-tooltip[data-mode=video]:before{content:"Enter video:"}.ql-snow a{color:#06c}.ql-container.ql-snow{border:1px solid #ccc}.create-container{max-width:800px;margin:4rem auto;padding:0 2rem}.create-card{padding:3rem;border-radius:24px}.create-subtitle{color:var(--text-secondary);margin-top:.5rem;margin-bottom:2.5rem}.create-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:.75rem;border-radius:8px;margin-bottom:1.5rem;font-size:.9rem}.create-form{display:flex;flex-direction:column;gap:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.form-group label{display:block;font-size:.9rem;color:var(--text-secondary);margin-bottom:.5rem;font-weight:500}.form-input{width:100%;padding:.8rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:8px;color:var(--text-primary);font-family:inherit;font-size:1rem;transition:all .2s}.form-textarea{resize:vertical;min-height:150px;font-family:monospace}.form-input:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 2px var(--accent-glow)}.upload-group{margin-top:1rem}.file-input-wrapper{position:relative;overflow:hidden;display:inline-block;width:100%}.hidden-file-input{position:absolute;left:0;top:0;opacity:0;width:100%;height:100%;cursor:pointer}.file-label{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:var(--bg-tertiary);border:2px dashed var(--border-light);padding:2rem;border-radius:12px;color:var(--text-secondary);cursor:pointer;transition:all .2s;text-align:center}.file-input-wrapper:hover .file-label{border-color:var(--accent-warm);background:#fde68a0a}.upload-help{font-size:.8rem;color:var(--text-muted);margin-top:.75rem}.create-submit-btn{background:var(--gradient-primary);background-size:200% 200%;animation:gradient-shift 3s ease infinite;color:var(--btn-text);border:none;padding:1rem;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:1rem;font-family:inherit;width:100%}.create-submit-btn:hover:not(:disabled){background:var(--accent-secondary);box-shadow:0 4px 12px var(--accent-glow)}.create-submit-btn:disabled{opacity:.7;cursor:not-allowed}@media (max-width: 768px){.form-row{grid-template-columns:1fr}.create-card{padding:2rem}}@media (max-width: 480px){.create-container{padding:0 .75rem;margin:2rem auto}.create-card{padding:1.25rem}.create-submit-btn{font-size:1rem}.file-label{padding:1.25rem}.form-input{padding:.65rem .8rem;font-size:.9rem}}.quill-editor-wrapper{border-radius:8px;overflow:hidden;border:1px solid var(--border-light)}.quill-editor-wrapper .ql-toolbar.ql-snow{background:var(--bg-tertiary);border:none;border-bottom:1px solid var(--border-light)}.quill-editor-wrapper .ql-toolbar .ql-stroke{stroke:var(--text-secondary)}.quill-editor-wrapper .ql-toolbar .ql-fill{fill:var(--text-secondary)}.quill-editor-wrapper .ql-toolbar .ql-picker-label{color:var(--text-secondary)}.quill-editor-wrapper .ql-toolbar button:hover .ql-stroke,.quill-editor-wrapper .ql-toolbar button.ql-active .ql-stroke{stroke:var(--accent-primary)}.quill-editor-wrapper .ql-toolbar button:hover .ql-fill,.quill-editor-wrapper .ql-toolbar button.ql-active .ql-fill{fill:var(--accent-primary)}.quill-editor-wrapper .ql-toolbar .ql-picker-label:hover,.quill-editor-wrapper .ql-toolbar .ql-picker-label.ql-active{color:var(--accent-primary)}.quill-editor-wrapper .ql-toolbar .ql-picker-options{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:6px}.quill-editor-wrapper .ql-toolbar .ql-picker-item{color:var(--text-secondary)}.quill-editor-wrapper .ql-toolbar .ql-picker-item:hover{color:var(--accent-primary)}.quill-editor-wrapper .ql-container.ql-snow{border:none;background:var(--bg-tertiary);min-height:250px;font-family:inherit;font-size:1rem}.quill-editor-wrapper .ql-editor{color:#fff;min-height:250px;line-height:1.7}.quill-editor-wrapper .ql-editor.ql-blank:before{color:var(--text-muted);font-style:normal}.quill-editor-wrapper .ql-editor h1,.quill-editor-wrapper .ql-editor h2,.quill-editor-wrapper .ql-editor h3{color:#fff}.quill-editor-wrapper .ql-editor a{color:var(--accent-primary)}.quill-editor-wrapper .ql-editor blockquote{border-left:3px solid var(--accent-primary);padding-left:1rem;color:var(--text-secondary)}.quill-editor-wrapper .ql-editor pre.ql-syntax{background:var(--bg-primary);color:var(--text-secondary);border-radius:6px;padding:1rem;font-family:monospace}.users-page-container{max-width:1000px;margin:3rem auto;padding:0 1rem;overflow-x:hidden}.users-header-row{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:2rem}.back-link{display:flex;align-items:center;gap:.25rem;color:var(--text-muted);font-size:.85rem;text-decoration:none;transition:color .2s}.back-link:hover{color:var(--text-primary)}.users-table-container{overflow-x:auto;padding:1rem}.users-table{width:100%;border-collapse:collapse;text-align:left;font-size:.9rem}.users-table th{padding:1rem;font-weight:500;color:var(--text-muted);border-bottom:1px solid var(--border-light);text-transform:uppercase;font-size:.75rem;letter-spacing:.5px}.users-table td{padding:1rem;border-bottom:1px solid rgba(255,255,255,.03);vertical-align:middle}.users-table tr:last-child td{border-bottom:none}.users-table tr:hover td{background-color:#ffffff05}.table-id{color:var(--text-muted);font-family:monospace;width:60px}.table-name{display:flex;align-items:center;gap:.75rem;font-weight:500;color:var(--text-primary)}.table-date{color:var(--text-secondary)}.user-avatar-tiny{width:24px;height:24px;border-radius:50%;background:var(--bg-tertiary);border:1px solid var(--border-light);display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600;color:var(--text-primary)}.role-badge[data-role=ADMIN]{color:#f59e0b;background:#f59e0b1a;border-color:#f59e0b33}.role-badge[data-role=MANAGER]{color:#3b82f6;background:#3b82f61a;border-color:#3b82f633}.role-badge[data-role=SUPERVISOR]{color:#10b981;background:#10b9811a;border-color:#10b98133}.table-actions{display:flex;justify-content:flex-end;gap:.5rem}.icon-btn{background:transparent;border:1px solid var(--border-light);color:var(--text-muted);width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.icon-btn:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-focus)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.modal-content{width:100%;max-width:450px;padding:2rem;animation:slideUp .3s cubic-bezier(.16,1,.3,1);box-shadow:0 24px 48px #000c}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h2{font-size:1.25rem;font-weight:600;margin:0}.modal-close{background:transparent;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:0;line-height:1;transition:color .2s}.modal-close:hover{color:var(--text-primary)}.modal-form{display:flex;flex-direction:column;gap:1.25rem}.input-with-icon{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:1rem;color:var(--text-muted)}.input-with-icon input{width:100%;padding:.75rem 1rem .75rem 2.75rem;background:var(--bg-secondary);border:1px solid var(--border-light);color:var(--text-primary);border-radius:8px;font-family:inherit;font-size:.95rem;outline:none;transition:border-color .2s}.input-with-icon input:focus{border-color:var(--border-focus)}.role-select{width:100%;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-light);color:var(--text-primary);border-radius:8px;font-family:inherit;font-size:.95rem;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.role-select:focus{border-color:var(--border-focus)}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-light)}.modal-actions button{min-width:100px}.delete-btn:hover{background:#ef44441a;color:#ef4444;border-color:#ef44444d}.delete-modal{border:1px solid rgba(239,68,68,.2)}.delete-warning{background:#ef44441a;border-left:4px solid #ef4444;padding:1rem;border-radius:4px;color:var(--text-primary);font-size:.95rem;line-height:1.5}.delete-confirm-input{width:100%;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-light);color:var(--text-primary);border-radius:8px;font-family:inherit;font-size:.95rem;outline:none;transition:border-color .2s;margin-top:.5rem}.delete-confirm-input:focus{border-color:#ef4444}.btn-danger{background:#ef4444;color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:background .2s;padding:0 1.25rem;height:40px}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-danger:disabled{background:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed;opacity:.7}@media (max-width: 768px){.users-container{padding:1rem}.users-header{flex-direction:column;align-items:flex-start;gap:1rem}.modal-content{margin:1rem;padding:1.5rem}}@media (max-width: 600px){.users-table th:nth-child(1),.users-table td:nth-child(1),.users-table th:nth-child(4),.users-table td:nth-child(4){display:none}.users-table th,.users-table td{padding:.6rem .5rem;font-size:.85rem}.users-table th{font-size:.7rem}.users-table-container{padding:.5rem}.table-name{gap:.5rem}.icon-btn{width:26px;height:26px}.table-actions{gap:.3rem}}.component-details-container{max-width:800px;margin:3rem auto;padding:0 2rem}.component-details-glass{padding:3rem;border-radius:12px}.tooltip-back-btn{background:transparent;border:1px solid var(--border-light);color:var(--text-secondary);padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;margin-bottom:2rem;transition:all .2s}.tooltip-back-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.component-details-header{margin-bottom:2rem;border-bottom:1px solid var(--border-light);padding-bottom:1.5rem}.component-title{font-size:2.5rem;margin-bottom:1rem}.component-meta{display:flex;gap:1rem;align-items:center}.meta-badge{background:var(--bg-tertiary);color:var(--text-secondary);padding:.4rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500}.component-info-section{color:var(--text-primary);line-height:1.7}.component-info-section h3{color:var(--text-primary);margin-bottom:1rem;font-size:1.3rem}.component-description{font-size:1.1rem;color:var(--text-secondary);margin-bottom:2rem}.datasheet-btn{display:inline-block;background-color:#f7931e;color:#fff;padding:.8rem 1.5rem;border-radius:6px;text-decoration:none;font-weight:600;margin-top:1.5rem;transition:opacity .2s}.datasheet-btn:hover{opacity:.9}@media (max-width: 768px){.component-details-glass{padding:2rem}.component-title{font-size:2rem}}@media (max-width: 480px){.component-details-container{padding:0 .75rem;margin:2rem auto;overflow-x:hidden}.component-details-glass{padding:1.25rem}.component-title{font-size:1.5rem}.component-meta{flex-wrap:wrap;gap:.5rem}.meta-badge{font-size:.8rem;padding:.3rem .75rem}.component-description{font-size:1rem}}.hardware-container{max-width:1300px;margin:0 auto;padding:2rem;overflow-x:hidden}.hardware-hero{text-align:center;margin-bottom:0;padding:1.5rem 1rem 1rem;overflow:hidden}.hardware-subtitle{color:var(--text-secondary);font-size:1.1rem;max-width:600px;margin:1rem auto 0;line-height:1.6}.hardware-layout{display:grid;grid-template-columns:280px 1fr;gap:1rem;align-items:flex-start;overflow-x:hidden}.hardware-sidebar{padding:1rem 1.5rem 1.5rem;position:sticky;top:1rem;max-height:calc(100vh - 80px);overflow-y:auto;overflow-x:hidden}.sidebar-heading{font-size:1.1rem;color:var(--text-primary);margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-light)}.source-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.source-item{padding:.75rem 1rem;border-radius:8px;cursor:pointer;color:var(--text-secondary);font-size:.95rem;transition:all .2s;border:1px solid transparent}.source-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.source-item.active{background:#fde68a14;color:var(--accent-light, #fde68a);border-color:#fde68a33;font-weight:600}.hardware-main{padding:1rem 2rem 2rem;margin-top:1rem;overflow-x:hidden}.hardware-main-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:.75rem}.add-component-btn{white-space:nowrap;flex-shrink:0}.search-action-row{display:flex;align-items:center;gap:.75rem;flex:1}.active-source-title{font-size:1.4rem;color:var(--text-primary);margin:0}.components-table-container{overflow-x:auto}.components-table{width:100%;border-collapse:collapse;text-align:left}.components-table th{padding:1rem;border-bottom:2px solid var(--border-light);color:var(--text-secondary);font-weight:600;text-transform:uppercase;font-size:.8rem;letter-spacing:.5px}.components-table td{padding:1rem;border-bottom:1px solid var(--border-light);color:var(--text-primary);vertical-align:top}.components-table tr:hover td{background:var(--bg-tertiary)}.comp-name-cell{width:40%}.comp-cat-cell{color:var(--text-secondary)!important}.tier-badge{background:var(--bg-tertiary, #2a2a35);color:var(--text-primary, #ffffff);padding:.3rem .8rem;border-radius:12px;font-size:.8rem;font-weight:600;white-space:nowrap;border:1px solid var(--border-light, #3f3f46)}@media (max-width: 900px){.hardware-layout{grid-template-columns:1fr}.hardware-sidebar{position:static}.hardware-main-header{flex-direction:column;align-items:flex-start}.hardware-search.search-box{width:100%}}@media (max-width: 768px){.hardware-container{padding:1rem}.hardware-hero{padding:2rem .5rem;margin-bottom:1.5rem}.hardware-hero h1{font-size:1.8rem}.hardware-subtitle{font-size:.95rem}.hardware-main{padding:1rem}.active-source-title{font-size:1.2rem}.components-table th,.components-table td{padding:.65rem .5rem;font-size:.85rem}.hardware-sidebar{padding:.75rem}.sidebar-heading{margin-bottom:.75rem;font-size:.95rem}.source-list{flex-direction:row;flex-wrap:nowrap;gap:.4rem;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:.5rem}.source-item{padding:.5rem .75rem;font-size:.85rem;white-space:nowrap;flex-shrink:0}}@media (max-width: 480px){.hardware-container{padding:.5rem}.hardware-hero h1{font-size:1.4rem}.hardware-hero{padding:1.5rem .5rem;margin-bottom:1rem}.hardware-subtitle{font-size:.85rem}.hardware-main{padding:.75rem}.hardware-sidebar{padding:.5rem}.components-table th:nth-child(2),.components-table td:nth-child(2){display:none}.components-table th,.components-table td{padding:.5rem .4rem;font-size:.78rem}.tier-badge{font-size:.7rem;padding:.2rem .5rem}.comp-name-cell{width:auto}.hardware-main-header{gap:.75rem}.add-component-btn{padding:.5rem .75rem;font-size:.8rem}}.notes-container{max-width:1100px;margin:4rem auto;padding:0 2rem;animation:fadeIn .5s ease;overflow-x:hidden}.notes-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.notes-subtitle{color:var(--text-secondary);margin-top:.3rem}.add-note-btn{display:flex;align-items:center;gap:.4rem;background:var(--gradient-primary);background-size:200% 200%;color:var(--btn-text);border:none;padding:.7rem 1.2rem;border-radius:10px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .3s cubic-bezier(.4,0,.2,1);animation:gradient-shift 3s ease infinite}.add-note-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #fde68a33}.notes-filter-tags{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2rem}.filter-tag{background:var(--bg-tertiary);border:1px solid var(--border-light);color:var(--text-secondary);padding:.4rem 1rem;border-radius:20px;cursor:pointer;font-size:.85rem;font-family:inherit;transition:all .25s cubic-bezier(.4,0,.2,1)}.filter-tag:hover{border-color:#fde68a33;color:var(--accent-light);background:#fde68a0d}.filter-tag.active{background:var(--gradient-primary);background-size:200% 200%;border-color:transparent;color:var(--btn-text);font-weight:600;animation:gradient-shift 3s ease infinite}.notes-empty{text-align:center;padding:4rem 2rem;color:var(--text-secondary);animation:fadeIn .5s ease}.notes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.note-card{padding:1.5rem;border-radius:16px;transition:all .35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;position:relative;overflow:hidden;animation:fadeInUp .5s ease backwards}.note-card:before{content:"";position:absolute;left:0;top:0;width:3px;height:100%;background:var(--gradient-primary);opacity:0;transition:opacity .3s ease}.note-card:hover{transform:translateY(-4px);border-color:#fde68a26;box-shadow:0 12px 32px #fde68a0f}.note-card:hover:before{opacity:1}.note-card.pinned{border-color:#fde68a33;background:#fde68a05}.note-card.pinned:before{background:linear-gradient(180deg,#fde68a,#fdba74);opacity:1}.note-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.note-tag{font-size:.75rem;padding:.2rem .6rem;border-radius:12px;background:#fde68a14;color:var(--accent-light);font-weight:500;border:1px solid rgba(253,230,138,.08)}.note-actions{display:flex;gap:.3rem;opacity:0;transition:opacity .2s}.note-card:hover .note-actions{opacity:1}.note-action-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:6px;transition:all .2s;display:flex;align-items:center}.note-action-btn:hover{color:var(--accent-light);background:#fde68a14}.note-action-btn.delete:hover{color:#ef4444;background:#ef44441a}.pin-badge{font-size:.75rem;color:var(--accent-light);margin-bottom:.3rem}.note-title{font-size:1.1rem;color:var(--text-primary);margin-bottom:.5rem;font-weight:600;transition:color .2s ease}.note-card:hover .note-title{color:var(--accent-cream)}.note-content{color:var(--text-secondary);font-size:.9rem;line-height:1.6;flex:1;white-space:pre-wrap;overflow:hidden;display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical}.note-footer{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-muted);margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--border-light)}.modal-close-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s}.modal-close-btn:hover{color:var(--text-primary);background:#ffffff0d}.notes-grid .note-card:nth-child(1){animation-delay:0s}.notes-grid .note-card:nth-child(2){animation-delay:.05s}.notes-grid .note-card:nth-child(3){animation-delay:.1s}.notes-grid .note-card:nth-child(4){animation-delay:.15s}.notes-grid .note-card:nth-child(5){animation-delay:.2s}.notes-grid .note-card:nth-child(6){animation-delay:.25s}@media (max-width: 768px){.notes-header{flex-direction:column;gap:1rem}.notes-grid{grid-template-columns:1fr}}@media (max-width: 480px){.notes-container{padding:0 .75rem;margin:2rem auto}.note-actions{opacity:1}.note-card{padding:1rem}.note-card-header{flex-wrap:wrap;gap:.5rem}.note-title{font-size:1rem}.note-content{font-size:.85rem;-webkit-line-clamp:4}.note-footer{font-size:.7rem;flex-wrap:wrap;gap:.25rem}.notes-grid{gap:1rem}.add-note-btn{padding:.6rem 1rem;font-size:.85rem}.filter-tag{font-size:.78rem;padding:.3rem .75rem}.note-detail-modal{padding:1.25rem}.note-detail-title{font-size:1.2rem}}.note-detail-modal{width:95%;max-width:600px;max-height:80vh;overflow-y:auto;padding:2rem;animation:noteSlideUp .3s cubic-bezier(.16,1,.3,1);box-shadow:0 24px 48px #0009}@keyframes noteSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.note-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.note-detail-meta{display:flex;align-items:center;gap:.75rem}.note-detail-title{font-size:1.6rem;font-weight:700;color:var(--text-primary);margin-bottom:.75rem;line-height:1.3}.note-detail-info{display:flex;justify-content:space-between;color:var(--text-muted);font-size:.85rem}.note-detail-info strong{color:var(--text-secondary)}.note-detail-divider{height:1px;background:var(--border-light);margin:1.25rem 0}.note-detail-content{font-size:1rem;line-height:1.8;color:var(--text-secondary);white-space:pre-wrap;word-break:break-word}:root{--bg-primary: #0b0b0e;--bg-secondary: #101014;--bg-tertiary: #18181e;--bg-panel: rgba(255, 255, 255, .025);--text-primary: #f5f3ef;--text-secondary: #b0aaa0;--text-muted: #78746c;--border-light: rgba(253, 230, 138, .07);--border-glow: rgba(253, 230, 138, .14);--border-focus: rgba(252, 211, 77, .35);--accent-sun: #f0c75e;--accent-warm: #fcd34d;--accent-light: #fde68a;--accent-cream: #fef3c7;--accent-peach: #fdba74;--accent-soft: #fbbf24;--gradient-primary: linear-gradient(135deg, #fcd34d, #fde68a, #fdba74);--gradient-subtle: linear-gradient(135deg, rgba(253, 230, 138, .1), rgba(252, 211, 77, .08));--gradient-glow: linear-gradient(135deg, rgba(253, 230, 138, .25), rgba(253, 186, 116, .2));--accent-primary: #ffffff;--accent-glow: rgba(253, 230, 138, .15);--btn-text: #1a1400;--star-color: #fbbf24;--glass-bg: rgba(16, 16, 20, .65);--navbar-bg: rgba(11, 11, 14, .88);--glass-hover-border: rgba(253, 230, 138, .12);--scrollbar-thumb: rgba(253, 230, 138, .2);--scrollbar-hover: rgba(253, 230, 138, .35);--body-glow1: rgba(253, 230, 138, .04);--body-glow2: rgba(253, 186, 116, .03)}[data-theme=light]{--bg-primary: #faf9f6;--bg-secondary: #f0ede6;--bg-tertiary: #e8e4dc;--bg-panel: rgba(0, 0, 0, .03);--text-primary: #1a1810;--text-secondary: #5c584e;--text-muted: #8a8578;--border-light: rgba(0, 0, 0, .08);--border-glow: rgba(0, 0, 0, .14);--border-focus: rgba(180, 140, 20, .4);--accent-sun: #c9a020;--accent-warm: #d4a017;--accent-light: #b8930f;--accent-cream: #a07e0a;--accent-peach: #c47a20;--accent-soft: #d4a017;--gradient-primary: linear-gradient(135deg, #d4a017, #e8b931, #c47a20);--gradient-subtle: linear-gradient(135deg, rgba(212, 160, 23, .08), rgba(200, 150, 20, .06));--gradient-glow: linear-gradient(135deg, rgba(212, 160, 23, .2), rgba(196, 122, 32, .15));--accent-primary: #1a1810;--accent-glow: rgba(212, 160, 23, .12);--btn-text: #ffffff;--star-color: #e6a817;--glass-bg: rgba(255, 255, 255, .7);--navbar-bg: rgba(250, 249, 246, .92);--glass-hover-border: rgba(0, 0, 0, .12);--scrollbar-thumb: rgba(0, 0, 0, .15);--scrollbar-hover: rgba(0, 0, 0, .25);--body-glow1: rgba(212, 160, 23, .04);--body-glow2: rgba(196, 122, 32, .03)}[data-theme=midnight]{--bg-primary: #0b1120;--bg-secondary: #0f1729;--bg-tertiary: #162032;--bg-panel: rgba(100, 180, 255, .025);--text-primary: #e4eaf5;--text-secondary: #8a9bb5;--text-muted: #5a6e8a;--border-light: rgba(100, 200, 255, .08);--border-glow: rgba(100, 200, 255, .15);--border-focus: rgba(34, 211, 238, .35);--accent-sun: #22d3ee;--accent-warm: #38bdf8;--accent-light: #67e8f9;--accent-cream: #a5f3fc;--accent-peach: #7dd3fc;--accent-soft: #06b6d4;--gradient-primary: linear-gradient(135deg, #22d3ee, #38bdf8, #06b6d4);--gradient-subtle: linear-gradient(135deg, rgba(34, 211, 238, .1), rgba(56, 189, 248, .08));--gradient-glow: linear-gradient(135deg, rgba(34, 211, 238, .25), rgba(56, 189, 248, .2));--accent-primary: #e4eaf5;--accent-glow: rgba(34, 211, 238, .15);--btn-text: #0b1120;--glass-bg: rgba(15, 23, 42, .65);--navbar-bg: rgba(11, 17, 32, .88);--glass-hover-border: rgba(100, 200, 255, .12);--scrollbar-thumb: rgba(34, 211, 238, .2);--scrollbar-hover: rgba(34, 211, 238, .35);--body-glow1: rgba(34, 211, 238, .04);--body-glow2: rgba(56, 189, 248, .03)}[data-theme=forest]{--bg-primary: #0a1210;--bg-secondary: #0e1a16;--bg-tertiary: #152420;--bg-panel: rgba(16, 185, 129, .025);--text-primary: #e8f5ec;--text-secondary: #8aab96;--text-muted: #5a7a68;--border-light: rgba(16, 185, 129, .08);--border-glow: rgba(16, 185, 129, .15);--border-focus: rgba(52, 211, 153, .35);--accent-sun: #10b981;--accent-warm: #34d399;--accent-light: #6ee7b7;--accent-cream: #a7f3d0;--accent-peach: #86efac;--accent-soft: #059669;--gradient-primary: linear-gradient(135deg, #10b981, #34d399, #059669);--gradient-subtle: linear-gradient(135deg, rgba(16, 185, 129, .1), rgba(52, 211, 153, .08));--gradient-glow: linear-gradient(135deg, rgba(16, 185, 129, .25), rgba(52, 211, 153, .2));--accent-primary: #e8f5ec;--accent-glow: rgba(16, 185, 129, .15);--btn-text: #052e16;--glass-bg: rgba(10, 18, 16, .65);--navbar-bg: rgba(10, 18, 16, .88);--glass-hover-border: rgba(16, 185, 129, .12);--scrollbar-thumb: rgba(16, 185, 129, .2);--scrollbar-hover: rgba(16, 185, 129, .35);--body-glow1: rgba(16, 185, 129, .04);--body-glow2: rgba(52, 211, 153, .03)}[data-theme=rose]{--bg-primary: #120a0e;--bg-secondary: #1a0e14;--bg-tertiary: #24151c;--bg-panel: rgba(244, 114, 182, .025);--text-primary: #f5e8ef;--text-secondary: #b08a9a;--text-muted: #7a5a68;--border-light: rgba(244, 114, 182, .08);--border-glow: rgba(244, 114, 182, .15);--border-focus: rgba(251, 146, 191, .35);--accent-sun: #f472b6;--accent-warm: #fb7acc;--accent-light: #f9a8d4;--accent-cream: #fbcfe8;--accent-peach: #f9a8d4;--accent-soft: #ec4899;--gradient-primary: linear-gradient(135deg, #f472b6, #fb7acc, #ec4899);--gradient-subtle: linear-gradient(135deg, rgba(244, 114, 182, .1), rgba(251, 122, 204, .08));--gradient-glow: linear-gradient(135deg, rgba(244, 114, 182, .25), rgba(251, 122, 204, .2));--accent-primary: #f5e8ef;--accent-glow: rgba(244, 114, 182, .15);--btn-text: #2e0519;--glass-bg: rgba(18, 10, 14, .65);--navbar-bg: rgba(18, 10, 14, .88);--glass-hover-border: rgba(244, 114, 182, .12);--scrollbar-thumb: rgba(244, 114, 182, .2);--scrollbar-hover: rgba(244, 114, 182, .35);--body-glow1: rgba(244, 114, 182, .04);--body-glow2: rgba(251, 122, 204, .03)}[data-theme=purple]{--bg-primary: #0c0a14;--bg-secondary: #100e1a;--bg-tertiary: #1a1628;--bg-panel: rgba(139, 92, 246, .025);--text-primary: #eee8f5;--text-secondary: #9a8ab5;--text-muted: #6a5a82;--border-light: rgba(139, 92, 246, .08);--border-glow: rgba(139, 92, 246, .15);--border-focus: rgba(167, 139, 250, .35);--accent-sun: #8b5cf6;--accent-warm: #a78bfa;--accent-light: #c4b5fd;--accent-cream: #ddd6fe;--accent-peach: #a78bfa;--accent-soft: #7c3aed;--gradient-primary: linear-gradient(135deg, #8b5cf6, #a78bfa, #7c3aed);--gradient-subtle: linear-gradient(135deg, rgba(139, 92, 246, .1), rgba(167, 139, 250, .08));--gradient-glow: linear-gradient(135deg, rgba(139, 92, 246, .25), rgba(167, 139, 250, .2));--accent-primary: #eee8f5;--accent-glow: rgba(139, 92, 246, .15);--btn-text: #1a0a3e;--glass-bg: rgba(12, 10, 20, .65);--navbar-bg: rgba(12, 10, 20, .88);--glass-hover-border: rgba(139, 92, 246, .12);--scrollbar-thumb: rgba(139, 92, 246, .2);--scrollbar-hover: rgba(139, 92, 246, .35);--body-glow1: rgba(139, 92, 246, .04);--body-glow2: rgba(167, 139, 250, .03)}[data-theme=black]{--bg-primary: #000000;--bg-secondary: #0a0a0a;--bg-tertiary: #141414;--bg-panel: rgba(255, 255, 255, .02);--text-primary: #e0e0e0;--text-secondary: #909090;--text-muted: #606060;--border-light: rgba(255, 255, 255, .06);--border-glow: rgba(255, 255, 255, .12);--border-focus: rgba(255, 255, 255, .3);--accent-sun: #d4d4d4;--accent-warm: #b0b0b0;--accent-light: #e0e0e0;--accent-cream: #f0f0f0;--accent-peach: #c0c0c0;--accent-soft: #a0a0a0;--gradient-primary: linear-gradient(135deg, #d4d4d4, #e0e0e0, #b0b0b0);--gradient-subtle: linear-gradient(135deg, rgba(255, 255, 255, .04), rgba(255, 255, 255, .02));--gradient-glow: linear-gradient(135deg, rgba(255, 255, 255, .1), rgba(255, 255, 255, .06));--accent-primary: #e0e0e0;--accent-glow: rgba(255, 255, 255, .08);--btn-text: #000000;--glass-bg: rgba(10, 10, 10, .8);--navbar-bg: rgba(0, 0, 0, .95);--glass-hover-border: rgba(255, 255, 255, .1);--scrollbar-thumb: rgba(255, 255, 255, .12);--scrollbar-hover: rgba(255, 255, 255, .2);--body-glow1: rgba(255, 255, 255, .01);--body-glow2: rgba(255, 255, 255, .01)}[data-theme=white]{--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--bg-tertiary: #ebebeb;--bg-panel: rgba(0, 0, 0, .02);--text-primary: #111111;--text-secondary: #555555;--text-muted: #999999;--border-light: rgba(0, 0, 0, .1);--border-glow: rgba(0, 0, 0, .16);--border-focus: rgba(0, 0, 0, .3);--accent-sun: #333333;--accent-warm: #444444;--accent-light: #222222;--accent-cream: #111111;--accent-peach: #555555;--accent-soft: #333333;--gradient-primary: linear-gradient(135deg, #333333, #555555, #222222);--gradient-subtle: linear-gradient(135deg, rgba(0, 0, 0, .04), rgba(0, 0, 0, .02));--gradient-glow: linear-gradient(135deg, rgba(0, 0, 0, .08), rgba(0, 0, 0, .05));--accent-primary: #111111;--accent-glow: rgba(0, 0, 0, .06);--btn-text: #ffffff;--glass-bg: rgba(255, 255, 255, .85);--navbar-bg: rgba(255, 255, 255, .95);--glass-hover-border: rgba(0, 0, 0, .15);--scrollbar-thumb: rgba(0, 0, 0, .15);--scrollbar-hover: rgba(0, 0, 0, .25);--body-glow1: rgba(0, 0, 0, .01);--body-glow2: rgba(0, 0, 0, .01)}html{overflow-x:hidden}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden;overflow-wrap:break-word;word-break:break-word;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-image:radial-gradient(circle at 25% 0%,var(--body-glow1) 0%,transparent 50%),radial-gradient(circle at 75% 100%,var(--body-glow2) 0%,transparent 50%);background-attachment:fixed}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-hover)}a{text-decoration:none;color:inherit}button{font-family:inherit;cursor:pointer}ul{list-style:none}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}@keyframes pulse-glow{0%,to{box-shadow:0 0 5px #fde68a26}50%{box-shadow:0 0 20px #fde68a4d}}@keyframes gradient-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes spin{to{transform:rotate(360deg)}}.glass-panel{background:var(--glass-bg);border:1px solid var(--border-light);border-radius:12px;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);transition:border-color .3s ease,box-shadow .3s ease}.glass-panel:hover{border-color:var(--glass-hover-border)}.center-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;color:var(--text-secondary);animation:fadeIn .5s ease}.btn{padding:.5rem 1rem;border-radius:8px;border:1px solid var(--border-light);background:var(--bg-secondary);color:var(--text-primary);font-size:.9rem;font-weight:500;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.btn:hover{background:var(--bg-tertiary);border-color:var(--border-glow);transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}.btn:active{transform:translateY(0)}.btn-primary{background:var(--gradient-primary);background-size:200% 200%;color:var(--btn-text);border:none;font-weight:600;animation:gradient-shift 3s ease infinite}.btn-primary:hover{box-shadow:0 4px 20px #fde68a4d;transform:translateY(-2px)}.btn-danger{background:#ef444426;color:#f87171;border-color:#ef44444d}.btn-danger:hover{background:#ef444440;border-color:#ef444480;box-shadow:0 4px 16px #ef444433}.text-gradient{background:var(--gradient-primary);background-size:200% 200%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:gradient-shift 4s ease infinite}.accent-gradient{background:linear-gradient(135deg,#fcd34d,#fde68a);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.status-badge{font-size:.65rem;padding:.15rem .5rem;border-radius:10px;font-weight:600;text-transform:uppercase;letter-spacing:.02em;animation:fadeIn .3s ease}.status-in-progress{background:#fde68a1f;color:#fde68a;border:1px solid rgba(253,230,138,.25)}.status-completed{background:#34d39926;color:#34d399;border:1px solid rgba(52,211,153,.3)}.status-on-hold{background:#fdba7426;color:#fdba74;border:1px solid rgba(253,186,116,.3)}.status-archived{background:#71717a26;color:#a1a1aa;border:1px solid rgba(113,113,122,.3)}.modal-overlay{animation:fadeIn .2s ease}.modal-content{animation:fadeInUp .3s ease}.comments-section{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border-light)}.comment-item{display:flex;gap:.75rem;padding:1rem 0;border-bottom:1px solid rgba(255,255,255,.03);animation:fadeInUp .3s ease;transition:background .2s ease}.comment-item:hover{background:#fde68a05;border-radius:8px;padding-left:.5rem;margin-left:-.5rem}.comment-avatar{width:36px;height:36px;border-radius:50%;background:var(--gradient-subtle);border:1px solid rgba(253,230,138,.15);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;color:var(--accent-light);flex-shrink:0}.comment-body{flex:1}.comment-meta{display:flex;align-items:center;gap:.5rem;margin-bottom:.3rem}.comment-author{font-weight:600;font-size:.85rem;color:var(--text-primary)}.comment-date{font-size:.75rem;color:var(--text-muted)}.comment-text{font-size:.9rem;color:var(--text-secondary);line-height:1.5}.comment-input-row{display:flex;gap:.75rem;margin-top:1rem}.comment-input-row input{flex:1;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:8px;padding:.6rem 1rem;color:var(--text-primary);font-family:inherit;font-size:.9rem;transition:all .3s ease}.comment-input-row input:focus{outline:none;border-color:var(--accent-warm);box-shadow:0 0 0 3px #fde68a14}.spinner{width:40px;height:40px;border:3px solid rgba(253,230,138,.12);border-top-color:var(--accent-warm);border-radius:50%;margin:0 auto 1.5rem;animation:spin .8s linear infinite}
