\
.tgms-wrap{max-width:1100px;margin:0 auto;padding:12px}
.tgms-h{margin:0 0 12px 0;font-size:24px}
.tgms-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.tgms-card{border:1px solid rgba(0,0,0,.12);border-radius:14px;overflow:hidden;background:#fff}
.tgms-img{width:100%;height:150px;object-fit:cover;background:#f3f3f3}
.tgms-cardbody{padding:12px}
.tgms-title{font-size:18px;font-weight:700;margin-bottom:8px}
.tgms-label{display:block;font-size:12px;opacity:.8;margin-bottom:4px}
.tgms-select{width:100%;padding:8px;border-radius:10px;border:1px solid rgba(0,0,0,.18);margin-bottom:10px}
.tgms-btn{display:inline-block;padding:10px 12px;border-radius:12px;border:1px solid rgba(0,0,0,.2);background:#fff;cursor:pointer}
.tgms-btn-primary{background:#111;color:#fff;border-color:#111}
.tgms-table{width:100%;border-collapse:collapse}
.tgms-table th,.tgms-table td{border-bottom:1px solid rgba(0,0,0,.12);padding:10px;text-align:left;vertical-align:top}
.tgms-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px}
.tgms-muted{opacity:.7;font-size:12px;margin-top:4px}
.tgms-totalrow{display:flex;gap:12px;justify-content:space-between;align-items:center;margin-top:12px}
.tgms-mini{padding:6px 10px;border-radius:10px;border:1px solid rgba(0,0,0,.2);background:#fff;cursor:pointer}
.tgms-qty{display:inline-block;min-width:22px;text-align:center}
.tgms-empty{opacity:.7}


/* Forms + notices */
.tgms-form{max-width:520px}
.tgms-row{margin:10px 0}
.tgms-row label{display:block;font-size:13px;opacity:.85;margin:0 0 4px}
.tgms-row input,.tgms-row textarea{width:100%;padding:10px;border-radius:12px;border:1px solid rgba(0,0,0,.18)}
.tgms-notice{padding:10px 12px;border-radius:12px;margin:10px 0;border:1px solid rgba(0,0,0,.15)}
.tgms-ok{background:#eef9f1}
.tgms-bad{background:#fdeeee}
