:root{--color-primary: #3b82f6;--color-primary-hover: #2563eb;--color-primary-light: #eff6ff;--color-success: #10b981;--color-success-light: #d1fae5;--color-success-dark: #065f46;--color-warning: #f59e0b;--color-warning-light: #fef3c7;--color-warning-dark: #92400e;--color-danger: #ef4444;--color-danger-light: #fee2e2;--color-danger-dark: #991b1b;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--sidebar-width: 260px;--sidebar-collapsed-width: 72px;--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--color-gray-50);color:var(--color-gray-900);line-height:1.5;min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}img{max-width:100%;display:block}.app-layout{display:flex;min-height:100vh}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background:var(--color-gray-900);display:flex;flex-direction:column;z-index:100;transition:transform var(--transition-slow)}.sidebar-header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-gray-700)}.sidebar-logo{display:flex;align-items:center;gap:var(--spacing-sm)}.sidebar-logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--color-primary) 0%,#1d4ed8 100%);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff}.sidebar-logo-text{display:flex;flex-direction:column}.sidebar-logo-title{font-size:16px;font-weight:700;color:#fff}.sidebar-logo-subtitle{font-size:11px;color:var(--color-gray-400);text-transform:uppercase;letter-spacing:.5px}.sidebar-nav{flex:1;padding:var(--spacing-md);overflow-y:auto}.sidebar-nav-label{font-size:11px;font-weight:600;color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.5px;padding:var(--spacing-md) var(--spacing-sm) var(--spacing-sm)}.sidebar-link{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);color:var(--color-gray-300);font-weight:500;transition:all var(--transition-fast);margin-bottom:4px}.sidebar-link:hover{background:var(--color-gray-800);color:#fff}.sidebar-link.active{background:var(--color-primary);color:#fff}.sidebar-link-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:16px}.sidebar-footer{padding:var(--spacing-md);border-top:1px solid var(--color-gray-700)}.sidebar-user{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);border-radius:var(--radius-md);transition:background var(--transition-fast)}.sidebar-user:hover{background:var(--color-gray-800)}.sidebar-user-avatar{width:36px;height:36px;background:var(--color-gray-700);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#fff}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:13px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:11px;color:var(--color-gray-400)}.sidebar-toggle{display:none;position:fixed;bottom:var(--spacing-lg);right:var(--spacing-lg);width:56px;height:56px;background:var(--color-gray-900);border:none;border-radius:var(--radius-full);color:#fff;font-size:24px;box-shadow:var(--shadow-lg);z-index:99;align-items:center;justify-content:center}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:99}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column}.main-header{position:sticky;top:0;background:#fff;border-bottom:1px solid var(--color-gray-200);padding:var(--spacing-md) var(--spacing-xl);display:flex;align-items:center;justify-content:space-between;z-index:50}.main-header-title{font-size:18px;font-weight:600}.main-body{flex:1;padding:var(--spacing-xl)}.page{display:flex;flex-direction:column;gap:var(--spacing-lg)}.page-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);flex-wrap:wrap}.page-title{font-size:24px;font-weight:700;color:var(--color-gray-900)}.page-subtitle{font-size:14px;color:var(--color-gray-500);margin-top:2px}.card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--color-gray-200);box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-gray-100);flex-wrap:wrap}.card-title{font-size:16px;font-weight:600;color:var(--color-gray-900)}.card-subtitle{font-size:13px;color:var(--color-gray-500)}.card-body{padding:var(--spacing-lg)}.card-footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-gray-100);background:var(--color-gray-50);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.stat-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--color-gray-200);padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-sm)}.stat-card-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:20px}.stat-card-icon.blue{background:var(--color-primary-light);color:var(--color-primary)}.stat-card-icon.green{background:var(--color-success-light);color:var(--color-success)}.stat-card-icon.yellow{background:var(--color-warning-light);color:var(--color-warning)}.stat-card-icon.red{background:var(--color-danger-light);color:var(--color-danger)}.stat-card-label{font-size:13px;color:var(--color-gray-500);font-weight:500}.stat-card-value{font-size:28px;font-weight:700;color:var(--color-gray-900);line-height:1.2}.stat-card-meta{font-size:12px;color:var(--color-gray-400)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);font-size:13px;font-weight:500;border-radius:var(--radius-md);border:1px solid transparent;transition:all var(--transition-fast);white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-secondary{background:#fff;border-color:var(--color-gray-300);color:var(--color-gray-700)}.btn-secondary:hover:not(:disabled){background:var(--color-gray-50);border-color:var(--color-gray-400)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-success{background:var(--color-success);color:#fff}.btn-success:hover:not(:disabled){background:#059669}.btn-ghost{background:transparent;color:var(--color-gray-600)}.btn-ghost:hover:not(:disabled){background:var(--color-gray-100)}.btn-sm{padding:6px 10px;font-size:12px}.btn-lg{padding:var(--spacing-md) var(--spacing-lg);font-size:15px}.btn-icon{width:36px;height:36px;padding:0}.btn-icon.btn-sm{width:28px;height:28px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:13px;font-weight:500;color:var(--color-gray-700)}.form-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:14px;border:1px solid var(--color-gray-300);border-radius:var(--radius-md);background:#fff;transition:all var(--transition-fast);color:var(--color-gray-900)}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.form-input::placeholder{color:var(--color-gray-400)}.form-input:disabled{background:var(--color-gray-100);cursor:not-allowed}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 8px center;background-repeat:no-repeat;background-size:20px;padding-right:36px}textarea.form-input{resize:vertical;min-height:100px}.form-row{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.form-row>*{flex:1;min-width:200px}.form-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.table-wrapper{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--color-gray-200)}.table{width:100%;border-collapse:collapse;font-size:13px}.table th{background:var(--color-gray-50);padding:var(--spacing-sm) var(--spacing-md);text-align:left;font-weight:600;color:var(--color-gray-600);border-bottom:1px solid var(--color-gray-200);white-space:nowrap}.table td{padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-gray-100);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:var(--color-gray-50)}.table-empty{padding:var(--spacing-2xl);text-align:center;color:var(--color-gray-500)}.badge{display:inline-flex;align-items:center;padding:3px 10px;font-size:12px;font-weight:500;border-radius:var(--radius-full)}.badge-success{background:var(--color-success-light);color:var(--color-success-dark)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning-dark)}.badge-danger{background:var(--color-danger-light);color:var(--color-danger-dark)}.badge-info{background:var(--color-primary-light);color:#1e40af}.badge-muted{background:var(--color-gray-100);color:var(--color-gray-600)}.alert{padding:var(--spacing-md);border-radius:var(--radius-md);font-size:14px;display:flex;align-items:flex-start;gap:var(--spacing-sm)}.alert-error{background:var(--color-danger-light);color:var(--color-danger-dark);border:1px solid #fecaca}.alert-success{background:var(--color-success-light);color:var(--color-success-dark);border:1px solid #a7f3d0}.alert-warning{background:var(--color-warning-light);color:var(--color-warning-dark);border:1px solid #fde68a}.alert-info{background:var(--color-primary-light);color:#1e40af;border:1px solid #bfdbfe}.panel{position:fixed;top:0;right:0;width:100%;max-width:600px;height:100vh;background:#fff;box-shadow:var(--shadow-lg);z-index:200;display:flex;flex-direction:column;animation:slideIn var(--transition-slow)}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.panel-overlay{position:fixed;inset:0;background:#00000080;z-index:199}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--color-gray-200)}.panel-title{font-size:18px;font-weight:600}.panel-body{flex:1;overflow-y:auto;padding:var(--spacing-lg)}.panel-footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-gray-200);background:var(--color-gray-50)}.tabs{display:flex;gap:4px;padding:4px;background:var(--color-gray-100);border-radius:var(--radius-md);overflow-x:auto}.tab{padding:var(--spacing-sm) var(--spacing-md);font-size:13px;font-weight:500;color:var(--color-gray-600);background:transparent;border:none;border-radius:var(--radius-sm);transition:all var(--transition-fast);white-space:nowrap}.tab:hover{color:var(--color-gray-900)}.tab.active{background:#fff;color:var(--color-gray-900);box-shadow:var(--shadow-sm)}.pagination{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md)}.pagination-info{font-size:13px;color:var(--color-gray-500);margin:0 var(--spacing-md)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);background:linear-gradient(135deg,var(--color-gray-900) 0%,#1e3a5f 100%)}.login-card{width:100%;max-width:420px;background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:var(--spacing-2xl)}.login-header{text-align:center;margin-bottom:var(--spacing-xl)}.login-logo{width:64px;height:64px;background:linear-gradient(135deg,var(--color-primary) 0%,#1d4ed8 100%);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:#fff;margin:0 auto var(--spacing-md)}.login-title{font-size:24px;font-weight:700;color:var(--color-gray-900);margin-bottom:var(--spacing-xs)}.login-subtitle{font-size:14px;color:var(--color-gray-500)}.login-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.empty-state{text-align:center;padding:var(--spacing-2xl)}.empty-state-icon{width:64px;height:64px;background:var(--color-gray-100);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto var(--spacing-md);color:var(--color-gray-400)}.empty-state-title{font-size:16px;font-weight:600;color:var(--color-gray-900);margin-bottom:var(--spacing-xs)}.empty-state-text{font-size:14px;color:var(--color-gray-500)}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-md)}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-label{font-size:12px;color:var(--color-gray-500);font-weight:500}.detail-value{font-size:14px;color:var(--color-gray-900);word-break:break-word}.detail-value.large{font-size:18px;font-weight:600}.thumbnail{width:48px;height:36px;object-fit:cover;border-radius:var(--radius-sm);background:var(--color-gray-100)}.thumbnail-placeholder{width:48px;height:36px;background:var(--color-gray-100);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--color-gray-400)}.section{display:flex;flex-direction:column;gap:var(--spacing-md)}.section-title{font-size:14px;font-weight:600;color:var(--color-gray-900);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-gray-200)}.text-muted{color:var(--color-gray-500)}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.text-sm{font-size:13px}.text-xs{font-size:12px}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-mono{font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:12px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.w-full{width:100%}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.loading{display:flex;align-items:center;justify-content:center;padding:var(--spacing-2xl);color:var(--color-gray-500)}.spinner{width:24px;height:24px;border:2px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--spacing-sm)}.photo-item{position:relative;aspect-ratio:4 / 3;overflow:hidden;border-radius:var(--radius-md);border:2px solid var(--color-gray-200);background:var(--color-gray-100);cursor:pointer;padding:0;transition:border-color .2s,box-shadow .2s,transform .2s}.photo-item:hover{border-color:var(--color-primary);box-shadow:0 4px 12px #3b82f633;transform:translateY(-2px)}.photo-item:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.photo-item:after{content:"🔍";position:absolute;bottom:6px;right:6px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#00000080;border-radius:50%;font-size:13px;opacity:0;transition:opacity .2s;pointer-events:none}.photo-item:hover:after{opacity:1}.photo-thumb{width:100%;height:100%;object-fit:cover;display:block}.lightbox-overlay{position:fixed;inset:0;z-index:9999;background:#000000eb;display:flex;align-items:center;justify-content:center;animation:lightbox-fade-in .2s ease}@keyframes lightbox-fade-in{0%{opacity:0}to{opacity:1}}.lightbox-content{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%;padding:60px 80px}.lightbox-image-wrapper{position:relative;max-width:100%;max-height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;cursor:zoom-in}.lightbox-image-wrapper.zoomed{cursor:grab;overflow:auto}.lightbox-image-wrapper.zoomed:active{cursor:grabbing}.lightbox-image{max-width:100%;max-height:calc(100vh - 120px);object-fit:contain;border-radius:var(--radius-md);user-select:none;-webkit-user-select:none;transition:transform .3s ease}.lightbox-image-wrapper.zoomed .lightbox-image{max-width:none;max-height:none;transform-origin:center center}.lightbox-close{position:absolute;top:16px;right:16px;z-index:10;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);border-radius:50%;color:#fff;font-size:20px;cursor:pointer;transition:background .2s,transform .2s}.lightbox-close:hover{background:#ffffff40;transform:scale(1.1)}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);border-radius:50%;color:#fff;font-size:22px;cursor:pointer;transition:background .2s,transform .2s}.lightbox-nav:hover{background:#ffffff40}.lightbox-prev{left:16px}.lightbox-prev:hover{transform:translateY(-50%) translate(-2px)}.lightbox-next{right:16px}.lightbox-next:hover{transform:translateY(-50%) translate(2px)}.lightbox-counter{position:absolute;bottom:20px;left:50%;transform:translate(-50%);background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;font-size:14px;font-weight:500;padding:6px 16px;border-radius:20px;letter-spacing:.5px;-webkit-user-select:none;user-select:none}.lightbox-zoom-hint{position:absolute;bottom:56px;left:50%;transform:translate(-50%);background:#00000080;color:#ffffffb3;font-size:12px;padding:4px 12px;border-radius:12px;-webkit-user-select:none;user-select:none;pointer-events:none;animation:lightbox-hint-fade 3s ease forwards}@keyframes lightbox-hint-fade{0%,70%{opacity:1}to{opacity:0}}@media(max-width:1024px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-toggle{display:flex}.sidebar-overlay.show{display:block}.main-content{margin-left:0}}@media(max-width:768px){:root{--spacing-lg: 16px;--spacing-xl: 24px}.page-header{flex-direction:column;align-items:stretch}.form-row{flex-direction:column}.form-row>*{min-width:100%}.stats-grid,.detail-grid{grid-template-columns:1fr 1fr}.panel{max-width:100%}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:var(--spacing-xs)}.lightbox-content{padding:50px 12px}.lightbox-nav{width:40px;height:40px;font-size:18px}.lightbox-prev{left:8px}.lightbox-next{right:8px}}@media(max-width:480px){.stats-grid,.detail-grid{grid-template-columns:1fr}.tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}.card-header{flex-direction:column;align-items:stretch}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr))}}
