*,:before,:after{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:Outfit,Segoe UI,sans-serif}#root{min-height:100vh}:root{--warm-light:#ffd09d;--warm-dark:#532a0c;--warm-cream:#fff7ef;--warm-surface:#fff8efe6;--warm-surface-strong:#fff0ddf5;--warm-border:#532a0c29;--warm-border-strong:#532a0c3d;--warm-text:#3f210b;--warm-text-muted:#3f210bad}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;font-family:Outfit,Segoe UI,sans-serif}.page{background-position:50%;background-size:cover;justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative}.overlay{background:#f0e6d780;position:absolute;inset:0}.card{z-index:1;-webkit-backdrop-filter:blur(20px);background:#fffdf7eb;border:1px solid #be9b6e33;border-radius:18px;flex-direction:column;align-items:center;width:100%;max-width:390px;margin:16px;padding:48px 40px 36px;animation:.45s cubic-bezier(.25,1,.5,1) both rise;display:flex;position:relative;box-shadow:inset 0 2px #fffc,0 12px 40px #5a370f29}@keyframes rise{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.logo{object-fit:contain;width:150px;height:auto;margin-bottom:10px}.subtitle{color:#a07850;letter-spacing:2.5px;text-transform:uppercase;margin-bottom:32px;font-size:11px;font-weight:500}form{flex-direction:column;gap:18px;width:100%;display:flex}.field{flex-direction:column;gap:6px;display:flex}.field label{text-transform:uppercase;letter-spacing:1px;color:#7a5535;font-size:11.5px;font-weight:600}.label-row{justify-content:space-between;align-items:center;display:flex}.forgot{color:#a07850;font-size:12.5px;font-weight:400;text-decoration:none;transition:color .2s}.forgot:hover{color:#5c3d22}.input-wrap{align-items:center;display:flex;position:relative}.input-wrap .icon{color:#c4aa88;pointer-events:none;flex-shrink:0;position:absolute;left:13px}.input-wrap input{color:#2e1c0e;background:#fffcf4f2;border:1.5px solid #c8a5734d;border-radius:9px;width:100%;padding:11px 40px;font-family:inherit;font-size:14.5px;transition:border-color .2s,box-shadow .2s}.input-wrap input::placeholder{color:#cdb99a}.input-wrap input:focus{border-color:#b08050;outline:none;box-shadow:0 0 0 3px #b080501f}.eye-btn{cursor:pointer;color:#c4aa88;background:0 0;border:none;align-items:center;padding:4px;transition:color .2s;display:flex;position:absolute;right:11px}.eye-btn:hover{color:#6b4828}.error-msg{color:#b94a2c;background:#b94a2c12;border:1px solid #b94a2c2e;border-radius:8px;padding:9px 13px;font-size:13px}.submit-btn{color:#fdf6ec;letter-spacing:.4px;cursor:pointer;background:#7c5030;border:none;border-radius:9px;width:100%;margin-top:6px;padding:13px;font-family:Outfit,sans-serif;font-size:15px;font-weight:600;transition:background .2s,transform .15s,box-shadow .2s;box-shadow:0 3px 12px #5a2d0a40}.submit-btn:hover:not(:disabled){background:#6a4228;transform:translateY(-1px);box-shadow:0 5px 16px #5a2d0a4d}.submit-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #5a2d0a33}.submit-btn:disabled{opacity:.55;cursor:not-allowed}.footer{color:#c4aa88;letter-spacing:.4px;margin-top:26px;font-size:11px}.dashboard-page{background-color:#0000;background-image:radial-gradient(at 20% 0,#ffd09db3 0%,#0000 55%),radial-gradient(at 80% 100%,#532a0c14 0%,#0000 58%);background-position:0 0;background-repeat:repeat;background-size:auto;background-attachment:scroll;background-origin:padding-box;background-clip:border-box;flex-direction:column;min-height:100vh;display:flex}.nav{z-index:100;-webkit-backdrop-filter:blur(18px);border-bottom:1px solid var(--warm-border);background:#fff5e8e0;align-items:center;gap:16px;height:64px;padding:0 28px;display:flex;position:sticky;top:0;box-shadow:0 1px 24px #532a0c1a}.nav-brand{flex-shrink:0;align-items:center;gap:10px;text-decoration:none;display:flex}.nav-logo{object-fit:contain;filter:none;width:auto;height:32px}.nav-title{letter-spacing:2px;text-transform:uppercase;color:var(--warm-dark);white-space:nowrap;font-size:12px;font-weight:600}.nav-links{flex:1;align-items:center;gap:4px;padding-left:24px;display:flex}.nav-link{color:var(--warm-text-muted);white-space:nowrap;border-radius:8px;align-items:center;gap:7px;padding:7px 14px;font-size:13.5px;font-weight:500;text-decoration:none;transition:background .2s,color .2s;display:flex}.nav-link:hover{color:var(--warm-dark);background:#ffd09d59}.nav-link.active{color:var(--warm-dark);background:#ffd09d8f}.nav-right{flex-shrink:0;align-items:center;gap:12px;margin-left:auto;display:flex}.nav-user{align-items:center;gap:9px;display:flex}.nav-avatar{background:linear-gradient(135deg, var(--warm-light), #f0b36e);width:32px;height:32px;color:var(--warm-dark);border:1.5px solid var(--warm-border-strong);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.nav-email{color:var(--warm-text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:180px;font-size:13px;overflow:hidden}.logout-btn{color:var(--warm-dark);cursor:pointer;white-space:nowrap;background:#ffd09d75;border:1px solid #532a0c38;border-radius:8px;align-items:center;gap:7px;padding:8px 16px;font-family:Outfit,sans-serif;font-size:13px;font-weight:500;transition:background .2s,border-color .2s,color .2s,transform .15s;display:flex}.logout-btn:hover:not(:disabled){color:var(--warm-dark);background:#ffd09db3;border-color:#532a0c52;transform:translateY(-1px)}.logout-btn:disabled{opacity:.5;cursor:not-allowed}.dashboard-main{flex:1;justify-content:center;align-items:center;padding:48px 24px;display:flex}.dashboard-welcome{text-align:center;flex-direction:column;align-items:center;gap:16px;animation:.5s cubic-bezier(.25,1,.5,1) both rise;display:flex}.welcome-icon{color:#d2af6499;background:#8c5a1e1f;border:1px solid #be965033;border-radius:28px;justify-content:center;align-items:center;width:96px;height:96px;margin-bottom:8px;display:flex}.welcome-title{color:#f0d7a5e6;letter-spacing:-.5px;font-size:32px;font-weight:700}.welcome-sub{color:#bea578a6;font-size:15px;line-height:1.6}.welcome-sub strong{color:#dcbe82d9;font-weight:600}.splash-loading{background:linear-gradient(#fff6e9 0%,#f6dbc0 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.spinner{border:3px solid #532a0c24;border-top-color:#532a0cb8;border-radius:50%;width:36px;height:36px;animation:.75s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.remember-row{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:9px;display:flex}.remember-check{accent-color:#7c5030;cursor:pointer;flex-shrink:0;width:16px;height:16px}.remember-label{color:#8a6640;font-size:13px;font-weight:500}.dashboard-body{flex:1;height:calc(100vh - 64px);display:flex;overflow:hidden}.sidebar{border-right:1px solid var(--warm-border);background:#fff3e3f5;flex-direction:column;flex-shrink:0;width:220px;display:flex;overflow-y:auto}.sidebar-hdr{letter-spacing:1.8px;text-transform:uppercase;color:#532a0c9e;border-bottom:1px solid #532a0c14;flex-shrink:0;align-items:center;gap:7px;padding:14px 16px 10px;font-size:10px;font-weight:700;display:flex}.sidebar-load{color:#532a0c80;justify-content:center;padding:24px;display:flex}.sidebar-empty{color:#532a0c75;padding:16px;font-size:12px;line-height:1.5}.sidebar-err{color:#dc6446d9}.table-list{margin:0;padding:6px 0;list-style:none}.table-btn{cursor:pointer;text-align:left;color:#532a0cb8;background:0 0;border:none;border-radius:0;align-items:center;gap:8px;width:100%;padding:8px 14px;font-family:Outfit,sans-serif;font-size:13px;transition:background .15s,color .15s;display:flex}.table-btn:hover{color:var(--warm-dark);background:#ffd09d61}.table-btn.active{color:var(--warm-dark);background:#ffd09dad}.tdot{background:#532a0c47;border-radius:50%;flex-shrink:0;width:6px;height:6px}.table-btn.active .tdot{background:var(--warm-dark)}.tname{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.dash-main{background:#fffaf3db;flex-direction:column;flex:1;display:flex;overflow:hidden}.main-hdr{border-bottom:1px solid #532a0c14;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:18px 24px 12px;display:flex}.main-hdr-left{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.main-title{color:var(--warm-dark);letter-spacing:-.3px;font-size:18px;font-weight:700}.preview-btn{color:var(--warm-dark);cursor:pointer;background:#ffd09d47;border:1px solid #532a0c24;border-radius:999px;align-items:center;gap:6px;padding:6px 12px;font-family:Outfit,sans-serif;font-size:12px;font-weight:600;transition:background .15s,border-color .15s,transform .15s;display:inline-flex}.preview-btn:hover{background:#ffd09d7a;border-color:#532a0c38;transform:translateY(-1px)}.save-pill{color:#532a0cad;letter-spacing:.3px;white-space:nowrap;background:#fff8efe0;border:1px solid #532a0c1a;border-radius:999px;align-items:center;gap:6px;padding:5px 10px;font-size:11px;font-weight:700;display:inline-flex}.save-pill.saving{color:#7a4a18eb;background:#ffd09d57}.save-pill.saved{color:#3f7d58;background:#3f7d581f;border-color:#3f7d582e}.save-pill.error{color:#9b4b35;background:#9b4b351f;border-color:#9b4b3533}.preview-overlay{z-index:220;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#23140a6b;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.preview-shell{background:#fffdf8fa;border:1px solid #532a0c24;border-radius:24px;width:min(1060px,100vw - 28px);max-height:calc(100vh - 28px);padding:18px;overflow:auto;box-shadow:0 24px 64px #23140a42}.preview-head{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.preview-kicker{letter-spacing:2px;text-transform:uppercase;color:#532a0c85;margin-bottom:6px;font-size:10px;font-weight:700}.preview-head h2{color:var(--warm-dark);letter-spacing:-.5px;font-size:26px;line-height:1.1}.preview-meta{color:#532a0ca3;margin-top:8px;font-size:13px}.preview-close{width:38px;height:38px;color:var(--warm-dark);cursor:pointer;background:#ffd09d47;border:1px solid #532a0c1f;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.preview-state{color:#532a0c9e;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;min-height:460px;display:flex}.preview-error{color:#9b4b35}.preview-grid{grid-template-columns:repeat(3,minmax(0,1fr));grid-auto-rows:1fr;gap:14px;display:grid}.preview-card{text-align:left;aspect-ratio:1;background:#fffdf8f0;border:1px solid #532a0c14;border-radius:16px;grid-template-rows:minmax(0,1fr) auto;align-items:stretch;gap:0;height:100%;padding:0;display:grid;overflow:hidden;box-shadow:0 6px 16px #532a0c0a}.preview-image-wrap{width:100%;height:100%;min-height:0;box-shadow:none;background:linear-gradient(#fff 0%,#fffaf3 100%);border:none;border-radius:0;justify-content:center;align-items:center;padding:0;display:flex;position:relative}.preview-image{object-fit:cover;width:100%;height:100%;display:block}.preview-image-wrap{position:relative;overflow:hidden}.preview-hover{pointer-events:auto;opacity:0;z-index:40;flex-direction:column;justify-content:end;align-items:center;gap:8px;padding:12px;transition:opacity .2s,transform .2s;display:flex;position:absolute;inset:0;transform:translateY(8px)}.preview-hover-text{color:#1e140ceb;text-shadow:0 1px #fff9;background:0 0;font-family:Outfit,sans-serif;font-size:13px;font-weight:600}.preview-hover-cta{color:#fff;cursor:pointer;background:linear-gradient(#5c2b11,#5a2910);border:none;border-radius:10px;width:100%;max-width:160px;padding:10px 14px;font-size:14px;font-weight:800;box-shadow:0 6px 18px #532a0c2e}.preview-image-wrap:hover .preview-hover{opacity:1;transform:translateY(0)}.preview-image-wrap:hover .preview-image{filter:blur(4px)saturate(.9)brightness(.95);transform:scale(1.02)}.preview-image-fallback{width:100%;height:100%;color:var(--warm-dark);letter-spacing:-1px;background:linear-gradient(135deg,#ffd09d5c,#532a0c14);border-radius:0;justify-content:center;align-items:center;font-size:30px;font-weight:700;display:flex}.preview-card-footer{-webkit-backdrop-filter:none;backdrop-filter:none;background:#fff8effa;border-top:1px solid #532a0c12;border-bottom-right-radius:16px;border-bottom-left-radius:16px;flex-direction:column;justify-content:flex-end;gap:2px;min-height:72px;padding:12px 12px 14px;display:flex;box-shadow:0 -1px #fff8effa,inset 0 10px 18px -18px #532a0c24}.preview-card-title{color:var(--warm-dark);white-space:nowrap;text-overflow:ellipsis;min-height:0;margin-bottom:0;font-family:Georgia,Times New Roman,serif;font-size:17px;font-weight:700;line-height:1.02;display:block;overflow:hidden}.preview-card-dimension-x{vertical-align:middle;opacity:.78;margin:0 1px;font-family:Outfit,sans-serif;font-size:.68em;font-weight:700;line-height:1;display:inline-block;transform:translateY(-.03em)}.preview-card-price{color:var(--warm-dark);font-family:Outfit,sans-serif;font-size:17px;line-height:1}.preview-card-price-value{font-weight:900}.preview-card-price-unit{color:#532a0ca8;font-size:.7em;font-weight:600}.preview-footer{flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;margin-top:22px;display:flex}.preview-pages{background:#fffaf4fa;border:1px solid #532a0c1f;border-radius:8px;align-items:center;gap:0;display:flex;overflow:hidden}.preview-page,.preview-page-step{height:36px;color:var(--warm-dark);cursor:pointer;background:0 0;border:none;font-family:Outfit,sans-serif;font-size:13px;font-weight:600}.preview-page{border-right:1px solid #532a0c14;min-width:36px;padding:0 10px}.preview-page:last-child{border-right:none}.preview-page.active{color:#fff;background:#111}.preview-page-step{background:#ffd09d33;border:1px solid #532a0c1f;border-radius:8px;justify-content:center;align-items:center;gap:6px;min-width:110px;padding:0 14px;display:inline-flex}.preview-page-step:disabled{opacity:.42;cursor:not-allowed}.grid-wrapper{flex-direction:column;flex:1;display:flex;overflow:hidden}.grid-toolbar{color:#532a0c9e;border-bottom:1px solid #532a0c14;flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 20px;font-size:12px;display:flex}.tb-btn{color:var(--warm-dark);cursor:pointer;background:#ffd09d80;border:1px solid #532a0c29;border-radius:6px;align-items:center;gap:5px;padding:5px 12px;font-family:Outfit,sans-serif;font-size:12px;transition:background .15s,color .15s;display:flex}.tb-btn:hover{color:var(--warm-dark);background:#ffd09db8}.grid-scroll{flex:1;overflow:auto}.dtable{border-collapse:collapse;width:max-content;min-width:100%;font-size:13px}.dtable thead{z-index:2;position:sticky;top:0}.dtable th{text-align:left;color:#fff0df;letter-spacing:.8px;text-transform:none;white-space:nowrap;background:#532a0cf7;border-bottom:1px solid #532a0c29;border-right:1px solid #ffd09d1f;padding:10px 16px;font-size:11px;font-weight:700}.sticky-col{z-index:3;position:sticky}.sticky-col-action{width:54px;min-width:54px;left:0}.sticky-col-id{left:54px}.dtable thead .sticky-col{z-index:4}.dtable tbody tr:nth-child(2n) .sticky-col,.dtable tbody tr:nth-child(2n) .sticky-col-action,.dtable tbody tr:hover .sticky-col,.dtable tbody tr:hover .sticky-col-action{background-color:var(--sticky-bg)}.dtable thead .sticky-col-action,.dtable thead .sticky-col-id{background:#532a0cf7}.dtable tbody .sticky-col,.dtable tbody .sticky-col-action{background-color:var(--sticky-bg);box-shadow:8px 0 12px #532a0c08}.col-label{text-transform:uppercase;letter-spacing:.8px}.col-unit{letter-spacing:.2px;color:#fff0dfc7;margin-left:3px;font-family:Georgia,Times New Roman,serif;font-style:italic;font-weight:500}.dtable th:last-child{border-right:none}.dtable tbody tr{--row-bg:#fff8eff5;--sticky-bg:#fff8ef;background:var(--row-bg);border-bottom:1px solid #532a0c0f;transition:background .1s}.dtable tbody tr:nth-child(2n){--row-bg:#ffd09d1f;--sticky-bg:#fff2e4}.dtable tbody tr:hover{--row-bg:#ffd09d38;--sticky-bg:#ffe8cf}.dtable td{color:var(--warm-text);white-space:nowrap;text-overflow:ellipsis;border-right:1px solid #532a0c0f;max-width:320px;padding:8px 16px;overflow:hidden}.dtable td.sticky-col,.dtable td.sticky-col-action{background-clip:padding-box;background-color:var(--sticky-bg);opacity:1}.dtable td:last-child{border-right:none}.dtable td.cnull{color:#532a0c57;font-style:italic}.dtable td.ctrue{color:#3f7d58;font-weight:600}.dtable td.cfalse{color:#9b4b35}.grid-state{color:#532a0c80;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:48px;font-size:14px;display:flex}.grid-err{color:#9b4b35c7}.spin{animation:.8s linear infinite spin}.grid-message{border-bottom:1px solid #532a0c14;padding:10px 20px;font-size:13px}.grid-message-err{color:#9b4b35;background:#ffd09d38}.toolbar-actions{align-items:center;gap:10px;display:flex}.add-btn{min-width:146px;color:var(--warm-dark);background:#ffd09d;justify-content:center;box-shadow:0 8px 18px #532a0c1f}.add-btn:hover:not(:disabled){background:#f5c07f}.add-btn-large{min-width:190px;padding:12px 18px;font-size:13px}.grid-empty-panel{background:#fff8efdb;border:1px dashed #532a0c2e;border-radius:16px;margin:16px}.action-head{width:54px;min-width:54px;padding:10px 8px}.row-actions-cell{text-align:center;border-right:1px solid #532a0c0f;width:54px;min-width:54px;padding:8px}.row-delete-btn{color:#9b4b35;cursor:pointer;background:#ffd09d59;border:1px solid #9b4b353d;border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;transition:background .15s,transform .15s,color .15s;display:inline-flex}.row-delete-btn:hover{background:#ffd09d9e;transform:translateY(-1px)}.grid-input,.modal-field input[type=text],.modal-field input[type=number]{width:100%;min-width:110px;color:var(--warm-text);font:inherit;background:#fffaf5f5;border:1px solid #532a0c24;border-radius:8px;padding:7px 9px;font-size:13px;transition:border-color .15s,box-shadow .15s,background .15s}.grid-input:focus,.modal-field input[type=text]:focus,.modal-field input[type=number]:focus{border-color:#532a0c66;outline:none;box-shadow:0 0 0 3px #ffd09d47}.grid-input-number{max-width:130px}.grid-id-field{align-items:center;gap:6px;min-width:0;display:inline-flex}.grid-id-value{min-width:16px}.grid-id-edit-btn{color:#532a0cb8;cursor:pointer;opacity:0;background:0 0;border:1px solid #0000;border-radius:7px;justify-content:center;align-items:center;width:24px;height:24px;transition:opacity .15s,background .15s,border-color .15s,transform .15s;display:inline-flex;transform:translateY(1px)}.grid-id-field:hover .grid-id-edit-btn,.grid-id-field:focus-within .grid-id-edit-btn{opacity:1}.grid-id-edit-btn:hover,.grid-id-edit-btn:focus-visible{background:#ffd09d73;border-color:#532a0c1f;outline:none;transform:translateY(0)}.grid-id-edit-icon{font-size:13px;line-height:1}.grid-id-input{width:72px;min-width:72px;padding:5px 8px;font-size:12px}.image-cell{vertical-align:top;padding-top:6px;padding-bottom:6px}.grid-image-field{flex-direction:column;align-items:stretch;gap:0;display:flex}.grid-image-field-row{flex-direction:row;align-items:center;gap:6px}.grid-image-thumb-button{cursor:pointer;background:#fffaf5f5;border:1px solid #532a0c24;border-radius:8px;flex-shrink:0;width:46px;height:34px;padding:0;position:relative;overflow:hidden;box-shadow:0 2px 8px #532a0c14}.grid-image-thumb-image{object-fit:cover;width:100%;height:100%;display:block}.grid-image-thumb-fallback{color:#532a0c6b;background:linear-gradient(135deg,#ffd09d52,#532a0c0f);justify-content:center;align-items:center;width:100%;height:100%;font-size:16px;font-weight:600;display:flex}.grid-image-thumb-overlay{color:#fff;opacity:0;background:#532a0c9e;justify-content:center;align-items:center;padding:0;transition:opacity .18s,transform .18s;display:flex;position:absolute;inset:0;transform:scale(.96)}.grid-image-thumb-button:hover .grid-image-thumb-overlay,.grid-image-thumb-button:focus-visible .grid-image-thumb-overlay{opacity:1;transform:scale(1)}.grid-image-thumb-button:focus-visible{border-color:#532a0c61;outline:none;box-shadow:0 0 0 3px #ffd09d47}.grid-image-url-input{flex:auto;min-width:0;max-width:100%;padding:5px 8px;font-size:12px}.grid-check{width:16px;height:16px;accent-color:var(--warm-dark);cursor:pointer}.modal-overlay{z-index:200;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#532a0c61;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-card{background:#fff8effa;border:1px solid #532a0c29;border-radius:20px;width:min(920px,100%);max-height:min(88vh,900px);padding:22px;overflow:auto;box-shadow:0 24px 72px #532a0c47}.modal-card-small{width:min(520px,100%)}.modal-header{justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:16px;display:flex}.modal-header h2{color:var(--warm-dark);margin-bottom:4px;font-size:22px}.modal-header p{color:#532a0ca8;font-size:13px}.modal-meta{color:#532a0ccc;text-transform:none;letter-spacing:.2px;background:#ffd09d57;border:1px solid #532a0c1f;border-radius:999px;align-items:center;gap:6px;margin-top:8px;padding:6px 10px;font-size:12px;font-weight:600;display:inline-flex}.icon-btn{width:34px;height:34px;color:var(--warm-dark);cursor:pointer;background:#ffd09d57;border:1px solid #532a0c1f;border-radius:10px;justify-content:center;align-items:center;display:inline-flex}.modal-error{color:#8c3f2d;background:#ffd09d42;border:1px solid #9b4b3538;border-radius:12px;margin-bottom:14px;padding:10px 12px;font-size:13px}.modal-form{flex-direction:column;gap:18px;display:flex}.modal-fields{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;display:grid}.modal-preview{background:#ffd09d2e;border:1px solid #532a0c1f;border-radius:14px;flex-direction:column;gap:6px;padding:14px 16px;display:flex}.modal-preview-label{color:#532a0c85;text-transform:uppercase;letter-spacing:.7px;font-size:11px;font-weight:700}.modal-preview-id{color:#532a0c85;width:100%;font:inherit;cursor:not-allowed;pointer-events:none;background:#f5efe7e6;border:1px solid #532a0c1a;border-radius:10px;padding:9px 10px;font-size:14px;font-weight:600}.modal-id-field{position:relative}.modal-preview-id-button{cursor:pointer;pointer-events:auto;text-align:left;justify-content:space-between;align-items:center;gap:8px;display:flex}.modal-preview-id-button .modal-preview-id-icon{opacity:0;color:#532a0c9e;transition:opacity .15s,transform .15s;transform:translateY(1px)}.modal-preview-id-button:hover .modal-preview-id-icon,.modal-preview-id-button:focus-visible .modal-preview-id-icon{opacity:1}.modal-preview-id-button:focus-visible{border-color:#532a0c61;outline:none;box-shadow:0 0 0 3px #ffd09d47}.modal-preview-id-value{flex:1;min-width:0}.modal-preview-id-input{pointer-events:auto;cursor:text}.modal-preview-id:disabled{opacity:1;-webkit-text-fill-color:#532a0c85}.modal-field{color:#532a0cc7;text-transform:uppercase;letter-spacing:.7px;flex-direction:column;gap:6px;font-size:12px;display:flex}.modal-field-heading{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.modal-field-name{color:#532a0cdb;text-transform:uppercase;letter-spacing:.7px;font-size:12px;font-weight:700}.modal-field-unit{color:#532a0c9e;letter-spacing:.3px;text-transform:none;background:#532a0c14;border:1px solid #532a0c1a;border-radius:999px;align-items:center;padding:3px 8px;font-size:11px;font-weight:700;display:inline-flex}.modal-field input[type=checkbox]{width:16px;height:16px;accent-color:var(--warm-dark)}.modal-image-upload-inline{flex-direction:row;align-items:center;gap:8px;width:100%;max-width:100%;min-height:38px;display:flex}.modal-image-upload-fieldwrap{flex:auto;min-width:0;position:relative}.modal-image-upload-input{width:100%;color:var(--warm-dark);font:inherit;text-transform:none;letter-spacing:normal;background:#f5efe7e6;border:1px solid #532a0c1a;border-radius:10px;padding:9px 36px 9px 10px;font-size:14px}.modal-image-upload-input:focus{border-color:#532a0c47;outline:none;box-shadow:0 0 0 3px #ffd09d38}.modal-image-url-editor{flex-direction:column;gap:6px;width:100%;display:flex}.modal-image-upload-btn{min-width:0;color:var(--warm-text);background:#fffaf5f5;border:1px solid #532a0c24;border-radius:8px;flex:auto;align-items:center;padding:7px 10px;font-size:13px;display:inline-flex}.modal-image-upload-btn-label{text-overflow:ellipsis;white-space:nowrap;max-width:100%;margin-left:8px;display:inline-block;overflow:hidden}.modal-image-url-toggle-btn{background:#fffaf5f5;border:1px solid #532a0c24;border-radius:8px;flex:none;align-items:center;padding:7px 10px;font-size:13px;display:inline-flex}.modal-image-url-toggle-btn.is-active{background:#ffd09d52}.modal-image-clear-btn{color:#532a0cb8;cursor:pointer;background:#fff8effa;border:1px solid #532a0c24;border-radius:999px;justify-content:center;align-items:center;width:22px;height:22px;display:inline-flex;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.modal-image-clear-inline{color:#532a0cc7;background:#fffaf5f5;border:1px solid #532a0c24;border-radius:8px;flex:none;justify-content:center;align-items:center;padding:7px 8px;display:inline-flex}.modal-image-clear-inline:hover{background:#ffd09d42}.modal-image-clear-btn:hover,.modal-image-clear-btn:focus-visible{background:#ffd09d42;border-color:#532a0c3d;outline:none}.modal-image-preview-hint{color:#532a0c8a;word-break:break-all;padding-left:2px;font-size:11px;line-height:1.3}.modal-image-upload-name{display:none}@media (width<=640px){.modal-image-upload-inline{flex-direction:column;gap:8px}.modal-image-upload-btn,.modal-image-url-toggle-btn{justify-content:center;width:100%}}.modal-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.modal-cancel{background:#fff8eff5}.delete-preview{color:var(--warm-dark);background:#ffd09d33;border:1px solid #532a0c1f;border-radius:14px;flex-direction:column;gap:4px;margin-bottom:18px;padding:14px 16px;display:flex}.delete-details{grid-template-columns:1fr;gap:8px;max-height:36vh;margin-bottom:18px;padding-right:4px;display:grid;overflow:auto}.delete-detail-row{background:#fff8efeb;border:1px solid #532a0c14;border-radius:12px;justify-content:space-between;align-items:flex-start;gap:12px;padding:10px 12px;display:flex}.delete-detail-label{color:#532a0c99;text-transform:uppercase;letter-spacing:.7px;flex:none;font-size:11px;font-weight:700}.delete-detail-value{color:var(--warm-dark);text-align:right;word-break:break-word;flex:1;font-size:13px}.delete-btn{color:var(--warm-dark);background:#ffd09db8;border:1px solid #9b4b3547}.delete-btn:hover:not(:disabled){background:#ffc387e0}@media (width<=900px){.nav{flex-wrap:wrap;align-items:flex-start;gap:12px;height:auto;padding:12px 16px}.nav-right{flex-wrap:wrap;justify-content:space-between;width:100%;margin-left:0}.nav-email{max-width:100%}.dashboard-body{flex-direction:column;min-height:0}.sidebar{border-bottom:1px solid #532a0c14;border-right:none;width:100%;overflow:auto hidden}.table-list{white-space:nowrap;-webkit-overflow-scrolling:touch;gap:8px;padding:10px 12px 12px;display:flex;overflow-x:auto}.table-list li{flex:none}.table-btn{border-radius:999px;padding:8px 12px}.dash-main{min-height:0}.main-hdr{flex-direction:column;align-items:flex-start;padding:14px 16px 10px}.main-hdr-left{gap:8px}.save-pill{align-self:flex-start}.preview-shell{border-radius:22px;max-height:calc(100vh - 24px);padding:18px}.preview-head{margin-bottom:16px}.preview-head h2{font-size:22px}.preview-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.preview-state{min-height:320px}.preview-footer{gap:10px}.grid-toolbar{flex-direction:column;align-items:flex-start;gap:12px;padding:12px 16px}.toolbar-actions{flex-wrap:wrap;justify-content:flex-start;width:100%}.grid-scroll{-webkit-overflow-scrolling:touch;overflow:auto}.grid-message{padding:10px 16px}.grid-empty-panel{margin:12px;padding:18px 14px}.grid-input,.modal-field input[type=text],.modal-field input[type=number]{min-width:0}.grid-input-number{max-width:88px}.modal-overlay{align-items:flex-end;padding:12px}.modal-card{border-radius:18px 18px 12px 12px;width:100%;max-height:calc(100vh - 24px);padding:16px}.modal-header{margin-bottom:12px}.modal-header h2{font-size:20px}.modal-fields{grid-template-columns:1fr}.modal-actions{flex-direction:column-reverse;align-items:stretch}.modal-actions .tb-btn{width:100%}.delete-details{max-height:30vh}}@media (width<=520px){.page{justify-content:stretch;align-items:stretch}.card{max-width:none;margin:12px;padding:34px 20px 28px}.logo{width:132px}.nav-logo{height:28px}.nav-title{letter-spacing:1.4px;font-size:11px}.nav-user{justify-content:space-between;width:100%}.logout-btn{justify-content:center;width:100%}.main-title{font-size:16px}.preview-btn{padding:5px 10px;font-size:11px}.save-pill{padding:4px 9px;font-size:10px}.grid-toolbar{font-size:11px}.tb-btn,.add-btn,.add-btn-large{min-width:0}.grid-input-number{max-width:76px}.preview-overlay{padding:10px}.preview-shell{border-radius:18px;padding:16px}.preview-head{flex-direction:column}.preview-close{align-self:flex-end}.preview-grid{grid-template-columns:1fr;gap:16px}.preview-page-step{min-width:100px}.delete-detail-row{flex-direction:column;align-items:flex-start}.delete-detail-value{text-align:left}.modal-meta{font-size:11px}.modal-fields{grid-template-columns:1fr}}
