:root{--color-bg: #f5f6fa;--color-surface: #ffffff;--color-text: #1a1a2e;--color-text-secondary: #6b7280;--color-border: #e2e5ea;--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-primary-light: #eff6ff;--color-danger: #dc2626;--color-danger-hover: #b91c1c;--color-danger-light: #fef2f2;--color-danger-border: #fca5a5;--color-success: #16a34a;--color-warning: #f59e0b;--color-nav-bg: #1e293b;--color-nav-text: #f1f5f9;--color-nav-prd: #991b1b;--radius: 6px;--radius-lg: 10px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 25px -5px rgba(0, 0, 0, .15);--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background:var(--color-bg);color:var(--color-text);line-height:1.5;-webkit-font-smoothing:antialiased}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;color:var(--color-text-secondary)}.loading-spinner{width:36px;height:36px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:12px}@keyframes spin{to{transform:rotate(360deg)}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#1e293b,#334155)}.login-card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:400px;padding:40px}.login-card__header{text-align:center;margin-bottom:32px}.login-card__header h1{font-size:28px;font-weight:700;color:var(--color-primary);margin-bottom:4px}.login-card__header p{color:var(--color-text-secondary);font-size:14px}.login-form__error{background:var(--color-danger-light);color:var(--color-danger);border:1px solid var(--color-danger-border);border-radius:var(--radius);padding:10px 14px;font-size:14px;margin-bottom:16px}.form-field{margin-bottom:18px}.form-field label{display:block;font-size:13px;font-weight:600;color:var(--color-text);margin-bottom:6px}.form-field input{width:100%;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:14px;font-family:var(--font-family);transition:border-color .15s,box-shadow .15s;outline:none}.form-field input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb26}.form-field input:disabled{background:var(--color-bg);cursor:not-allowed}.btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;border:none;border-radius:var(--radius);font-size:14px;font-weight:500;font-family:var(--font-family);cursor:pointer;transition:background-color .15s,opacity .15s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn--primary{background:var(--color-primary);color:#fff}.btn--primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn--full{width:100%;padding:11px 16px}.btn--logout{background:transparent;color:var(--color-nav-text);opacity:.8;padding:6px 12px;font-size:13px}.btn--logout:hover{opacity:1;background:#ffffff1a}.navbar{display:flex;align-items:center;justify-content:space-between;background:var(--color-nav-bg);color:var(--color-nav-text);padding:0 24px;height:56px;border-bottom:3px solid transparent}.navbar--prd{background:var(--color-nav-prd);border-bottom-color:var(--color-danger)}.navbar__title{font-size:16px;font-weight:700;letter-spacing:.3px;white-space:nowrap}.navbar__center,.navbar__right{display:flex;align-items:center}.env-selector{display:flex;gap:2px;background:#0003;border-radius:var(--radius);padding:2px}.env-btn{padding:5px 16px;border:none;border-radius:4px;font-size:12px;font-weight:700;font-family:var(--font-family);letter-spacing:.5px;cursor:pointer;background:transparent;color:#fff9;transition:all .15s}.env-btn:hover{color:#fff;background:#ffffff1a}.env-btn--active{color:#fff;background:#fff3}.env-btn--prd{color:#fca5a5}.env-btn--prd.env-btn--active{background:var(--color-danger);color:#fff}.env-btn--prd:hover{color:#fff}.prd-warning-bar{background:var(--color-danger);color:#fff;text-align:center;padding:4px;font-size:11px;font-weight:700;letter-spacing:1.5px}.user-info{display:flex;align-items:center;gap:10px}.user-info__name{font-size:13px;font-weight:500}.role-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.3px}.role-badge--adops{background:#2563eb33;color:#93c5fd}.role-badge--director{background:#f59e0b33;color:#fcd34d}.role-badge--adengineer{background:#16a34a33;color:#86efac}.app-layout{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:24px;max-width:1400px;width:100%;margin:0 auto}.placeholder-page{display:flex;align-items:center;justify-content:center;min-height:300px;background:var(--color-surface);border:2px dashed var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-secondary)}.placeholder-page h2{font-size:18px;font-weight:500}.navbar__left{display:flex;align-items:center;gap:24px}.navbar__nav{display:flex;gap:4px}.nav-link{color:#fff9;text-decoration:none;font-size:13px;font-weight:500;padding:6px 12px;border-radius:var(--radius);transition:all .15s}.nav-link:hover{color:#fff;background:#ffffff1a}.nav-link--active{color:#fff;background:#ffffff26}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.page-header h2{font-size:22px;font-weight:700;display:flex;align-items:center;gap:12px}.page-header__status{font-size:14px}.btn--secondary{background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border)}.btn--secondary:hover:not(:disabled){background:var(--color-border)}.btn--danger{background:var(--color-danger);color:#fff}.btn--danger:hover:not(:disabled){background:var(--color-danger-hover)}.btn--sm{padding:4px 10px;font-size:12px}.error-banner{background:var(--color-danger-light);color:var(--color-danger);border:1px solid var(--color-danger-border);border-radius:var(--radius);padding:10px 14px;font-size:14px;margin-bottom:16px}.text-secondary{color:var(--color-text-secondary);font-size:14px}.filter-bar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:16px;padding:12px 16px;background:var(--color-surface);border-radius:var(--radius);border:1px solid var(--color-border)}.filter-bar__select{padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:13px;font-family:var(--font-family);background:#fff;outline:none;cursor:pointer}.filter-bar__select:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px #2563eb1a}.status-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.status-badge--draft{background:#e5e7eb;color:#4b5563}.status-badge--confirmed{background:#dbeafe;color:#1d4ed8}.status-badge--pending{background:#fef3c7;color:#92400e}.status-badge--approved{background:#dbeafe;color:#1e40af}.status-badge--deployed{background:#dcfce7;color:#166534}.env-tag{display:inline-block;padding:1px 6px;border-radius:4px;font-size:11px;font-weight:700;letter-spacing:.3px}.env-tag--dev{background:#dbeafe;color:#1d4ed8}.env-tag--stg{background:#fef3c7;color:#92400e}.env-tag--prd{background:var(--color-danger-light);color:var(--color-danger)}.table-wrapper{background:var(--color-surface);border-radius:var(--radius);border:1px solid var(--color-border);overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{background:var(--color-bg);padding:10px 12px;text-align:left;font-weight:600;font-size:12px;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.3px;border-bottom:1px solid var(--color-border);white-space:nowrap;-webkit-user-select:none;user-select:none}.data-table__sortable{cursor:pointer}.data-table__sortable:hover{color:var(--color-primary)}.sort-icon{margin-left:4px;font-size:11px;opacity:.5}.data-table td{padding:10px 12px;border-bottom:1px solid var(--color-border);vertical-align:middle}.data-table__row:hover{background:var(--color-primary-light)}.data-table__row--selected{background:#eff6ff}.data-table__row--prd{border-left:3px solid var(--color-danger)}.data-table__check-col{width:36px;text-align:center}.data-table__actions{display:flex;gap:4px;flex-wrap:nowrap}.table-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--color-text-secondary)}.table-empty{display:flex;align-items:center;justify-content:center;padding:60px 20px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-secondary)}.pagination{display:flex;align-items:center;gap:4px;margin-top:16px;justify-content:center}.pagination__btn{padding:6px 12px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);font-size:13px;font-family:var(--font-family);cursor:pointer;transition:all .15s}.pagination__btn:hover:not(:disabled){background:var(--color-primary-light);border-color:var(--color-primary)}.pagination__btn:disabled{opacity:.5;cursor:not-allowed}.pagination__btn--active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.pagination__ellipsis{padding:0 4px;color:var(--color-text-secondary)}.pagination__info{margin-left:12px;font-size:13px;color:var(--color-text-secondary)}.batch-toolbar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--color-primary-light);border:1px solid var(--color-primary);border-radius:var(--radius);margin-bottom:12px}.batch-toolbar__count{font-size:14px;font-weight:600;color:var(--color-primary)}.batch-toolbar__actions{display:flex;gap:8px}.inline-edit-cell--editable{cursor:text;position:relative}.inline-edit-cell--editable:hover{background:#2563eb0d}.inline-edit-cell--editing{padding:4px 6px}.inline-edit-input{width:100%;padding:4px 8px;border:2px solid var(--color-primary);border-radius:4px;font-size:13px;font-family:var(--font-family);outline:none}.inline-edit-saving{color:var(--color-text-secondary);font-size:12px;margin-left:4px}.dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.dialog{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:480px;padding:28px;animation:slideUp .2s ease-out}@keyframes slideUp{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.dialog--danger{border-top:4px solid var(--color-danger)}.dialog__title{font-size:18px;font-weight:700;margin-bottom:8px}.dialog--danger .dialog__title{color:var(--color-danger)}.dialog__message{color:var(--color-text-secondary);font-size:14px;line-height:1.6;margin-bottom:20px}.dialog__actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.au-form{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:24px}.au-form--prd{border-color:var(--color-danger);border-width:2px}.au-form__grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:20px}@media (max-width: 900px){.au-form__grid{grid-template-columns:1fr 1fr}}@media (max-width: 600px){.au-form__grid{grid-template-columns:1fr}}.au-form__checkboxes{display:flex;flex-direction:column;gap:12px;margin-bottom:20px;padding:16px;background:var(--color-bg);border-radius:var(--radius)}.au-form__section{margin-bottom:20px;padding:16px;background:var(--color-bg);border-radius:var(--radius)}.au-form__section h3{font-size:15px;font-weight:600;margin-bottom:12px}.au-form__actions{display:flex;gap:12px;align-items:flex-end;padding-top:16px;border-top:1px solid var(--color-border)}.form-field select{width:100%;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:14px;font-family:var(--font-family);background:#fff;outline:none;cursor:pointer}.form-field select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb26}.form-field select:disabled{background:var(--color-bg);cursor:not-allowed}.form-field textarea{width:100%;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:14px;font-family:var(--font-family);outline:none;resize:vertical}.form-field textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb26}.form-field__hint{display:block;font-size:12px;color:var(--color-text-secondary);margin-top:4px}.form-field__hint--warning{color:var(--color-warning);font-weight:500}.select--prd{border-color:var(--color-danger)}.radio-group{display:flex;gap:16px}.radio-label,.checkbox-label{display:flex;align-items:center;gap:6px;font-size:14px;cursor:pointer}.checkbox-label{flex-wrap:wrap}.checkbox-label--warning{padding:8px 12px;background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius)}.kv-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}.kv-row select{padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:13px;font-family:var(--font-family);background:#fff}.kv-row input{flex:1;padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:13px;font-family:var(--font-family)}.emergency-banner{background:#fffbeb;color:#92400e;border:1px solid #fde68a;border-radius:var(--radius);padding:12px 16px;font-size:14px;font-weight:500;margin-bottom:16px}.page--prd{position:relative}.page--prd:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--color-danger)}.admin-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}@media (max-width: 900px){.admin-grid{grid-template-columns:1fr}}.admin-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:20px}.admin-section h3{font-size:16px;font-weight:700;margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.admin-list{margin-bottom:16px;max-height:300px;overflow-y:auto}.admin-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--color-bg)}.admin-item__code{font-family:monospace;font-size:13px;background:var(--color-bg);padding:2px 6px;border-radius:4px;font-weight:600}.admin-item__label{font-size:14px;color:var(--color-text-secondary)}.admin-add-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap;padding-top:12px;border-top:1px solid var(--color-border)}.admin-add-form__input{flex:1;min-width:80px;padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:13px;font-family:var(--font-family)}.admin-add-form__error{color:var(--color-danger);font-size:12px;width:100%}.import-page{max-width:none}.import-page .import-form,.import-page .import-warning,.import-page .import-result,.import-page .import-status{max-width:700px}.filter-bar__input{padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:13px;font-family:var(--font-family);background:#fff;outline:none}.filter-bar__input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px #2563eb1a}.status-badge--staged{background:#e0e7ff;color:#3730a3}.import-warning{background:#fffbeb;color:#92400e;border:1px solid #fde68a;border-radius:var(--radius);padding:12px 16px;font-size:14px;margin-bottom:20px;line-height:1.6}.import-form{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:24px;margin-bottom:20px}.upload-zone{border:2px dashed var(--color-border);border-radius:var(--radius);padding:40px 20px;text-align:center;cursor:pointer;transition:all .15s;margin-bottom:16px}.upload-zone:hover,.upload-zone--active{border-color:var(--color-primary);background:var(--color-primary-light)}.upload-zone--has-file{border-style:solid;border-color:var(--color-success);background:#f0fdf4}.upload-zone__placeholder p{color:var(--color-text-secondary);font-size:14px}.upload-zone__file{display:flex;align-items:center;justify-content:center;gap:10px}.upload-zone__filename{font-weight:600;font-size:14px}.upload-zone__size{color:var(--color-text-secondary);font-size:13px}.import-status{display:flex;flex-direction:column;align-items:center;padding:30px;color:var(--color-text-secondary)}.import-result{padding:20px;border-radius:var(--radius-lg);margin-top:16px}.import-result--success{background:#f0fdf4;border:1px solid #86efac}.import-result--success h3{color:#166534;margin-bottom:8px}.import-result--error{background:var(--color-danger-light);border:1px solid var(--color-danger-border)}.import-result--error h3{color:var(--color-danger);margin-bottom:8px}.import-result__table{margin-top:12px;border-radius:var(--radius);overflow:hidden}
