*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--primary: #2563eb;--primary-dark: #1d4ed8;--primary-light: #dbeafe;--danger: #dc2626;--danger-dark: #b91c1c;--success: #16a34a;--warning: #d97706;--sidebar-w: 220px;--header-h: 56px;--nav-bg: #ffffff;--nav-border: #e2e8f0;--nav-text: #64748b;--nav-active-bg: rgba(37,99,235,.1);--nav-active: #2563eb;--bg: #f1f5f9;--surface: #ffffff;--border: #e2e8f0;--text: #0f172a;--text-muted: #64748b;--radius: 8px;--radius-lg: 12px;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--shadow-lg: 0 10px 30px rgba(0,0,0,.12)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;background:var(--bg);color:var(--text);line-height:1.5}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.375rem;padding:.5rem 1rem;border-radius:var(--radius);font-size:.875rem;font-weight:500;cursor:pointer;border:none;text-decoration:none;transition:all .15s ease;white-space:nowrap}.btn:disabled{opacity:.6;cursor:not-allowed}.btn--primary{background:var(--primary);color:#fff}.btn--primary:hover:not(:disabled){background:var(--primary-dark)}.btn--secondary{background:#e2e8f0;color:#374151}.btn--secondary:hover:not(:disabled){background:#cbd5e1}.btn--danger{background:var(--danger);color:#fff}.btn--danger:hover:not(:disabled){background:var(--danger-dark)}.btn--success{background:var(--success);color:#fff}.btn--warning{background:var(--warning);color:#fff}.btn--sm{padding:.25rem .625rem;font-size:.75rem}.btn--full{width:100%}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fff,#fff);padding:1.5rem}.auth-card{background:var(--surface);border-radius:16px;padding:2.5rem 2rem;width:100%;max-width:400px;box-shadow:var(--shadow-lg)}.auth-logo{display:flex;align-items:center;gap:.875rem;margin-bottom:2rem}.auth-logo__avatar{width:46px;height:46px;background:var(--primary);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:.9375rem;font-weight:700;color:#fff;letter-spacing:.5px;flex-shrink:0}.auth-logo__text{display:flex;flex-direction:column}.auth-logo__name{font-size:1.125rem;font-weight:700;color:var(--text);line-height:1.2}.auth-logo__sub{font-size:.75rem;color:var(--text-muted)}.auth-form{display:flex;flex-direction:column;gap:1.125rem}.auth-error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fef2f2;color:var(--danger);border:1px solid #fecaca;border-radius:var(--radius);font-size:.875rem}.auth-field{display:flex;flex-direction:column;gap:.375rem}.auth-label{font-size:.875rem;font-weight:500;color:#374151}.auth-input{width:100%;padding:.625rem .875rem;border:1.5px solid var(--border);border-radius:var(--radius);font-size:.9375rem;color:var(--text);background:#f8fafc;transition:border-color .15s,box-shadow .15s}.auth-input:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #2563eb1a}.auth-input-wrap{position:relative}.auth-input--pw{padding-right:2.75rem}.auth-eye{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;padding:0;transition:color .15s}.auth-eye:hover{color:var(--text)}.auth-btn{width:100%;padding:.75rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s;margin-top:.25rem}.auth-btn:hover:not(:disabled){background:var(--primary-dark)}.auth-btn:disabled{opacity:.6;cursor:not-allowed}.auth-hint{text-align:center;font-size:.8125rem;color:var(--text-muted)}.auth-hint code{background:#f1f5f9;border-radius:4px;padding:.125rem .3rem;font-size:.8rem;color:var(--text)}.app-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--nav-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:200;overflow-y:auto;box-shadow:1px 0 4px #0000000a}.sidebar__logo{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1rem 1rem;border-bottom:1px solid var(--nav-border)}.sidebar__logo-avatar{width:36px;height:36px;background:var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff;flex-shrink:0}.sidebar__logo-text{display:flex;flex-direction:column;min-width:0}.sidebar__logo-name{font-size:.9375rem;font-weight:700;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__logo-sub{font-size:.625rem;font-weight:600;letter-spacing:.08em;color:var(--nav-text)}.sidebar__nav{padding:.75rem .5rem 1.5rem;display:flex;flex-direction:column;gap:.25rem}.sidebar__group{margin-top:1rem}.sidebar__group-label{display:block;font-size:.625rem;font-weight:700;letter-spacing:.1em;color:var(--nav-text);text-transform:uppercase;padding:0 .625rem .4rem}.sidebar__link{display:flex;align-items:center;gap:.625rem;padding:.5rem .625rem;border-radius:6px;font-size:.875rem;font-weight:500;color:var(--nav-text);text-decoration:none;transition:background .12s,color .12s}.sidebar__link:hover{background:#f1f5f9;color:#0f172a}.sidebar__link--active{background:var(--nav-active-bg);color:var(--nav-active)}.sidebar__link-icon{font-size:1rem;flex-shrink:0}.app-main{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh}.app-header{height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 1.75rem;position:sticky;top:0;z-index:100;box-shadow:var(--shadow)}.app-header__title{font-size:.9375rem;font-weight:600;color:var(--text-muted)}.app-header__right{display:flex;align-items:center;gap:.75rem}.app-header__user{display:flex;align-items:center;gap:.625rem}.app-header__avatar{width:32px;height:32px;background:var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.6875rem;font-weight:700;color:#fff}.app-header__user-info{display:flex;flex-direction:column}.app-header__username{font-size:.875rem;font-weight:600;color:var(--text);line-height:1.2}.app-header__role{font-size:.6875rem;color:var(--text-muted)}.app-header__logout{background:none;border:1px solid var(--border);border-radius:var(--radius);padding:.375rem .5rem;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;transition:all .15s}.app-header__logout:hover{background:#fee2e2;color:var(--danger);border-color:#fecaca}.app-content{flex:1;padding:1.75rem}.dash{display:flex;flex-direction:column;gap:1.5rem}.dash__head{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:1rem}.dash__title{font-size:1.5rem;font-weight:700;color:var(--text)}.dash__subtitle{font-size:.875rem;color:var(--text-muted);margin-top:.25rem}.dash__stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.125rem 1.25rem;display:flex;align-items:center;gap:.875rem;box-shadow:var(--shadow)}.stat-card__icon{font-size:1.75rem}.stat-card__value{font-size:1.75rem;font-weight:700;line-height:1;color:var(--text)}.stat-card__label{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.stat--blue .stat-card__value{color:var(--primary)}.stat--green .stat-card__value{color:var(--success)}.stat--purple .stat-card__value{color:#7c3aed}.stat--orange .stat-card__value{color:var(--warning)}.stat--gray .stat-card__value{color:var(--text-muted)}.stat--red .stat-card__value{color:var(--danger)}.dash__section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;box-shadow:var(--shadow)}.dash__section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.125rem}.dash__section-title{font-size:1rem;font-weight:600;color:var(--text)}.dash__see-all{font-size:.8125rem;color:var(--primary);text-decoration:none}.dash__see-all:hover{text-decoration:underline}.dash__loading{padding:2rem;text-align:center;color:var(--text-muted)}.dash__empty{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:2.5rem;color:var(--text-muted)}.recent-list{display:flex;flex-direction:column;gap:.625rem}.recent-item{display:flex;align-items:center;gap:.875rem;padding:.75rem;border-radius:var(--radius);border:1px solid var(--border);background:#f8fafc;transition:background .1s}.recent-item:hover{background:#f1f5f9}.recent-item__thumb{width:42px;height:42px;flex-shrink:0;border-radius:6px;overflow:hidden;background:#e2e8f0;display:flex;align-items:center;justify-content:center;font-size:1.25rem}.recent-item__thumb img{width:100%;height:100%;object-fit:cover}.recent-item__info{flex:1;min-width:0}.recent-item__title{display:block;font-size:.9rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-item__meta{font-size:.75rem;color:var(--text-muted)}.recent-item__contacts{display:flex;flex-direction:column;gap:.125rem;font-size:.75rem;color:var(--text-muted)}.recent-item__badge{padding:.25rem .625rem;border-radius:999px;font-size:.6875rem;font-weight:600;white-space:nowrap}.badge--active{background:#dcfce7;color:#16a34a}.badge--inactive{background:#f1f5f9;color:#64748b}.badge--deleted{background:#fee2e2;color:var(--danger)}.page-container{max-width:1100px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem;gap:1rem;flex-wrap:wrap}.page-title{font-size:1.5rem;font-weight:700;color:var(--text)}.page-subtitle{margin-top:.25rem;font-size:.875rem;color:var(--text-muted)}.loading-spinner{display:flex;justify-content:center;align-items:center;padding:4rem}.spinner{border:3px solid var(--border);border-top:3px solid var(--primary);border-radius:50%;width:36px;height:36px;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-message{padding:1rem 1.25rem;background:#fef2f2;color:var(--danger);border:1px solid #fecaca;border-radius:var(--radius);margin:1rem 0}.job-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1.25rem}.job-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:box-shadow .15s}.job-card:hover{box-shadow:var(--shadow-md)}.job-card--inactive{opacity:.65}.job-card--deleted{opacity:.55;border-color:#fecaca;background:#fff5f5}.job-card__media{position:relative;aspect-ratio:9/16;max-height:200px;background:#1e293b;overflow:hidden;flex-shrink:0}.job-card__thumbnail{width:100%;height:100%;object-fit:cover}.job-card__no-media{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.375rem;color:#64748b;font-size:.8125rem;background:#f1f5f9}.job-card__no-media span:first-child{font-size:2rem}.job-card__badge{position:absolute;top:.5rem;right:.5rem;padding:.2rem .5rem;border-radius:4px;font-size:.6875rem;font-weight:600}.job-card__badge--inactive,.job-card__badge--video{background:#0000008c;color:#fff}.job-card__badge--active{background:#16a34a;color:#fff}.job-card__badge--deleted{background:var(--danger);color:#fff;top:.5rem;left:.5rem;right:auto}.job-card__body{padding:.875rem 1rem;display:flex;flex-direction:column;gap:.4rem;flex:1}.job-card__title{font-size:.9375rem;font-weight:600;color:var(--text)}.job-card__desc{font-size:.8125rem;color:var(--text-muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.job-card__contacts{display:flex;flex-direction:column;gap:.2rem}.job-card__contact{font-size:.8125rem;color:var(--text)}.job-card__meta{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-muted);padding-top:.375rem;border-top:1px solid var(--border)}.job-card__actions{padding:.625rem 1rem;border-top:1px solid var(--border);display:flex;gap:.5rem;flex-wrap:wrap}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5rem 2rem;text-align:center;gap:1rem}.empty-state__icon{font-size:3.5rem}.empty-state__title{font-size:1.125rem;font-weight:600;color:var(--text-muted)}.empty-state__text{font-size:.9375rem;color:var(--text-muted)}.form-layout,.job-form{display:flex;flex-direction:column;gap:1.25rem}.form-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.375rem}.form-section__title{font-size:.9375rem;font-weight:600;color:var(--text);margin-bottom:.875rem;padding-bottom:.625rem;border-bottom:1px solid var(--border)}.form-section__hint{font-size:.8125rem;color:var(--text-muted);margin-top:-.5rem;margin-bottom:.875rem}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-label{font-size:.875rem;font-weight:500;color:#374151}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 600px){.form-row{grid-template-columns:1fr}}.form-input{padding:.6rem .875rem;border:1.5px solid var(--border);border-radius:var(--radius);font-size:.9375rem;color:var(--text);background:#f8fafc;width:100%;transition:border-color .15s,box-shadow .15s}.form-input:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #2563eb1a}.form-textarea{resize:vertical;min-height:110px}.form-error{padding:.75rem 1rem;background:#fef2f2;color:var(--danger);border:1px solid #fecaca;border-radius:var(--radius);font-size:.875rem}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:.25rem}.media-upload-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.125rem}@media (max-width: 600px){.media-upload-grid{grid-template-columns:1fr}}.media-upload-item{display:flex;flex-direction:column;gap:.5rem}.media-dropzone{position:relative;width:100%;aspect-ratio:9/16;max-height:260px;border:2px dashed var(--border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;background:#f8fafc;display:flex;align-items:center;justify-content:center;transition:border-color .15s,background .15s}.media-dropzone:hover{border-color:var(--primary);background:var(--primary-light)}.media-dropzone--has-content{border-style:solid;border-color:var(--border)}.media-dropzone__placeholder{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:1.5rem;text-align:center}.media-dropzone__icon{font-size:2rem}.media-dropzone__text{font-size:.875rem;font-weight:500;color:var(--text)}.media-dropzone__hint{font-size:.75rem;color:var(--text-muted)}.media-preview{width:100%;height:100%;object-fit:cover}.media-preview--video{object-fit:contain;background:#000}.media-remove-btn{align-self:flex-start}.media-input-hidden{display:none}.user-list{list-style:none}.user-item{padding:1rem;border-bottom:1px solid var(--border);cursor:pointer}.user-item:hover{background:#f8fafc}
