:root{--rojo-900: #7a0a1c;--rojo-700: #a31030;--rojo: #C8102E;--rojo-500: #dc2640;--rojo-100: #fde7eb;--rojo-50: #fef3f5;--azul-900: #061a3d;--azul-800: #0A2A5E;--azul: #143A7A;--azul-600: #1f4a96;--azul-100: #e3eaf5;--azul-50: #f1f5fb;--bg: #f7f7f5;--surface: #ffffff;--surface-2: #fafaf8;--line: #e6e5e1;--line-2: #efeeea;--ink-900: #15171c;--ink-700: #2c3038;--ink-500: #5a6068;--ink-400: #858a92;--ink-300: #b1b5bb;--ok: #1a7a3e;--ok-bg: #e6f3ec;--warn: #b35900;--warn-bg: #fdf1df;--danger: var(--rojo);--danger-bg: var(--rojo-50);--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, "SF Mono", monospace;--r-xs: 4px;--r-sm: 6px;--r-md: 8px;--r-lg: 12px;--shadow-sm: 0 1px 2px rgba(10, 22, 50, .06);--shadow-md: 0 4px 14px rgba(10, 22, 50, .08);--shadow-lg: 0 12px 32px rgba(10, 22, 50, .14)}*{box-sizing:border-box}html,body,#app{margin:0;padding:0;width:100%;height:100%;overflow:hidden}body{font-family:var(--font-sans);color:var(--ink-900);background:var(--bg);-webkit-font-smoothing:antialiased;font-feature-settings:"cv02","cv11"}.app{display:grid;grid-template-columns:240px 1fr;grid-template-rows:56px 1fr;width:100%;height:100vh;min-height:0;background:var(--bg);font-size:14px;color:var(--ink-900);overflow:hidden;position:relative}.app__sidebar{grid-row:1 / span 2;background:var(--azul-800);color:#e7ecf5;display:flex;flex-direction:column;border-right:1px solid var(--azul-900);min-height:0}.app__topbar{background:#f1f3f7;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 24px}.app__main{background:var(--bg);overflow:auto;padding:24px 28px 36px;min-height:0}.predios-view{height:100%;min-height:0;display:flex;flex-direction:column}.predios-workspace{flex:1;min-height:0;display:grid;grid-template-columns:320px 1fr 380px;gap:14px}.brand{display:flex;align-items:center;gap:10px;padding:16px 18px;border-bottom:1px solid rgba(255,255,255,.08)}.brand__mark{width:32px;height:32px;border-radius:6px;background:var(--rojo);display:grid;place-items:center;color:#fff;font-weight:700;font-size:14px;letter-spacing:.02em;position:relative}.brand__mark:after{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border:1px solid rgba(255,255,255,.4);border-radius:3px}.brand__logo,.login__logo{width:38px;height:38px;object-fit:contain;flex-shrink:0}.brand__logo{width:32px;height:32px}.brand__name{font-weight:600;font-size:13.5px;letter-spacing:.01em;line-height:1.15}.brand__sub{font-size:11px;color:#ffffff8c;letter-spacing:.04em;text-transform:uppercase;margin-top:2px}.login-screen{width:100%;height:100vh;min-height:0;display:grid;grid-template-columns:minmax(360px,1fr) minmax(420px,1.05fr);background:var(--bg);overflow:auto}.login-hero{position:relative;min-height:100vh;padding:44px 48px;display:flex;flex-direction:column;color:#fff;overflow:hidden;background:linear-gradient(155deg,var(--azul-900) 0%,var(--azul-800) 60%,var(--azul) 100%);animation:loginHeroIn .72s cubic-bezier(.2,.8,.2,1) both}.login-hero__grid{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.07;animation:loginGridDrift 16s linear infinite}.login-hero__accent{position:absolute;left:0;top:0;bottom:0;width:6px;background:var(--rojo);transform-origin:top;animation:loginAccentIn .62s cubic-bezier(.2,.8,.2,1) .12s both}.login-brand{position:relative;display:flex;align-items:center;gap:12px;animation:loginFadeUp .58s cubic-bezier(.2,.8,.2,1) .18s both}.login-brand__name{font-size:14px;font-weight:600;letter-spacing:0}.login-brand__unit{max-width:500px;margin-top:2px;font-size:11px;opacity:.65;text-transform:uppercase;letter-spacing:.08em;line-height:1.35}.login-copy{position:relative;margin-top:auto;max-width:430px;animation:loginFadeUp .62s cubic-bezier(.2,.8,.2,1) .34s both}.login-copy__eyebrow,.login-form__eyebrow{font-size:11px;text-transform:uppercase;letter-spacing:.14em}.login-copy__eyebrow{margin-bottom:12px;color:#fff9}.login-copy h1{margin:0;font-size:44px;line-height:1.05;font-weight:600;letter-spacing:0}.login-copy p{margin:18px 0 0;font-size:14px;line-height:1.5;color:#ffffffb8}.login-panel{min-height:100vh;display:grid;place-items:center;padding:32px;animation:loginPanelIn .72s cubic-bezier(.2,.8,.2,1) .12s both}.login-form{width:min(408px,100%);animation:loginFadeUp .58s cubic-bezier(.2,.8,.2,1) .28s both}.login-form__eyebrow{margin-bottom:8px;color:var(--ink-500)}.login-form h2{margin:0 0 6px;font-size:26px;font-weight:600;letter-spacing:0}.login-form p{margin:0;font-size:13.5px;color:var(--ink-500)}.login-form__fields{gap:14px;margin-top:24px}.login-field-head{display:flex;justify-content:space-between;gap:12px}.login-field-head a{font-size:12px;color:var(--azul-600);text-decoration:none;cursor:pointer}.login-input{position:relative}.login-input>svg{position:absolute;left:10px;top:10px;color:var(--ink-400);z-index:1}.login-input .input{width:100%;padding-left:32px}.login-input:has(.login-input__icon-btn) .input{padding-right:32px}.login-input__icon-btn{position:absolute;right:6px;top:6px;height:22px;width:22px;display:grid;place-items:center;background:transparent;border:0;cursor:pointer;color:var(--ink-400)}.login-submit{width:100%;height:40px;margin-top:18px;font-size:14px;justify-content:center}.login-submit:disabled{cursor:wait;filter:grayscale(.15);opacity:.78}.login-error{margin-top:12px;padding:10px 12px;border:1px solid var(--rojo-100);border-radius:6px;background:var(--rojo-50);color:var(--rojo-700);font-size:12.5px;line-height:1.4}@keyframes loginHeroIn{0%{opacity:0;transform:translate(-18px)}to{opacity:1;transform:translate(0)}}@keyframes loginPanelIn{0%{opacity:0;transform:translate(22px)}to{opacity:1;transform:translate(0)}}@keyframes loginFadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes loginAccentIn{0%{transform:scaleY(0)}to{transform:scaleY(1)}}@keyframes loginGridDrift{0%{transform:translateZ(0)}to{transform:translate3d(-32px,-32px,0)}}@media(max-width:900px){.login-screen{grid-template-columns:1fr;grid-template-rows:minmax(330px,44vh) auto}.login-hero{min-height:0;padding:28px}.login-panel{min-height:auto;place-items:start center;padding:30px 24px 38px}.login-copy h1{font-size:36px}}@media(max-width:560px){.login-screen{grid-template-rows:minmax(300px,40vh) auto}.login-hero{padding:22px 20px}.login-brand{align-items:flex-start}.login-brand__name{font-size:13.5px}.login-brand__unit{font-size:10px;letter-spacing:.06em}.login-copy h1{font-size:31px}.login-copy p{font-size:13px}.login-panel{padding:26px 18px 34px}.login-field-head{align-items:flex-start;flex-direction:column;gap:4px}}@media(prefers-reduced-motion:reduce){.login-hero,.login-hero__grid,.login-hero__accent,.login-brand,.login-copy,.login-panel,.login-form{animation:none}}.nav{padding:14px 8px;flex:1;overflow:auto}.nav__group{margin-bottom:14px}.nav__label{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:#ffffff6b;padding:6px 12px}.nav__item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:6px;font-size:13px;color:#ffffffc7;cursor:pointer;-webkit-user-select:none;user-select:none}.nav__item:hover{background:#ffffff0f;color:#fff}.nav__item.is-active{background:#ffffff1a;color:#fff;position:relative}.nav__item.is-active:before{content:"";position:absolute;left:-8px;top:6px;bottom:6px;width:3px;background:var(--rojo);border-radius:0 3px 3px 0}.nav__icon{width:16px;height:16px;opacity:.9;flex-shrink:0}.nav__count{margin-left:auto;background:#ffffff1f;font-size:11px;padding:1px 6px;border-radius:8px;font-variant-numeric:tabular-nums}.sidebar__foot{padding:12px;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:10px}.avatar{width:30px;height:30px;border-radius:50%;background:var(--rojo);color:#fff;display:grid;place-items:center;font-size:12px;font-weight:600;flex-shrink:0}.sidebar__user-name{font-size:12.5px;color:#fff;font-weight:500}.sidebar__user-role{font-size:11px;color:#ffffff8c}.crumbs{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-500)}.crumbs__sep{color:var(--ink-300)}.crumbs__current{color:var(--ink-900);font-weight:500}.topbar__right{display:flex;align-items:center;gap:14px}.search{display:flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--line);border-radius:6px;padding:6px 10px;width:280px}.search input{border:0;outline:0;background:transparent;font-size:13px;color:var(--ink-900);width:100%;font-family:inherit}.search input::placeholder{color:var(--ink-400)}.kbd{font-family:var(--font-mono);font-size:11px;color:var(--ink-400);border:1px solid var(--line);border-radius:3px;padding:0 4px;background:var(--surface)}.icon-btn{width:32px;height:32px;display:grid;place-items:center;border-radius:6px;cursor:pointer;color:var(--ink-500);position:relative}.icon-btn:hover{background:var(--surface-2);color:var(--ink-900)}.icon-btn .dot{position:absolute;top:6px;right:7px;width:7px;height:7px;border-radius:50%;background:var(--rojo);border:2px solid var(--surface)}.page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:18px;gap:24px}.page-head h1{font-size:22px;font-weight:600;margin:0 0 4px;letter-spacing:-.01em}.page-head__sub{font-size:13px;color:var(--ink-500)}.page-head__actions{display:flex;gap:8px;align-items:center}.btn{font-family:inherit;font-size:13px;font-weight:500;height:34px;padding:0 14px;border-radius:6px;border:1px solid transparent;cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:filter .12s,background .12s}.btn--primary{background:var(--azul-800);color:#fff}.btn--primary:hover{background:var(--azul-900)}.btn--danger{background:var(--rojo);color:#fff}.btn--danger:hover{background:var(--rojo-700)}.btn--ghost{background:transparent;color:var(--ink-700);border-color:var(--line)}.btn--ghost:hover{background:var(--surface-2)}.btn--soft{background:var(--azul-100);color:var(--azul-800)}.btn--soft:hover{background:#d6e0ef}.btn--sm{height:28px;padding:0 10px;font-size:12.5px;border-radius:5px}.card{background:var(--surface);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow-sm)}.card__head{padding:14px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}.card__title{font-size:14px;font-weight:600}.card__sub{font-size:12px;color:var(--ink-500)}.card__body{padding:18px}.stat{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:16px 18px;position:relative;overflow:hidden}.stat__label{font-size:12px;color:var(--ink-500);display:flex;align-items:center;gap:6px}.stat__value{font-size:28px;font-weight:600;letter-spacing:-.02em;margin-top:6px;font-variant-numeric:tabular-nums}.stat__delta{font-size:12px;color:var(--ink-500);margin-top:4px;display:flex;align-items:center;gap:4px}.stat__delta.up{color:var(--ok)}.stat__delta.down{color:var(--rojo)}.stat__bar{position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--azul-800)}.stat--accent .stat__bar{background:var(--rojo)}.tbl{width:100%;border-collapse:collapse;font-size:13px}.tbl thead th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-500);font-weight:500;padding:10px 14px;border-bottom:1px solid var(--line);background:var(--surface-2);white-space:nowrap}.tbl tbody td{padding:12px 14px;border-bottom:1px solid var(--line-2);vertical-align:middle}.tbl tbody tr:hover{background:var(--azul-50)}.tbl tbody tr.is-selected{background:var(--azul-100)}.data-table-card{overflow:visible}.data-table-card .tbl{border-radius:0 0 8px 8px}.pill{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:500;padding:2px 8px;border-radius:99px;white-space:nowrap;line-height:18px}.pill--ok{background:var(--ok-bg);color:var(--ok)}.pill--warn{background:var(--warn-bg);color:var(--warn)}.pill--danger{background:var(--danger-bg);color:var(--rojo-700)}.pill--neutral{background:var(--surface-2);color:var(--ink-500);border:1px solid var(--line)}.pill--azul{background:var(--azul-100);color:var(--azul-800)}.pill__dot{width:6px;height:6px;border-radius:50%;background:currentColor}.field{display:flex;flex-direction:column;gap:6px}.field__label{font-size:12px;color:var(--ink-700);font-weight:500}.field__hint{font-size:11.5px;color:var(--ink-400)}.input,.select,.textarea{font-family:inherit;font-size:13px;height:34px;padding:0 10px;border:1px solid var(--line);border-radius:6px;background:var(--surface);color:var(--ink-900);outline:none}.input:focus,.select:focus,.textarea:focus{border-color:var(--azul-600);box-shadow:0 0 0 3px var(--azul-100)}.input.is-invalid,.select.is-invalid,.textarea.is-invalid{border-color:var(--rojo);box-shadow:0 0 0 3px var(--rojo-100)}.textarea{height:auto;padding:8px 10px;resize:vertical;min-height:70px}.select--sm{height:30px;padding:0 8px;font-size:12.5px}.field__error{color:var(--rojo-700);font-size:11.5px;line-height:1.35}.search-select{position:relative;width:100%}.search-select__control{width:100%;height:34px;padding:0 9px 0 10px;border:1px solid var(--line);border-radius:6px;background:var(--surface);color:var(--ink-900);display:flex;align-items:center;gap:8px;font-family:var(--font-sans);font-size:13px;text-align:left;cursor:pointer}.search-select__control:hover{border-color:var(--azul-100)}.search-select.is-open .search-select__control{border-color:var(--azul-600);box-shadow:0 0 0 3px var(--azul-100)}.search-select.is-disabled .search-select__control{cursor:not-allowed;opacity:.65}.search-select__value{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-select__value.is-placeholder{color:var(--ink-400)}.search-select__clear{width:20px;height:20px;border:0;border-radius:5px;background:transparent;color:var(--ink-400);display:grid;place-items:center;cursor:pointer;flex-shrink:0}.search-select__clear:hover{background:var(--surface-2);color:var(--rojo)}.search-select__chevron{color:var(--ink-400);flex-shrink:0}.search-select__dropdown{position:absolute;left:0;right:0;top:calc(100% + 6px);z-index:55;padding:6px;border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--shadow-lg)}.search-select__search{height:32px;padding:0 8px;border:1px solid var(--line);border-radius:6px;background:var(--surface-2);display:flex;align-items:center;gap:7px;color:var(--ink-400)}.search-select__search input{width:100%;border:0;outline:0;background:transparent;color:var(--ink-900);font-family:var(--font-sans);font-size:13px}.search-select__options{margin-top:6px;max-height:220px;overflow:auto}.search-select__option{width:100%;min-height:32px;padding:7px 8px;border:0;border-radius:6px;background:transparent;color:var(--ink-700);display:flex;align-items:center;justify-content:space-between;gap:8px;font-family:var(--font-sans);font-size:13px;text-align:left;cursor:pointer}.search-select__option:hover,.search-select__option.is-highlighted{background:var(--azul-50);color:var(--azul-800)}.search-select__option.is-selected{background:var(--azul-100);color:var(--azul-800);font-weight:600}.search-select__empty{padding:12px 8px;color:var(--ink-500);font-size:12.5px;text-align:center}.checkbox,.radio{display:inline-flex;align-items:center;gap:8px;font-size:13px;cursor:pointer}.checkbox input,.radio input{accent-color:var(--azul-800)}.toggle{--w: 30px;--h: 18px;width:var(--w);height:var(--h);background:var(--ink-300);border-radius:99px;position:relative;cursor:pointer;transition:background .15s}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;background:#fff;border-radius:50%;box-shadow:0 1px 2px #0003;transition:left .15s}.toggle.is-on{background:var(--azul-800)}.toggle.is-on:after{left:14px}.drawer{position:absolute;top:0;right:0;bottom:0;width:420px;background:var(--surface);border-left:1px solid var(--line);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;z-index:30}.drawer__head{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}.drawer__body{padding:20px 22px;overflow:auto;flex:1}.drawer__foot{padding:14px 22px;border-top:1px solid var(--line);display:flex;gap:8px;justify-content:flex-end;background:var(--surface-2)}.scrim{position:absolute;top:0;right:0;bottom:0;left:0;background:#0a16321a;z-index:25}.modal{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;z-index:40}.modal__card{width:720px;max-height:86%;background:var(--surface);border-radius:12px;box-shadow:var(--shadow-lg);overflow:hidden;display:flex;flex-direction:column;position:relative;z-index:41}.modal__head{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}.modal__body{padding:22px;overflow:auto}.modal__foot{padding:14px 22px;border-top:1px solid var(--line);display:flex;gap:8px;justify-content:flex-end;background:var(--surface-2)}.persona-modal{width:min(760px,calc(100vw - 32px))}.roles-box{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 14px;padding:12px;border:1px solid var(--line);border-radius:8px;background:var(--surface-2)}.tbl-actions{position:relative;overflow:visible}.actions-trigger{height:30px;padding:0 10px;border:1px solid var(--line);border-radius:6px;background:var(--surface);color:var(--ink-700);display:inline-flex;align-items:center;gap:6px;font-family:var(--font-sans);font-size:12.5px;font-weight:500;cursor:pointer}.actions-trigger:hover{border-color:var(--azul-100);background:var(--azul-50);color:var(--azul-800)}.actions-menu{position:absolute;right:14px;top:calc(100% - 4px);z-index:80;width:190px;padding:6px;border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--shadow-lg)}.actions-menu button{width:100%;height:34px;padding:0 9px;border:0;border-radius:6px;background:transparent;color:var(--ink-700);display:flex;align-items:center;gap:9px;font-family:var(--font-sans);font-size:12.5px;font-weight:500;text-align:left;cursor:pointer}.actions-menu button:hover{background:var(--azul-50);color:var(--azul-800)}.actions-menu button.is-danger{color:var(--rojo-700)}.actions-menu button.is-danger:hover{background:var(--rojo-50);color:var(--rojo)}.table-pagination{padding:12px 14px;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--surface)}.table-pagination__summary,.table-pagination__page{color:var(--ink-500);font-size:12.5px}.table-pagination__controls{display:flex;align-items:center;gap:8px}.btn:disabled,.actions-trigger:disabled{cursor:not-allowed;opacity:.55}.unit-form{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:end;padding-bottom:16px;border-bottom:1px solid var(--line)}.unit-list{margin-top:14px;display:flex;flex-direction:column;gap:8px;max-height:360px;overflow:auto}.unit-list__item{padding:12px;border:1px solid var(--line);border-radius:8px;background:var(--surface);display:flex;align-items:center;justify-content:space-between;gap:12px}.unit-list__name{font-size:13px;font-weight:600;color:var(--ink-900)}.unit-list__meta{margin-top:3px;font-size:11.5px;color:var(--ink-500)}.unit-list__actions{display:flex;gap:6px;flex-shrink:0}.image-preview{margin-bottom:8px;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:var(--surface-2)}.image-preview img{display:block;width:100%;height:170px;object-fit:contain;background:var(--surface)}.image-preview a,.image-preview button{display:block;width:100%;padding:8px 10px;border-top:1px solid var(--line);border-right:0;border-bottom:0;border-left:0;background:var(--surface);color:var(--azul-800);font-family:var(--font-sans);font-size:12px;font-weight:500;text-decoration:none;text-align:left;cursor:pointer}.image-preview a:hover,.image-preview button:hover{background:var(--azul-50)}.upload-preview-modal{width:min(940px,calc(100vw - 34px));height:min(760px,calc(100vh - 34px))}.upload-preview-body{flex:1;min-height:0;padding:14px;background:var(--surface-2);display:grid;place-items:center}.upload-preview-body img{max-width:100%;max-height:100%;object-fit:contain;border:1px solid var(--line);border-radius:8px;background:var(--surface)}.upload-preview-body iframe{width:100%;height:100%;border:1px solid var(--line);border-radius:8px;background:var(--surface)}.upload-box{min-height:74px;padding:12px;border:1px dashed var(--line);border-radius:8px;background:var(--surface-2);color:var(--ink-700);display:flex;flex-direction:column;justify-content:center;gap:4px;cursor:pointer;transition:border-color .12s,background .12s,color .12s}.upload-box:hover{border-color:var(--azul-600);background:var(--azul-50);color:var(--azul-800)}.upload-box input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.upload-box span{font-size:13px;font-weight:600}.upload-box small{color:var(--ink-500);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.designer-modal{place-items:stretch;padding:18px}.designer-modal__card{width:100%;max-height:100%;border-radius:8px}.designer-page{height:calc(100vh - 116px);min-height:0;display:flex}.designer-page__card{width:100%;min-height:0;background:var(--surface);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow-sm);overflow:hidden;display:flex;flex-direction:column}.designer-toolbar{padding:12px 16px;border-bottom:1px solid var(--line);background:var(--surface-2);display:grid;grid-template-columns:minmax(240px,340px) 1fr;gap:12px;align-items:end}.designer-name{gap:5px}.designer-tools{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.designer-error{grid-column:1 / -1;margin-top:-4px}.designer-body{flex:1;min-height:0;padding:0;display:grid;grid-template-columns:minmax(0,1fr) 280px;overflow:hidden}.designer-canvas-area{min-width:0;min-height:0;padding:20px;background:#b7bdc6;overflow:auto;display:flex;align-items:flex-start;justify-content:center}.designer-canvas-shell{line-height:0;box-shadow:0 10px 28px #0a16323d}.designer-canvas-shell canvas{display:block}.designer-side{min-height:0;padding:14px;border-left:1px solid var(--line);background:var(--surface);overflow:auto;display:flex;flex-direction:column;gap:14px}.designer-side__section{display:flex;flex-direction:column;gap:10px}.designer-side__title{color:var(--ink-500);font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.designer-color{width:48px;padding:2px;flex-shrink:0}.designer-inline-buttons{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.designer-layer{min-height:32px;padding:6px 8px;border:1px solid var(--line);border-radius:6px;background:var(--surface-2);color:var(--ink-700);display:flex;align-items:center;gap:8px;font-family:var(--font-sans);font-size:12px;cursor:pointer}.designer-layer:hover{border-color:var(--azul-100);background:var(--azul-50);color:var(--azul-800)}.designer-layer span{min-width:34px;color:var(--ink-500);font-family:var(--font-mono);font-size:11px}.designer-layer strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}.designer-empty,.designer-status{color:var(--ink-500);font-size:12.5px}.designer-status{margin-right:auto}.admin-tabs{margin-bottom:14px;display:flex;gap:8px;border-bottom:1px solid var(--line)}.admin-tab{height:36px;padding:0 14px;border:0;border-bottom:2px solid transparent;background:transparent;color:var(--ink-500);font-family:var(--font-sans);font-size:13px;font-weight:600;cursor:pointer}.admin-tab:hover{color:var(--azul-800)}.admin-tab.is-active{color:var(--azul-800);border-bottom-color:var(--rojo)}.admin-grid{display:grid;grid-template-columns:minmax(320px,420px) minmax(0,1fr);gap:14px;align-items:start}.admin-checks{max-height:210px;padding:10px;border:1px solid var(--line);border-radius:8px;background:var(--surface-2);display:grid;gap:8px;overflow:auto}.admin-templates{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.template-card{min-width:0}.template-card__body{display:flex;flex-direction:column;gap:14px}.preview-fabric-wrapper{min-height:300px;padding:16px;border:1px solid var(--line);border-radius:8px;background:#b7bdc6;display:flex;align-items:flex-start;justify-content:center;overflow:auto;position:relative}.preview-fabric-shell{line-height:0;box-shadow:0 8px 22px #0a163233}.preview-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:18px;color:var(--ink-500);font-size:12.5px;text-align:center}.template-actions{grid-column:1 / -1;display:flex;justify-content:flex-end}@media(max-width:620px){.roles-box,.grid-2{grid-template-columns:1fr}.table-pagination,.table-pagination__controls,.unit-list__item,.unit-list__actions{align-items:stretch;flex-direction:column}.unit-form{grid-template-columns:1fr}}@media(max-width:900px){.designer-modal{padding:10px}.designer-toolbar{grid-template-columns:1fr}.designer-tools{justify-content:flex-start}.designer-body{grid-template-columns:1fr}.designer-side{max-height:310px;border-left:0;border-top:1px solid var(--line)}.admin-grid,.admin-templates{grid-template-columns:1fr}}.swal-uap{border-radius:8px;border:1px solid var(--line);box-shadow:var(--shadow-lg);color:var(--ink-900);font-family:var(--font-sans)}.swal-uap .swal2-title{color:var(--ink-900);font-size:20px;font-weight:600;letter-spacing:0}.swal-uap .swal2-html-container{color:var(--ink-500);font-size:13.5px}.swal-uap .swal2-icon.swal2-warning{border-color:var(--rojo);color:var(--rojo)}.swal-uap__confirm,.swal-uap__cancel{height:36px;padding:0 14px;border-radius:6px;border:1px solid transparent;font-family:var(--font-sans);font-size:13px;font-weight:500;cursor:pointer}.swal-uap__confirm{background:var(--rojo);color:#fff}.swal-uap__confirm:hover{background:var(--rojo-700)}.swal-uap__cancel{background:var(--surface);border-color:var(--line);color:var(--ink-700)}.swal-uap__cancel:hover{background:var(--surface-2)}.filterbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:10px 14px;background:var(--surface);border:1px solid var(--line);border-radius:8px 8px 0 0;border-bottom:0}.chip{font-size:12px;height:26px;padding:0 9px;border:1px dashed var(--line);border-radius:5px;background:var(--surface-2);display:inline-flex;align-items:center;gap:6px;color:var(--ink-700);cursor:pointer}.chip:hover{border-color:var(--azul-600);color:var(--azul-800)}.chip--applied{background:var(--azul-50);border-style:solid;border-color:var(--azul-100);color:var(--azul-800)}.row{display:flex;gap:12px}.col{display:flex;flex-direction:column;gap:12px}.spacer{flex:1}.muted{color:var(--ink-500)}.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.hr{height:1px;background:var(--line);border:0;margin:14px 0}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
