@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap");:root{--gray-50:#fafafa;--gray-100:#f5f5f5;--gray-200:#e5e5e5;--gray-300:#d4d4d4;--gray-400:#a3a3a3;--gray-500:#737373;--gray-600:#525252;--gray-700:#404040;--gray-800:#262626;--gray-900:#171717;--gray-950:#0a0a0a;--brand:#000;--brand-hover:#333;--brand-accent:#0070f3;--danger:#ef4444;--danger-hover:#dc2626;--danger-bg:#fef2f2;--danger-border:#fca5a5;--success:#10b981;--success-hover:#059669;--bg-body:var(--gray-50);--bg-surface:#fff;--bg-sidebar:var(--gray-950);--border-subtle:#eaeaea;--border-focus:var(--gray-400);--text-primary:var(--gray-900);--text-secondary:#666;--text-inverse:#fff;--shadow-sm:0 1px 2px rgba(0,0,0,.04);--shadow-md:0 4px 6px -1px rgba(0,0,0,.05),0 2px 4px -2px rgba(0,0,0,.05);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.05),0 4px 6px -4px rgba(0,0,0,.02);--shadow-float:0 30px 60px rgba(0,0,0,.12);--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px}*{box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body,html{margin:0;padding:0;height:100%;background-color:var(--bg-body);color:var(--text-primary);font-family:Inter,system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.5}h1,h2,h3,h4,h5,h6{font-family:Inter,sans-serif;margin:0;font-weight:600;letter-spacing:-.02em}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.admin-layout{display:flex;min-height:100vh}.sidebar{width:260px;background-color:var(--bg-sidebar);color:var(--text-inverse);display:flex;flex-direction:column;position:-webkit-sticky;position:sticky;top:0;height:100vh;z-index:50;border-right:1px solid var(--gray-800)}.sidebar-header{padding:24px;display:flex;align-items:center;gap:12px}.sidebar-logo{font-size:16px;font-weight:700;letter-spacing:-.01em;color:#fff}.sidebar-nav{flex:1 1;padding:12px;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.12);border-radius:2px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:hsla(0,0%,100%,.24)}.nav-group{margin-bottom:24px}.nav-group-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-500);margin-bottom:8px;padding-left:12px}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:6px;color:var(--gray-300);text-decoration:none;font-size:13px;font-weight:500;margin-bottom:2px;transition:all .15s ease}.nav-item:hover{background-color:var(--gray-800);color:#fff}.nav-item.active{background-color:#fff;color:#000}.sidebar-footer{padding:16px;border-top:1px solid var(--gray-800)}.user-profile{gap:10px;padding:8px;border-radius:var(--radius-md)}.user-avatar,.user-profile{display:flex;align-items:center}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--gray-800);justify-content:center;font-weight:600;font-size:12px;color:#fff;border:1px solid var(--gray-700)}.user-info{flex:1 1;min-width:0}.user-name{display:block;font-size:13px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{display:block;font-size:11px;color:var(--gray-500)}.main-content{flex:1 1;display:flex;flex-direction:column;min-width:0}.top-bar{height:64px;background-color:hsla(0,0%,100%,.8);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between;padding:0 32px;position:-webkit-sticky;position:sticky;top:0;z-index:40}.page-title-area h1{font-size:16px;font-weight:600;color:var(--text-primary)}.content-body{padding:24px 32px;flex:1 1;width:100%}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-gap:16px;gap:16px;margin-bottom:32px}.stat-card{background-color:var(--bg-surface);padding:20px;border-radius:var(--radius-md);border:1px solid var(--border-subtle);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px;transition:border-color .2s ease,box-shadow .2s ease}.stat-card:hover{border-color:var(--gray-300);box-shadow:var(--shadow-md)}.stat-label{font-size:13px;font-weight:500;color:var(--text-secondary);display:flex;align-items:center;gap:6px}.stat-value{font-size:28px;font-weight:700;color:var(--text-primary);letter-spacing:-.03em}.crud-workbench{display:grid;grid-template-columns:1fr 320px;grid-gap:24px;gap:24px;align-items:start}.crud-main,.crud-sidebar{display:flex;flex-direction:column;gap:24px}.crud-sidebar{position:-webkit-sticky;position:sticky;top:88px}.card{background-color:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--border-subtle);box-shadow:var(--shadow-sm);overflow:hidden}.card-header{padding:16px 24px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between;background-color:#fff}.card-title{font-size:15px;font-weight:600;color:var(--text-primary)}.card-body{padding:24px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 14px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease;border:1px solid transparent;gap:8px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-primary{background-color:var(--brand);color:var(--text-inverse);box-shadow:0 2px 4px rgba(0,0,0,.1)}.btn-primary:hover:not(:disabled){background-color:var(--brand-hover);transform:translateY(-1px);box-shadow:0 4px 6px rgba(0,0,0,.12)}.btn-secondary{background-color:#fff;border-color:var(--border-subtle);color:var(--text-primary);box-shadow:var(--shadow-sm)}.btn-secondary:hover:not(:disabled){background-color:var(--gray-50);border-color:var(--gray-300)}.btn-danger{background-color:var(--danger-bg);color:var(--danger);border-color:var(--danger-border)}.btn-danger:hover:not(:disabled){background-color:#fecaca}.btn-success{background-color:var(--success);color:#fff}.btn-success:hover:not(:disabled){background-color:var(--success-hover)}.btn-block{width:100%}.form-group{margin-bottom:20px}.form-label{display:block;font-weight:500;margin-bottom:8px}.form-input,.form-label,.form-textarea{font-size:13px;color:var(--text-primary)}.form-input,.form-textarea{width:100%;padding:10px 12px;border-radius:6px;border:1px solid var(--border-subtle);font-family:inherit;transition:all .15s ease;background-color:#fff;box-shadow:var(--shadow-sm)}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--brand-accent);box-shadow:0 0 0 1px var(--brand-accent)}.form-textarea{min-height:480px;line-height:1.6;resize:vertical}.form-textarea,.response-container{font-family:JetBrains Mono,monospace;font-size:12px}.response-container{background-color:var(--gray-50);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:16px;color:var(--text-primary);overflow:auto;max-height:600px;box-shadow:inset 0 2px 4px rgba(0,0,0,.02)}.response-container pre{margin:0;white-space:pre-wrap;word-wrap:break-word}.action-panel-grid{display:flex;flex-direction:column;gap:12px}.data-table-shell{background-color:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);margin-top:16px}.table-status{padding:10px 16px;font-size:12px;font-weight:500;display:flex;align-items:center;gap:8px;transition:all .2s ease}.table-status:before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;flex-shrink:0}.table-status-info{background-color:#f8fafc;color:#475569;border-bottom:1px solid var(--border-subtle)}.table-status-info:before{background-color:#3b82f6}.table-status-success{background-color:#f0fdf4;color:#166534;border-bottom:1px solid #dcfce7}.table-status-success:before{background-color:#22c55e}.table-status-danger{background-color:#fef2f2;color:#991b1b;border-bottom:1px solid #fee2e2}.table-status-danger:before{background-color:#ef4444}.data-table-scroll{overflow-x:auto}.data-table{width:100%;border-collapse:separate;border-spacing:0;text-align:left}.data-table td,.data-table th{padding:10px 14px;font-size:13px;border-bottom:1px solid var(--border-subtle);color:var(--text-primary);white-space:nowrap}.data-table th{background-color:var(--gray-50);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;font-size:11px}.data-table tbody tr{transition:background-color .15s ease}.data-table tbody tr:hover{background-color:var(--gray-50)}.data-table tbody tr:last-child td{border-bottom:none}.table-select-cell{width:48px;text-align:center}.table-action-cell{position:-webkit-sticky;position:sticky;right:0;background-color:#fff;z-index:10;width:160px;text-align:right;border-left:1px solid var(--border-subtle);box-shadow:-6px 0 10px rgba(0,0,0,.02)}.data-table th.table-action-cell{background-color:var(--gray-50);z-index:11}.data-table tbody tr:hover td.table-action-cell{background-color:var(--gray-50)}.table-row-actions{display:flex;gap:8px;align-items:center;justify-content:flex-end}.table-action-button{background:transparent;border:none;font-size:12px;font-weight:600;color:var(--brand-accent);cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .15s ease}.table-action-button:hover:not(:disabled){background-color:#eff6ff}.table-action-button.danger{color:var(--danger)}.table-action-button.danger:hover:not(:disabled){background-color:var(--danger-bg)}.table-action-button.success{color:var(--success)}.table-action-button.success:hover:not(:disabled){background-color:#d1fae5}.table-action-button:disabled{opacity:.4;cursor:not-allowed}.status-badge{display:inline-flex;align-items:center;max-width:100%;min-height:22px;padding:2px 8px;border-radius:999px;border:1px solid var(--gray-200);background:var(--gray-100);color:var(--gray-700);font-size:12px;font-weight:600;line-height:1.4}.status-badge-success{background:#ecfdf5;border-color:#a7f3d0;color:#047857}.status-badge-danger{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.status-badge-warning{background:#fffbeb;border-color:#fde68a;color:#92400e}.status-badge-neutral{background:var(--gray-100);border-color:var(--gray-200);color:var(--gray-700)}.table-empty{text-align:center;padding:48px!important;color:var(--text-secondary)!important}.toast-stack{position:fixed;top:82px;right:24px;z-index:180;width:min(380px,calc(100vw - 32px));display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast{pointer-events:auto;display:grid;grid-template-columns:minmax(0,1fr) auto;grid-gap:12px;gap:12px;align-items:flex-start;padding:13px 14px;border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:hsla(0,0%,100%,.96);box-shadow:var(--shadow-float);animation:toastSlideIn .18s ease-out}.toast strong{display:block;color:var(--text-primary);font-size:13px;font-weight:700;margin-bottom:3px}.toast p{margin:0;color:var(--text-secondary);font-size:12px;line-height:1.5;word-break:break-word}.toast button{width:24px;height:24px;border:0;border-radius:6px;background:transparent;color:var(--gray-400);cursor:pointer;font-size:18px;line-height:1}.toast button:hover{background:var(--gray-100);color:var(--text-primary)}.toast-success{border-color:#bbf7d0;box-shadow:0 18px 40px rgba(5,150,105,.14)}.toast-danger{border-color:#fecaca;box-shadow:0 18px 40px rgba(220,38,38,.14)}.toast-info{border-color:#bfdbfe;box-shadow:0 18px 40px rgba(37,99,235,.12)}@keyframes toastSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.table-pagination{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border-top:1px solid var(--border-subtle);background-color:#fff}.pagination-summary{color:var(--text-secondary);font-size:12px;font-weight:500}.pagination-actions{display:flex;align-items:center;gap:6px}.pagination-button{min-width:34px;height:32px;padding:0 10px;border:1px solid var(--border-subtle);border-radius:6px;background-color:#fff;color:var(--text-primary);cursor:pointer;font-size:12px;font-weight:600;transition:all .15s ease}.pagination-button:hover:not(:disabled){border-color:var(--gray-300);background-color:var(--gray-50)}.pagination-button.active{background-color:var(--gray-950);border-color:var(--gray-950);color:#fff}.pagination-button:disabled{opacity:.45;cursor:not-allowed}.modal-backdrop{position:fixed;inset:0;background-color:rgba(0,0,0,.4);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;padding:32px}.modal-panel{background-color:var(--bg-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-float);width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;animation:modalSlideUp .3s cubic-bezier(.16,1,.3,1)}.confirm-backdrop{z-index:190}.confirm-panel{width:min(440px,100%);background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-float);padding:24px;display:grid;grid-template-columns:42px minmax(0,1fr);grid-gap:16px;gap:16px;animation:modalSlideUp .24s cubic-bezier(.16,1,.3,1)}.confirm-icon{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px}.confirm-icon-danger{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca}.confirm-icon-primary{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.confirm-copy h2{font-size:17px;line-height:1.35;letter-spacing:0;margin:0 0 8px}.confirm-copy p{margin:0;color:var(--text-secondary);font-size:13px;line-height:1.7;word-break:break-word}.confirm-actions{grid-column:1/-1;display:flex;justify-content:flex-end;gap:10px;padding-top:8px}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{padding:24px;border-bottom:1px solid var(--border-subtle);display:flex;justify-content:space-between;align-items:flex-start}.modal-header h2{font-size:18px;font-weight:600;margin-bottom:4px}.modal-header p{color:var(--text-secondary);font-size:13px;margin:0}.modal-close{background:transparent;border:none;font-size:24px;line-height:1;color:var(--gray-400);cursor:pointer;padding:4px;border-radius:4px;transition:all .15s ease}.modal-close:hover{background-color:var(--gray-100);color:var(--text-primary)}.modal-body{padding:24px;overflow-y:auto;flex:1 1}.modal-form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));grid-gap:24px;gap:24px}.site-editor-modal .drawer-body{padding-top:0}.site-editor-modal .modal-form-grid{grid-template-columns:minmax(0,.82fr);justify-content:center;gap:18px}.site-modal-tabs{position:-webkit-sticky;position:sticky;top:0;z-index:1;display:flex;justify-content:center;gap:36px;padding:22px 0 0;border-bottom:1px solid var(--border-subtle);background:var(--bg-surface)}.site-modal-tab{position:relative;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;color:var(--text-primary);cursor:pointer;padding:0 2px 16px;font-size:15px;font-weight:600;letter-spacing:0}.site-modal-tab:hover{color:var(--brand-accent)}.site-modal-tab.active{color:#5f68bd}.site-modal-tab.active:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:3px;border-radius:3px 3px 0 0;background:#6f78d6}.site-modal-tab-desc{width:min(680px,100%);margin:16px auto 22px;color:var(--text-secondary);font-size:13px;line-height:1.6}.seo-config-modal .drawer-body{padding:0}.seo-config-layout{display:grid;grid-template-columns:minmax(320px,.9fr) minmax(420px,1.1fr);min-height:560px}.seo-help-panel{border-right:1px solid var(--border-subtle);background:#f7f8ff;padding:24px;overflow-y:auto}.seo-help-section h3{font-size:17px;margin:0 0 10px;letter-spacing:0}.seo-help-section p{margin:0 0 18px;color:var(--text-secondary);font-size:13px;line-height:1.7}.seo-help-table-wrap{overflow-x:auto;border:1px solid #d9ddf0;border-radius:var(--radius-md);background:#fff}.seo-help-table{width:100%;min-width:560px;border-collapse:collapse}.seo-help-table td,.seo-help-table th{padding:9px 10px;border-bottom:1px solid #e2e5f3;font-size:12px;line-height:1.55;vertical-align:top;text-align:left}.seo-help-table th{background:#e8ebf7;color:var(--text-primary);font-weight:700}.seo-help-table tr:last-child td{border-bottom:0}.seo-variable-box{margin-top:14px;padding:16px;border:1px solid #d9ddf0;border-radius:var(--radius-md);background:#eef1ff}.seo-variable-box h4{margin:0 0 12px;font-size:14px;letter-spacing:0}.seo-variable-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:8px 16px;gap:8px 16px}.seo-variable-grid span{display:flex;align-items:center;justify-content:space-between;gap:8px;color:var(--text-secondary);font-size:12px;min-width:0}.seo-variable-grid code{color:var(--text-primary);font-family:JetBrains Mono,monospace;font-size:12px;background:hsla(0,0%,100%,.72);border:1px solid #dfe3f6;border-radius:5px;padding:1px 5px}.seo-config-form{padding:28px 32px;overflow-y:auto}.tdk-template-tabs{display:flex;justify-content:center;gap:28px;border-bottom:1px solid var(--border-subtle);margin:-6px 0 24px}.tdk-template-tab{position:relative;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;color:var(--text-secondary);cursor:pointer;padding:0 2px 14px;font-size:14px;font-weight:700}.tdk-template-tab:hover{color:var(--brand-accent)}.tdk-template-tab.active{color:#5f68bd}.tdk-template-tab.active:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:3px;border-radius:3px 3px 0 0;background:#6f78d6}.seo-form-grid{grid-template-columns:1fr;gap:18px}.seo-rules-field{grid-column:1/-1}.seo-rules-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px;padding:14px;border:1px solid #dfe5f2;border-radius:8px;background:#f8fafc}.seo-rules-head .form-label{margin-bottom:4px}.seo-rules-head p{margin:0;color:var(--text-secondary);font-size:12px;line-height:1.6}.seo-rules-head .btn{flex:0 0 auto}.seo-rules-stack,.seo-rules-table{display:flex;flex-direction:column;gap:14px}.seo-rules-table{margin-bottom:14px}.tdk-rule-inputs{display:grid;grid-gap:8px;gap:8px}.tdk-rule-inputs .form-textarea{min-height:74px}.seo-rule-card{border:1px solid #dfe5f2;border-radius:8px;background:hsla(0,0%,100%,.86);box-shadow:var(--shadow-sm);padding:16px}.seo-rule-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.seo-rule-card-header strong{display:block;font-size:14px;margin-bottom:4px}.seo-rule-card-header span{display:block;color:var(--text-secondary);font-size:12px}.seo-rule-grid{display:grid;grid-template-columns:minmax(180px,.9fr) minmax(160px,.8fr) minmax(260px,1.4fr);grid-gap:12px;gap:12px}.seo-rule-card.tdk .seo-rule-grid{grid-template-columns:minmax(180px,.9fr) minmax(160px,.8fr) minmax(340px,1.6fr)}.seo-rule-control{display:grid;grid-gap:6px;gap:6px;min-width:0}.seo-rule-control>span{color:var(--text-secondary);font-size:12px;font-weight:700}.seo-detail-section{margin-top:16px;border-top:1px solid var(--border-subtle);padding-top:16px}.seo-detail-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.seo-detail-header strong{font-size:13px}.seo-detail-list{display:flex;flex-direction:column;gap:12px}.seo-detail-row{display:grid;grid-template-columns:1fr 72px;grid-gap:12px;gap:12px;align-items:start;border:1px dashed var(--border-subtle);border-radius:8px;padding:12px;background:rgba(248,250,252,.7)}.seo-detail-grid{display:grid;grid-template-columns:minmax(160px,.8fr) minmax(150px,.7fr) minmax(240px,1.4fr);grid-gap:10px;gap:10px}.seo-detail-row.tdk .seo-detail-grid{grid-template-columns:minmax(160px,.8fr) minmax(150px,.7fr) minmax(320px,1.7fr)}.seo-empty-state{padding:12px;border-radius:8px;border:1px dashed var(--border-subtle);background:var(--gray-50);color:var(--text-secondary);font-size:13px}.modal-footer{padding:20px 24px;border-top:1px solid var(--border-subtle);display:flex;justify-content:flex-end;gap:12px;background-color:var(--gray-50);border-radius:0 0 var(--radius-xl) var(--radius-xl)}.module-toolbar{flex-direction:column;margin-bottom:24px}.module-toolbar,.module-toolbar-actions{display:flex;gap:12px}.toolbar-hint{font-size:13px;color:var(--text-secondary);margin:0}.field-chip-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.field-chip{padding:4px 10px;border-radius:16px;background-color:var(--gray-100);color:var(--text-secondary);font-size:12px;font-weight:500}.checkbox-list,.field-chip{border:1px solid var(--border-subtle)}.checkbox-list{display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto;padding:12px;border-radius:6px;background-color:var(--gray-50)}.multi-select-dropdown{position:relative}.multi-select-dropdown summary{width:100%;min-height:40px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:6px;border:1px solid var(--border-subtle);background:#fff;box-shadow:var(--shadow-sm);color:var(--text-primary);cursor:pointer;list-style:none;font-size:13px;line-height:1.45}.multi-select-dropdown summary::-webkit-details-marker{display:none}.multi-select-dropdown summary:after{content:"⌄";color:var(--gray-400);font-size:16px;line-height:1}.multi-select-dropdown[open] summary{border-color:var(--brand-accent);box-shadow:0 0 0 1px var(--brand-accent)}.multi-select-dropdown .checkbox-list{position:absolute;inset-inline:0;top:calc(100% + 6px);z-index:6;max-height:260px;background:#fff;box-shadow:var(--shadow-lg)}.image-upload-field{display:grid;grid-gap:8px;gap:8px}.image-upload-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.image-upload-button{position:relative;overflow:hidden;min-height:36px}.image-upload-button.disabled{opacity:.6;pointer-events:none}.image-upload-button input{position:absolute;inset:0;opacity:0;cursor:pointer}.image-upload-link{color:var(--brand-accent);font-size:12px;font-weight:600;text-decoration:none}.image-upload-preview{display:block;width:min(240px,100%);aspect-ratio:16/9;background-position:50%;background-repeat:no-repeat;background-size:cover;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background-color:var(--gray-100)}.checkbox-option{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-primary);cursor:pointer}.empty-options{font-size:13px;color:var(--text-secondary);font-style:italic}.chip{display:inline-flex;align-items:center;padding:2px 8px;border-radius:9999px;font-size:11px;font-weight:600;background-color:var(--gray-100);color:var(--gray-600);border:1px solid var(--gray-200)}.chip-brand{background-color:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--gray-50);padding:20px;background-image:radial-gradient(var(--gray-200) 1px,transparent 0);background-size:32px 32px}.login-card{width:100%;max-width:400px;background:#fff;padding:40px;border-radius:var(--radius-lg);border:1px solid var(--border-subtle);box-shadow:var(--shadow-float)}.login-header{text-align:center;margin-bottom:32px}.login-logo{font-size:24px;font-weight:800;letter-spacing:-.04em;color:var(--brand);margin-bottom:8px}.login-title{font-size:20px;color:var(--text-primary);margin-bottom:8px}.login-subtitle{font-size:13px;color:var(--text-secondary)}@media (max-width:1024px){.crud-workbench{grid-template-columns:1fr}.crud-sidebar{position:static}.sidebar{width:72px}.nav-group-title,.nav-item span:not(.icon),.sidebar-logo,.user-info{display:none}.nav-item,.sidebar-header,.user-profile{justify-content:center;padding:12px}.site-modal-tabs{justify-content:flex-start;gap:20px;overflow-x:auto}.seo-config-layout,.site-editor-modal .modal-form-grid{grid-template-columns:1fr}.seo-config-layout{min-height:0}.seo-help-panel{max-height:320px;border-right:0;border-bottom:1px solid var(--border-subtle)}.seo-config-form{padding:24px}.tdk-template-tabs{justify-content:flex-start;gap:20px;overflow-x:auto}.seo-detail-grid,.seo-detail-row,.seo-rule-grid{grid-template-columns:1fr}.seo-rules-head{flex-direction:column}.seo-detail-header,.seo-rule-card-header{flex-direction:column;align-items:flex-start}}.drawer-backdrop{position:fixed;inset:0;background-color:rgba(9,9,11,.4);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;justify-content:flex-end}.drawer-panel{background-color:var(--bg-surface);box-shadow:-10px 0 40px rgba(0,0,0,.12);width:100%;max-width:520px;height:100vh;display:flex;flex-direction:column;animation:drawerSlideIn .28s cubic-bezier(.16,1,.3,1);border-left:1px solid var(--border-subtle)}@keyframes drawerSlideIn{0%{transform:translateX(100%)}to{transform:translateX(0)}}.drawer-header{padding:24px;border-bottom:1px solid var(--border-subtle);display:flex;justify-content:space-between;align-items:flex-start;background:var(--gray-50)}.drawer-header h2{font-size:16px;font-weight:600;margin-bottom:4px;letter-spacing:-.01em}.drawer-header p{color:var(--text-secondary);font-size:12px;margin:0}.drawer-close{background:transparent;border:none;font-size:20px;line-height:1;color:var(--gray-400);cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .15s ease}.drawer-close:hover{background-color:var(--gray-200);color:var(--text-primary)}.drawer-body{padding:24px;overflow-y:auto;flex:1 1}.drawer-form-grid{display:flex;flex-direction:column;gap:20px}.drawer-footer{padding:16px 24px;border-top:1px solid var(--border-subtle);display:flex;justify-content:flex-end;gap:12px;background-color:var(--gray-50)}.search-input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M21 21l-6-6m2-5a7 7 0 11-14 0 7 7 0 0114 0z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:12px;background-size:16px;padding-left:36px!important}.skeleton-row td{padding:12px 14px}.skeleton-element{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 50%,#f1f5f9 75%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:4px}.skeleton-checkbox{width:16px;height:16px;margin:0 auto}.skeleton-text{height:14px;width:80%}.skeleton-button{height:24px;width:48px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}