:root{color:#17212f;background:#f5f7fa;font-family:Inter,Noto Sans TC,Microsoft JhengHei,PingFang TC,Arial,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0;background:#f5f7fa}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}h1,h2,h3,p{margin:0}.app-shell{display:grid;min-height:100vh;grid-template-columns:240px minmax(0,1fr)}.app-shell__main{min-width:0}.app-sidebar{display:flex;min-height:100vh;flex-direction:column;gap:24px;border-right:1px solid #dbe1ea;background:#fff;padding:20px 14px}.app-sidebar__brand{display:flex;align-items:center;gap:12px;padding:4px 6px 14px;border-bottom:1px solid #edf0f5}.app-sidebar__brand strong,.app-sidebar__brand span{display:block}.app-sidebar__brand strong{font-size:15px}.app-sidebar__brand span{margin-top:2px;color:#6a7280;font-size:12px}.app-sidebar__mark{display:grid;width:40px;height:40px;place-items:center;border-radius:8px;background:#0f766e;color:#fff;font-weight:700}.app-sidebar__nav{display:flex;flex-direction:column;gap:6px}.app-sidebar__nav a{border-radius:6px;color:#475162;font-size:14px;font-weight:600;padding:10px 12px;transition:background .15s ease,color .15s ease}.app-sidebar__nav a:hover{background:#eef5f4;color:#0f766e}.app-sidebar__nav a.active{background:#dff3ef;color:#0a5f59}.app-header{display:flex;min-height:76px;align-items:center;justify-content:space-between;gap:16px;border-bottom:1px solid #dbe1ea;background:#fff;padding:16px 28px}.app-header h1{font-size:20px;line-height:1.3}.app-header__eyebrow{margin-bottom:2px;color:#6a7280;font-size:12px;font-weight:700;letter-spacing:0}.app-header__user{display:flex;min-width:220px;align-items:center;justify-content:flex-end;gap:12px;color:#6a7280;font-size:12px}.app-header__user>div{display:flex;min-width:0;flex-direction:column;align-items:flex-end;gap:2px}.app-header__user strong{max-width:320px;overflow:hidden;color:#17212f;font-size:14px;text-overflow:ellipsis;white-space:nowrap}.app-header__user small{color:#0f766e;font-size:12px}.app-header__user button{min-height:36px;border:1px solid #cdd6e3;border-radius:6px;background:#fff;color:#475162;cursor:pointer;font:inherit;font-weight:700;padding:6px 12px}.app-header__user button:hover{border-color:#9aa7b7;background:#f7f9fb}.app-header__user button:disabled{cursor:not-allowed;opacity:.6}.app-content{width:100%;max-width:1240px;padding:28px}.page-stack{display:flex;flex-direction:column;gap:20px}@media (max-width: 760px){.app-shell{grid-template-columns:1fr}.app-sidebar{min-height:auto;border-bottom:1px solid #dbe1ea;border-right:0}.app-sidebar__nav{flex-direction:row;flex-wrap:wrap}.app-header{align-items:flex-start;flex-direction:column;padding:16px}.app-header__user{align-items:flex-start;justify-content:flex-start}.app-header__user>div{align-items:flex-start}.app-content{padding:16px}}.standalone-state{display:grid;min-height:100vh;place-items:center;padding:24px}.standalone-state .alert{max-width:520px}.login-page{display:grid;min-height:100vh;place-items:center;background:linear-gradient(180deg,#eef5f4b8,#f7f9fbdb),#f7f9fb;padding:24px}.login-card{width:min(100%,440px);border:1px solid #dbe1ea;border-radius:8px;background:#fff;box-shadow:0 18px 50px #0f172a1a;padding:28px}.login-brand{display:flex;align-items:center;gap:14px;margin-bottom:18px}.login-brand h1{font-size:24px;line-height:1.25}.login-brand p{margin-top:4px;color:#6a7280;font-size:14px}.login-brand__mark{display:grid;width:58px;height:58px;flex:0 0 auto;place-items:center;border-radius:12px;background:#0f766e;color:#fff;font-size:18px;font-weight:800}.login-card__intro{margin-bottom:18px;color:#475162;line-height:1.7}.login-form{display:flex;flex-direction:column;gap:14px;margin-top:18px}.login-form label{display:flex;flex-direction:column;gap:6px}.login-form span{color:#475162;font-size:13px;font-weight:700}.login-form input{width:100%;min-height:44px;border:1px solid #cdd6e3;border-radius:6px;background:#fff;color:#17212f;font:inherit;padding:9px 11px}.login-form input:focus{border-color:#0f766e;box-shadow:0 0 0 3px #0f766e1f;outline:0}.login-form input:disabled{background:#f7f9fb;cursor:not-allowed}.login-form button{min-height:44px;border:1px solid #0f766e;border-radius:6px;background:#0f766e;color:#fff;cursor:pointer;font:inherit;font-weight:700;padding:10px 14px}.login-form button:hover{background:#0a5f59}.login-form button:disabled{cursor:not-allowed;opacity:.65}.page-hero,.content-section,.summary-card,.feature-card,.state{border:1px solid #dbe1ea;border-radius:8px;background:#fff;box-shadow:0 1px 2px #0f172a0a}.page-hero{padding:28px}.page-hero h2{margin-bottom:8px;font-size:28px;line-height:1.25}.page-hero p{max-width:760px;color:#475162;line-height:1.7}.page-hero__label{margin-bottom:8px;color:#0f766e;font-size:13px;font-weight:700}.summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.summary-card{display:flex;min-height:140px;flex-direction:column;gap:8px;padding:18px}.summary-card span{color:#6a7280;font-size:13px;font-weight:700}.summary-card strong{color:#17212f;font-size:22px;line-height:1.3}.summary-card p{color:#475162;font-size:14px;line-height:1.6}.content-section{padding:22px}.section-heading{margin-bottom:18px}.section-heading h2{margin-bottom:6px;font-size:20px}.section-heading p{color:#6a7280;line-height:1.7}.section-heading--split{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.audit-summary{flex:0 0 auto;border-radius:999px;background:#eef5f4;color:#0a5f59;font-size:13px;font-weight:700;padding:8px 12px}.dashboard-orders-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:18px}.dashboard-orders-section{padding:0}.dashboard-orders-section>.section-heading{margin-bottom:0;padding:22px}.dashboard-orders-section .state{border-width:1px 0 0;border-radius:0;box-shadow:none}.dashboard-table-toolbar{display:flex;justify-content:flex-end;border-top:1px solid #edf0f5;padding:14px 22px}.dashboard-page-size{display:inline-flex;align-items:center;gap:8px;color:#475162;font-size:13px;font-weight:700}.dashboard-page-size select{min-height:34px;border:1px solid #cdd6e3;border-radius:6px;background:#fff;color:#17212f;font:inherit;padding:6px 8px}.dashboard-page-size select:disabled{cursor:not-allowed;opacity:.65}.dashboard-orders-error{display:grid;gap:14px;border-top:1px solid #edf0f5;padding:22px}.dashboard-orders-error .permission-denied{margin:0}.dashboard-empty-state{border-top:1px solid #edf0f5;padding:64px 24px;text-align:center}.dashboard-empty-state__title{display:block;margin-bottom:8px;color:#1f2937;font-size:18px;font-weight:700}.dashboard-empty-state__description{display:block;margin:0;color:#6b7280;line-height:1.6}.pending-orders-table-wrap{width:100%;overflow-x:auto}.pending-orders-table{width:100%;min-width:1340px;table-layout:fixed}.pending-orders-table strong,.pending-orders-table small{display:block}.pending-orders-table small{margin-top:4px;color:#6a7280;font-size:12px}.pending-orders-table th:nth-child(1),.pending-orders-table td:nth-child(1){width:160px}.pending-orders-table th:nth-child(2),.pending-orders-table td:nth-child(2){width:160px}.pending-orders-table th:nth-child(3),.pending-orders-table td:nth-child(3){width:220px}.pending-orders-table th:nth-child(4),.pending-orders-table td:nth-child(4){width:280px}.pending-orders-table th:nth-child(5),.pending-orders-table td:nth-child(5){width:140px}.pending-orders-table th:nth-child(6),.pending-orders-table td:nth-child(6){width:280px}.pending-orders-table th:nth-child(7),.pending-orders-table td:nth-child(7){width:100px}.dashboard-table-header-button{display:inline-flex;width:100%;min-height:28px;align-items:center;justify-content:flex-start;gap:6px;border:0;background:transparent;color:#475162;cursor:pointer;font:inherit;font-size:12px;font-weight:800;padding:0;text-align:left}.dashboard-table-header-button:hover,.dashboard-table-header-button.is-active{color:#0f766e}.dashboard-table-sort-icon{color:#6a7280;font-size:12px;line-height:1}.dashboard-table-header-button.is-active .dashboard-table-sort-icon{color:#0f766e}.dashboard-table-cell--wrap{white-space:normal;word-break:break-word;overflow-wrap:anywhere}.dashboard-table-cell--truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pending-orders-table__items,.pending-orders-table__address{display:block;overflow-wrap:anywhere}.pending-orders-table__item{display:block;line-height:1.5}.pending-orders-table__item+.pending-orders-table__item{margin-top:4px}.pending-orders-table__action{text-align:center}.pending-orders-table__action .table-action-button{min-width:52px;white-space:nowrap}.dashboard-pagination{display:flex;align-items:center;justify-content:space-between;gap:12px;border-top:1px solid #edf0f5;color:#475162;font-size:13px;padding:14px 22px}.dashboard-pagination__info{font-weight:700}.dashboard-pagination__actions{display:flex;gap:8px}.filter-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.filter-grid label{display:flex;flex-direction:column;gap:6px}.filter-grid span{color:#475162;font-size:13px;font-weight:700}.filter-grid input,.filter-grid select{width:100%;min-height:40px;border:1px solid #cdd6e3;border-radius:6px;background:#fff;color:#17212f;font:inherit;padding:8px 10px}.filter-grid input:focus,.filter-grid select:focus{border-color:#0f766e;box-shadow:0 0 0 3px #0f766e1f;outline:0}.filter-actions{display:flex;align-items:end;gap:8px}.filter-actions button{min-height:40px;border:1px solid #0f766e;border-radius:6px;background:#0f766e;color:#fff;cursor:pointer;font:inherit;font-weight:700;padding:8px 14px}.filter-actions button:hover{background:#0a5f59}.filter-actions button.button-secondary{border-color:#cdd6e3;background:#fff;color:#475162}.filter-actions button.button-secondary:hover{border-color:#9aa7b7;background:#f7f9fb}.audit-table-section{padding:0}.audit-table-wrap{overflow-x:auto}.audit-table{width:100%;min-width:900px;border-collapse:collapse}.audit-table th,.audit-table td{border-bottom:1px solid #edf0f5;padding:12px 14px;text-align:left;vertical-align:top}.audit-table th{background:#f7f9fb;color:#475162;font-size:12px;font-weight:700}.audit-table td{color:#17212f;font-size:14px;line-height:1.5}.audit-table tr:last-child td{border-bottom:0}.status-pill{display:inline-flex;min-width:48px;justify-content:center;border-radius:999px;font-size:12px;font-weight:700;padding:4px 8px}.status-pill--success{background:#e8f7ee;color:#167044}.status-pill--failed{background:#fff1f1;color:#b42318}.status-pill--unknown{background:#f1f4f8;color:#475162}.rbac-table-wrap{overflow-x:auto}.table-row-selected{background:#f4fbf9}.table-action-button{min-height:34px;border:1px solid #0f766e;border-radius:6px;background:#fff;color:#0f766e;cursor:pointer;font:inherit;font-size:13px;font-weight:700;padding:6px 12px}.table-action-button:hover{background:#eef5f4}.table-action-button:disabled{cursor:not-allowed;opacity:.6}.table-action-button--warning{border-color:#c77700;color:#9a5a00}.table-action-button--warning:hover{background:#fff8e8}.table-action-button--secondary{border-color:#cdd6e3;color:#475162}.table-action-button--secondary:hover{border-color:#9aa7b7;background:#f7f9fb}.table-action-button--danger{border-color:#b42318;color:#b42318}.table-action-button--danger:hover{background:#fff1f1}.rbac-editor{display:flex;flex-direction:column;gap:18px}.rbac-editor__user{border:1px solid #dbe1ea;border-radius:8px;background:#f7f9fb;padding:16px}.rbac-editor__user span,.rbac-editor__user strong,.rbac-editor__user small{display:block}.rbac-editor__user span{margin-bottom:6px;color:#6a7280;font-size:13px;font-weight:700}.rbac-editor__user strong{color:#17212f;font-size:18px}.rbac-editor__user p{margin-top:4px;color:#475162}.rbac-editor__user small{margin-top:10px;color:#0f766e;font-size:13px;font-weight:700}.role-option-grid,.role-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.role-option{display:grid;grid-template-columns:auto minmax(0,1fr);gap:10px;border:1px solid #dbe1ea;border-radius:8px;background:#fff;cursor:pointer;padding:14px}.role-option:has(input:checked){border-color:#0f766e;background:#f4fbf9}.role-option input{margin-top:3px}.role-option strong,.role-option small,.role-option em{display:block}.role-option strong{color:#17212f}.role-option small{margin-top:4px;color:#475162;line-height:1.5}.role-option em{margin-top:8px;color:#6a7280;font-size:12px;font-style:normal;line-height:1.5}.role-card{border:1px solid #dbe1ea;border-radius:8px;background:#fff;padding:16px}.role-card h3{margin-bottom:6px;font-size:16px}.role-card p{color:#475162;line-height:1.6}.role-card__meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.role-card__meta span{border-radius:999px;background:#eef5f4;color:#0a5f59;font-size:12px;font-weight:700;padding:5px 9px}.products-table{min-width:980px;table-layout:fixed}.products-table strong,.products-table small{display:block}.products-table small{margin-top:4px;color:#6a7280}.products-table th:nth-child(1),.products-table td:nth-child(1){width:28%}.products-table th:nth-child(2),.products-table td:nth-child(2){width:10%}.products-table th:nth-child(3),.products-table td:nth-child(3){width:14%}.products-table th:nth-child(4),.products-table td:nth-child(4){width:16%}.products-table th:nth-child(5),.products-table td:nth-child(5){width:14%}.products-table-wrap{overflow-x:auto}.products-table__actions{width:auto;min-width:220px}.products-table__actions-inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-start;gap:8px;max-width:100%}.products-table__actions button{white-space:nowrap}.product-categories-table-wrap{overflow-x:auto}.product-categories-table{min-width:900px;table-layout:fixed}.product-categories-table th:nth-child(1),.product-categories-table td:nth-child(1){width:28%}.product-categories-table th:nth-child(2),.product-categories-table td:nth-child(2){width:16%}.product-categories-table th:nth-child(3),.product-categories-table td:nth-child(3){width:10%}.product-categories-table th:nth-child(4),.product-categories-table td:nth-child(4){width:10%}.product-categories-table th:nth-child(5),.product-categories-table td:nth-child(5){width:16%}.product-display-table-wrap{overflow-x:auto}.product-display-groups{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.product-display-groups button{display:grid;gap:8px;min-height:92px;border:1px solid #dbe1ea;border-radius:8px;background:#fff;color:#17212f;cursor:pointer;font:inherit;padding:14px;text-align:left}.product-display-groups button:hover{border-color:#0f766e;background:#f8fbfb}.product-display-groups button.is-active{border-color:#0f766e;background:#eef5f4;box-shadow:0 0 0 3px #0f766e1f}.product-display-groups strong{font-size:15px}.product-display-groups span{width:fit-content;border-radius:999px;background:#0f766e;color:#fff;font-size:12px;font-weight:800;padding:5px 8px}.product-display-table{min-width:1040px;table-layout:fixed}.product-display-table th:nth-child(1),.product-display-table td:nth-child(1){width:28%}.product-display-table th:nth-child(2),.product-display-table td:nth-child(2){width:16%}.product-display-table th:nth-child(3),.product-display-table td:nth-child(3),.product-display-table th:nth-child(4),.product-display-table td:nth-child(4),.product-display-table th:nth-child(5),.product-display-table td:nth-child(5){width:9%}.product-display-table th:nth-child(6),.product-display-table td:nth-child(6){width:18%}.product-display-search{width:min(260px,100%);min-height:40px;border:1px solid #cdd6e3;border-radius:6px;background:#fff;color:#17212f;font:inherit;padding:8px 10px}.product-display-search:focus{border-color:#0f766e;box-shadow:0 0 0 3px #0f766e1f;outline:0}.product-display-badges,.product-display-badge-options{display:flex;flex-wrap:wrap;gap:6px}.product-display-badges span{border-radius:999px;background:#eef5f4;color:#0a5f59;font-size:12px;font-weight:700;padding:5px 8px}.product-display-single-badge{display:inline-flex;border-radius:999px;background:#eef5f4;color:#0a5f59;font-size:12px;font-weight:800;padding:5px 9px}.product-display-muted{color:#6a7280;font-size:13px}.product-display-window{display:grid;gap:4px}.product-display-window span{color:#475162;font-size:13px}.product-display-dialog{width:min(640px,100%)}.product-display-form{padding:22px}.product-display-group-readonly{display:grid;gap:6px;border:1px solid #dbe1ea;border-radius:8px;background:#f7f9fb;padding:12px}.product-display-group-readonly span{color:#475162;font-size:13px;font-weight:700}.product-display-group-readonly strong{color:#17212f}.product-display-group-readonly small{color:#6a7280;line-height:1.5}.product-display-add-dialog{display:grid;gap:16px;padding:22px}.product-display-add-search{display:grid;gap:6px}.product-display-add-search span{color:#475162;font-size:13px;font-weight:700}.product-display-add-search input{width:100%;min-height:40px;border:1px solid #cdd6e3;border-radius:6px;background:#fff;color:#17212f;font:inherit;padding:8px 10px}.product-display-add-search input:focus{border-color:#0f766e;box-shadow:0 0 0 3px #0f766e1f;outline:0}.product-display-add-list{display:grid;max-height:min(52vh,520px);gap:8px;overflow-y:auto;border:1px solid #dbe1ea;border-radius:8px;background:#f7f9fb;padding:10px}.product-display-add-item{display:grid;grid-template-columns:auto minmax(0,1fr);gap:10px;align-items:center;border:1px solid #dbe1ea;border-radius:8px;background:#fff;cursor:pointer;padding:10px}.product-display-add-item:has(input:checked){border-color:#0f766e;background:#eef5f4}.product-display-add-item>input{width:auto;min-height:0}.product-display-badge-field{display:grid;gap:8px}.product-display-badge-field>span{color:#475162;font-size:13px;font-weight:700}.product-display-badge-options{border:1px solid #cdd6e3;border-radius:6px;background:#fff;padding:10px}.product-display-badge-options label{display:inline-flex;min-height:34px;align-items:center;gap:6px;border:1px solid #dbe1ea;border-radius:999px;cursor:pointer;padding:6px 10px}.product-display-badge-options label:has(input:checked){border-color:#0f766e;background:#eef5f4;color:#0a5f59}.product-display-badge-options input{width:auto;min-height:0}.product-display-badge-options span{font-size:13px;font-weight:700}.product-category-name{min-width:0}.product-category-name strong,.product-category-name small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.product-category-name small{margin-top:4px;color:#6a7280}.product-category-dialog{width:min(600px,100%)}.product-category-dialog .category-form{gap:16px;padding:24px 28px 26px}.product-category-dialog .category-form label{gap:8px}.product-category-dialog .category-form input,.product-category-dialog .category-form select,.product-category-dialog .category-form textarea{box-sizing:border-box}.publish-readiness{min-width:0}.publish-readiness__badges{display:flex;flex-wrap:wrap;gap:6px}.publish-readiness-badge{display:inline-flex;align-items:center;border-radius:999px;font-size:12px;font-weight:700;line-height:1;padding:6px 9px;white-space:nowrap}.publish-readiness-badge--ready{background:#eef5f4;color:#0a5f59}.publish-readiness-badge--published{background:#ecfdf3;color:#047857}.publish-readiness-badge--missing{background:#fff7ed;color:#b45309}.publish-readiness-badge--more{background:#f3f4f6;color:#5b6472}.products-pagination{display:flex;align-items:center;justify-content:flex-end;gap:12px;border-top:1px solid #edf0f5;color:#475162;font-size:13px;padding:14px}.products-pagination label{display:inline-flex;align-items:center;gap:6px}.products-pagination select{min-height:34px;border:1px solid #cdd6e3;border-radius:6px;background:#fff;color:#17212f;font:inherit;padding:6px 8px}.products-pagination__actions{display:flex;gap:8px}.products-pagination__actions button{min-height:34px;border:1px solid #0f766e;border-radius:6px;background:#0f766e;color:#fff;cursor:pointer;font:inherit;font-weight:700;padding:6px 12px}.products-pagination__actions button:hover{background:#0a5f59}.products-pagination__actions button:disabled{cursor:not-allowed;opacity:.6}.products-pagination__actions button.button-secondary{border-color:#cdd6e3;background:#fff;color:#475162}.products-pagination__actions button.button-secondary:hover{border-color:#9aa7b7;background:#f7f9fb}.products-toolbar{display:flex;flex:0 0 auto;flex-wrap:wrap;justify-content:flex-end;gap:8px}.products-toolbar button{min-height:40px;border:1px solid #0f766e;border-radius:6px;background:#0f766e;color:#fff;cursor:pointer;font:inherit;font-weight:700;padding:8px 14px}.products-toolbar button:hover{background:#0a5f59}.products-toolbar button:disabled{cursor:not-allowed;opacity:.6}.products-toolbar button.button-secondary{border-color:#cdd6e3;background:#fff;color:#475162}.products-toolbar button.button-secondary:hover{border-color:#9aa7b7;background:#f7f9fb}.product-import-tools{background:#f8fbfb}.product-import-tools__content{display:flex;align-items:flex-start;justify-content:space-between;gap:18px}.product-import-tools__content h2{margin-bottom:6px;font-size:18px}.product-import-tools__content p{max-width:760px;color:#475162;line-height:1.7}.product-import-tools__actions{display:flex;flex:0 0 auto;flex-wrap:wrap;justify-content:flex-end;gap:8px}.product-import-tools__actions button{min-height:40px;border:1px solid #0f766e;border-radius:6px;background:#0f766e;color:#fff;cursor:pointer;font:inherit;font-weight:700;padding:8px 14px}.product-import-tools__actions button:hover{background:#0a5f59}.product-import-tools__actions button.button-secondary{border-color:#cdd6e3;background:#fff;color:#475162}.product-import-tools__actions button.button-secondary:hover{border-color:#9aa7b7;background:#f7f9fb}.product-cell{display:grid;grid-template-columns:48px minmax(0,1fr);gap:12px;align-items:center}.product-cell__text{min-width:0}.product-cell__text strong,.product-cell__text small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.product-thumbnail{display:block;width:48px;height:48px;border:1px solid #dbe1ea;border-radius:8px;background:#f7f9fb;object-fit:cover}.product-thumbnail-button{display:block;width:48px;height:48px;border:0;background:transparent;cursor:pointer;padding:0}.product-thumbnail-button:hover .product-thumbnail{border-color:#0f766e;box-shadow:0 0 0 3px #0f766e1f}.product-thumbnail--empty{display:grid;place-items:center;color:#9aa7b7;font-size:12px;font-weight:700}.product-form{display:flex;flex-direction:column;gap:14px}.product-form label{display:flex;flex-direction:column;gap:6px}.product-form span{color:#475162;font-size:13px;font-weight:700}.product-form input,.product-form select,.product-form textarea{width:100%;min-height:40px;border:1px solid #cdd6e3;border-radius:6px;background:#fff;color:#17212f;font:inherit;padding:8px 10px}.product-form input:focus,.product-form select:focus,.product-form textarea:focus{border-color:#0f766e;box-shadow:0 0 0 3px #0f766e1f;outline:0}.product-form input:disabled,.product-form select:disabled,.product-form textarea:disabled{background:#f1f4f8;color:#6a7280;cursor:not-allowed}.product-form textarea{resize:vertical}.product-preview{display:grid;grid-template-columns:auto minmax(0,1fr);gap:12px;align-items:center;border:1px solid #dbe1ea;border-radius:8px;background:#f7f9fb;padding:12px}.product-preview strong,.product-preview span{display:block}.product-preview strong{overflow:hidden;color:#17212f;text-overflow:ellipsis;white-space:nowrap}.product-preview span{margin-top:4px;color:#6a7280;font-size:13px}.product-readonly{border:1px solid #dbe1ea;border-radius:8px;background:#f7f9fb;padding:12px}.product-readonly span,.product-readonly small{display:block}.product-readonly span{color:#475162;font-size:13px;font-weight:700}.product-readonly p{margin-top:6px;overflow-wrap:anywhere;color:#17212f;line-height:1.5}.product-readonly small{margin-top:6px;color:#6a7280;font-size:12px}.product-category-field{display:flex;flex-direction:column;gap:6px}.product-category-field>span{color:#475162;font-size:13px;font-weight:700}.product-category-options{display:grid;max-height:180px;gap:8px;overflow-y:auto;border:1px solid #cdd6e3;border-radius:6px;background:#fff;padding:10px}.product-category-options label{display:grid;grid-template-columns:auto minmax(0,1fr);gap:8px;align-items:center;color:#17212f;font-size:14px}.product-category-options input{width:auto;min-height:0}.product-category-options span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.product-category-options p{color:#6a7280;font-size:13px;line-height:1.6}.product-create-listing{display:grid;gap:14px;border:1px solid #dbe1ea;border-radius:8px;background:#f7f9fb;padding:12px}.product-create-listing__heading strong,.product-create-listing__heading small{display:block}.product-create-listing__heading strong{color:#17212f;font-size:15px}.product-create-listing__heading small{margin-top:4px;color:#6a7280;font-size:13px;line-height:1.6}.product-variant-table-wrap{overflow-x:auto}.product-variant-table{width:100%;min-width:680px;border-collapse:collapse}.product-variant-table th,.product-variant-table td{border-bottom:1px solid #dbe1ea;padding:8px;text-align:left;vertical-align:middle}.product-variant-table th{color:#475162;font-size:12px;font-weight:700}.product-variant-table td{color:#17212f;font-size:13px}.product-variant-table input{min-height:36px}.product-variant-table button{min-height:32px;border:1px solid #cdd6e3;border-radius:6px;background:#fff;color:#475162;cursor:pointer;font:inherit;font-size:12px;font-weight:700;padding:5px 8px}.product-variant-table button:hover{border-color:#9aa7b7;background:#f7f9fb}.product-variant-table button:disabled{cursor:not-allowed;opacity:.6}.product-variant-enabled{display:inline-flex;min-height:36px;align-items:center;gap:6px}.product-variant-enabled input{width:auto;min-height:0}.product-variant-enabled span{color:#17212f;font-size:13px;font-weight:700}.product-variant-actions{display:flex;justify-content:flex-start}.product-variant-actions button{min-height:36px;border:1px solid #cdd6e3;border-radius:6px;background:#fff;color:#475162;cursor:pointer;font:inherit;font-size:13px;font-weight:700;padding:7px 12px}.product-variant-actions button:hover{border-color:#9aa7b7;background:#f7f9fb}.product-variant-actions button:disabled{cursor:not-allowed;opacity:.6}.product-helper-text{color:#6a7280;font-size:13px;line-height:1.6}.product-field-error{color:#b42318;font-size:13px;font-weight:700;line-height:1.5}.product-checkbox-field{justify-content:start}.product-checkbox-control{display:inline-flex;min-height:40px;align-items:center;gap:8px;color:#17212f;font-size:14px;font-weight:700}.product-checkbox-control input{width:auto;min-height:0}.product-image-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:10px}.product-image-heading{display:flex;align-items:center;justify-content:space-between;gap:12px}.product-image-heading>span{color:#475162;font-size:13px;font-weight:700}.image-upload-button{display:inline-flex;min-height:34px;align-items:center;border:1px solid #0f766e;border-radius:6px;background:#0f766e;color:#fff;cursor:pointer;font-size:13px;font-weight:700;padding:6px 10px}.image-upload-button input{display:none}.image-upload-button:has(input:disabled){cursor:not-allowed;opacity:.6}.product-image-option{position:relative;display:grid;gap:6px;border:1px solid #dbe1ea;border-radius:8px;background:#fff;padding:8px}.product-image-option img{width:100%;aspect-ratio:1;border-radius:6px;object-fit:cover}.product-image-option span{color:#475162;font-size:12px;font-weight:700;text-align:center}.product-image-option strong{color:#0a5f59;font-size:12px;text-align:center}.product-image-preview-trigger{position:absolute;top:8px;right:8px;left:8px;aspect-ratio:1;border:0;border-radius:6px;background:transparent;cursor:pointer;padding:0}.product-image-preview-trigger:hover{box-shadow:inset 0 0 0 3px #0f766e3d}.product-image-preview-trigger:disabled{cursor:default}.product-image-actions{display:grid;grid-template-columns:1fr;gap:6px}.product-image-actions button{min-height:32px;border:1px solid #0f766e;border-radius:6px;background:#0f766e;color:#fff;cursor:pointer;font:inherit;font-size:12px;font-weight:700;padding:5px 8px}.product-image-actions button:hover{background:#0a5f59}.product-image-actions button:disabled{cursor:not-allowed;opacity:.6}.product-image-actions button.button-secondary{border-color:#cdd6e3;background:#fff;color:#475162}.product-image-actions button.button-secondary:hover{border-color:#9aa7b7;background:#f7f9fb}.product-image-order-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.dialog-backdrop{position:fixed;z-index:20;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#0f172a7a;padding:24px}.dialog-panel{width:min(720px,100%);max-height:calc(100vh - 48px);overflow-y:auto;border:1px solid #dbe1ea;border-radius:8px;background:#fff;box-shadow:0 24px 60px #0f172a3d}.dialog-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;border-bottom:1px solid #edf0f5;padding:20px 22px}.dialog-header h2{margin-bottom:6px;font-size:20px}.dialog-header p{color:#6a7280;line-height:1.6}.dialog-close-button{display:grid;flex:0 0 auto;width:34px;height:34px;place-items:center;border:1px solid #cdd6e3;border-radius:6px;background:#fff;color:#475162;cursor:pointer;font:inherit;font-size:22px;line-height:1}.dialog-close-button:hover{background:#f7f9fb}.dialog-close-button:disabled{cursor:not-allowed;opacity:.6}.product-dialog .product-form{padding:22px}.product-dialog .state--loading{min-height:260px}.product-dialog__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.product-import-dialog__panel{width:min(760px,100%)}.product-import-dialog__body{display:grid;gap:18px;padding:22px}.product-import-dialog__section{display:grid;gap:10px;border:1px solid #dbe1ea;border-radius:8px;background:#f7f9fb;padding:14px}.product-import-dialog__section h3{color:#17212f;font-size:16px}.product-import-dialog__section p{color:#475162;line-height:1.6}.product-import-dialog__section button{width:fit-content;min-height:38px;border:1px solid #0f766e;border-radius:6px;background:#0f766e;color:#fff;cursor:pointer;font:inherit;font-weight:700;padding:8px 12px}.product-import-dialog__section button:hover{background:#0a5f59}.product-import-dialog__section button:disabled{cursor:not-allowed;opacity:.6}.product-import-dialog__section button.button-secondary{border-color:#cdd6e3;background:#fff;color:#475162}.product-import-dialog__section button.button-secondary:hover{border-color:#9aa7b7;background:#fff}.product-import-file{display:grid;gap:6px}.product-import-file span{color:#475162;font-size:13px;font-weight:700}.product-import-file input{width:100%;border:1px solid #cdd6e3;border-radius:6px;background:#fff;color:#17212f;font:inherit;padding:8px 10px}.product-import-file__meta{color:#0a5f59;font-size:13px;font-weight:700}.product-import-notes{display:grid;gap:4px}.product-import-result{display:grid;gap:12px}.product-import-errors-wrap{max-height:260px;overflow:auto;border:1px solid #dbe1ea;border-radius:8px}.product-import-errors{min-width:760px}.product-import-success-list{display:grid;gap:8px}.product-import-success-item{display:grid;gap:4px;border:1px solid #dbe1ea;border-radius:8px;background:#fff;padding:10px 12px}.product-import-success-item strong{color:#17212f}.product-import-success-item small{color:#6a7280;line-height:1.5}.product-image-preview{z-index:35}.product-image-preview__panel{width:min(920px,100%)}.product-image-preview__body{display:grid;gap:16px;padding:22px}.product-image-preview__image{display:block;width:100%;max-height:min(62vh,680px);border:1px solid #dbe1ea;border-radius:8px;background:#f7f9fb;object-fit:contain}.product-image-preview__meta{display:grid;gap:6px;border:1px solid #dbe1ea;border-radius:8px;background:#f7f9fb;padding:12px}.product-image-preview__meta strong{color:#475162;font-size:13px}.product-image-preview__meta p{overflow-wrap:anywhere;color:#17212f;line-height:1.6}.dialog-actions{display:flex;justify-content:flex-end;gap:8px;border-top:1px solid #edf0f5;padding-top:16px}.dialog-actions button{min-height:40px;border:1px solid #0f766e;border-radius:6px;background:#0f766e;color:#fff;cursor:pointer;font:inherit;font-weight:700;padding:8px 14px}.dialog-actions button:hover{background:#0a5f59}.dialog-actions button:disabled{cursor:not-allowed;opacity:.6}.dialog-actions button.button-secondary{border-color:#cdd6e3;background:#fff;color:#475162}.dialog-actions button.button-secondary:hover{border-color:#9aa7b7;background:#f7f9fb}.dialog-actions__leading{margin-right:auto}.product-hidden-submit{display:none}.message-dialog-backdrop{position:fixed;z-index:30;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#0f172a6b;padding:24px}.message-dialog-panel{width:min(520px,100%);border:1px solid #dbe1ea;border-radius:8px;background:#fff;box-shadow:0 24px 60px #0f172a3d;overflow:hidden}.message-dialog-header{display:grid;grid-template-columns:auto minmax(0,1fr);gap:12px;align-items:center;border-bottom:1px solid #edf0f5;padding:18px 20px}.message-dialog-mark{width:12px;height:12px;border-radius:999px;background:#6a7280}.message-dialog-title{margin:0;color:#17212f;font-size:20px;line-height:1.3}.message-dialog-body{padding:18px 20px}.message-dialog-body p{color:#17212f;line-height:1.7}.message-dialog-detail{margin-top:12px;border-radius:6px;background:#f7f9fb;color:#475162;font-size:13px;line-height:1.6;overflow-wrap:anywhere;padding:10px 12px}.message-dialog-actions{display:flex;justify-content:flex-end;border-top:1px solid #edf0f5;padding:14px 20px}.message-dialog-actions button{min-height:40px;border:1px solid #0f766e;border-radius:6px;background:#0f766e;color:#fff;cursor:pointer;font:inherit;font-weight:700;padding:8px 14px}.message-dialog-actions button:hover{background:#0a5f59}.message-dialog-success .message-dialog-mark{background:#167044}.message-dialog-error .message-dialog-mark{background:#b42318}.message-dialog-warning .message-dialog-mark{background:#c77700}.message-dialog-info .message-dialog-mark{background:#0f766e}.confirm-dialog-backdrop{position:fixed;z-index:30;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#0f172a6b;padding:24px}.confirm-dialog-panel{width:min(520px,100%);overflow:hidden;border:1px solid #dbe1ea;border-radius:8px;background:#fff;box-shadow:0 24px 60px #0f172a3d}.confirm-dialog-header{border-bottom:1px solid #edf0f5;padding:18px 20px}.confirm-dialog-header h2{font-size:20px;line-height:1.3}.confirm-dialog-body{padding:18px 20px}.confirm-dialog-body p{color:#17212f;line-height:1.7}.confirm-dialog-detail{margin-top:12px;border-radius:6px;background:#fff8e8;color:#7a4b00;font-size:13px;line-height:1.6;padding:10px 12px}.confirm-dialog-actions{display:flex;justify-content:flex-end;gap:8px;border-top:1px solid #edf0f5;padding:14px 20px}.confirm-dialog-actions button{min-height:40px;border:1px solid #c77700;border-radius:6px;background:#c77700;color:#fff;cursor:pointer;font:inherit;font-weight:700;padding:8px 14px}.confirm-dialog-actions button:hover{background:#9a5a00}.confirm-dialog-actions button:disabled{cursor:not-allowed;opacity:.6}.confirm-dialog-actions button.button-secondary{border-color:#cdd6e3;background:#fff;color:#475162}.confirm-dialog-actions button.button-secondary:hover{border-color:#9aa7b7;background:#f7f9fb}.feature-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.feature-card{display:block;min-height:140px;padding:18px;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.feature-card span{display:block;margin-bottom:8px;color:#0f766e;font-size:18px;font-weight:700}.feature-card p{color:#475162;line-height:1.7}.feature-card:hover{border-color:#0f766e;box-shadow:0 10px 20px #0f766e1f;transform:translateY(-1px)}.alert{border:1px solid #cdd6e3;border-radius:8px;background:#fff;padding:14px 16px;color:#17212f}.alert--info{border-color:#b8d6ef;background:#eef7ff}.alert--success{border-color:#b7dec8;background:#effaf3}.alert--warning{border-color:#f2d28a;background:#fff8e8}.alert--error{border-color:#efb6b6;background:#fff1f1}.alert__title{margin-bottom:4px;font-weight:700}.alert__message{line-height:1.7}.state{display:flex;align-items:center;justify-content:center;min-height:180px;padding:24px;color:#475162;text-align:center}.state h2{margin-bottom:6px;font-size:18px}.state p{color:#6a7280;line-height:1.7}.state--loading{min-height:100vh;flex-direction:column;gap:14px;border:0;border-radius:0;box-shadow:none}.state__spinner{width:28px;height:28px;border:3px solid #cdd6e3;border-top-color:#0f766e;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 900px){.summary-grid,.feature-grid,.filter-grid,.product-dialog__grid,.role-option-grid,.role-list{grid-template-columns:1fr}.products-table-wrap{overflow-x:auto}.products-table{min-width:980px}.section-heading--split,.dashboard-orders-hero,.product-import-tools__content{flex-direction:column}.product-import-tools__actions{justify-content:flex-start}.product-display-groups{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 640px){.dialog-backdrop{align-items:stretch;padding:12px}.dialog-panel{max-height:calc(100vh - 24px)}.product-image-preview__body{padding:16px}.product-image-preview__image{max-height:54vh}.dialog-header,.product-dialog .product-form,.product-import-dialog__body,.product-category-dialog .category-form{padding:16px}.product-display-groups{grid-template-columns:1fr}.product-display-add-dialog{padding:16px}.dialog-actions{flex-direction:column-reverse}.dialog-actions button{width:100%}.message-dialog-backdrop{padding:12px}.message-dialog-actions button{width:100%}.confirm-dialog-backdrop{padding:12px}.confirm-dialog-actions{flex-direction:column-reverse}.confirm-dialog-actions button{width:100%}.product-image-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.products-pagination,.dashboard-pagination{align-items:stretch;flex-direction:column}.dashboard-pagination__actions button{flex:1}.dashboard-table-toolbar{justify-content:flex-start}.products-pagination__actions button{flex:1}}
