*{box-sizing:border-box}html{min-height:100%;min-height:100svh;min-height:100dvh;background:linear-gradient(180deg,#eef2ff,#f8fafc 45%,#f8fafc)}html,body,#root{margin:0;width:100%}body{min-height:100%;min-height:100svh;min-height:100dvh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Arial,sans-serif;background:transparent;color:#0f172a;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}#root{min-height:100%;min-height:100svh;min-height:100dvh;display:flex;flex-direction:column}.admin-app-shell{flex:1;display:flex;flex-direction:column;min-height:100%;min-height:100svh;min-height:100dvh;padding-top:env(safe-area-inset-top,0px);padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px)}.admin-app-shell>main.container{flex:1;display:flex;flex-direction:column}.container{max-width:1140px;margin:0 auto;padding:18px;padding-bottom:calc(18px + env(safe-area-inset-bottom,0px))}.hint{color:#475569;margin-top:-6px}.mobile-topbar{display:none;align-items:center;gap:12px;margin-bottom:10px}.menu-trigger{width:44px;min-height:44px;padding:9px;border-radius:12px;display:inline-flex;flex-direction:column;justify-content:center;gap:4px}.menu-trigger span{display:block;width:18px;height:2px;background:#fff;border-radius:2px}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a6b;opacity:0;pointer-events:none;transition:opacity .18s ease;z-index:20}.drawer-overlay.open{opacity:1;pointer-events:auto}.mobile-drawer{position:fixed;top:0;left:0;height:100dvh;width:min(84vw,320px);background:#fff;border-right:1px solid #e2e8f0;transform:translate(-101%);transition:transform .22s ease;z-index:21;padding:14px 12px calc(16px + env(safe-area-inset-bottom));display:flex;flex-direction:column}.mobile-drawer.open{transform:translate(0)}.drawer-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.drawer-close{width:40px;min-height:40px;padding:0;font-size:22px;line-height:1}.drawer-list-scroll{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.drawer-list{display:grid;gap:8px;overflow:auto;flex:1;min-height:0;align-content:start}.drawer-footer{margin-top:auto;padding-top:12px;border-top:1px solid #e2e8f0;flex-shrink:0}.drawer-logout{width:100%;text-align:center;background:#fef2f2;border-color:#fecaca;color:#991b1b;font-weight:600}.drawer-logout:hover{background:#fee2e2;border-color:#fca5a5}@media (min-width: 981px){.drawer-footer{display:none}}.admin-page-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:6px}.admin-page-title{margin:0;flex:1;min-width:0}.header-logout-btn{display:none;flex-shrink:0;background:#fef2f2;border-color:#fecaca;color:#991b1b;font-weight:600;padding-left:18px;padding-right:18px}.header-logout-btn:hover{background:#fee2e2;border-color:#fca5a5}@media (min-width: 981px){.header-logout-btn{display:inline-flex;align-items:center;justify-content:center}}.drawer-item{width:100%;text-align:left;background:#f8fafc;color:#0f172a;border:1px solid #e2e8f0;box-shadow:none!important}.drawer-item.active{background:#e0e7ff;border-color:#a5b4fc;color:#312e81}.card{background:#ffffffeb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #e2e8f0;border-radius:14px;padding:16px;margin-bottom:14px;box-shadow:0 8px 24px #0f172a0f;animation:cardIn .24s ease}.clone-template-panel__title{margin:0 0 8px;font-size:1.15rem}.clone-template-panel__intro{margin:0 0 14px;line-height:1.5}.clone-template-form{display:flex;flex-direction:column;gap:14px}.clone-template-form .field-label span{font-size:13px;font-weight:600;color:#334155}.clone-template-replace{display:flex;align-items:flex-start;gap:12px;margin:0;padding:14px;border:1px solid #e2e8f0;border-radius:12px;background:#f8fafc;cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent}.clone-template-replace--on{background:#eef2ff;border-color:#c7d2fe}.clone-template-replace--disabled{opacity:.7;cursor:not-allowed}.clone-template-replace__input{width:22px;height:22px;min-height:22px!important;margin:2px 0 0;padding:0!important;flex-shrink:0;border-radius:6px;cursor:pointer}.clone-template-replace__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.clone-template-replace__title{font-weight:600;font-size:15px;line-height:1.35;color:#0f172a}.clone-template-replace__detail{font-size:13px;line-height:1.45;color:#64748b}@media (max-width: 980px){.clone-template-replace{padding:16px 14px;gap:14px}.clone-template-replace__input{width:24px;height:24px;min-height:24px!important;margin-top:3px}.clone-template-replace__title{font-size:16px}.clone-template-replace__detail{font-size:14px}}.grid{display:grid;gap:10px;margin-bottom:10px}.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}input,select,button,textarea{min-height:40px;border:1px solid #cbd5e1;border-radius:10px;padding:8px 12px;font-size:14px;font-family:inherit}textarea{min-height:72px}input:focus,select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f126}button{background:linear-gradient(135deg,#111827,#1e293b);color:#fff;cursor:pointer;transition:transform .16s ease,opacity .16s ease,box-shadow .16s ease}button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 16px #0f172a33}button:active:not(:disabled){transform:translateY(0)}button:disabled{opacity:.65;cursor:not-allowed}.actions{display:flex;gap:8px;margin:8px 0;flex-wrap:wrap}.table-toolbar{display:grid;gap:8px;grid-template-columns:1.2fr 1fr 1fr;margin-bottom:10px}.reports-filters{display:grid;gap:10px;grid-template-columns:repeat(4,minmax(0,1fr));margin:10px 0}.reports-filters label{display:grid;gap:6px;font-size:12px;color:#64748b}.row-actions{display:flex;gap:6px;flex-wrap:wrap}.row-actions button{width:auto;min-height:34px;padding:6px 10px}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:10px}table{width:100%;border-collapse:separate;border-spacing:0;overflow:hidden;border-radius:10px}th,td{border-bottom:1px solid #e2e8f0;text-align:left;padding:10px;font-size:13px;background:#fff}th{background:#f8fafc;color:#475569}.status{background:#0f172a;color:#d1fae5;border-radius:10px;padding:10px;min-height:56px;overflow:auto}.muted{color:#64748b}.category-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:#eef2ff;border:1px solid #c7d2fe;color:#3730a3;font-size:12px;font-weight:600}.status-pill{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700;min-width:88px}.status-pill.on{background:#dcfce7;border:1px solid #86efac;color:#166534}.status-pill.off{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b}.product-name{font-weight:700}.empty-state{padding:14px;text-align:center;color:#64748b}.metrics-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:10px 0}.metric-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:10px;display:grid;gap:4px}.metric-card small{color:#64748b;font-size:12px}.metric-card strong{font-size:18px;line-height:1.2}@keyframes cardIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 980px){.grid.three,.grid.four,.grid.two{grid-template-columns:1fr}.container{padding:12px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px))}.card{padding:14px;border-radius:12px}.mobile-topbar{display:flex}button,input,select{width:100%;min-height:44px}.table-toolbar{grid-template-columns:1fr}.reports-filters,.metrics-grid{grid-template-columns:1fr 1fr}.actions{display:grid;grid-template-columns:1fr 1fr}.actions button{width:100%}.row-actions{display:grid;grid-template-columns:1fr}.row-actions button{width:100%;min-height:40px}}@media (max-width: 720px){.metrics-grid,.reports-filters,.actions{grid-template-columns:1fr}th{display:none}table,tbody,tr,td{display:block;width:100%}tr{border:1px solid #e2e8f0;border-radius:10px;margin-bottom:10px;overflow:hidden}td{border-bottom:1px solid #f1f5f9;padding:10px 12px}td:last-child{border-bottom:none}td:before{content:attr(data-label);display:block;font-size:11px;color:#64748b;margin-bottom:4px;text-transform:uppercase;letter-spacing:.04em}.status-pill{min-width:0}}.field-label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#475569}.field-label select,.field-label input{font-size:14px}.product-photo-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.product-thumb-wrap{display:inline-flex;border-radius:8px;overflow:hidden;border:1px solid #e2e8f0;background:#f8fafc}img.product-thumb{width:56px;height:56px;object-fit:cover;display:block}img.product-thumb-table{width:44px;height:44px;object-fit:cover;border-radius:6px;border:1px solid #e2e8f0;vertical-align:middle}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.auth-wrap{max-width:440px}.auth-card{display:flex;flex-direction:column;gap:14px;padding:20px}.auth-error{color:#b91c1c;margin:0;font-size:14px}.auth-mode-toggle{display:flex;gap:8px;margin-bottom:12px}.auth-mode-toggle button{flex:1;padding:10px 12px;border-radius:10px;border:1px solid #cbd5e1;background:#fff;cursor:pointer;font-weight:600;color:#475569}.auth-mode-toggle button.active{border-color:#6366f1;background:#eef2ff;color:#312e81}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-textarea-full{grid-column:1 / -1;min-height:72px;resize:vertical}.platform-page{display:flex;flex-direction:column;gap:16px}@media (min-width: 840px){.platform-page--split{display:grid;grid-template-columns:minmax(0,380px) minmax(0,1fr);gap:18px;align-items:start}}.platform-section-title{margin:0 0 8px;font-size:1.15rem}.platform-hint-tight{margin-top:0;margin-bottom:12px;line-height:1.45}.platform-list-head{margin-bottom:4px}.btn-refresh{flex-shrink:0;white-space:nowrap}.m-touch .field-label select,.m-touch .field-label input{width:100%;min-height:48px;font-size:16px;border-radius:12px;padding:10px 14px}.m-touch .field-label span{font-size:13px;font-weight:600;color:#334155}.btn-tall{min-height:48px!important;padding:12px 16px!important;font-size:16px!important;border-radius:12px!important}.btn-block{width:100%;display:inline-flex;align-items:center;justify-content:center}.btn-secondary{background:#fff!important;color:#0f172a!important;border:1px solid #cbd5e1!important;box-shadow:none!important}.btn-secondary:hover:not(:disabled){background:#f8fafc!important}.row-between{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:10px}.stack-form,.entity-stack{display:flex;flex-direction:column;gap:12px}.entity-card{border:1px solid #e2e8f0;border-radius:14px;padding:14px 14px 12px;background:#f8fafc}.entity-card__head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}.entity-id{font-weight:700;color:#0f172a;font-size:15px}.entity-badge{font-size:12px;line-height:1.3;padding:6px 10px;border-radius:999px;background:#e0e7ff;color:#312e81;text-align:right;max-width:68%;word-break:break-word}.entity-badge--mono{font-family:ui-monospace,monospace;max-width:72%}.entity-dl{display:grid;grid-template-columns:minmax(0,100px) 1fr;gap:8px 12px;margin:0;font-size:15px}.entity-dl dt{color:#64748b;margin:0;font-weight:500}.entity-dl dd{margin:0;word-break:break-word;color:#0f172a}.entity-card__foot{margin-top:12px;padding-top:12px;border-top:1px solid #e2e8f0}.entity-inline-form,.btn-row{display:flex;flex-direction:column;gap:10px}@media (min-width: 480px){.btn-row{flex-direction:row}.btn-row .btn-block{flex:1;width:auto}}.license-banner{background:#fef3c7;border:1px solid #fcd34d;border-radius:14px;padding:14px;margin-bottom:14px;display:flex;flex-direction:column;gap:12px}.license-banner__text{display:flex;flex-direction:column;gap:8px}.license-code{display:block;font-size:14px;line-height:1.4;word-break:break-all;padding:10px;background:#ffffffd9;border-radius:10px;border:1px solid #fde68a}.inline-code{font-family:ui-monospace,monospace;font-size:12px;background:#f1f5f9;padding:2px 6px;border-radius:6px;word-break:break-all}.license-sublist{margin-top:12px;padding-top:12px;border-top:1px solid #e2e8f0}.license-sublist__title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#64748b;margin-bottom:8px}.license-sublist__ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.license-sublist__item{display:flex;flex-direction:column;gap:8px;padding:12px;border-radius:12px;background:#fff;border:1px solid #e2e8f0}.license-sublist__meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:14px}.license-sublist__label{color:#64748b;font-size:13px}.pill{font-size:12px;padding:4px 10px;border-radius:999px;font-weight:600}.pill-on{background:#dcfce7;color:#166534}.pill-off{background:#f1f5f9;color:#475569}.btn-compact{align-self:flex-start;width:100%;max-width:280px}.license-key-block{margin-top:6px;display:flex;flex-direction:column;gap:8px}.license-key-block .license-code{font-size:13px}.license-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.license-actions .btn-tall{flex:1 1 auto;min-width:120px}@media (min-width: 480px){.license-actions .btn-tall{flex:0 1 auto;min-width:0}}@media (min-width: 480px){.btn-compact{width:auto}}.role-perm-card{padding-bottom:8px}.role-perm-role-field{margin-bottom:12px}.perm-tiles-scroll{max-height:min(50vh,400px);overflow-y:auto;-webkit-overflow-scrolling:touch;margin:0 -4px;padding:4px;border-radius:12px}.perm-tiles{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.perm-tile{display:flex;align-items:flex-start;gap:12px;padding:14px;border-radius:14px;border:1px solid #e2e8f0;background:#fff;cursor:pointer;min-height:52px;box-sizing:border-box}.perm-tile:focus-within{border-color:#a5b4fc;box-shadow:0 0 0 1px #6366f133}.perm-tile__input{width:22px;height:22px;min-height:22px!important;margin-top:2px;flex-shrink:0;accent-color:#4f46e5;cursor:pointer}.perm-tile__body{display:flex;flex-direction:column;gap:4px;min-width:0}.perm-tile__code{font-family:ui-monospace,monospace;font-size:12px;color:#64748b;word-break:break-all}.perm-tile__label{font-size:15px;line-height:1.35;color:#0f172a}.platform-sticky-footer{position:sticky;bottom:calc(-1*env(safe-area-inset-bottom,0px));margin:16px -16px -16px;padding:12px 16px calc(14px + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:10px;background:linear-gradient(180deg,#f8fafc00,#fffffff7 18%);border-top:1px solid #e2e8f0;border-radius:14px 14px 0 0}@media (min-width: 560px){.platform-sticky-footer{flex-direction:row;flex-wrap:wrap}.platform-sticky-footer .btn-block{width:auto;flex:1;min-width:160px}}@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}
