.toast-container{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);z-index:10000;display:flex;flex-direction:column;gap:.5rem;align-items:center;pointer-events:none}.toast{pointer-events:auto;padding:.75rem 1.5rem;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;box-shadow:0 4px 16px #00000040;animation:toast-in .3s ease-out;max-width:90vw;text-align:center}.toast--error{background:#c53030;color:#fff}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.spinner-page{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:3rem 0;width:100%}.spinner-wrap{display:inline-flex;align-items:center;gap:.5rem}.spinner{border-radius:50%;border-style:solid;border-color:#2563eb33;border-top-color:#2563eb;animation:spinnerRotate .7s linear infinite}.spinner--page{width:40px;height:40px;border-width:3.5px}.spinner--inline{width:22px;height:22px;border-width:2.5px}.spinner--small{width:16px;height:16px;border-width:2px}.spinner-label{font-size:.9rem;color:#64748b}@keyframes spinnerRotate{to{transform:rotate(360deg)}}.login-page{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-size:cover;background-position:center;background-repeat:no-repeat}.login-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:transparent}.login-card{position:relative;z-index:1;width:100%;max-width:420px;margin:1rem;padding:2.5rem 2rem 2rem;background:#ffffff1f;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.18);border-radius:20px;box-shadow:0 8px 32px #00000059,inset 0 1px #ffffff26;color:#fff}.login-header{text-align:center;margin-bottom:2rem}.login-title{font-size:1.75rem;font-weight:700;letter-spacing:.5px;color:#fff;margin-bottom:.25rem}.login-subtitle{font-size:.85rem;font-weight:400;color:#fff9;letter-spacing:1.5px;text-transform:uppercase}.login-form{display:flex;flex-direction:column;gap:1.25rem}.input-group{display:flex;flex-direction:column;gap:.4rem}.input-group label{font-size:.8rem;font-weight:500;color:#ffffffb3;letter-spacing:.4px;text-transform:uppercase}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:14px;width:18px;height:18px;color:#ffffff40;pointer-events:none}.input-wrapper input{width:100%;padding:.75rem 2.5rem .75rem 2.75rem;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:10px;color:#fff;font-size:.95rem;transition:border-color .2s,background .2s,box-shadow .2s}.input-wrapper input::placeholder{color:#ffffff59}.input-wrapper input:focus{outline:none;border-color:#64b4ff99;background:#ffffff1f;box-shadow:0 0 0 3px #64b4ff26}.password-toggle{position:absolute;right:10px;display:flex;align-items:center;justify-content:center;background:none;border:none;padding:4px;cursor:pointer;color:#ffffff59;transition:color .2s}.password-toggle:hover{color:#ffffffb3}.password-toggle svg{width:20px;height:20px}.login-error{display:flex;align-items:center;gap:.5rem;padding:.65rem .85rem;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:10px;color:#fca5a5;font-size:.85rem}.login-error svg{width:18px;height:18px;flex-shrink:0}.login-btn{width:100%;padding:.8rem;margin-top:.25rem;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;font-size:1rem;font-weight:600;letter-spacing:.3px;border:none;border-radius:10px;cursor:pointer;transition:transform .15s,box-shadow .2s,opacity .2s;box-shadow:0 4px 14px #2563eb66;display:flex;align-items:center;justify-content:center;min-height:48px}.login-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #2563eb80}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-spinner{width:22px;height:22px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{margin-top:1.75rem;text-align:center}.login-footer p{font-size:.75rem;color:#ffffff59;letter-spacing:.5px;text-transform:uppercase}@media(max-width:480px){.login-card{margin:.75rem;padding:2rem 1.5rem 1.5rem;border-radius:16px}.login-title{font-size:1.5rem}}.product-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:.75rem;display:flex;flex-direction:column;gap:.4rem;transition:box-shadow .2s,transform .2s;cursor:pointer;max-width:220px}@media(max-width:600px){.product-card{max-width:100%;width:100%}}.product-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.product-card__image-wrapper{width:100%;aspect-ratio:3 / 4;border-radius:6px;overflow:hidden}.product-card__image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.product-card:hover .product-card__image{transform:scale(1.05)}.product-card__placeholder{width:100%;height:100%;background-color:#e2e8f0}.product-card__name{margin:0;font-size:.9rem;font-weight:600;color:#1a365d;transition:color .2s}.product-card:hover .product-card__name{color:#2b6cb0}.product-card__description{margin:0;font-size:.85rem;color:#718096;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.product-display{display:grid;grid-template-columns:repeat(auto-fill,220px);gap:2.5rem;justify-content:center}@media(max-width:600px){.product-display{grid-template-columns:1fr 1fr;gap:1rem;justify-items:stretch}}@media(max-width:380px){.product-display{grid-template-columns:1fr}}.product-filter{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:1.25rem;display:flex;flex-direction:column;gap:1rem;position:sticky;top:1rem;max-height:calc(100vh - 2rem);overflow-y:auto}.product-filter__title{margin:0;font-size:1.1rem;font-weight:600;color:#1a365d;border-bottom:1px solid #e2e8f0;padding-bottom:.75rem}.product-filter__search{margin-bottom:.25rem}.product-filter__search-input{width:100%;padding:.5rem .7rem;border:1px solid #cbd5e1;border-radius:6px;font-size:.875rem;color:#1a365d;background:#fff;outline:none;box-sizing:border-box;transition:border-color .15s}.product-filter__search-input:focus{border-color:#60a5fa;box-shadow:0 0 0 2px #60a5fa26}.product-filter__search-input::placeholder{color:#94a3b8}.product-filter__section{display:flex;flex-direction:column;gap:0;border:1px solid #e2e8f0;border-radius:6px;overflow:hidden}.product-filter__section-header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:.5rem .6rem;background:#f7fafc;border:none;font-size:.8rem;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:background .15s}.product-filter__section-header:hover{background:#edf2f7}.product-filter__section-label{display:flex;align-items:center;gap:.4rem}.product-filter__section-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.15rem;height:1.15rem;padding:0 .25rem;background:#2b6cb0;color:#fff;border-radius:999px;font-size:.65rem;font-weight:600;line-height:1;text-transform:none;letter-spacing:0}.product-filter__section-chevron{font-size:.7rem;color:#a0aec0}.product-filter__section-body{display:flex;flex-direction:column;gap:.35rem;padding:.5rem .6rem;border-top:1px solid #e2e8f0;max-height:200px;overflow-y:auto}.product-filter__section-title{margin:0;font-size:.8rem;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.5px}.product-filter__checkbox{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#2d3748;cursor:pointer}.product-filter__checkbox input{accent-color:#2b6cb0;cursor:pointer}.product-exploration-page{position:relative;min-height:100vh;background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed;background-color:transparent}.product-exploration-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:0;pointer-events:none}.product-exploration-page>*{position:relative;z-index:1}.page.product-exploration-page h1{color:#fff;text-transform:uppercase;letter-spacing:.15em}.product-exploration-page .admin-link-btn{color:#fff;background:#ffffff26;border-color:#ffffff4d}.product-exploration-page .admin-link-btn:hover{background:#ffffff40}.product-exploration-layout{display:flex;gap:1.5rem;width:100%;padding:0 2rem;margin-top:50px;box-sizing:border-box}.product-exploration-main{flex:1 1 0%;min-width:0}.product-exploration-sidebar{flex:0 0 280px;max-width:33.33%}.product-exploration-main>.product-exploration-sidebar{display:none}.product-exploration-filter-toggle{display:none}@media(max-width:1000px){.product-exploration-layout{flex-direction:column}.product-exploration-sidebar--desktop{display:none}.product-exploration-main>.product-exploration-sidebar{display:none;max-width:none;min-width:0}.product-exploration-main>.product-exploration-sidebar--open{display:block;margin-bottom:1rem}.product-exploration-filter-toggle{display:flex;justify-content:center;align-items:center;gap:.4rem;margin:0 auto 1rem;padding:.5rem 1rem;background:#ffffff26;border:1px solid rgba(255,255,255,.35);border-radius:6px;color:#fff;font-size:.9rem;cursor:pointer;transition:background .15s}.product-exploration-filter-toggle:hover{background:#ffffff40}}@media(max-width:600px){.product-exploration-layout{padding:0 .5rem}.page.product-exploration-page h1{font-size:1.3rem;text-align:center}}.region-map-wrapper{border:1px solid #e2e8f0;border-radius:8px;overflow:hidden;background:#f7fafc}.region-map-svg{display:block;width:100%;height:auto}.product-page{max-width:1100px;margin:0 auto;padding:1.5rem 1.5rem 4rem;align-items:stretch}.product-page__status{text-align:center;color:#718096;font-size:1.1rem;margin-top:4rem}.product-page__top-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.product-page__back{background:none;border:1px solid #cbd5e0;border-radius:6px;padding:.35rem .8rem;font-size:.82rem;color:#4a5568;cursor:pointer;transition:background .15s,border-color .15s}.product-page__back:hover{background:#edf2f7;border-color:#a0aec0}.product-page__delete{background:#fff5f5;border:1px solid #fc8181;border-radius:6px;padding:.35rem .8rem;font-size:.82rem;color:#c53030;cursor:pointer}.product-page__delete:hover{background:#fed7d7}.product-page__delete:disabled{opacity:.5;cursor:not-allowed}.pp-bento{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.pp-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:1.1rem 1.25rem;display:flex;flex-direction:column;overflow:hidden}.pp-card__label{margin:0 0 .5rem;font-size:.68rem;font-weight:600;color:#a0aec0;text-transform:uppercase;letter-spacing:.06em}.pp-card__body{overflow:hidden;position:relative;transition:max-height .25s ease}.pp-card__body--collapsed:after{content:"";position:absolute;bottom:0;left:0;right:0;height:40px;background:linear-gradient(transparent,#fff);pointer-events:none}.pp-card__toggle{margin-top:.4rem;background:none;border:none;color:#4299e1;font-size:.75rem;font-weight:600;cursor:pointer;padding:0;align-self:flex-start}.pp-card__toggle:hover{color:#2b6cb0}.pp-card--image{grid-column:span 1;padding:0;overflow:hidden}.pp-card__img{width:100%;height:auto;object-fit:contain;display:block}.pp-card__img-placeholder{width:100%;min-height:200px;background:linear-gradient(135deg,#e2e8f0,#edf2f7)}.pp-card--info{grid-column:span 3;justify-content:center;gap:.5rem}.pp-card__name{margin:0;font-size:1.8rem;font-weight:700;color:#1a202c;line-height:1.2}.pp-card__desc{margin:0;font-size:.92rem;color:#4a5568;line-height:1.65}.pp-formulations{display:flex;flex-wrap:wrap;gap:.35rem}.pp-formulation-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .6rem;background:#ebf4ff;border:1px solid #bee3f8;border-radius:999px;font-size:.75rem;color:#2b6cb0}.pp-formulation-badge strong{color:#2c5282}.pp-card--specs{grid-column:span 1}.pp-spec-list{display:flex;flex-direction:column;gap:.35rem}.pp-spec-link{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .7rem;background:#f7fafc;border:1px solid #e2e8f0;border-radius:5px;color:#2d3748;font-size:.8rem;text-decoration:none;transition:background .12s}.pp-spec-link:hover{background:#edf2f7}.pp-spec-link svg{flex-shrink:0;color:#718096}.pp-card--crops,.pp-card--pests,.pp-card--diseases{grid-column:1 / -1}.pp-tags{display:flex;flex-wrap:wrap;gap:.3rem}.pp-tag{display:inline-block;padding:.22rem .6rem;border-radius:999px;font-size:.78rem;font-weight:500}.pp-tag--green{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.pp-tag--amber{background:#fffbeb;border:1px solid #fde68a;color:#92400e}.pp-tag--red{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.pp-card--map{grid-column:1 / -1}.pp-map-row{display:flex;gap:1rem;align-items:flex-start}.pp-map-col{flex:2;min-width:0}.pp-map-col .region-map-wrapper{width:100%}.pp-region-list{flex:0 0 180px;list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.3rem}.pp-region-item{padding:.4rem .75rem;background:#f7fafc;border:1px solid #e2e8f0;border-radius:5px;font-size:.82rem;color:#2d3748;font-weight:500}@media(max-width:900px){.pp-bento{grid-template-columns:repeat(2,1fr)}.pp-card--image,.pp-card--info{grid-column:span 1}}@media(max-width:600px){.product-page{padding:.75rem .75rem 2rem}.pp-bento{grid-template-columns:1fr;gap:6px}.pp-card--image,.pp-card--info,.pp-card--specs,.pp-card--crops,.pp-card--pests,.pp-card--diseases,.pp-card--map{grid-column:span 1}.pp-card__name{font-size:1.35rem}.pp-map-row{flex-direction:column;gap:.75rem}.pp-region-list{flex:none;width:100%}}@keyframes marching-ants{0%{background-position:0 0,0 100%,0 0,100% 0}to{background-position:20px 0,-20px 100%,0 -20px,100% 20px}}:root{--rc-drag-handle-size: 12px;--rc-drag-handle-mobile-size: 24px;--rc-drag-handle-bg-colour: rgba(0, 0, 0, .2);--rc-drag-bar-size: 6px;--rc-border-color: rgba(255, 255, 255, .7);--rc-focus-color: #0088ff}.ReactCrop{position:relative;display:inline-block;cursor:crosshair;max-width:100%}.ReactCrop *,.ReactCrop *:before,.ReactCrop *:after{box-sizing:border-box}.ReactCrop--disabled,.ReactCrop--locked{cursor:inherit}.ReactCrop__child-wrapper{overflow:hidden;max-height:inherit}.ReactCrop__child-wrapper>img,.ReactCrop__child-wrapper>video{display:block;max-width:100%;max-height:inherit}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>img,.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>video{touch-action:none}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__crop-selection{touch-action:none}.ReactCrop__crop-mask{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;width:calc(100% + .5px);height:calc(100% + .5px)}.ReactCrop__crop-selection{position:absolute;top:0;left:0;transform:translateZ(0);cursor:move}.ReactCrop--disabled .ReactCrop__crop-selection{cursor:inherit}.ReactCrop--circular-crop .ReactCrop__crop-selection{border-radius:50%}.ReactCrop--circular-crop .ReactCrop__crop-selection:after{pointer-events:none;content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border:1px solid var(--rc-border-color);opacity:.3}.ReactCrop--no-animate .ReactCrop__crop-selection{outline:1px dashed white}.ReactCrop__crop-selection:not(.ReactCrop--no-animate .ReactCrop__crop-selection){animation:marching-ants 1s;background-image:linear-gradient(to right,#fff 50%,#444 50%),linear-gradient(to right,#fff 50%,#444 50%),linear-gradient(to bottom,#fff 50%,#444 50%),linear-gradient(to bottom,#fff 50%,#444 50%);background-size:10px 1px,10px 1px,1px 10px,1px 10px;background-position:0 0,0 100%,0 0,100% 0;background-repeat:repeat-x,repeat-x,repeat-y,repeat-y;color:#fff;animation-play-state:running;animation-timing-function:linear;animation-iteration-count:infinite}.ReactCrop__crop-selection:focus{outline:2px solid var(--rc-focus-color);outline-offset:-1px}.ReactCrop--invisible-crop .ReactCrop__crop-mask,.ReactCrop--invisible-crop .ReactCrop__crop-selection{display:none}.ReactCrop__rule-of-thirds-vt:before,.ReactCrop__rule-of-thirds-vt:after,.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-hz:after{content:"";display:block;position:absolute;background-color:#fff6}.ReactCrop__rule-of-thirds-vt:before,.ReactCrop__rule-of-thirds-vt:after{width:1px;height:100%}.ReactCrop__rule-of-thirds-vt:before{left:33.3333333333%}.ReactCrop__rule-of-thirds-vt:after{left:66.6666666667%}.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-hz:after{width:100%;height:1px}.ReactCrop__rule-of-thirds-hz:before{top:33.3333333333%}.ReactCrop__rule-of-thirds-hz:after{top:66.6666666667%}.ReactCrop__drag-handle{position:absolute;width:var(--rc-drag-handle-size);height:var(--rc-drag-handle-size);background-color:var(--rc-drag-handle-bg-colour);border:1px solid var(--rc-border-color)}.ReactCrop__drag-handle:focus{background:var(--rc-focus-color)}.ReactCrop .ord-nw{top:0;left:0;transform:translate(-50%,-50%);cursor:nw-resize}.ReactCrop .ord-n{top:0;left:50%;transform:translate(-50%,-50%);cursor:n-resize}.ReactCrop .ord-ne{top:0;right:0;transform:translate(50%,-50%);cursor:ne-resize}.ReactCrop .ord-e{top:50%;right:0;transform:translate(50%,-50%);cursor:e-resize}.ReactCrop .ord-se{bottom:0;right:0;transform:translate(50%,50%);cursor:se-resize}.ReactCrop .ord-s{bottom:0;left:50%;transform:translate(-50%,50%);cursor:s-resize}.ReactCrop .ord-sw{bottom:0;left:0;transform:translate(-50%,50%);cursor:sw-resize}.ReactCrop .ord-w{top:50%;left:0;transform:translate(-50%,-50%);cursor:w-resize}.ReactCrop__disabled .ReactCrop__drag-handle{cursor:inherit}.ReactCrop__drag-bar{position:absolute}.ReactCrop__drag-bar.ord-n{top:0;left:0;width:100%;height:var(--rc-drag-bar-size);transform:translateY(-50%)}.ReactCrop__drag-bar.ord-e{right:0;top:0;width:var(--rc-drag-bar-size);height:100%;transform:translate(50%)}.ReactCrop__drag-bar.ord-s{bottom:0;left:0;width:100%;height:var(--rc-drag-bar-size);transform:translateY(50%)}.ReactCrop__drag-bar.ord-w{top:0;left:0;width:var(--rc-drag-bar-size);height:100%;transform:translate(-50%)}.ReactCrop--new-crop .ReactCrop__drag-bar,.ReactCrop--new-crop .ReactCrop__drag-handle,.ReactCrop--fixed-aspect .ReactCrop__drag-bar,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-n,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-e,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-s,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-w{display:none}@media(pointer:coarse){.ReactCrop .ord-n,.ReactCrop .ord-e,.ReactCrop .ord-s,.ReactCrop .ord-w{display:none}.ReactCrop__drag-handle{width:var(--rc-drag-handle-mobile-size);height:var(--rc-drag-handle-mobile-size)}}.admin-page{max-width:800px;width:100%;padding-bottom:4rem}.admin-header{width:100%;display:flex;align-items:center;gap:1rem}.admin-back{background:none;border:none;color:#2b6cb0;font-size:.9rem;cursor:pointer;padding:.3rem 0;white-space:nowrap}.admin-back:hover{text-decoration:underline}.admin-sections{width:100%;display:flex;flex-direction:column;gap:1rem}.admin-section{border:1px solid #e2e8f0;border-radius:8px;overflow:hidden;background:#fff}.admin-section__header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f7fafc;border:none;font-size:1rem;font-weight:600;color:#1a365d;cursor:pointer;transition:background .15s}.admin-section__header:hover{background:#edf2f7}.admin-section__chevron{font-size:.85rem;color:#a0aec0}.admin-section__body{padding:1rem;border-top:1px solid #e2e8f0}.admin-form{display:flex;flex-direction:column;gap:.85rem}.admin-form__row{display:flex;gap:.75rem;align-items:flex-end}.admin-form__row>*{flex:1}.admin-form__row>button{flex:0 0 auto;margin-bottom:2px}.admin-field{display:flex;flex-direction:column;gap:.25rem}.admin-field__label{font-size:.8rem;font-weight:600;color:#4a5568}.admin-field input,.admin-field textarea{padding:.5rem .6rem;border:1px solid #cbd5e0;border-radius:5px;font-size:.9rem;font-family:inherit;transition:border-color .15s}.admin-field input:focus,.admin-field textarea:focus{outline:none;border-color:#2b6cb0;box-shadow:0 0 0 3px #2b6cb026}.admin-fieldset{border:1px solid #e2e8f0;border-radius:6px;padding:.75rem}.admin-fieldset legend{font-size:.8rem;font-weight:600;color:#4a5568;padding:0 .35rem}.admin-collapsible{border:1px solid #e2e8f0;border-radius:6px;overflow:hidden}.admin-collapsible__header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:.6rem .75rem;background:#f7fafc;border:none;font-size:.8rem;font-weight:600;color:#4a5568;cursor:pointer;transition:background .15s}.admin-collapsible__header:hover{background:#edf2f7}.admin-collapsible__label{display:flex;align-items:center;gap:.5rem}.admin-collapsible__badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.2rem;height:1.2rem;padding:0 .3rem;background:#2b6cb0;color:#fff;border-radius:999px;font-size:.7rem;font-weight:600;line-height:1}.admin-collapsible__chevron{font-size:.75rem;color:#a0aec0}.admin-collapsible__body{padding:.75rem;border-top:1px solid #e2e8f0}.admin-checkbox-grid{display:flex;flex-wrap:wrap;gap:.5rem 1rem}.admin-checkbox{display:flex;align-items:center;gap:.35rem;font-size:.85rem;cursor:pointer}.admin-chip-list{list-style:none;display:flex;flex-wrap:wrap;gap:.4rem;padding:0;margin:.5rem 0 0}.admin-chip{display:flex;align-items:center;gap:.3rem;padding:.25rem .55rem;background:#edf2f7;border-radius:4px;font-size:.8rem;color:#2d3748}.admin-chip button{background:none;border:none;color:#a0aec0;font-size:.9rem;cursor:pointer;padding:0;line-height:1}.admin-chip button:hover{color:#e53e3e}.admin-btn{padding:.55rem 1.25rem;background-color:#2b6cb0;color:#fff;border:none;border-radius:5px;font-size:.9rem;font-weight:500;cursor:pointer;align-self:flex-start;transition:background .15s}.admin-btn:hover:not(:disabled){background-color:#2c5282}.admin-btn:disabled{opacity:.6;cursor:not-allowed}.admin-btn--small{padding:.4rem .7rem;font-size:1rem;line-height:1}.admin-btn--danger{background-color:#e53e3e}.admin-btn--danger:hover:not(:disabled){background-color:#c53030}.admin-image-drop{display:flex;align-items:center;justify-content:center;height:120px;border:2px dashed #cbd5e0;border-radius:6px;cursor:pointer;color:#a0aec0;font-size:.9rem;transition:border-color .15s,color .15s}.admin-image-drop:hover{border-color:#2b6cb0;color:#2b6cb0}.admin-doc-drop{display:flex;align-items:center;justify-content:center;gap:.5rem;height:80px;border:2px dashed #cbd5e0;border-radius:6px;cursor:pointer;color:#a0aec0;font-size:.9rem;transition:border-color .15s,color .15s}.admin-doc-drop:hover{border-color:#2b6cb0;color:#2b6cb0}.admin-doc-drop__icon{font-size:1.4rem}.admin-chip--doc{background:#ebf8ff;color:#2b6cb0}.admin-chip--doc .admin-chip__icon{font-size:.9rem;opacity:.7}.admin-image-preview{display:flex;align-items:flex-start;gap:.75rem}.admin-image-preview img{width:160px;height:120px;object-fit:cover;border-radius:6px;border:1px solid #e2e8f0}.admin-image-preview__actions{display:flex;flex-direction:column;gap:.4rem;align-items:flex-start}.admin-image-preview__ok{color:#38a169;font-weight:600;font-size:1rem}.admin-image-cropper{display:flex;flex-direction:column;gap:.5rem}.image-cropper{display:flex;flex-direction:column;gap:.75rem}.image-cropper__react-crop{max-width:100%}.image-cropper__source{max-width:100%;max-height:400px;display:block}.image-cropper__actions{display:flex;gap:.5rem}.admin-btn--secondary{background-color:#a0aec0}.admin-btn--secondary:hover:not(:disabled){background-color:#718096}.admin-success{color:#276749;background:#c6f6d5;border:1px solid #9ae6b4;border-radius:6px;padding:.5rem .75rem;font-size:.85rem;margin:0}.admin-error{color:#e53e3e;font-size:.85rem;margin:0}.admin-muted{color:#a0aec0;font-size:.85rem;font-style:italic}.admin-link-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .8rem;background:#2b6cb01a;color:#2b6cb0;border:1px solid rgba(43,108,176,.25);border-radius:5px;font-size:.8rem;font-weight:500;text-decoration:none;transition:background .15s}.admin-link-btn:hover{background:#2b6cb02e}@media(max-width:768px){.admin-page{padding-left:1rem;padding-right:1rem}.admin-header{flex-direction:column;align-items:flex-start;gap:.25rem}.admin-form__row{flex-direction:column;gap:.5rem}.admin-image-preview img{width:120px;height:90px}}.admin-settings-page{max-width:1200px;margin:0 auto;padding:2rem}.admin-settings__success{background:#c6f6d5;color:#22543d;padding:.6rem 1rem;border-radius:6px;font-size:.9rem;margin-bottom:1rem}.admin-settings__error{background:#fed7d7;color:#822727;padding:.6rem 1rem;border-radius:6px;font-size:.9rem;margin-bottom:1rem}.admin-settings__section{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.admin-settings__section h2{margin:0 0 1rem;font-size:1.15rem;font-weight:600;color:#1a365d}.admin-settings__section--wide{max-width:100%}.admin-settings__form{display:flex;gap:.75rem;flex-wrap:wrap;align-items:flex-end}.admin-settings__form input{flex:1;min-width:160px;padding:.5rem .75rem;border:1px solid #cbd5e0;border-radius:6px;font-size:.9rem}.admin-settings__form input:focus{outline:none;border-color:#2b6cb0;box-shadow:0 0 0 2px #2b6cb026}.admin-settings__form button{padding:.5rem 1.25rem;background:#2b6cb0;color:#fff;border:none;border-radius:6px;font-size:.9rem;cursor:pointer;transition:background .15s;white-space:nowrap}.admin-settings__form button:hover{background:#2c5282}.admin-settings__form button:disabled{opacity:.5;cursor:not-allowed}.admin-settings__table-wrap{overflow-x:auto}.admin-settings__table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-settings__table th{text-align:left;padding:.6rem .75rem;font-weight:600;color:#718096;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e2e8f0}.admin-settings__table td{padding:.6rem .75rem;border-bottom:1px solid #edf2f7;color:#2d3748}.admin-settings__badge{display:inline-block;padding:.15rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500;background:#edf2f7;color:#718096}.admin-settings__badge--admin{background:#c6f6d5;color:#22543d}.admin-settings__badge--manager{background:#e9d8fd;color:#553c9a}.admin-settings__th-center,.admin-settings__td-center{text-align:center}.admin-settings__checkbox{width:18px;height:18px;cursor:pointer;accent-color:#2b6cb0}.admin-settings__checkbox:disabled{cursor:not-allowed;opacity:.5}.admin-settings__row--changed{background:ivory}.admin-settings__apply-bar{display:flex;justify-content:flex-end;margin-top:1rem;padding-top:1rem;border-top:1px solid #e2e8f0}.admin-settings__apply-btn{padding:.6rem 2rem;background:#2b6cb0;color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s}.admin-settings__apply-btn:hover{background:#2c5282}.admin-settings__apply-btn:disabled{opacity:.5;cursor:not-allowed}.admin-settings__actions{display:flex;gap:.5rem;flex-wrap:wrap}.admin-settings__btn{padding:.3rem .7rem;border-radius:5px;font-size:.8rem;cursor:pointer;border:1px solid;transition:background .15s;white-space:nowrap}.admin-settings__btn--toggle{background:#ebf8ff;color:#2b6cb0;border-color:#90cdf4}.admin-settings__btn--toggle:hover{background:#bee3f8}.admin-settings__btn--reset{background:#fffaf0;color:#c05621;border-color:#fbd38d}.admin-settings__btn--reset:hover{background:#feebc8}.admin-settings__overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#00000080;display:flex;align-items:center;justify-content:center;padding:1rem}.admin-settings__dialog{background:#fff;border-radius:10px;padding:1.5rem 2rem;max-width:400px;width:100%;box-shadow:0 10px 40px #00000040}.admin-settings__dialog h3{margin:0 0 .25rem;font-size:1.1rem;color:#1a365d}.admin-settings__dialog-email{margin:0 0 1rem;font-size:.9rem;color:#718096}.admin-settings__dialog input{width:100%;padding:.5rem .75rem;border:1px solid #cbd5e0;border-radius:6px;font-size:.9rem;margin-bottom:1rem;box-sizing:border-box}.admin-settings__dialog input:focus{outline:none;border-color:#2b6cb0;box-shadow:0 0 0 2px #2b6cb026}.admin-settings__dialog-buttons{display:flex;gap:.75rem;justify-content:flex-end}.admin-settings__dialog-buttons button{padding:.45rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:background .15s}.admin-settings__dialog-buttons button[type=button]{background:#edf2f7;color:#4a5568;border:1px solid #cbd5e0}.admin-settings__dialog-buttons button[type=button]:hover{background:#e2e8f0}.admin-settings__dialog-buttons button[type=submit]{background:#2b6cb0;color:#fff;border:none}.admin-settings__dialog-buttons button[type=submit]:hover{background:#2c5282}.admin-settings__dialog-buttons button:disabled{opacity:.5;cursor:not-allowed}@media(max-width:600px){.admin-settings-page{padding:1.5rem 1rem}.admin-settings__form{flex-direction:column}.admin-settings__form input{min-width:0}.admin-settings__actions{flex-direction:column}}.project-management-page{max-width:1200px;margin:0 auto;padding:2rem;align-items:stretch}.project-management-page h1{text-transform:uppercase;letter-spacing:.15em}.pm-create-btn{display:inline-block;margin-top:.5rem;padding:.5rem 1.5rem;background:#2b6cb0;color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:600;text-decoration:none;transition:background .15s}.pm-create-btn:hover{background:#2c5282}.pm-status{text-align:center;color:#718096;font-size:1.05rem;margin-top:2rem}.pm-layout{display:flex;gap:2rem;width:100%;margin-top:1rem;align-items:flex-start}.pm-section-title{margin:0 0 1rem;font-size:1rem;font-weight:600;color:#2d3748;text-transform:uppercase;letter-spacing:.4px}.pm-events{flex:0 0 280px;min-width:0}.pm-events__empty{color:#a0aec0;font-size:.9rem;font-style:italic}.pm-events__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem;max-height:calc(100vh - 12rem);overflow-y:auto}.pm-events__item{display:flex;flex-direction:column;gap:.15rem;padding:.65rem .85rem;background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;font-size:.85rem}.pm-events__time{color:#a0aec0;font-size:.75rem}.pm-events__user{font-weight:600;color:#2d3748}.pm-events__message{color:#4a5568;line-height:1.4}.pm-projects{flex:1;min-width:0}.pm-list{display:flex;flex-direction:column;gap:1rem;width:100%;max-height:calc(100vh - 12rem);overflow-y:auto}.pm-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:1.25rem 1.5rem;transition:box-shadow .15s}.pm-card:hover{box-shadow:0 2px 8px #00000014}.pm-card--overdue{border-left:4px solid #e53e3e;background:#fff5f5}.pm-card--overdue .pm-card__name{color:#742a2a}.pm-card--complete{border-left:4px solid #38a169;background:#f0fff4}.pm-card--complete .pm-card__name{color:#22543d}.pm-card__header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.pm-card__name{margin:0;font-size:1.25rem;font-weight:600;color:#1a365d}.pm-card__badge{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:.2rem .6rem;border-radius:999px}.pm-card__badge--published{background:#c6f6d5;color:#22543d}.pm-card__badge--draft{background:#fefcbf;color:#744210}.pm-card__description{margin:0 0 .75rem;font-size:.95rem;color:#4a5568;line-height:1.6}.pm-card__meta{display:flex;gap:1.5rem;font-size:.8rem;color:#718096}.pm-approvals{flex:0 0 220px;min-width:0}.pm-approvals__empty{color:#a0aec0;font-size:.9rem;font-style:italic}.pm-approvals__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem;max-height:calc(100vh - 12rem);overflow-y:auto}.pm-approvals__item{display:flex;flex-direction:column;gap:.15rem;padding:.6rem .8rem;background:ivory;border:1px solid #e2e8f0;border-left:3px solid #d69e2e;border-radius:6px;font-size:.85rem;cursor:pointer;transition:box-shadow .15s}.pm-approvals__item:hover{box-shadow:0 2px 8px #00000014}.pm-approvals__module{font-weight:600;color:#2d3748}.pm-approvals__project{color:#718096;font-size:.8rem}.pm-approvals__due{font-size:.75rem;color:#a0aec0}.pm-approvals__due--overdue{color:#e53e3e;font-weight:600}@media(max-width:768px){.project-management-page{padding:1.5rem 1rem}.project-management-page h1{text-align:center;width:100%}.pm-layout{flex-direction:column}.pm-events{flex:none;width:100%}.pm-events__list{max-height:200px}.pm-approvals{flex:none;width:100%}.pm-approvals__list{max-height:200px}.pm-card__meta{flex-direction:column;gap:.25rem}}.user-picker{display:flex;flex-direction:column;gap:.5rem}.user-picker__search{width:100%;padding:.45rem .75rem;border:1px solid #cbd5e0;border-radius:6px;font-size:.85rem;outline:none;transition:border-color .15s;box-sizing:border-box}.user-picker__search:focus{border-color:#4299e1}.user-picker__list{display:flex;flex-direction:column;gap:.25rem;max-height:260px;overflow-y:auto}.user-picker__empty{color:#a0aec0;font-size:.85rem;font-style:italic;padding:.5rem 0;margin:0}.user-picker__item{display:flex;align-items:center;gap:.5rem;padding:.4rem .6rem;border-radius:6px;cursor:pointer;transition:background .1s}.user-picker__item:hover{background:#edf2f7}.user-picker__item--disabled{opacity:.65;cursor:default;background:#f7fafc}.user-picker__item--disabled:hover{background:#f7fafc}.user-picker__item input[type=checkbox]{width:1rem;height:1rem;accent-color:#2b6cb0;flex-shrink:0;cursor:pointer}.user-picker__item--disabled input[type=checkbox]{cursor:default}.user-picker__name{font-weight:600;color:#2d3748;font-size:.9rem;white-space:nowrap}.user-picker__badge{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:.1rem .5rem;border-radius:999px;background:#bee3f8;color:#2a4365;white-space:nowrap}.user-picker__email{margin-left:auto;font-size:.8rem;color:#a0aec0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-picker__perm-select{margin-left:.5rem;padding:.15rem .3rem;border:1px solid #cbd5e0;border-radius:4px;font-size:.75rem;color:#2d3748;background:#fff;cursor:pointer;flex-shrink:0}.user-picker__perm-select:focus{outline:none;border-color:#4299e1}@media(max-width:480px){.user-picker__email{display:none}.user-picker__name{white-space:normal;word-break:break-word}}.create-project-page{padding:0!important;align-items:stretch!important;width:100%}.cp-split{display:grid;grid-template-columns:1fr 1fr;height:calc(100vh - 60px);width:100%}.cp-left{padding:3rem;display:flex;flex-direction:column;align-items:center;overflow-y:hidden}.cp-left h1{text-transform:uppercase;letter-spacing:.15em}.cp-error{background:#fed7d7;color:#822727;padding:.6rem 1rem;border-radius:6px;font-size:.9rem;margin-bottom:1rem}.cp-form{margin-top:1.5rem;width:100%;max-width:480px;display:flex;flex-direction:column;gap:1.25rem}.cp-group{display:flex;flex-direction:column;gap:.35rem}.cp-group label{font-size:.85rem;font-weight:600;color:#4a5568}.cp-group input,.cp-group textarea{padding:.55rem .75rem;border:1px solid #cbd5e0;border-radius:6px;font-family:inherit;font-size:.9rem;resize:vertical}.cp-group input:focus,.cp-group textarea:focus{outline:none;border-color:#2b6cb0;box-shadow:0 0 0 2px #2b6cb026}.cp-members h3{font-size:1rem;font-weight:600;color:#2d3748;margin-bottom:.75rem}.cp-members__empty{color:#a0aec0;font-size:.9rem;font-style:italic}.cp-members__list{display:flex;flex-direction:column;gap:.3rem;max-height:240px;overflow-y:auto;border:1px solid #e2e8f0;border-radius:6px;padding:.5rem}.cp-members__item{display:flex;align-items:center;gap:.5rem;padding:.45rem .55rem;border-radius:4px;cursor:pointer;transition:background .1s}.cp-members__item:hover{background:#f7fafc}.cp-members__item--owner{background:#ebf8ff;border:1px solid #bee3f8}.cp-members__item--owner:hover{background:#ebf8ff}.cp-members__item input[type=checkbox]{width:16px;height:16px;accent-color:#2b6cb0;cursor:pointer}.cp-members__item--owner input[type=checkbox]{cursor:default}.cp-members__name{font-size:.9rem;font-weight:500;color:#2d3748}.cp-members__badge{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:#2b6cb0;color:#fff;padding:.1rem .45rem;border-radius:3px}.cp-members__email{font-size:.8rem;color:#a0aec0;margin-left:auto}.cp-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:.5rem;padding-top:1.5rem;border-top:1px solid #e2e8f0}.cp-btn{padding:.55rem 1.5rem;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s}.cp-btn--cancel{background:#edf2f7;color:#4a5568;border:1px solid #cbd5e0}.cp-btn--cancel:hover{background:#e2e8f0}.cp-btn--save{background:#2b6cb0;color:#fff;border:none}.cp-btn--save:hover{background:#2c5282}.cp-btn--save:disabled{opacity:.5;cursor:not-allowed}.cp-add-module-btn{position:sticky;bottom:1rem;align-self:flex-end;margin-top:auto;width:56px;height:56px;border-radius:50%;background:#fff;border:2px solid #cbd5e0;font-size:2rem;line-height:1;color:#2b6cb0;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001a;transition:box-shadow .15s,border-color .15s;flex-shrink:0}.cp-add-module-btn:hover{border-color:#2b6cb0;box-shadow:0 4px 14px #2b6cb033}.cp-right{background:#edf2f7;padding:3rem 3rem 5rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem;overflow-y:auto;position:relative}.cp-module-card{background:#fff;border-radius:8px;padding:1.25rem;box-shadow:0 1px 4px #00000014;display:flex;flex-direction:column;gap:1rem;width:100%;max-width:480px;position:relative}.cp-module-card__remove{position:absolute;top:.5rem;right:.5rem;background:none;border:none;font-size:1.1rem;color:#a0aec0;cursor:pointer;line-height:1;padding:.1rem .3rem;border-radius:4px;transition:color .15s,background .15s}.cp-module-card__remove:hover{color:#e53e3e;background:#fed7d7}.cp-module-card__header{display:flex;align-items:center;gap:.5rem}.cp-module-card__title{flex:1;border:none;border-bottom:2px solid #e2e8f0;padding:.4rem 0;font-size:1.05rem;font-weight:600;font-family:inherit;color:#2d3748;outline:none;transition:border-color .15s}.cp-module-arrow{display:flex;justify-content:center;margin:-.5rem 0}.cp-module-arrow svg{width:22px;height:22px;color:#a0aec0}.cp-module-card__separator{border:none;border-top:1px solid #cbd5e0;margin:.75rem 0 .5rem}.cp-module-card__bottom{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.cp-module-card__pill{display:flex;align-items:center;gap:.4rem;padding:.5rem .65rem;background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;font-family:inherit;color:#a0aec0;font-size:.8rem;transition:border-color .15s,background .15s,color .15s;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.cp-module-card__pill:hover{border-color:#2b6cb0;background:#ebf8ff;color:#2b6cb0}.cp-module-card__pill--active{background:#ebf8ff;border-color:#90cdf4;color:#2b6cb0}.cp-pill__icon{width:16px;height:16px;flex-shrink:0}.cp-pill__text{overflow:hidden;text-overflow:ellipsis}.cp-modal--narrow{max-width:320px}.cp-modal__body--center{display:flex;justify-content:center;padding:1.5rem 1.25rem}.cp-date-modal__input{padding:.5rem .75rem;border:1px solid #cbd5e0;border-radius:6px;font-family:inherit;font-size:1rem;color:#2d3748;outline:none;width:100%;max-width:220px}.cp-date-modal__input:focus{border-color:#2b6cb0;box-shadow:0 0 0 2px #2b6cb026}.cp-modal__footer--spaced{justify-content:space-between}.cp-btn--small{padding:.4rem 1rem;font-size:.8rem}.cp-module-card__title::placeholder{color:#a0aec0;font-weight:400}.cp-module-card__title:focus{border-color:#2b6cb0}.cp-module-card__fields{display:flex;flex-direction:column;gap:.5rem}.cp-field-row{display:flex;align-items:center;gap:.5rem;padding:.35rem .5rem;background:#f7fafc;border-radius:4px;border:1px solid #e2e8f0}.cp-field-row__type{width:26px;height:26px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:.8rem;flex-shrink:0}.cp-field-row__type--bool{background:#c6f6d5;color:#276749}.cp-field-row__type--document{background:#bee3f8;color:#2a4365}.cp-field-row__title{flex:1;border:none;background:transparent;padding:.3rem .4rem;font-family:inherit;font-size:.85rem;color:#2d3748;outline:none}.cp-field-row__title::placeholder{color:#a0aec0}.cp-field-row__remove{background:none;border:none;font-size:1.1rem;color:#a0aec0;cursor:pointer;padding:0 .25rem;line-height:1;transition:color .1s}.cp-field-row__remove:hover{color:#e53e3e}.cp-module-card__add{display:flex;gap:.5rem}.cp-add-field-btn{padding:.35rem .75rem;border:1px dashed #cbd5e0;border-radius:4px;background:transparent;font-family:inherit;font-size:.8rem;color:#718096;cursor:pointer;transition:border-color .15s,color .15s}.cp-add-field-btn:hover{border-color:#2b6cb0;color:#2b6cb0}.cp-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.cp-modal{background:#fff;border-radius:10px;width:90%;max-width:420px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 30px #0000002e}.cp-modal__header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #e2e8f0}.cp-modal__header h3{margin:0;font-size:1rem;font-weight:600;color:#2d3748}.cp-modal__close{background:none;border:none;font-size:1.3rem;color:#a0aec0;cursor:pointer;line-height:1;padding:0}.cp-modal__close:hover{color:#e53e3e}.cp-modal__body{padding:.75rem 1.25rem;overflow-y:auto;flex:1}.cp-modal__list{display:flex;flex-direction:column;gap:.3rem}.cp-modal__footer{padding:.75rem 1.25rem;border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end}@media(max-width:768px){.cp-split{grid-template-columns:1fr;height:auto;min-height:calc(100vh - 60px)}.cp-left{padding:1.5rem 1rem;overflow-y:auto}.cp-right{padding:1.5rem 1rem;min-height:300px}}.project-page{padding:0!important;align-items:center!important;width:100%;display:flex;flex-direction:column;height:100vh;overflow:hidden}.pp-status{text-align:center;color:#718096;font-size:1rem;margin-top:3rem}.pp-status--error{color:#e53e3e}.pp-header{width:100%;max-width:560px;padding:2rem 1rem 1.25rem;flex-shrink:0;align-self:center}.pp-back{display:inline-flex;align-items:center;gap:.3rem;background:none;border:none;font-family:inherit;font-size:.85rem;color:#2b6cb0;cursor:pointer;padding:0;margin-bottom:1rem;transition:color .15s}.pp-back:hover{color:#2c5282}.pp-back svg{width:16px;height:16px}.pp-title{margin:0 0 .5rem;font-size:1.6rem;text-transform:uppercase;letter-spacing:.1em;color:#1a202c}.pp-description{margin:0 0 .75rem;color:#4a5568;font-size:.95rem;line-height:1.6}.pp-meta{display:flex;gap:1.5rem;font-size:.82rem;color:#718096}.pp-delete-project-btn{margin-top:.75rem;font-family:inherit;font-size:.8rem;font-weight:600;padding:.35rem 1rem;border:1px solid #feb2b2;border-radius:6px;background:#fff5f5;color:#c53030;cursor:pointer;transition:background .15s}.pp-delete-project-btn:hover{background:#fed7d7}.pp-modules-scroll{flex:1;overflow-y:auto;background:#edf2f7;width:100%;padding-bottom:40vh}.pp-modules-scroll--locked{overflow:hidden}.pp-modules{width:100%;max-width:680px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:1.5rem 1rem 0}.pp-module-arrow{display:flex;justify-content:center;margin:-.5rem 0}.pp-module-arrow svg{width:22px;height:22px;color:#a0aec0}.pp-module-card{background:#fff;border-radius:10px;padding:1.5rem 1.75rem;box-shadow:0 1px 4px #00000014;display:flex;flex-direction:column;gap:1.1rem;width:100%;border-left:4px solid #e2e8f0;transition:border-color .2s}.pp-module-card--complete{border-left-color:#48bb78}.pp-module-card__header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.pp-module-card__title{margin:0;font-size:1.05rem;font-weight:600;color:#2d3748}.pp-module-card__badge{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.15rem .5rem;border-radius:999px}.pp-module-card__badge--complete{background:#c6f6d5;color:#22543d}.pp-module-card__fields{display:flex;flex-direction:column;gap:.5rem}.pp-field-row{display:flex;align-items:center;gap:.6rem;padding:.45rem .6rem;background:#f7fafc;border-radius:4px;border:1px solid #e2e8f0}.pp-field-row__checkbox{width:18px;height:18px;accent-color:#2b6cb0;cursor:pointer;flex-shrink:0}.pp-field-row__label{flex:1;font-size:.9rem;color:#2d3748}.pp-field-row__label--done{text-decoration:line-through;color:#a0aec0}.pp-field-row__type{width:26px;height:26px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:.8rem;flex-shrink:0}.pp-field-row__type--document{background:#bee3f8;color:#2a4365}.pp-field-row__doc-actions{display:flex;align-items:center;gap:.5rem;margin-left:auto}.pp-doc-link,.pp-doc-update,.pp-doc-upload,.pp-doc-history{font-family:inherit;font-size:.8rem;color:#2b6cb0;font-weight:500;cursor:pointer;padding:.2rem .6rem;border:1px solid #90cdf4;border-radius:4px;background:none;line-height:1.4;transition:background .15s,border-color .15s}.pp-doc-link:hover,.pp-doc-update:hover,.pp-doc-upload:hover,.pp-doc-history:hover{background:#ebf8ff;border-color:#2b6cb0}.pp-doc-upload{border-style:dashed}.pp-doc-delete{background:none;border:none;font-family:inherit;font-size:1.1rem;color:#a0aec0;cursor:pointer;padding:0 .2rem;line-height:1;transition:color .1s}.pp-doc-delete:hover{color:#e53e3e}.pp-doc-upload:hover{background:#ebf8ff;border-color:#2b6cb0}.pp-module-card__separator{border:none;border-top:1px solid #e2e8f0;margin:.5rem 0 .25rem}.pp-module-card__bottom{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.pp-module-card__pill{display:flex;align-items:center;gap:.4rem;padding:.5rem .65rem;background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;font-family:inherit;color:#4a5568;font-size:.8rem;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.pp-module-card__pill--overdue{background:#fff5f5;border-color:#feb2b2;color:#c53030}.pp-pill__icon{width:16px;height:16px;flex-shrink:0}.pp-pill__text{overflow:hidden;text-overflow:ellipsis}.pp-approve-btn{width:100%;padding:.65rem 1rem;font-family:inherit;font-size:.85rem;font-weight:700;letter-spacing:.08em;color:#fff;background:#38a169;border:none;border-radius:6px;cursor:pointer;transition:background .15s}.pp-approve-btn:hover{background:#2f855a}.pp-approve-btn--done{background:#c6f6d5;color:#22543d;cursor:default}.pp-approve-btn--done:hover{background:#c6f6d5}.pp-approve-btn--unapprove{background:#fed7d7;color:#9b2c2c}.pp-approve-btn--unapprove:hover{background:#feb2b2}.pp-confirm-text{font-size:.95rem;color:#2d3748;line-height:1.5;margin-bottom:1.25rem}.pp-confirm-actions{display:flex;gap:.75rem;justify-content:flex-end}.pp-confirm-yes,.pp-confirm-no{font-family:inherit;font-size:.85rem;font-weight:600;padding:.45rem 1.4rem;border-radius:6px;cursor:pointer;border:none}.pp-confirm-yes{background:#e53e3e;color:#fff}.pp-confirm-yes:hover{background:#c53030}.pp-confirm-no{background:#edf2f7;color:#2d3748}.pp-confirm-no:hover{background:#e2e8f0}.pp-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:1000}.pp-modal{background:#fff;border-radius:10px;width:95%;max-width:480px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 30px #0000002e}.pp-modal__header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #e2e8f0}.pp-modal__title{margin:0;font-size:1rem;font-weight:600;color:#2d3748}.pp-modal__close{background:none;border:none;font-size:1.4rem;color:#a0aec0;cursor:pointer;padding:0 .2rem;line-height:1;transition:color .1s}.pp-modal__close:hover{color:#e53e3e}.pp-modal__body{padding:1rem 1.25rem;overflow-y:auto}.pp-modal__empty{color:#a0aec0;font-size:.9rem;text-align:center;margin:1rem 0}.pp-history-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.6rem}.pp-history-item{display:flex;align-items:center;justify-content:space-between;padding:.6rem .75rem;background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px}.pp-history-item__info{display:flex;flex-direction:column;gap:.15rem}.pp-history-item__version{font-size:.85rem;font-weight:600;color:#2d3748}.pp-history-item__current{font-weight:500;color:#38a169;font-size:.8rem}.pp-history-item__date{font-size:.75rem;color:#a0aec0}.pp-members-btn{background:none;border:none;font-family:inherit;font-size:.82rem;color:#2b6cb0;cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:2px}.pp-members-btn:hover{color:#2c5282}.pp-modal--members{width:400px;max-width:92vw}.pp-member-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.25rem}.pp-member-item{display:flex;align-items:center;justify-content:space-between;padding:.45rem .5rem;border-radius:6px;transition:background .1s}.pp-member-item:hover{background:#f7fafc}.pp-member-info{display:flex;align-items:center;gap:.5rem;min-width:0}.pp-member-name{font-size:.88rem;color:#1a202c;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pp-member-badge{font-size:.65rem;font-weight:600;text-transform:uppercase;background:#ebf4ff;color:#3182ce;padding:.12rem .45rem;border-radius:10px;flex-shrink:0}.pp-member-remove{background:none;border:none;color:#e53e3e;font-size:1.2rem;cursor:pointer;padding:0 .3rem;line-height:1;flex-shrink:0}.pp-member-remove:hover{color:#c53030}.pp-member-remove:disabled{opacity:.5;cursor:default}.pp-member-add{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e2e8f0}.pp-member-add__title{margin:0 0 .4rem;font-size:.78rem;font-weight:600;color:#4a5568;text-transform:uppercase;letter-spacing:.04em}.pp-member-add__search{width:100%;padding:.4rem .6rem;border:1px solid #cbd5e0;border-radius:6px;font-size:.85rem;outline:none;box-sizing:border-box;transition:border-color .15s}.pp-member-add__search:focus{border-color:#4299e1}.pp-member-add__results{list-style:none;margin:.35rem 0 0;padding:0;max-height:180px;overflow-y:auto}.pp-member-add__item{display:flex;align-items:center;justify-content:space-between;padding:.35rem .5rem;border-radius:4px;font-size:.85rem}.pp-member-add__item:hover{background:#f7fafc}.pp-member-add__btn{padding:.2rem .6rem;border:none;border-radius:5px;background:#2b6cb0;color:#fff;font-size:.75rem;font-weight:600;cursor:pointer;flex-shrink:0}.pp-member-add__btn:hover:not(:disabled){background:#2c5282}.pp-member-add__btn:disabled{opacity:.5;cursor:default}@media(max-width:640px){.pp-header,.pp-modules{max-width:100%}.pp-module-card__bottom{grid-template-columns:1fr}.pp-module-card{padding:1rem}.pp-field-row__doc-actions{flex-wrap:wrap}}.document-center-page{max-width:1200px;margin:0 auto;padding:2rem;align-items:stretch}.document-center-page h1{text-transform:uppercase;letter-spacing:.15em}.dc-layout{display:flex;gap:1.5rem;width:100%;margin-top:.75rem;align-items:flex-start}.dc-section-title{margin:0 0 .5rem;font-size:.88rem;font-weight:600;color:#2d3748;text-transform:uppercase;letter-spacing:.4px}.dc-sidebar{flex:0 0 200px;display:flex;flex-direction:column;gap:.25rem;min-width:0;position:sticky;top:2rem;align-self:flex-start}.dc-sidebar__btn{text-align:left;padding:.6rem 1rem;border:none;border-radius:6px;background:transparent;font-size:.9rem;font-weight:500;color:#4a5568;cursor:pointer;transition:background .1s,color .1s}.dc-sidebar__btn:hover{background:#edf2f7}.dc-sidebar__btn--active{background:#ebf8ff;color:#2b6cb0;font-weight:600}.dc-sidebar__add{padding:.6rem 1rem;border:none;border-radius:6px;background:#2b6cb0;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s;margin-bottom:.5rem;width:100%}.dc-sidebar__add:hover{background:#2c5282}.dc-sidebar__divider{border:none;border-top:1px solid #e2e8f0;margin:.25rem 0}.dc-sidebar__btn--filter{margin-top:.25rem;padding-top:.6rem}.dc-filters{display:flex;flex-direction:column;gap:.35rem;padding:.5rem .25rem}.dc-filters__label{font-size:.78rem;font-weight:600;color:#4a5568;text-transform:uppercase;letter-spacing:.3px}.dc-filters__select{padding:.35rem .5rem;border:1px solid #cbd5e0;border-radius:5px;font-size:.85rem;color:#2d3748;background:#fff;cursor:pointer}.dc-filters__search{width:100%;padding:.35rem .5rem;border:1px solid #cbd5e0;border-radius:5px;font-size:.82rem;outline:none;box-sizing:border-box;transition:border-color .15s}.dc-filters__search:focus{border-color:#4299e1}.dc-filters__user-list{display:flex;flex-direction:column;gap:.15rem;max-height:180px;overflow-y:auto}.dc-filters__user-item{display:flex;align-items:center;gap:.4rem;padding:.3rem .5rem;border-radius:5px;font-size:.82rem;color:#4a5568;cursor:pointer;transition:background .1s}.dc-filters__user-item:hover{background:#edf2f7}.dc-filters__user-item--active{background:#ebf8ff;color:#2b6cb0;font-weight:600}.dc-content{flex:1;min-width:0}.dc-content__empty{color:#a0aec0;font-style:italic;font-size:.95rem}@media(max-width:768px){.document-center-page{padding:1.5rem .75rem}.document-center-page h1{text-align:center;width:100%}.dc-layout{flex-direction:column;gap:1rem}.dc-sidebar{flex:none;flex-direction:row;flex-wrap:wrap;gap:.35rem;overflow-x:visible;width:100%;position:static}.dc-sidebar__add{width:100%;margin-bottom:.25rem}.dc-sidebar__btn{padding:.45rem .75rem;font-size:.82rem}.dc-sidebar__btn--filter{margin-top:0;border-top:none;padding-top:.45rem}.dc-filters{width:100%;flex-basis:100%}.dc-doc-col--owner,.dc-doc-col--date{display:none}.dc-doc-col--cls{width:4.5rem;padding-left:.5rem;font-size:.6rem}.dc-doc-col--name{font-size:.82rem}.dc-doc-table__head{padding:.4rem .6rem}.dc-doc-row{padding:.5rem .6rem;font-size:.82rem}.dc-doc-detail{flex-wrap:wrap;padding:.5rem .6rem;gap:.4rem}.dc-doc-detail__btn{padding:.3rem .6rem;font-size:.75rem}.dc-history-cols{flex-direction:column}.dc-history-col:first-child{border-right:none;border-bottom:1px solid #e2e8f0}.dc-section-title{text-align:center;font-size:.9rem}}.dc-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.dc-modal{background:#fff;border-radius:10px;width:480px;max-width:90vw;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 30px #00000026}.dc-modal__header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #e2e8f0}.dc-modal__header h3{margin:0;font-size:1.05rem;color:#2d3748}.dc-modal__header--center{justify-content:center;position:relative}.dc-modal__header--center h3{text-transform:uppercase;letter-spacing:.1em;font-size:1rem}.dc-modal__header--center .dc-modal__close{position:absolute;right:1.25rem}.dc-modal__close{background:none;border:none;font-size:1.4rem;color:#a0aec0;cursor:pointer;line-height:1}.dc-modal__close:hover{color:#4a5568}.dc-modal__body{padding:1.25rem;overflow-y:auto}.dc-modal__footer{display:flex;justify-content:flex-end;gap:.5rem;padding:.75rem 1.25rem;border-top:1px solid #e2e8f0}.dc-btn{padding:.5rem 1.25rem;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s}.dc-btn--cancel{background:#e2e8f0;color:#4a5568}.dc-btn--cancel:hover{background:#cbd5e0}.dc-btn--upload{background:#2b6cb0;color:#fff}.dc-btn--upload:hover:not(:disabled){background:#2c5282}.dc-btn--upload:disabled{opacity:.5;cursor:not-allowed}.dc-form-label{display:block;font-size:.82rem;font-weight:600;color:#4a5568;margin-bottom:.3rem;margin-top:.8rem}.dc-form-label:first-child{margin-top:0}.dc-form-file{display:block;width:100%;font-size:.9rem}.dc-form-input{display:block;width:100%;padding:.45rem .6rem;border:1px solid #cbd5e0;border-radius:6px;font-size:.9rem;box-sizing:border-box}.dc-form-input:focus{outline:none;border-color:#3182ce;box-shadow:0 0 0 2px #3182ce33}.dc-form-radios{display:flex;gap:1rem}.dc-form-radio{display:flex;align-items:center;gap:.3rem;font-size:.9rem;color:#2d3748;cursor:pointer}.dc-doc-table{border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.dc-doc-table__head{display:flex;align-items:center;padding:.35rem .75rem;background:#edf2f7;font-size:.7rem;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid #e2e8f0}.dc-doc-col--name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.dc-doc-col--owner{width:8.5rem;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-left:.75rem}.dc-doc-col--date{width:6rem;flex-shrink:0;text-align:center;padding-left:.75rem;font-size:.78rem}.dc-doc-col--cls{width:6rem;flex-shrink:0;text-align:center;padding-left:.75rem}.dc-doc-row-wrap{border-bottom:1px solid #e2e8f0}.dc-doc-row-wrap:last-child{border-bottom:none}.dc-doc-sentinel{display:flex;align-items:center;justify-content:center;padding:.25rem .75rem;min-height:1px}.dc-doc-sentinel__text{font-size:.82rem;color:#a0aec0;font-style:italic}.dc-doc-row{display:flex;align-items:center;padding:.32rem .75rem;font-size:.82rem;color:#2d3748;cursor:pointer;transition:background .1s;min-height:0}.dc-doc-row:hover{background:#f7fafc}.dc-doc-row--open{background:#ebf8ff}.dc-doc-tag{display:inline-block;font-size:.6rem;font-weight:600;padding:.1rem .4rem;border-radius:9999px;text-transform:uppercase;letter-spacing:.3px;line-height:1.4}.dc-doc-tag--notes{background:#fefcbf;color:#975a16}.dc-doc-tag--general{background:#bee3f8;color:#2a4365}.dc-doc-tag--contract{background:#c6f6d5;color:#276749}.dc-doc-detail{display:flex;align-items:center;gap:.35rem;padding:.3rem .75rem .35rem;background:#f7fafc;border-top:1px solid #edf2f7}.dc-doc-detail__btn{display:inline-flex;align-items:center;padding:.25rem .65rem;border:1px solid #cbd5e0;border-radius:5px;background:#fff;font-size:.75rem;font-weight:500;color:#2d3748;cursor:pointer;text-decoration:none;transition:background .12s,border-color .12s}.dc-doc-detail__btn:hover{background:#edf2f7;border-color:#a0aec0}.dc-doc-detail__btn--danger{color:#c53030;border-color:#feb2b2}.dc-doc-detail__btn--danger:hover{background:#fff5f5;border-color:#fc8181}.dc-btn--danger{background:#c53030;color:#fff}.dc-btn--danger:hover:not(:disabled){background:#9b2c2c}.dc-btn--danger:disabled{opacity:.5;cursor:not-allowed}.dc-modal--sm{width:400px;max-width:90vw}.dc-add-body{display:flex;flex-direction:column;gap:0}.dc-add-body .dc-update-drop{margin-bottom:.75rem}.dc-update-body{display:flex;flex-direction:column;align-items:center;padding:1.5rem 1.25rem;text-align:center}.dc-update-docname{margin:0 0 .25rem;font-size:.95rem;font-weight:600;color:#2d3748}.dc-update-hint{margin:0 0 1.25rem;font-size:.82rem;color:#a0aec0}.dc-update-drop{display:flex;align-items:center;justify-content:center;width:100%;padding:1.5rem 1rem;border:2px dashed #cbd5e0;border-radius:8px;cursor:pointer;transition:border-color .15s,background .15s}.dc-update-drop:hover{border-color:#90cdf4;background:#ebf8ff}.dc-update-drop__input{display:none}.dc-update-drop__label{font-size:.88rem;color:#4a5568;font-weight:500}.dc-modal--wide{width:720px;max-width:95vw}.dc-history-body{padding:0!important}.dc-history-cols{display:flex;min-height:300px}.dc-history-col{flex:1;padding:1rem 1.25rem;overflow-y:auto;max-height:55vh}.dc-history-col:first-child{border-right:1px solid #e2e8f0}.dc-history-col__title{margin:0 0 .75rem;font-size:.85rem;font-weight:700;color:#2d3748;text-transform:uppercase;letter-spacing:.3px}.dc-history-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.dc-history-item{padding:.5rem .6rem;border-radius:6px;background:#f7fafc;border:1px solid #e2e8f0}.dc-history-item--link{display:block;text-decoration:none;color:inherit;cursor:pointer;transition:background .12s,border-color .12s}.dc-history-item--link:hover{background:#edf2f7;border-color:#a0aec0}.dc-history-item--current{background:#ebf8ff;border-color:#90cdf4}.dc-history-item--link.dc-history-item--current:hover{background:#bee3f8}.dc-history-item__row{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.dc-history-item__label{font-weight:600;font-size:.85rem;color:#2d3748}.dc-history-item__badge{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px;padding:.1rem .45rem;border-radius:999px;background:#bee3f8;color:#2a4365}.dc-history-item__user{font-weight:600;font-size:.85rem;color:#2d3748}.dc-history-item__date{font-size:.75rem;color:#a0aec0}.dc-history-item__msg{display:block;margin-top:.2rem;font-size:.82rem;color:#4a5568}.dc-perm-body{display:flex;flex-direction:column;gap:1rem}.dc-perm-section{border-bottom:1px solid #e2e8f0;padding-bottom:.75rem}.dc-perm-section:last-child{border-bottom:none;padding-bottom:0}.dc-perm-section__title{font-size:.82rem;font-weight:600;color:#4a5568;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.04em}.dc-perm-user{display:flex;align-items:center;justify-content:space-between;padding:.4rem 0;gap:.5rem}.dc-perm-user--owner{background:#f7fafc;border-radius:6px;padding:.5rem .6rem}.dc-perm-user__name{font-size:.88rem;color:#1a202c;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dc-perm-user__badge{font-size:.7rem;font-weight:600;text-transform:uppercase;background:#ebf4ff;color:#3182ce;padding:.15rem .5rem;border-radius:10px}.dc-perm-user__actions{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.dc-perm-select{font-size:.82rem;padding:.25rem .5rem;border:1px solid #cbd5e0;border-radius:4px;background:#fff;cursor:pointer}.dc-perm-select:disabled{opacity:.6;cursor:default}.dc-perm-remove{background:none;border:none;color:#e53e3e;font-size:1.1rem;cursor:pointer;padding:0 .3rem;line-height:1}.dc-perm-remove:hover{color:#c53030}.dc-perm-list{list-style:none;margin:0;padding:0}.dc-perm-empty{font-size:.82rem;color:#a0aec0;margin:0}.dc-perm-transfer{margin-top:.5rem}.dc-perm-transfer__row{display:flex;gap:.4rem;flex-wrap:wrap;align-items:center}.dc-perm-transfer__row .dc-perm-select{flex:1;min-width:120px}.dc-perm-add-results{list-style:none;margin:.4rem 0 0;padding:0;max-height:180px;overflow-y:auto}.dc-perm-add-item{display:flex;align-items:center;justify-content:space-between;padding:.35rem .5rem;border-radius:4px;font-size:.85rem}.dc-perm-add-item:hover{background:#f7fafc}.dc-btn--link{background:none;border:none;color:#3182ce;cursor:pointer;font-size:.82rem;padding:0;text-decoration:underline}.dc-btn--link:hover{color:#2b6cb0}.dc-btn--sm{font-size:.78rem;padding:.25rem .6rem}@media(max-width:600px){.dc-perm-transfer__row{flex-direction:column}.dc-perm-transfer__row .dc-perm-select{width:100%}.dc-perm-user__actions{flex-wrap:wrap}}.usm{position:relative}.usm__trigger{display:flex;align-items:center;justify-content:center;background:none;border:none;color:#ffffffb3;cursor:pointer;padding:4px;border-radius:4px;transition:color .15s,background .15s}.usm__trigger:hover{color:#fff;background:#ffffff1f}.usm__panel{position:absolute;top:calc(100% + 8px);right:0;width:280px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 8px 24px #00000024;padding:1rem 1.1rem;z-index:1100;animation:usmFadeIn .12s ease-out}@keyframes usmFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.usm__heading{margin:0 0 .75rem;font-size:.82rem;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.04em}.usm__loading{margin:0;font-size:.85rem;color:#a0aec0}.usm__row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.55rem 0}.usm__row+.usm__row{border-top:1px solid #f0f0f0}.usm__label{font-size:.85rem;color:#2d3748;font-weight:500}.usm__select{padding:.3rem .5rem;border:1px solid #cbd5e0;border-radius:5px;font-size:.82rem;color:#2d3748;background:#fff;cursor:pointer;outline:none;transition:border-color .15s}.usm__select:focus{border-color:#63b3ed}.usm__toggle{position:relative;display:inline-block;width:38px;height:22px;flex-shrink:0}.usm__toggle input{opacity:0;width:0;height:0}.usm__toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:#cbd5e0;border-radius:22px;cursor:pointer;transition:background .2s}.usm__toggle-slider:before{content:"";position:absolute;width:16px;height:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform .2s}.usm__toggle input:checked+.usm__toggle-slider{background:#48bb78}.usm__toggle input:checked+.usm__toggle-slider:before{transform:translate(16px)}@media(max-width:600px){.usm__panel{right:-1rem;width:260px}.usm__trigger{color:#fffc}}.notif-bell{position:relative}.notif-bell__btn{background:none;border:none;color:#e0e0e0;cursor:pointer;padding:6px;position:relative;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background .15s}.notif-bell__btn:hover{background:#ffffff1a;color:#fff}.notif-bell__badge{position:absolute;top:1px;right:0;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;line-height:16px;text-align:center;pointer-events:none}.notif-panel{position:absolute;top:calc(100% + 8px);right:0;width:340px;max-height:420px;background:#1e293b;border:1px solid #334155;border-radius:10px;box-shadow:0 8px 24px #00000059;display:flex;flex-direction:column;z-index:1000;overflow:hidden}.notif-panel__header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #334155}.notif-panel__title{font-size:14px;font-weight:600;color:#f1f5f9}.notif-panel__mark-all{background:none;border:none;color:#60a5fa;font-size:12px;cursor:pointer;padding:2px 6px;border-radius:4px}.notif-panel__mark-all:hover{background:#60a5fa1f}.notif-panel__list{overflow-y:auto;flex:1}.notif-panel__empty{padding:32px 16px;text-align:center;color:#94a3b8;font-size:13px}.notif-item{display:flex;align-items:flex-start;gap:10px;width:100%;padding:10px 16px;background:none;border:none;border-bottom:1px solid #1e293b;cursor:pointer;text-align:left;color:#cbd5e1;font-size:13px;transition:background .12s}.notif-item:hover{background:#ffffff0a}.notif-item--unread{background:#60a5fa0f}.notif-item--unread:hover{background:#60a5fa1f}.notif-item__dot{flex-shrink:0;width:8px;height:8px;margin-top:4px}.notif-item__dot span{display:block;width:8px;height:8px;border-radius:50%;background:#60a5fa}.notif-item__body{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.notif-item__msg{color:#e2e8f0;line-height:1.4;word-break:break-word}.notif-item--unread .notif-item__msg{font-weight:600}.notif-item__time{font-size:11px;color:#64748b}@media(max-width:700px){.notif-panel{width:290px;right:-40px}}.app{min-height:100vh;background-color:#fff}.nav-bar{background-color:#1a365d;color:#fff}.nav-bar__top{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem}.nav-logo-link{display:flex;align-items:center;margin-right:1.5rem;flex-shrink:0}.nav-logo{height:40px;width:auto;display:block}.nav-hamburger{display:none;background:none;border:none;color:#fff;font-size:1.4rem;cursor:pointer;padding:.25rem}.nav-dropdown{display:none}.nav-links{display:flex;gap:1.5rem}.nav-links a{color:#ffffffb3;text-decoration:none;font-weight:500;padding:.25rem 0;border-bottom:2px solid transparent;transition:color .2s,border-color .2s}.nav-links a:hover{color:#fff}.nav-links a.active{color:#fff;border-bottom-color:#fff}.nav-right{display:flex;align-items:center;gap:1rem}.nav-user{font-size:.875rem;opacity:.8}.nav-logout{padding:.35rem .75rem;background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:4px;font-size:.8rem;cursor:pointer;transition:background .2s}.nav-logout:hover{background:#ffffff40}.lang-toggle{display:flex;align-items:center;gap:.4rem}.lang-label{font-size:.75rem;color:#ffffff73;font-weight:500;transition:color .2s;-webkit-user-select:none;user-select:none}.lang-label--active{color:#fff}.lang-switch{position:relative;width:36px;height:20px;background:#ffffff40;border:none;border-radius:10px;cursor:pointer;padding:0;transition:background .2s}.lang-switch:hover{background:#ffffff59}.lang-switch__thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform .2s}.lang-switch--zh .lang-switch__thumb{transform:translate(16px)}.page{display:flex;flex-direction:column;align-items:center;gap:1rem;padding-top:4rem;padding-left:1rem;padding-right:1rem;background-color:#fff;box-sizing:border-box;animation:pageFadeIn .2s ease-out}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.page h1{color:#1a365d}.subtitle{color:#718096}.status{padding:.5rem 1rem;border-radius:8px;font-weight:500}.status.healthy{background-color:#c6f6d5;color:#22543d}.status.error{background-color:#fed7d7;color:#822727}.primary-btn{padding:.6rem 1.5rem;background-color:#2b6cb0;color:#fff;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:background-color .2s}.primary-btn:hover{background-color:#2c5282}@media(max-width:600px){.nav-bar{position:relative}.nav-bar__top{justify-content:space-between}.nav-logo-link{margin-right:0;position:absolute;left:50%;transform:translate(-50%)}.nav-logo{height:28px}.nav-links,.nav-right{display:none!important}.nav-hamburger{display:block;margin-left:auto}.nav-dropdown{display:none;flex-direction:column;gap:.75rem;padding:.75rem 1.5rem 1rem;border-top:1px solid rgba(255,255,255,.15);position:absolute;top:100%;left:0;right:0;background-color:#1a365d;z-index:1000;box-shadow:0 4px 12px #0003}.nav-dropdown--open{display:flex}.nav-dropdown a{color:#fffc;text-decoration:none;font-weight:500;font-size:.95rem;padding:.3rem 0;transition:color .15s}.nav-dropdown a:hover,.nav-dropdown a.active{color:#fff}.nav-dropdown__lang{display:flex;align-items:center;gap:.4rem}.nav-dropdown__user{font-size:.8rem;opacity:.7}.page{padding-top:2rem}.page h1{font-size:1.3rem;text-align:center;width:100%}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#213547;background-color:#171c4d;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{min-width:320px;min-height:100vh}
